This repository has been archived on 2023-11-10. You can view files and clone it, but cannot push or open issues or pull requests.
freecodecamp-projects/7-quality-assurance/2-issue-tracker/tests/2_functional-tests.js

203 lines
7.8 KiB
JavaScript
Raw Permalink Normal View History

const chaiHttp = require('chai-http');
const chai = require('chai');
const assert = chai.assert;
const server = require('../server');
chai.use(chaiHttp);
suite('Functional Tests', () => {
suite('POST requests', () => {
test('Create an issue with every field: POST request to /api/issues/{project}', (done) => {
chai
.request(server)
.post('/api/issues/apitest')
.send({
"issue_title": "Test issue",
"issue_text": "This is a test",
"created_by": "sammy",
"assigned_to": "sammy",
"status_text": "none"
})
.end((err, res) => {
assert.equal(res.status, 200)
assert.equal(res.body.issue_title, 'Test issue')
assert.equal(res.body.issue_text, 'This is a test')
assert.equal(res.body.created_by, 'sammy')
assert.equal(res.body.assigned_to, 'sammy')
assert.equal(res.body.status_text, 'none')
assert.equal(res.body.open, true)
assert.isOk(res.body._id)
assert.isOk(res.body.created_on)
assert.isOk(res.body.updated_on)
done()
})
})
test('Create an issue with only required fields: POST request to /api/issues/{project}', (done) => {
chai
.request(server)
.post('/api/issues/apitest')
.send({
"issue_title": "Test issue",
"issue_text": "This is a test",
"created_by": "sammy"
})
.end((err, res) => {
assert.equal(res.status, 200)
assert.equal(res.body.issue_title, 'Test issue')
assert.equal(res.body.issue_text, 'This is a test')
assert.equal(res.body.created_by, 'sammy')
assert.equal(res.body.assigned_to, '')
assert.equal(res.body.status_text, '')
assert.exists(res.body._id)
done()
})
})
test('Create an issue with missing required fields: POST request to /api/issues/{project}', (done) => {
chai
.request(server)
.post('/api/issues/apitest')
.send({
"issue_title": "Test issue",
"issue_text": "This is a test",
})
.end((err, res) => {
assert.equal(res.body.error, 'required field(s) missing')
done()
})
})
})
suite('GET requests', () => {
test('View issues on a project: GET request to /api/issues/{project}', (done) => {
chai
.request(server)
.get('/api/issues/apitest')
.end((err, res) => {
assert.equal(res.status, 200)
assert.exists(res.body[0])
assert.exists(res.body[0].issue_title)
done()
})
})
test('View issues on a project with one filter: GET request to /api/issues/{project}', (done) => {
chai
.request(server)
.get('/api/issues/apitest')
.query({open: false})
.end((err, res) => {
assert.equal(res.body[0].open, false)
done()
})
})
test('View issues on a project with multiple filters: GET request to /api/issues/{project}', (done) => {
chai
.request(server)
.get('/api/issues/apitest')
.query({open: false, assigned_to: 'nobody'})
.end((err, res) => {
assert.equal(res.body[0].open, false)
assert.equal(res.body[0].assigned_to, 'nobody')
done()
})
})
})
suite('PUT requests', () => {
test('Update one field on an issue: PUT request to /api/issues/{project}', (done) => {
chai
.request(server)
.put('/api/issues/apitest')
.send({_id: '63657aca0afa26c228f5e0c1', open: false})
.end((err, res) => {
assert.equal(res.body.result, 'successfully updated')
assert.equal(res.body._id, '63657aca0afa26c228f5e0c1')
done()
})
})
test('Update multiple fields on an issue: PUT request to /api/issues/{project}', (done) => {
chai
.request(server)
.put('/api/issues/apitest')
.send({_id: '63657ac80afa26c228f5e0bf', open: false, assigned_to: 'not sammy'})
.end((err, res) => {
assert.equal(res.body.result, 'successfully updated')
assert.equal(res.body._id, '63657ac80afa26c228f5e0bf')
done()
})
})
test('Update an issue with missing _id: PUT request to /api/issues/{project}', (done) => {
chai
.request(server)
.put('/api/issues/apitest')
.send({open: false})
.end((err, res) => {
assert.equal(res.body.error, 'missing _id')
done()
})
})
test('Update an issue with no fields to update: PUT request to /api/issues/{project}', (done) => {
chai
.request(server)
.put('/api/issues/apitest')
.send({_id: '63657911922d375e25ad1b85'})
.end((err, res) => {
assert.equal(res.body.error, 'no update field(s) sent')
assert.equal(res.body._id, '63657911922d375e25ad1b85')
done()
})
})
test('Update an issue with an invalid _id: PUT request to /api/issues/{project}', (done) => {
chai
.request(server)
.put('/api/issues/apitest')
.send({_id: 'invalid', open: false})
.end((err, res) => {
assert.equal(res.body.error, 'could not update')
assert.equal(res.body._id, 'invalid')
done()
})
})
})
suite('DELETE requests', () => {
test('Delete an issue: DELETE request to /api/issues/{project}', (done) => {
chai
.request(server)
.delete('/api/issues/apitest')
.send({_id: '63657911922d375e25ad1b85'})
.end((err, res) => {
assert.equal(res.body.result, 'successfully deleted')
assert.equal(res.body._id, '63657911922d375e25ad1b85')
done()
})
})
test('Delete an issue with an invalid _id: DELETE request to /api/issues/{project}', (done) => {
chai
.request(server)
.delete('/api/issues/apitest')
.send({_id: 'INVALID STILL'})
.end((err, res) => {
assert.equal(res.body.error, 'could not delete')
assert.equal(res.body._id, 'INVALID STILL')
done()
})
})
test('Delete an issue with missing _id: DELETE request to /api/issues/{project}', (done) => {
chai
.request(server)
.delete('/api/issues/apitest')
.end((err, res) => {
assert.equal(res.body.error, 'missing _id')
done()
})
})
})
});