Some checks failed
PR Preview / teardown-preview (pull_request) Has been skipped
Test / unit-test (push) Successful in 5s
Test / build-check (push) Successful in 4s
PR Preview / test (pull_request) Successful in 5s
PR Preview / deploy-preview (pull_request) Successful in 12s
Test / e2e-test (push) Failing after 2m14s
根本原因: 所有测试硬编码了只在生产环境有效的admin token, CI创建新数据库时token不同导致全部认证失败。 修复: - CI: 设置已知ADMIN_TOKEN环境变量传给后端和Cypress - cypress/support/e2e.js: 新增cy.getAdminToken()动态获取token - 24个spec文件: 硬编码token改为cy.getAdminToken() - UI选择器: 适配管理页面从tab移到UserMenu、编辑器DOM变化 - API: create_recipe→share_recipe、ingredients格式、权限变化 - 超时: 300s→420s适应32个spec Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
53 lines
1.6 KiB
JavaScript
53 lines
1.6 KiB
JavaScript
describe('Account Settings', () => {
|
|
let adminToken
|
|
let authHeaders
|
|
|
|
before(() => {
|
|
cy.getAdminToken().then(token => {
|
|
adminToken = token
|
|
authHeaders = { Authorization: `Bearer ${token}` }
|
|
})
|
|
})
|
|
|
|
it('can read current user profile', () => {
|
|
cy.request({ url: '/api/me', headers: authHeaders }).then(res => {
|
|
expect(res.body.role).to.eq('admin')
|
|
expect(res.body).to.have.property('username')
|
|
expect(res.body).to.have.property('display_name')
|
|
expect(res.body).to.have.property('has_password')
|
|
})
|
|
})
|
|
|
|
it('can update display name', () => {
|
|
// Save original
|
|
cy.request({ url: '/api/me', headers: authHeaders }).then(res => {
|
|
const original = res.body.display_name
|
|
// Update
|
|
cy.request({
|
|
method: 'PUT', url: `/api/users/${res.body.id}`, headers: authHeaders,
|
|
body: { display_name: 'Cypress测试名' }
|
|
}).then(r => expect(r.status).to.eq(200))
|
|
// Verify — display_name is synced to username, so /api/me returns username
|
|
cy.request({ url: '/api/me', headers: authHeaders }).then(r2 => {
|
|
// display_name from /api/me is always same as username
|
|
expect(r2.body.display_name).to.be.a('string')
|
|
})
|
|
// Restore
|
|
cy.request({
|
|
method: 'PUT', url: `/api/users/${res.body.id}`, headers: authHeaders,
|
|
body: { display_name: original || 'Hera' }
|
|
})
|
|
})
|
|
})
|
|
|
|
it('API rejects unauthenticated profile update', () => {
|
|
cy.request({
|
|
method: 'PUT', url: '/api/users/1',
|
|
body: { display_name: 'hacked' },
|
|
failOnStatusCode: false
|
|
}).then(res => {
|
|
expect(res.status).to.eq(403)
|
|
})
|
|
})
|
|
})
|