β‘Automation for Salesforce is tough (no , seriously). And every platform release brings the lightning and thunder for UI Automation tests (Winter21 caused even our tests to shiver). So we thought, what if we could find a solution to this madness and create a simple (but robust) framework for Salesforce automation tests. And solve the problem of flaky tests, while accelerating the development of automation tests.
Presenting (drum roll π₯) TestZeus -> An open source automation framework built specifically for Salesforce. So what ? Well, this framework has boiler plate code to get you started with test automation for your Salesforce org. And just to name a few features :
- a.Advance utilities like Autolocators π§ββοΈ (https://github.com/TestZeus/TestZeus/blob/main/README.md#autolocator-strategy-)
- b.API integrations for REST APIs π
- c.Intelligent Waiting mechanism for Salesforce pages β
- d.Contextual actions for Salesforce UI elementsπΉ
- e.Basic integrations like Email , Selenium, TESTNG, MAVEN and page objects.β
The core of the framework works on top of Salesforce's UI API to achieve UI automation. Dont know what is UI API? No worries at all , here is a resource to get you going : https://developer.salesforce.com/docs/atlas.en-us.uiapi.meta/uiapi/ui_api_get_started.htm
And here is a nice diagram from our friends at Salesforce:
This is where the magic happens. We parse the UI API and process the jsonresponse for labels, datatypes and sections to create the actions and locators for the UI elements on the fly. Ask me how? See this now :
Here is a high level diagram for the framework. The tests can be run from maven or TestNG.
Note - Kindly open the above images in new tab and you can see the full image displayed correctly.
Dont know a lot about the Salesforce platform, or this stuff looks too complicated? Dont worry, we have you covered with the definitive course on Salesforce Test Automation : Automating Salesforce Tests with TestZeus.
π€«Psst.. Its free π€
Here's a neat podcast around test automation for Salesforce using TestZeus : Youtube Link
- Technical requirements : JAVA, Maven, TestNG, ChromeDriver on the local.
- And Non-technical requirements : A beverage of your choice (coffee/tea) and some good music to automate the toughest of test cases.
There are 2 ways of using TestZeus:
- Clone this repository
- Import into your favourite IDE as a "Maven" project
- As this repository already contains Maven dependencies for TestZeus, Selenium, TestNG, Emails, APIs etc; therefore you need not add these separately
As easy as 1-2-3:
- Add the Page object class for which the flow has to be modeled
- The class variable for the same needs to be added to the BaseTest class for instantiation
- Create the actual test class with references to the web elements and corresponding actions from the page object class
Each test class is extended from BaseTest, thereby inheriting the wrapped methods for @BeforeClass and @BeforeSuite.
BaseTest class also triggers the below 2 things:
- Page Object Model: The page objects are instantiated at run time via Reflection
- Data setup and post execution clean up of webdriver
Wrapper methods for abstracting the webdriver internals are written in the PageBase class. Methods to interact with UI API and create locators/interactions are setup in the SFPageBase class.
Note.1 : There are sample tests included in the location src/test/java/testscripts/
to help you get started.
Note.2 : The demo test cases under src/test/java/testscripts/
require credentials from config.json file for authentication and authorization, so dont forget to put in the credentials before trying to run the tests .
- Option 1 - Both the UI and API test can be run as standalone TESTNG tests OR
- Option 2- Perform a maven build with
mvn clean install test
goals on the pom.xml
Detailed option: Run as -Dtest=SmokeTest -Dmaven.surefire.debug test And then: Debug config->set up 5005 port and then continue debugging
Quick Option: As always, adding break points and debug as TestNG test
-
Add the Testzeus maven dependency in your pom.xml file. Latest build here: https://search.maven.org/artifact/com.testzeus/Test_Zeus
-
TestZeus will need the below to perform the requisite automated operations :
- A webdriver instance
WebDriver driver = new ChromeDriver();
to perform the UI interactions (clicks, smart waits, selects) from the SFPageBase class - User and API credentials to perform CRUD operations and fetch UI API details for building the web elements on the fly.
Sample method call and Test Class :
public class AccountCreationViaUI {
@Test(priority = 1)
public void createAccount() throws Exception {
// Credentials for using the Connected app and accessing data via REST API
final String SFAPIUSERNAME_UAT = "gmail@rajnikanth.com";
final String SFAPITOKEN_UAT = "yourAPItoken";
final String SFAPIPASSWORDSTRING_UAT = "passwordstring";
// password needs to be appended with token as per : //
// https://stackoverflow.com/questions/38334027/salesforce-oauth-authentication-bad-request-error
final String SFAPIPASSWORD_UAT = SFAPIPASSWORDSTRING_UAT + SFAPITOKEN_UAT;
final String SFAPILOGINURL_UAT = "https://testzeus.my.salesforce.com";
final String SFAPIGRANTSERVICE = "/services/oauth2/token?grant_type=password";
// Client id is the consumerkey for the connected app
final String SFAPICLIENTID_UAT = "clientID";
// Client secret is the consumer secret protected static final String
final String SFAPICLIENTSECRET_UAT = "clientsecret";
// Setting up Login for SF API requests
HTTPClientWrapper.SFLogin_API(SFAPILOGINURL_UAT, SFAPIGRANTSERVICE, SFAPICLIENTID_UAT, SFAPICLIENTSECRET_UAT,
SFAPIUSERNAME_UAT, SFAPIPASSWORD_UAT);
//Sample usage of BoniGarcia's webdriver manager
WebDriverManager.chromedriver().setup();
ChromeDriver driver = new ChromeDriver();
//Create a new instance of the SFPageBase class
SFPageBase pb = new SFPageBase(driver);
// Use methods from TestZeus as below for Navigation to login page
pb.openHomepage("https://testzeus2-dev-ed.my.salesforce.com");
pb.maximize();
// Or Use the webdriver implementations: Example for Submitting user id,
// password and logging in
driver.findElement(By.id("username")).sendKeys("UIusername@gmail.com");
driver.findElement(By.id("password")).sendKeys("UIpassword");
WebElement loginbutton = driver.findElement(By.id("Login"));
pb.safeClick(loginbutton);
pb.appLauncher("Account");
WebElement newbutton = driver.findElement(By.xpath("//a[@title='New']"));
pb.safeClick(newbutton);
// We fetch all the labels and datatype from UI API here for a certain record
String recordid = "0015g00000S9lfUAAR";
pb.uiApiParser(recordid);
// Form data can be passed directly on the new sObject creation screen
pb.formValueFiller("Account Name", "AccountCreatedOn : " + pb.getCurrentDateTimeStamp());
WebElement savebutton = driver.findElement(By.xpath("//button[@name='SaveEdit']"));
pb.safeClick(savebutton);
HTTPClientWrapper.SFLogout_API();
// Dont forget to say thanks
System.out.println("Thank you :) ");
driver.close();
driver.quit();
// Setting driver to null for stopping persistent use of driver
// session across browsers
driver = null;
}
}
Under 5 minute video to show you the highlights of the framework and a demo of the execution :
TestZeusDemocompressed.mp4
- Link to the video recording
- Link to the slides
Zeus is the God of lightning and thunder and we want this framework to be the same with Lightning platform. (plus we got the domain name for a cheap price π€)
- Stop writing flaky locators and cryptic xpaths for Webelements on the Salesforce UI. We source the locator values for your scripts from the Salesforce UI API , so that you can focus more on building tests and less on maintenance
- The world of testing for Salesforce can be fast-paced and scary. That's why we are together in this mission and need your help to spread the word, try the framework or contribute to our codebase. And we have a long road ahead of us, so lets join forces to automate Salesforce
You can find a happy and helping community of Test Automation/QA folks at the below link:
And if you would like to technically contribute/raise an issue, then feel free to open a ticket on this Github Repo.
Kindly note , that we have observed a few users mentioning about an issue with project imports and getting errors related to Testzeus base file missing from the project. This is an IDE related issue and can be easily resolved with the solution mentioned here
Another note: If you are facing MFA issues (where Salesforce asks for a temporary code sent to your email), you can bypass it by following the steps here
Note : We are in no way directly or indirectly associated with Salesforce (yet).
Made with β₯ in India.