0
Fork 0
mirror of https://github.com/TryGhost/Ghost.git synced 2025-01-06 22:40:14 -05:00

Merge pull request #6889 from kirrg001/improvement/general

improvement: general fixes
This commit is contained in:
Hannah Wolfe 2016-06-01 07:58:00 +01:00
commit 45226bcaaa
5 changed files with 62 additions and 21 deletions

View file

@ -28,27 +28,27 @@ logger = {
init = function init(tablesOnly) { init = function init(tablesOnly) {
tablesOnly = tablesOnly || false; tablesOnly = tablesOnly || false;
// There are 4 possibilities: // There are 4 possible cases:
// 1. The database exists and is up-to-date // CASE 1: The database exists and is up-to-date
// 2. The database exists but is out of date // CASE 2: The database exists but is out of date
// 3. The database exists but the currentVersion setting does not or cannot be understood // CASE 3: The database exists but the currentVersion setting does not or cannot be understood
// 4. The database has not yet been created // CASE 4: The database has not yet been created
return versioning.getDatabaseVersion().then(function (databaseVersion) { return versioning.getDatabaseVersion().then(function (databaseVersion) {
var defaultVersion = versioning.getDefaultDatabaseVersion(); var defaultVersion = versioning.getDefaultDatabaseVersion();
// Update goes first, to allow for FORCE_MIGRATION // Update goes first, to allow for FORCE_MIGRATION
// 2. The database exists but is out of date // CASE 2: The database exists but is out of date
if (databaseVersion < defaultVersion || process.env.FORCE_MIGRATION) { if (databaseVersion < defaultVersion || process.env.FORCE_MIGRATION) {
// Migrate to latest version // Migrate to latest version
logger.info('Database upgrade required from version ' + databaseVersion + ' to ' + defaultVersion); logger.info('Database upgrade required from version ' + databaseVersion + ' to ' + defaultVersion);
return update(databaseVersion, defaultVersion, logger); return update(databaseVersion, defaultVersion, logger);
// 1. The database exists and is up-to-date // CASE 1: The database exists and is up-to-date
} else if (databaseVersion === defaultVersion) { } else if (databaseVersion === defaultVersion) {
logger.info('Up-to-date at version ' + databaseVersion); logger.info('Up-to-date at version ' + databaseVersion);
return; return;
// 3. The database exists but the currentVersion setting does not or cannot be understood // CASE 3: The database exists but the currentVersion setting does not or cannot be understood
} else { } else {
// In this case we don't understand the version because it is too high // In this case we don't understand the version because it is too high
errors.logErrorAndExit( errors.logErrorAndExit(
@ -58,14 +58,14 @@ init = function init(tablesOnly) {
} }
}, function (err) { }, function (err) {
if (err && err.message === 'Settings table does not exist') { if (err && err.message === 'Settings table does not exist') {
// 4. The database has not yet been created // CASE 4: The database has not yet been created
// Bring everything up from initial version. // Bring everything up from initial version.
logger.info('Database initialisation required for version ' + versioning.getDefaultDatabaseVersion()); logger.info('Database initialisation required for version ' + versioning.getDefaultDatabaseVersion());
return populate(logger, tablesOnly); return populate(logger, tablesOnly);
} }
// 3. The database exists but the currentVersion setting does not or cannot be understood // CASE 3: the database exists but the currentVersion setting does not or cannot be understood
// In this case the setting was missing or there was some other problem // In this case the setting was missing or there was some other problem
errors.logErrorAndExit('There is a problem with the database', err.message); errors.logErrorAndExit(err, 'Problem occurred during migration initialisation!');
}); });
}; };

View file

@ -155,7 +155,9 @@ errors = {
// TODO: Logging framework hookup // TODO: Logging framework hookup
// Eventually we'll have better logging which will know about envs // Eventually we'll have better logging which will know about envs
if ((process.env.NODE_ENV === 'development' || // you can use DEBUG=true when running tests and need error stdout
if ((process.env.NODE_LEVEL === 'DEBUG' ||
process.env.NODE_ENV === 'development' ||
process.env.NODE_ENV === 'staging' || process.env.NODE_ENV === 'staging' ||
process.env.NODE_ENV === 'production')) { process.env.NODE_ENV === 'production')) {
msgs = [chalk.red(i18n.t('errors.errors.error'), err), '\n']; msgs = [chalk.red(i18n.t('errors.errors.error'), err), '\n'];

View file

@ -84,7 +84,15 @@ I18n = {
init: function init() { init: function init() {
// read file for current locale and keep its content in memory // read file for current locale and keep its content in memory
blos = fs.readFileSync(__dirname + '/translations/' + currentLocale + '.json'); blos = fs.readFileSync(__dirname + '/translations/' + currentLocale + '.json');
blos = JSON.parse(blos);
// if translation file is not valid, you will see an error
try {
blos = JSON.parse(blos);
} catch (err) {
blos = undefined;
throw err;
}
if (global.Intl) { if (global.Intl) {
// Determine if the built-in `Intl` has the locale data we need. // Determine if the built-in `Intl` has the locale data we need.
var hasBuiltInLocaleData, var hasBuiltInLocaleData,

View file

@ -1,12 +1,19 @@
var _ = require('lodash'), var _ = require('lodash'),
Promise = require('bluebird'),
Models = require('../models'), Models = require('../models'),
errors = require('../errors'), errors = require('../errors'),
i18n = require('../i18n'),
effective; effective;
effective = { effective = {
user: function (id) { user: function (id) {
return Models.User.findOne({id: id, status: 'all'}, {include: ['permissions', 'roles', 'roles.permissions']}) return Models.User.findOne({id: id, status: 'all'}, {include: ['permissions', 'roles', 'roles.permissions']})
.then(function (foundUser) { .then(function (foundUser) {
// CASE: {context: {user: id}} where the id is not in our database
if (!foundUser) {
return Promise.reject(new errors.NotFoundError(i18n.t('errors.models.user.userNotFound')));
}
var seenPerms = {}, var seenPerms = {},
rolePerms = _.map(foundUser.related('roles').models, function (role) { rolePerms = _.map(foundUser.related('roles').models, function (role) {
return role.related('permissions').models; return role.related('permissions').models;

View file

@ -327,6 +327,11 @@ fixtures = {
Owner: 4 Owner: 4
}; };
// CASE: if empty db will throw SQLITE_MISUSE, hard to debug
if (_.isEmpty(permsToInsert)) {
return Promise.reject(new Error('no permission found:' + obj));
}
permsToInsert = _.map(permsToInsert, function (perms) { permsToInsert = _.map(permsToInsert, function (perms) {
actions.push(perms.action_type); actions.push(perms.action_type);
return DataGenerator.forKnex.createBasic(perms); return DataGenerator.forKnex.createBasic(perms);
@ -347,12 +352,18 @@ fixtures = {
}); });
return db.knex('permissions').insert(permsToInsert).then(function () { return db.knex('permissions').insert(permsToInsert).then(function () {
if (_.isEmpty(permissionsRoles)) {
return Promise.resolve();
}
return db.knex('permissions_roles').insert(permissionsRoles); return db.knex('permissions_roles').insert(permissionsRoles);
}); });
}, },
insertClients: function insertClients() { insertClients: function insertClients() {
return db.knex('clients').insert(DataGenerator.forKnex.clients); return db.knex('clients').insert(DataGenerator.forKnex.clients);
}, },
insertAccessToken: function insertAccessToken(override) { insertAccessToken: function insertAccessToken(override) {
return db.knex('accesstokens').insert(DataGenerator.forKnex.createToken(override)); return db.knex('accesstokens').insert(DataGenerator.forKnex.createToken(override));
} }
@ -438,10 +449,15 @@ getFixtureOps = function getFixtureOps(toDos) {
// Go through our list of things to do, and add them to an array // Go through our list of things to do, and add them to an array
_.each(toDos, function (value, toDo) { _.each(toDos, function (value, toDo) {
var tmp; var tmp;
if (toDo !== 'perms:init' && toDo.indexOf('perms:') !== -1) { if (toDo !== 'perms:init' && toDo.indexOf('perms:') !== -1) {
tmp = toDo.split(':'); tmp = toDo.split(':');
fixtureOps.push(toDoList[tmp[0]](tmp[1])); fixtureOps.push(toDoList[tmp[0]](tmp[1]));
} else { } else {
if (!toDoList[toDo]) {
throw new Error('setup todo does not exist - spell mistake?');
}
fixtureOps.push(toDoList[toDo]); fixtureOps.push(toDoList[toDo]);
} }
}); });
@ -470,12 +486,16 @@ setup = function setup() {
var self = this, var self = this,
args = arguments; args = arguments;
return function (done) { return function setup(done) {
Models.init(); Models.init();
return initFixtures.apply(self, args).then(function () { if (done) {
done(); return initFixtures.apply(self, args).then(function () {
}).catch(done); done();
}).catch(done);
} else {
return initFixtures.apply(self, args);
}
}; };
}; };
@ -556,9 +576,13 @@ togglePermalinks = function togglePermalinks(request, toggle) {
}; };
teardown = function teardown(done) { teardown = function teardown(done) {
migration.reset().then(function () { if (done) {
done(); migration.reset().then(function () {
}).catch(done); done();
}).catch(done);
} else {
return migration.reset();
}
}; };
module.exports = { module.exports = {