RVL-based Module
Let's take a look how it works. First we will create a new Test Automation Framework.
data:image/s3,"s3://crabby-images/51140/5114064f14c4c737f1d30d82ccb2cd86fcb53c92" alt=""
Name it PageObjectsDemo and choose Web test type.
data:image/s3,"s3://crabby-images/d2fda/d2fda2e82e6c395ee9935444be84364ab237ec67" alt=""
Choose Chrome browser profile.
data:image/s3,"s3://crabby-images/68e7e/68e7e3fcc5a204fae7a183ec0f26c42bbc3d3894" alt=""
In the Object Tree pane right click Modules/Pages and choose Create Module/Page Object.
data:image/s3,"s3://crabby-images/8d7d9/8d7d988351d0d6da08586b2ae67104dca4b68e99" alt=""
Give it a name LoginPage and click Create button.
data:image/s3,"s3://crabby-images/b4afa/b4afaac4c289910f6fc3b32a4a027dcd01992f32" alt=""
We are going to create an RVL module, so choose RVL option.
data:image/s3,"s3://crabby-images/7b351/7b351c98aee81ec338ad385b9b6ea6f75bbd2f11" alt=""
LoginPage RVL will be created.
data:image/s3,"s3://crabby-images/8d60b/8d60b28b03a5141fad372f4cb1007ac79fb8fcf2" alt=""
And LoginPage module will appear in the Object Tree.
data:image/s3,"s3://crabby-images/fdf73/fdf733b128d6f9bfc3f63e480e6f5ed9f4919620" alt=""
Our page object has a default action DoAction, you may see it's name in RVL tabs. Double click it and change to DoLogin.
data:image/s3,"s3://crabby-images/deb45/deb4564ba333cf1bb1647a741157bfc4d2bcabcf" alt=""
Define two input parameters for this action: USR, PWD.
data:image/s3,"s3://crabby-images/489ae/489ae37ec74537426f32d13b3aaf8a9cff66a6e3" alt=""
We will now record a login sequence of steps on https://libraryinformationsystem.org with credentials librarian/librarian. Make sure that the LoginPage RVL document is still active and click Record button on the toolbar. You will see the Choose Test Case dialog with LoginPage selected.
data:image/s3,"s3://crabby-images/74819/7481939556010a120d0ccd99cea4d5b6aefde215" alt=""
Click OK and record the login scenario. Enter the URL when prompted.
data:image/s3,"s3://crabby-images/427d2/427d2d0c31cec1357613686459653ec78fdb5e41" alt=""
Click the Log In link.
data:image/s3,"s3://crabby-images/e02fc/e02fcdba3064362be3e83f61210e302faaad08b2" alt=""
Enter username and password and click Log In button.
data:image/s3,"s3://crabby-images/b690c/b690c520ab51424aae7636db96f1bd4ab7e11845" alt=""
Click Finish in the Recording Activity dialog.
data:image/s3,"s3://crabby-images/c2e1f/c2e1fe122304e09577b2902a186abd2c52f50521" alt=""
Select line 10 and click Insert Here button.
data:image/s3,"s3://crabby-images/3853d/3853d2a88e876f07671943581bd7d55a413e23cf" alt=""
You will see the steps inserted.
data:image/s3,"s3://crabby-images/a3d28/a3d289a983864972abdabe600cdbcf80b733d565" alt=""
Bind Username and Password fields to USR and PWD input parameters.
data:image/s3,"s3://crabby-images/0eab1/0eab18a2de4766f72892d8f2a9690b0f6056eb8c" alt=""
DoLogin action is ready to use. Let's now create one more sheet DoLogout.
data:image/s3,"s3://crabby-images/f9f04/f9f0401a75b667a84f9778a4b068bbf257a422de" alt=""
Click Record on the toolbar, click OK in the Choose Test Case dialog. Rapise will reconnect to Chrome. Just click on Log Out link.
data:image/s3,"s3://crabby-images/46b0d/46b0d1d123ae9ebea0efbf9bd749f553a079026e" alt=""
Click Finish in the Recording Activity dialog.
data:image/s3,"s3://crabby-images/c85d2/c85d2c9811f85a9e802154d81c6b1c7080d912b4" alt=""
Insert the recorded steps, remove the default parameter for the DoLogout action. You will see the result.
data:image/s3,"s3://crabby-images/63c23/63c2392cd178de03a6de719ab34143f9ae76f91f" alt=""
We are now ready to create the very first test case.
data:image/s3,"s3://crabby-images/c2454/c245428f9e4d54c860c9baa6a3f629b939bfd345" alt=""
In CheckLogin RVL use LoginPage module like this:
data:image/s3,"s3://crabby-images/c9413/c9413a86b16f958ec66e338b43853c75d4a1a79c" alt=""
You may now run CheckLogin test case, just click Play icon against the test case name.
data:image/s3,"s3://crabby-images/26216/262167091a1faa643261bbb86ccf0b8024a4e6de" alt=""
After execution you will see the report:
data:image/s3,"s3://crabby-images/17c5a/17c5ae6520d55ac82db4e82eea37a986f67b588d" alt=""
If you wish to close the browser at the end of each test case please refer to Recommended way of executing code before and after each test case.
JavaScript-based Module
Let's now create JavaScript module with name GridModule.
data:image/s3,"s3://crabby-images/d87eb/d87ebd128fdc1ef655c4635716296397efe8f7e5" alt=""
data:image/s3,"s3://crabby-images/8debe/8debeac458cc42142d4dadc838b687ea97a71d9d" alt=""
data:image/s3,"s3://crabby-images/cef04/cef043c3166492254532847f088db4dc3d6d7217" alt=""
GridModule.js will be created and opened.
data:image/s3,"s3://crabby-images/9d583/9d583c3720ba471d243e10b709efdcc2eebdc3a3" alt=""
Change it to
/**
* @PageObject GridModule description
*/
SeSPageObject("GridModule");
/**
* Get the number of rows in the main grid
*/
function GridModule_GetRowCount() /**number*/
{
var /**HTMLObject*/ tableObj = Navigator.SeSFind("//table[@class='dataGrid']");
if (tableObj)
{
var rowCount = tableObj.DoDOMQueryValue("count(.//tr)");
return rowCount - 1;
}
return -1;
}
Now we may use it in a test case. Let's create new test case with name CheckGrid by cloning existing test case CheckLogin.
data:image/s3,"s3://crabby-images/433e2/433e2117d8b319db3982b769e8ea7a7365d36cbf" alt=""
Make sure that you are logged into the Library Information System in Chrome and record click on Book Management link.
data:image/s3,"s3://crabby-images/2ffa0/2ffa025f7d7b282210733c51fad178c5bd9bf09c" alt=""
Then update the CheckGrid RVL to look like this:
data:image/s3,"s3://crabby-images/a7a1c/a7a1ce9c5504d5cc5762e223840bac8997e77f3d" alt=""
Logout from the Library Information System in Chrome and play CheckGrid test. You will see the report.
data:image/s3,"s3://crabby-images/fdb60/fdb60678433b6ca077da90f7d3e4655289baed30" alt=""
Note: the framework created in this article is attached.