2013-09-15 17:04:42 +01:00
|
|
|
/*globals describe, before, beforeEach, afterEach, it*/
|
2014-07-21 18:50:04 +01:00
|
|
|
var testUtils = require('../utils/index'),
|
2014-06-04 22:26:03 +01:00
|
|
|
should = require('should'),
|
|
|
|
sinon = require('sinon'),
|
2014-08-17 06:17:23 +00:00
|
|
|
Promise = require('bluebird'),
|
2014-06-04 22:26:03 +01:00
|
|
|
_ = require('lodash'),
|
2013-09-15 17:04:42 +01:00
|
|
|
|
|
|
|
// Stuff we are testing
|
2016-01-25 17:50:04 +00:00
|
|
|
versioning = require('../../server/data/schema').versioning,
|
2016-03-12 18:54:06 +00:00
|
|
|
exporter = require('../../server/data/export'),
|
2016-02-14 12:46:09 +00:00
|
|
|
|
|
|
|
DEF_DB_VERSION = versioning.getDefaultDatabaseVersion(),
|
2014-07-21 18:50:04 +01:00
|
|
|
sandbox = sinon.sandbox.create();
|
2013-09-15 17:04:42 +01:00
|
|
|
|
2014-06-04 22:26:03 +01:00
|
|
|
describe('Exporter', function () {
|
2014-07-21 18:50:04 +01:00
|
|
|
before(testUtils.teardown);
|
|
|
|
afterEach(testUtils.teardown);
|
|
|
|
afterEach(function () {
|
2014-02-11 21:40:39 -06:00
|
|
|
sandbox.restore();
|
2013-09-15 17:04:42 +01:00
|
|
|
});
|
2014-07-21 18:50:04 +01:00
|
|
|
beforeEach(testUtils.setup('default'));
|
|
|
|
|
|
|
|
should.exist(exporter);
|
2013-09-15 17:04:42 +01:00
|
|
|
|
2014-06-04 22:26:03 +01:00
|
|
|
it('exports data', function (done) {
|
2016-02-14 12:46:09 +00:00
|
|
|
// Stub migrations to return DEF_DB_VERSION as the current database version
|
2014-06-04 22:26:03 +01:00
|
|
|
var versioningStub = sandbox.stub(versioning, 'getDatabaseVersion', function () {
|
2016-02-14 12:46:09 +00:00
|
|
|
return Promise.resolve(DEF_DB_VERSION);
|
2013-09-15 17:04:42 +01:00
|
|
|
});
|
|
|
|
|
2016-03-12 18:54:06 +00:00
|
|
|
exporter.doExport().then(function (exportData) {
|
2014-06-04 22:26:03 +01:00
|
|
|
var tables = ['posts', 'users', 'roles', 'roles_users', 'permissions', 'permissions_roles',
|
2014-07-27 16:04:58 -05:00
|
|
|
'permissions_users', 'settings', 'tags', 'posts_tags'],
|
|
|
|
dbVersionSetting;
|
2013-09-15 17:04:42 +01:00
|
|
|
|
|
|
|
should.exist(exportData);
|
|
|
|
|
|
|
|
should.exist(exportData.meta);
|
|
|
|
should.exist(exportData.data);
|
|
|
|
|
2016-02-14 12:46:09 +00:00
|
|
|
exportData.meta.version.should.equal(DEF_DB_VERSION);
|
2014-07-27 16:04:58 -05:00
|
|
|
|
2016-06-11 12:23:27 -06:00
|
|
|
dbVersionSetting = _.find(exportData.data.settings, {key: 'databaseVersion'});
|
2014-07-27 16:04:58 -05:00
|
|
|
|
|
|
|
should.exist(dbVersionSetting);
|
|
|
|
|
2016-02-14 12:46:09 +00:00
|
|
|
dbVersionSetting.value.should.equal(DEF_DB_VERSION);
|
2013-09-15 17:04:42 +01:00
|
|
|
|
|
|
|
_.each(tables, function (name) {
|
|
|
|
should.exist(exportData.data[name]);
|
|
|
|
});
|
|
|
|
// should not export sqlite data
|
|
|
|
should.not.exist(exportData.data.sqlite_sequence);
|
|
|
|
|
2014-05-31 18:53:21 -05:00
|
|
|
versioningStub.restore();
|
2013-09-15 17:04:42 +01:00
|
|
|
done();
|
2014-05-05 21:58:58 +01:00
|
|
|
}).catch(done);
|
2013-09-15 17:04:42 +01:00
|
|
|
});
|
|
|
|
});
|