CartoDB-SQL-API/test/acceptance/backend_crash.js

88 lines
2.4 KiB
JavaScript
Raw Normal View History

require('../helper');
2015-05-13 17:21:44 +08:00
var assert = require('../support/assert');
var step = require('step');
var net = require('net');
var sql_server_port = 5540;
var sql_server = net.createServer(function(c) {
console.log('server connected');
c.destroy();
console.log('server socket destroyed.');
sql_server.close(function() {
console.log('server closed');
});
});
2015-05-13 17:21:44 +08:00
describe('backend crash', function() {
2015-05-13 17:21:44 +08:00
before(function(done){
sql_server.listen(sql_server_port, done);
});
// See https://github.com/CartoDB/CartoDB-SQL-API/issues/135
2015-05-13 17:21:44 +08:00
it('does not hang server', function(done){
//console.log("settings:"); console.dir(global.settings);
var db_host_backup = global.settings.db_host;
var db_port_backup = global.settings.db_port;
global.settings.db_host = 'localhost';
global.settings.db_port = sql_server_port;
2015-12-04 01:33:17 +08:00
var app = require(global.settings.app_root + '/app/app')();
2015-05-13 17:21:44 +08:00
step(
function sendQuery() {
var next = this;
assert.response(app, {
url: '/api/v1/sql?q=SELECT+1',
method: 'GET',
headers: {host: 'vizzuality.localhost' }
},{}, function(res, err) {
next(err, res);
});
},
function checkResponse(err, res) {
2015-05-13 17:21:44 +08:00
assert.ifError(err);
assert.equal(res.statusCode, 500, res.statusCode + ': ' + res.body);
var parsed = JSON.parse(res.body);
assert.ok(parsed.error);
var msg = parsed.error[0];
assert.ok(msg.match(/unexpected.*end/), msg);
return null;
},
function sendAnotherQuery() {
var next = this;
assert.response(app, {
url: '/api/v1/sql?q=SELECT+2',
method: 'GET',
headers: {host: 'vizzuality.localhost' }
},{}, function(res, err) {
next(err, res);
});
},
function checkResponse(err, res) {
2015-05-13 17:21:44 +08:00
assert.ifError(err);
assert.equal(res.statusCode, 500, res.statusCode + ': ' + res.body);
var parsed = JSON.parse(res.body);
assert.ok(parsed.error);
var msg = parsed.error[0];
assert.ok(msg.match(/connect/), msg);
return null;
},
function finish(err) {
global.settings.db_host = db_host_backup;
global.settings.db_port = db_port_backup;
done(err);
}
);
});
2015-05-13 17:21:44 +08:00
after(function(done) {
try {
sql_server.close(done);
} catch (er) {
console.log(er);
done(); // error expected as server is probably closed already
}
});
});