Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/kripaliz/unifiedbdd-automation-framework
Automation framework / solution implemented in Java to support web browser as well as mobile browser / App automation
https://github.com/kripaliz/unifiedbdd-automation-framework
allure-report allure2 appium automated-testing bdd bdd-tests cucumber cucumber-jvm gherkin java pageobjects selenium-webdriver spring-boot spring-boot-starter-test testng webdriver-manager
Last synced: 3 months ago
JSON representation
Automation framework / solution implemented in Java to support web browser as well as mobile browser / App automation
- Host: GitHub
- URL: https://github.com/kripaliz/unifiedbdd-automation-framework
- Owner: kripaliz
- Created: 2018-11-07T10:34:40.000Z (about 6 years ago)
- Default Branch: main
- Last Pushed: 2023-06-14T22:20:12.000Z (over 1 year ago)
- Last Synced: 2024-10-01T15:54:40.357Z (4 months ago)
- Topics: allure-report, allure2, appium, automated-testing, bdd, bdd-tests, cucumber, cucumber-jvm, gherkin, java, pageobjects, selenium-webdriver, spring-boot, spring-boot-starter-test, testng, webdriver-manager
- Language: Java
- Homepage:
- Size: 83 KB
- Stars: 3
- Watchers: 5
- Forks: 2
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
Awesome Lists containing this project
README
# UnifiedBDD Automation Framework
## BDD automation testing made simple
[![Maven Central](https://maven-badges.herokuapp.com/maven-central/com.github.kripaliz/unifiedbdd-automation-framework/badge.svg)](https://maven-badges.herokuapp.com/maven-central/com.github.kripaliz/unifiedbdd-automation-framework)Automation framework / solution implemented in Java to support web browser as well as mobile browser / App automation. This includes
* abstraction for PageObject
* ContextLoader for Spring context initialisation
* Junit5 test runner that kicks off cucumber
* Spring Boot application configuration
* Webdriver properties, test data properties## Built With
* [Cucumber](https://cucumber.io/docs/cucumber/) – BDD tests
* [Allure Reports](https://docs.qameta.io/allure/) - test report
* [Selenium](https://www.seleniumhq.org/) – web automation
* [Appium](http://appium.io/) – mobile automation
* [Page Object Model](https://www.selenium.dev/documentation/test_practices/encouraged/page_object_models/) – design pattern to abstract page behaviour
* [Spring Boot](http://spring.io/projects/spring-boot) – cleaner code
* [Webdriver Manager](https://github.com/bonigarcia/webdrivermanager) – manage webdriver executables automatically## Prerequisites
* [JDK 11](https://openjdk.org/projects/jdk/11)
* [Maven](https://maven.apache.org/download.cgi)## Usage
To use this automation framework in your test suite:
1. Inherit from [unifiedbdd-automation-parent](https://github.com/kripaliz/unifiedbdd-automation-parent)
```xml
4.0.0
com.github.kripaliz
unifiedbdd-automation-parent
0.1.6
com.company.testing
uiautomation-suite
0.0.1-SNAPSHOT
true
com.company.testing.step
json:target/cucumber-reports/result.json,junit:target/cucumber-reports/result.xml
```2. Create an application.yml file for spring boot
```yml
spring.main.sources: com.company.testingspring.profiles.active: chrome
---
spring.config.activate.on-profile: chrome
webdriver:
type: chrome---
spring.config.activate.on-profile: saucelabs
webdriver:
type: remote
url: http://user:[email protected]:80/wd/hub
desiredCapabilities:
browserName: chrome
browserVersion: latest
platformName: macOS 10.13
```3. Create [logback](https://logback.qos.ch/manual/configuration.html) xml
```xml
%d{HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%n
```
4. Create a Test suite class```java
@Suite
@IncludeEngines("cucumber")
@SelectClasspathResource("features")
public class AutomationTests {}
```Reference: https://github.com/cucumber/cucumber-jvm/tree/v7.8.1/cucumber-junit-platform-engine#suites-with-different-configurations
5. Create PageObject classes that extend `com.github.kripaliz.automation.pageobject.AbstractPage` and use the marker interface `com.github.kripaliz.automation.pageobject.PageObject`.
```java
@PageObject
public class AnukoHomePage extends AbstractPage {@FindBy(css = AnukoHomePageConstants.LOGIN_LINK_CSS)
private WebElement loginLink;public void visitUrl() {
webDriver.get("https://timetracker.anuko.com/");
}
}
```
6. Create [StepDef](https://cucumber.io/docs/cucumber/step-definitions/) classes that use spring dependency injection to get pageObjects. (under a package you configured in `cucumber.glue` in pom.xml)```java
public class SignInSteps {@Autowired
private AnukoHomePage anukoHomePage;@Given("^I visit Anuko Home Page$")
public void i_visit_Anuko_Home_Page() throws Exception {
anukoHomePage.visitUrl();
}
}
```
7. Create [gherkin](https://cucumber.io/docs/gherkin/) feature files in src/test/resources/features8. To run the suite
```sh
mvn clean test \
-Dcucumber.execution.parallel.config.fixed.parallelism=10 \
-Dgroups="!wip" \
-Dspring.profiles.active=chrome \
-Dsurefire.rerunFailingTestsCount=0
```options:
- `cucumber.execution.parallel.config.fixed.parallelism`: specify the number of concurrent scenarios to execute
- `groups`: [junit tag expressions](https://github.com/cucumber/cucumber-jvm/tree/main/cucumber-junit-platform-engine#tags) to limit scope of test execution
- `spring.profiles.active`: switch between [spring profiles](https://docs.spring.io/spring-boot/docs/current/reference/html/features.html#features.profiles) created in application.yml
- `surefire.rerunFailingTestsCount`: reruns for any failed tests9. To view the [allure report](https://github.com/allure-framework/allure-maven)
```sh
mvn allure:serve
```10. To re-run failed tests
```sh
mvn test -Dcucumber.options=@target/rerun.txt -Dspring.profiles.active=chrome -DthreadCount=4
```## Configuring the TypeRegistry
Cucumber 3+ provides `TypeRegistryConfigurer` to configure custom parameter types and data table types. The framework already defines one to setup a default DataTable Transformer using Jackson library.
To extend it, please use ServiceLoader mechanism:* Create an implementation of `DataTableTypeProvider` or `ParameterTypeProvider`
* In your test suite, add file(s) with the implementations referenced:
* `META-INF/services/com.github.kripaliz.automation.cucumber.DataTableTypeProvider`
* `META-INF/services/com.github.kripaliz.automation.cucumber.ParameterTypeProvider`Here's some more info on ServiceLoader; https://www.baeldung.com/java-spi
## Setting up eclipse for developing
* Download [eclipse](https://www.eclipse.org/downloads/)
* Follow instructions [here](https://projectlombok.org/setup/eclipse) for lombok setup
* Install eclipse plugins from the [eclipse marketplace](https://marketplace.eclipse.org/content/welcome-eclipse-marketplace) or using their [update site](https://help.eclipse.org/kepler/index.jsp?topic=%2Forg.eclipse.platform.doc.user%2Ftasks%2Ftasks-127.htm) - [YEdit](http://dadacoalition.org/yedit/), [Cucumber](https://cucumber.github.io/cucumber-eclipse-update-site-snapshot)
* Follow instructions in the answer [here](https://stackoverflow.com/questions/1886185/eclipse-and-windows-newlines) to use Unix style line endings for new files