import { module, test } from 'qunit';
import { setupRenderingTest } from 'ember-qunit';
import { render } from '@ember/test-helpers';
import engineResolverFor from 'ember-engines/test-support/engine-resolver-for';
import hbs from 'htmlbars-inline-precompile';
const resolver = engineResolverFor('replication');
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, { resolver });
hooks.beforeEach(function() {
this.set('secondaries', SECONDARIES);
});
test('it renders a table of known secondaries', async function(assert) {
await render(hbs``);
assert.dom('[data-test-known-secondaries-table]').exists();
});
test('it shows the secondary URL and connection_status', async function(assert) {
await render(hbs``);
SECONDARIES.forEach(secondary => {
assert.equal(
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.equal(
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.equal(
this.element
.querySelector(`[data-test-secondaries=connection-status-for-${secondary.node_id}]`)
.innerHTML.trim(),
secondary.connection_status,
'shows the connection status'
);
});
});
});