/**
* Copyright (c) HashiCorp, Inc.
* SPDX-License-Identifier: BUSL-1.1
*/
import { module, test } from 'qunit';
import { setupRenderingTest } from 'vault/tests/helpers';
import { render } from '@ember/test-helpers';
import { hbs } from 'ember-cli-htmlbars';
import { getErrorResponse } from 'vault/tests/helpers/api/error-response';
import { GENERAL } from 'vault/tests/helpers/general-selectors';
module('Integration | Component | page/error', function (hooks) {
setupRenderingTest(hooks);
test('it should render 404 error', async function (assert) {
this.error = {
httpStatus: 404,
path: '/v1/kubernetes/config',
};
await render(hbs``);
assert.dom('h1').hasText('404 Not Found', 'Error title renders');
assert
.dom('p')
.hasText(`Sorry, we were unable to find any content at ${this.error.path}.`, 'Error message renders');
});
test('it should render 403 error', async function (assert) {
this.error = {
httpStatus: 403,
path: '/v1/kubernetes/config',
};
await render(hbs``);
assert.dom('h1').hasText('Not authorized', 'Error title renders');
assert
.dom('p')
.hasText(`You are not authorized to access content at ${this.error.path}.`, 'Error message renders');
});
test('it should render general error', async function (assert) {
this.error = {
message: 'An unexpected error occurred',
errors: ['This is one thing that went wrong', 'Unfortunately something else went wrong too'],
};
await render(hbs``);
assert.dom('h1').hasText('Error', 'Error title renders');
assert.dom('[data-test-page-error-message]').hasText(this.error.message, 'Error message renders');
this.error.errors.forEach((error, index) => {
assert
.dom(`[data-test-page-error-details="${index}"]`)
.hasText(this.error.errors[index], 'Error detail renders');
});
});
test('it should handle api client errors', async function (assert) {
this.error = getErrorResponse();
await render(hbs``);
assert
.dom(GENERAL.pageError.errorTitle('404'))
.hasText('404 Not Found', 'Error title renders based on status');
assert
.dom(GENERAL.pageError.errorSubtitle)
.hasText(
'Sorry, we were unable to find any content at /v1/test/error/parsing.',
'Error subtitle renders'
);
const error = { errors: ['something bad happened'], message: 'bad things occurred' };
this.error = getErrorResponse(error, 400);
await render(hbs``);
assert.dom(GENERAL.pageError.errorTitle('400')).hasText('Error', 'Error title renders');
assert.dom(GENERAL.pageError.errorMessage).hasText(error.message, 'Error message renders');
assert.dom(GENERAL.pageError.errorDetails).hasText(error.errors[0], 'Error details render');
});
});