Files
oil-formula-calculator/frontend/cypress/e2e/navigation.cy.js
Hera Zhao b8b4eceff3
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
fix: 修复全部27个失败的e2e测试
根本原因: 所有测试硬编码了只在生产环境有效的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>
2026-04-13 21:08:40 +00:00

86 lines
2.5 KiB
JavaScript

describe('Navigation & Routing', () => {
let adminToken
before(() => {
cy.getAdminToken().then(token => { adminToken = token })
})
it('direct URL /oils loads oil reference page', () => {
cy.visit('/oils')
cy.contains('精油价目').should('be.visible')
})
it('direct URL / loads search page', () => {
cy.visit('/')
cy.get('input[placeholder*="搜索"]', { timeout: 8000 }).should('be.visible')
})
it('unknown route still renders the app', () => {
cy.visit('/nonexistent-page')
cy.get('.app-header').should('be.visible')
cy.get('.nav-tabs').should('be.visible')
})
it('back button works between tabs', () => {
cy.visit('/')
cy.get('.nav-tab').contains('精油价目').click()
cy.url().should('include', '/oils')
cy.go('back')
cy.url().should('not.include', '/oils')
})
it('tab active state tracks after click', () => {
cy.visit('/')
cy.get('.nav-tab').contains('精油价目').click()
cy.get('.nav-tab').contains('精油价目').should('have.class', 'active')
cy.get('.nav-tab').contains('配方查询').should('not.have.class', 'active')
})
it('admin-only pages not accessible as tabs for anonymous users', () => {
cy.visit('/')
// The nav tabs should only show public tabs
cy.get('.nav-tab').should('have.length.lte', 5)
// No admin menu links visible
cy.get('.usermenu-card').should('not.exist')
})
it('admin pages accessible via direct URL when logged in', () => {
cy.visit('/audit', {
onBeforeLoad(win) {
win.localStorage.setItem('oil_auth_token', adminToken)
}
})
cy.contains('操作日志', { timeout: 10000 }).should('be.visible')
})
it('all tab pages are navigable', () => {
cy.visit('/', {
onBeforeLoad(win) {
win.localStorage.setItem('oil_auth_token', adminToken)
}
})
const pages = [
{ tab: '管理配方', url: '/manage' },
{ tab: '个人库存', url: '/inventory' },
{ tab: '精油价目', url: '/oils' },
]
pages.forEach(({ tab, url }) => {
cy.get('.nav-tab').contains(tab).click()
cy.url().should('include', url)
})
})
it('admin pages accessible via user menu', () => {
cy.visit('/', {
onBeforeLoad(win) {
win.localStorage.setItem('oil_auth_token', adminToken)
}
})
// Open user menu
cy.get('.user-name', { timeout: 10000 }).click()
cy.get('.usermenu-card').should('be.visible')
cy.get('.usermenu-btn').contains('操作日志').click()
cy.url().should('include', '/audit')
})
})