Class: Watir::Frame

Inherits:
HTMLElement show all
Defined in:
lib/watir-webdriver/elements/frame.rb,
lib/watir-webdriver/elements/generated.rb

Constant Summary

Constants included from AttributeHelper

AttributeHelper::IGNORED_ATTRIBUTES

Constants included from Atoms

Atoms::ATOMS

Instance Method Summary collapse

Methods inherited from Element

#==, #attribute_value, #browser, #click, #double_click, #drag_and_drop_by, #drag_and_drop_on, #driver, #exists?, #fire_event, #flash, #focus, #focused?, #hash, #hover, #initialize, #inspect, #parent, #present?, #right_click, #run_checkers, #select_text, #send_keys, #style, #tag_name, #text, #to_subtype, #value, #visible?, #wd

Methods included from AttributeHelper

#attributes, #typed_attributes

Methods included from EventuallyPresent

#wait_until_present, #wait_while_present, #when_present

Methods included from Container

#a, #abbr, #abbrs, #address, #addresses, #area, #areas, #article, #articles, #as, #aside, #asides, #audio, #audios, #b, #base, #bases, #bdi, #bdis, #bdo, #bdos, #blockquote, #blockquotes, #body, #bodys, #br, #brs, #bs, #button, #buttons, #canvas, #canvases, #caption, #captions, #checkbox, #checkboxes, #cite, #cites, #code, #codes, #col, #colgroup, #colgroups, #cols, #command, #commands, #data, #datalist, #datalists, #dd, #dds, #del, #dels, #details, #detailses, #dfn, #dfns, #div, #divs, #dl, #dls, #dt, #dts, #element, #elements, #em, #embed, #embeds, #ems, #extract_selector, #field_set, #field_sets, #fieldset, #fieldsets, #figcaption, #figcaptions, #figure, #figures, #file_field, #file_fields, #font, #fonts, #footer, #footers, #form, #forms, #frame, #frames, #frameset, #framesets, #h1, #h1s, #h2, #h2s, #h3, #h3s, #h4, #h4s, #h5, #h5s, #h6, #h6s, #head, #header, #headers, #heads, #hgroup, #hgroups, #hidden, #hiddens, #hr, #hrs, #htmls, #i, #iframe, #iframes, #image, #images, #img, #imgs, #input, #inputs, #ins, #inses, #is, #kbd, #kbds, #keygen, #keygens, #label, #labels, #legend, #legends, #li, #link, #links, #lis, #map, #maps, #mark, #marks, #menu, #menus, #meta, #metas, #meter, #meters, #nav, #navs, #noscript, #noscripts, #object, #objects, #ol, #ols, #optgroup, #optgroups, #option, #options, #output, #outputs, #p, #param, #params, #pre, #pres, #progress, #progresses, #ps, #q, #qs, #radio, #radios, #rp, #rps, #rt, #rts, #rubies, #ruby, #s, #samp, #samps, #script, #scripts, #section, #sections, #select, #select_list, #select_lists, #selects, #small, #smalls, #source, #sources, #span, #spans, #ss, #strong, #strongs, #style, #styles, #sub, #subs, #summaries, #summary, #sup, #sups, #table, #tables, #tbody, #tbodys, #td, #tds, #text_field, #text_fields, #textarea, #textareas, #tfoot, #tfoots, #th, #thead, #theads, #ths, #time, #times, #title, #titles, #tr, #track, #tracks, #trs, #u, #ul, #uls, #us, #var, #vars, #video, #videos, #wbr, #wbrs

Methods included from Atoms

load

Methods included from XpathSupport

escape

Constructor Details

This class inherits a constructor from Watir::Element

Dynamic Method Handling

This class handles dynamic methods through the method_missing method in the class Watir::Element

Instance Method Details

#assert_existsObject



16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
# File 'lib/watir-webdriver/elements/frame.rb', line 16

def assert_exists
  if @selector.has_key? :element
    raise UnknownFrameException, "wrapping a WebDriver element as a Frame is not currently supported"
  end

  if @element && !Watir.always_locate?
    begin
      @element.tag_name # rpc
      return @element
    rescue Selenium::WebDriver::Error::ObsoleteElementError
      @element = nil # re-locate
    end
  end

  super
end

#element_by_xpath(*args) ⇒ Object



45
46
47
48
# File 'lib/watir-webdriver/elements/frame.rb', line 45

def element_by_xpath(*args)
  assert_exists
  super
end

#elements_by_xpath(*args) ⇒ Object



50
51
52
53
# File 'lib/watir-webdriver/elements/frame.rb', line 50

def elements_by_xpath(*args)
  assert_exists
  super
end

#execute_script(*args) ⇒ Object



41
42
43
# File 'lib/watir-webdriver/elements/frame.rb', line 41

def execute_script(*args)
  browser.execute_script(*args)
end

#htmlObject



33
34
35
36
37
38
39
# File 'lib/watir-webdriver/elements/frame.rb', line 33

def html
  assert_exists

  # this will actually give us the innerHTML instead of the outerHTML of the <frame>,
  # but given the choice this seems more useful
  execute_atom(:getOuterHtml, @element.find_element(:tag_name => "html")).strip
end

#locateObject



5
6
7
8
9
10
11
12
13
14
# File 'lib/watir-webdriver/elements/frame.rb', line 5

def locate
  @parent.assert_exists

  element = locate_iframe || locate_frame
  element or raise UnknownFrameException, "unable to locate frame/iframe using #{selector_string}"

  @parent.reset!

  FramedDriver.new(element, driver)
end