diff --git a/src/tests/runnerTeams/team_add+delete.spec.ts b/src/tests/runnerTeams/team_add+delete.spec.ts new file mode 100644 index 0000000..8e7233a --- /dev/null +++ b/src/tests/runnerTeams/team_add+delete.spec.ts @@ -0,0 +1,47 @@ +import axios from 'axios'; +import { config } from '../../config'; +const base = "http://localhost:" + config.internal_port + +// --------------- +describe('adding org', () => { + let added_org; + let added_org_id; + let added_team; + let added_team_id + it('creating a new org with just a name should return 200', async () => { + const res1 = await axios.post(base + '/api/organisations', { + "name": "test123" + }); + added_org = res1.data; + added_org_id = added_org.id; + expect(res1.status).toEqual(200); + expect(res1.headers['content-type']).toContain("application/json") + }); + it('creating a new team with a valid org should return 200', async () => { + const res2 = await axios.post(base + '/api/teams', { + "name": "test123", + "parentGroup": added_org_id + }); + added_team = res2.data; + added_team_id = added_team.id; + expect(res2.status).toEqual(200); + expect(res2.headers['content-type']).toContain("application/json") + }); + it('delete', async () => { + const res2 = await axios.delete(base + '/api/teams/' + added_team_id); + expect(res2.status).toEqual(200); + expect(res2.headers['content-type']).toContain("application/json") + let deleted_team = res2.data + delete deleted_team.id; + delete deleted_team.parentGroup; + expect(deleted_team).toEqual({ + "name": "test123", + "contact": null + }); + }); + it('check if org really was deleted', async () => { + const res3 = await axios.get(base + '/api/teams/' + added_team_id, { validateStatus: undefined }); + expect(res3.status).toEqual(404); + expect(res3.headers['content-type']).toContain("application/json") + }); +}); \ No newline at end of file