import Mirage from 'ember-cli-mirage'; import setupMirage from 'ember-cli-mirage/test-support/setup-mirage'; import {authenticateSession} from 'ember-simple-auth/test-support'; import {beforeEach, describe, it} from 'mocha'; import {click, currentRouteName, fillIn, find, findAll, visit} from '@ember/test-helpers'; import {expect} from 'chai'; import {fileUpload} from '../helpers/file-upload'; import {setupApplicationTest} from 'ember-mocha'; import {versionMismatchResponse} from 'ghost-admin/mirage/utils'; let htmlErrorResponse = function () { return new Mirage.Response( 504, {'Content-Type': 'text/html'}, 'Server Error504 Gateway Timeout' ); }; describe('Acceptance: Error Handling', function () { let hooks = setupApplicationTest(); setupMirage(hooks); describe('VersionMismatch errors', function () { describe('logged in', function () { beforeEach(async function () { let role = this.server.create('role', {name: 'Administrator'}); this.server.create('user', {roles: [role]}); return await authenticateSession(); }); it('displays an alert and disables navigation when saving', async function () { this.server.createList('post', 3); // mock the post save endpoint to return version mismatch this.server.put('/posts/:id', versionMismatchResponse); await visit('/'); await click('.posts-list li:nth-of-type(2) a'); // select second post await click('[data-test-publishmenu-trigger]'); await click('[data-test-publishmenu-save]'); // "Save post" // has the refresh to update alert expect(findAll('.gh-alert').length).to.equal(1); expect(find('.gh-alert').textContent).to.match(/refresh/); // try navigating back to the content list await click('[data-test-link="posts"]'); expect(currentRouteName()).to.equal('editor.edit'); }); it('displays alert and aborts the transition when navigating', async function () { await visit('/'); // mock the tags endpoint to return version mismatch this.server.get('/tags/', versionMismatchResponse); await click('[data-test-nav="tags"]'); // navigation is blocked on loading screen expect(currentRouteName()).to.equal('settings.tags_loading'); // has the refresh to update alert expect(findAll('.gh-alert').length).to.equal(1); expect(find('.gh-alert').textContent).to.match(/refresh/); }); it('displays alert and aborts the transition when an ember-ajax error is thrown whilst navigating', async function () { this.server.get('/settings/', versionMismatchResponse); await visit('/settings/tags'); await click('[data-test-nav="settings"]'); // navigation is blocked expect(currentRouteName()).to.equal('settings.general_loading'); // has the refresh to update alert expect(findAll('.gh-alert').length).to.equal(1); expect(find('.gh-alert').textContent).to.match(/refresh/); }); it('can be triggered when passed in to a component', async function () { this.server.post('/subscribers/csv/', versionMismatchResponse); await visit('/subscribers'); await click('[data-test-link="import-csv"]'); await fileUpload('.fullscreen-modal input[type="file"]', ['test'], {name: 'test.csv'}); // alert is shown expect(findAll('.gh-alert').length).to.equal(1); expect(find('.gh-alert').textContent).to.match(/refresh/); }); }); describe('logged out', function () { it('displays alert', async function () { this.server.post('/session', versionMismatchResponse); await visit('/signin'); await fillIn('[name="identification"]', 'test@example.com'); await fillIn('[name="password"]', 'password'); await click('.gh-btn-blue'); // has the refresh to update alert expect(findAll('.gh-alert').length).to.equal(1); expect(find('.gh-alert').textContent).to.match(/refresh/); }); }); }); describe('CloudFlare errors', function () { beforeEach(async function () { this.server.loadFixtures(); let roles = this.server.schema.roles.where({name: 'Administrator'}); this.server.create('user', {roles}); return await authenticateSession(); }); it('handles Ember Data HTML response', async function () { this.server.put('/posts/1/', htmlErrorResponse); this.server.create('post'); await visit('/editor/post/1'); await click('[data-test-publishmenu-trigger]'); await click('[data-test-publishmenu-save]'); expect(findAll('.gh-alert').length).to.equal(1); expect(find('.gh-alert').textContent).to.not.match(/html>/); expect(find('.gh-alert').textContent).to.match(/Request was rejected due to server error/); }); it('handles ember-ajax HTML response', async function () { this.server.del('/themes/foo/', htmlErrorResponse); await visit('/settings/design'); await click('[data-test-theme-id="foo"] [data-test-theme-delete-button]'); await click('.fullscreen-modal [data-test-delete-button]'); expect(findAll('.gh-alert').length).to.equal(1); expect(find('.gh-alert').textContent).to.not.match(/html>/); expect(find('.gh-alert').textContent).to.match(/Request was rejected due to server error/); }); }); });