unleash-server
Version:
Unleash is an enterprise ready feature toggles service. It provides different strategies for handling feature toggles.
83 lines • 3.29 kB
JavaScript
"use strict";
var __importDefault = (this && this.__importDefault) || function (mod) {
return (mod && mod.__esModule) ? mod : { "default": mod };
};
Object.defineProperty(exports, "__esModule", { value: true });
const test_config_1 = require("../../../config/test-config");
const user_service_1 = __importDefault(require("../../../../lib/services/user-service"));
const access_service_1 = require("../../../../lib/services/access-service");
const test_helper_1 = require("../../helpers/test-helper");
const database_init_1 = __importDefault(require("../../helpers/database-init"));
const no_logger_1 = __importDefault(require("../../../fixtures/no-logger"));
const email_service_1 = require("../../../../lib/services/email-service");
const session_service_1 = __importDefault(require("../../../../lib/services/session-service"));
const model_1 = require("../../../../lib/types/model");
const setting_service_1 = __importDefault(require("../../../../lib/services/setting-service"));
const group_service_1 = require("../../../../lib/services/group-service");
const reset_token_service_1 = __importDefault(require("../../../../lib/services/reset-token-service"));
let app;
let stores;
let db;
const config = (0, test_config_1.createTestConfig)({
getLogger: no_logger_1.default,
server: {
unleashUrl: 'http://localhost:3000',
baseUriPath: '',
},
email: {
host: 'test',
},
});
const password = 'DtUYwi&l5I1KX4@Le';
let userService;
let adminUser;
beforeAll(async () => {
db = await (0, database_init_1.default)('simple_password_provider_api_serial', no_logger_1.default);
stores = db.stores;
app = await (0, test_helper_1.setupApp)(stores);
const groupService = new group_service_1.GroupService(stores, config);
const accessService = new access_service_1.AccessService(stores, config, groupService);
const resetTokenService = new reset_token_service_1.default(stores, config);
const emailService = new email_service_1.EmailService(undefined, config.getLogger);
const sessionService = new session_service_1.default(stores, config);
const settingService = new setting_service_1.default(stores, config);
userService = new user_service_1.default(stores, config, {
accessService,
resetTokenService,
emailService,
sessionService,
settingService,
});
const adminRole = await accessService.getRootRole(model_1.RoleName.ADMIN);
adminUser = await userService.createUser({
username: 'admin@test.com',
email: 'admin@test.com',
rootRole: adminRole.id,
password: password,
});
});
afterAll(async () => {
await app.destroy();
await db.destroy();
});
test('Can log in', async () => {
await app.request
.post('/auth/simple/login')
.send({
username: adminUser.username,
password,
})
.expect(200);
});
test('Gets rate limited after 5 tries', async () => {
for (let statusCode of [200, 200, 200, 200, 429]) {
await app.request
.post('/auth/simple/login')
.send({
username: adminUser.username,
password,
})
.expect(statusCode);
}
});
//# sourceMappingURL=simple-password-provider.e2e.test.js.map