test: strengthen Cypress e2e tests with real API assertions
- Remove blanket uncaught:exception suppressor (API-only tests)
- Trim smoke test to single infra-verification assertion
- Rewrite health test with strict status/field assertions, no failOnStatusCode
- Add session CRUD tests (create, get, list, delete, 404 cases, cleanup)
- Use Cypress.env('API_URL') instead of baseUrl to avoid blocking smoke tests
- Remove unused main and type fields from package.json
This commit is contained in:
@@ -1,30 +1,21 @@
|
||||
/// <reference types="cypress" />
|
||||
|
||||
describe('Session Manager API', () => {
|
||||
describe('Health Check', () => {
|
||||
it('should respond to the health endpoint', () => {
|
||||
cy.request({
|
||||
method: 'GET',
|
||||
url: '/api/health',
|
||||
failOnStatusCode: false,
|
||||
}).then((response) => {
|
||||
// The endpoint should exist and return a response
|
||||
expect(response.status).to.be.oneOf([200, 503]);
|
||||
expect(response.body).to.be.an('object');
|
||||
});
|
||||
});
|
||||
});
|
||||
const api = () => Cypress.env('API_URL');
|
||||
|
||||
describe('Sessions API', () => {
|
||||
it('should list sessions', () => {
|
||||
cy.request({
|
||||
method: 'GET',
|
||||
url: '/api/sessions',
|
||||
failOnStatusCode: false,
|
||||
}).then((response) => {
|
||||
expect(response.status).to.eq(200);
|
||||
expect(response.body).to.be.an('object');
|
||||
});
|
||||
describe('Health API', () => {
|
||||
it('GET /api/health returns status and required fields', () => {
|
||||
cy.request(`${api()}/api/health`).then((response) => {
|
||||
expect(response.status).to.eq(200);
|
||||
expect(response.body).to.have.property('status');
|
||||
expect(response.body.status).to.be.oneOf([
|
||||
'healthy',
|
||||
'degraded',
|
||||
'unhealthy',
|
||||
]);
|
||||
expect(response.body).to.have.property('docker');
|
||||
expect(response.body).to.have.property('active_sessions');
|
||||
expect(response.body).to.have.property('timestamp');
|
||||
expect(response.body).to.have.property('resource_limits');
|
||||
});
|
||||
});
|
||||
});
|
||||
|
||||
97
cypress/e2e/api/sessions.cy.js
Normal file
97
cypress/e2e/api/sessions.cy.js
Normal file
@@ -0,0 +1,97 @@
|
||||
/// <reference types="cypress" />
|
||||
|
||||
const api = () => Cypress.env('API_URL');
|
||||
|
||||
describe('Sessions API', () => {
|
||||
const createdSessions = [];
|
||||
|
||||
afterEach(() => {
|
||||
createdSessions.splice(0).forEach((id) => {
|
||||
cy.request({
|
||||
method: 'DELETE',
|
||||
url: `${api()}/api/sessions/${id}`,
|
||||
failOnStatusCode: false,
|
||||
});
|
||||
});
|
||||
});
|
||||
|
||||
describe('GET /api/sessions', () => {
|
||||
it('returns 200 with an array', () => {
|
||||
cy.request(`${api()}/api/sessions`).then((response) => {
|
||||
expect(response.status).to.eq(200);
|
||||
expect(response.body).to.be.an('array');
|
||||
});
|
||||
});
|
||||
});
|
||||
|
||||
describe('POST /api/sessions', () => {
|
||||
it('creates a session with expected fields', () => {
|
||||
cy.request('POST', `${api()}/api/sessions`).then((response) => {
|
||||
expect(response.status).to.be.oneOf([200, 201]);
|
||||
expect(response.body).to.have.property('session_id');
|
||||
expect(response.body).to.have.property('auth_token');
|
||||
expect(response.body).to.have.property('status');
|
||||
createdSessions.push(response.body.session_id);
|
||||
});
|
||||
});
|
||||
});
|
||||
|
||||
describe('GET /api/sessions/:id', () => {
|
||||
it('returns the created session', () => {
|
||||
cy.request('POST', `${api()}/api/sessions`).then((createRes) => {
|
||||
createdSessions.push(createRes.body.session_id);
|
||||
const id = createRes.body.session_id;
|
||||
|
||||
cy.request(`${api()}/api/sessions/${id}`).then((response) => {
|
||||
expect(response.status).to.eq(200);
|
||||
expect(response.body).to.have.property('session_id', id);
|
||||
});
|
||||
});
|
||||
});
|
||||
|
||||
it('returns 404 for nonexistent session', () => {
|
||||
cy.request({
|
||||
url: `${api()}/api/sessions/nonexistent-id-000`,
|
||||
failOnStatusCode: false,
|
||||
}).then((response) => {
|
||||
expect(response.status).to.eq(404);
|
||||
});
|
||||
});
|
||||
});
|
||||
|
||||
describe('DELETE /api/sessions/:id', () => {
|
||||
it('deletes a session', () => {
|
||||
cy.request('POST', `${api()}/api/sessions`).then((createRes) => {
|
||||
const id = createRes.body.session_id;
|
||||
|
||||
cy.request('DELETE', `${api()}/api/sessions/${id}`).then(
|
||||
(response) => {
|
||||
expect(response.status).to.eq(200);
|
||||
expect(response.body).to.have.property('message');
|
||||
}
|
||||
);
|
||||
});
|
||||
});
|
||||
|
||||
it('returns 404 for nonexistent session', () => {
|
||||
cy.request({
|
||||
method: 'DELETE',
|
||||
url: `${api()}/api/sessions/nonexistent-id-000`,
|
||||
failOnStatusCode: false,
|
||||
}).then((response) => {
|
||||
expect(response.status).to.eq(404);
|
||||
});
|
||||
});
|
||||
});
|
||||
|
||||
describe('POST /api/cleanup', () => {
|
||||
it('returns 200 with cleanup message', () => {
|
||||
cy.request('POST', `${api()}/api/cleanup`).then((response) => {
|
||||
expect(response.status).to.eq(200);
|
||||
expect(response.body)
|
||||
.to.have.property('message')
|
||||
.that.includes('Cleanup completed');
|
||||
});
|
||||
});
|
||||
});
|
||||
});
|
||||
Reference in New Issue
Block a user