Using Java method annotations for custom objects
If you customize your instance of Salesforce, you may need to insert Java method annotations in order to test those features. (See the page object operations page for additional info.)
To test these custom elements, go to the Navigator pane on the left side of your screen in Provar and find the page objects folder under the project/src folder. Double-click the custom page object that you created. You’ll see two tabs at the bottom of your page object viewer: Page Object Editor and Java Source. Click Java Source.
Within the Java Source screen, you can enter the annotations below to customize the custom page object that is part of your overall test.
Below is a quick glossary of the most frequently used method annotations that you can use to insert and apply the commands you need.
@FindBy
This is a selenium annotation that is used to find an element. You can use parameters such as linkText, xpath, id, Name, CSS, Label, and Component Xpath.
Example:
@FindBy(linkText = "Account Information")
@LinkType()
This controls how the user interacts with links in a variety of ways. This annotation can be customized based on the interaction type: Hover, Click, Double-Click, Download, Drag and Drop.
Example:
@LinkType() @FindBy(xpath = "//input[text()='Email']") public WebElement email;
@TextType()
This controls how the user interacts with text in a variety of ways. This annotation can be customized based on the interaction type: Hover, Double Click, Set, Click, Clear, Drag and Drop.
Example:
@TextType() @FindBy(xpath = "//input[text()='Email']") public WebElement email;
@ButtonType()
This controls how the user interacts with buttons in a variety of ways. This annotation can be customized based on the interaction type, such as Hover, Click, Double Click, Download, Drag and Drop.
Example:
@ButtonType() @FindBy(xpath = "//input[text()='Save']") public WebElement save; @ButtonType(file=true) is used to get “Choose File“ interaction
@BooleanType()
This controls how the user performs actions in a variety of ways. This annotation can be customized based on the action type, such as Hover, Double Click, Check, Uncheck, Toggle, Drag and Drop.
Example:
@BooleanType() @FindBy(xpath = "//input[text()='yes']") public WebElement Yes;
@ChoiceListType
This controls how the user interacts with a picklist (a.k.a. drop-down menu) in various ways. This annotation can be customized based on the interaction type: Hover, Double Click, SetByIndex, Set, Clear, Click, Drag and Drop.
Example:
@ChoiceListType(values = { @ChoiceListValue(value = "prod1", title = "Test 123"), @ChoiceListValue(value = "prod2", title = "testing 321") }) @FindBy(xpath = "//*[@id="sproduct"]/select") public WebElement selectProduct;
@ChoiceListValue
This function is used to verify that a specific item is available in a drop-down menu. For example, you can use this to verify that an opportunity stage drop-down menu includes the option to select “Prospecting”.
@FindByLabel
This can be used for finding an element by label in a custom table.
Example:
@PageTable(row = Con.class) @VisualforceBy(componentXPath = "apex:dataTable[@value = "{!con}"]") public List<Con> Con; @PageRow(byColumn = true) public static class Con { @TextType() @VisualforceBy(componentXPath = "apex:outputField[@value = "{!a.lastname}"]") public WebElement lastName; @LinkType() @VisualforceBy(componentXPath = "apex:outputField[@value = "{!a.email}"]") public WebElement email; } @PageTable(row = Con.class) is used to define Rows in table @PageRow(byColumn = true)is used to get in row by column
@PageFrame
This annotation is used to define a frame/Iframe in page objects. (Most of the time Provar automatically manages iframes, but sometimes you may need to handle iframes manually.)
Example:
@PageFrame() public static class Frame{ @TextType() @FindBy(xpath = "//*[text()=’username’]") public WebElement username; } @Findby(name ="testFrame") public Frame frame;
- Provar Automation
- Installing Provar Automation
- Updating Provar Automation
- Using Provar Automation
- API testing
- Behavior-driven development
- Creating and importing projects
- Creating test cases
- Custom table mapping
- Functions
- Debugging tests
- Defining a namespace prefix on a connection
- Defining proxy settings
- Environment management
- Exporting test cases into a PDF
- Exporting test projects
- Override auto-retry for Test Step
- Managing test steps
- Namespace org testing
- NitroX
- Provar desktop
- Provar Test Builder
- Refresh and Recompile
- Reintroduction of CLI license Check
- Reload Org Cache
- Reporting
- Running tests
- Searching Provar with find usages
- Secrets management and encryption
- Setup and teardown test cases
- Tags and Service Level Agreements (SLAs)
- Test cycles
- Test plans
- Testing browser options
- Tooltip testing
- Using the Test Palette
- Using custom APIs
- Callable tests
- Data-driven testing
- Page objects
- Block locator strategies
- Introduction to XPaths
- Creating an XPath
- JavaScript locator support
- Label locator strategies
- Maintaining page objects
- Mapping non-Salesforce fields
- Page object operations
- ProvarX™
- Refresh and reselect field locators in Test Builder
- Using Java method annotations for custom objects
- Applications testing
- DevOps
- Introduction to test scheduling
- Apache Ant
- Configuration for Sending Emails via the Automation Command Line Interface
- Continuous integration
- AutoRABIT Salesforce DevOps in Provar Test
- Azure DevOps
- Running a Provar CI Task in Azure DevOps Pipelines
- Configuring the Automation secrets password in Microsoft Azure Pipelines
- Parallel Execution in Microsoft Azure Pipelines Using Multiple build.xml Files
- Parallel Execution in Microsoft Azure Pipelines using Targets
- Parallel execution in Microsoft Azure Pipelines using Test Plans
- Bitbucket Pipelines
- CircleCI
- Copado
- Docker
- Flosum
- Gearset DevOps CI/CD
- GitHub Actions
- Integrating GitHub Actions CI to Run Automation CI Task
- Remote Trigger in GitHub Actions
- Parameterization using Environment Variables in GitHub Actions
- Parallel Execution in GitHub Actions using Multiple build.xml Files
- Parallel Execution in GitHub Actions using Targets
- Parallel Execution in GitHub Actions using Test Plan
- Parallel Execution in GitHub Actions using Job Matrix
- GitLab Continuous Integration
- Travis CI
- Jenkins
- Execution Environment Security Configuration
- Provar Jenkins Plugin
- Parallel Execution
- Running Provar on Linux
- Reporting
- Salesforce DX
- Git
- Team Foundation Server
- Version control
- Provar Automation trial guide and extensions
- Salesforce Testing
- Provar Manager
- Best Practices
- Troubleshooting
- Release Notes