mirror of
https://github.com/hashicorp/vault.git
synced 2025-08-06 22:57:02 +02:00
56 lines
2.1 KiB
JavaScript
56 lines
2.1 KiB
JavaScript
/**
|
|
* Copyright (c) HashiCorp, Inc.
|
|
* SPDX-License-Identifier: BUSL-1.1
|
|
*/
|
|
|
|
/* eslint qunit/no-conditional-assertions: "warn" */
|
|
import { module, test } from 'qunit';
|
|
import { setupTest } from 'ember-qunit';
|
|
import { DOMAIN_STRINGS, PROVIDER_WITH_LOGO } from 'vault/models/role-jwt';
|
|
|
|
module('Unit | Model | role-jwt', function (hooks) {
|
|
setupTest(hooks);
|
|
|
|
test('it exists', function (assert) {
|
|
const model = this.owner.lookup('service:store').createRecord('role-jwt');
|
|
assert.ok(!!model);
|
|
assert.strictEqual(model.providerName, null, 'no providerName');
|
|
assert.strictEqual(model.providerIcon, null, 'no providerIcon');
|
|
});
|
|
|
|
test('it computes providerName when known provider url match fails', function (assert) {
|
|
const model = this.owner.lookup('service:store').createRecord('role-jwt', {
|
|
authUrl: 'http://example.com',
|
|
});
|
|
|
|
assert.strictEqual(model.providerName, null, 'no providerName');
|
|
assert.strictEqual(model.providerIcon, null, 'no providerIcon');
|
|
});
|
|
|
|
test('it provides a providerName for listed known providers', function (assert) {
|
|
assert.expect(12);
|
|
Object.keys(DOMAIN_STRINGS).forEach((domain) => {
|
|
const model = this.owner.lookup('service:store').createRecord('role-jwt', {
|
|
authUrl: `http://provider-${domain}`,
|
|
});
|
|
|
|
const expectedName = DOMAIN_STRINGS[domain];
|
|
assert.strictEqual(model.providerName, expectedName, `computes providerName: ${expectedName}`);
|
|
let expectedIcon = null;
|
|
if (PROVIDER_WITH_LOGO.includes(expectedName)) {
|
|
expectedIcon = expectedName.toLowerCase();
|
|
}
|
|
assert.strictEqual(model.providerIcon, expectedIcon, `computes providerIcon: ${domain}`);
|
|
});
|
|
});
|
|
|
|
test('it does not return provider unless domain matches completely', function (assert) {
|
|
assert.expect(2);
|
|
const model = this.owner.lookup('service:store').createRecord('role-jwt', {
|
|
authUrl: `http://custom-auth0-provider.com`,
|
|
});
|
|
assert.strictEqual(model.providerName, null, `no providerName for custom URL`);
|
|
assert.strictEqual(model.providerIcon, null, 'no providerIcon for custom URL');
|
|
});
|
|
});
|