const https = require('https') const http = require('http') const testPasswordOptions = async () => { console.log('🔍 測試新增用戶密碼選項') console.log('=' .repeat(50)) try { // 1. 測試使用預設密碼創建用戶 console.log('\n📊 1. 測試使用預設密碼創建用戶...') const defaultPasswordUser = { name: '預設密碼測試用戶', email: 'default.password@company.com', password: 'password123', // 預設密碼 department: '測試部', role: 'user' } const createResponse1 = await new Promise((resolve, reject) => { const postData = JSON.stringify(defaultPasswordUser) const options = { hostname: 'localhost', port: 3000, path: '/api/admin/users', method: 'POST', headers: { 'Content-Type': 'application/json', 'Content-Length': Buffer.byteLength(postData) } } const req = http.request(options, (res) => { let data = '' res.on('data', chunk => data += chunk) res.on('end', () => resolve({ status: res.statusCode, data })) }) req.on('error', reject) req.write(postData) req.end() }) let defaultPasswordUserId = null if (createResponse1.status === 200) { const createData = JSON.parse(createResponse1.data) if (createData.success) { defaultPasswordUserId = createData.data.id console.log('✅ 使用預設密碼創建用戶成功:') console.log(` ID: ${createData.data.id}`) console.log(` 姓名: ${createData.data.name}`) console.log(` 電子郵件: ${createData.data.email}`) console.log(` 密碼: password123 (已加密儲存)`) } else { console.log('❌ 使用預設密碼創建用戶失敗:', createData.error) } } // 2. 測試使用自定義密碼創建用戶 console.log('\n📊 2. 測試使用自定義密碼創建用戶...') const customPasswordUser = { name: '自定義密碼測試用戶', email: 'custom.password@company.com', password: 'MyCustomPassword2024!', // 自定義密碼 department: '測試部', role: 'user' } const createResponse2 = await new Promise((resolve, reject) => { const postData = JSON.stringify(customPasswordUser) const options = { hostname: 'localhost', port: 3000, path: '/api/admin/users', method: 'POST', headers: { 'Content-Type': 'application/json', 'Content-Length': Buffer.byteLength(postData) } } const req = http.request(options, (res) => { let data = '' res.on('data', chunk => data += chunk) res.on('end', () => resolve({ status: res.statusCode, data })) }) req.on('error', reject) req.write(postData) req.end() }) let customPasswordUserId = null if (createResponse2.status === 200) { const createData = JSON.parse(createResponse2.data) if (createData.success) { customPasswordUserId = createData.data.id console.log('✅ 使用自定義密碼創建用戶成功:') console.log(` ID: ${createData.data.id}`) console.log(` 姓名: ${createData.data.name}`) console.log(` 電子郵件: ${createData.data.email}`) console.log(` 密碼: MyCustomPassword2024! (已加密儲存)`) } else { console.log('❌ 使用自定義密碼創建用戶失敗:', createData.error) } } // 3. 測試密碼驗證規則 console.log('\n📊 3. 測試密碼驗證規則...') const shortPasswordUser = { name: '短密碼測試用戶', email: 'short.password@company.com', password: '123', // 太短的密碼 department: '測試部', role: 'user' } const createResponse3 = await new Promise((resolve, reject) => { const postData = JSON.stringify(shortPasswordUser) const options = { hostname: 'localhost', port: 3000, path: '/api/admin/users', method: 'POST', headers: { 'Content-Type': 'application/json', 'Content-Length': Buffer.byteLength(postData) } } const req = http.request(options, (res) => { let data = '' res.on('data', chunk => data += chunk) res.on('end', () => resolve({ status: res.statusCode, data })) }) req.on('error', reject) req.write(postData) req.end() }) if (createResponse3.status === 400) { const errorData = JSON.parse(createResponse3.data) console.log('✅ 密碼長度驗證正常:') console.log(` 錯誤訊息: ${errorData.error}`) } else { console.log('❌ 密碼長度驗證失敗,應該拒絕短密碼') } // 4. 清理測試用戶 console.log('\n📊 4. 清理測試用戶...') const userIdsToDelete = [defaultPasswordUserId, customPasswordUserId].filter(id => id) for (const userId of userIdsToDelete) { const deleteResponse = await new Promise((resolve, reject) => { const options = { hostname: 'localhost', port: 3000, path: `/api/admin/users?id=${userId}`, method: 'DELETE' } const req = http.request(options, (res) => { let data = '' res.on('data', chunk => data += chunk) res.on('end', () => resolve({ status: res.statusCode, data })) }) req.on('error', reject) req.end() }) if (deleteResponse.status === 200) { console.log(`✅ 已刪除測試用戶: ${userId}`) } } console.log('\n📝 密碼選項功能總結:') console.log('✅ 支援預設密碼選項 (password123)') console.log('✅ 支援自定義密碼輸入') console.log('✅ 密碼長度驗證 (至少6個字元)') console.log('✅ 密碼加密儲存') console.log('✅ 用戶友好的介面設計') console.log('\n🎨 介面改進:') console.log('✅ 預設密碼按鈕') console.log('✅ 密碼提示文字') console.log('✅ 靈活的密碼輸入方式') } catch (error) { console.error('❌ 測試失敗:', error.message) } finally { console.log('\n✅ 密碼選項功能測試完成') } } testPasswordOptions()