seleniumwrapper
seleniumwrapper copied to clipboard
selenium webdriver wrapper to make manipulation easier.
About this module
selenium webdriver wrapper to make manipulation easier.
.. image:: https://secure.travis-ci.org/keitaoouchi/seleniumwrapper.png .. image:: https://img.shields.io/pypi/dm/seleniumwrapper.svg :target: https://pypi.python.org/pypi//seleniumwrapper/ :alt: Downloads .. image:: https://img.shields.io/pypi/v/seleniumwrapper.svg :target: https://pypi.python.org/pypi/seleniumwrapper/ :alt: Latest Version .. image:: https://img.shields.io/pypi/pyversions/seleniumwrapper.svg :target: https://pypi.python.org/pypi/seleniumwrapper/ :alt: Supported Python versions .. image:: https://img.shields.io/pypi/l/seleniumwrapper.svg :target: https://pypi.python.org/pypi/seleniumwrapper/ :alt: License
Features
- Support Internet Explorer, Chrome, Opera, Firefox, PhantomJS
- Support remote webdriver.
- Easy to type aliases. (find_element_by_xpath => xpath, etc.)
- Wrapped WebdriverWait( ... ).until( ... ) pattern.
- Polling at the time of clicking or selecting.
- Wrapping chaining.
How to install
Requires python2.6 or later. You need pip or distribute or setuptools::
$ pip install seleniumwrapper
or use easy_install::
$ easy_install seleniumwrapper
also you need selenium::
$ pip install selenium
Example to use
create function helps you to init webdriver and wrap it easily::
>>> import seleniumwrapper as selwrap
>>> br = selwrap.create("chrome")
connect function helps you to use remote webdriver and wrap it::
>>> br = connect("android", "http://localhost:9999", {"acceptSslCerts": True})
SeleniumWrapper delegate to its wrapped webdriver::
>>> br.get("http://www.example.com")
<seleniumwrapper.wrapper.SeleniumWrapper object at 0x...>
>>> br.xpath("//div[@class='main'])
<seleniumwrapper.wrapper.SeleniumWrapper object at 0x...>
Setting eager=True to invoke find_elements::
>>> br.xpath("//a", eager=True)
<seleniumwrapper.wrapper.SeleniumContainerWrapper object at 0x...>
SeleniumContainerWrapper also delegate to its wrapped container::
>>> links = [i.get_attribute("href") for i in br.xpath("//a", eager=True)]
Each contents in SeleniumContainerWrapper also SeleniumWrapper::
>>> tds = [tr.xpath("//td", eager=True) for tr in br.xpath("//tr", eager=True)]
Basic API
- seleniumwrapper.create(drivername)
- seleniumwrapper.connect(drivername, executor, custom_capabilities) Create webdriver instance and wrap it with SeleniumWrapper.
SeleniumWrapper ^^^^^^^^^^^^^^^
-
unwrap Retrieves WebDriver or WebElement from wrapped object::
>>> isinstance(br.unwrap, WebElement) True
-
parent find_element_by_xpath("./parent::node()")::
>>> price = br.by_tag("th", "Price").parent.by_tag("td").text
-
performance Returns window.performance wrapped object::
>>> performance = br.performance >>> timing = performance.timing >>> navigation = performance.navigation >>> timing.loadEventEnd 1358319427476
-
to_select Convert wrapped WebElement to raw Select object::
>>> br.by_id('select_button').to_select.select_by_visible_text("hoge")
select method returns the same as below::
>>> br.select(id = 'select_button').select_by_visible_text("hoge")
-
alert Returns Alert(switch_to_alert()) object::
>>> br.alert.accept()
-
current_url Returns current_url after loading page body::
>>> br.current_url
-
timeout Accessor for _timeout property::
>>> br.timeout 5 >>> br.timeout = 10 >>> br.timeout 10
-
silent Accessor for _silent property::
# default >>> br.by_id("Hoge") Traceback (most recent call last): ... NoSuchElementException:... >>> br.silent = True >>> br.by_id("Hoge") is None True
-
attr(name) Shortcut to get_attribute::
>>> br.attr('href')
-
click(timeout=3, presleep=0, postsleep=0) Continue to polling until timeout or element is displayed and clickable::
>>> br.button("Send").click()
-
scroll_to(x, y) equivalent to javascript's scrollTo::
>>> br.scrollTo(0, 100)
-
scroll_by(x, y) equivalent to javascript's scrollBy::
>>> br.scrollBy(10, 10)
-
scroll_into_view(jq_identifier, align_with_top=True) find elements by jq_identifier and retrieve its first element and invoke scrollIntoView to it::
>>> var element = $('#hoge'); >>> element && element.scrollIntoView(true)
second argument is passed as javascript's boolean to scrollIntoView::
>>> br.scrollIntoView('#hoge', False)
-
waitfor(type, target, eager=False, timeout=3) See source::
>>> br.waitfor("xpath", "//input[@type='submit']")
-
xpath(target, eager=False, timeout=3) find_element_by_xpath(target, timeout)::
>>> buttons = br.xpath("//input[@type='submit' or @type='button']", eager=True)
-
css(target, eager=False, timeout=3) find_element_by_css_selector(target, timeout)::
>>> [li.text for li in br.css("ul li")]
-
by_tag(self, tag, eager=False, timeout=3, **attributes) Returns specified tagged element with specified attributes optionally.::
>>> br.by_tag("link", rel="stylesheet")
-
by_text(text, tag='*', partial=False, eager=False, timeout=3) similar to find_element_by_link_text or find_element_by_partial_link_text, but this method can be applicable to any tag::
>>> br.by_text("Go back to Top Page", "a")
-
by_class(target, eager=False, timeout=3) find_element_by_class_name(target, timeout)::
>>> br.by_class("colored")
-
by_id(target, eager=False, timeout=3) find_element_by_id(target, timeout)::
>>> br.by_id("main_contents")
-
by_name(target, eager=False, timeout=3) find_element_by_name(target, timeout)::
>>> br.by_name("page_password")
-
by_linktxt(target, eager=False, timeout=3, partial=False) find_element_by_link_text(target, timeout). if partial=True, then find_element_by_partial_link_text::
>>> br.by_linktxt("Go back to", partial=True)
-
href(partialurl=None, eager=False, timeout=3): find_element_by_xpath("//a", timeout). if partialurl was given, search 'a' tag which href contains partialurl::
>>> phplinks = br.href(".php", eager=True)
-
img(alt=None, ext=None, eager=False, timeout=3) find_elements_by_xpath("//img", timeout)::
>>> br.img(alt="I am sorry", ext="sorry.gif")
-
button(value, eager=False, timeout=3) find_element_by_xpath("//input[@type='submit' or @type='button' and @value='{0}']|.//button[text()='{0}']".format(value), timeout)::
>>> br.button("Send this form").click()
-
checkbox(self, eager=False, timeout=3, **attributes) Returns 'input' element type='checkbox'::
>>> br.checkbox(name='checked_value', id='hoge')
-
radio(self, eager=False, timeout=3, **attributes) Retuns 'input' element type='radio'.::
>>> br.radio(name='hoge', id='fuga').click()
-
select(self, eager=False, timeout=3, **attributes) Returns Select(self.by_tag("select", eager, timeout, **attributes) or their wrapped SeleniumContainerWrapper::
>>> br.select(name="hoge").select_by_index(1) >>> [select.is_multiple for select in br.select(eager=True, name="hoge")]
SeleniumContainerWrapper ^^^^^^^^^^^^^^^^^^^^^^^^
-
size Returns length of wrapped iterable::
>>> br.img(eager=True).size
-
sample(size) Returns random.sample(self._iterable, size)::
>>> br.img(eager=True).sample(10)
-
choice() Returns random.choice(self._iterable)::
>>> br.img(eager=True).choice()
Recent Change
- 0.5.4
- Add support for Python-3.4.
- Fix button to look for
<button>
tag.
- 0.5.3
- Fix README
- 0.5.2
- Add silent mode option.
- 0.5.0
- Support Python3.
- 0.4.3
- Add perfomance, performance.timing, performance.navigation, performance.memory properties.
- 0.4.2
- Add 'PhantomJS' support.
- 0.4.1
- Fixed some bugs.
- 0.4.0
- Added scroll_to, scroll_by, scroll_into_view methods.
- 0.3.5
- Added attr method.
- Fixed some typos.
- 0.3.4
- Added size property to SeleniumContainerWrapper
- Fixed to be able to change default timeout.
- 0.3.3
- Fixed bugs of string formatting.
- 0.3.2
- Changed alert to wait until Alert's text is accesible.
- Override current_url to wait for page body loaded.
- 0.3.1
- Added connect functon.
- 0.3.0
- Changed tag method to by_tag.
- Added checkbox, radio.
- Changed select property to method.
- Added sample, choice methods to SeleniumContainerWrapper.
- Fixed click bug.
- 0.2.4
- Fixed bug.
- 0.2.3
- Added ext argument to img (alt and ext are both optional.)
- 0.2.2
- Added new property alert
- Changed img's argument from ext to alt( find_element_by_xpath("//img[@alt='{}'.format(alt)) )
- Modified SeleniumContainerWrapper's contains behavior to unwrap given object if it is a SeleniumWrapper.