1
0
mirror of https://github.com/0rangebananaspy/authelia.git synced 2024-09-14 22:47:21 +07:00
authelia/test/unit/server/ServerConfiguration.test.ts

89 lines
2.2 KiB
TypeScript
Raw Normal View History

2017-05-17 04:17:46 +07:00
import assert = require("assert");
import Sinon = require("sinon");
2017-05-17 04:17:46 +07:00
import nedb = require("nedb");
import express = require("express");
import winston = require("winston");
import speakeasy = require("speakeasy");
import u2f = require("u2f");
import nodemailer = require("nodemailer");
import session = require("express-session");
2017-05-17 04:17:46 +07:00
import { AppConfiguration, UserConfiguration } from "../../../src/server/lib/configuration/Configuration";
import { GlobalDependencies, Nodemailer } from "../../../src/types/Dependencies";
import Server from "../../../src/server/lib/Server";
2017-05-17 04:17:46 +07:00
describe("test server configuration", function () {
let deps: GlobalDependencies;
let sessionMock: Sinon.SinonSpy;
2017-05-17 04:17:46 +07:00
before(function () {
const transporter = {
sendMail: Sinon.stub().yields()
2017-05-17 04:17:46 +07:00
};
const createTransport = Sinon.stub(nodemailer, "createTransport");
createTransport.returns(transporter);
sessionMock = Sinon.spy(session);
2017-05-17 04:17:46 +07:00
deps = {
2017-05-20 14:49:05 +07:00
nodemailer: nodemailer,
2017-05-17 04:17:46 +07:00
speakeasy: speakeasy,
u2f: u2f,
nedb: nedb,
winston: winston,
ldapjs: {
createClient: Sinon.spy(function () {
return {
on: Sinon.spy(),
bind: Sinon.spy(),
};
2017-05-17 04:17:46 +07:00
})
},
session: sessionMock as any,
ConnectRedis: Sinon.spy(),
dovehash: Sinon.spy() as any
2017-05-17 04:17:46 +07:00
};
});
it("should set cookie scope to domain set in the config", function () {
const config: UserConfiguration = {
2017-05-17 04:17:46 +07:00
session: {
domain: "example.com",
secret: "secret"
},
ldap: {
url: "http://ldap",
user: "user",
password: "password",
base_dn: "dc=example,dc=com"
2017-05-17 04:17:46 +07:00
},
notifier: {
gmail: {
2017-05-20 14:49:05 +07:00
username: "user@example.com",
password: "password"
2017-05-17 04:17:46 +07:00
}
},
regulation: {
max_retries: 3,
ban_time: 5 * 60,
find_time: 5 * 60
},
storage: {
local: {
in_memory: true
}
2017-05-17 04:17:46 +07:00
}
};
2017-05-17 04:17:46 +07:00
const server = new Server();
server.start(config, deps);
assert(sessionMock.calledOnce);
assert.equal(sessionMock.getCall(0).args[0].cookie.domain, "example.com");
2017-05-17 04:17:46 +07:00
});
});