2017-12-15 21:39:18 +00:00
|
|
|
import $ from 'jquery';
|
2017-09-30 01:33:57 +00:00
|
|
|
import { click, find, findAll, currentURL, visit } from 'ember-native-dom-helpers';
|
2017-09-19 14:47:10 +00:00
|
|
|
import { test } from 'qunit';
|
|
|
|
import moduleForAcceptance from 'nomad-ui/tests/helpers/module-for-acceptance';
|
|
|
|
import { findLeader } from '../../mirage/config';
|
|
|
|
import ipParts from 'nomad-ui/utils/ip-parts';
|
|
|
|
|
|
|
|
function minimumSetup() {
|
|
|
|
server.createList('node', 1);
|
|
|
|
server.createList('agent', 1);
|
|
|
|
}
|
|
|
|
|
2017-10-28 01:23:41 +00:00
|
|
|
moduleForAcceptance('Acceptance | clients list');
|
2017-09-19 14:47:10 +00:00
|
|
|
|
2017-10-28 01:23:41 +00:00
|
|
|
test('/clients should list one page of clients', function(assert) {
|
2017-09-19 14:47:10 +00:00
|
|
|
// Make sure to make more nodes than 1 page to assert that pagination is working
|
|
|
|
const nodesCount = 10;
|
|
|
|
const pageSize = 8;
|
|
|
|
|
|
|
|
server.createList('node', nodesCount);
|
|
|
|
server.createList('agent', 1);
|
|
|
|
|
2017-10-28 01:23:41 +00:00
|
|
|
visit('/clients');
|
2017-09-19 14:47:10 +00:00
|
|
|
|
|
|
|
andThen(() => {
|
2017-09-26 07:47:16 +00:00
|
|
|
assert.equal(findAll('.client-node-row').length, pageSize);
|
|
|
|
assert.ok(findAll('.pagination').length, 'Pagination found on the page');
|
2017-09-19 14:47:10 +00:00
|
|
|
|
|
|
|
const sortedNodes = server.db.nodes.sortBy('modifyIndex').reverse();
|
|
|
|
|
|
|
|
for (var nodeNumber = 0; nodeNumber < pageSize; nodeNumber++) {
|
|
|
|
assert.equal(
|
2017-09-26 07:47:16 +00:00
|
|
|
$(`.client-node-row:eq(${nodeNumber}) td:eq(0)`).text(),
|
2017-09-19 14:47:10 +00:00
|
|
|
sortedNodes[nodeNumber].id.split('-')[0],
|
2017-10-28 01:23:41 +00:00
|
|
|
'Clients are ordered'
|
2017-09-19 14:47:10 +00:00
|
|
|
);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
test('each client record should show high-level info of the client', function(assert) {
|
|
|
|
minimumSetup();
|
|
|
|
const node = server.db.nodes[0];
|
|
|
|
|
2017-10-28 01:23:41 +00:00
|
|
|
visit('/clients');
|
2017-09-19 14:47:10 +00:00
|
|
|
|
|
|
|
andThen(() => {
|
2017-09-26 07:47:16 +00:00
|
|
|
const nodeRow = $(findAll('.client-node-row')[0]);
|
2017-09-19 14:47:10 +00:00
|
|
|
const allocations = server.db.allocations.where({ nodeId: node.id });
|
|
|
|
const { address, port } = ipParts(node.httpAddr);
|
|
|
|
|
|
|
|
assert.equal(nodeRow.find('td:eq(0)').text(), node.id.split('-')[0], 'ID');
|
|
|
|
assert.equal(nodeRow.find('td:eq(1)').text(), node.name, 'Name');
|
|
|
|
assert.equal(nodeRow.find('td:eq(2)').text(), node.status, 'Status');
|
|
|
|
assert.equal(nodeRow.find('td:eq(3)').text(), address, 'Address');
|
|
|
|
assert.equal(nodeRow.find('td:eq(4)').text(), port, 'Port');
|
|
|
|
assert.equal(nodeRow.find('td:eq(5)').text(), node.datacenter, 'Datacenter');
|
|
|
|
assert.equal(nodeRow.find('td:eq(6)').text(), allocations.length, '# Allocations');
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
test('each client should link to the client detail page', function(assert) {
|
|
|
|
minimumSetup();
|
|
|
|
const node = server.db.nodes[0];
|
|
|
|
|
2017-10-28 01:23:41 +00:00
|
|
|
visit('/clients');
|
2017-09-26 07:47:16 +00:00
|
|
|
andThen(() => {
|
|
|
|
click(findAll('.client-node-row')[0]);
|
|
|
|
});
|
2017-09-19 14:47:10 +00:00
|
|
|
|
|
|
|
andThen(() => {
|
2017-10-28 01:23:41 +00:00
|
|
|
assert.equal(currentURL(), `/clients/${node.id}`);
|
2017-09-19 14:47:10 +00:00
|
|
|
});
|
|
|
|
});
|
|
|
|
|
2017-09-30 01:33:57 +00:00
|
|
|
test('when there are no clients, there is an empty message', function(assert) {
|
|
|
|
server.createList('agent', 1);
|
|
|
|
|
2017-10-28 01:23:41 +00:00
|
|
|
visit('/clients');
|
2017-09-30 01:33:57 +00:00
|
|
|
|
|
|
|
andThen(() => {
|
|
|
|
assert.ok(find('.empty-message'));
|
|
|
|
assert.equal(find('.empty-message-headline').textContent, 'No Clients');
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
test('when there are clients, but no matches for a search term, there is an empty message', function(
|
|
|
|
assert
|
|
|
|
) {
|
|
|
|
server.createList('agent', 1);
|
|
|
|
server.create('node', { name: 'node' });
|
|
|
|
|
2017-10-28 01:23:41 +00:00
|
|
|
visit('/clients');
|
2017-09-30 01:33:57 +00:00
|
|
|
|
|
|
|
andThen(() => {
|
|
|
|
fillIn('.search-box input', 'client');
|
|
|
|
});
|
|
|
|
|
|
|
|
andThen(() => {
|
|
|
|
assert.ok(find('.empty-message'));
|
|
|
|
assert.equal(find('.empty-message-headline').textContent, 'No Matches');
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
2017-10-24 23:08:01 +00:00
|
|
|
test('when accessing clients is forbidden, show a message with a link to the tokens page', function(
|
|
|
|
assert
|
|
|
|
) {
|
|
|
|
server.create('agent');
|
|
|
|
server.create('node', { name: 'node' });
|
|
|
|
server.pretender.get('/v1/nodes', () => [403, {}, null]);
|
|
|
|
|
2017-10-28 01:23:41 +00:00
|
|
|
visit('/clients');
|
2017-10-24 23:08:01 +00:00
|
|
|
|
|
|
|
andThen(() => {
|
|
|
|
assert.equal(find('.empty-message-headline').textContent, 'Not Authorized');
|
|
|
|
});
|
|
|
|
|
|
|
|
andThen(() => {
|
|
|
|
click('.empty-message-body a');
|
|
|
|
});
|
|
|
|
|
|
|
|
andThen(() => {
|
|
|
|
assert.equal(currentURL(), '/settings/tokens');
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
2017-09-19 14:47:10 +00:00
|
|
|
test('/servers should list all servers', function(assert) {
|
|
|
|
const agentsCount = 10;
|
|
|
|
const pageSize = 8;
|
|
|
|
|
|
|
|
server.createList('node', 1);
|
|
|
|
server.createList('agent', agentsCount);
|
|
|
|
|
|
|
|
const leader = findLeader(server.schema);
|
|
|
|
|
|
|
|
visit('/servers');
|
|
|
|
|
|
|
|
andThen(() => {
|
2017-09-26 07:47:16 +00:00
|
|
|
assert.equal(findAll('.server-agent-row').length, pageSize);
|
2017-09-19 14:47:10 +00:00
|
|
|
|
|
|
|
const sortedAgents = server.db.agents
|
|
|
|
.sort((a, b) => {
|
|
|
|
if (`${a.address}:${a.tags.port}` === leader) {
|
|
|
|
return 1;
|
|
|
|
} else if (`${b.address}:${b.tags.port}` === leader) {
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
return 0;
|
|
|
|
})
|
|
|
|
.reverse();
|
|
|
|
|
|
|
|
for (var agentNumber = 0; agentNumber < 8; agentNumber++) {
|
|
|
|
assert.equal(
|
2017-09-26 07:47:16 +00:00
|
|
|
$(`.server-agent-row:eq(${agentNumber}) td:eq(0)`).text(),
|
2017-09-19 14:47:10 +00:00
|
|
|
sortedAgents[agentNumber].name,
|
|
|
|
'Clients are ordered'
|
|
|
|
);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
test('each server should show high-level info of the server', function(assert) {
|
|
|
|
minimumSetup();
|
|
|
|
const agent = server.db.agents[0];
|
|
|
|
|
|
|
|
visit('/servers');
|
|
|
|
|
|
|
|
andThen(() => {
|
2017-09-26 07:47:16 +00:00
|
|
|
const agentRow = $(findAll('.server-agent-row')[0]);
|
2017-09-19 14:47:10 +00:00
|
|
|
|
|
|
|
assert.equal(agentRow.find('td:eq(0)').text(), agent.name, 'Name');
|
|
|
|
assert.equal(agentRow.find('td:eq(1)').text(), agent.status, 'Status');
|
|
|
|
assert.equal(agentRow.find('td:eq(2)').text(), 'True', 'Leader?');
|
|
|
|
assert.equal(agentRow.find('td:eq(3)').text(), agent.address, 'Address');
|
|
|
|
assert.equal(agentRow.find('td:eq(4)').text(), agent.serf_port, 'Serf Port');
|
|
|
|
assert.equal(agentRow.find('td:eq(5)').text(), agent.tags.dc, 'Datacenter');
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
test('each server should link to the server detail page', function(assert) {
|
|
|
|
minimumSetup();
|
|
|
|
const agent = server.db.agents[0];
|
|
|
|
|
|
|
|
visit('/servers');
|
2017-09-26 07:47:16 +00:00
|
|
|
andThen(() => {
|
|
|
|
click(findAll('.server-agent-row')[0]);
|
|
|
|
});
|
2017-09-19 14:47:10 +00:00
|
|
|
|
|
|
|
andThen(() => {
|
|
|
|
assert.equal(currentURL(), `/servers/${agent.name}`);
|
|
|
|
});
|
|
|
|
});
|
2017-09-30 02:20:28 +00:00
|
|
|
|
2017-10-24 23:08:01 +00:00
|
|
|
test('when accessing servers is forbidden, show a message with a link to the tokens page', function(
|
|
|
|
assert
|
|
|
|
) {
|
|
|
|
server.create('agent');
|
|
|
|
server.pretender.get('/v1/agent/members', () => [403, {}, null]);
|
|
|
|
|
|
|
|
visit('/servers');
|
|
|
|
|
|
|
|
andThen(() => {
|
|
|
|
assert.equal(find('.empty-message-headline').textContent, 'Not Authorized');
|
|
|
|
});
|
|
|
|
|
|
|
|
andThen(() => {
|
|
|
|
click('.empty-message-body a');
|
|
|
|
});
|
|
|
|
|
|
|
|
andThen(() => {
|
|
|
|
assert.equal(currentURL(), '/settings/tokens');
|
|
|
|
});
|
|
|
|
});
|