11 changed files with 342 additions and 191 deletions
@ -1,61 +0,0 @@ |
|||||||
/* |
|
||||||
* Copyright 2002-2011 the original author or authors. |
|
||||||
* |
|
||||||
* Licensed under the Apache License, Version 2.0 (the "License"); |
|
||||||
* you may not use this file except in compliance with the License. |
|
||||||
* You may obtain a copy of the License at |
|
||||||
* |
|
||||||
* http://www.apache.org/licenses/LICENSE-2.0 |
|
||||||
* |
|
||||||
* Unless required by applicable law or agreed to in writing, software |
|
||||||
* distributed under the License is distributed on an "AS IS" BASIS, |
|
||||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
|
||||||
* See the License for the specific language governing permissions and |
|
||||||
* limitations under the License. |
|
||||||
*/ |
|
||||||
package org.springframework.security.samples |
|
||||||
|
|
||||||
import geb.spock.* |
|
||||||
import spock.lang.Shared |
|
||||||
import spock.lang.Stepwise |
|
||||||
import org.springframework.security.samples.pages.* |
|
||||||
|
|
||||||
/** |
|
||||||
* Tests the CAS sample application using service tickets. |
|
||||||
* |
|
||||||
* @author Rob Winch |
|
||||||
*/ |
|
||||||
@Stepwise |
|
||||||
class JaasXmlTests extends GebReportingSpec { |
|
||||||
def 'access home page with unauthenticated works'() { |
|
||||||
when: 'Unauthenticated user accesses the Home Page' |
|
||||||
to HomePage |
|
||||||
then: 'The home page is displayed' |
|
||||||
at HomePage |
|
||||||
} |
|
||||||
|
|
||||||
def 'access secure page with unauthenticated requires login'() { |
|
||||||
when: 'Unauthenticated user accesses the Secure Page' |
|
||||||
securePage LoginPage |
|
||||||
then: 'The login page is displayed' |
|
||||||
at LoginPage |
|
||||||
} |
|
||||||
|
|
||||||
def 'authenticated user is sent to original page'() { |
|
||||||
when: 'user authenticates' |
|
||||||
login() |
|
||||||
then: 'The secure page is displayed' |
|
||||||
at SecurePage |
|
||||||
} |
|
||||||
|
|
||||||
def 'authenticated user logs out'() { |
|
||||||
when: 'user logs out' |
|
||||||
logout() |
|
||||||
then: 'the default logout success page is displayed' |
|
||||||
at LogoutPage |
|
||||||
when: 'Unauthenticated user accesses the Secure Page' |
|
||||||
via SecurePage |
|
||||||
then: 'The login page is displayed' |
|
||||||
at LoginPage |
|
||||||
} |
|
||||||
} |
|
||||||
@ -1,31 +0,0 @@ |
|||||||
/* |
|
||||||
* Copyright 2002-2011 the original author or authors. |
|
||||||
* |
|
||||||
* Licensed under the Apache License, Version 2.0 (the "License"); |
|
||||||
* you may not use this file except in compliance with the License. |
|
||||||
* You may obtain a copy of the License at |
|
||||||
* |
|
||||||
* http://www.apache.org/licenses/LICENSE-2.0 |
|
||||||
* |
|
||||||
* Unless required by applicable law or agreed to in writing, software |
|
||||||
* distributed under the License is distributed on an "AS IS" BASIS, |
|
||||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
|
||||||
* See the License for the specific language governing permissions and |
|
||||||
* limitations under the License. |
|
||||||
*/ |
|
||||||
package org.springframework.security.samples.pages; |
|
||||||
|
|
||||||
import geb.* |
|
||||||
|
|
||||||
/** |
|
||||||
* The home page |
|
||||||
* |
|
||||||
* @author Rob Winch |
|
||||||
*/ |
|
||||||
class HomePage extends Page { |
|
||||||
static url = '' |
|
||||||
static at = { assert driver.title == 'Home Page'; true} |
|
||||||
static content = { |
|
||||||
securePage(to: [SecurePage,LoginPage]) { $('a').click() } |
|
||||||
} |
|
||||||
} |
|
||||||
@ -1,37 +0,0 @@ |
|||||||
/* |
|
||||||
* Copyright 2002-2011 the original author or authors. |
|
||||||
* |
|
||||||
* Licensed under the Apache License, Version 2.0 (the "License"); |
|
||||||
* you may not use this file except in compliance with the License. |
|
||||||
* You may obtain a copy of the License at |
|
||||||
* |
|
||||||
* http://www.apache.org/licenses/LICENSE-2.0 |
|
||||||
* |
|
||||||
* Unless required by applicable law or agreed to in writing, software |
|
||||||
* distributed under the License is distributed on an "AS IS" BASIS, |
|
||||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
|
||||||
* See the License for the specific language governing permissions and |
|
||||||
* limitations under the License. |
|
||||||
*/ |
|
||||||
package org.springframework.security.samples.pages; |
|
||||||
|
|
||||||
import geb.* |
|
||||||
|
|
||||||
/** |
|
||||||
* The login page. |
|
||||||
* |
|
||||||
* @author Rob Winch |
|
||||||
*/ |
|
||||||
class LoginPage extends Page { |
|
||||||
static url = 'login' |
|
||||||
static at = { assert driver.title == 'Login Page'; true} |
|
||||||
static content = { |
|
||||||
login(required:false) { user='user', password='user' -> |
|
||||||
loginForm.username = user |
|
||||||
loginForm.password = password |
|
||||||
submit.click() |
|
||||||
} |
|
||||||
loginForm { $('form') } |
|
||||||
submit { $('input', type: 'submit') } |
|
||||||
} |
|
||||||
} |
|
||||||
@ -1,28 +0,0 @@ |
|||||||
/* |
|
||||||
* Copyright 2002-2011 the original author or authors. |
|
||||||
* |
|
||||||
* Licensed under the Apache License, Version 2.0 (the "License"); |
|
||||||
* you may not use this file except in compliance with the License. |
|
||||||
* You may obtain a copy of the License at |
|
||||||
* |
|
||||||
* http://www.apache.org/licenses/LICENSE-2.0 |
|
||||||
* |
|
||||||
* Unless required by applicable law or agreed to in writing, software |
|
||||||
* distributed under the License is distributed on an "AS IS" BASIS, |
|
||||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
|
||||||
* See the License for the specific language governing permissions and |
|
||||||
* limitations under the License. |
|
||||||
*/ |
|
||||||
package org.springframework.security.samples.pages |
|
||||||
|
|
||||||
import geb.Page |
|
||||||
|
|
||||||
/** |
|
||||||
* The login page. |
|
||||||
* |
|
||||||
* @author Rob Winch |
|
||||||
*/ |
|
||||||
class LogoutPage extends LoginPage { |
|
||||||
static url = 'login' |
|
||||||
static at = { assert driver.title == 'Login Page' && $('p').text() == 'You have been logged out'; true} |
|
||||||
} |
|
||||||
@ -1,32 +0,0 @@ |
|||||||
/* |
|
||||||
* Copyright 2002-2011 the original author or authors. |
|
||||||
* |
|
||||||
* Licensed under the Apache License, Version 2.0 (the "License"); |
|
||||||
* you may not use this file except in compliance with the License. |
|
||||||
* You may obtain a copy of the License at |
|
||||||
* |
|
||||||
* http://www.apache.org/licenses/LICENSE-2.0 |
|
||||||
* |
|
||||||
* Unless required by applicable law or agreed to in writing, software |
|
||||||
* distributed under the License is distributed on an "AS IS" BASIS, |
|
||||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
|
||||||
* See the License for the specific language governing permissions and |
|
||||||
* limitations under the License. |
|
||||||
*/ |
|
||||||
package org.springframework.security.samples.pages |
|
||||||
|
|
||||||
import geb.Page |
|
||||||
|
|
||||||
/** |
|
||||||
* The home page |
|
||||||
* |
|
||||||
* @author Rob Winch |
|
||||||
*/ |
|
||||||
class SecurePage extends Page { |
|
||||||
static url = 'secure/' |
|
||||||
static at = { assert driver.title == 'Security Debug Information'; true} |
|
||||||
static content = { |
|
||||||
message { $('p').text() } |
|
||||||
logout { $('input', type: 'submit').click() } |
|
||||||
} |
|
||||||
} |
|
||||||
@ -0,0 +1,83 @@ |
|||||||
|
/* |
||||||
|
* Copyright 2002-2018 the original author or authors. |
||||||
|
* |
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License"); |
||||||
|
* you may not use this file except in compliance with the License. |
||||||
|
* You may obtain a copy of the License at |
||||||
|
* |
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
* |
||||||
|
* Unless required by applicable law or agreed to in writing, software |
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS, |
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
||||||
|
* See the License for the specific language governing permissions and |
||||||
|
* limitations under the License. |
||||||
|
*/ |
||||||
|
package org.springframework.security.samples; |
||||||
|
|
||||||
|
import org.junit.After; |
||||||
|
import org.junit.Before; |
||||||
|
import org.junit.Test; |
||||||
|
import org.openqa.selenium.WebDriver; |
||||||
|
import org.openqa.selenium.htmlunit.HtmlUnitDriver; |
||||||
|
import org.springframework.security.samples.pages.HomePage; |
||||||
|
import org.springframework.security.samples.pages.LoginPage; |
||||||
|
import org.springframework.security.samples.pages.LogoutPage; |
||||||
|
import org.springframework.security.samples.pages.SecurePage; |
||||||
|
|
||||||
|
/** |
||||||
|
* @author Michael Simons |
||||||
|
*/ |
||||||
|
public class JaasXmlTests { |
||||||
|
private WebDriver driver; |
||||||
|
|
||||||
|
private int port; |
||||||
|
|
||||||
|
@Before |
||||||
|
public void setup() { |
||||||
|
this.port = Integer.parseInt(System.getProperty("app.httpPort")); |
||||||
|
this.driver = new HtmlUnitDriver(); |
||||||
|
} |
||||||
|
|
||||||
|
@After |
||||||
|
public void tearDown() { |
||||||
|
this.driver.quit(); |
||||||
|
} |
||||||
|
|
||||||
|
@Test |
||||||
|
public void accessHomePageWithUnauthenticatedWorks() { |
||||||
|
final HomePage homePage = HomePage.to(this.driver, this.port); |
||||||
|
homePage.assertAt(); |
||||||
|
} |
||||||
|
|
||||||
|
@Test |
||||||
|
public void accessSecurePageWithUnauthenticatedRequiresLogin() { |
||||||
|
final LoginPage loginPage = SecurePage.to(this.driver, this.port); |
||||||
|
loginPage.assertAt(); |
||||||
|
} |
||||||
|
|
||||||
|
@Test |
||||||
|
public void authenticatedUserIsSentToOriginalPage() { |
||||||
|
final SecurePage securePage = SecurePage.to(this.driver, this.port) |
||||||
|
.loginForm() |
||||||
|
.username("user") |
||||||
|
.password("user") |
||||||
|
.submit(); |
||||||
|
securePage |
||||||
|
.assertAt(); |
||||||
|
} |
||||||
|
|
||||||
|
@Test |
||||||
|
public void authenticatedUserLogsOut() { |
||||||
|
final LogoutPage logoutPage = SecurePage.to(this.driver, this.port) |
||||||
|
.loginForm() |
||||||
|
.username("user") |
||||||
|
.password("user") |
||||||
|
.submit() |
||||||
|
.logout(); |
||||||
|
logoutPage.assertAt(); |
||||||
|
|
||||||
|
final LoginPage loginPage = SecurePage.to(this.driver, this.port); |
||||||
|
loginPage.assertAt(); |
||||||
|
} |
||||||
|
} |
||||||
@ -0,0 +1,68 @@ |
|||||||
|
/* |
||||||
|
* Copyright 2002-2018 the original author or authors. |
||||||
|
* |
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License"); |
||||||
|
* you may not use this file except in compliance with the License. |
||||||
|
* You may obtain a copy of the License at |
||||||
|
* |
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
* |
||||||
|
* Unless required by applicable law or agreed to in writing, software |
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS, |
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
||||||
|
* See the License for the specific language governing permissions and |
||||||
|
* limitations under the License. |
||||||
|
*/ |
||||||
|
package org.springframework.security.samples.pages; |
||||||
|
|
||||||
|
import org.openqa.selenium.WebDriver; |
||||||
|
import org.openqa.selenium.WebElement; |
||||||
|
import org.openqa.selenium.support.FindBy; |
||||||
|
import org.openqa.selenium.support.PageFactory; |
||||||
|
|
||||||
|
import static org.assertj.core.api.Assertions.assertThat; |
||||||
|
|
||||||
|
/** |
||||||
|
* The home page. |
||||||
|
* |
||||||
|
* @author Michael Simons |
||||||
|
*/ |
||||||
|
public class HomePage { |
||||||
|
|
||||||
|
public static HomePage to(WebDriver driver, int port) { |
||||||
|
driver.get("http://localhost:" + port +"/"); |
||||||
|
return PageFactory.initElements(driver, HomePage.class); |
||||||
|
} |
||||||
|
|
||||||
|
private final WebDriver webDriver; |
||||||
|
|
||||||
|
@FindBy(css = "p") |
||||||
|
private WebElement message; |
||||||
|
|
||||||
|
@FindBy(css = "input[type=submit]") |
||||||
|
private WebElement logoutButton; |
||||||
|
|
||||||
|
public HomePage(WebDriver webDriver) { |
||||||
|
this.webDriver = webDriver; |
||||||
|
} |
||||||
|
|
||||||
|
public Content assertAt() { |
||||||
|
assertThat(this.webDriver.getTitle()).isEqualTo("Home Page"); |
||||||
|
return PageFactory.initElements(this.webDriver, Content.class); |
||||||
|
} |
||||||
|
|
||||||
|
public LoginPage logout() { |
||||||
|
this.logoutButton.submit(); |
||||||
|
return PageFactory.initElements(this.webDriver, LoginPage.class); |
||||||
|
} |
||||||
|
|
||||||
|
public static class Content { |
||||||
|
@FindBy(css = "p") |
||||||
|
private WebElement message; |
||||||
|
|
||||||
|
public Content andTheUserNameIsDisplayed() { |
||||||
|
assertThat(message.getText()).isEqualTo("Hello user"); |
||||||
|
return this; |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
@ -0,0 +1,76 @@ |
|||||||
|
/* |
||||||
|
* Copyright 2002-2018 the original author or authors. |
||||||
|
* |
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License"); |
||||||
|
* you may not use this file except in compliance with the License. |
||||||
|
* You may obtain a copy of the License at |
||||||
|
* |
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
* |
||||||
|
* Unless required by applicable law or agreed to in writing, software |
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS, |
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
||||||
|
* See the License for the specific language governing permissions and |
||||||
|
* limitations under the License. |
||||||
|
*/ |
||||||
|
package org.springframework.security.samples.pages; |
||||||
|
|
||||||
|
import org.openqa.selenium.WebDriver; |
||||||
|
import org.openqa.selenium.WebElement; |
||||||
|
import org.openqa.selenium.support.FindBy; |
||||||
|
import org.openqa.selenium.support.PageFactory; |
||||||
|
|
||||||
|
import static org.assertj.core.api.Assertions.assertThat; |
||||||
|
|
||||||
|
/** |
||||||
|
* The login page. |
||||||
|
* |
||||||
|
* @author Michael Simons |
||||||
|
*/ |
||||||
|
public class LoginPage { |
||||||
|
|
||||||
|
private final WebDriver webDriver; |
||||||
|
|
||||||
|
private final LoginForm loginForm; |
||||||
|
|
||||||
|
public LoginPage(WebDriver webDriver) { |
||||||
|
this.webDriver = webDriver; |
||||||
|
this.loginForm = PageFactory.initElements(this.webDriver, LoginForm.class); |
||||||
|
} |
||||||
|
|
||||||
|
public LoginPage assertAt() { |
||||||
|
assertThat(this.webDriver.getTitle()).isEqualTo("Login Page"); |
||||||
|
return this; |
||||||
|
} |
||||||
|
|
||||||
|
public LoginForm loginForm() { |
||||||
|
return this.loginForm; |
||||||
|
} |
||||||
|
|
||||||
|
public static class LoginForm { |
||||||
|
private WebDriver webDriver; |
||||||
|
private WebElement username; |
||||||
|
private WebElement password; |
||||||
|
@FindBy(css = "input[type=submit]") |
||||||
|
private WebElement submit; |
||||||
|
|
||||||
|
public LoginForm(WebDriver webDriver) { |
||||||
|
this.webDriver = webDriver; |
||||||
|
} |
||||||
|
|
||||||
|
public LoginForm username(String username) { |
||||||
|
this.username.sendKeys(username); |
||||||
|
return this; |
||||||
|
} |
||||||
|
|
||||||
|
public LoginForm password(String password) { |
||||||
|
this.password.sendKeys(password); |
||||||
|
return this; |
||||||
|
} |
||||||
|
|
||||||
|
public SecurePage submit() { |
||||||
|
this.submit.click(); |
||||||
|
return PageFactory.initElements(this.webDriver, SecurePage.class); |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
@ -0,0 +1,44 @@ |
|||||||
|
/* |
||||||
|
* Copyright 2002-2018 the original author or authors. |
||||||
|
* |
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License"); |
||||||
|
* you may not use this file except in compliance with the License. |
||||||
|
* You may obtain a copy of the License at |
||||||
|
* |
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
* |
||||||
|
* Unless required by applicable law or agreed to in writing, software |
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS, |
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
||||||
|
* See the License for the specific language governing permissions and |
||||||
|
* limitations under the License. |
||||||
|
*/ |
||||||
|
package org.springframework.security.samples.pages; |
||||||
|
|
||||||
|
import org.openqa.selenium.WebDriver; |
||||||
|
import org.openqa.selenium.WebElement; |
||||||
|
import org.openqa.selenium.support.FindBy; |
||||||
|
|
||||||
|
import static org.assertj.core.api.Assertions.assertThat; |
||||||
|
|
||||||
|
/** |
||||||
|
* Logout Page is the same as login page with an additional message. |
||||||
|
* |
||||||
|
* @author Michael Simons |
||||||
|
*/ |
||||||
|
public class LogoutPage extends LoginPage { |
||||||
|
@FindBy(css = "p") |
||||||
|
private WebElement p; |
||||||
|
|
||||||
|
public LogoutPage(WebDriver webDriver) { |
||||||
|
super(webDriver); |
||||||
|
} |
||||||
|
|
||||||
|
@Override |
||||||
|
public LogoutPage assertAt() { |
||||||
|
super.assertAt(); |
||||||
|
|
||||||
|
assertThat(p.getText()).isEqualTo("You have been logged out"); |
||||||
|
return this; |
||||||
|
} |
||||||
|
} |
||||||
@ -0,0 +1,55 @@ |
|||||||
|
/* |
||||||
|
* Copyright 2002-2018 the original author or authors. |
||||||
|
* |
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License"); |
||||||
|
* you may not use this file except in compliance with the License. |
||||||
|
* You may obtain a copy of the License at |
||||||
|
* |
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
* |
||||||
|
* Unless required by applicable law or agreed to in writing, software |
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS, |
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
||||||
|
* See the License for the specific language governing permissions and |
||||||
|
* limitations under the License. |
||||||
|
*/ |
||||||
|
package org.springframework.security.samples.pages; |
||||||
|
|
||||||
|
import org.openqa.selenium.WebDriver; |
||||||
|
import org.openqa.selenium.WebElement; |
||||||
|
import org.openqa.selenium.support.FindBy; |
||||||
|
import org.openqa.selenium.support.PageFactory; |
||||||
|
|
||||||
|
import static org.assertj.core.api.Assertions.assertThat; |
||||||
|
|
||||||
|
/** |
||||||
|
* A secure page. |
||||||
|
* |
||||||
|
* @author Michael Simons |
||||||
|
*/ |
||||||
|
public class SecurePage { |
||||||
|
|
||||||
|
public static LoginPage to(WebDriver driver, int port) { |
||||||
|
driver.get("http://localhost:" + port + "/secure"); |
||||||
|
return PageFactory.initElements(driver, LoginPage.class); |
||||||
|
}; |
||||||
|
|
||||||
|
private final WebDriver webDriver; |
||||||
|
|
||||||
|
@FindBy(css = "input[type=submit]") |
||||||
|
private WebElement submit; |
||||||
|
|
||||||
|
public SecurePage(WebDriver webDriver) { |
||||||
|
this.webDriver = webDriver; |
||||||
|
} |
||||||
|
|
||||||
|
public SecurePage assertAt() { |
||||||
|
assertThat(this.webDriver.getTitle()).isEqualTo("Security Debug Information"); |
||||||
|
return this; |
||||||
|
} |
||||||
|
|
||||||
|
public LogoutPage logout() { |
||||||
|
this.submit.click(); |
||||||
|
return PageFactory.initElements(this.webDriver, LogoutPage.class); |
||||||
|
} |
||||||
|
} |
||||||
Loading…
Reference in new issue