/** * Copyright (c) HashiCorp, Inc. * SPDX-License-Identifier: BUSL-1.1 */ import { module, test } from 'qunit'; import { setupTest } from 'ember-qunit'; import { env } from '../../../env'; const shouldHaveNspace = function (nspace) { return typeof nspace !== 'undefined' && env('CONSUL_NSPACES_ENABLED'); }; module('Integration | Adapter | oidc-provider', function (hooks) { setupTest(hooks); const dc = 'dc-1'; const id = 'slug'; const undefinedNspace = 'default'; [undefinedNspace, 'team-1', undefined].forEach((nspace) => { test('requestForQuery returns the correct url/method', function (assert) { const adapter = this.owner.lookup('adapter:oidc-provider'); const client = this.owner.lookup('service:client/http'); const request = client.requestParams.bind(client); const expected = `GET /v1/internal/ui/oidc-auth-methods?dc=${dc}${ shouldHaveNspace(nspace) ? `&ns=${nspace}` : `` }`; let actual = adapter.requestForQuery(request, { dc: dc, ns: nspace, }); assert.equal(`${actual.method} ${actual.url}`, expected); }); test('requestForQueryRecord returns the correct url/method', function (assert) { const adapter = this.owner.lookup('adapter:oidc-provider'); const client = this.owner.lookup('service:client/http'); const request = client.url.bind(client); const expected = `POST /v1/acl/oidc/auth-url?dc=${dc}${ shouldHaveNspace(nspace) ? `&ns=${nspace}` : `` }`; const actual = adapter .requestForQueryRecord(request, { dc: dc, id: id, ns: nspace, }) .split('\n') .shift(); assert.equal(actual, expected); }); test("requestForQueryRecord throws if you don't specify an id", function (assert) { const adapter = this.owner.lookup('adapter:oidc-provider'); const client = this.owner.lookup('service:client/http'); const request = client.url.bind(client); assert.throws(function () { adapter.requestForQueryRecord(request, { dc: dc, }); }); }); test('requestForAuthorize returns the correct url/method', function (assert) { const adapter = this.owner.lookup('adapter:oidc-provider'); const client = this.owner.lookup('service:client/http'); const request = client.url.bind(client); const expected = `POST /v1/acl/oidc/callback?dc=${dc}${ shouldHaveNspace(nspace) ? `&ns=${nspace}` : `` }`; const actual = adapter .requestForAuthorize(request, { dc: dc, id: id, code: 'code', state: 'state', ns: nspace, }) .split('\n') .shift(); assert.equal(actual, expected); }); test('requestForLogout returns the correct url/method', function (assert) { const adapter = this.owner.lookup('adapter:oidc-provider'); const client = this.owner.lookup('service:client/http'); const request = client.url.bind(client); const expected = `POST /v1/acl/logout`; const actual = adapter .requestForLogout(request, { id: id, }) .split('\n') .shift(); assert.equal(actual, expected); }); }); });