mirror of
https://github.com/0rangebananaspy/authelia.git
synced 2024-09-14 22:47:21 +07:00
123 lines
3.8 KiB
TypeScript
123 lines
3.8 KiB
TypeScript
|
import SessionConfigurationBuilder from "../../src/server/lib/SessionConfigurationBuilder";
|
||
|
import { AppConfiguration } from "../../src/types/Configuration";
|
||
|
import { GlobalDependencies } from "../../src/types/Dependencies";
|
||
|
import ExpressSession = require("express-session");
|
||
|
import ConnectRedis = require("connect-redis");
|
||
|
import sinon = require("sinon");
|
||
|
import Assert = require("assert");
|
||
|
|
||
|
describe.only("test session configuration builder", function () {
|
||
|
it("should return session options without redis options", function () {
|
||
|
const configuration: AppConfiguration = {
|
||
|
access_control: {
|
||
|
default: [],
|
||
|
users: {},
|
||
|
groups: {}
|
||
|
},
|
||
|
ldap: {
|
||
|
url: "ldap://ldap",
|
||
|
base_dn: "dc=example,dc=com",
|
||
|
user: "user",
|
||
|
password: "password"
|
||
|
},
|
||
|
logs_level: "debug",
|
||
|
notifier: {
|
||
|
filesystem: {
|
||
|
filename: "/test"
|
||
|
}
|
||
|
},
|
||
|
port: 8080,
|
||
|
session: {
|
||
|
domain: "example.com",
|
||
|
expiration: 3600,
|
||
|
secret: "secret"
|
||
|
},
|
||
|
store_in_memory: true
|
||
|
};
|
||
|
|
||
|
const deps: GlobalDependencies = {
|
||
|
ConnectRedis: sinon.spy() as any,
|
||
|
ldapjs: sinon.spy() as any,
|
||
|
nedb: sinon.spy() as any,
|
||
|
nodemailer: sinon.spy() as any,
|
||
|
session: sinon.spy() as any,
|
||
|
speakeasy: sinon.spy() as any,
|
||
|
u2f: sinon.spy() as any,
|
||
|
winston: sinon.spy() as any
|
||
|
};
|
||
|
|
||
|
const options = SessionConfigurationBuilder.build(configuration, deps);
|
||
|
|
||
|
const expectedOptions = {
|
||
|
secret: "secret",
|
||
|
resave: false,
|
||
|
saveUninitialized: true,
|
||
|
cookie: {
|
||
|
secure: false,
|
||
|
maxAge: 3600,
|
||
|
domain: "example.com"
|
||
|
}
|
||
|
};
|
||
|
|
||
|
Assert.deepEqual(expectedOptions, options);
|
||
|
});
|
||
|
|
||
|
it("should return session options with redis options", function () {
|
||
|
const configuration: AppConfiguration = {
|
||
|
access_control: {
|
||
|
default: [],
|
||
|
users: {},
|
||
|
groups: {}
|
||
|
},
|
||
|
ldap: {
|
||
|
url: "ldap://ldap",
|
||
|
base_dn: "dc=example,dc=com",
|
||
|
user: "user",
|
||
|
password: "password"
|
||
|
},
|
||
|
logs_level: "debug",
|
||
|
notifier: {
|
||
|
filesystem: {
|
||
|
filename: "/test"
|
||
|
}
|
||
|
},
|
||
|
port: 8080,
|
||
|
session: {
|
||
|
domain: "example.com",
|
||
|
expiration: 3600,
|
||
|
secret: "secret",
|
||
|
redis: {
|
||
|
host: "redis.example.com",
|
||
|
port: 6379
|
||
|
}
|
||
|
},
|
||
|
store_in_memory: true
|
||
|
};
|
||
|
|
||
|
const deps: GlobalDependencies = {
|
||
|
ConnectRedis: sinon.stub().returns({ RedisStore: sinon.spy() }) as any,
|
||
|
ldapjs: sinon.spy() as any,
|
||
|
nedb: sinon.spy() as any,
|
||
|
nodemailer: sinon.spy() as any,
|
||
|
session: sinon.spy() as any,
|
||
|
speakeasy: sinon.spy() as any,
|
||
|
u2f: sinon.spy() as any,
|
||
|
winston: sinon.spy() as any
|
||
|
};
|
||
|
|
||
|
const options = SessionConfigurationBuilder.build(configuration, deps);
|
||
|
|
||
|
const expectedOptions: ExpressSession.SessionOptions = {
|
||
|
secret: "secret",
|
||
|
resave: false,
|
||
|
saveUninitialized: true,
|
||
|
cookie: {
|
||
|
secure: false,
|
||
|
maxAge: 3600,
|
||
|
domain: "example.com"
|
||
|
}
|
||
|
};
|
||
|
|
||
|
Assert(expectedOptions.store != undefined);
|
||
|
});
|
||
|
});
|