mirror of
https://github.com/matrix-org/matrix-js-sdk.git
synced 2025-06-01 07:41:44 +03:00
The earlier commit, d3ce0cb82f3ee76a22ed8b80db18f679c01f8525, has most of the juicy details on this. In addition to d3ce's changes, we also: * Use `TestClient` in many integration tests due to subtle behaviour changes in imports when switching to ES6. Namely the behaviour where setting the request function is less reliable in the way we did it, but `TestClient` is very reliable. * We now use the Olm loader more often to avoid having to maintain so much duplicate code. This makes the imports slightly easier to read.
149 lines
4.7 KiB
JavaScript
149 lines
4.7 KiB
JavaScript
/*
|
|
Copyright 2016 OpenMarket Ltd
|
|
Copyright 2019 The Matrix.org Foundation C.I.C.
|
|
|
|
Licensed under the Apache License, Version 2.0 (the "License");
|
|
you may not use this file except in compliance with the License.
|
|
You may obtain a copy of the License at
|
|
|
|
http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
Unless required by applicable law or agreed to in writing, software
|
|
distributed under the License is distributed on an "AS IS" BASIS,
|
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
See the License for the specific language governing permissions and
|
|
limitations under the License.
|
|
*/
|
|
"use strict";
|
|
|
|
import 'source-map-support/register';
|
|
import {logger} from "../../src/logger";
|
|
import {InteractiveAuth} from "../../src/interactive-auth";
|
|
import {MatrixError} from "../../src/http-api";
|
|
|
|
// Trivial client object to test interactive auth
|
|
// (we do not need TestClient here)
|
|
class FakeClient {
|
|
generateClientSecret() {
|
|
return "testcl1Ent5EcreT";
|
|
}
|
|
}
|
|
|
|
describe("InteractiveAuth", function() {
|
|
it("should start an auth stage and complete it", function() {
|
|
const doRequest = jest.fn();
|
|
const stateUpdated = jest.fn();
|
|
|
|
const ia = new InteractiveAuth({
|
|
matrixClient: new FakeClient(),
|
|
doRequest: doRequest,
|
|
stateUpdated: stateUpdated,
|
|
authData: {
|
|
session: "sessionId",
|
|
flows: [
|
|
{ stages: ["logintype"] },
|
|
],
|
|
params: {
|
|
"logintype": { param: "aa" },
|
|
},
|
|
},
|
|
});
|
|
|
|
expect(ia.getSessionId()).toEqual("sessionId");
|
|
expect(ia.getStageParams("logintype")).toEqual({
|
|
param: "aa",
|
|
});
|
|
|
|
// first we expect a call here
|
|
stateUpdated.mockImplementation(function(stage) {
|
|
logger.log('aaaa');
|
|
expect(stage).toEqual("logintype");
|
|
ia.submitAuthDict({
|
|
type: "logintype",
|
|
foo: "bar",
|
|
});
|
|
});
|
|
|
|
// .. which should trigger a call here
|
|
const requestRes = {"a": "b"};
|
|
doRequest.mockImplementation(function(authData) {
|
|
logger.log('cccc');
|
|
expect(authData).toEqual({
|
|
session: "sessionId",
|
|
type: "logintype",
|
|
foo: "bar",
|
|
});
|
|
return Promise.resolve(requestRes);
|
|
});
|
|
|
|
return ia.attemptAuth().then(function(res) {
|
|
expect(res).toBe(requestRes);
|
|
expect(doRequest).toBeCalledTimes(1);
|
|
expect(stateUpdated).toBeCalledTimes(1);
|
|
});
|
|
});
|
|
|
|
it("should make a request if no authdata is provided", function() {
|
|
const doRequest = jest.fn();
|
|
const stateUpdated = jest.fn();
|
|
|
|
const ia = new InteractiveAuth({
|
|
matrixClient: new FakeClient(),
|
|
stateUpdated: stateUpdated,
|
|
doRequest: doRequest,
|
|
});
|
|
|
|
expect(ia.getSessionId()).toBe(undefined);
|
|
expect(ia.getStageParams("logintype")).toBe(undefined);
|
|
|
|
// first we expect a call to doRequest
|
|
doRequest.mockImplementation(function(authData) {
|
|
logger.log("request1", authData);
|
|
expect(authData).toEqual({});
|
|
const err = new MatrixError({
|
|
session: "sessionId",
|
|
flows: [
|
|
{ stages: ["logintype"] },
|
|
],
|
|
params: {
|
|
"logintype": { param: "aa" },
|
|
},
|
|
});
|
|
err.httpStatus = 401;
|
|
throw err;
|
|
});
|
|
|
|
// .. which should be followed by a call to stateUpdated
|
|
const requestRes = {"a": "b"};
|
|
stateUpdated.mockImplementation(function(stage) {
|
|
expect(stage).toEqual("logintype");
|
|
expect(ia.getSessionId()).toEqual("sessionId");
|
|
expect(ia.getStageParams("logintype")).toEqual({
|
|
param: "aa",
|
|
});
|
|
|
|
// submitAuthDict should trigger another call to doRequest
|
|
doRequest.mockImplementation(function(authData) {
|
|
logger.log("request2", authData);
|
|
expect(authData).toEqual({
|
|
session: "sessionId",
|
|
type: "logintype",
|
|
foo: "bar",
|
|
});
|
|
return Promise.resolve(requestRes);
|
|
});
|
|
|
|
ia.submitAuthDict({
|
|
type: "logintype",
|
|
foo: "bar",
|
|
});
|
|
});
|
|
|
|
return ia.attemptAuth().then(function(res) {
|
|
expect(res).toBe(requestRes);
|
|
expect(doRequest).toBeCalledTimes(2);
|
|
expect(stateUpdated).toBeCalledTimes(1);
|
|
});
|
|
});
|
|
});
|