What is Addon?
From testproject addon page - an addon is a collection of coded actions you can use within any test. It's all stored in TestProject's collaborative addons library. More details can be found from above link.
Create an addon
Step by step guide to create an addon using Test Project java SDK. What we need:
- IntelliJ IDE (or any other IDE e.g. Eclipse)
- Test Project Java SDK
- manifest.json file
- descriptor.xml file
- Good understanding of Maven
- Good understanding of Selenium automation
- Reference to https://github.com/testproject-io/java-sdk-examples
- DEV_TOKEN
To create Addon, we will follow the samples mentioned in above github url.
Sample Scenario
Think of a scanario, where we have to create an addon to fill the 3 fields: Address, eMail and Phone in https://example.testproject.io/web/.
Create a Test case in TestProject to fill up the Name, Password, Country, Address, eMail and Phone fields. And with the help of addon, we will fill up Address, eMail and Phone fields. Though its not an ideal candidate for addon but this blog is just an example on how to create add on and use it.
Create a Test case in TestProject to fill up the Name, Password, Country, Address, eMail and Phone fields. And with the help of addon, we will fill up Address, eMail and Phone fields. Though its not an ideal candidate for addon but this blog is just an example on how to create add on and use it.
Create Project in IntelliJ
Create a maven project and make sure the structure is similar to the screenshot attached.
We should have Addon folder (any class within this with @Action annotation will go to TestProject as Action), resources and Runners (to test addon locally) folders
We should have Addon folder (any class within this with @Action annotation will go to TestProject as Action), resources and Runners (to test addon locally) folders
Download Manifest.json file
- Create an AddOn in TestProject, provide a name and select File System and Environment and click on Generate & Download manifest button to download the manifest.json file.
- Copy the manifest.json file and copy to resources folder
The manifest.json file content may look different in your case. version no might be 0.1. For me its 0.4 as I have updated the addon actions multiple times. And also we have to focus on guid, which will be discussed later in the blog.
And store the DEV Token somewhere safe :)
Download the testproject sdk and get the DEV KEY
Go to Integration Menu in the testproject and download the SDK and store it in a folder of your choice.
Update the pom.xml
Navigate to https://github.com/testproject-io/java-sdk-examples/tree/master/Web/Addon and copy the content of pom.xml file and update in the project.
Notice the line no 46 in the pom.xml file. Make sure systempath is updated with the path where the testproject sdk is stored in your local machine.4.0.0 io.testproject TestProjectAddon 1.1 ${project.basedir}/../../io.testproject.sdk.java.jar UTF-8 org.junit.jupiter junit-jupiter-api 5.3.1 org.junit.platform junit-platform-runner 1.3.1 org.junit.jupiter junit-jupiter-engine 5.3.1 test org.junit.vintage junit-vintage-engine 5.3.1 test io.testproject java-sdk 1.0 C:/testproject/TestProject_SDK_0.61.0.jar system src maven-assembly-plugin src/main/descriptor.xml make-assembly package single maven-surefire-plugin 2.22.0 true maven-compiler-plugin 3.5.1 1.8 1.8
Descriptor.xml file
Now we have the manifest file added, pom file updated. testproject sdk download and DEV KEY saved, time to get the descriptor.xml file and add to the project.
Navigate to https://github.com/testproject-io/java-sdk-examples/tree/master/Web/Addon/src/main and copy the descriptor.xml file and add to the project in main folder.
Create addon
Create a class named FillUpThreeFiledsTestProject (any name of your choice) and make sure it implements WebAction interface.
Make sure include the @Action annotation as this will be listed as Action name in Test Project.
package main.Addon; import io.testproject.java.annotations.v2.Action; import io.testproject.java.sdk.v2.addons.WebAction; import io.testproject.java.sdk.v2.addons.helpers.WebAddonHelper; import io.testproject.java.sdk.v2.drivers.WebDriver; import io.testproject.java.sdk.v2.enums.ExecutionResult; import io.testproject.java.sdk.v2.exceptions.FailureException; import org.openqa.selenium.WebElement; /** * Created by Sisirkant on 4/11/2020. */ @Action(name = "Fill Up Three Fields") public class FillUpThreeFieldsTestProject implements WebAction { @Override public ExecutionResult execute(WebAddonHelper webAddonHelper) throws FailureException { WebDriver driver = webAddonHelper.getDriver(); WebElement address = driver.findElementByXPath("//input[@id='address']"); address.sendKeys("My Address one"); WebElement eMailId = driver.findElementByXPath("//input[@id='email']"); eMailId.sendKeys("test@test.com"); WebElement phoneNo = driver.findElementByXPath("//input[@id='phone']"); phoneNo.sendKeys("1111111111"); return ExecutionResult.PASSED; } }
Its a simple add on which will fill up the fields and make sure it returns ExecutionResult.PASSED or FAILED based on your requirement.
Test the addon
In Runners folder, create a class ActionRunnerFillUpThreeFields and write the following
package main.Runners; import io.testproject.java.classes.DriverSettings; import io.testproject.java.enums.DriverType; import io.testproject.java.sdk.v2.Runner; import io.testproject.java.sdk.v2.drivers.WebDriver; import main.Addon.FillUpThreeFieldsTestProject; import org.openqa.selenium.support.ui.Select; /** * Created by Sisirkant on 4/11/2020. */ public class ActionRunnerFillUpThreeFields { private static final String DEV_TOKEN = "PASTE YOUR DEV TOKEN HERE"; public static void main(String[] args) throws Exception { DriverSettings driverSettings = new DriverSettings(DriverType.Chrome); try (Runner runner = new Runner(DEV_TOKEN, driverSettings)) { FillUpThreeFieldsTestProject fillUpThreeFieldsTestProject = new FillUpThreeFieldsTestProject(); WebDriver driver = runner.getDriver(fillUpThreeFieldsTestProject); driver.navigate().to("https://example.testproject.io/web/"); Thread.sleep(5000); driver.findElementByXPath("//input[@id='name']").sendKeys("Sisirkant"); driver.findElementByXPath("//input[@id='password']").sendKeys("12345"); driver.findElementByXPath("//button[@id='login']").click(); Thread.sleep(5000); Select country = new Select(driver.findElementByXPath("//select[@id='country']")); country.selectByVisibleText("Algeria"); runner.run(fillUpThreeFieldsTestProject); } } }
Right click on the ActionRunnerFillUpThreeFields and run to make sure that addon works fine.
Create package
Go to Terminal and type the run the following command
- mvn clean validate compile test package
The necessary addon package should have been created in target folder as mentioned in the screenshot
Import the AddOn to your project
Go to your project in TestProject and import the addon and it will be similar to the following screen shot. I see 2 add ons as I have created 2 add ons. In case of your project, you may see one.
Upon finish you see the following
All set, now you have your own add to use.
Use it in Test case
If you remember, we have created a Test case in TestProject to fill up the Name, Password, Country, Address, eMail and Phone fields. Not its time to replace the steps filling up Address, eMail and Phone fields with the addon that we have created.
Add the addon Action
Move the added step up (place it just before Step which saves the form) and Save & Exit
Now Run the test case and see if its working or not. It should be working perfectly. Let me know if it does not work :)
No comments:
Post a Comment