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