131 lines
4.2 KiB
TypeScript
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;
|
|
}
|
|
});
|
|
});
|