NAME
Win32::IEAutomation - Web application automation using Internet Explorer
SYNOPSIS
use Win32::IEAutomation;
# Creating new instance of Internet Explorer
my $ie = Win32::IEAutomation->new( visible => 1, maximize => 1);
# Site navigation
$ie->gotoURL('http://www.google.com');
# Finding hyperlinks and clicking them
# Using 'linktext:' option (text of the link shown on web page)
$ie->getLink('linktext:', "About Google")->Click;
# Or using 'linktext:' option with pattern matching
$ie->getLink('linktext:', qr/About Google/)->Click;
# Or using 'id:' option ( <a id=1a class=q href=......>)
$ie->getLink('id:', "1a")->Click;
# Finding checkbox and selecting it
# Using 'name:' option ( <input type = "checkbox" name = "checkme" value = "1"> )
$ie->getCheckbox('name:', "checkme")->Select;
# Or using 'aftertext:' option (for checkbox after some text on the web page)
$ie->getCheckbox('aftertext:', "some text here")->Select;
# Finding text field and entering data into it
# Using 'name:' option ( <input type="text" name="username" .......> )
$ie->getTextBox('name:', "username")->SetValue($user);
# Finding button and clicking it
# using 'caption:' option
$ie->getButton('caption:', "Google Search")->Click;
# Accessing controls under frame
$ie->getFrame("name:", "content")->getLink("linktext:", "All Documents")->Click;
# Nested frames
$ie->getFrame("name:", "first_frame")->getFrame("name:", "nested_frame");
# Catching the popup as new window and accessing controls in it
my $popup = $ie->getPopupWindow("title of popup window");
$popup->getButton('value:', "button_value")->Click;
Additionally it provides methods to interact with security alert dialog, conformation dialog, logon dialog etc.
# To navigate to some secure site and pushing 'Yes' button of security alert dialog box
use Win32::IEAutomation;
use Win32::IEAutomation::WinClicker; # this will provide methods to interact with dialog box
my $ie = Win32::IEAutomation->new();
$ie->gotoURL("https://some_secure_site.com", 1); # second argument says that don't wait for complete document loading and allow code to go to next line.
my $clicker = Win32::IEAutomation::WinClicker->new();
$clicker->push_security_alert_yes();
$ie->WaitforDone; # we will wait here for complete loading of navigated site
DESCRIPTION
This module tries to give web application automation using internet explorer on windows platform. It internally uses Win32::OLE to create automation object for IE. It drives internet explorer using its DOM properties and methods. The module allows user to interact with web page controls like links, buttons, radios, checkbox, text fields etc. It also supports frames, popup window and interaction with dialogs like security alert, confirmation dialog etc.
METHODS
CONSTRUCTION AND GENERIC METHODS
Win32::IEAutomation->new( [visible => 1, maximize => 1] )
This is the constructor for new Internet Explorer instance through Win32::OLE. Calling this function will create a perl object which internally contains a automation object for internet explorer. Two options are supported to this method in hash format. Both of these are optional.
visible
It sets the visibility of Internet Explorer window. The default value is 1, means by default it will be visible if you don't provide this option. You can set it to 0 to run it in invisible mode.
maximize
Default value of this is 0, means it runs IE in the size of last run. Setting this to 1 will maximize the window.
gotoURL($url, [$nowait])
This method navigates to the given url and waits for it to be loaded completely if second argument is not provided Second argument is optional and it represents the boolean value for not waiting till page gets loaded. Giving second argument as 1 (true boolean value) makes your code not to wait for page loading in this 'gotoURL' method. This is useful if you need to interact with any dialog like security alert. In that case use this method with second argument, then interact with dialog (methods for interacting with dialog are described below) and then using method 'WaitforDone' (described below) wait for IE to load page completely.
Back()
Works as IE's Back button and waits for it to be loaded completely
Reload()
Works as IE's Refresh button and waits for it to be loaded completely
URL()
This will return the URL of the current document
Title()
This will return title of the current document
Content()
This will return the HTML of the current document. Please note that all the tags are upper cased. The return value is of scalar type.
VerifyText($string)
Verifies that given string is present in the current document. It returns 1 on success and undefined on failure.
WaitforDone($string)
Waits till IE had came out of busy state and document is loaded completly. This will poll IE for every one second and check its busy state and document complete state, before we move on.
closeIE()
It will close the instance of internet explorer.
getAgent()
It will return a reference to the Internet Explorer automation object, created using Win32::OLE.
LINK METHODS
getLink($how, $what)
This is the method to access link on web page. It returns Win32::IEAutomation::Element object containing html link element.
$how : This is the option how you want to access the link
$what : This is string or integer, what you are looking for. For this, it also supports pattern matching using 'qr' operator of perl (see example below)
Valid options to use for $how:
'linktext:' - Find the link by matching the link text i.e. the text that is displayed to the user 'id:' - Find the link by matching id attribute 'name:' - Find the link by matching name attribute 'linkurl:' - Find the link by matching url attribute of the link 'class:' - Find the link by matching class attribute
Typical Usage:
$ie->getLink('linktext:', "Sign in"); # access the link that has Sign in as its text $ie->getLink('linktext:', qr/About Google/); # access the link whose text matches with 'About Google' $ie->getLink('id:', 5); # access the link whose id attribute is having value 5
getAllLinks()
This will return a list of all links present in the current document, in form of Win32::IEAutomation::Element objects. For return value, in scalar context, gives number of links present and in list context gives array of all link objects. Each object in the array is similar to one we get using getLink method.
Methods supported for link object
Click($nowait);
Clicks the link and waits till document is completely loaded. As it uses click method of DOM, it supports clicking link with javascript in it.
$nowait: This is optional. Giving this argument as 1 (true boolean value) makes your code not to wait for complete page loading after clicking link. This is useful if you need to interact with any dialog (like logon dialog) after clicking the link. (please see logon() method example for details)
linkText();
Returns text of the link
linkUrl();
Returns url of the link
getProperty($property)
Retrieves the value of the given property for link object. This makes easy to get value of any property that is supported by html link.
IMAGE METHODS
getImage($how, $what)
This is the method to access image on web page. It returns Win32::IEAutomation::Element object containing html image element.
$how : This is the option how you want to access the image
$what : This is string or integer, what you are looking for. For this, it also supports pattern matching using 'qr' operator of perl (see example below)
Valid options to use for $how:
'id:' - Find the image by matching id attribute 'name:' - Find the image by matching name attribute 'imgurl:' - Find the image by matching src attribute of the image 'alt:' - Find the image by matching alt attribute of the image 'class:' - Find the image by matching class attribute
Typical Usage:
$ie->getImage('imgurl:', qr/logo.gif$/); # access the image that matches logo.gif at last of string of its url (src) $ie->getImage('alt:', "Google"); # access the image whose alt attribute is 'Google' $ie->getImage('class:', $some_class); # access the image whose class attribute is having value $some_class
getAllImages()
This will return a list of all images present in the current document, in form of Win32::IEAutomation::Element objects. For return value, in scalar context, gives number of images present and in list context gives array of all image objects. Each object in the array is similar to one we get using getImage method.
Methods supported for image object
Click($nowait)
Clicks the image and waits till document is completely loaded. As it uses click method of DOM, it supports clicking link with javascript in it.
$nowait: This is optional. Giving this argument as 1 (true boolean value) makes your code not to wait for complete page loading after clicking image. This is useful if you need to interact with any dialog (like logon dialog) after clicking the image. (please see logon() method example for details)
imgUrl()
Returns url of the image
getProperty($property)
Retrieves the value of the given property for image object. This makes easy to get value of any property that is supported by html image.
BUTTON METHODS
getButton($how, $what)
This is the method to access button on web page. It returns Win32::IEAutomation::Element object containing html input type=button or submit element.
$how : This is the option how you want to access the button
$what : This is string or integer, what you are looking for. For this, it also supports pattern matching using 'qr' operator of perl (see example below)
Valid options to use for $how:
'id:' - Find the button by matching id attribute 'name:' - Find the button by matching name attribute 'value:' - Find the button by matching value attribute 'caption:' - Find the button by matching text shown on button 'class:' - Find the button by matching class attribute
If there are more than one button having same value for the option you are quering, then it returns first button of the collection.
Typical Usage:
$ie->getButton('caption:', "Google Search"); # access the button with 'Google Search' as its caption $ie->getButton('name:', "btnG"); # access the button whose name attribute is 'btnG'
Methods supported for button object
Click($nowait)
Clicks the button and waits till document is completely loaded.
$nowait: This is optional. Giving this argument as 1 (true boolean value) makes your code not to wait for complete page loading after clicking button. This is useful if you need to interact with any dialog (like logon dialog) after clicking the button. (please see logon() method example for details)
getProperty($property)
Retrieves the value of the given property for button object. This makes easy to get value of any property that is supported by html button.
RADIO and CHECKBOX METHODS
getRadio($how, $what)
This is the method to access radio button on web page. It returns Win32::IEAutomation::Element object containing html input type=radio element.
getCheckbox($how, $what)
This is the method to access checkbox on web page. It returns Win32::IEAutomation::Element object containing html input type=checkbox element.
$how : This is the option how you want to access the radio or checkbox
$what : This is string or integer, what you are looking for. For this, it also supports pattern matching using 'qr' operator of perl (see example below)
Valid options to use for $how:
'id:' - Find the radio or checkbox by matching id attribute 'name:' - Find the radio or checkbox by matching name attribute 'value:' - Find the radio or checkbox by matching value attribute 'class:' - Find the radio or checkbox by matching class attribute 'index:' - Find the radio or checkbox using the index in the total collection of the radio or checkbox. (see example below) 'beforetext:' - Find the radio or checkbox before the specified text. 'aftertext:' - Find the radio or checkbox after the specified text.
If there are more than one object having same value for the option you are quering, then it returns first object of the collection.
Typical Usage:
$ie->getRadio('beforetext:', "Option One"); # access the radio which appears before text 'Option One' $ie->getRadio('value:', $radio_value); # access the radio whose value attribute is $radio_value $ie->getCheckbox('aftertext:', "Remember Password"); # access the checkbox which appears after text 'Remember Password' $ie->getCheckbox('index:', 3); # access third checkbox from the collection of checkbox on the current web page
Methods supported for radio or checkbox object
Select()
It selects the specified radio or checkbox, provided it is not already selected.
$ie->getRadio('beforetext:', "Option One")->Select;
deSelect()
It deselects the specified radio or checkbox, provided it is not already deselected.
$ie->getCheckbox('aftertext:', "Remember Password")->deSelect;
getProperty($property)
Retrieves the value of the given property for radio or checkbox object. This makes easy to get value of any property that is supported by html radio or checkbox.
SELECT LIST METHODS
getSelectList($how, $what)
This is the method to access select list on web page. It returns Win32::IEAutomation::Element object containing html select element.
$how : This is the option how you want to access the select list
$what : This is string or integer, what you are looking for. For this, it also supports pattern matching using 'qr' operator of perl (see example below)
Valid options to use for $how:
'id:' - Find the select list by matching id attribute 'name:' - Find the select list by matching name attribute 'class:' - Find the select list by matching class attribute 'index:' - Find the select list using the index in the total collection of the select lists. (see example below) 'beforetext:' - Find the select list before the specified text. 'aftertext:' - Find the select list after the specified text.
If there are more than one object having same value for the option you are quering, then it returns first object of the collection.
Typical Usage:
$ie->getSelectList('aftertext:', "some text"); # access the select list which appears after text 'some text' $ie->getSelectList('name:', 'time_zone'); # access the select list whose name attribute is 'time_zone' $ie->getSelectList('index:', 3); # access third select list from the collection of select lists on the current web page
Methods supported for select list object
SelectItem()
It selects one or more items from the select list. You can pass a single or multiple item to this method. Provide the name of item which is visible to user on web page ( and not that is in html code). Use this method for selection of multiple items only if select list is supporting multiple selection.
$ie->getSelectList('name:', 'time_zone')->SelectItem("India"); # selects one item "India" in the select list $ie->getSelectList('name:', 'time_zone')->SelectItem("India", "U. S. A.", "Australia"); # selects three items "India", "U. S. A." and "Australia" in the select list
deSelectItem()
It deselects one or more items from the select list. You can pass a single or multiple item to this method. Provide the name of item which is visible to user on web page ( and not that is in html code)
$ie->getSelectList('name:', 'time_zone')->deSelectItem("India"); # deselect one item "India" in the select list $ie->getSelectList('name:', 'time_zone')->deSelectItem("India", "U. S. A.", "Australia"); # deselect three items "India", "U. S. A." and "Australia" in the select list
deSelectAll()
It deselects all items from the select list. Call this method without any argument. This method is useful, when a select list appears with a random selected item and you need to deselect that.
$ie->getSelectList('name:', 'time_zone')->deSelectAll(); # deselect all items in the select list
getProperty($property)
Retrieves the value of the given property for select list object. This makes easy to get value of any property that is supported by html select list.
TEXTBOX and TEXTAREA METHODS
getTextBox($how, $what)
This is the method to access input text field on web page. It returns Win32::IEAutomation::Element object containing html input type=text or password element.
getTextArea($how, $what)
This is the method to access input text area on web page. It returns Win32::IEAutomation::Element object containing html textarea element.
$how : This is the option how you want to access the select list
$what : This is string or integer, what you are looking for. For this, it also supports pattern matching using 'qr' operator of perl (see example below)
Valid options to use for $how:
'id:' - Find the text field by matching id attribute 'name:' - Find the text field by matching name attribute 'value:' - Find the text field by matching value attribute 'class:' - Find the text field by matching class attribute 'index:' - Find the text field using the index in the total collection of the text fields. (see example below) 'beforetext:' - Find the text field before the specified text. 'aftertext:' - Find the text field after the specified text.
If there are more than one object having same value for the option you are quering, then it returns first object of the collection.
Typical Usage:
$ie->getSelectList('aftertext:', "User Name:"); # access the text fields which appears after text 'User Name:' $ie->getSelectList('name:', 'password'); # access the text field whose name attribute is 'password' $ie->getSelectList('index:', 3); # access third text field from the collection of text fields on the current web page
Methods supported for text field object
SetValue($string)
It will set the value of text field or text area to the string provided.
$ie->getTextBox('name:', "q")->SetValue("web automation") # it will enter text 'web automation' in the input text filed.
ClearValue()
It will clear the text field.
$ie->getTextBox('name:', "q")->ClearValue() # it will clear the input text field
getProperty($property)
Retrieves the value of the given property for text field object. This makes easy to get value of any property that is supported by html input text field.
FRAME METHOD
getFrame($how, $what)
It will return the Win32::IEAutomation object for frame document. Frame document is having same structure as that of parent IE instance, so all methods for link, button, image, text field etc. are supported on frame object.
$how : This is the option how you want to access the select list
$what : This is string or integer, what you are looking for. For this, it also supports pattern matching using 'qr' operator of perl (see example below)
Valid options to use for $how:
'id:' - Find the frame by matching id attribute 'name:' - Find the frame by matching name attribute 'value:' - Find the frame by matching value attribute 'class:' - Find the frame by matching class attribute
Typical Usage:
$ie->getFrame('id:', "f1"); # access the frame whose id attribute is 'f1' $ie->getFrame('name:', 'groups'); # access the frame whose name attribute is 'groups'
To control any objects under frame, first get the frame object using 'getFrame' method and then use other methods (getLink, getRadio etc.) to access objects.
$ie->getFrame('name:', 'groups')->getRadio('beforetext:', "Option One")->Select; # select the radio which is under frame
There might be case of frame inside frame (nested farmes), so use getFrame method uptp target frame
$ie->getFrame("name:", "first_frame")->getFrame("name:", "nested_frame");
Methods supported for frame object
All methods listed under GENERIC METHODS, LINK METHODS, IMAGE METHODS, BUTTON METHODS, RADIO and CHECKBOX METHODS, SELECT LIST METHODS, TEXTBOX and TEXTAREA METHODS are supported.
POPUP METHOD
getPopupWindow($title)
It will return the Win32::IEAutomation object for popup window. Popup window is having same structure as that of parent IE instance, so all methods for link, button, image, text field etc. are supported on popup object.
Provide the exact title of the popup window as an argument to this method.
Typical Usage:
$ie->getPopupWindow("Popup One"); # access the popup window whose title is "Popup One"
To control any objects under popup, first get the popup object using 'getPopupWindow' method and then use other methods (getLink, getRadio etc.) to access objects.
my $popup = $ie->getPopupWindow("Popup One") # access the popup window $popup->getRadio('beforetext:', "Option One")->Select; # select the radio
There might be case where popup takes time to load its document, so you can use 'WaitforDone' method on popup
my $popup = $ie->getPopupWindow("Popup One") # access the popup window $popup->WaitforDone; # wait so that popup will load its document completly
Methods supported for frame object
All methods listed under GENERIC METHODS, LINK METHODS, IMAGE METHODS, BUTTON METHODS, RADIO and CHECKBOX METHODS, SELECT LIST METHODS, TEXTBOX and TEXTAREA METHODS are supported.
DIALOG HANDLING METHODS
Win32::IEAutomation::WinClicker class provides some methods to ineract with dialogs like security alert, confirmation dialog, logon dialog etc. COM interface to AutoIt (http://www.autoitscript.com/autoit3/) is used to implement these.
You need to create a new instance of Win32::IEAutomation::WinClicker and then use these methods.
Win32::IEAutomation::WinClicker->new()
This will create a new instance of WinClicker class.
push_security_alert_yes($wait_time)
It will push the 'Yes' button of Security Alert dialog box. Provide wait time so that it will wait for Security Alert dialog box to appear. Default value of wait time is 5 seconds (if wait time is not provided). It will timeout after wait time, and execute next line of code.
Typical Usage:
# To navigate to some secure site and pushing 'Yes' button of security alert dialog box use Win32::IEAutomation; use Win32::IEAutomation::WinClicker; # this will provide methods to interact with dialog box my $ie = Win32::IEAutomation->new(); $ie->gotoURL("https://some_secure_site.com", 1); # second argument says that don't wait for complete document loading and allow code to go to next line. my $clicker = Win32::IEAutomation::WinClicker->new(); $clicker->push_security_alert_yes(); $ie->WaitforDone; # we will wait here for complete loading of navigated site
push_confirm_button_ok($title, $wait_time)
It will push the 'OK' button of any confirmation dialog box.
$title: Provide exact title of dialog box
$wait_time: Provide wait time so that it will wait for confirmation dialog box to appear. Default value of wait time is 5 seconds (if wait time is not provided). It will timeout after wait time, and execute next line of code.
push_confirm_button_cancle($wait_time)
It will push the 'Cancle' button of any confirmation dialog box.
$title: Provide exact title of dialog box
$wait_time: Provide wait time so that it will wait for confirmation dialog box to appear. Default value of wait time is 5 seconds (if wait time is not provided). It will timeout after wait time, and execute next line of code.
logon($title, $user, $password, $wait_time)
It will fill the logon dialog box with user name and password, and then press enter.
$title: Provide exact title of logon doalog box
$user: Provide user name to enter
$password: Provide password to enter
$wait_time: Provide wait time so that it will wait for logon dialog box to appear. Default value of wait time is 5 seconds (if wait time is not provided). It will timeout after wait time, and execute next line of code.
Typical Usage:
# To navigate to some authenticated site and pushing 'Yes' button of security alert dialog box use Win32::IEAutomation; use Win32::IEAutomation::WinClicker; # this will provide methods to interact with dialog box my $ie = Win32::IEAutomation->new(); $ie->gotoURL('http://pause.perl.org'); $ie->getLink('linktext:', "Login")->Click(1); # providing no wait argument says that don't wait for complete document loading and allow code to go to next line. my $clicker = Win32::IEAutomation::WinClicker->new(); $clicker->logon("Enter Network Password", $user, $password, $wait_time); $ie->WaitforDone; # we will wait here for complete loading document
AUTHOR
Prashant Shewale <pvshewale@gmail.com>
COPYRIGHT AND LICENSE
This library is free software; you can redistribute it and/or modify it under the same terms as Perl itself.
33 POD Errors
The following errors were encountered while parsing the POD:
- Around line 599:
Expected '=item *'
- Around line 604:
Expected '=item *'
- Around line 689:
Expected '=item *'
- Around line 691:
Expected '=item *'
- Around line 700:
Expected '=item *'
- Around line 704:
Expected '=item *'
- Around line 708:
Expected '=item *'
- Around line 746:
Expected '=item *'
- Around line 748:
Expected '=item *'
- Around line 756:
Expected '=item *'
- Around line 760:
Expected '=item *'
- Around line 793:
Expected '=item *'
- Around line 795:
Expected '=item *'
- Around line 802:
Expected '=item *'
- Around line 843:
Expected '=item *'
- Around line 845:
Expected '=item *'
- Around line 851:
Expected '=item *'
- Around line 857:
Expected '=item *'
- Around line 892:
Expected '=item *'
- Around line 894:
Expected '=item *'
- Around line 903:
Expected '=item *'
- Around line 911:
Expected '=item *'
- Around line 918:
Expected '=item *'
- Around line 958:
Expected '=item *'
- Around line 960:
Expected '=item *'
- Around line 966:
Expected '=item *'
- Around line 972:
Expected '=item *'
- Around line 980:
Unknown directive: =over4
- Around line 982:
'=item' outside of any '=over'
- Around line 1011:
Expected '=item *'
- Around line 1020:
Unknown directive: =over4
- Around line 1022:
'=item' outside of any '=over'
- Around line 1043:
Expected '=item *'