rabbitmq-server/selenium/test/oauth/with-idp-initiated/landing.js

45 lines
1.4 KiB
JavaScript

const { By, Key, until, Builder } = require('selenium-webdriver')
require('chromedriver')
const assert = require('assert')
const { buildDriver, goToHome, captureScreensFor, teardown } = require('../../utils')
const FakePortalPage = require('../../pageobjects/FakePortalPage')
const SSOHomePage = require('../../pageobjects/SSOHomePage')
describe('A user which accesses any protected URL without a session', function () {
let homePage
let fakePortal
let captureScreen
before(async function () {
driver = buildDriver()
await goToHome(driver)
homePage = new SSOHomePage(driver)
fakePortal = new FakePortalPage(driver)
captureScreen = captureScreensFor(driver, __filename)
})
it('should be presented with a login button to log in', async function () {
await homePage.isLoaded()
const value = await homePage.getLoginButton()
assert.equal(value, 'Click here to log in')
})
it('should not have a warning message', async function () {
await homePage.isLoaded()
const visible = await homePage.isWarningVisible()
assert.ok(!visible)
})
it('login button should redirect to the configured oauth_provider_url', async function () {
await homePage.clickToLogin()
await captureScreen.shot('fakeportal')
await fakePortal.isLoaded()
})
after(async function () {
await teardown(driver, this, captureScreen)
})
})