adminbasetests.js revision 198a26b947e9f9c6a7cd6c8a9528f9a74d43bf3a
/**
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER.
*
* Copyright (c) 2014 ForgeRock AS. All Rights Reserved
*
* The contents of this file are subject to the terms
* of the Common Development and Distribution License
* (the License). You may not use this file except in
* compliance with the License.
*
* You can obtain a copy of the License at
* http://forgerock.org/license/CDDLv1.0.html
* See the License for the specific language governing
* permission and limitations under the License.
*
* When distributing Covered Code, include this CDDL
* Header Notice in each file and include the License file
* at http://forgerock.org/license/CDDLv1.0.html
* If applicable, add the following below the CDDL Header,
* with the fields enclosed by brackets [] replaced by
* your own identifying information:
* "Portions Copyrighted [year] [name of copyright owner]"
*/
/*global require, define, QUnit, $ */
define([
"sinon",
"org/forgerock/commons/ui/common/util/Constants",
"org/forgerock/commons/ui/common/main/Router",
"org/forgerock/commons/ui/common/main/EventManager",
"org/forgerock/openidm/ui/common/MandatoryPasswordChangeDialog",
"org/forgerock/openidm/ui/admin/ResourcesView",
"./mocks/adminInit",
"./mocks/encryptedPW",
"./mocks/cleartextPW"
], function (sinon, constants, router, eventManager, mandatoryPasswordChangeDialog, resourcesView, adminInit, encryptedPW, cleartextPW) {
return {
executeAll: function (server) {
adminInit(server);
module('Admin UI Login Functions');
QUnit.asyncTest("Initial Login Process", function () {
var dialogRenderStub = sinon.stub(mandatoryPasswordChangeDialog, "render", function (args, callback) {
mandatoryPasswordChangeDialog.render.restore();
mandatoryPasswordChangeDialog.render(args, function () {
QUnit.ok(true, "Mandatory password change dialog displayed when cleartext password used");
QUnit.equal(mandatoryPasswordChangeDialog.$el.find(".validationRules.group-field-errors>.field-rule").length, 5, "Five validation rules for password displayed");
if (callback) {
callback();
}
QUnit.start();
});
});
cleartextPW(server);
eventManager.sendEvent(constants.EVENT_LOGIN_REQUEST, { userName: "openidm-admin", password: "openidm-admin" });
});
QUnit.asyncTest("Subsequent Login Process", function () {
var resourceRenderStub = sinon.stub(resourcesView, "render", function (args, callback) {
resourcesView.render.restore();
resourcesView.render(args, function () {
var viewManager = require("org/forgerock/commons/ui/common/main/ViewManager");
QUnit.ok(viewManager.currentView === "org/forgerock/openidm/ui/admin/ResourcesView" && viewManager.currentDialog === "null", "Resource page shown after successful login with encrypted password");
if (callback) {
callback();
}
QUnit.start();
});
});
encryptedPW(server);
eventManager.sendEvent(constants.EVENT_LOGIN_REQUEST, { userName: "openidm-admin", password: "Passw0rd" });
});
}
};
});