import { module, test } from 'qunit';
import { setupRenderingTest } from 'ember-qunit';
import { render, click } from '@ember/test-helpers';
import hbs from 'htmlbars-inline-precompile';
import sinon from 'sinon';
module('Integration | Component | sidebar-user-menu', function (hooks) {
setupRenderingTest(hooks);
hooks.beforeEach(function () {
this.auth = this.owner.lookup('service:auth');
});
test('it should render trigger and open menu', async function (assert) {
await render(hbs``);
assert
.dom('[data-test-user-menu-trigger] [data-test-icon="user"]')
.exists('Correct icon renders for menu trigger');
await click('[data-test-user-menu-trigger]');
assert.dom('[data-test-user-menu-content]').exists('User menu content renders');
});
test('it should render default menu items', async function (assert) {
sinon.stub(this.auth, 'currentToken').value('root');
sinon.stub(this.auth, 'authData').value({ displayName: 'token' });
await render(hbs``);
await click('[data-test-user-menu-trigger]');
assert.dom('.menu-label').hasText('Token', 'Auth data display name renders');
assert.dom('li').exists({ count: 2 }, 'Correct number of menu items render');
assert.dom('[data-clipboard-text="root"]').exists('Copy token action renders');
assert.dom('#logout').hasText('Log out', 'Log out action renders');
});
test('it should render conditional menu items', async function (assert) {
const router = this.owner.lookup('service:router');
const transitionStub = sinon.stub(router, 'transitionTo');
const renewStub = sinon.stub(this.auth, 'renew').resolves();
const revokeStub = sinon.stub(this.auth, 'revokeCurrentToken').resolves();
const date = new Date();
sinon.stub(this.auth, 'tokenExpirationDate').value(date.setDate(date.getDate() + 1));
sinon.stub(this.auth, 'authData').value({ displayName: 'token', renewable: true, entity_id: 'foo' });
this.auth.set('allowExpiration', true);
await render(hbs``);
await click('[data-test-user-menu-trigger]');
assert.dom('[data-test-user-menu-item="token alert"]').exists('Token expiration alert renders');
assert.dom('[data-test-user-menu-item="mfa"]').hasText('Multi-factor authentication', 'MFA link renders');
await click('[data-test-user-menu-item="revoke token"]');
await click('[data-test-confirm-button]');
assert.true(revokeStub.calledOnce, 'Auth revoke token method called on revoke confirm');
assert.true(
transitionStub.calledWith('vault.cluster.logout'),
'Route transitions to log out on revoke success'
);
await click('[data-test-user-menu-item="renew token"]');
assert.true(renewStub.calledOnce, 'Auth renew token method called');
});
});