121 lines
3.7 KiB
TypeScript
121 lines
3.7 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,
|
|
enterDeviceSettings,
|
|
renameDevice,
|
|
changeDeviceRoom,
|
|
navigateToTimerPage,
|
|
addTimer,
|
|
deleteAllTimers,
|
|
navigateToFirmwarePage,
|
|
checkFirmwareVersion,
|
|
navigateToDeviceInfo,
|
|
getDeviceInfo,
|
|
scrollToAndTap,
|
|
waitForSource,
|
|
enterEditInfo,
|
|
addDeviceViaBLE,
|
|
isDeviceOnHomepage,
|
|
createScene,
|
|
executeSceneFromHomepage,
|
|
deleteScene,
|
|
ensureHomeTab,
|
|
} from '../../utils/common';
|
|
import * as dotenv from 'dotenv';
|
|
import * as path from 'path';
|
|
|
|
dotenv.config({ path: path.resolve(__dirname, '../../.env') });
|
|
|
|
const deviceName = getDeviceName('fan', 'FAN_DEVICE');
|
|
|
|
describe('Fan Scene - 手动场景', () => {
|
|
let driver: DeviceDriver;
|
|
let reporter: TestReporter;
|
|
const sceneName = `FanScene_${Date.now().toString().slice(-4)}`;
|
|
|
|
beforeAll(async () => {
|
|
driver = createDriver();
|
|
await driver.createSession();
|
|
reporter = new TestReporter('Fan_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('创建手动场景', async () => {
|
|
const start = Date.now();
|
|
try {
|
|
const created = await createScene(driver, {
|
|
name: sceneName,
|
|
deviceKeyword: deviceName,
|
|
action: 'Turns on',
|
|
});
|
|
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 on, 首页=${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(5000);
|
|
console.log('场景执行完成:', sceneName);
|
|
|
|
reporter.record('执行手动场景', 'PASS', Date.now() - start, `Scene "${sceneName}" 执行成功`);
|
|
} 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 {
|
|
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;
|
|
}
|
|
});
|
|
});
|