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; } }); });