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