codecombat/spec/helpers/helper.js
2016-07-18 10:56:25 -07:00

129 lines
3.6 KiB
JavaScript

var _ = require('lodash');
require('coffee-script');
require('coffee-script/register');
// Various assurances that in running tests, we don't accidentally run them
// on the production DB.
// 1. Make sure there are no environmental variables for COCO_ in place
var allowedKeys = [
'COCO_TRAVIS_TEST'
];
var cocoKeysPresent = _.any(_.keys(process.env), function(envKey) {
return envKey.indexOf('COCO_') >= 0 && !_.contains(allowedKeys, envKey);
});
if (cocoKeysPresent) {
throw Error('Stopping server tests because COCO_ environmental variables are present.');
}
// 2. Clear environmental variables anyway
process.env = {};
// 3. Check server_config
global.testing = true;
var config = require('../../server_config');
if(config.mongo.host !== 'localhost') {
throw Error('Stopping server tests because mongo host is not localhost.');
}
// 4. Check database string
var database = require('../../server/commons/database');
var dbString = 'mongodb://localhost:27017/coco_unittest';
if (database.generateMongoConnectionString() !== dbString) {
throw Error('Stopping server tests because db connection string was not as expected.');
}
jasmine.DEFAULT_TIMEOUT_INTERVAL = 1000 * 15; // for long Stripe tests
require('../server/common'); // Make sure global testing functions are set up
// Ignore Stripe/Nocking erroring
console.error = function() {
try {
if(arguments[1].stack.indexOf('An error occurred with our connection to Stripe') > -1)
return;
}
catch (e) { }
console.log.apply(console, arguments);
};
if (process.argv.indexOf('--with-test-names') > -1) {
jasmine.getEnv().addReporter({
specStarted: function(result){
// Printing weirdly so pass/fail indicator is on the same line as the test name
process.stdout.write('\n' + result.fullName);
}
})
}
var initialized = false;
beforeEach(function(done) {
if (initialized) {
return done();
}
console.log('/spec/helpers/helper.js - Initializing spec environment...');
var async = require('async');
async.series([
function(cb) {
// Start the server
var server = require('../../server');
server.startServer(cb);
},
function(cb) {
// 5. Check actual database
var User = require('../../server/models/User');
User.find({}).count(function(err, count) {
// For this to serve as a line of defense against testing with the
// production DB, tests must be run with
expect(err).toBeNull();
expect(count).toBeLessThan(100);
if(err || count >= 100) {
// the only way to be sure we don't keep going with the tests
process.exit(1);
}
GLOBAL.mc.lists.subscribe = _.noop;
cb()
});
},
function(cb) {
// Clear db
var mongoose = require('mongoose');
mongoose.connection.db.command({dropDatabase:1}, function(err, result) {
if (err) { console.log(err); }
cb(err);
});
},
function(cb) {
// Initialize products
var utils = require('../server/utils');
request = require('../server/request');
utils.initUser()
.then(function (user) {
return utils.loginUser(user, {request: request})
})
.then(function () {
cb()
});
},
function(cb) {
// Initialize products
request = require('../server/request');
request.get(getURL('/db/products'), function(err, res, body) {
expect(err).toBe(null);
expect(res.statusCode).toBe(200);
cb(err);
});
}
],
function(err) {
if (err) {
process.exit(1);
}
initialized = true;
console.log('/spec/helpers/helper.js - Done');
done();
});
});