* fixing enableExpressErrorHandler logic * Fix tests Co-authored-by: n.andryukhin <n.andryukhin@mediasoft.team> Co-authored-by: Diamond Lewis <findlewis@gmail.com>
55 lines
1.7 KiB
JavaScript
55 lines
1.7 KiB
JavaScript
const ParseServer = require('../lib/index');
|
|
const express = require('express');
|
|
const request = require('../lib/request');
|
|
|
|
describe('Enable express error handler', () => {
|
|
it('should call the default handler in case of error, like updating a non existing object', done => {
|
|
const serverUrl = 'http://localhost:12667/parse';
|
|
const appId = 'anOtherTestApp';
|
|
const masterKey = 'anOtherTestMasterKey';
|
|
let server;
|
|
|
|
const parseServer = ParseServer.ParseServer(
|
|
Object.assign({}, defaultConfiguration, {
|
|
appId: appId,
|
|
masterKey: masterKey,
|
|
serverURL: serverUrl,
|
|
enableExpressErrorHandler: true,
|
|
serverStartComplete: () => {
|
|
expect(Parse.applicationId).toEqual('anOtherTestApp');
|
|
const app = express();
|
|
app.use('/parse', parseServer);
|
|
|
|
server = app.listen(12667);
|
|
|
|
app.use(function(err, req, res, next) {
|
|
expect(err.message).toBe('Object not found.');
|
|
next(err);
|
|
});
|
|
|
|
request({
|
|
method: 'PUT',
|
|
url: serverUrl + '/classes/AnyClass/nonExistingId',
|
|
headers: {
|
|
'X-Parse-Application-Id': appId,
|
|
'X-Parse-Master-Key': masterKey,
|
|
'Content-Type': 'application/json',
|
|
},
|
|
body: { someField: 'blablabla' },
|
|
})
|
|
.then(() => {
|
|
fail('Should throw error');
|
|
})
|
|
.catch(response => {
|
|
expect(response).toBeDefined();
|
|
expect(response.status).toEqual(500);
|
|
})
|
|
.then(() => {
|
|
server.close(done);
|
|
});
|
|
},
|
|
})
|
|
);
|
|
});
|
|
});
|