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('curtain', 'CURTAIN_DEVICE'); describe('Curtain Logs - 操作日志验证', () => { let driver: DeviceDriver; let reporter: TestReporter; beforeAll(async () => { driver = createDriver(); await driver.createSession(); reporter = new TestReporter('Curtain_Logs', driver.platform.toUpperCase()); }); beforeEach(async () => { await driver.dismissPopupIfPresent(); await driver.goBackToHomepage(); await sleep(500); await driver.dismissPopupIfPresent(); }); afterAll(async () => { reporter.generate(); await driver.destroySession(); }); it('操作后查看历史日志', async () => { const start = Date.now(); try { // First, perform an Open action to generate 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}卡片`); await driver.tapElement(el); await sleep(2000); // Tap Open to generate log const openBtn = await driver.findElementRaw('name', 'Open'); if (openBtn) { await driver.tapElement(openBtn); await sleep(5000); } // Go back to homepage and enter settings await driver.goBackToHomepage(); await sleep(1000); const entered = await enterDeviceSettings(driver, deviceName); expect(entered).toBe(true); // Navigate to Logs 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('Open') || source.includes('Close') || source.includes('Pause') || source.includes('App Control') || source.includes('Ran successfully') || source.includes('Manual') || source.includes('May') || source.includes('Jun') || source.includes('No more data') || source.includes('Today'); const detail = `Logs页面加载成功, 有操作记录=${hasEntries}`; console.log(detail); expect(hasEntries).toBe(true); 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; } }); });