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.)
In order 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 includes 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 selenium annotation that is used to find an element. You can use a variety of different 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 such as 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 such as 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 a variety of ways. This annotation can be customized based on the interaction type such as 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;
- General information
- Licensing Provar
- Provar trial guide and extensions
- Using Provar
- 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
- Provar desktop
- Provar Test Builder
- Refresh and Recompile
- 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 Provar Command Line Interface
- Continuous integration
- AutoRABIT Salesforce DevOps in Provar Test
- Azure DevOps
- Running a Provar CI Task in Azure DevOps Pipelines
- Configuring the Provar 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 Provar 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
- Salesforce testing
- Adding a Salesforce connection
- Assert Page Error Messages on Add/Edit Product
- Dynamic Forms
- Internationalization support
- List and table testing
- Salesforce Release Updates
- Salesforce Lightning Testing
- Salesforce Lightning Web Component (LWC) locator support
- Salesforce console testing
- Visualforce Testing
- Performance Best Practices
- Testing best practices
- Troubleshooting
- Browsers
- Configurations and permissions
- Connections
- DevOps
- Error messages
- Administrator has blocked access to client
- JavascriptException: Javascript error
- macOS Big Sur Upgrade
- Resolving failed to create ChromeDriver error
- Resolving Jenkins license missing error
- Resolving metadata timeout errors
- Test execution fails – Firefox not installed
- Update to Opportunity field validation behaviour
- Licensing, installation and firewalls
- Memory
- Test Builder and test cases
- Release notes