/** * Copyright (c) HashiCorp, Inc. * SPDX-License-Identifier: MPL-2.0 */ /* eslint qunit/no-conditional-assertions: "warn" */ import { module, test } from 'qunit'; import { setupRenderingTest } from 'ember-qunit'; import { render } from '@ember/test-helpers'; import { setupEngine } from 'ember-engines/test-support'; import hbs from 'htmlbars-inline-precompile'; const SECONDARIES = [ { node_id: 'secondary-1', api_address: 'https://127.0.0.1:52304', connection_status: 'connected' }, { node_id: '2nd', connection_status: 'disconnected' }, { node_id: '_three_', api_address: 'http://127.0.0.1:8202', connection_status: 'connected' }, ]; module('Integration | Component | replication known-secondaries-table', function (hooks) { setupRenderingTest(hooks); setupEngine(hooks, 'replication'); hooks.beforeEach(function () { this.context = { owner: this.engine }; // this.engine set by setupEngine this.set('secondaries', SECONDARIES); }); test('it renders a table of known secondaries', async function (assert) { await render(hbs``, this.context); assert.dom('[data-test-known-secondaries-table]').exists(); }); test('it shows the secondary URL and connection_status', async function (assert) { assert.expect(9); await render(hbs``, this.context); SECONDARIES.forEach((secondary) => { assert.strictEqual( this.element.querySelector(`[data-test-secondaries=row-for-${secondary.node_id}]`).innerHTML.trim(), secondary.node_id, 'shows a table row and ID for each known secondary' ); if (secondary.api_address) { const expectedUrl = `${secondary.api_address}/ui/`; assert.strictEqual( this.element.querySelector(`[data-test-secondaries=api-address-for-${secondary.node_id}]`).href, expectedUrl, 'renders a URL to the secondary UI' ); } else { assert.notOk( this.element.querySelector(`[data-test-secondaries=api-address-for-${secondary.node_id}]`) ); } assert.strictEqual( this.element .querySelector(`[data-test-secondaries=connection-status-for-${secondary.node_id}]`) .innerHTML.trim(), secondary.connection_status, 'shows the connection status' ); }); }); });