mirror of
https://github.com/TryGhost/Ghost.git
synced 2024-12-20 17:32:15 +03:00
3536d91c9c
no issue - cleans up the interface to maintain consistency between loadScript and loadStyle - update gh-cm-editor component to await result of loadStyle
60 lines
1.9 KiB
JavaScript
60 lines
1.9 KiB
JavaScript
/* jshint expr:true */
|
|
import {expect} from 'chai';
|
|
import {describe, it} from 'mocha';
|
|
import {setupTest} from 'ember-mocha';
|
|
import Pretender from 'pretender';
|
|
import $ from 'jquery';
|
|
|
|
describe('Integration: Service: lazy-loader', function() {
|
|
setupTest('service:lazy-loader', {integration: true});
|
|
let server;
|
|
let ghostPaths = {
|
|
adminRoot: '/assets/'
|
|
};
|
|
|
|
beforeEach(function () {
|
|
server = new Pretender();
|
|
});
|
|
|
|
afterEach(function () {
|
|
server.shutdown();
|
|
});
|
|
|
|
it('loads a script correctly and only once', function () {
|
|
let subject = this.subject({
|
|
ghostPaths,
|
|
scriptPromises: {},
|
|
testing: false
|
|
});
|
|
|
|
server.get('/assets/test.js', function ({requestHeaders}) {
|
|
expect(requestHeaders.Accept).to.match(/text\/javascript/);
|
|
|
|
return [200, {'Content-Type': 'text/javascript'}, 'window.testLoadScript = \'testvalue\''];
|
|
});
|
|
|
|
return subject.loadScript('test-script', 'test.js').then(() => {
|
|
expect(subject.get('scriptPromises.test-script')).to.exist;
|
|
expect(window.testLoadScript).to.equal('testvalue');
|
|
expect(server.handlers[0].numberOfCalls).to.equal(1);
|
|
|
|
return subject.loadScript('test-script', 'test.js');
|
|
}).then(() => {
|
|
expect(server.handlers[0].numberOfCalls).to.equal(1);
|
|
});
|
|
});
|
|
|
|
it('loads styles correctly', function () {
|
|
let subject = this.subject({
|
|
ghostPaths,
|
|
testing: false
|
|
});
|
|
|
|
return subject.loadStyle('testing', 'style.css').catch(() => {
|
|
// we add a catch handler here because `/assets/style.css` doesn't exist
|
|
expect($('#testing-styles').length).to.equal(1);
|
|
expect($('#testing-styles').attr('href')).to.equal('/assets/style.css');
|
|
});
|
|
});
|
|
});
|