Class: Appium::Core::Element
- Inherits:
-
Selenium::WebDriver::Element
- Object
- Selenium::WebDriver::Element
- Appium::Core::Element
- Includes:
- Base::TakesScreenshot
- Defined in:
- lib/appium_lib_core/element.rb
Overview
Implement useful features for element. Patch for Selenium Webdriver.
Instance Attribute Summary collapse
-
#id ⇒ String
readonly
Retuns the element id.
Instance Method Summary collapse
-
#location_rel(driver) ⇒ ::Selenium::WebDriver::Point
For use with location_rel.
-
#method_missing(method_name, *args, &block) ⇒ String
Returns the value of attributes like below.
- #respond_to_missing? ⇒ Boolean
-
#save_screenshot(png_path) ⇒ File
Save an element screenshot to the given path.
-
#screenshot ⇒ Object
Return an element screenshot as base64.
-
#screenshot_as(format) ⇒ Object
Return an element screenshot in the given format.
Methods included from Base::TakesScreenshot
#element_screenshot_as, #save_element_screenshot, #save_viewport_screenshot
Dynamic Method Handling
This class handles dynamic methods through the method_missing method
#method_missing(method_name, *args, &block) ⇒ String
Returns the value of attributes like below. Read each platform to know more details.
checkable, checked, class, clickable, content-desc, enabled, focusable, focused
long-clickable, package, password, resource-id, scrollable, selection-start, selection-end
selected, text, bounds, index
XCUITest automation name supports below attributes.
UID, accessibilityContainer, accessible, enabled, frame,
label, name, rect, type, value, visible, wdAccessibilityContainer,
wdAccessible, wdEnabled, wdFrame, wdLabel, wdName, wdRect, wdType,
wdUID, wdValue, wdVisible
54 55 56 57 58 59 |
# File 'lib/appium_lib_core/element.rb', line 54 def method_missing(method_name, *args, &block) ignore_list = [:to_hash] return if ignore_list.include? method_name respond_to?(method_name) ? attribute(method_name.to_s.tr('_', '-')) : super end |
Instance Attribute Details
#id ⇒ String (readonly)
Retuns the element id.
31 32 33 |
# File 'lib/appium_lib_core/element.rb', line 31 def id @id end |
Instance Method Details
#location_rel(driver) ⇒ ::Selenium::WebDriver::Point
For use with location_rel.
77 78 79 80 81 82 83 84 85 86 87 88 89 90 |
# File 'lib/appium_lib_core/element.rb', line 77 def location_rel(driver) rect = self.rect location_x = rect.x.to_f location_y = rect.y.to_f size_width = rect.width.to_f size_height = rect.height.to_f center_x = location_x + (size_width / 2.0) center_y = location_y + (size_height / 2.0) w = driver.window_size ::Selenium::WebDriver::Point.new "#{center_x} / #{w.width.to_f}", "#{center_y} / #{w.height.to_f}" end |
#respond_to_missing? ⇒ Boolean
61 62 63 |
# File 'lib/appium_lib_core/element.rb', line 61 def respond_to_missing?(*) true end |
#save_screenshot(png_path) ⇒ File
Save an element screenshot to the given path
133 134 135 136 137 138 139 140 |
# File 'lib/appium_lib_core/element.rb', line 133 def save_screenshot(png_path) extension = File.extname(png_path).downcase if extension != '.png' ::Appium::Logger.warn 'name used for saved screenshot does not match file type. ' \ 'It should end with .png extension' end File.open(png_path, 'wb') { |f| f << screenshot_as(:png) } end |
#screenshot ⇒ Object
Return an element screenshot as base64
100 101 102 |
# File 'lib/appium_lib_core/element.rb', line 100 def screenshot bridge.element_screenshot @id end |
#screenshot_as(format) ⇒ Object
Return an element screenshot in the given format
113 114 115 116 117 118 119 120 121 122 |
# File 'lib/appium_lib_core/element.rb', line 113 def screenshot_as(format) case format when :base64 bridge.element_screenshot @id when :png bridge.element_screenshot(@id).unpack('m')[0] else raise Core::Error::UnsupportedOperationError, "unsupported format: #{format.inspect}" end end |