AI_UIAutomation/tests/bot/bot_scene.test.ts

131 lines
4.2 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 { getDeviceName } from '../../config/device.config';
import {
sleep,
ensureHomeTab,
createScene,
executeSceneFromHomepage,
deleteScene,
verifySceneInLogs,
navigateToManageScenes,
sourceContains,
} from '../../utils/common';
import * as dotenv from 'dotenv';
import * as path from 'path';
dotenv.config({ path: path.resolve(__dirname, '../../.env') });
const deviceName = getDeviceName('bot', 'BOT_DEVICE');
describe('Bot Scene - 手动场景', () => {
let driver: DeviceDriver;
let reporter: TestReporter;
const sceneName = `SceneTest_${Date.now().toString().slice(-4)}`;
beforeAll(async () => {
driver = createDriver();
await driver.createSession();
reporter = new TestReporter('Bot_Scene', driver.platform.toUpperCase());
});
beforeEach(async () => {
await driver.dismissPopupIfPresent();
await driver.goBackToHomepage();
await driver.dismissPopupIfPresent();
});
afterAll(async () => {
try {
await driver.goBackToHomepage();
await deleteScene(driver, sceneName);
} catch (_) { /* scene may already be deleted */ }
reporter.generate();
await driver.destroySession();
});
it('创建手动场景 - Bot Turns off', async () => {
const start = Date.now();
try {
const created = await createScene(driver, {
name: sceneName,
deviceKeyword: deviceName,
action: 'Turns off',
});
expect(created).toBe(true);
const source = await driver.getSource();
const hasScene = source.includes(sceneName);
console.log('场景已创建:', sceneName, '在首页可见:', hasScene);
reporter.record('创建手动场景', 'PASS', Date.now() - start, `创建"${sceneName}", Turns off, 首页=${hasScene}`);
} catch (e: any) {
const ss = await driver.screenshot().catch(() => '');
reporter.record('创建手动场景', 'FAIL', Date.now() - start, e.message, ss);
throw e;
}
});
it('执行手动场景并验证执行结果', async () => {
const start = Date.now();
try {
await ensureHomeTab(driver);
const executed = await executeSceneFromHomepage(driver, sceneName);
expect(executed).toBe(true);
await sleep(8000);
await driver.goBackToHomepage();
const hasRecord = await verifySceneInLogs(driver, sceneName);
console.log('执行记录:', hasRecord);
expect(hasRecord).toBe(true);
reporter.record('执行手动场景', 'PASS', Date.now() - start, `Scene执行成功, 日志有记录=${hasRecord}`);
} catch (e: any) {
const ss = await driver.screenshot().catch(() => '');
reporter.record('执行手动场景', 'FAIL', Date.now() - start, e.message, ss);
throw e;
}
});
it('在Manage Scenes中验证场景存在', async () => {
const start = Date.now();
try {
const navigated = await navigateToManageScenes(driver);
expect(navigated).toBe(true);
const source = await driver.getSource();
expect(source).toContain(sceneName);
console.log('Manage Scenes验证通过');
reporter.record('Manage Scenes验证', 'PASS', Date.now() - start, `"${sceneName}"存在`);
} catch (e: any) {
const ss = await driver.screenshot().catch(() => '');
reporter.record('Manage Scenes验证', 'FAIL', Date.now() - start, e.message, ss);
throw e;
}
});
it('删除手动场景', async () => {
const start = Date.now();
try {
const deleted = await deleteScene(driver, sceneName);
expect(deleted).toBe(true);
await driver.goBackToHomepage();
await sleep(500);
const source = await driver.getSource();
const sceneGone = !source.includes(sceneName);
console.log('场景已删除:', sceneGone);
reporter.record('删除手动场景', 'PASS', Date.now() - start, `删除"${sceneName}", gone=${sceneGone}`);
} catch (e: any) {
const ss = await driver.screenshot().catch(() => '');
reporter.record('删除手动场景', 'FAIL', Date.now() - start, e.message, ss);
throw e;
}
});
});