diff --git a/src/tests/donations/donations_update.spec.ts b/src/tests/donations/donations_update.spec.ts index 4af9962..cd45b54 100644 --- a/src/tests/donations/donations_update.spec.ts +++ b/src/tests/donations/donations_update.spec.ts @@ -36,36 +36,36 @@ describe('adding + updating fixed donation illegally', () => { expect(res.headers['content-type']).toContain("application/json") }); it('updating empty should return 400', async () => { - const res2 = await axios.put(base + '/api/donations/fixed/' + added_donation.id, null, axios_config); - expect(res2.status).toEqual(400); - expect(res2.headers['content-type']).toContain("application/json") + const res = await axios.put(base + '/api/donations/fixed/' + added_donation.id, null, axios_config); + expect(res.status).toEqual(400); + expect(res.headers['content-type']).toContain("application/json") }); it('updating with wrong id should return 406', async () => { - const res2 = await axios.put(base + '/api/donations/fixed/' + added_donation.id, { + const res = await axios.put(base + '/api/donations/fixed/' + added_donation.id, { "id": added_donation.id + 1, "donor": added_donor.id, "amount": 100 }, axios_config); - expect(res2.status).toEqual(406); - expect(res2.headers['content-type']).toContain("application/json") + expect(res.status).toEqual(406); + expect(res.headers['content-type']).toContain("application/json") }); it('updating with negative amount should return 400', async () => { - const res2 = await axios.put(base + '/api/donations/fixed/' + added_donation.id, { + const res = await axios.put(base + '/api/donations/fixed/' + added_donation.id, { "id": added_donation.id, "donor": added_donor.id, "amount": -1 }, axios_config); - expect(res2.status).toEqual(400); - expect(res2.headers['content-type']).toContain("application/json") + expect(res.status).toEqual(400); + expect(res.headers['content-type']).toContain("application/json") }); it('updating with invalid donor should return 404', async () => { - const res2 = await axios.put(base + '/api/donations/fixed/' + added_donation.id, { + const res = await axios.put(base + '/api/donations/fixed/' + added_donation.id, { "id": added_donation.id, "donor": 9999999999999999999, "amount": 100 }, axios_config); - expect(res2.status).toEqual(404); - expect(res2.headers['content-type']).toContain("application/json") + expect(res.status).toEqual(404); + expect(res.headers['content-type']).toContain("application/json") }); }); // --------------- @@ -112,48 +112,229 @@ describe('adding + updating distance donation illegally', () => { expect(res.headers['content-type']).toContain("application/json") }); it('updating empty should return 400', async () => { - const res2 = await axios.put(base + '/api/donations/distance/' + added_donation.id, null, axios_config); - expect(res2.status).toEqual(400); - expect(res2.headers['content-type']).toContain("application/json") + const res = await axios.put(base + '/api/donations/distance/' + added_donation.id, null, axios_config); + expect(res.status).toEqual(400); + expect(res.headers['content-type']).toContain("application/json") }); it('updating with wrong id should return 406', async () => { - const res2 = await axios.put(base + '/api/donations/distance/' + added_donation.id, { + const res = await axios.put(base + '/api/donations/distance/' + added_donation.id, { "id": added_donation.id + 1, "runner": added_runner.id, "amountPerDistance": 100, "donor": added_donor.id }, axios_config); - expect(res2.status).toEqual(406); - expect(res2.headers['content-type']).toContain("application/json") + expect(res.status).toEqual(406); + expect(res.headers['content-type']).toContain("application/json") }); it('updating with negative amountPerDistance should return 400', async () => { - const res2 = await axios.put(base + '/api/donations/distance/' + added_donation.id, { + const res = await axios.put(base + '/api/donations/distance/' + added_donation.id, { "id": added_donation.id, "runner": added_runner.id, "amountPerDistance": -1, "donor": added_donor.id }, axios_config); - expect(res2.status).toEqual(400); - expect(res2.headers['content-type']).toContain("application/json") + expect(res.status).toEqual(400); + expect(res.headers['content-type']).toContain("application/json") }); it('updating with invalid donor should return 404', async () => { - const res2 = await axios.put(base + '/api/donations/distance/' + added_donation.id, { + const res = await axios.put(base + '/api/donations/distance/' + added_donation.id, { "id": added_donation.id, "runner": added_runner.id, "amountPerDistance": 100, "donor": 9999999999999999999 }, axios_config); - expect(res2.status).toEqual(404); - expect(res2.headers['content-type']).toContain("application/json") + expect(res.status).toEqual(404); + expect(res.headers['content-type']).toContain("application/json") }); it('updating with invalid runner should return 404', async () => { - const res2 = await axios.put(base + '/api/donations/distance/' + added_donation.id, { + const res = await axios.put(base + '/api/donations/distance/' + added_donation.id, { "id": added_donation.id, "runner": 9999999999999999999, "amountPerDistance": 100, "donor": added_donor.id }, axios_config); - expect(res2.status).toEqual(404); - expect(res2.headers['content-type']).toContain("application/json") + expect(res.status).toEqual(404); + expect(res.headers['content-type']).toContain("application/json") + }); +}); +// --------------- +describe('adding + updating fixed donation valid', () => { + let added_donor; + let added_donor2; + let added_donation; + it('creating a new donor with only needed params should return 200', async () => { + const res = await axios.post(base + '/api/donors', { + "firstname": "first", + "lastname": "last" + }, axios_config); + added_donor = res.data + expect(res.status).toEqual(200); + expect(res.headers['content-type']).toContain("application/json") + }); + it('creating a new donor with only needed params should return 200', async () => { + const res = await axios.post(base + '/api/donors', { + "firstname": "first", + "lastname": "last" + }, axios_config); + delete res.data.donationAmount; + added_donor2 = res.data + expect(res.status).toEqual(200); + expect(res.headers['content-type']).toContain("application/json") + }); + it('creating a new fixed donation should return 200', async () => { + const res = await axios.post(base + '/api/donations/fixed', { + "donor": added_donor.id, + "amount": 1000 + }, axios_config); + added_donation = res.data; + expect(res.status).toEqual(200); + expect(res.headers['content-type']).toContain("application/json") + }); + it('updating nothing should return 200', async () => { + const res = await axios.put(base + '/api/donations/fixed/' + added_donation.id, { + "id": added_donation.id, + "donor": added_donor.id, + "amount": 1000 + }, axios_config); + delete res.data.donor.donationAmount; + expect(res.status).toEqual(200); + expect(res.headers['content-type']).toContain("application/json"); + expect(res.data).toEqual(added_donation); + }); + it('updating amount should return 200', async () => { + const res = await axios.put(base + '/api/donations/fixed/' + added_donation.id, { + "id": added_donation.id, + "donor": added_donor.id, + "amount": 42 + }, axios_config); + expect(res.status).toEqual(200); + expect(res.headers['content-type']).toContain("application/json"); + expect(res.data.amount).toEqual(42); + }); + it('updating donor should return 200', async () => { + const res = await axios.put(base + '/api/donations/fixed/' + added_donation.id, { + "id": added_donation.id, + "donor": added_donor2.id, + "amount": 42 + }, axios_config); + delete res.data.donor.donationAmount; + expect(res.status).toEqual(200); + expect(res.headers['content-type']).toContain("application/json"); + expect(res.data.donor).toEqual(added_donor2); + }); +}); +// --------------- +describe('adding + updating distance donation valid', () => { + let added_donor; + let added_donor2; + let added_org; + let added_runner; + let added_runner2; + let added_donation; + it('creating a new donor with only needed params should return 200', async () => { + const res = await axios.post(base + '/api/donors', { + "firstname": "first", + "lastname": "last" + }, axios_config); + added_donor = res.data + expect(res.status).toEqual(200); + expect(res.headers['content-type']).toContain("application/json") + }); + it('creating a new donor with only needed params should return 200', async () => { + const res = await axios.post(base + '/api/donors', { + "firstname": "first", + "lastname": "last" + }, axios_config); + added_donor2 = res.data + expect(res.status).toEqual(200); + expect(res.headers['content-type']).toContain("application/json") + }); + it('creating a new org with just a name should return 200', async () => { + const res = await axios.post(base + '/api/organisations', { + "name": "test123" + }, axios_config); + added_org = res.data + expect(res.status).toEqual(200); + expect(res.headers['content-type']).toContain("application/json") + }); + it('creating a new runner with only needed params should return 200', async () => { + const res = await axios.post(base + '/api/runners', { + "firstname": "first", + "lastname": "last", + "group": added_org.id + }, axios_config); + added_runner = res.data; + expect(res.status).toEqual(200); + expect(res.headers['content-type']).toContain("application/json") + }); + it('creating a new runner with only needed params should return 200', async () => { + const res = await axios.post(base + '/api/runners', { + "firstname": "first", + "lastname": "last", + "group": added_org.id + }, axios_config); + delete res.data.group; + added_runner2 = res.data; + expect(res.status).toEqual(200); + expect(res.headers['content-type']).toContain("application/json") + }); + it('creating a new distance donation should return 200', async () => { + const res = await axios.post(base + '/api/donations/distance', { + "runner": added_runner.id, + "amountPerDistance": 100, + "donor": added_donor.id + }, axios_config); + delete res.data.donor.donationAmount; + added_donation = res.data; + expect(res.status).toEqual(200); + expect(res.headers['content-type']).toContain("application/json") + }); + it('updating nothing should return 200', async () => { + const res = await axios.put(base + '/api/donations/distance/' + added_donation.id, { + "id": added_donation.id, + "runner": added_runner.id, + "amountPerDistance": 100, + "donor": added_donor.id + }, axios_config); + delete res.data.donor.donationAmount; + expect(res.status).toEqual(200); + expect(res.headers['content-type']).toContain("application/json"); + expect(res.data).toEqual(added_donation); + }); + it('updating amount should return 200', async () => { + const res = await axios.put(base + '/api/donations/distance/' + added_donation.id, { + "id": added_donation.id, + "runner": added_runner.id, + "amountPerDistance": 69, + "donor": added_donor.id + }, axios_config); + delete res.data.donor.donationAmount; + expect(res.status).toEqual(200); + expect(res.headers['content-type']).toContain("application/json"); + expect(res.data.amountPerDistance).toEqual(69); + }); + it('updating runner should return 200', async () => { + const res = await axios.put(base + '/api/donations/distance/' + added_donation.id, { + "id": added_donation.id, + "runner": added_runner2.id, + "amountPerDistance": 69, + "donor": added_donor.id + }, axios_config); + delete res.data.runner.group; + expect(res.status).toEqual(200); + expect(res.headers['content-type']).toContain("application/json"); + expect(res.data.runner).toEqual(added_runner2); + }); + it('updating donor should return 200', async () => { + const res = await axios.put(base + '/api/donations/distance/' + added_donation.id, { + "id": added_donation.id, + "runner": added_runner2.id, + "amountPerDistance": 69, + "donor": added_donor2.id + }, axios_config); + delete res.data.donor.donationAmount; + expect(res.status).toEqual(200); + expect(res.headers['content-type']).toContain("application/json"); + expect(res.data.donor).toEqual(added_donor2); }); }); \ No newline at end of file