AI_UIAutomation/tests/curtain/curtain_logs.test.ts

95 lines
3.1 KiB
TypeScript

import { describe, it, beforeAll, afterAll, beforeEach, expect } from 'vitest';
import { DeviceDriver } from '../../drivers/types';
import { createDriver } from '../../drivers/factory';
import { TestReporter } from '../../utils/test-reporter';
import {
sleep,
enterDeviceSettings,
scrollToAndTap,
waitForSource,
} from '../../utils/common';
import { getDeviceName } from '../../config/device.config';
import * as dotenv from 'dotenv';
import * as path from 'path';
dotenv.config({ path: path.resolve(__dirname, '../../.env') });
const deviceName = getDeviceName('curtain', 'CURTAIN_DEVICE');
describe('Curtain Logs - 操作日志验证', () => {
let driver: DeviceDriver;
let reporter: TestReporter;
beforeAll(async () => {
driver = createDriver();
await driver.createSession();
reporter = new TestReporter('Curtain_Logs', driver.platform.toUpperCase());
});
beforeEach(async () => {
await driver.dismissPopupIfPresent();
await driver.goBackToHomepage();
await sleep(500);
await driver.dismissPopupIfPresent();
});
afterAll(async () => {
reporter.generate();
await driver.destroySession();
});
it('操作后查看历史日志', async () => {
const start = Date.now();
try {
// First, perform an Open action to generate a log entry
let el = await driver.findElementRaw('name', deviceName);
if (!el) {
await driver.scrollDown(250);
await sleep(1000);
el = await driver.findElementRaw('name', deviceName);
}
if (!el) throw new Error(`找不到${deviceName}卡片`);
await driver.tapElement(el);
await sleep(2000);
// Tap Open to generate log
const openBtn = await driver.findElementRaw('name', 'Open');
if (openBtn) {
await driver.tapElement(openBtn);
await sleep(5000);
}
// Go back to homepage and enter settings
await driver.goBackToHomepage();
await sleep(1000);
const entered = await enterDeviceSettings(driver, deviceName);
expect(entered).toBe(true);
// Navigate to Logs
const tapped = await scrollToAndTap(driver, 'Logs');
expect(tapped).toBe(true);
await waitForSource(driver, 'Logs', 5000);
const source = await driver.getSource();
expect(source).toContain('Logs');
const hasEntries = source.includes('Open') || source.includes('Close') ||
source.includes('Pause') || source.includes('App Control') ||
source.includes('Ran successfully') || source.includes('Manual') ||
source.includes('May') || source.includes('Jun') ||
source.includes('No more data') || source.includes('Today');
const detail = `Logs页面加载成功, 有操作记录=${hasEntries}`;
console.log(detail);
expect(hasEntries).toBe(true);
reporter.record('操作后查看历史日志', 'PASS', Date.now() - start, detail);
} catch (e: any) {
const ss = await driver.screenshot().catch(() => '');
reporter.record('操作后查看历史日志', 'FAIL', Date.now() - start, e.message, ss);
throw e;
}
});
});