mirror of
https://github.com/TryGhost/Ghost.git
synced 2025-01-20 22:42:53 -05:00
869a35c97d
* 🎨 move heart of fixtures to schema folder and change user model - add fixtures.json to schema folder - add fixture utils to schema folder - keep all the logic! --> FIXTURE.JSON - add owner user with roles --> USER MODEL - add password as default - findAll: allow querying inactive users when internal context (defaultFilters) - findOne: do not remove values from original object! - add: do not remove values from original object! * 🔥 remove migrations key from default_settings.json - this was a temporary invention for an older migration script - sephiroth keep alls needed information in a migration collection * 🔥 add code property to errors - add code property to errors - IMPORTANT: please share your opinion about that - this is a copy paste behaviour of how node is doing that (errno, code etc.) - so code specifies a GhostError * 🎨 change error handling in versioning - no need to throw specific database errors anymore (this was just a temporary solution) - now: we are throwing real DatabaseVersionErrors - specified by a code - background: the versioning unit has not idea about seeding and population of the database - it just throws what it knows --> database version does not exist or settings table does not exist * 🎨 sephiroth optimisations - added getPath function to get the path to init scripts and migration scripts - migrationPath is still hardcoded (see TODO) - tidy up database naming to transacting * ✨ migration init scripts are now complete - 1. add tables - 2. add fixtures - 3. add default settings * 🎨 important: make bootup script smaller! - remove all TODO'S except of one - no seeding logic in bootup script anymore 🕵🏻 * ✨ sephiroth: allow params for init command - param: skip (do not run this script) - param: only (only run this script) - very simple way * 🎨 adapt tests and test env - do not use migrate.populate anymore - use sephiroth instead - jscs/jshint * 🎨 fix User model status checks
213 lines
8.2 KiB
JavaScript
213 lines
8.2 KiB
JavaScript
var should = require('should'),
|
|
sinon = require('sinon'),
|
|
Promise = require('bluebird'),
|
|
|
|
// Stuff we are testing
|
|
versioning = require('../../server/data/schema').versioning,
|
|
db = require('../../server/data/db'),
|
|
errors = require('../../server/errors'),
|
|
|
|
sandbox = sinon.sandbox.create();
|
|
|
|
describe('Versioning', function () {
|
|
afterEach(function () {
|
|
sandbox.restore();
|
|
});
|
|
|
|
describe('getMigrationVersions', function () {
|
|
it('should output a single item if the from and to versions are the same', function () {
|
|
should.exist(versioning.getMigrationVersions);
|
|
versioning.getMigrationVersions('1.0', '1.0').should.eql([]);
|
|
versioning.getMigrationVersions('1.2', '1.2').should.eql([]);
|
|
});
|
|
|
|
it('should output an empty array if the toVersion is higher than the fromVersion', function () {
|
|
versioning.getMigrationVersions('1.2', '1.1').should.eql([]);
|
|
});
|
|
|
|
it('should output all the versions between two versions', function () {
|
|
versioning.getMigrationVersions('1.0', '1.1').should.eql(['1.1']);
|
|
versioning.getMigrationVersions('1.0', '1.2').should.eql(['1.1', '1.2']);
|
|
versioning.getMigrationVersions('1.2', '1.5').should.eql(['1.3', '1.4', '1.5']);
|
|
versioning.getMigrationVersions('2.1', '2.2').should.eql(['2.2']);
|
|
});
|
|
});
|
|
|
|
describe('getNewestDatabaseVersion', function () {
|
|
it('should return the correct version', function () {
|
|
var currentVersion = '1.0';
|
|
|
|
// This function has an internal cache, so we call it twice.
|
|
// First, to check that it fetches the correct version from default-settings.json.
|
|
versioning.getNewestDatabaseVersion().should.eql(currentVersion);
|
|
// Second, to check that it returns the same value from the cache.
|
|
versioning.getNewestDatabaseVersion().should.eql(currentVersion);
|
|
});
|
|
});
|
|
|
|
describe('getDatabaseVersion', function () {
|
|
var knexStub, knexMock, queryMock;
|
|
|
|
beforeEach(function () {
|
|
queryMock = {
|
|
where: sandbox.stub().returnsThis(),
|
|
first: sandbox.stub()
|
|
};
|
|
|
|
knexMock = sandbox.stub().returns(queryMock);
|
|
knexMock.schema = {
|
|
hasTable: sandbox.stub()
|
|
};
|
|
|
|
// this MUST use sinon, not sandbox, see sinonjs/sinon#781
|
|
knexStub = sinon.stub(db, 'knex', {
|
|
get: function () {
|
|
return knexMock;
|
|
}
|
|
});
|
|
});
|
|
|
|
afterEach(function () {
|
|
knexStub.restore();
|
|
});
|
|
|
|
it('should throw error if settings table does not exist', function (done) {
|
|
// Setup
|
|
knexMock.schema.hasTable.returns(new Promise.resolve(false));
|
|
|
|
// Execute
|
|
versioning.getDatabaseVersion().then(function () {
|
|
done('Should throw an error if the settings table does not exist');
|
|
}).catch(function (err) {
|
|
should.exist(err);
|
|
(err instanceof errors.DatabaseVersionError).should.eql(true);
|
|
|
|
knexStub.get.calledOnce.should.be.true();
|
|
knexMock.schema.hasTable.calledOnce.should.be.true();
|
|
knexMock.schema.hasTable.calledWith('settings').should.be.true();
|
|
queryMock.where.called.should.be.false();
|
|
queryMock.first.called.should.be.false();
|
|
done();
|
|
}).catch(done);
|
|
});
|
|
|
|
it('should lookup & return version, if settings table exists', function (done) {
|
|
// Setup
|
|
knexMock.schema.hasTable.returns(new Promise.resolve(true));
|
|
queryMock.first.returns(new Promise.resolve({value: '1.0'}));
|
|
|
|
// Execute
|
|
versioning.getDatabaseVersion().then(function (version) {
|
|
should.exist(version);
|
|
version.should.eql('1.0');
|
|
|
|
knexStub.get.calledTwice.should.be.true();
|
|
knexMock.schema.hasTable.calledOnce.should.be.true();
|
|
knexMock.schema.hasTable.calledWith('settings').should.be.true();
|
|
queryMock.where.called.should.be.true();
|
|
queryMock.first.called.should.be.true();
|
|
|
|
done();
|
|
}).catch(done);
|
|
});
|
|
|
|
// @TODO change this so we handle a non-existent version?
|
|
// There is an open bug in Ghost around this:
|
|
// https://github.com/TryGhost/Ghost/issues/7345
|
|
// I think it is a timing error
|
|
it.skip('should throw error if version does not exist', function (done) {
|
|
// Setup
|
|
knexMock.schema.hasTable.returns(new Promise.resolve(true));
|
|
queryMock.first.returns(new Promise.resolve());
|
|
|
|
// Execute
|
|
versioning.getDatabaseVersion().then(function () {
|
|
done('Should throw an error if version does not exist');
|
|
}).catch(function (err) {
|
|
should.exist(err);
|
|
(err instanceof errors.DatabaseVersionError).should.eql(true);
|
|
|
|
knexStub.get.calledTwice.should.be.true();
|
|
knexMock.schema.hasTable.calledOnce.should.be.true();
|
|
knexMock.schema.hasTable.calledWith('settings').should.be.true();
|
|
queryMock.where.called.should.be.true();
|
|
queryMock.first.called.should.be.true();
|
|
|
|
done();
|
|
}).catch(done);
|
|
});
|
|
|
|
// @TODO decide on a new scheme for database versioning and update
|
|
// how we validate those versions
|
|
it.skip('should throw error if version is not a number', function (done) {
|
|
// Setup
|
|
knexMock.schema.hasTable.returns(new Promise.resolve(true));
|
|
queryMock.first.returns(new Promise.resolve('Eyjafjallajökull'));
|
|
|
|
// Execute
|
|
versioning.getDatabaseVersion().then(function () {
|
|
done('Should throw an error if version is not a number');
|
|
}).catch(function (err) {
|
|
should.exist(err);
|
|
(err instanceof errors.DatabaseVersionError).should.eql(true);
|
|
|
|
knexStub.get.calledTwice.should.be.true();
|
|
knexMock.schema.hasTable.calledOnce.should.be.true();
|
|
knexMock.schema.hasTable.calledWith('settings').should.be.true();
|
|
queryMock.where.called.should.be.true();
|
|
queryMock.first.called.should.be.true();
|
|
|
|
done();
|
|
}).catch(done);
|
|
});
|
|
|
|
it('database does exist: expect alpha error', function (done) {
|
|
knexMock.schema.hasTable.returns(new Promise.resolve(true));
|
|
queryMock.first.returns(new Promise.resolve({value: '008'}));
|
|
|
|
versioning.getDatabaseVersion()
|
|
.then(function () {
|
|
done('Should throw an error if version is not a number');
|
|
})
|
|
.catch(function (err) {
|
|
(err instanceof errors.DatabaseVersionError).should.eql(true);
|
|
err.message.should.eql('Your database version is not compatible with Ghost 1.0.0 Alpha (master branch)');
|
|
done();
|
|
});
|
|
});
|
|
});
|
|
|
|
describe('setDatabaseVersion', function () {
|
|
var knexStub, knexMock, queryMock;
|
|
|
|
beforeEach(function () {
|
|
queryMock = {
|
|
where: sandbox.stub().returnsThis(),
|
|
update: sandbox.stub().returns(new Promise.resolve())
|
|
};
|
|
|
|
knexMock = sandbox.stub().returns(queryMock);
|
|
|
|
// this MUST use sinon, not sandbox, see sinonjs/sinon#781
|
|
knexStub = sinon.stub(db, 'knex', {
|
|
get: function () {
|
|
return knexMock;
|
|
}
|
|
});
|
|
});
|
|
|
|
afterEach(function () {
|
|
knexStub.restore();
|
|
});
|
|
|
|
it('should try to update the databaseVersion', function (done) {
|
|
versioning.setDatabaseVersion().then(function () {
|
|
knexStub.get.calledOnce.should.be.true();
|
|
queryMock.where.called.should.be.true();
|
|
queryMock.update.called.should.be.true();
|
|
|
|
done();
|
|
}).catch(done);
|
|
});
|
|
});
|
|
});
|