mirror of
https://github.com/naturalcrit/homebrewery.git
synced 2026-01-13 06:32:39 +00:00
Added in full test coverage of current spec
This commit is contained in:
114
test/api.test.js
Normal file
114
test/api.test.js
Normal file
@@ -0,0 +1,114 @@
|
||||
const testing = require('./test.init.js');
|
||||
const request = require('supertest-as-promised');
|
||||
const jwt = require('jwt-simple');
|
||||
const config = require('nconf');
|
||||
|
||||
const app = require('app.js');
|
||||
const DB = require('db.js');
|
||||
const BrewData = require('brew.data.js');
|
||||
const Error = require('error.js');
|
||||
|
||||
const apiPath = '/api/brew';
|
||||
|
||||
let session_token;
|
||||
const test_user = {
|
||||
username : 'cool guy'
|
||||
};
|
||||
let storedBrew = {
|
||||
title : 'good title',
|
||||
text : 'original text',
|
||||
authors : ['your_dm']
|
||||
};
|
||||
|
||||
describe('Brew API', () => {
|
||||
before('Connect DB', DB.connect);
|
||||
before('Clear DB', BrewData.removeAll);
|
||||
before('Create session token', () => {
|
||||
session_token = jwt.encode(test_user, config.get('secret'));
|
||||
});
|
||||
before('Create brew', ()=>{
|
||||
return BrewData.create(storedBrew)
|
||||
.then((brew)=>{ storedBrew = brew; });
|
||||
});
|
||||
|
||||
|
||||
describe('Create', () => {
|
||||
it('creates a new brew', () => {
|
||||
return request(app)
|
||||
.post(apiPath)
|
||||
.send({ text : 'Brew Text' })
|
||||
.expect(200)
|
||||
.then((res) => {
|
||||
const brew = res.body;
|
||||
brew.should.have.property('editId').that.is.a('string');
|
||||
brew.should.have.property('shareId').that.is.a('string');
|
||||
brew.should.have.property('text').equal('Brew Text');
|
||||
brew.should.not.have.property('_id');
|
||||
});
|
||||
});
|
||||
|
||||
it('creates a new brew with a session author', () => {
|
||||
return request(app)
|
||||
.post(apiPath)
|
||||
.set('Cookie', `nc_session=${session_token}`)
|
||||
.send({ text : 'Brew Text' })
|
||||
.expect(200)
|
||||
.then((res) => {
|
||||
const brew = res.body;
|
||||
brew.should.have.property('authors').include(test_user.username);
|
||||
});
|
||||
});
|
||||
});
|
||||
|
||||
describe('Update', () => {
|
||||
it('updates an existing brew', () => {
|
||||
return request(app)
|
||||
.put(`${apiPath}/${storedBrew.editId}`)
|
||||
.send({ text : 'New Text' })
|
||||
.expect(200)
|
||||
.then((res) => {
|
||||
const brew = res.body;
|
||||
brew.should.have.property('editId').equal(storedBrew.editId);
|
||||
brew.should.have.property('text').equal('New Text');
|
||||
brew.should.have.property('authors').include('your_dm');
|
||||
brew.should.not.have.property('_id');
|
||||
});
|
||||
});
|
||||
|
||||
it('adds the user as author', () => {
|
||||
return request(app)
|
||||
.put(`${apiPath}/${storedBrew.editId}`)
|
||||
.set('Cookie', `nc_session=${session_token}`)
|
||||
.send({ text : 'New Text' })
|
||||
.expect(200)
|
||||
.then((res) => {
|
||||
const brew = res.body;
|
||||
brew.should.have.property('authors').include(test_user.username);
|
||||
brew.should.have.property('authors').include('your_dm');
|
||||
});
|
||||
});
|
||||
it('should throw error on bad edit id', ()=>{
|
||||
return request(app)
|
||||
.put(`${apiPath}/BADEDITID`)
|
||||
.send({ text : 'New Text' })
|
||||
.expect(404)
|
||||
});
|
||||
});
|
||||
|
||||
describe('Remove', () => {
|
||||
it('should removes a brew', ()=>{
|
||||
return request(app)
|
||||
.del(`${apiPath}/${storedBrew.editId}`)
|
||||
.send()
|
||||
.expect(200)
|
||||
.then(() => {
|
||||
BrewData.getByEdit(storedBrew.editId)
|
||||
.then(() => { throw 'Brew found when one should not have been'; })
|
||||
.catch((err) => {
|
||||
err.should.be.instanceof(Error.noBrew);
|
||||
})
|
||||
});
|
||||
});
|
||||
});
|
||||
|
||||
});
|
||||
@@ -1,35 +0,0 @@
|
||||
const testing = require('./test.init.js');
|
||||
const request = require('supertest-as-promised');
|
||||
|
||||
const app = require('app.js');
|
||||
const BrewDB = require('db.js');
|
||||
|
||||
|
||||
describe('/api/brew', () => {
|
||||
const apiPath = '/api/brew';
|
||||
|
||||
before('Await DB', ()=>{
|
||||
return BrewDB.connect()
|
||||
});
|
||||
|
||||
describe('POST', () => {
|
||||
it('creates a new brew', () => {
|
||||
return request(app)
|
||||
.post(apiPath)
|
||||
.send({
|
||||
text : 'Brew Text'
|
||||
})
|
||||
.expect(200)
|
||||
.then((res) => {
|
||||
const brew = res.body;
|
||||
//should.exist(brew);
|
||||
brew.should.have.property('editId').that.is.a('string');
|
||||
brew.should.have.property('shareId').that.is.a('string');
|
||||
brew.should.have.property('text').that.is.a('string');
|
||||
})
|
||||
});
|
||||
|
||||
});
|
||||
|
||||
|
||||
});
|
||||
@@ -1,24 +0,0 @@
|
||||
const testing = require('./test.init.js');
|
||||
|
||||
const BrewDB = require('db.js');
|
||||
const BrewData = require('brew.data.js');
|
||||
|
||||
|
||||
describe('BrewDB', () => {
|
||||
before('Await DB', ()=>{
|
||||
return BrewDB.connect()
|
||||
});
|
||||
|
||||
it('generates ID on save', () => {
|
||||
return BrewData.create({
|
||||
text : "Brew Text"
|
||||
}).then((brew) => {
|
||||
//should.exist(brew);
|
||||
brew.should.have.property('editId').that.is.a('string');
|
||||
brew.should.have.property('shareId').that.is.a('string');
|
||||
brew.should.have.property('text').that.is.a('string');
|
||||
})
|
||||
|
||||
});
|
||||
|
||||
});
|
||||
108
test/brew.test.js
Normal file
108
test/brew.test.js
Normal file
@@ -0,0 +1,108 @@
|
||||
const testing = require('./test.init.js');
|
||||
|
||||
const DB = require('db.js');
|
||||
const BrewData = require('brew.data.js');
|
||||
const Error = require('error.js');
|
||||
|
||||
|
||||
let storedBrew = {
|
||||
title : 'good title',
|
||||
text : 'original text'
|
||||
};
|
||||
|
||||
describe('Brew Data', () => {
|
||||
before('Connect DB', DB.connect);
|
||||
before('Clear DB', BrewData.removeAll);
|
||||
before('Create brew', ()=>{
|
||||
return BrewData.create(storedBrew)
|
||||
.then((brew)=>{ storedBrew = brew; });
|
||||
});
|
||||
|
||||
it('generates edit/share ID on create', () => {
|
||||
return BrewData.create({
|
||||
text : 'Brew Text'
|
||||
}).then((brew) => {
|
||||
brew.should.have.property('editId').that.is.a('string');
|
||||
brew.should.have.property('shareId').that.is.a('string');
|
||||
brew.should.have.property('text').that.is.a('string');
|
||||
brew.should.have.property('views').equal(0);
|
||||
});
|
||||
});
|
||||
|
||||
it('generates edit/share ID on create even if given one', () => {
|
||||
return BrewData.create({
|
||||
editId : 'NOPE',
|
||||
shareId : 'NOTTA'
|
||||
}).then((brew) => {
|
||||
brew.should.have.property('editId').not.equal('NOPE');
|
||||
brew.should.have.property('shareId').not.equal('NOTTA');
|
||||
});
|
||||
});
|
||||
|
||||
|
||||
it('can update an existing brew', () => {
|
||||
return BrewData.update(storedBrew.editId,{
|
||||
text : 'New Text'
|
||||
}).then((brew) => {
|
||||
brew.should.have.property('editId').equal(storedBrew.editId);
|
||||
brew.should.have.property('text').equal('New Text');
|
||||
brew.should.have.property('title').equal(storedBrew.title);
|
||||
})
|
||||
});
|
||||
|
||||
|
||||
it('properly returns a brew if retrieved by just share', () => {
|
||||
return BrewData.getByShare(storedBrew.shareId)
|
||||
.then((brew) => {
|
||||
brew.should.not.have.property('editId');
|
||||
brew.should.have.property('shareId').equal(storedBrew.shareId);
|
||||
brew.should.have.property('views').equal(1);
|
||||
})
|
||||
});
|
||||
|
||||
|
||||
it('can properly remove a brew', () => {
|
||||
return BrewData.remove(storedBrew.editId)
|
||||
.then(() => {
|
||||
return BrewData.getByEdit(storedBrew.editId)
|
||||
})
|
||||
.then(() => { throw 'Brew found when one should not have been'; })
|
||||
.catch((err) => {
|
||||
err.should.be.an.instanceof(Error.noBrew);
|
||||
});
|
||||
});
|
||||
|
||||
it('throws the right error if can not find brew', () => {
|
||||
return BrewData.getByEdit('NOT A REAL ID')
|
||||
.then(() => { throw 'Brew found when one should not have been'; })
|
||||
.catch((err) => {
|
||||
err.should.be.an.instanceof(Error.noBrew);
|
||||
});
|
||||
});
|
||||
|
||||
describe('Title Generation', () => {
|
||||
it('should use the title if given one', () => {
|
||||
return BrewData.create({
|
||||
title : 'Actual Title',
|
||||
text : '# Not this'
|
||||
}).then((brew) => {
|
||||
brew.should.have.property('title').equal('Actual Title');
|
||||
});
|
||||
});
|
||||
it('should use the first header found if no title provided', () => {
|
||||
return BrewData.create({
|
||||
text : 'Not this \n # But This'
|
||||
}).then((brew) => {
|
||||
brew.should.have.property('title').equal('But This');
|
||||
})
|
||||
});
|
||||
it('should use the first line if no headers are found', () => {
|
||||
return BrewData.create({
|
||||
text : 'First line \n second line'
|
||||
}).then((brew) => {
|
||||
brew.should.have.property('title').equal('First line');
|
||||
});
|
||||
});
|
||||
});
|
||||
|
||||
});
|
||||
0
test/markdown.test.js
Normal file
0
test/markdown.test.js
Normal file
124
test/middleware.test.js
Normal file
124
test/middleware.test.js
Normal file
@@ -0,0 +1,124 @@
|
||||
const _ = require('lodash');
|
||||
const testing = require('./test.init.js');
|
||||
const request = require('supertest-as-promised');
|
||||
const jwt = require('jwt-simple');
|
||||
|
||||
const DB = require('db.js');
|
||||
const BrewData = require('brew.data.js');
|
||||
const Error = require('error.js');
|
||||
|
||||
const config = require('nconf');
|
||||
const mw = require('middleware.js');
|
||||
|
||||
const requestHandler = (req, res) => {
|
||||
return res.status(200).json(_.pick(req, ['brew', 'account', 'admin', 'params', 'query', 'body']));
|
||||
};
|
||||
|
||||
const test_user = {
|
||||
username : 'cool guy'
|
||||
};
|
||||
|
||||
describe('Middleware', () => {
|
||||
let app = undefined;
|
||||
let session_token = '';
|
||||
|
||||
before('create session token', () => {
|
||||
session_token = jwt.encode(test_user, config.get('secret'));
|
||||
});
|
||||
beforeEach('setup test server', ()=>{
|
||||
app = require('express')();
|
||||
app.use(require('cookie-parser')());
|
||||
});
|
||||
|
||||
describe('Account', ()=>{
|
||||
it('should get the account for a session', () => {
|
||||
app.use(mw.account);
|
||||
app.use(requestHandler)
|
||||
return request(app).get('/')
|
||||
.set('Cookie', `nc_session=${session_token}`)
|
||||
.send()
|
||||
.expect(200)
|
||||
.then((res) => {
|
||||
const req = res.body;
|
||||
req.should.have.property('account').is.a('object');
|
||||
req.account.should.have.property('username').equal(test_user.username);
|
||||
});
|
||||
});
|
||||
it('should not have an account for an invalid session', () => {
|
||||
app.use(mw.account);
|
||||
app.use(requestHandler)
|
||||
return request(app).get('/')
|
||||
.set('Cookie', `nc_session=BADSESSION`)
|
||||
.send()
|
||||
.expect(200)
|
||||
.then((res) => {
|
||||
const req = res.body;
|
||||
req.should.not.have.property('account');
|
||||
});
|
||||
});
|
||||
});
|
||||
|
||||
|
||||
describe('Brew', ()=>{
|
||||
let storedBrew = {
|
||||
text : 'brew brew',
|
||||
authors : [test_user.username]
|
||||
};
|
||||
before('Connect DB', DB.connect);
|
||||
before('Clear DB', BrewData.removeAll);
|
||||
before('Create brew', ()=>{
|
||||
return BrewData.create(storedBrew)
|
||||
.then((brew)=>{ storedBrew = brew; });
|
||||
});
|
||||
|
||||
it('should load brew with editId params', ()=>{
|
||||
app.get('/:editId', mw.loadBrew, requestHandler);
|
||||
return request(app).get('/' + storedBrew.editId)
|
||||
.send()
|
||||
.expect(200)
|
||||
.then((res) => {
|
||||
const req = res.body;
|
||||
req.should.have.property('brew').is.a('object');
|
||||
req.brew.should.have.property('editId').equal(storedBrew.editId);
|
||||
});
|
||||
});
|
||||
|
||||
it('should view brew with shareId params', ()=>{
|
||||
app.get('/:shareId', mw.viewBrew, requestHandler);
|
||||
return request(app).get('/' + storedBrew.shareId)
|
||||
.send()
|
||||
.expect(200)
|
||||
.then((res) => {
|
||||
const req = res.body;
|
||||
req.should.have.property('brew').is.a('object');
|
||||
req.brew.should.not.have.property('editId');
|
||||
req.brew.should.have.property('shareId').equal(storedBrew.shareId);
|
||||
req.brew.should.have.property('views').equal(1);
|
||||
});
|
||||
});
|
||||
});
|
||||
|
||||
describe('Admin', ()=>{
|
||||
it('should detect when you use the admin key', () => {
|
||||
app.use(mw.admin);
|
||||
app.use(requestHandler)
|
||||
return request(app).get(`/?admin_key=${config.get('admin_key')}`)
|
||||
.send()
|
||||
.expect(200)
|
||||
.then((res) => {
|
||||
const req = res.body;
|
||||
req.should.have.property('admin').equal(true);
|
||||
});
|
||||
});
|
||||
it('should block you if you are not an admin', ()=>{
|
||||
app.use(mw.admin);
|
||||
app.use(mw.adminOnly);
|
||||
app.get('/', (req, res) => { return res.status(200).send(); });
|
||||
app.use(Error.expressHandler);
|
||||
return request(app).get(`/?admin_key=BADKEY`)
|
||||
.send()
|
||||
.expect(401);
|
||||
});
|
||||
});
|
||||
|
||||
});
|
||||
0
test/search.test.js
Normal file
0
test/search.test.js
Normal file
Reference in New Issue
Block a user