154 lines
5.4 KiB
TypeScript
154 lines
5.4 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,
|
|
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('sensor', 'SENSOR_DEVICE');
|
|
|
|
// 必测项控制锚点: Contact Sensor 功能页显示开关状态 BLE 15975#A8C4BsCm / WiFi 15974#JKSgHHbC
|
|
import { onesCtrl } from "../../utils/common";
|
|
const CTRL_SENSOR = onesCtrl("sensor", deviceName);
|
|
|
|
describe('Sensor Control - 功能页操作', () => {
|
|
let driver: DeviceDriver;
|
|
let reporter: TestReporter;
|
|
|
|
beforeAll(async () => {
|
|
driver = createDriver();
|
|
await driver.createSession();
|
|
reporter = new TestReporter('Sensor_Control', driver.platform.toUpperCase());
|
|
});
|
|
|
|
beforeEach(async () => {
|
|
await driver.dismissPopupIfPresent();
|
|
await driver.goBackToHomepage();
|
|
await driver.dismissPopupIfPresent();
|
|
});
|
|
|
|
afterAll(async () => {
|
|
reporter.generate();
|
|
await driver.destroySession();
|
|
});
|
|
|
|
async function enterControlPage(): Promise<void> {
|
|
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(3000);
|
|
}
|
|
|
|
it('功能页显示', async () => {
|
|
const start = Date.now();
|
|
try {
|
|
await enterControlPage();
|
|
|
|
const source = await driver.getSource();
|
|
// Verify control page elements: detection status, indicator light, etc.
|
|
const hasDetectionStatus = source.includes('No movement') || source.includes('Motion detected') ||
|
|
source.includes('Open') || source.includes('Closed') || source.includes('Not detected') ||
|
|
source.includes('Detected');
|
|
const hasIndicatorLight = source.includes('Indicator Light') || source.includes('indicator');
|
|
|
|
const detail = `功能页加载成功, 检测状态=${hasDetectionStatus}, 指示灯选项=${hasIndicatorLight}`;
|
|
console.log(detail);
|
|
expect(hasDetectionStatus || hasIndicatorLight).toBe(true);
|
|
|
|
reporter.record(`${CTRL_SENSOR} 功能页显示`, 'PASS', Date.now() - start, detail);
|
|
} catch (e: any) {
|
|
const ss = await driver.screenshot().catch(() => '');
|
|
reporter.record(`${CTRL_SENSOR} 功能页显示`, 'FAIL', Date.now() - start, e.message, ss);
|
|
throw e;
|
|
}
|
|
});
|
|
|
|
it('打开/关闭指示灯', async () => {
|
|
const start = Date.now();
|
|
try {
|
|
await enterControlPage();
|
|
|
|
// Find Indicator Light switch
|
|
let source = await driver.getSource();
|
|
const indicatorEl = await driver.findElementRaw('name', 'Indicator Light') ||
|
|
await driver.findElementRaw('name', 'indicator light');
|
|
|
|
if (!indicatorEl) {
|
|
// Try scrolling to find it
|
|
const tapped = await scrollToAndTap(driver, 'Indicator Light');
|
|
expect(tapped).toBe(true);
|
|
} else {
|
|
await driver.tapElement(indicatorEl);
|
|
}
|
|
await sleep(3000);
|
|
|
|
// Verify state changed
|
|
source = await driver.getSource();
|
|
const afterFirstTap = source.includes('ON') || source.includes('Off') || source.includes('Indicator Light');
|
|
|
|
// Tap again to restore
|
|
const indicatorEl2 = await driver.findElementRaw('name', 'Indicator Light') ||
|
|
await driver.findElementRaw('name', 'indicator light');
|
|
if (indicatorEl2) {
|
|
await driver.tapElement(indicatorEl2);
|
|
await sleep(3000);
|
|
}
|
|
|
|
source = await driver.getSource();
|
|
const detail = `指示灯切换成功, 页面元素=${afterFirstTap}`;
|
|
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;
|
|
}
|
|
});
|
|
|
|
it('日志显示', async () => {
|
|
const start = Date.now();
|
|
try {
|
|
await enterControlPage();
|
|
|
|
// Find Logs area or scroll to it
|
|
const tapped = await scrollToAndTap(driver, 'Logs');
|
|
if (!tapped) {
|
|
// Try alternative text
|
|
const altTapped = await scrollToAndTap(driver, 'History') ||
|
|
await scrollToAndTap(driver, 'Log');
|
|
expect(altTapped).toBe(true);
|
|
}
|
|
await waitForSource(driver, 'Logs', 5000);
|
|
|
|
const source = await driver.getSource();
|
|
const hasLogEntries = source.includes('Logs') || source.includes('History') ||
|
|
source.includes('Open') || source.includes('Closed') || source.includes('Motion detected') ||
|
|
source.includes('No movement') || source.includes('No more data') || source.includes('No logs');
|
|
|
|
const detail = `Logs页面加载成功, 有日志记录=${hasLogEntries}`;
|
|
console.log(detail);
|
|
expect(hasLogEntries).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;
|
|
}
|
|
});
|
|
});
|