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