mirror of
https://github.com/TryGhost/Ghost.git
synced 2025-02-24 23:48:13 -05:00
cleanup feature service error handling
This commit is contained in:
parent
648d0043e2
commit
ca707aa45f
3 changed files with 91 additions and 24 deletions
|
@ -8,6 +8,8 @@ const {
|
||||||
set
|
set
|
||||||
} = Ember;
|
} = Ember;
|
||||||
|
|
||||||
|
const EmberError = Ember.Error;
|
||||||
|
|
||||||
export function feature(name) {
|
export function feature(name) {
|
||||||
return computed(`config.${name}`, `labs.${name}`, {
|
return computed(`config.${name}`, `labs.${name}`, {
|
||||||
get() {
|
get() {
|
||||||
|
@ -22,7 +24,7 @@ export function feature(name) {
|
||||||
});
|
});
|
||||||
},
|
},
|
||||||
set(key, value) {
|
set(key, value) {
|
||||||
this.update(key, value).then((savedValue) => {
|
return this.update(key, value).then((savedValue) => {
|
||||||
return savedValue;
|
return savedValue;
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
@ -76,8 +78,13 @@ export default Service.extend({
|
||||||
this.set('_settings', savedSettings);
|
this.set('_settings', savedSettings);
|
||||||
resolve(this._parseLabs(savedSettings).get(key));
|
resolve(this._parseLabs(savedSettings).get(key));
|
||||||
}).catch((errors) => {
|
}).catch((errors) => {
|
||||||
this.get('notifications').showErrors(errors);
|
if (errors) { // model.save errors, show notifications
|
||||||
settings.rollbackAttributes();
|
this.get('notifications').showErrors(errors);
|
||||||
|
settings.rollbackAttributes();
|
||||||
|
} else {
|
||||||
|
settings.rollbackAttributes();
|
||||||
|
throw new EmberError(`Validation of the feature service settings model failed when updating labs.`);
|
||||||
|
}
|
||||||
resolve(this._parseLabs(settings)[key]);
|
resolve(this._parseLabs(settings)[key]);
|
||||||
});
|
});
|
||||||
}).catch(reject);
|
}).catch(reject);
|
||||||
|
|
|
@ -6,30 +6,43 @@ import Pretender from 'pretender';
|
||||||
import wait from 'ember-test-helpers/wait';
|
import wait from 'ember-test-helpers/wait';
|
||||||
import FeatureService, {feature} from 'ghost/services/feature';
|
import FeatureService, {feature} from 'ghost/services/feature';
|
||||||
import Ember from 'ember';
|
import Ember from 'ember';
|
||||||
|
import { errorOverride, errorReset } from 'ghost/tests/helpers/adapter-error';
|
||||||
|
|
||||||
const {merge, run} = Ember;
|
const {merge, run} = Ember;
|
||||||
|
const EmberError = Ember.Error;
|
||||||
|
|
||||||
|
function stubSettings(server, labs, validSave = true, validSettings = true) {
|
||||||
|
let settings = [
|
||||||
|
{
|
||||||
|
id: '1',
|
||||||
|
type: 'blog',
|
||||||
|
key: 'labs',
|
||||||
|
value: JSON.stringify(labs)
|
||||||
|
}
|
||||||
|
];
|
||||||
|
|
||||||
|
if (validSettings) {
|
||||||
|
settings.push({
|
||||||
|
id: '2',
|
||||||
|
type: 'blog',
|
||||||
|
key: 'postsPerPage',
|
||||||
|
value: 1
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
function stubSettings(server, labs) {
|
|
||||||
server.get('/ghost/api/v0.1/settings/', function () {
|
server.get('/ghost/api/v0.1/settings/', function () {
|
||||||
return [200, {'Content-Type': 'application/json'}, JSON.stringify({settings: [
|
return [200, {'Content-Type': 'application/json'}, JSON.stringify({settings})];
|
||||||
{
|
|
||||||
id: '1',
|
|
||||||
type: 'blog',
|
|
||||||
key: 'labs',
|
|
||||||
value: JSON.stringify(labs)
|
|
||||||
},
|
|
||||||
// postsPerPage is needed to satisfy the validation
|
|
||||||
{
|
|
||||||
id: '2',
|
|
||||||
type: 'blog',
|
|
||||||
key: 'postsPerPage',
|
|
||||||
value: 1
|
|
||||||
}
|
|
||||||
]})];
|
|
||||||
});
|
});
|
||||||
|
|
||||||
server.put('/ghost/api/v0.1/settings/', function (request) {
|
server.put('/ghost/api/v0.1/settings/', function (request) {
|
||||||
return [200, {'Content-Type': 'application/json'}, request.requestBody];
|
let statusCode = (validSave) ? 200 : 400;
|
||||||
|
let response = (validSave) ? request.requestBody : JSON.stringify({
|
||||||
|
errors: [{
|
||||||
|
message: 'Test Error'
|
||||||
|
}]
|
||||||
|
});
|
||||||
|
|
||||||
|
return [statusCode, {'Content-Type': 'application/json'}, response];
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -182,7 +195,6 @@ describeModule(
|
||||||
return wait().then(() => {
|
return wait().then(() => {
|
||||||
expect(server.handlers[1].numberOfCalls).to.equal(1);
|
expect(server.handlers[1].numberOfCalls).to.equal(1);
|
||||||
|
|
||||||
// TODO: failing because service.update only sets values on
|
|
||||||
service.get('testFlag').then((testFlag) => {
|
service.get('testFlag').then((testFlag) => {
|
||||||
expect(testFlag).to.be.true;
|
expect(testFlag).to.be.true;
|
||||||
done();
|
done();
|
||||||
|
@ -190,7 +202,56 @@ describeModule(
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
it('notifies for server errors');
|
it('notifies for server errors', function (done) {
|
||||||
it('notifies for validation errors');
|
stubSettings(server, {testFlag: false}, false);
|
||||||
|
addTestFlag();
|
||||||
|
|
||||||
|
let service = this.subject();
|
||||||
|
|
||||||
|
run(() => {
|
||||||
|
service.get('testFlag').then((testFlag) => {
|
||||||
|
expect(testFlag).to.be.false;
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
run(() => {
|
||||||
|
service.set('testFlag', true);
|
||||||
|
});
|
||||||
|
|
||||||
|
return wait().then(() => {
|
||||||
|
expect(server.handlers[1].numberOfCalls).to.equal(1);
|
||||||
|
|
||||||
|
expect(service.get('notifications.notifications').length).to.equal(1);
|
||||||
|
|
||||||
|
service.get('testFlag').then((testFlag) => {
|
||||||
|
expect(testFlag).to.be.false;
|
||||||
|
done();
|
||||||
|
});
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
it('notifies for validation errors', function (done) {
|
||||||
|
stubSettings(server, {testFlag: false}, true, false);
|
||||||
|
addTestFlag();
|
||||||
|
|
||||||
|
let service = this.subject();
|
||||||
|
|
||||||
|
run(() => {
|
||||||
|
service.get('testFlag').then((testFlag) => {
|
||||||
|
expect(testFlag).to.be.false;
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
run(() => {
|
||||||
|
expect(() => {
|
||||||
|
service.set('testFlag', true);
|
||||||
|
}, EmberError, 'Threw validation error');
|
||||||
|
});
|
||||||
|
|
||||||
|
service.get('testFlag').then((testFlag) => {
|
||||||
|
expect(testFlag).to.be.false;
|
||||||
|
done();
|
||||||
|
});
|
||||||
|
});
|
||||||
}
|
}
|
||||||
);
|
);
|
||||||
|
|
|
@ -112,7 +112,6 @@ describe('Unit: Validator: tag-settings', function () {
|
||||||
nameErrors = tag.get('errors').errorsFor('name').get(0);
|
nameErrors = tag.get('errors').errorsFor('name').get(0);
|
||||||
expect(nameErrors.attribute, 'errors.name.attribute').to.equal('name');
|
expect(nameErrors.attribute, 'errors.name.attribute').to.equal('name');
|
||||||
expect(nameErrors.message, 'errors.name.message').to.equal('Tag names can\'t start with commas.');
|
expect(nameErrors.message, 'errors.name.message').to.equal('Tag names can\'t start with commas.');
|
||||||
expect(tag.get('errors.length')).to.equal(1);
|
|
||||||
|
|
||||||
expect(passed, 'passed').to.be.false;
|
expect(passed, 'passed').to.be.false;
|
||||||
expect(tag.get('hasValidated'), 'hasValidated').to.include('name');
|
expect(tag.get('hasValidated'), 'hasValidated').to.include('name');
|
||||||
|
|
Loading…
Add table
Reference in a new issue