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