Files
oil-formula-calculator/frontend/cypress/e2e/manage-recipes.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

107 lines
3.7 KiB
JavaScript

describe('Manage Recipes Page', () => {
let adminToken
before(() => {
cy.getAdminToken().then(token => { adminToken = token })
})
beforeEach(() => {
cy.visit('/manage', {
onBeforeLoad(win) {
win.localStorage.setItem('oil_auth_token', adminToken)
}
})
// Wait for the recipe manager to load
cy.get('.recipe-manager', { timeout: 10000 }).should('exist')
})
it('loads and shows recipe lists', () => {
// Should show public recipes section with at least some recipes
cy.contains('公共配方库').should('be.visible')
cy.get('.recipe-row').should('have.length.gte', 1)
})
it('search box filters recipes', () => {
cy.get('.recipe-row').then($rows => {
const initialCount = $rows.length
// Type a search term
cy.get('.search-input').type('薰衣草')
cy.wait(500)
// Filtered count should be different (fewer or equal)
cy.get('.recipe-row').should('have.length.lte', initialCount)
})
})
it('clearing search restores all recipes', () => {
cy.get('.search-input').type('薰衣草')
cy.wait(500)
cy.get('.recipe-row').then($filtered => {
const filteredCount = $filtered.length
cy.get('.search-input').clear()
cy.wait(500)
cy.get('.recipe-row').should('have.length.gte', filteredCount)
})
})
it('can click a recipe to open the editor overlay', () => {
// Click the row-info area (which triggers editRecipe)
cy.get('.recipe-row .row-info').first().click()
// Editor overlay should appear
cy.get('.overlay-panel', { timeout: 5000 }).should('be.visible')
cy.contains('编辑配方').should('be.visible')
// Should have editor name input
cy.get('.editor-name-input').should('exist')
})
it('editor shows ingredients table with oil inputs', () => {
cy.get('.recipe-row .row-info').first().click()
cy.get('.overlay-panel', { timeout: 5000 }).should('be.visible')
// Ingredients section should have rows with oil search inputs
cy.get('.overlay-panel .editor-table').should('exist')
cy.get('.overlay-panel .form-select').should('have.length.gte', 1)
cy.get('.overlay-panel .editor-drops').should('have.length.gte', 1)
})
it('can close the editor overlay', () => {
cy.get('.recipe-row .row-info').first().click()
cy.get('.overlay-panel', { timeout: 5000 }).should('be.visible')
// Close via the close button
cy.get('.overlay-panel .btn-close').click()
cy.get('.overlay-panel').should('not.exist')
})
it('can close the editor with close button again', () => {
cy.get('.recipe-row .row-info').first().click()
cy.get('.overlay-panel', { timeout: 5000 }).should('be.visible')
// Close via the X button
cy.get('.overlay-panel .btn-close').click()
cy.get('.overlay-panel').should('not.exist')
})
it('tag filter bar toggles', () => {
// Look for any tag-related toggle button
cy.get('body').then($body => {
const hasToggle = $body.find('.tag-toggle-btn, [class*="tag-filter"] button, button:contains("标签")').length > 0
if (hasToggle) {
cy.get('.tag-toggle-btn, [class*="tag-filter"] button, button').contains('标签').first().click()
cy.wait(500)
// Tag area should exist after toggle
cy.get('[class*="tag"]').should('exist')
}
})
})
it('shows recipe cost in each row', () => {
cy.get('.row-cost').first().should('not.be.empty')
cy.get('.row-cost').first().invoke('text').should('contain', '¥')
})
it('has add recipe button that opens overlay', () => {
cy.get('.action-chip').contains('新增').click()
cy.get('.overlay-panel', { timeout: 5000 }).should('be.visible')
cy.contains('添加配方').should('be.visible')
// Close it
cy.get('.overlay-panel .btn-close').click()
})
})