Files
schedule-planner/frontend/cypress/e2e/responsive.cy.js
Hera Zhao d3f3b4f37b
Some checks failed
Test / build-check (push) Successful in 3s
PR Preview / test (pull_request) Successful in 3s
PR Preview / teardown-preview (pull_request) Has been skipped
Test / e2e-test (push) Failing after 55s
PR Preview / deploy-preview (pull_request) Failing after 40s
Refactor to Vue 3 + FastAPI + SQLite architecture
- Backend: FastAPI + SQLite (WAL mode), 22 tables, ~40 API endpoints
- Frontend: Vue 3 + Vite + Pinia + Vue Router, 8 views, 3 stores
- Database: migrate from JSON file to SQLite with proper schema
- Dockerfile: multi-stage build (node + python)
- Deploy: K8s manifests (namespace, deployment, service, ingress, pvc, backup)
- CI/CD: Gitea Actions (test, deploy, PR preview at pr-$id.planner.oci.euphon.net)
- Tests: 20 Cypress E2E test files, 196 test cases, ~85% coverage
- Doc: test-coverage.md with full feature coverage report

Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
2026-04-07 21:18:22 +00:00

53 lines
1.5 KiB
JavaScript

describe('Responsive Layout', () => {
beforeEach(() => {
cy.visit('/', {
onBeforeLoad(win) {
win.localStorage.setItem('sp_login_expires', String(Date.now() + 86400000))
}
})
cy.get('header').should('be.visible')
})
it('mobile viewport (375px) renders correctly', () => {
cy.viewport(375, 812)
cy.get('header').should('be.visible')
cy.get('.tab-btn').should('be.visible')
cy.get('.tab-btn').first().should('be.visible')
})
it('tablet viewport (768px) renders correctly', () => {
cy.viewport(768, 1024)
cy.get('header').should('be.visible')
cy.get('main').should('be.visible')
})
it('desktop viewport (1280px) renders correctly', () => {
cy.viewport(1280, 800)
cy.get('header').should('be.visible')
cy.get('main').should('be.visible')
})
it('mobile: tabs are scrollable', () => {
cy.viewport(375, 812)
cy.get('.tabs').should('have.css', 'overflow-x', 'auto')
})
it('mobile: quadrant grid stacks vertically', () => {
cy.viewport(375, 812)
cy.get('.tab-btn').contains('待办').click()
cy.get('.quadrant-grid').should('be.visible')
})
it('mobile: schedule layout stacks vertically', () => {
cy.viewport(375, 812)
cy.get('.tab-btn').contains('日程').click()
cy.get('.planning-layout').should('be.visible')
})
it('wide viewport (1920px) renders correctly', () => {
cy.viewport(1920, 1080)
cy.get('header').should('be.visible')
cy.get('main').should('be.visible')
})
})