From eadbdeca412d812f530fc5783f2eecec06a587ed Mon Sep 17 00:00:00 2001 From: Thomas Walpole Date: Wed, 1 May 2019 09:56:08 -0700 Subject: [PATCH] Expand `click_on` beyond just an alias of `click_link_or_button` --- lib/capybara/node/actions.rb | 26 +++++++++++++++++++++++++- 1 file changed, 25 insertions(+), 1 deletion(-) diff --git a/lib/capybara/node/actions.rb b/lib/capybara/node/actions.rb index c50168f11..ec6339638 100644 --- a/lib/capybara/node/actions.rb +++ b/lib/capybara/node/actions.rb @@ -24,7 +24,31 @@ module Actions def click_link_or_button(locator = nil, **options) find(:link_or_button, locator, options).click end - alias_method :click_on, :click_link_or_button + + ## + # + # Finds an element and clicks on it + # + # By default this is an alias of {Capybara::Node::Actions#click_llink_or_button} + # @overload click_on([locator], **options) + # By default this is an alias of {Capybara::Node::Actions#click_link_or_button} + # @macro waiting_behavior + # @param [String] locator See {Capybara::Node::Actions#click_button} and {Capybara::Node::Actions#click_link} + # + # @overload click_on(selector, [locator], **options) + # @macro waiting_behavior + # @param [Symbol] symbol A registered selector type (:css, :xpath, :element, ...) See {Capybara::Selector} for built-in selectors. + # @param [String] locator See {Capybara::Selector} for locator specifics + # + # @return [Capybara::Node::Element] The element clicked + # + def click_on(*args, **options) + if args[0].is_a?(Symbol) + find(*args, **options).click + else + click_link_or_button(*args, **options) + end + end ## #