96 lines
3.3 KiB
TypeScript
96 lines
3.3 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('plug', 'PLUG_DEVICE');
|
|
|
|
describe('Plug Logs - 设备日志验证', () => {
|
|
let driver: DeviceDriver;
|
|
let reporter: TestReporter;
|
|
|
|
beforeAll(async () => {
|
|
driver = createDriver();
|
|
await driver.createSession();
|
|
reporter = new TestReporter('Plug_Logs', driver.platform.toUpperCase());
|
|
});
|
|
|
|
beforeEach(async () => {
|
|
await driver.dismissPopupIfPresent();
|
|
await driver.goBackToHomepage();
|
|
await driver.dismissPopupIfPresent();
|
|
});
|
|
|
|
afterAll(async () => {
|
|
reporter.generate();
|
|
await driver.destroySession();
|
|
});
|
|
|
|
it('开关插座产生日志', async () => {
|
|
const start = Date.now();
|
|
try {
|
|
// Find and tap the plug card power button to produce 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}卡片`);
|
|
|
|
const rect = await driver.getElementRect(el);
|
|
// Tap power button on card (right side)
|
|
await driver.tap(rect.x + rect.width - 30, rect.y + rect.height / 2);
|
|
await sleep(10000);
|
|
|
|
// Toggle back to restore state
|
|
await driver.tap(rect.x + rect.width - 30, rect.y + rect.height / 2);
|
|
await sleep(5000);
|
|
|
|
console.log('插座开关操作完成, 日志应已产生');
|
|
reporter.record('开关插座产生日志', 'PASS', Date.now() - start, '开关操作已执行, 等待日志生成');
|
|
} 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 entered = await enterDeviceSettings(driver, deviceName);
|
|
expect(entered).toBe(true);
|
|
|
|
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('Turn on') || source.includes('Turn off') ||
|
|
source.includes('App Control') || source.includes('Ran successfully') ||
|
|
source.includes('No more data') || source.includes('No logs');
|
|
|
|
const detail = `Logs页面加载成功, 有操作记录=${hasEntries}`;
|
|
console.log(detail);
|
|
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;
|
|
}
|
|
});
|
|
});
|