Features: - Backend statistics API (cloud-native Prisma aggregation) - Results page with hybrid solution (AI consensus + human final decision) - Excel export (frontend generation, zero disk write, cloud-native) - PRISMA-style exclusion reason analysis with bar chart - Batch selection and export (3 export methods) - Fixed logic contradiction (inclusion does not show exclusion reason) - Optimized table width (870px, no horizontal scroll) Components: - Backend: screeningController.ts - add getProjectStatistics API - Frontend: ScreeningResults.tsx - complete results page (hybrid solution) - Frontend: excelExport.ts - Excel export utility (40 columns full info) - Frontend: ScreeningWorkbench.tsx - add navigation button - Utils: get-test-projects.mjs - quick test tool Architecture: - Cloud-native: backend aggregation reduces network transfer - Cloud-native: frontend Excel generation (zero file persistence) - Reuse platform: global prisma instance, logger - Performance: statistics API < 500ms, Excel export < 3s (1000 records) Documentation: - Update module status guide (add Week 4 features) - Update task breakdown (mark Week 4 completed) - Update API design spec (add statistics API) - Update database design (add field usage notes) - Create Week 4 development plan - Create Week 4 completion report - Create technical debt list Test: - End-to-end flow test passed - All features verified - Performance test passed - Cloud-native compliance verified Ref: Week 4 Development Plan Scope: ASL Module MVP - Title Abstract Screening Results Cloud-Native: Backend aggregation + Frontend Excel generation
65 lines
1.4 KiB
TypeScript
65 lines
1.4 KiB
TypeScript
/**
|
|
* 为ASL测试创建测试用户
|
|
*/
|
|
|
|
import { prisma } from '../src/config/database.js';
|
|
|
|
async function createTestUser() {
|
|
try {
|
|
console.log('🔍 检查测试用户是否存在...\n');
|
|
|
|
const testUserId = 'asl-test-user-001';
|
|
|
|
// 检查用户是否已存在
|
|
const existingUser = await prisma.user.findUnique({
|
|
where: { id: testUserId },
|
|
});
|
|
|
|
if (existingUser) {
|
|
console.log('✅ 测试用户已存在:');
|
|
console.log(' ID:', existingUser.id);
|
|
console.log(' 邮箱:', existingUser.email);
|
|
console.log(' 姓名:', existingUser.name);
|
|
return existingUser;
|
|
}
|
|
|
|
// 创建测试用户
|
|
const user = await prisma.user.create({
|
|
data: {
|
|
id: testUserId,
|
|
email: 'asl-test@example.com',
|
|
password: 'test-password-hash',
|
|
name: 'ASL测试用户',
|
|
role: 'user',
|
|
status: 'active',
|
|
kbQuota: 10,
|
|
kbUsed: 0,
|
|
isTrial: true,
|
|
},
|
|
});
|
|
|
|
console.log('✅ 测试用户创建成功:');
|
|
console.log(' ID:', user.id);
|
|
console.log(' 邮箱:', user.email);
|
|
console.log(' 姓名:', user.name);
|
|
console.log('\n💡 在测试脚本中使用此用户ID进行测试');
|
|
|
|
return user;
|
|
} catch (error) {
|
|
console.error('❌ 创建测试用户失败:', error);
|
|
throw error;
|
|
} finally {
|
|
await prisma.$disconnect();
|
|
}
|
|
}
|
|
|
|
createTestUser();
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|