159 lines
5.7 KiB
JavaScript
159 lines
5.7 KiB
JavaScript
const https = require('https')
|
|
const http = require('http')
|
|
|
|
const testFixedDimensionScoring = async () => {
|
|
console.log('🧪 測試修正後的維度分數計算')
|
|
console.log('=' .repeat(50))
|
|
|
|
const userId = 'user-1759073326705-m06y3wacd'
|
|
const testResultId = 'test_1759086508812_xv2pof6lk'
|
|
|
|
try {
|
|
// 1. 獲取測試結果
|
|
console.log('\n📊 1. 獲取測試結果...')
|
|
const resultResponse = await new Promise((resolve, reject) => {
|
|
const req = http.get(`http://localhost:3000/api/test-results/creative?userId=${userId}`, (res) => {
|
|
let data = ''
|
|
res.on('data', chunk => data += chunk)
|
|
res.on('end', () => resolve({ status: res.statusCode, data }))
|
|
})
|
|
req.on('error', reject)
|
|
})
|
|
|
|
let testResult = null
|
|
if (resultResponse.status === 200) {
|
|
const resultData = JSON.parse(resultResponse.data)
|
|
if (resultData.success && resultData.data.length > 0) {
|
|
testResult = resultData.data[0]
|
|
console.log('測試結果:', {
|
|
id: testResult.id,
|
|
score: testResult.score,
|
|
total_questions: testResult.total_questions,
|
|
correct_answers: testResult.correct_answers
|
|
})
|
|
}
|
|
}
|
|
|
|
// 2. 獲取題目資料
|
|
console.log('\n📊 2. 獲取題目資料...')
|
|
const questionsResponse = await new Promise((resolve, reject) => {
|
|
const req = http.get('http://localhost:3000/api/creative-questions', (res) => {
|
|
let data = ''
|
|
res.on('data', chunk => data += chunk)
|
|
res.on('end', () => resolve({ status: res.statusCode, data }))
|
|
})
|
|
req.on('error', reject)
|
|
})
|
|
|
|
let questions = []
|
|
if (questionsResponse.status === 200) {
|
|
const questionsData = JSON.parse(questionsResponse.data)
|
|
if (questionsData.success) {
|
|
questions = questionsData.questions
|
|
console.log(`獲取到 ${questions.length} 個題目`)
|
|
}
|
|
}
|
|
|
|
// 3. 獲取詳細答案
|
|
console.log('\n📊 3. 獲取詳細答案...')
|
|
const answersResponse = await new Promise((resolve, reject) => {
|
|
const req = http.get(`http://localhost:3000/api/creative-test-answers?testResultId=${testResultId}`, (res) => {
|
|
let data = ''
|
|
res.on('data', chunk => data += chunk)
|
|
res.on('end', () => resolve({ status: res.statusCode, data }))
|
|
})
|
|
req.on('error', reject)
|
|
})
|
|
|
|
if (answersResponse.status === 200) {
|
|
const answersData = JSON.parse(answersResponse.data)
|
|
if (answersData.success) {
|
|
const answers = answersData.data
|
|
console.log(`獲取到 ${answers.length} 個答案`)
|
|
|
|
// 4. 模擬結果頁面的維度分數計算
|
|
console.log('\n📊 4. 模擬結果頁面的維度分數計算...')
|
|
|
|
// 計算各維度分數(模擬資料庫計算)
|
|
const dimensionScores = {
|
|
innovation: { total: 0, count: 0 },
|
|
imagination: { total: 0, count: 0 },
|
|
flexibility: { total: 0, count: 0 },
|
|
originality: { total: 0, count: 0 }
|
|
}
|
|
|
|
answers.forEach((answer) => {
|
|
const question = questions.find(q => q.id === answer.question_id)
|
|
if (question && dimensionScores[question.category]) {
|
|
dimensionScores[question.category].total += answer.score
|
|
dimensionScores[question.category].count += 1
|
|
}
|
|
})
|
|
|
|
// 計算百分比分數
|
|
const calculatedDimensionScores = {
|
|
innovation: 0,
|
|
imagination: 0,
|
|
flexibility: 0,
|
|
originality: 0
|
|
}
|
|
|
|
Object.keys(dimensionScores).forEach(category => {
|
|
const { total, count } = dimensionScores[category]
|
|
calculatedDimensionScores[category] =
|
|
count > 0 ? Math.round((total / (count * 5)) * 100) : 0
|
|
})
|
|
|
|
console.log('\n📈 計算結果:')
|
|
console.log('創新能力:', calculatedDimensionScores.innovation + '%')
|
|
console.log('想像力:', calculatedDimensionScores.imagination + '%')
|
|
console.log('靈活性:', calculatedDimensionScores.flexibility + '%')
|
|
console.log('原創性:', calculatedDimensionScores.originality + '%')
|
|
|
|
// 5. 模擬結果頁面的 categoryResults 計算
|
|
console.log('\n📊 5. 模擬結果頁面的 categoryResults 計算...')
|
|
|
|
const dimensionNames = {
|
|
innovation: '創新能力',
|
|
imagination: '想像力',
|
|
flexibility: '靈活性',
|
|
originality: '原創性'
|
|
}
|
|
|
|
const categoryResults = Object.entries(calculatedDimensionScores).map(([key, score]) => ({
|
|
category: key,
|
|
name: dimensionNames[key],
|
|
score: score,
|
|
rawScore: 0,
|
|
maxRawScore: 0
|
|
}))
|
|
|
|
console.log('\n📈 categoryResults:')
|
|
categoryResults.forEach(category => {
|
|
console.log(`${category.name}: ${category.score}分`)
|
|
})
|
|
|
|
// 6. 驗證總分一致性
|
|
console.log('\n📊 6. 驗證總分一致性...')
|
|
const totalScore = answers.reduce((sum, answer) => sum + answer.score, 0)
|
|
const maxTotalScore = answers.length * 5
|
|
const totalPercentage = Math.round((totalScore / maxTotalScore) * 100)
|
|
|
|
console.log(`資料庫總分數: ${testResult.correct_answers}`)
|
|
console.log(`計算總分數: ${totalScore}`)
|
|
console.log(`資料庫百分比: ${testResult.score}%`)
|
|
console.log(`計算百分比: ${totalPercentage}%`)
|
|
console.log(`一致性: ${testResult.correct_answers === totalScore && testResult.score === totalPercentage ? '✅ 一致' : '❌ 不一致'}`)
|
|
|
|
}
|
|
}
|
|
|
|
} catch (error) {
|
|
console.error('❌ 測試失敗:', error.message)
|
|
} finally {
|
|
console.log('\n✅ 修正後的維度分數計算測試完成')
|
|
}
|
|
}
|
|
|
|
testFixedDimensionScoring()
|