github.com/Ilhicas/nomad@v1.0.4-0.20210304152020-e86851182bc3/ui/tests/acceptance/server-monitor-test.js (about) 1 import { currentURL } from '@ember/test-helpers'; 2 import { run } from '@ember/runloop'; 3 import { module, test } from 'qunit'; 4 import { setupApplicationTest } from 'ember-qunit'; 5 import { setupMirage } from 'ember-cli-mirage/test-support'; 6 import a11yAudit from 'nomad-ui/tests/helpers/a11y-audit'; 7 import ServerMonitor from 'nomad-ui/tests/pages/servers/monitor'; 8 import Layout from 'nomad-ui/tests/pages/layout'; 9 10 let agent; 11 let managementToken; 12 let clientToken; 13 14 module('Acceptance | server monitor', function(hooks) { 15 setupApplicationTest(hooks); 16 setupMirage(hooks); 17 18 hooks.beforeEach(function() { 19 agent = server.create('agent'); 20 21 managementToken = server.create('token'); 22 clientToken = server.create('token'); 23 24 window.localStorage.nomadTokenSecret = managementToken.secretId; 25 26 run.later(run, run.cancelTimers, 500); 27 }); 28 29 test('it passes an accessibility audit', async function(assert) { 30 await ServerMonitor.visit({ name: agent.name }); 31 await a11yAudit(assert); 32 }); 33 34 test('/servers/:id/monitor should have a breadcrumb trail linking back to servers', async function(assert) { 35 await ServerMonitor.visit({ name: agent.name }); 36 37 assert.equal(Layout.breadcrumbFor('servers.index').text, 'Servers'); 38 assert.equal(Layout.breadcrumbFor('servers.server').text, agent.name); 39 40 await Layout.breadcrumbFor('servers.index').visit(); 41 assert.equal(currentURL(), '/servers'); 42 }); 43 44 test('the monitor page immediately streams agent monitor output at the info level', async function(assert) { 45 await ServerMonitor.visit({ name: agent.name }); 46 47 const logRequest = server.pretender.handledRequests.find(req => 48 req.url.startsWith('/v1/agent/monitor') 49 ); 50 assert.ok(ServerMonitor.logsArePresent); 51 assert.ok(logRequest); 52 assert.ok(logRequest.url.includes('log_level=info')); 53 }); 54 55 test('switching the log level persists the new log level as a query param', async function(assert) { 56 await ServerMonitor.visit({ name: agent.name }); 57 await ServerMonitor.selectLogLevel('Debug'); 58 assert.equal(currentURL(), `/servers/${agent.name}/monitor?level=debug`); 59 }); 60 61 test('when the current access token does not include the agent:read rule, a descriptive error message is shown', async function(assert) { 62 window.localStorage.nomadTokenSecret = clientToken.secretId; 63 64 await ServerMonitor.visit({ name: agent.name }); 65 assert.notOk(ServerMonitor.logsArePresent); 66 assert.ok(ServerMonitor.error.isShown); 67 assert.equal(ServerMonitor.error.title, 'Not Authorized'); 68 assert.ok(ServerMonitor.error.message.includes('agent:read')); 69 70 await ServerMonitor.error.seekHelp(); 71 assert.equal(currentURL(), '/settings/tokens'); 72 }); 73 });