No commit activity in last 3 years
No release in over a year
Automatically instantiates custom HTML tag names into watir-webdriver and\or page-object gem.
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
2025
 Dependencies

Runtime

 Project Readme

watir-customize_elements

The purpose of this gem is to enable Watir and page-object gem to work with custom, non-standard HTML element tag names.

While Watir and the page-object gem do not support non-standard HTML tags, we encountered many cases in our testing when we needed to use such elements. Although it's possible to register custom elements with PageObject via widgets, and to add support for it in Watir, the process of doing so for each custom element got tedious. That's why we created this gem. It automatically instantiates custom HTML tag names into watir and/or page-object gem from a few lines in a simple yml file.

Installation

Add this line to your application's Gemfile:

gem 'watir-customize_elements'

And then execute:

$ bundle

Or install it yourself as:

$ gem install watir-customize_elements

Usage

  • Create a yml file (call it whatever you like), and include the name and path as an env argument named CUSTOM_ELEMENTS_CONFIG_PATH. See explanation at the end of this section
  • Require watir-customize_elements after requiring watir and/or page-object.
  • If you don't want to pass ENV[CUSTOM_ELEMENTS_CONFIG_PATH] from the command line, set it before requiring watir-customize_elements
require 'watir'
require 'page-object'
ENV['CUSTOM_ELEMENTS_CONFIG_PATH'] = 'path\to\custom_elements_file.yml'
require 'watir-customize_elements'

yml file

The yml file should include two parts: modules and elements

modules:
  watir: true
  page_object: true
elements:
  element_name:
    element_collection: element_names
    element_class: ElementName
    element_type: CheckBox
  mh_button:
    element_collection: mh_buttons
    element_class: MHButton
    element_type: Button
Modules

Determines which gem to interact with. Configure according to your setup.

Elements section explained:
  • element_name - This is the exact name of the tag type, with underscores instead of dashes
  • element_collection - This is the name of the element name, but pluralized. element-name would be element_name
  • element_class - This is the element name in class form. mh-checkbox would be MHCheckBox.
  • element_type- This is the PageObject element type (found here: http://bit.ly/1TNEtal). This will give your custom element the same type of attribute as its native HTML element type (ex: mh-checkbox with a type of CheckBox is treated by PageObject as a true HTML checkbox). If there isn't a matching type, choose Element.

You can find an example of a complete yml file here