var should = require('should'), // jshint ignore:line sinon = require('sinon'), rewire = require('rewire'), _ = require('lodash'), Promise = require('bluebird'), crypto = require('crypto'), fs = require('fs'), models = require('../../server/models'), exporter = require('../../server/data/export'), schema = require('../../server/data/schema'), backupDatabase = rewire('../../server/data/db/backup'), fixtures = require('../../server/data/schema/fixtures'), sandbox = sinon.sandbox.create(); /** * @NOTE * * If this test fails for you, you have modified the database schema or fixtures. * When you make a change, please test that: * * 1. A new blog get's installed and the database looks correct and complete. * 2. A blog get's updated from a lower Ghost version and the database looks correct and complete. * * Typical cases: * You have to add a migration script if you've added/modified permissions. * You have to add a migration script if you've add a new table. */ describe('DB version integrity', function () { // Only these variables should need updating var currentSchemaHash = '329f9b498944c459040426e16fc65b11', currentFixturesHash = '90925e0004a0cedd1e6ea789c81ec67d'; // If this test is failing, then it is likely a change has been made that requires a DB version bump, // and the values above will need updating as confirmation it('should not change without fixing this test', function () { var tablesNoValidation = _.cloneDeep(schema.tables), schemaHash, fixturesHash; _.each(tablesNoValidation, function (table) { return _.each(table, function (column, name) { table[name] = _.omit(column, 'validations'); }); }); schemaHash = crypto.createHash('md5').update(JSON.stringify(tablesNoValidation), 'binary').digest('hex'); fixturesHash = crypto.createHash('md5').update(JSON.stringify(fixtures), 'binary').digest('hex'); schemaHash.should.eql(currentSchemaHash); fixturesHash.should.eql(currentFixturesHash); }); }); describe('Migrations', function () { before(function () { models.init(); }); afterEach(function () { sandbox.restore(); }); describe('Backup', function () { var exportStub, filenameStub, fsStub; beforeEach(function () { exportStub = sandbox.stub(exporter, 'doExport').returns(new Promise.resolve()); filenameStub = sandbox.stub(exporter, 'fileName').returns(new Promise.resolve('test')); fsStub = sandbox.stub(fs, 'writeFile').yields(); }); it('should create a backup JSON file', function (done) { backupDatabase().then(function () { exportStub.calledOnce.should.be.true(); filenameStub.calledOnce.should.be.true(); fsStub.calledOnce.should.be.true(); done(); }).catch(done); }); }); });