mirror of
https://github.com/LHY0125/PathEditor.git
synced 2026-06-29 01:45:54 +08:00
8c0e80d862
新增配置文件: - .editorconfig — 跨编辑器代码风格统一 - .gitattributes — 行尾符 CRLF 规范化 - .prettierrc + .prettierignore — 前端代码格式化 - .markdownlint.json — Markdown 格式规范 - commitlint.config.js — Conventional Commits 强制校验 新增 GitHub 社区文件: - .github/dependabot.yml — 依赖自动更新 (npm + Cargo + Actions) - .github/CODEOWNERS — 自动 PR 审查分配 - .github/FUNDING.yml — 开源赞助入口 新增文档: - ROADMAP.md — v5.1/v5.2/v6.0 路线图 - SUPPORT.md — 帮助与支持指南 - docs/screenshots/ — 截图目录就位 新增 Git Hooks: - .husky/pre-commit — lint-staged 自动格式化+修复 - .husky/commit-msg — commitlint 校验提交消息 CI 强化 (.github/workflows/ci.yml): - 新增 Prettier 格式检查步骤 - 新增 cargo fmt --check 步骤 - 新增 Vitest 覆盖率生成 + Codecov 上报 修复: - index.html 标题 v4.0 → v5.0 - PathEditDialog set-state-in-effect 改用 useRef prevOpen 守卫 - use-app-actions.test.tsx 缺失 @vitest-environment jsdom - 所有 TS/TSX 文件 Prettier 格式化统一 配置更新: - vitest.config.ts — v8 覆盖率 + 阈值门禁 (60%/70%) - package.json — format/format:check/test:coverage/prepare 脚本 + lint-staged - .gitignore — 新增 coverage/sync-conflict/playwright-report - README.md — 新增 coverage + platform 徽章 + 截图区域
67 lines
2.1 KiB
TypeScript
67 lines
2.1 KiB
TypeScript
import { test, expect } from '@playwright/test';
|
|
|
|
test.beforeEach(async ({ page }) => {
|
|
await page.addInitScript(() => {
|
|
window.__TAURI_INTERNALS__ = {
|
|
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
invoke: async (cmd, args) => {
|
|
switch (cmd) {
|
|
case 'check_admin':
|
|
return true;
|
|
case 'load_system_paths':
|
|
return ['C:\\\\Windows', 'invalid_path', 'C:\\\\Temp'];
|
|
case 'load_user_paths':
|
|
return [];
|
|
case 'load_disabled_state':
|
|
return { system: [], user: [] };
|
|
case 'save_system_paths':
|
|
return undefined;
|
|
case 'save_user_paths':
|
|
return undefined;
|
|
case 'save_disabled_state':
|
|
return undefined;
|
|
case 'backup_registry':
|
|
return '';
|
|
case 'broadcast_env_change':
|
|
return undefined;
|
|
case 'validate_path':
|
|
return false;
|
|
case 'expand_env_vars':
|
|
return '';
|
|
case 'read_text_file':
|
|
return '';
|
|
case 'get_appdata_dir':
|
|
return '';
|
|
default:
|
|
return undefined;
|
|
}
|
|
},
|
|
};
|
|
});
|
|
await page.goto('/');
|
|
});
|
|
|
|
test('搜索过滤后清理无效路径', async ({ page }) => {
|
|
// 初始 3 条路径
|
|
await page.waitForTimeout(500);
|
|
await expect(page.locator('table tbody tr')).toHaveCount(3);
|
|
|
|
// 搜索 "Windows"
|
|
const searchInput = page.locator('input[placeholder]');
|
|
await searchInput.fill('Windows');
|
|
await page.waitForTimeout(300);
|
|
await expect(page.locator('table tbody tr')).toHaveCount(1);
|
|
|
|
// 清除搜索
|
|
await searchInput.fill('');
|
|
await page.waitForTimeout(300);
|
|
await expect(page.locator('table tbody tr')).toHaveCount(3);
|
|
|
|
// 点击"一键清理"按钮
|
|
await page.click('text=一键清理');
|
|
await page.waitForTimeout(300);
|
|
// is_valid_path_format 只校验格式,不检查存在性
|
|
// "invalid_path" 格式无效被移除,C:\Windows 和 C:\Temp 格式有效保留
|
|
await expect(page.locator('table tbody tr')).toHaveCount(2);
|
|
});
|