2014-07-10 06:58:26 -05:00
|
|
|
var knex = require('../../server/models/base').knex,
|
2013-12-28 15:13:47 -05:00
|
|
|
when = require('when'),
|
2014-03-16 11:21:02 -05:00
|
|
|
sequence = require('when/sequence'),
|
2014-06-15 22:33:25 -05:00
|
|
|
nodefn = require('when/node'),
|
2014-02-12 22:26:56 -05:00
|
|
|
_ = require('lodash'),
|
2013-12-28 15:13:47 -05:00
|
|
|
fs = require('fs-extra'),
|
|
|
|
path = require('path'),
|
2014-07-15 16:43:22 -05:00
|
|
|
migration = require('../../server/data/migration/'),
|
2013-11-07 08:26:47 -05:00
|
|
|
DataGenerator = require('./fixtures/data-generator'),
|
2014-02-21 20:25:31 -05:00
|
|
|
API = require('./api'),
|
2014-07-21 04:29:03 -05:00
|
|
|
fork = require('./fork'),
|
|
|
|
|
|
|
|
teardown;
|
2013-05-23 23:02:41 -05:00
|
|
|
|
2013-10-07 20:39:33 -05:00
|
|
|
function initData() {
|
|
|
|
return migration.init();
|
|
|
|
}
|
2013-06-14 17:12:04 -05:00
|
|
|
|
2013-10-07 20:39:33 -05:00
|
|
|
function clearData() {
|
|
|
|
// we must always try to delete all tables
|
|
|
|
return migration.reset();
|
|
|
|
}
|
2013-06-14 17:12:04 -05:00
|
|
|
|
2013-10-07 20:39:33 -05:00
|
|
|
function insertPosts() {
|
2014-02-24 15:28:18 -05:00
|
|
|
// ToDo: Get rid of pyramid of doom
|
2013-11-05 10:02:57 -05:00
|
|
|
return when(knex('posts').insert(DataGenerator.forKnex.posts).then(function () {
|
2013-12-28 15:13:47 -05:00
|
|
|
return knex('tags').insert(DataGenerator.forKnex.tags).then(function () {
|
|
|
|
return knex('posts_tags').insert(DataGenerator.forKnex.posts_tags);
|
|
|
|
});
|
|
|
|
}));
|
2013-10-07 20:39:33 -05:00
|
|
|
}
|
2013-06-14 17:12:04 -05:00
|
|
|
|
2013-12-31 12:09:49 -05:00
|
|
|
function insertMorePosts(max) {
|
2013-10-07 20:39:33 -05:00
|
|
|
var lang,
|
|
|
|
status,
|
2014-03-16 11:21:02 -05:00
|
|
|
posts = [],
|
2013-10-07 20:39:33 -05:00
|
|
|
i, j, k = 0;
|
2013-06-14 17:12:04 -05:00
|
|
|
|
2013-12-31 12:09:49 -05:00
|
|
|
max = max || 50;
|
|
|
|
|
2013-10-07 20:39:33 -05:00
|
|
|
for (i = 0; i < 2; i += 1) {
|
|
|
|
lang = i % 2 ? 'en' : 'fr';
|
|
|
|
posts.push(DataGenerator.forKnex.createGenericPost(k++, null, lang));
|
2013-06-14 17:12:04 -05:00
|
|
|
|
2013-12-31 12:09:49 -05:00
|
|
|
for (j = 0; j < max; j += 1) {
|
|
|
|
status = j % 2 ? 'draft' : 'published';
|
2013-10-07 20:39:33 -05:00
|
|
|
posts.push(DataGenerator.forKnex.createGenericPost(k++, status, lang));
|
|
|
|
}
|
2013-06-25 06:43:15 -05:00
|
|
|
}
|
2013-08-24 15:51:58 -05:00
|
|
|
|
2014-07-10 06:58:26 -05:00
|
|
|
return sequence(_.times(posts.length, function(index) {
|
2014-03-16 11:21:02 -05:00
|
|
|
return function() {
|
2014-07-10 06:58:26 -05:00
|
|
|
return knex('posts').insert(posts[index]);
|
2014-07-21 04:29:03 -05:00
|
|
|
};
|
2014-03-16 11:21:02 -05:00
|
|
|
}));
|
2013-10-07 20:39:33 -05:00
|
|
|
}
|
|
|
|
|
2014-02-12 22:26:56 -05:00
|
|
|
function insertMorePostsTags(max) {
|
|
|
|
max = max || 50;
|
|
|
|
|
|
|
|
return when.all([
|
2014-03-16 11:21:02 -05:00
|
|
|
// PostgreSQL can return results in any order
|
|
|
|
knex('posts').orderBy('id', 'asc').select('id'),
|
2014-02-12 22:26:56 -05:00
|
|
|
knex('tags').select('id', 'name')
|
|
|
|
]).then(function (results) {
|
|
|
|
var posts = _.pluck(results[0], 'id'),
|
|
|
|
injectionTagId = _.chain(results[1])
|
|
|
|
.where({name: 'injection'})
|
|
|
|
.pluck('id')
|
|
|
|
.value()[0],
|
|
|
|
promises = [],
|
|
|
|
i;
|
|
|
|
|
|
|
|
if (max > posts.length) {
|
|
|
|
throw new Error('Trying to add more posts_tags than the number of posts.');
|
|
|
|
}
|
|
|
|
|
|
|
|
for (i = 0; i < max; i += 1) {
|
|
|
|
promises.push(DataGenerator.forKnex.createPostsTags(posts[i], injectionTagId));
|
|
|
|
}
|
|
|
|
|
2014-03-16 11:21:02 -05:00
|
|
|
return sequence(_.times(promises.length, function(index) {
|
|
|
|
return function() {
|
|
|
|
return knex('posts_tags').insert(promises[index]);
|
|
|
|
};
|
|
|
|
}));
|
2014-02-12 22:26:56 -05:00
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2013-10-07 20:39:33 -05:00
|
|
|
function insertDefaultUser() {
|
2014-07-10 06:58:26 -05:00
|
|
|
var user;
|
2014-07-10 05:00:51 -05:00
|
|
|
|
|
|
|
user = DataGenerator.forKnex.createUser(DataGenerator.Content.users[0]);
|
2013-05-23 23:02:41 -05:00
|
|
|
|
2014-02-11 22:40:39 -05:00
|
|
|
return knex('users')
|
2014-07-10 05:00:51 -05:00
|
|
|
.where('id', '=', '1')
|
|
|
|
.update(user);
|
2014-02-11 22:40:39 -05:00
|
|
|
}
|
|
|
|
|
2014-07-21 15:50:43 -05:00
|
|
|
function insertAdminUser() {
|
2014-04-08 08:40:33 -05:00
|
|
|
var users = [],
|
2014-07-10 06:58:26 -05:00
|
|
|
userRoles = [];
|
2014-04-08 08:40:33 -05:00
|
|
|
|
|
|
|
users.push(DataGenerator.forKnex.createUser(DataGenerator.Content.users[1]));
|
2014-04-10 10:56:56 -05:00
|
|
|
userRoles.push(DataGenerator.forKnex.createUserRole(2, 2));
|
2014-04-08 08:40:33 -05:00
|
|
|
return knex('users')
|
|
|
|
.insert(users)
|
|
|
|
.then(function () {
|
|
|
|
return knex('roles_users').insert(userRoles);
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2014-07-21 15:50:43 -05:00
|
|
|
function insertEditorUser() {
|
2014-04-08 08:40:33 -05:00
|
|
|
var users = [],
|
2014-07-10 06:58:26 -05:00
|
|
|
userRoles = [];
|
2014-04-08 08:40:33 -05:00
|
|
|
|
|
|
|
users.push(DataGenerator.forKnex.createUser(DataGenerator.Content.users[2]));
|
2014-07-21 15:50:43 -05:00
|
|
|
userRoles.push(DataGenerator.forKnex.createUserRole(3, 2));
|
|
|
|
return knex('users')
|
|
|
|
.insert(users)
|
|
|
|
.then(function () {
|
|
|
|
return knex('roles_users').insert(userRoles);
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
function insertAuthorUser() {
|
|
|
|
var users = [],
|
|
|
|
userRoles = [];
|
|
|
|
|
|
|
|
users.push(DataGenerator.forKnex.createUser(DataGenerator.Content.users[3]));
|
|
|
|
userRoles.push(DataGenerator.forKnex.createUserRole(4, 3));
|
2014-04-08 08:40:33 -05:00
|
|
|
return knex('users')
|
|
|
|
.insert(users)
|
|
|
|
.then(function () {
|
|
|
|
return knex('roles_users').insert(userRoles);
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2014-02-11 22:40:39 -05:00
|
|
|
function insertDefaultApp() {
|
2014-07-10 06:58:26 -05:00
|
|
|
var apps = [];
|
2014-02-11 22:40:39 -05:00
|
|
|
|
|
|
|
apps.push(DataGenerator.forKnex.createApp(DataGenerator.Content.apps[0]));
|
|
|
|
|
2014-07-15 16:43:22 -05:00
|
|
|
return knex('permissions')
|
|
|
|
.select('id')
|
|
|
|
.where('object_type', 'post')
|
|
|
|
.andWhere('action_type', 'edit')
|
|
|
|
.then(function (result) {
|
|
|
|
var permission_id = result[0].id;
|
|
|
|
if (permission_id) {
|
|
|
|
return knex('apps')
|
|
|
|
.insert(apps)
|
|
|
|
.then(function () {
|
|
|
|
return knex('permissions_apps')
|
|
|
|
.insert({
|
|
|
|
app_id: 1,
|
|
|
|
permission_id: permission_id
|
|
|
|
});
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
throw new Error('Permissions not created');
|
2014-02-11 22:40:39 -05:00
|
|
|
});
|
2013-12-28 15:13:47 -05:00
|
|
|
}
|
|
|
|
|
2014-02-24 15:28:18 -05:00
|
|
|
function insertApps() {
|
|
|
|
return knex('apps').insert(DataGenerator.forKnex.apps).then(function () {
|
|
|
|
return knex('app_fields').insert(DataGenerator.forKnex.app_fields);
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
function insertAppWithSettings() {
|
2014-07-10 06:58:26 -05:00
|
|
|
var apps = [], app_settings = [];
|
2014-02-24 15:28:18 -05:00
|
|
|
|
|
|
|
apps.push(DataGenerator.forKnex.createApp(DataGenerator.Content.apps[0]));
|
|
|
|
app_settings.push(DataGenerator.forKnex.createAppSetting(DataGenerator.Content.app_settings[0]));
|
|
|
|
app_settings.push(DataGenerator.forKnex.createAppSetting(DataGenerator.Content.app_settings[1]));
|
|
|
|
|
|
|
|
return knex('apps').insert(apps, 'id')
|
|
|
|
.then(function (results) {
|
|
|
|
var appId = results[0];
|
|
|
|
|
|
|
|
for (var i = 0; i < app_settings.length; i++) {
|
|
|
|
app_settings[i].app_id = appId;
|
|
|
|
}
|
|
|
|
|
|
|
|
return knex('app_settings').insert(app_settings);
|
|
|
|
});
|
|
|
|
}
|
|
|
|
function insertAppWithFields() {
|
2014-07-10 06:58:26 -05:00
|
|
|
var apps = [], app_fields = [];
|
2014-02-24 15:28:18 -05:00
|
|
|
|
|
|
|
apps.push(DataGenerator.forKnex.createApp(DataGenerator.Content.apps[0]));
|
|
|
|
app_fields.push(DataGenerator.forKnex.createAppField(DataGenerator.Content.app_fields[0]));
|
|
|
|
app_fields.push(DataGenerator.forKnex.createAppField(DataGenerator.Content.app_fields[1]));
|
|
|
|
|
|
|
|
return knex('apps').insert(apps, 'id')
|
|
|
|
.then(function (results) {
|
2014-05-15 21:29:42 -05:00
|
|
|
var appId = results[0],
|
|
|
|
i;
|
2014-02-24 15:28:18 -05:00
|
|
|
|
2014-05-15 21:29:42 -05:00
|
|
|
for (i = 0; i < app_fields.length; i++) {
|
2014-02-24 15:28:18 -05:00
|
|
|
app_fields[i].app_id = appId;
|
|
|
|
}
|
|
|
|
|
|
|
|
return knex('app_fields').insert(app_fields);
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2013-12-28 15:13:47 -05:00
|
|
|
function insertDefaultFixtures() {
|
2014-04-10 10:56:56 -05:00
|
|
|
return insertDefaultUser().then(function () {
|
2014-05-15 21:29:42 -05:00
|
|
|
return insertPosts();
|
2014-04-10 10:56:56 -05:00
|
|
|
}).then(function () {
|
|
|
|
return insertApps();
|
|
|
|
});
|
2013-12-28 15:13:47 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
function loadExportFixture(filename) {
|
|
|
|
var filepath = path.resolve(__dirname + '/fixtures/' + filename + '.json');
|
|
|
|
|
|
|
|
return nodefn.call(fs.readFile, filepath).then(function (fileContents) {
|
|
|
|
var data;
|
|
|
|
|
|
|
|
// Parse the json data
|
|
|
|
try {
|
|
|
|
data = JSON.parse(fileContents);
|
|
|
|
} catch (e) {
|
|
|
|
return when.reject(new Error("Failed to parse the file"));
|
|
|
|
}
|
|
|
|
|
|
|
|
return data;
|
|
|
|
});
|
2013-10-07 20:39:33 -05:00
|
|
|
}
|
|
|
|
|
2014-07-21 04:29:03 -05:00
|
|
|
teardown = function (done) {
|
|
|
|
migration.reset().then(function () {
|
|
|
|
done();
|
|
|
|
}).catch(done);
|
|
|
|
};
|
|
|
|
|
2013-10-07 20:39:33 -05:00
|
|
|
module.exports = {
|
2014-07-21 04:29:03 -05:00
|
|
|
teardown: teardown,
|
|
|
|
|
2013-10-07 20:39:33 -05:00
|
|
|
initData: initData,
|
|
|
|
clearData: clearData,
|
|
|
|
insertDefaultFixtures: insertDefaultFixtures,
|
|
|
|
insertPosts: insertPosts,
|
|
|
|
insertMorePosts: insertMorePosts,
|
2014-02-12 22:26:56 -05:00
|
|
|
insertMorePostsTags: insertMorePostsTags,
|
2013-10-07 20:39:33 -05:00
|
|
|
insertDefaultUser: insertDefaultUser,
|
2014-07-21 15:50:43 -05:00
|
|
|
insertAdminUser: insertAdminUser,
|
2014-04-08 08:40:33 -05:00
|
|
|
insertEditorUser: insertEditorUser,
|
|
|
|
insertAuthorUser: insertAuthorUser,
|
2014-02-11 22:40:39 -05:00
|
|
|
insertDefaultApp: insertDefaultApp,
|
2014-02-24 15:28:18 -05:00
|
|
|
insertApps: insertApps,
|
|
|
|
insertAppWithSettings: insertAppWithSettings,
|
|
|
|
insertAppWithFields: insertAppWithFields,
|
2013-10-07 20:39:33 -05:00
|
|
|
|
2013-12-28 15:13:47 -05:00
|
|
|
loadExportFixture: loadExportFixture,
|
|
|
|
|
2013-10-07 20:39:33 -05:00
|
|
|
DataGenerator: DataGenerator,
|
2014-02-21 20:25:31 -05:00
|
|
|
API: API,
|
2014-05-15 21:29:42 -05:00
|
|
|
|
2014-02-21 20:25:31 -05:00
|
|
|
fork: fork
|
2013-10-07 20:39:33 -05:00
|
|
|
};
|