open-nomad/ui/tests/acceptance/servers-list-test.js
Phil Renaud b67bd4c377
Percy snapshot tests (#12872)
* Sample percy test added

* Node engine up to 14.x for UI prep

* Force ui test rerun

* Updated config.yml

* Node v upgraded to 14 for docker image

* Expect length in test

* Running ember tests under percy exec

* Percy exec format

* Percy cli added

* Noop to rerun tests with updated percy_token

* Evals full list and details open snapshots

* Pretty legit use of assert so disable the warning

* Jobs list tests

* Snapshots for top-level clients, servers, ACL, topology, and storage lists

* Expect caveat for Topology test

* Stabilizing tests with faker seeded to 1

* Seed-stabilizing any tests with percySnapshots

* Faker import

* Drop unused param

* Assets and test audit using an older node version

* New strategy: avoid seeding, just use percyCSS to hide certain things
2022-05-05 16:05:13 -04:00

106 lines
3.2 KiB
JavaScript

/* eslint-disable qunit/require-expect */
import { currentURL } from '@ember/test-helpers';
import { module, test } from 'qunit';
import { setupApplicationTest } from 'ember-qunit';
import { setupMirage } from 'ember-cli-mirage/test-support';
import a11yAudit from 'nomad-ui/tests/helpers/a11y-audit';
import { findLeader } from '../../mirage/config';
import ServersList from 'nomad-ui/tests/pages/servers/list';
import formatHost from 'nomad-ui/utils/format-host';
import percySnapshot from '@percy/ember';
const minimumSetup = () => {
server.createList('node', 1);
server.createList('agent', 1);
};
const agentSort = (leader) => (a, b) => {
if (formatHost(a.member.Address, a.member.Tags.port) === leader) {
return 1;
} else if (formatHost(b.member.Address, b.member.Tags.port) === leader) {
return -1;
}
return 0;
};
module('Acceptance | servers list', function (hooks) {
setupApplicationTest(hooks);
setupMirage(hooks);
test('it passes an accessibility audit', async function (assert) {
minimumSetup();
await ServersList.visit();
await a11yAudit(assert);
});
test('/servers should list all servers', async function (assert) {
server.createList('node', 1);
server.createList('agent', 10);
const leader = findLeader(server.schema);
const sortedAgents = server.db.agents.sort(agentSort(leader)).reverse();
await ServersList.visit();
await percySnapshot(assert);
assert.equal(
ServersList.servers.length,
ServersList.pageSize,
'List is stopped at pageSize'
);
ServersList.servers.forEach((server, index) => {
assert.equal(
server.name,
sortedAgents[index].name,
'Servers are ordered'
);
});
assert.equal(document.title, 'Servers - Nomad');
});
test('each server should show high-level info of the server', async function (assert) {
minimumSetup();
const agent = server.db.agents[0];
await ServersList.visit();
const agentRow = ServersList.servers.objectAt(0);
assert.equal(agentRow.name, agent.name, 'Name');
assert.equal(agentRow.status, agent.member.Status, 'Status');
assert.equal(agentRow.leader, 'True', 'Leader?');
assert.equal(agentRow.address, agent.member.Address, 'Address');
assert.equal(agentRow.serfPort, agent.member.Port, 'Serf Port');
assert.equal(agentRow.datacenter, agent.member.Tags.dc, 'Datacenter');
assert.equal(agentRow.version, agent.version, 'Version');
});
test('each server should link to the server detail page', async function (assert) {
minimumSetup();
const agent = server.db.agents[0];
await ServersList.visit();
await ServersList.servers.objectAt(0).clickRow();
assert.equal(
currentURL(),
`/servers/${agent.name}`,
'Now at the server detail page'
);
});
test('when accessing servers is forbidden, show a message with a link to the tokens page', async function (assert) {
server.create('agent');
server.pretender.get('/v1/agent/members', () => [403, {}, null]);
await ServersList.visit();
assert.equal(ServersList.error.title, 'Not Authorized');
await ServersList.error.seekHelp();
assert.equal(currentURL(), '/settings/tokens');
});
});