Components of teststep in Selenium IDE
A test step in Selenium
comprises of following:
Selenese Commands - set of selenium commands used in Selenium IDE. e.g: Open , type , sendKeys, etc.
Target - object on which to execute the commands. Target object can be identified based on the locator for the object,i.e. by Id, classname, xpath,CSS, etc.
Value - acts as input or the expected result on execution of command on the target object.
Selenese Commands - set of selenium commands used in Selenium IDE. e.g: Open , type , sendKeys, etc.
Target - object on which to execute the commands. Target object can be identified based on the locator for the object,i.e. by Id, classname, xpath,CSS, etc.
Value - acts as input or the expected result on execution of command on the target object.
Selenium commands in Selenium IDE
Below are some of the
useful commands used in Selenium.
- Open - open(url). URL provided accepts both relative and absolute URLs. The "open" command waits for the page to load before proceeding. URL is provided in the target of the command. In case only ‘/’is provided in the target. It will open the URL as provided in base URL. Following are few ways in which open command works. Suppose base url is http://www.google.com, below are the scenarios
- / in target will open http://www.google.com/ (relative path)
- /#q=google in target will open http://www.google.com/#q=google (relative Path)
- http://www.rediff.com in target will open http://www.rediff.com (absolute Path). Similar to this is OpenWindow(url) – This will open url provided in target in a new window.
- type(Locator, value) - Types the value in the object identified by the locator. This can be used to set the value of combo boxes, check boxes, etc. Target will be object
- Sendkeys(Locator, value) - This command types the value key-by-key defined in value on the object identified by Locator. It may be confusing for new users the use of sendkeys when type command already exists. The difference between Sendkeys and type is when we use sendkeys, it does not replace the existing content in the field, whereas when we use type, it replaces the content of the field. Both the methods are used to input data in an edit field.
- Click(locator) – Clicks an object defined by locator in Target. In case we need to wait for page to load completely before performing further action, we use ClickandWait.
- Select(Locator, value) – This is used to select a value from a webList identified by Locator defined in target and sets the value as defined in the value. In case of Page load in case of selecting value from the weblist, use selectandwait.
- Store(expression, variable Name) – This stores the value of element defined in expression in the target and stores in the variable name defined in value. This value can be used further in the test by using variable as $variableName.
- Similar to store are storeAttribute(an element locator followed by a @ sign and then the name of the attribute, e.g. "id=name@href"), storeText(stores the text of an element) to name a few.waitForPageToLoad(time in millisecond) – This waits for the Page to Load completely in the time defined in target. Will move to next step in case the Page loads before the defined time
- pause(time in milliseconds) – This is similar to wait statement and execution is paused for the time defined for pause command in target.
- Refresh – This command refreshes the page.
- verifyText(locator, expected pattern) – This compares the text in the locator element with the expected pattern defined in value. To provide a pattern, you can use text within *value*. This will verify if value appears in the text displayed for locator. Similar to verifyText, we can use verifynottext, verifyalert, verifyattribute to validate information in the Page.
- AssertText(locator, expected pattern) – This compares the text in the locator element with the expected pattern defined in value. To provide a pattern, you can use text within *value*. This will verify if value appears in the text displayed for locator. Similar to AssertText, we can use Assertnottext, Assertalert, Assertattribute to validate information in the Page. Difference between Assert and verify is while test stops in case of assert fails but remaining statements in the test are executed in case of verify statement even if the verify statement fails.
- Highlight(Locator) – highlights the object identified by locator in the page.
- Break – This halts the test execution, test execution will continue once we click on continue in the IDE. This should be used in test but removed once test stabilizes as it results in manual intervention.
- captureEntirePageScreenshot(filename) – This command captures screenshot and save in the location defined in filename in the target
- check(locator) – this checks a radio button/checkbox based on locator defined in target.
- Close() – This command simulates the user clicking the "close" button in the title bar of a popup window or tab
- windowMaximize() – this command will resize currently selected window to take up entire screen
Different types of Selenese Commands
Selenese commands can be classified into
following types:
a. Actions – Performs action
on an object. E.g. Click, type
b. Assertions – Used to add
validation steps. E.g. AssertText, verifytext
c. Accessors – checks the
state of application and stores values from the test. E.g. storetext.
Default timeout for Selenium Commands
Default timeout for selenium commands is
30000. The timeout can be changed from Options>General>default timeout of
recorded command