2023-03-15 16:00:52 +00:00
|
|
|
/**
|
|
|
|
* Copyright (c) HashiCorp, Inc.
|
|
|
|
* SPDX-License-Identifier: MPL-2.0
|
|
|
|
*/
|
|
|
|
|
2021-11-15 15:48:11 +00:00
|
|
|
import { module, test } from 'qunit';
|
|
|
|
import { setupTest } from 'ember-qunit';
|
|
|
|
import EmberObject from '@ember/object';
|
|
|
|
import Evented from '@ember/object/evented';
|
|
|
|
import sinon from 'sinon';
|
2022-03-21 21:09:59 +00:00
|
|
|
import { _cancelTimers as cancelTimers } from '@ember/runloop';
|
2021-11-15 15:48:11 +00:00
|
|
|
|
|
|
|
const mockWindow = EmberObject.extend(Evented, {
|
|
|
|
origin: 'http://localhost:4200',
|
2023-02-08 20:32:57 +00:00
|
|
|
close: () => {},
|
2021-11-15 15:48:11 +00:00
|
|
|
});
|
|
|
|
|
2021-12-17 03:44:29 +00:00
|
|
|
module('Unit | Component | auth-jwt', function (hooks) {
|
2021-11-15 15:48:11 +00:00
|
|
|
setupTest(hooks);
|
|
|
|
|
2021-12-17 03:44:29 +00:00
|
|
|
hooks.beforeEach(function () {
|
2021-11-15 15:48:11 +00:00
|
|
|
this.component = this.owner.lookup('component:auth-jwt');
|
|
|
|
this.component.set('window', mockWindow.create());
|
|
|
|
this.errorSpy = sinon.spy(this.component, 'handleOIDCError');
|
|
|
|
});
|
|
|
|
|
2023-02-08 20:32:57 +00:00
|
|
|
test('it should ignore messages from cross origin windows while waiting for oidc callback', async function (assert) {
|
|
|
|
assert.expect(2);
|
2021-11-15 15:48:11 +00:00
|
|
|
this.component.prepareForOIDC.perform(mockWindow.create());
|
|
|
|
this.component.window.trigger('message', { origin: 'http://anotherdomain.com', isTrusted: true });
|
2023-02-08 20:32:57 +00:00
|
|
|
|
|
|
|
assert.ok(this.errorSpy.notCalled, 'Error handler not triggered while waiting for oidc callback message');
|
|
|
|
assert.strictEqual(this.component.exchangeOIDC.performCount, 0, 'exchangeOIDC method not fired');
|
2022-03-21 21:09:59 +00:00
|
|
|
cancelTimers();
|
2021-11-15 15:48:11 +00:00
|
|
|
});
|
|
|
|
|
2023-02-08 20:32:57 +00:00
|
|
|
test('it should ignore untrusted messages while waiting for oidc callback', async function (assert) {
|
|
|
|
assert.expect(2);
|
2021-11-15 15:48:11 +00:00
|
|
|
this.component.prepareForOIDC.perform(mockWindow.create());
|
|
|
|
this.component.window.trigger('message', { origin: 'http://localhost:4200', isTrusted: false });
|
2023-02-08 20:32:57 +00:00
|
|
|
assert.ok(this.errorSpy.notCalled, 'Error handler not triggered while waiting for oidc callback message');
|
|
|
|
assert.strictEqual(this.component.exchangeOIDC.performCount, 0, 'exchangeOIDC method not fired');
|
2022-03-21 21:09:59 +00:00
|
|
|
cancelTimers();
|
2021-11-15 15:48:11 +00:00
|
|
|
});
|
2023-02-08 20:32:57 +00:00
|
|
|
|
2021-11-15 15:48:11 +00:00
|
|
|
// test case for https://github.com/hashicorp/vault/issues/12436
|
2021-12-17 03:44:29 +00:00
|
|
|
test('it should ignore messages sent from outside the app while waiting for oidc callback', async function (assert) {
|
2021-11-15 15:48:11 +00:00
|
|
|
assert.expect(2);
|
|
|
|
this.component.prepareForOIDC.perform(mockWindow.create());
|
|
|
|
const message = {
|
|
|
|
origin: 'http://localhost:4200',
|
|
|
|
isTrusted: true,
|
|
|
|
data: {
|
|
|
|
namespace: 'foobar',
|
|
|
|
path: '/foo/bar',
|
|
|
|
state: 'authorized',
|
|
|
|
code: 204,
|
|
|
|
},
|
|
|
|
};
|
|
|
|
|
|
|
|
this.component.window.trigger('message', message);
|
|
|
|
message.data.source = 'foo-bar';
|
|
|
|
this.component.window.trigger('message', message);
|
|
|
|
message.data.source = 'oidc-callback';
|
|
|
|
this.component.window.trigger('message', message);
|
|
|
|
|
|
|
|
assert.ok(this.errorSpy.notCalled, 'Error handler not triggered while waiting for oidc callback message');
|
2022-10-18 15:46:02 +00:00
|
|
|
assert.strictEqual(
|
2021-11-15 15:48:11 +00:00
|
|
|
this.component.exchangeOIDC.performCount,
|
|
|
|
1,
|
|
|
|
'exchangeOIDC method fires when oidc callback message is received'
|
|
|
|
);
|
2022-03-21 21:09:59 +00:00
|
|
|
cancelTimers();
|
2021-11-15 15:48:11 +00:00
|
|
|
});
|
|
|
|
});
|