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  });