import { describe, it, beforeAll, afterAll, expect } from 'vitest'; import { DeviceDriver } from '../../drivers/types'; import { createDriver } from '../../drivers/factory'; import { TestReporter } from '../../utils/test-reporter'; import { getDeviceName } from '../../config/device.config'; import { sleep, addDeviceViaBLE, isDeviceOnHomepage, removeDeviceFromAccount, } from '../../utils/common'; import * as dotenv from 'dotenv'; import * as path from 'path'; dotenv.config({ path: path.resolve(__dirname, '../../.env') }); const deviceName = getDeviceName('bot', 'BOT_DEVICE'); describe('Bot Connect - 添加Bot设备', () => { let driver: DeviceDriver; let reporter: TestReporter; beforeAll(async () => { driver = createDriver(); await driver.createSession(); reporter = new TestReporter('Bot_Connect', driver.platform.toUpperCase()); }); afterAll(async () => { reporter.generate(); await driver.destroySession(); }); it(`[ONES:15968] 通过BLE添加${deviceName}设备`, async () => { const start = Date.now(); try { const alreadyExists = await isDeviceOnHomepage(driver, deviceName); if (alreadyExists) { console.log(`${deviceName}已在首页,跳过重新添加`); reporter.record(`[P0][ONES:15968] 添加${deviceName}`, 'PASS', Date.now() - start, `${deviceName}已存在, 无需重新添加`); return; } const result = await addDeviceViaBLE(driver, { categoryName: 'Bot', deviceKeyword: deviceName, scanTimeout: 30000, connectionKeywords: [ 'Initial Setup', 'Start Using', 'Done', 'added successfully', 'Got it', 'cloud service', 'Pick a room', 'Display Type', ], }); expect(result).toBe(true); const elapsed = ((Date.now() - start) / 1000).toFixed(1); reporter.record(`[P0][ONES:15968] 添加${deviceName}`, 'PASS', Date.now() - start, `${deviceName}添加成功, 耗时${elapsed}s`); } catch (e: any) { const ss = await driver.screenshot().catch(() => ''); reporter.record(`[P0][ONES:15968] 添加${deviceName}`, 'FAIL', Date.now() - start, e.message, ss); throw e; } }); });