2010-07-09 20:20:32 -04:00
|
|
|
module Capybara
|
2010-11-21 08:37:36 -05:00
|
|
|
module Node
|
2010-07-09 20:20:32 -04:00
|
|
|
module Actions
|
2010-07-17 10:03:46 -04:00
|
|
|
|
|
|
|
##
|
|
|
|
#
|
|
|
|
# Finds a button or link by id, text or value and clicks it. Also looks at image
|
|
|
|
# alt text inside the link.
|
|
|
|
#
|
|
|
|
# @param [String] locator Text, id or value of link or button
|
|
|
|
#
|
2013-02-24 10:28:48 -05:00
|
|
|
def click_link_or_button(locator, options={})
|
|
|
|
find(:link_or_button, locator, options).click
|
2010-07-09 20:20:32 -04:00
|
|
|
end
|
2010-10-29 07:41:49 -04:00
|
|
|
alias_method :click_on, :click_link_or_button
|
2010-07-09 20:20:32 -04:00
|
|
|
|
2010-07-17 10:03:46 -04:00
|
|
|
##
|
|
|
|
#
|
|
|
|
# Finds a link by id or text and clicks it. Also looks at image
|
|
|
|
# alt text inside the link.
|
|
|
|
#
|
|
|
|
# @param [String] locator Text, id or text of link
|
2013-02-19 15:12:54 -05:00
|
|
|
# @param options
|
|
|
|
# @option options [String] :href The value the href attribute must be
|
2010-07-17 10:03:46 -04:00
|
|
|
#
|
2013-02-19 15:12:54 -05:00
|
|
|
def click_link(locator, options={})
|
|
|
|
find(:link, locator, options).click
|
2010-07-09 20:20:32 -04:00
|
|
|
end
|
|
|
|
|
2010-07-17 10:03:46 -04:00
|
|
|
##
|
|
|
|
#
|
|
|
|
# Finds a button by id, text or value and clicks it.
|
|
|
|
#
|
|
|
|
# @param [String] locator Text, id or value of button
|
|
|
|
#
|
2013-02-24 10:36:08 -05:00
|
|
|
def click_button(locator, options={})
|
|
|
|
find(:button, locator, options).click
|
2010-07-09 20:20:32 -04:00
|
|
|
end
|
|
|
|
|
2010-07-17 10:03:46 -04:00
|
|
|
##
|
|
|
|
#
|
|
|
|
# Locate a text field or text area and fill it in with the given text
|
|
|
|
# The field can be found via its name, id or label text.
|
|
|
|
#
|
|
|
|
# page.fill_in 'Name', :with => 'Bob'
|
|
|
|
#
|
|
|
|
# @param [String] locator Which field to fill in
|
|
|
|
# @param [Hash{:with => String}] The value to fill in
|
|
|
|
#
|
2010-07-09 20:20:32 -04:00
|
|
|
def fill_in(locator, options={})
|
|
|
|
raise "Must pass a hash containing 'with'" if not options.is_a?(Hash) or not options.has_key?(:with)
|
2013-02-24 10:41:20 -05:00
|
|
|
with = options.delete(:with)
|
|
|
|
find(:fillable_field, locator, options).set(with)
|
2010-07-09 20:20:32 -04:00
|
|
|
end
|
|
|
|
|
2010-07-17 10:03:46 -04:00
|
|
|
##
|
|
|
|
#
|
|
|
|
# Find a radio button and mark it as checked. The radio button can be found
|
|
|
|
# via name, id or label text.
|
|
|
|
#
|
|
|
|
# page.choose('Male')
|
|
|
|
#
|
|
|
|
# @param [String] locator Which radio button to choose
|
|
|
|
#
|
2013-02-24 10:48:14 -05:00
|
|
|
def choose(locator, options={})
|
|
|
|
find(:radio_button, locator, options).set(true)
|
2010-07-09 20:20:32 -04:00
|
|
|
end
|
|
|
|
|
2010-07-17 10:03:46 -04:00
|
|
|
##
|
|
|
|
#
|
|
|
|
# Find a check box and mark it as checked. The check box can be found
|
|
|
|
# via name, id or label text.
|
|
|
|
#
|
|
|
|
# page.check('German')
|
|
|
|
#
|
|
|
|
# @param [String] locator Which check box to check
|
|
|
|
#
|
2013-02-24 10:48:25 -05:00
|
|
|
def check(locator, options={})
|
|
|
|
find(:checkbox, locator, options).set(true)
|
2010-07-09 20:20:32 -04:00
|
|
|
end
|
|
|
|
|
2010-07-17 10:03:46 -04:00
|
|
|
##
|
|
|
|
#
|
|
|
|
# Find a check box and mark uncheck it. The check box can be found
|
|
|
|
# via name, id or label text.
|
|
|
|
#
|
|
|
|
# page.uncheck('German')
|
|
|
|
#
|
|
|
|
# @param [String] locator Which check box to uncheck
|
|
|
|
#
|
2013-02-24 10:48:33 -05:00
|
|
|
def uncheck(locator, options={})
|
|
|
|
find(:checkbox, locator, options).set(false)
|
2010-07-09 20:20:32 -04:00
|
|
|
end
|
|
|
|
|
2010-07-17 10:03:46 -04:00
|
|
|
##
|
|
|
|
#
|
|
|
|
# Find a select box on the page and select a particular option from it. If the select
|
|
|
|
# box is a multiple select, +select+ can be called multiple times to select more than
|
|
|
|
# one option. The select box can be found via its name, id or label text.
|
|
|
|
#
|
2010-12-08 16:37:22 -05:00
|
|
|
# page.select 'March', :from => 'Month'
|
2010-07-17 10:03:46 -04:00
|
|
|
#
|
2011-04-07 15:43:30 -04:00
|
|
|
# @param [String] value Which option to select
|
2010-12-08 16:37:22 -05:00
|
|
|
# @param [Hash{:from => String}] The id, name or label of the select box
|
2010-07-17 10:03:46 -04:00
|
|
|
#
|
2010-07-09 20:20:32 -04:00
|
|
|
def select(value, options={})
|
2010-10-03 13:15:40 -04:00
|
|
|
if options.has_key?(:from)
|
2013-02-24 10:58:46 -05:00
|
|
|
from = options.delete(:from)
|
|
|
|
find(:select, from, options).find(:option, value, options).select_option
|
2010-10-03 13:15:40 -04:00
|
|
|
else
|
2013-02-24 10:58:46 -05:00
|
|
|
find(:option, value, options).select_option
|
2010-10-03 13:15:40 -04:00
|
|
|
end
|
2010-07-09 20:20:32 -04:00
|
|
|
end
|
|
|
|
|
2010-07-17 10:03:46 -04:00
|
|
|
##
|
|
|
|
#
|
2011-04-07 15:43:30 -04:00
|
|
|
# Find a select box on the page and unselect a particular option from it. If the select
|
|
|
|
# box is a multiple select, +unselect+ can be called multiple times to unselect more than
|
2010-07-17 10:03:46 -04:00
|
|
|
# one option. The select box can be found via its name, id or label text.
|
|
|
|
#
|
2011-04-07 15:43:30 -04:00
|
|
|
# page.unselect 'March', :from => 'Month'
|
2010-07-17 10:03:46 -04:00
|
|
|
#
|
2011-04-07 15:43:30 -04:00
|
|
|
# @param [String] value Which option to unselect
|
|
|
|
# @param [Hash{:from => String}] The id, name or label of the select box
|
2010-07-17 10:03:46 -04:00
|
|
|
#
|
2010-07-09 20:20:32 -04:00
|
|
|
def unselect(value, options={})
|
2010-10-03 13:15:40 -04:00
|
|
|
if options.has_key?(:from)
|
2013-02-24 11:03:12 -05:00
|
|
|
from = options.delete(:from)
|
|
|
|
find(:select, from, options).find(:option, value, options).unselect_option
|
2010-10-03 13:15:40 -04:00
|
|
|
else
|
2013-02-24 11:03:12 -05:00
|
|
|
find(:option, value, options).unselect_option
|
2010-10-03 13:15:40 -04:00
|
|
|
end
|
2010-07-09 20:20:32 -04:00
|
|
|
end
|
|
|
|
|
2010-07-17 10:03:46 -04:00
|
|
|
##
|
|
|
|
#
|
|
|
|
# Find a file field on the page and attach a file given its path. The file field can
|
|
|
|
# be found via its name, id or label text.
|
|
|
|
#
|
|
|
|
# page.attach_file(locator, '/path/to/file.png')
|
|
|
|
#
|
|
|
|
# @param [String] locator Which field to attach the file to
|
2012-09-17 08:48:13 -04:00
|
|
|
# @param [String] path The path of the file that will be attached, or an array of paths
|
2010-07-17 10:03:46 -04:00
|
|
|
#
|
2013-02-24 11:06:01 -05:00
|
|
|
def attach_file(locator, path, options={})
|
2012-11-20 16:51:25 -05:00
|
|
|
Array(path).each do |p|
|
2012-09-17 08:48:13 -04:00
|
|
|
raise Capybara::FileNotFound, "cannot attach file, #{p} does not exist" unless File.exist?(p.to_s)
|
|
|
|
end
|
2013-02-24 11:06:01 -05:00
|
|
|
find(:file_field, locator, options).set(path)
|
2010-07-09 20:20:32 -04:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|