AI_UIAutomation/tests/meter/meter_control.test.ts

156 lines
5.3 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,
} 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('meter', 'METER_DEVICE');
// 必测项: meter 控制步(报警/校正)在此文件无对应用例,跳过;切换单位对应 feature 用例 74078(case 级,无协议)
const FEAT_UNIT = '[P0][ONES:74078]';
describe('Meter Control - 功能页操作', () => {
let driver: DeviceDriver;
let reporter: TestReporter;
beforeAll(async () => {
driver = createDriver();
await driver.createSession();
reporter = new TestReporter('Meter_Control', driver.platform.toUpperCase());
});
beforeEach(async () => {
await driver.dismissPopupIfPresent();
await driver.goBackToHomepage();
await driver.dismissPopupIfPresent();
});
afterAll(async () => {
reporter.generate();
await driver.destroySession();
});
async function enterMeterControl(): Promise<void> {
const el = await driver.findElementRaw('name', deviceName);
if (!el) throw new Error(`找不到${deviceName}卡片`);
await driver.tapElement(el);
await sleep(3000);
}
it('切换单位为°C', async () => {
const start = Date.now();
try {
await enterMeterControl();
const celsiusEl = await driver.findElementRaw('name', '°C') ||
await driver.findElementRaw('name', 'C') ||
await driver.findElementRaw('name', '℃');
expect(celsiusEl).not.toBeNull();
await driver.tapElement(celsiusEl!);
await sleep(2000);
const source = await driver.getSource();
const hasCelsius = source.includes('°C') || source.includes('℃');
expect(hasCelsius).toBe(true);
reporter.record(`${FEAT_UNIT} 切换单位为°C`, 'PASS', Date.now() - start, '温度单位已切换为°C');
} catch (e: any) {
const ss = await driver.screenshot().catch(() => '');
reporter.record(`${FEAT_UNIT} 切换单位为°C`, 'FAIL', Date.now() - start, e.message, ss);
throw e;
}
});
it('切换单位为°F', async () => {
const start = Date.now();
try {
await enterMeterControl();
const fahrenheitEl = await driver.findElementRaw('name', '°F') ||
await driver.findElementRaw('name', 'F') ||
await driver.findElementRaw('name', '℉');
expect(fahrenheitEl).not.toBeNull();
await driver.tapElement(fahrenheitEl!);
await sleep(2000);
const source = await driver.getSource();
const hasFahrenheit = source.includes('°F') || source.includes('℉');
expect(hasFahrenheit).toBe(true);
// Restore to °C
const celsiusEl = await driver.findElementRaw('name', '°C') ||
await driver.findElementRaw('name', 'C') ||
await driver.findElementRaw('name', '℃');
if (celsiusEl) {
await driver.tapElement(celsiusEl);
await sleep(1000);
}
reporter.record(`${FEAT_UNIT} 切换单位为°F`, 'PASS', Date.now() - start, '温度单位已切换为°F并还原');
} catch (e: any) {
const ss = await driver.screenshot().catch(() => '');
reporter.record(`${FEAT_UNIT} 切换单位为°F`, 'FAIL', Date.now() - start, e.message, ss);
throw e;
}
});
it('加载更多数据', async () => {
const start = Date.now();
try {
await enterMeterControl();
// Scroll down in data view to load more data
await driver.scrollDown(400);
await sleep(2000);
await driver.scrollDown(400);
await sleep(2000);
const source = await driver.getSource();
const hasData = source.includes('Temperature') || source.includes('Humidity') ||
source.includes('°C') || source.includes('°F') || source.includes('%');
expect(hasData).toBe(true);
reporter.record('加载更多数据', 'PASS', Date.now() - start, `滚动加载更多数据成功, 含温湿度数据=${hasData}`);
} 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 enterMeterControl();
const exportEl = await driver.findElementRaw('name', 'Export') ||
await driver.findElementRaw('name', 'export');
if (!exportEl) {
await scrollToAndTap(driver, 'Export');
} else {
await driver.tapElement(exportEl);
}
await sleep(3000);
const source = await driver.getSource();
const hasExportOptions = source.includes('Export') || source.includes('CSV') ||
source.includes('Share') || source.includes('Email') || source.includes('Loading');
expect(hasExportOptions).toBe(true);
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;
}
});
});