mirror of
https://github.com/TryGhost/Ghost.git
synced 2024-12-24 11:22:19 +03:00
f08a55c21f
refs: https://github.com/TryGhost/Team/issues/856 refs: https://github.com/TryGhost/Team/issues/756 - The .test.js extension is better than _spec.js as it's more obvious that it's an extension - It also meaans we can use the --extension parameter in mocha, which should result in a better default behaviour for `yarn test` - It also highlights that some of our tests were named incorrectly and were not (and still will not be) run (see https://github.com/TryGhost/Team/issues/856) - Note: even with this change, `yarn test` is throwing errors, I believe because of this issue https://github.com/TryGhost/Team/issues/756
97 lines
2.9 KiB
JavaScript
97 lines
2.9 KiB
JavaScript
const should = require('should');
|
|
const fs = require('fs-extra');
|
|
const StorageBase = require('ghost-storage-base');
|
|
const configUtils = require('../../../utils/configUtils');
|
|
const storage = require('../../../../core/server/adapters/storage');
|
|
const LocalFileStorage = require('../../../../core/server/adapters/storage/LocalFileStorage');
|
|
|
|
const storagePath = configUtils.config.getContentPath('adapters') + 'storage/';
|
|
describe('storage: index_spec', function () {
|
|
const scope = {adapter: null};
|
|
|
|
before(function () {
|
|
if (!fs.existsSync(storagePath)) {
|
|
fs.mkdirSync(storagePath);
|
|
}
|
|
});
|
|
|
|
afterEach(function () {
|
|
if (scope.adapter) {
|
|
fs.unlinkSync(scope.adapter);
|
|
scope.adapter = null;
|
|
}
|
|
|
|
configUtils.restore();
|
|
});
|
|
|
|
it('default image storage is local file storage', function () {
|
|
const chosenStorage = storage.getStorage();
|
|
(chosenStorage instanceof StorageBase).should.eql(true);
|
|
(chosenStorage instanceof LocalFileStorage).should.eql(true);
|
|
});
|
|
|
|
it('custom adapter', function () {
|
|
scope.adapter = storagePath + 'custom-adapter.js';
|
|
|
|
configUtils.set({
|
|
storage: {
|
|
active: 'custom-adapter'
|
|
}
|
|
});
|
|
|
|
const jsFile = '' +
|
|
'\'use strict\';' +
|
|
'var StorageBase = require(\'ghost-storage-base\');' +
|
|
'class AnotherAdapter extends StorageBase {' +
|
|
'exists(){}' +
|
|
'save(){}' +
|
|
'serve(){}' +
|
|
'delete(){}' +
|
|
'read(){}' +
|
|
'}' +
|
|
'module.exports = AnotherAdapter';
|
|
|
|
let chosenStorage;
|
|
|
|
fs.writeFileSync(scope.adapter, jsFile);
|
|
|
|
configUtils.config.get('storage:active').should.eql('custom-adapter');
|
|
chosenStorage = storage.getStorage();
|
|
(chosenStorage instanceof LocalFileStorage).should.eql(false);
|
|
(chosenStorage instanceof StorageBase).should.eql(true);
|
|
});
|
|
|
|
it('create bad adapter: exists fn is missing', function () {
|
|
scope.adapter = storagePath + 'broken-storage.js';
|
|
|
|
configUtils.set({
|
|
storage: {
|
|
active: 'broken-storage'
|
|
},
|
|
paths: {
|
|
storage: __dirname + '/broken-storage.js'
|
|
}
|
|
});
|
|
|
|
const jsFile = '' +
|
|
'\'use strict\';' +
|
|
'var StorageBase = require(\'ghost-storage-base\');' +
|
|
'class AnotherAdapter extends StorageBase {' +
|
|
'save(){}' +
|
|
'serve(){}' +
|
|
'delete(){}' +
|
|
'read(){}' +
|
|
'}' +
|
|
'module.exports = AnotherAdapter';
|
|
|
|
fs.writeFileSync(scope.adapter, jsFile);
|
|
|
|
try {
|
|
storage.getStorage();
|
|
} catch (err) {
|
|
should.exist(err);
|
|
should.equal(err.errorType, 'IncorrectUsageError');
|
|
}
|
|
});
|
|
});
|