Ghost/ghost/admin/tests/integration/services/config-test.js
Kevin Ansfield 7b443d4b63 Removed need for .get() with config service
no issue

The `config` service has been a source of confusion when writing with modern Ember patterns because it's use of the deprecated `ProxyMixin` forced all property access/setting to go via `.get()` and `.set()` whereas the rest of the system has mostly (there are a few other uses of ProxyObjects remaining) eliminated the use of the non-native get/set methods.

- removed use of `ProxyMixin` in the `config` service by grabbing the API response after fetching and using `Object.defineProperty()` to add native getters/setters that pass through to a tracked object holding the API response data. Ember's autotracking automatically works across the native getters/setters so we can then use the service as if it was any other native object
- updated all code to use `config.{attrName}` directly for getting/setting instead of `.get()` and `.set()`
- removed unnecessary async around `config.availableTimezones` which wasn't making any async calls
2022-10-07 16:14:57 +01:00

77 lines
2.3 KiB
JavaScript

import Pretender from 'pretender';
import ghostPaths from 'ghost-admin/utils/ghost-paths';
import {describe, it} from 'mocha';
import {expect} from 'chai';
import {settled} from '@ember/test-helpers';
import {setupTest} from 'ember-mocha';
describe('Integration: Service: config', function () {
setupTest();
let server;
beforeEach(function () {
server = new Pretender();
});
afterEach(function () {
server.shutdown();
});
it('returns a list of timezones in the expected format', function () {
const service = this.owner.lookup('service:config');
const timezones = service.availableTimezones;
expect(timezones.length).to.equal(66);
expect(timezones[0].name).to.equal('Pacific/Pago_Pago');
expect(timezones[0].label).to.equal('(GMT -11:00) Midway Island, Samoa');
expect(timezones[1].name).to.equal('Pacific/Honolulu');
expect(timezones[1].label).to.equal('(GMT -10:00) Hawaii');
});
it('normalizes blogUrl to non-trailing-slash', function (done) {
let stubBlogUrl = function stubBlogUrl(url) {
server.get(`${ghostPaths().apiRoot}/config/`, function () {
return [
200,
{'Content-Type': 'application/json'},
JSON.stringify({})
];
});
server.get(`${ghostPaths().apiRoot}/site/`, function () {
return [
200,
{'Content-Type': 'application/json'},
JSON.stringify({
site: {
url
}
})
];
});
};
let service = this.owner.lookup('service:config');
stubBlogUrl('http://localhost:2368/');
service.fetch().then(() => {
expect(
service.get('blogUrl'), 'trailing-slash'
).to.equal('http://localhost:2368');
});
settled().then(() => {
stubBlogUrl('http://localhost:2368');
service.fetch().then(() => {
expect(
service.get('blogUrl'), 'non-trailing-slash'
).to.equal('http://localhost:2368');
done();
});
});
});
});