336 lines
11 KiB
TypeScript
336 lines
11 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,
|
|
enterEditInfo,
|
|
renameDevice,
|
|
changeDeviceRoom,
|
|
scrollToAndTap,
|
|
waitForSource,
|
|
navigateToFirmwarePage,
|
|
checkFirmwareVersion,
|
|
navigateToDeviceInfo,
|
|
getDeviceInfo,
|
|
} 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('lock', 'LOCK_DEVICE');
|
|
|
|
describe('Lock Settings - 设备设置页', () => {
|
|
let driver: DeviceDriver;
|
|
let reporter: TestReporter;
|
|
|
|
beforeAll(async () => {
|
|
driver = createDriver();
|
|
await driver.createSession();
|
|
reporter = new TestReporter('Lock_Settings', 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 {
|
|
const entered = await enterDeviceSettings(driver, deviceName);
|
|
expect(entered).toBe(true);
|
|
const editOpened = await enterEditInfo(driver);
|
|
expect(editOpened).toBe(true);
|
|
|
|
const renamed = await renameDevice(driver, 'TestLock', 'save');
|
|
expect(renamed).toBe(true);
|
|
|
|
let source = await driver.getSource();
|
|
expect(source).toContain('TestLock');
|
|
console.log('名称已修改为: TestLock');
|
|
|
|
// Restore
|
|
const restored = await renameDevice(driver, deviceName, 'save');
|
|
expect(restored).toBe(true);
|
|
|
|
source = await driver.getSource();
|
|
expect(source).toContain(deviceName);
|
|
console.log('名称还原: true');
|
|
|
|
reporter.record('修改设备名称-保存还原', 'PASS', Date.now() - start, `${deviceName} → TestLock → ${deviceName} (还原=true)`);
|
|
} 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 editOpened = await enterEditInfo(driver);
|
|
expect(editOpened).toBe(true);
|
|
|
|
const result = await changeDeviceRoom(driver);
|
|
expect(result.success).toBe(true);
|
|
console.log('可选房间数:', result.roomCount);
|
|
|
|
// Restore
|
|
await changeDeviceRoom(driver);
|
|
|
|
reporter.record('修改设备房间', 'PASS', Date.now() - start, `Select Room页面, ${result.roomCount}个房间可选`);
|
|
} catch (e: any) {
|
|
const ss = await driver.screenshot().catch(() => '');
|
|
reporter.record('修改设备房间', 'FAIL', Date.now() - start, e.message, ss);
|
|
throw e;
|
|
}
|
|
});
|
|
|
|
it('查看设备FAQ', async () => {
|
|
const start = Date.now();
|
|
try {
|
|
const entered = await enterDeviceSettings(driver, deviceName);
|
|
expect(entered).toBe(true);
|
|
|
|
const tapped = await scrollToAndTap(driver, 'FAQ');
|
|
expect(tapped).toBe(true);
|
|
await sleep(3000);
|
|
|
|
const source = await driver.getSource();
|
|
const hasFAQ = source.includes('FAQ') || source.includes('Help') ||
|
|
source.includes('Question') || source.includes('Support');
|
|
expect(hasFAQ).toBe(true);
|
|
|
|
reporter.record('查看设备FAQ', 'PASS', Date.now() - start, 'FAQ页面打开成功');
|
|
} catch (e: any) {
|
|
const ss = await driver.screenshot().catch(() => '');
|
|
reporter.record('查看设备FAQ', '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 navOk = await navigateToFirmwarePage(driver);
|
|
expect(navOk).toBe(true);
|
|
await sleep(3000);
|
|
|
|
const version = await checkFirmwareVersion(driver);
|
|
const detail = `固件版本=${version}`;
|
|
console.log(detail);
|
|
expect(version).not.toBe('unknown');
|
|
|
|
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 {
|
|
const entered = await enterDeviceSettings(driver, deviceName);
|
|
expect(entered).toBe(true);
|
|
|
|
const navOk = await navigateToDeviceInfo(driver);
|
|
expect(navOk).toBe(true);
|
|
await sleep(3000);
|
|
|
|
const info = await getDeviceInfo(driver);
|
|
const detail = `BLE MAC=${info.macAddress || 'not found'}`;
|
|
console.log(detail);
|
|
expect(info.macAddress).toBeDefined();
|
|
|
|
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('NFC页面', async () => {
|
|
const start = Date.now();
|
|
try {
|
|
const entered = await enterDeviceSettings(driver, deviceName);
|
|
expect(entered).toBe(true);
|
|
|
|
const tapped = await scrollToAndTap(driver, 'NFC');
|
|
expect(tapped).toBe(true);
|
|
await sleep(2000);
|
|
|
|
const source = await driver.getSource();
|
|
const hasNFC = source.includes('NFC') || source.includes('Tag') || source.includes('Write');
|
|
expect(hasNFC).toBe(true);
|
|
|
|
reporter.record('NFC页面', 'PASS', Date.now() - start, 'NFC页面打开成功');
|
|
} catch (e: any) {
|
|
const ss = await driver.screenshot().catch(() => '');
|
|
reporter.record('NFC页面', '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);
|
|
|
|
// Find the Indicator Light switch
|
|
const indicatorEl = await driver.findElementRaw('name', 'Indicator Light') ||
|
|
await driver.findElementRaw('name', 'LED');
|
|
expect(indicatorEl).not.toBeNull();
|
|
|
|
// Find the switch/toggle next to it
|
|
const rect = await driver.getElementRect(indicatorEl!);
|
|
// Tap the switch area (right side of the row)
|
|
await driver.tap(rect.x + rect.width + 50, rect.y + rect.height / 2);
|
|
await sleep(3000);
|
|
|
|
// Toggle back
|
|
await driver.tap(rect.x + rect.width + 50, rect.y + rect.height / 2);
|
|
await sleep(3000);
|
|
|
|
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);
|
|
|
|
// Find notification switch
|
|
const notifEl = await driver.findElementRaw('name', 'Notification') ||
|
|
await driver.findElementRaw('name', 'Remote Unlock Notification') ||
|
|
await driver.findElementRaw('name', 'Alert');
|
|
|
|
if (!notifEl) {
|
|
// Scroll to find it
|
|
await scrollToAndTap(driver, 'Notification');
|
|
await sleep(2000);
|
|
} else {
|
|
const rect = await driver.getElementRect(notifEl);
|
|
// Tap the switch area (right side of the row)
|
|
await driver.tap(rect.x + rect.width + 50, rect.y + rect.height / 2);
|
|
await sleep(3000);
|
|
|
|
// Toggle back
|
|
await driver.tap(rect.x + rect.width + 50, rect.y + rect.height / 2);
|
|
await sleep(3000);
|
|
}
|
|
|
|
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);
|
|
|
|
// Find alert switch for door not closed
|
|
const alertEl = await driver.findElementRaw('name', 'Alert') ||
|
|
await driver.findElementRaw('name', 'Door Not Closed Alert') ||
|
|
await driver.findElementRaw('name', 'Unclosed Alert');
|
|
|
|
if (!alertEl) {
|
|
const tapped = await scrollToAndTap(driver, 'Alert') ||
|
|
await scrollToAndTap(driver, 'Door Not Closed');
|
|
expect(tapped).toBe(true);
|
|
await sleep(2000);
|
|
} else {
|
|
const rect = await driver.getElementRect(alertEl);
|
|
// Tap the switch area
|
|
await driver.tap(rect.x + rect.width + 50, rect.y + rect.height / 2);
|
|
await sleep(3000);
|
|
|
|
// Toggle back
|
|
await driver.tap(rect.x + rect.width + 50, rect.y + rect.height / 2);
|
|
await sleep(3000);
|
|
}
|
|
|
|
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);
|
|
|
|
// Find Auto Lock switch
|
|
const autoLockEl = await driver.findElementRaw('name', 'Auto Lock') ||
|
|
await driver.findElementRaw('name', 'Auto-Lock');
|
|
|
|
if (!autoLockEl) {
|
|
const tapped = await scrollToAndTap(driver, 'Auto Lock') ||
|
|
await scrollToAndTap(driver, 'Auto-Lock');
|
|
expect(tapped).toBe(true);
|
|
await sleep(2000);
|
|
} else {
|
|
const rect = await driver.getElementRect(autoLockEl);
|
|
// Tap the switch area
|
|
await driver.tap(rect.x + rect.width + 50, rect.y + rect.height / 2);
|
|
await sleep(3000);
|
|
}
|
|
|
|
// Verify auto lock state
|
|
const source = await driver.getSource();
|
|
const hasAutoLock = source.includes('Auto Lock') || source.includes('Auto-Lock');
|
|
expect(hasAutoLock).toBe(true);
|
|
|
|
// Toggle back if we toggled on
|
|
if (autoLockEl) {
|
|
const rect = await driver.getElementRect(autoLockEl);
|
|
await driver.tap(rect.x + rect.width + 50, rect.y + rect.height / 2);
|
|
await sleep(3000);
|
|
}
|
|
|
|
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;
|
|
}
|
|
});
|
|
});
|