2013-09-15 20:04:42 +04:00
|
|
|
/*globals describe, before, beforeEach, afterEach, it*/
|
2013-11-07 17:26:47 +04:00
|
|
|
var testUtils = require('../utils'),
|
2013-09-15 20:04:42 +04:00
|
|
|
should = require('should'),
|
|
|
|
sinon = require('sinon'),
|
|
|
|
when = require('when'),
|
2014-02-05 12:40:30 +04:00
|
|
|
_ = require("lodash"),
|
2014-05-09 14:11:29 +04:00
|
|
|
errors = require('../../server/errors'),
|
2013-09-15 20:04:42 +04:00
|
|
|
|
|
|
|
// Stuff we are testing
|
|
|
|
migration = require('../../server/data/migration'),
|
|
|
|
exporter = require('../../server/data/export'),
|
|
|
|
Settings = require('../../server/models/settings').Settings;
|
|
|
|
|
|
|
|
describe("Exporter", function () {
|
|
|
|
|
|
|
|
should.exist(exporter);
|
|
|
|
|
2014-02-12 07:40:39 +04:00
|
|
|
var sandbox;
|
|
|
|
|
2013-09-15 20:04:42 +04:00
|
|
|
before(function (done) {
|
|
|
|
testUtils.clearData().then(function () {
|
|
|
|
done();
|
2014-05-06 00:58:58 +04:00
|
|
|
}).catch(done);
|
2013-09-15 20:04:42 +04:00
|
|
|
});
|
|
|
|
|
|
|
|
beforeEach(function (done) {
|
2014-02-12 07:40:39 +04:00
|
|
|
sandbox = sinon.sandbox.create();
|
2013-09-15 20:04:42 +04:00
|
|
|
testUtils.initData().then(function () {
|
|
|
|
done();
|
2014-05-06 00:58:58 +04:00
|
|
|
}).catch(done);
|
2013-09-15 20:04:42 +04:00
|
|
|
});
|
|
|
|
|
|
|
|
afterEach(function (done) {
|
2014-02-12 07:40:39 +04:00
|
|
|
sandbox.restore();
|
2013-09-15 20:04:42 +04:00
|
|
|
testUtils.clearData().then(function () {
|
|
|
|
done();
|
2014-05-06 00:58:58 +04:00
|
|
|
}).catch(done);
|
2013-09-15 20:04:42 +04:00
|
|
|
});
|
|
|
|
|
|
|
|
it("exports data", function (done) {
|
|
|
|
// Stub migrations to return 000 as the current database version
|
2014-02-12 07:40:39 +04:00
|
|
|
var migrationStub = sandbox.stub(migration, "getDatabaseVersion", function () {
|
|
|
|
return when.resolve("003");
|
2013-09-15 20:04:42 +04:00
|
|
|
});
|
|
|
|
|
|
|
|
exporter().then(function (exportData) {
|
|
|
|
var tables = ['posts', 'users', 'roles', 'roles_users', 'permissions', 'permissions_roles', 'permissions_users',
|
|
|
|
'settings', 'tags', 'posts_tags'];
|
|
|
|
|
|
|
|
should.exist(exportData);
|
|
|
|
|
|
|
|
should.exist(exportData.meta);
|
|
|
|
should.exist(exportData.data);
|
|
|
|
|
2014-02-12 07:40:39 +04:00
|
|
|
exportData.meta.version.should.equal("003");
|
|
|
|
_.findWhere(exportData.data.settings, {key: "databaseVersion"}).value.should.equal("003");
|
2013-09-15 20:04:42 +04:00
|
|
|
|
|
|
|
_.each(tables, function (name) {
|
|
|
|
should.exist(exportData.data[name]);
|
|
|
|
});
|
|
|
|
// should not export sqlite data
|
|
|
|
should.not.exist(exportData.data.sqlite_sequence);
|
|
|
|
|
|
|
|
migrationStub.restore();
|
|
|
|
done();
|
2014-05-06 00:58:58 +04:00
|
|
|
}).catch(done);
|
2013-09-15 20:04:42 +04:00
|
|
|
});
|
|
|
|
});
|