Skip to content

Instantly share code, notes, and snippets.

@williamn
Created September 27, 2011 08:51
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save williamn/1244632 to your computer and use it in GitHub Desktop.
Save williamn/1244632 to your computer and use it in GitHub Desktop.
Cucumber-Rails built in steps in Bahasa Indonesia
# TL;DR: YOU SHOULD DELETE THIS FILE
#
# This file was generated by Cucumber-Rails and is only here to get you a head start
# These step definitions are thin wrappers around the Capybara/Webrat API that lets you
# visit pages, interact with widgets and make assertions about page content.
#
# If you use these step definitions as basis for your features you will quickly end up
# with features that are:
#
# * Hard to maintain
# * Verbose to read
#
# A much better approach is to write your own higher level step definitions, following
# the advice in the following blog posts:
#
# * http://benmabey.com/2008/05/19/imperative-vs-declarative-scenarios-in-user-stories.html
# * http://dannorth.net/2011/01/31/whose-domain-is-it-anyway/
# * http://elabs.se/blog/15-you-re-cuking-it-wrong
#
require 'uri'
require 'cgi'
require File.expand_path(File.join(File.dirname(__FILE__), "..", "support", "paths"))
require File.expand_path(File.join(File.dirname(__FILE__), "..", "support", "selectors"))
module WithinHelpers
def with_scope(locator)
locator ? within(*selector_for(locator)) { yield } : yield
end
end
World(WithinHelpers)
# Single-line step scoper
Ketika /^(.*) di dalam (.*[^:])$/ do |step, parent|
with_scope(parent) { Ketika step }
end
# Multi-line step scoper
Ketika /^(.*) di dalam (.*[^:]):$/ do |step, parent, table_or_string|
with_scope(parent) { Ketika "#{step}:", table_or_string }
end
Dengan /^(?:|saya )berada di (.+)$/ do |page_name|
visit path_to(page_name)
end
Ketika /^(?:|saya )berkunjung ke (.+)$/ do |page_name|
visit path_to(page_name)
end
Ketika /^(?:|saya )menekan "([^"]*)"$/ do |button|
click_button(button)
end
Ketika /^(?:|saya )klik "([^"]*)"$/ do |link|
click_link(link)
end
Ketika /^(?:|saya )mengisi "([^"]*)" dengan "([^"]*)"$/ do |field, value|
fill_in(field, :with => value)
end
Ketika /^(?:|saya )isikan "([^"]*)" untuk "([^"]*)"$/ do |value, field|
fill_in(field, :with => value)
end
# Use this to fill in an entire form with data from a table. Example:
#
# When I fill in the following:
# | Account Number | 5002 |
# | Expiry date | 2009-11-01 |
# | Note | Nice guy |
# | Wants Email? | |
#
# TODO: Add support for checkbox, select or option
# based on naming conventions.
#
Ketika /^(?:|saya )isikan yang berikut ini:$/ do |fields|
fields.rows_hash.each do |name, value|
Ketika %{I fill in "#{name}" with "#{value}"}
end
end
Ketika /^(?:|saya )memilih "([^"]*)" dari "([^"]*)"$/ do |value, field|
select(value, :from => field)
end
Ketika /^(?:|saya )mencentang "([^"]*)"$/ do |field|
check(field)
end
Ketika /^(?:|saya )menghapus centang "([^"]*)"$/ do |field|
uncheck(field)
end
Ketika /^(?:|saya )memilih "([^"]*)"$/ do |field|
choose(field)
end
Ketika /^(?:|saya )melampirkan berkas "([^"]*)" ke "([^"]*)"$/ do |path, field|
attach_file(field, File.expand_path(path))
end
Maka /^(?:|saya )seharusnya melihat "([^"]*)"$/ do |text|
if page.respond_to? :should
page.should have_content(text)
else
assert page.has_content?(text)
end
end
Maka /^(?:|saya )seharusnya melihat \/([^\/]*)\/$/ do |regexp|
regexp = Regexp.new(regexp)
if page.respond_to? :should
page.should have_xpath('//*', :text => regexp)
else
assert page.has_xpath?('//*', :text => regexp)
end
end
Maka /^(?:|saya )seharusnya tidak melihat "([^"]*)"$/ do |text|
if page.respond_to? :should
page.should have_no_content(text)
else
assert page.has_no_content?(text)
end
end
Maka /^(?:|saya )seharusnya tidak melihat \/([^\/]*)\/$/ do |regexp|
regexp = Regexp.new(regexp)
if page.respond_to? :should
page.should have_no_xpath('//*', :text => regexp)
else
assert page.has_no_xpath?('//*', :text => regexp)
end
end
Maka /^field "([^"]*)" (?: di dalam (.*))? seharusnya memuat "([^"]*)"$/ do |field, parent, value|
with_scope(parent) do
field = find_field(field)
field_value = (field.tag_name == 'textarea') ? field.text : field.value
if field_value.respond_to? :should
field_value.should =~ /#{value}/
else
assert_match(/#{value}/, field_value)
end
end
end
Maka /^field "([^"]*)" (?: di dalam (.*))? seharusnya tidak memuat "([^"]*)"$/ do |field, parent, value|
with_scope(parent) do
field = find_field(field)
field_value = (field.tag_name == 'textarea') ? field.text : field.value
if field_value.respond_to? :should_not
field_value.should_not =~ /#{value}/
else
assert_no_match(/#{value}/, field_value)
end
end
end
Maka /^field "([^"]*)" seharusnya memuat error "([^"]*)"$/ do |field, error_message|
element = find_field(field)
classes = element.find(:xpath, '..')[:class].split(' ')
form_for_input = element.find(:xpath, 'ancestor::form[1]')
using_formtastic = form_for_input[:class].include?('formtastic')
error_class = using_formtastic ? 'error' : 'field_with_errors'
if classes.respond_to? :should
classes.should include(error_class)
else
assert classes.include?(error_class)
end
if page.respond_to?(:should)
if using_formtastic
error_paragraph = element.find(:xpath, '../*[@class="inline-errors"][1]')
error_paragraph.should have_content(error_message)
else
page.should have_content("#{field.titlecase} #{error_message}")
end
else
if using_formtastic
error_paragraph = element.find(:xpath, '../*[@class="inline-errors"][1]')
assert error_paragraph.has_content?(error_message)
else
assert page.has_content?("#{field.titlecase} #{error_message}")
end
end
end
Maka /^field "([^"]*)" seharusnya tidak memuat error$/ do |field|
element = find_field(field)
classes = element.find(:xpath, '..')[:class].split(' ')
if classes.respond_to? :should
classes.should_not include('field_with_errors')
classes.should_not include('error')
else
assert !classes.include?('field_with_errors')
assert !classes.include?('error')
end
end
Maka /^checkbox "([^"]*)" (?: di dalam (.*))? seharusnya tercentang$/ do |label, parent|
with_scope(parent) do
field_checked = find_field(label)['checked']
if field_checked.respond_to? :should
field_checked.should be_true
else
assert field_checked
end
end
end
Maka /^checkbox "([^"]*)" (?: di dalam (.*))? seharusnya tidak tercentang$/ do |label, parent|
with_scope(parent) do
field_checked = find_field(label)['checked']
if field_checked.respond_to? :should
field_checked.should be_false
else
assert !field_checked
end
end
end
Maka /^(?:|saya )seharusnya berada di (.+)$/ do |page_name|
current_path = URI.parse(current_url).path
if current_path.respond_to? :should
current_path.should == path_to(page_name)
else
assert_equal path_to(page_name), current_path
end
end
Maka /^(?:|saya )seharusnya mempunyai string query berikut ini:$/ do |expected_pairs|
query = URI.parse(current_url).query
actual_params = query ? CGI.parse(query) : {}
expected_params = {}
expected_pairs.rows_hash.each_pair{|k,v| expected_params[k] = v.split(',')}
if actual_params.respond_to? :should
actual_params.should == expected_params
else
assert_equal expected_params, actual_params
end
end
Maka /^tunjukan halamannya kepada saya$/ do
save_and_open_page
end
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment