2019-02-12 22:41:19 +00:00
|
|
|
import Logout from "../../../helpers/Logout";
|
|
|
|
import { StartDriver, StopDriver } from "../../../helpers/context/WithDriver";
|
|
|
|
import LoginOneFactor from "../../../helpers/behaviors/LoginOneFactor";
|
|
|
|
import VerifySecretObserved from "../../../helpers/assertions/VerifySecretObserved";
|
|
|
|
import VisitPage from "../../../helpers/VisitPage";
|
|
|
|
import VerifyUrlIs from "../../../helpers/assertions/VerifyUrlIs";
|
|
|
|
import VerifyIsSecondFactorStage from "../../../helpers/assertions/VerifyIsSecondFactorStage";
|
|
|
|
|
2019-02-13 22:04:57 +00:00
|
|
|
/*
|
|
|
|
* Those tests are related to single factor protected resources.
|
|
|
|
*/
|
2019-02-12 22:41:19 +00:00
|
|
|
export default function() {
|
|
|
|
beforeEach(async function() {
|
|
|
|
this.driver = await StartDriver();
|
|
|
|
});
|
|
|
|
|
|
|
|
afterEach(async function() {
|
|
|
|
await Logout(this.driver);
|
|
|
|
await StopDriver(this.driver);
|
|
|
|
});
|
|
|
|
|
|
|
|
it("should redirect user after first stage", async function() {
|
|
|
|
await LoginOneFactor(this.driver, "john", "password", "https://single_factor.example.com:8080/secret.html");
|
|
|
|
await VerifySecretObserved(this.driver);
|
|
|
|
});
|
|
|
|
|
|
|
|
it("should redirect to portal if not enough authorized", async function() {
|
|
|
|
await LoginOneFactor(this.driver, "john", "password", "https://single_factor.example.com:8080/secret.html");
|
|
|
|
await VisitPage(this.driver, "https://admin.example.com:8080/secret.html");
|
|
|
|
|
|
|
|
// the url should be the one from the portal.
|
|
|
|
await VerifyUrlIs(this.driver, "https://login.example.com:8080/?rd=https://admin.example.com:8080/secret.html");
|
|
|
|
|
|
|
|
// And the user should end up on the second factor page.
|
|
|
|
await VerifyIsSecondFactorStage(this.driver);
|
2019-02-12 22:57:09 +00:00
|
|
|
});
|
2019-02-12 22:41:19 +00:00
|
|
|
}
|