Há algum tempo venho utilizando o Cucumber em um cliente para testar aplicações web feitas em ASP e .NET. Nesse post, vou mostrar como configurar todo o ambiente, mas assumo que você já esteja familiarizado com Cucumber e Webrat. Além dessas duas bibliotecas, precisaremos ainda do Mechanize, uma gem capaz de automaticamente armazenar cookies, fazer redirects, enviar forms, etc; e tudo isso de forma integrada com o Webrat e Cucumber.
Para chegar a solução atual, fiz uma pesquisa em diversos sites, mas mesmo a referência oficial do webrat não funcionava para mim, então acredito que esse post possa beneficiar mais pessoas.
Antes de mais nada, é necessário instalarmos as gems que utilizaremos:
sudo gem install cucumber webrat mechanize
Para começar, vamos criar a estrutura de diretórios necessária:
|teste
|–features – onde ficarão nossas features
|—-step_definition – nossos webrat steps
|—-support – onde ficará nossos arquivos env.rb e paths.rb
Vamos agora configurar nosso arquivo features/support/env.rb:
-
require 'webrat'
-
-
include Webrat::Methods
-
include Webrat::Matchers
-
-
Webrat.configure do |config|
-
config.mode = :mechanize
-
end
-
-
World do
-
Webrat::Session.new(Webrat::MechanizeAdapter.new)
-
end
Crie também o arquivo features/step_definitions/webrat_steps.rb, note que esse arquivo é o mesmo que é gerado quando você utiliza o cucumber em aplicações Rails, mas reproduzi na integra esse arquivo:
-
require File.expand_path(File.join(File.dirname(__FILE__), "..", "support", "paths"))
-
-
# Commonly used webrat steps
-
# http://github.com/brynary/webrat
-
-
Given /^I am on (.+)$/ do |page_name|
-
visit path_to(page_name)
-
end
-
-
When /^I go to (.+)$/ do |page_name|
-
visit path_to(page_name)
-
end
-
-
When /^I press "([^\"]*)"$/ do |button|
-
click_button(button)
-
end
-
-
When /^I follow "([^\"]*)"$/ do |link|
-
click_link(link)
-
end
-
-
When /^I follow "([^\"]*)" within "([^\"]*)"$/ do |link, parent|
-
click_link_within(parent, link)
-
end
-
-
When /^I fill in "([^\"]*)" with "([^\"]*)"$/ do |field, value|
-
fill_in(field, :with => value)
-
end
-
-
When /^I fill in "([^\"]*)" for "([^\"]*)"$/ do |value, field|
-
fill_in(field, :with => value)
-
end
-
-
When /^I fill in the following:$/ do |fields|
-
fields.rows_hash.each do |name, value|
-
When %{I fill in "#{name}" with "#{value}"}
-
end
-
end
-
-
When /^I select "([^\"]*)" from "([^\"]*)"$/ do |value, field|
-
select(value, :from => field)
-
end
-
-
When /^I select "([^\"]*)" as the date and time$/ do |time|
-
select_datetime(time)
-
end
-
-
When /^I select "([^\"]*)" as the "([^\"]*)" date and time$/ do |datetime, datetime_label|
-
select_datetime(datetime, :from => datetime_label)
-
end
-
-
When /^I select "([^\"]*)" as the time$/ do |time|
-
select_time(time)
-
end
-
-
When /^I select "([^\"]*)" as the "([^\"]*)" time$/ do |time, time_label|
-
select_time(time, :from => time_label)
-
end
-
-
When /^I select "([^\"]*)" as the date$/ do |date|
-
select_date(date)
-
end
-
-
When /^I select "([^\"]*)" as the "([^\"]*)" date$/ do |date, date_label|
-
select_date(date, :from => date_label)
-
end
-
-
When /^I check "([^\"]*)"$/ do |field|
-
check(field)
-
end
-
-
When /^I uncheck "([^\"]*)"$/ do |field|
-
uncheck(field)
-
end
-
-
When /^I choose "([^\"]*)"$/ do |field|
-
choose(field)
-
end
-
-
When /^I attach the file at "([^\"]*)" to "([^\"]*)"$/ do |path, field|
-
attach_file(field, path)
-
end
-
-
Then /^I should see "([^\"]*)"$/ do |text|
-
response.should contain(text)
-
end
-
-
Then /^I should see \/([^\/]*)\/$/ do |regexp|
-
regexp = Regexp.new(regexp)
-
response.should contain(regexp)
-
end
-
-
Then /^I should not see "([^\"]*)"$/ do |text|
-
response.should_not contain(text)
-
end
-
-
Then /^I should not see \/([^\/]*)\/$/ do |regexp|
-
regexp = Regexp.new(regexp)
-
response.should_not contain(regexp)
-
end
-
-
Then /^the "([^\"]*)" field should contain "([^\"]*)"$/ do |field, value|
-
field_labeled(field).value.should =~ /#{value}/
-
end
-
-
Then /^the "([^\"]*)" field should not contain "([^\"]*)"$/ do |field, value|
-
field_labeled(field).value.should_not =~ /#{value}/
-
end
-
-
Then /^the "([^\"]*)" checkbox should be checked$/ do |label|
-
field_labeled(label).should be_checked
-
end
-
-
Then /^the "([^\"]*)" checkbox should not be checked$/ do |label|
-
field_labeled(label).should_not be_checked
-
end
-
-
Then /^I should be on (.+)$/ do |page_name|
-
URI.parse(current_url).path.should == path_to(page_name)
-
end
-
-
Then /^show me the page$/ do
-
save_and_open_page
-
end
Ainda precisamos criar nosso arquivo /features/support/paths.rb, que será responsável pelo mapeamento dos sites que iremos testar:
-
module NavigationHelpers
-
# Maps a name to a path. Used by the
-
#
-
# When /^I go to (.+)$/ do |page_name|
-
#
-
# step definition in webrat_steps.rb
-
#
-
def path_to(page_name)
-
case page_name
-
-
when /google/ # poderia ser minha_app
-
'http://www.google.com' # e http://localhost:8080/minha_app
-
else
-
raise "Can't find mapping from \"#{page_name}\" to a path.\n" +
-
"Now, go and add a mapping in #{__FILE__}"
-
end
-
end
-
end
-
-
World(NavigationHelpers)
Agora só falta criarmos nosso teste. Crie o arquivo features/teste.feature:
-
Feature: Testing
-
In order to value
-
As a role
-
I want feature
-
-
Scenario: google
-
Given I am on google
-
When I fill in "q" with "java são paulo curso"
-
And I press "Pesquisa Google"
-
Then I should see "Caelum"
Agora basta executarmos nosso teste com o comando
cucumber
Cauê, excelente o seu artigo! Muito bom mesmo!
Quero começar a usar BDD em uns projetos. Fiz alguns testes com o phpspec, mas sinceramente, achei ele ruim.
Estranho pelo menos.
Você acha que seria possível integrar isso a uma aplicação feita em php?
Vou seguir o artigo e tentar testar uma aplicação feita em php. Posto aqui se deu certo.
Meus parabéns pelo artigo!
[]’s
Comment by Walter — February 25, 2010 @ 12:55 AM
Oi Walter
Obrigado pelo feedback! Sem duvida alguma deve funcionar, espero por noticias
Comment by caueguerra — March 25, 2010 @ 4:16 AM
Muito legal!
Em vez de webrat, daria pra fazer usando selenium?
Abraços
Comment by Rafael Scremin — May 19, 2010 @ 4:56 PM