UI Automation Hybrid Framework with Selenium WebDriver and TestNG integration, Extent Reports, Faker Library, Docker Setup for Selenium Grid, Elasticsearch & Kibana for Live Tests Reports, Azure Devops CI/CD Pipeline and relevant dependencies.
- Java
- Selenium WebDriver
- TestNG
- Selenium Grid
- Rest Assured
- Elastisearch and Kibana
- Docker Containerization
- Azure Devops
- Selenium WebDriver with TestNG Framework to test and validate Web Application
- Extent Report 5.x for generating Reports and Logging for TestNG Test Run
- Thread safety for WebDriver and Extent Reports
- Implementation classes to take Screenshot, read from properties/json, rest-assured methods, string encoding-decoding
- Helper classes to create wrappers around diff WebElement methods, Wait, Dropdown etc.
- TestNG Custom Annotations and RetryAnalyzer listeners
- TestNG XML -> Sample XMLs for to run Tests based on Groups/Parallel
- Selenium Grid with chrome and firefox nodes to run the tests in server via docker setup
- Elastisearch and Kibana to check live tests outcome in server via docker setup
- Dockerfile -> to create the Image of the project, copying relevant JARs and Files and Entrypoint to specify Test Execution
- docker-compose files -> to create Selenium Grid setup and Elastisearch and Kibana setup
- azure-pipelines.yml -> to build the Maven project, create and push the Docker image to repository
- pom.xml -> maven pom.xml specifying all the dependencies and plugins for goals, reports and running the specified testNG xml using surefire plugin
- Monte Screen Recording APIs -> to capture video recording for the Test Run
- Log4j2 -> Logging for Tests executions
- Excel Read/Write
- Email APIs to send Reports
- Data Parameterization examples/Parametrized Tests run using Excel
- Jenkinsfile -> for creating and pushing Image to Docker repository
- mvn test command won't work due to surefire plugin which requires testNG xml suite to be selected, will throw this error Execution default-test of goal org.apache.maven.plugins:maven-surefire-plugin:2.22.2:test failed: testSuiteXmlFiles0 has null value
- Screen recording using Monte library won't work in parallel run
- Maven Command to Prepare Jars before running Dockerfile -> mvn clean package -DskipTests
- To Build Docker Image, run command: "docker build -t preferredImageName:latest ." example: docker build -t selenium_uiautomation:latest .
- Run docker-compose -f docker-compose-localgrid.yaml to start the Selenium Grid Hub with Chrome and Firefox
- The runmode in config.properties/config.json needs to be set as "remote"
- The TestNG XML suites and Tests can be run from the IDE as it is(right click and Run)
- The Tests can be run from Maven command line by specifying the XML suite and Browser(if Browser is not provided default Chrome is selected) - mvn clean package test -DsuiteXmlFile=${path/testNG XML name} -DBROWSER=${Browser}
- To bring down the Docker Setup docker-compose -f docker-compose-localgrid.yaml down
- Updating Grid and Node images to latest "docker pull image:tagName", example : docker pull selenium/node-firefox:latest
- Scaling up Nodes for parallel execution, docker-compose -f docker-compose-localgrid.yaml up --scale chrome=3
- Run docker-compose -f docker-compose-eklsetup.yaml to start the ElastiSearch and Kibana Setup
- The writetoekl in config.properties/config.json needs to be set as "yes"
- Once the docker setup runs, it requires approx 5 mins before the Kibana setup is ready, the Tests should be run post Kibana webapp is ready, the app can be accessed at "http://localhost:5601/" (the port is defined in docker-compose file)
- The dashboard needs to be configured, to view the different statistics
- Create Sample Collection and Document using POSTMAN app/Curl commands, in Postman do a POST request for "http://localhost:9200/regression/_doc" with JSON body having keys "testname" and "status" with dummy values( reference can be checked in EKLImpl.java class)
- Go to Management > Stack Management
- Go to Kibana > Data Views > Create Data View for regression collection
- Go to Analytics > Dashboard > Create Dashboard for the above created Data View
- To bring down the Docker Setup docker-compose -f docker-compose-eklsetup.yaml down
Sample EKS Dashboard
- Set the screenrecording value to yes in properties file to record the video for tests(method added only for failed Tests)
- Set the log4jloggingrequired value to yes in properties file to write logs to file(per Test one respective file) and to display in the console
Please check the config.properties file under test/resources for further info on various keys set in the framework
- mvn test - will throw error since the surefire plugin in POM expect TestNG XML file to be specified
- The Docker default Port Mapping is set to 4444,if localHost has already Application mapped with 4444 port; this needs to be changed in Docker compose and the same needs to be updated in Huburl in config.properties/config.json
- Check changes to Selenium Grid image from GitHub for changes to Env variables and other settings
- The webapp is not loading -> It takes almost 5 mins for the Kibana app to load, check the logs after running docker-compose if elastisearch is exiting at code 137, if Yes the Docker app needs to be updated with more resources from the local system
- The Create Data View is not listing any Collection/Document -> Sample Collection and Document needs to be created using POSTMAN/Curl commands
Special Thanks to Instructors who have done a splendid job on explaining and designing the framework
- TestingMiniBytes
- TestingMiniBytes - YouTube
- And many more sources from which I learnt trouble-shooting points via YouTube, StackOverFlow, Articles, etc