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