Here is our table
data:image/s3,"s3://crabby-images/76c4d/76c4db00c395259095bae3730c6244d298faf0ee" alt=""
To reach the table navigate to
http://libraryinformationsystem.org/react-js
then login with librarian/librarian credentials and click Books link at the top of the page.
Let's build a locator of Edit button for a given book. Recording a click on any of Edit buttons will produce a locator like
//tr[5]/td[7]/div/button[1]
Properties of the captured object will look like
data:image/s3,"s3://crabby-images/4e17b/4e17b42686457419e94f75e070beeee5d3c2f7ad" alt=""
To parameterize the XPath expression for the object enter the following value into XPATH property:
param_vars://tr[./td/text()='{BookName}']/td[7]/div/button[1]
Here param_vars: prefix tells Rapise that the locator is parameterized. {BookName} is a placeholder for the parameter value. You may also use % instead of curly braces: %BookName%.
To define the parameter select the object in the Object tree, right click it and choose Add Parameter from the popup menu.
data:image/s3,"s3://crabby-images/832f3/832f37862392557a4635a1254e1fe1ed5ccf3197" alt=""
Specify parameter name and click Ok.
data:image/s3,"s3://crabby-images/28ca5/28ca53fe9ade95badd1678bf74b0a536a0dfc38d" alt=""
Properties of the Edit object now look like (notice BookName parameter at the bottom).
data:image/s3,"s3://crabby-images/bfa87/bfa871393c489bfc4d87d17b682d02469555343e" alt=""
Specify the default value for this parameter, e.g. Amsterdam.
To set the book name during test playback in RVL use RVL.SetLocatorOpts action:
data:image/s3,"s3://crabby-images/37f09/37f098c7aae7ca6bf36e9898bef462cee7d9c0d1" alt=""
If you are using JavaScript you may simply pass BookName to SeS function.
// Edit default book
SeS('Edit').DoClick();
SeS('Cancel').DoClick();
// Set book name to Saturday
SeS('Edit', {BookName: "Saturday"}).DoClick();
SeS('Cancel').DoClick();
The sample test is available in Rapise Samples repository on GitHub:
https://github.com/Inflectra/rapise-samples/tree/master/DynamicWebLocator