Working With the REPL Overview One of the important tools in creating UITests is the the REPL (read-eval-print-loop). The REPL is a console-like environment in which the developer enters expressions or a commands. It will then evaluate those expressions, and display the results to the user. The REPL is helpful when creating UITests – it allows us to explore the user interface and create the queries and statements so that the test may interact with the application. Starting the REPL The REPL can only be started by running a test which calls the IApp.Repl() method: [TestFixture] public class Tests { AndroidApp app; [SetUp] public void BeforeEachTest() { app = ConfigureApp.Android.StartApp(); } [Test] public void CreditCardNumber_TooShort_DisplayErrorMessage() { app.Repl(); } } When the test is run and .Repl() is invoked, UITest will halt the test and start the REPL in a terminal window: There are three ways to exit the REPL: Pressing Ctrl-C Typing exit Typing quit UITest will resume executing the rest of the test when the REPL is closed. Using the REPL The REPL provides an instance of IApp that will allow interaction with the application. The REPL also provides two commands that are useful for creating UITests, the tree command and the copy command. A common workflow is to use the tree command or IApp.Flash to identify views on the screen and to obtain meta-data about those views. That information is used to to create AppQueries and spike out the steps that will make up a test. Then the copy command can be used to copy that work to the clipboard so that it may be pasted into the test. Discovering Views With the tree Command The tree command will display a hierarchical list of the views that are visible on the screen: Discovering Views with IApp.Flash Many of the UITest API's take an AppQuery object to locate views on the screen. The IApp.Flash() method can be very helpful in testing these queries in the REPL. IApp.Flash() will highlight the results of the query by making them flash, and return some details about the views in the results. As an example, the following snippet shows how we can locate all of the EditText views that are visible on an Android activity: >>> app.Flash(c=>c.Class("EditText")) Flashing query for Class("EditText") gave 1 results. [ { "Id": "creditCardNumberText", "Description": "android.widget.EditText{528165e4 VFED..CL .F...... 139,70941,178 #7f050001 app:id/creditCardNumberText}", "Rect": { "Width": 802.0, "Height": 108.0, "X": 139.0, "Y": 274.0, "CenterX": 540.0, "CenterY": 328.0 }, "Label": null, "Text": "", "Class": "android.widget.EditText", "Enabled": true } ] We can use the Flash method to help create AppQuerys to use in conjunction with the other APIs to work out a test. Creating Steps in a Test Let's see how we can use the REPL to quickly test out individual steps in a test without having to compile the application, deploy it to a device/simulator/emulator, and then run the application – a very time consuming process. As an example, we can use the results of the tree command above. If our test is required to enter text in the EditText with the ID of creditCardNumberText, it could use the IApp.EnterText method: >>> app.EnterText(c=>c.Marked("creditCardNumberText"), "1234567890123456") Using element matching Marked("creditCardNumberText"). Tapping coordinates [ 540, 328 ]. Likewise, if the test needs to simulate the user tapping on a button, it could use the IApp.Tap method: >>> app.Tap(c=>c.Marked("validateButton")) Using element matching Marked("validateButton"). Tapping coordinates [ 540, 533 ]. Using the copy Command The REPL will keep a history of the commands that you have entered into it during the session. The copy command paste those commands into the clipboard: >>> copy Copying history to clipboard. This allows you to test out and debug commands in the REPL, and then promptly update your test code. Summary In this guide we discussed how to use the REPL to help create UITests. We discussed how to start and stop the REPL, Other th and how to build out the steps that make up a UITest.
© Copyright 2025