mirror of
https://github.com/TryGhost/Ghost.git
synced 2024-12-25 11:55:03 +03:00
630c03d4d4
closes #639 Updated url helper to work Updated tests Changed helper.js in tests/unit to be called testUtil to avoid confusion
203 lines
7.5 KiB
JavaScript
203 lines
7.5 KiB
JavaScript
/*globals describe, beforeEach, it*/
|
|
var testUtils = require('./testUtils'),
|
|
should = require('should'),
|
|
sinon = require('sinon'),
|
|
when = require('when'),
|
|
_ = require("underscore"),
|
|
errors = require('../../server/errorHandling'),
|
|
|
|
// Stuff we are testing
|
|
knex = require("../../server/models/base").Knex,
|
|
migration = require('../../server/data/migration'),
|
|
exporter = require('../../server/data/export'),
|
|
importer = require('../../server/data/import'),
|
|
Importer001 = require('../../server/data/import/001'),
|
|
Importer002 = require('../../server/data/import/002'),
|
|
Settings = require('../../server/models/settings').Settings;
|
|
|
|
describe("Import", function () {
|
|
|
|
should.exist(exporter);
|
|
should.exist(importer);
|
|
|
|
beforeEach(function (done) {
|
|
// clear database... we need to initialise it manually for each test
|
|
testUtils.clearData().then(function () {
|
|
done();
|
|
}, done);
|
|
});
|
|
|
|
it("resolves 001", function (done) {
|
|
var importStub = sinon.stub(Importer001, "importData", function () {
|
|
return when.resolve();
|
|
}),
|
|
fakeData = { test: true };
|
|
|
|
importer("001", fakeData).then(function () {
|
|
importStub.calledWith(fakeData).should.equal(true);
|
|
|
|
importStub.restore();
|
|
|
|
done();
|
|
}).then(null, done);
|
|
});
|
|
|
|
describe("001", function () {
|
|
this.timeout(4000);
|
|
|
|
should.exist(Importer001);
|
|
|
|
it("imports data from 001", function (done) {
|
|
var exportData;
|
|
|
|
// initialise database to version 001 - confusingly we have to set the max version to be one higher
|
|
// than the migration version we want
|
|
migration.migrateUpFromVersion('001', '002').then(function () {
|
|
return Settings.populateDefaults();
|
|
}).then(function () {
|
|
// export the version 001 data ready to import
|
|
// TODO: Should have static test data here?
|
|
return exporter("001");
|
|
}).then(function (exported) {
|
|
exportData = exported;
|
|
|
|
// Version 001 exporter required the database be empty...
|
|
var tables = [
|
|
'posts', 'users', 'roles', 'roles_users', 'permissions', 'permissions_roles',
|
|
'settings'
|
|
],
|
|
truncateOps = _.map(tables, function (name) {
|
|
return knex(name).truncate();
|
|
});
|
|
|
|
return when.all(truncateOps);
|
|
}).then(function () {
|
|
return importer("001", exportData);
|
|
}).then(function () {
|
|
// Grab the data from tables
|
|
return when.all([
|
|
knex("users").select(),
|
|
knex("posts").select(),
|
|
knex("settings").select()
|
|
]);
|
|
}).then(function (importedData) {
|
|
|
|
should.exist(importedData);
|
|
importedData.length.should.equal(3);
|
|
|
|
// we always have 0 users as there isn't one in fixtures
|
|
importedData[0].length.should.equal(0);
|
|
importedData[1].length.should.equal(exportData.data.posts.length);
|
|
importedData[2].length.should.be.above(0);
|
|
|
|
_.findWhere(exportData.data.settings, {key: "currentVersion"}).value.should.equal("001");
|
|
|
|
done();
|
|
}).then(null, done);
|
|
});
|
|
});
|
|
|
|
it("resolves 002", function (done) {
|
|
var importStub = sinon.stub(Importer002, "importData", function () {
|
|
return when.resolve();
|
|
}),
|
|
fakeData = { test: true };
|
|
|
|
importer("002", fakeData).then(function () {
|
|
importStub.calledWith(fakeData).should.equal(true);
|
|
|
|
importStub.restore();
|
|
|
|
done();
|
|
}).then(null, done);
|
|
});
|
|
|
|
describe("002", function () {
|
|
this.timeout(4000);
|
|
|
|
should.exist(Importer002);
|
|
|
|
it("imports data from 001", function (done) {
|
|
var exportData;
|
|
|
|
// initialise database to version 001 - confusingly we have to set the max version to be one higher
|
|
// than the migration version we want
|
|
migration.migrateUpFromVersion('001', '002').then(function () {
|
|
return Settings.populateDefaults();
|
|
}).then(function () {
|
|
// export the version 001 data ready to import
|
|
// TODO: Should have static test data here?
|
|
return exporter("001");
|
|
}).then(function (exported) {
|
|
exportData = exported;
|
|
|
|
// now migrate up to the proper version ready for importing - confusingly we have to set the max version
|
|
// to be one higher than the migration version we want
|
|
return migration.migrateUpFromVersion('002', '003');
|
|
}).then(function () {
|
|
return importer("002", exportData);
|
|
}).then(function () {
|
|
// Grab the data from tables
|
|
return when.all([
|
|
knex("users").select(),
|
|
knex("posts").select(),
|
|
knex("settings").select()
|
|
]);
|
|
}).then(function (importedData) {
|
|
|
|
should.exist(importedData);
|
|
importedData.length.should.equal(3);
|
|
|
|
// we always have 0 users as there isn't one in fixtures
|
|
importedData[0].length.should.equal(0);
|
|
// import no longer requires all data to be dropped, and adds posts
|
|
importedData[1].length.should.equal(exportData.data.posts.length + 1);
|
|
importedData[2].length.should.be.above(0);
|
|
|
|
_.findWhere(importedData[2], {key: "currentVersion"}).value.should.equal("002");
|
|
|
|
done();
|
|
}).then(null, done);
|
|
});
|
|
|
|
it("imports data from 002", function (done) {
|
|
var exportData;
|
|
|
|
// initialise database to version 001 - confusingly we have to set the max version to be one higher
|
|
// than the migration version we want
|
|
migration.migrateUpFromVersion('001', '003').then(function () {
|
|
return Settings.populateDefaults();
|
|
}).then(function () {
|
|
// export the version 002 data ready to import
|
|
// TODO: Should have static test data here?
|
|
return exporter("002");
|
|
}).then(function (exported) {
|
|
exportData = exported;
|
|
|
|
return importer("002", exportData);
|
|
}).then(function () {
|
|
// Grab the data from tables
|
|
return when.all([
|
|
knex("users").select(),
|
|
knex("posts").select(),
|
|
knex("settings").select()
|
|
]);
|
|
}).then(function (importedData) {
|
|
|
|
should.exist(importedData);
|
|
importedData.length.should.equal(3);
|
|
|
|
// we always have 0 users as there isn't one in fixtures
|
|
importedData[0].length.should.equal(0);
|
|
// import no longer requires all data to be dropped, and adds posts
|
|
importedData[1].length.should.equal(exportData.data.posts.length + 1);
|
|
importedData[2].length.should.be.above(0);
|
|
|
|
_.findWhere(importedData[2], {key: "currentVersion"}).value.should.equal("002");
|
|
|
|
done();
|
|
}).then(null, done);
|
|
});
|
|
});
|
|
});
|