193 lines
6.2 KiB
JavaScript
193 lines
6.2 KiB
JavaScript
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()
|