Files
kt-financial-system/test-new-menu.js
你的用户名 675fe0a1a8 feat: 增强财务管理系统功能与分析能力
主要更新:
- 🎯 新增综合分析仪表板,包含关键指标卡片、预算对比、智能洞察等组件
- 📊 增强数据可视化能力,新增标签云分析、时间维度分析等图表
- 📱 优化移动端响应式设计,改进触控交互体验
- 🔧 新增多个API模块(base、budget、tag),完善数据管理
- 🗂️ 重构路由结构,新增贷款、快速添加、设置、统计等独立模块
- 🔄 优化数据导入导出功能,增强数据迁移能力
- 🐛 修复多个已知问题,提升系统稳定性

技术改进:
- 使用IndexedDB提升本地存储性能
- 实现模拟API服务,支持离线开发
- 增加自动化测试脚本,确保功能稳定
- 优化打包配置,提升构建效率

文件变更:
- 新增42个文件
- 修改55个文件
- 包含测试脚本、配置文件、组件和API模块

🤖 Generated with [Claude Code](https://claude.ai/code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-08-24 16:41:58 +08:00

88 lines
3.3 KiB
JavaScript

import { chromium } from 'playwright';
(async () => {
const browser = await chromium.launch({ headless: false });
const page = await browser.newPage();
try {
console.log('1. 访问系统...');
await page.goto('http://localhost:5666');
await page.waitForTimeout(3000);
// 检查是否需要登录
if (page.url().includes('login')) {
console.log('2. 执行登录...');
await page.fill('input[placeholder*="账号"]', 'admin');
await page.fill('input[placeholder*="密码"]', '111111');
await page.click('button:has-text("登录")');
await page.waitForTimeout(3000);
}
console.log('\n3. 检查新菜单结构...');
// 检查一级菜单是否存在
const menuItems = [
{ text: '仪表板', exists: false },
{ text: '记一笔', exists: false },
{ text: '交易记录', exists: false },
{ text: '统计分析', exists: false },
{ text: '设置', exists: false },
{ text: '贷款管理', exists: false },
{ text: '系统工具', exists: false }
];
for (const item of menuItems) {
const menuItem = await page.locator(`.ant-menu-item:has-text("${item.text}"), .ant-menu-submenu:has-text("${item.text}")`).count();
item.exists = menuItem > 0;
console.log(` - ${item.text}: ${item.exists ? '✅' : '❌'}`);
}
console.log('\n4. 测试"记一笔"快速记账...');
const quickAddMenu = page.locator('.ant-menu-item:has-text("记一笔")');
if (await quickAddMenu.count() > 0) {
await quickAddMenu.click();
await page.waitForTimeout(2000);
// 检查是否弹出了新建交易窗口
const modalVisible = await page.locator('.ant-modal').isVisible();
console.log(` - 新建交易窗口: ${modalVisible ? '✅ 已弹出' : '❌ 未弹出'}`);
if (modalVisible) {
// 关闭弹窗
await page.keyboard.press('Escape');
await page.waitForTimeout(1000);
}
} else {
console.log(' - ❌ 未找到"记一笔"菜单');
}
console.log('\n5. 检查"统计分析"子菜单...');
const statsMenu = page.locator('.ant-menu-submenu:has-text("统计分析")');
if (await statsMenu.count() > 0) {
await statsMenu.click();
await page.waitForTimeout(1000);
const subMenus = ['分类统计', '趋势分析', '月度报表', '年度总结'];
for (const subMenu of subMenus) {
const exists = await page.locator(`.ant-menu-item:has-text("${subMenu}")`).count() > 0;
console.log(` - ${subMenu}: ${exists ? '✅' : '❌'}`);
}
} else {
console.log(' - ❌ 未找到"统计分析"菜单');
}
console.log('\n6. 检查是否去掉了"财务管理"二级菜单...');
const financeMenu = await page.locator('.ant-menu-submenu:has-text("财务管理")').count();
console.log(` - 财务管理菜单: ${financeMenu === 0 ? '✅ 已移除' : '❌ 仍存在'}`);
// 截图
await page.screenshot({ path: 'new-menu-structure.png', fullPage: true });
console.log('\n✅ 测试完成!截图保存为: new-menu-structure.png');
} catch (error) {
console.error('❌ 测试失败:', error.message);
await page.screenshot({ path: 'menu-test-error.png' });
} finally {
await browser.close();
}
})();