opsb-email_spec 0.6.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- data/History.txt +199 -0
- data/MIT-LICENSE.txt +19 -0
- data/README.rdoc +135 -0
- data/Rakefile +77 -0
- data/examples/rails_root/Rakefile +13 -0
- data/examples/rails_root/app/controllers/application_controller.rb +15 -0
- data/examples/rails_root/app/controllers/welcome_controller.rb +16 -0
- data/examples/rails_root/app/helpers/application_helper.rb +3 -0
- data/examples/rails_root/app/helpers/welcome_helper.rb +2 -0
- data/examples/rails_root/app/models/user.rb +2 -0
- data/examples/rails_root/app/models/user_mailer.rb +39 -0
- data/examples/rails_root/app/views/user_mailer/attachments.erb +6 -0
- data/examples/rails_root/app/views/user_mailer/newsletter.erb +8 -0
- data/examples/rails_root/app/views/user_mailer/signup.erb +3 -0
- data/examples/rails_root/app/views/welcome/attachments.html.erb +0 -0
- data/examples/rails_root/app/views/welcome/confirm.html.erb +1 -0
- data/examples/rails_root/app/views/welcome/index.html.erb +8 -0
- data/examples/rails_root/app/views/welcome/newsletter.html.erb +0 -0
- data/examples/rails_root/app/views/welcome/signup.html.erb +1 -0
- data/examples/rails_root/attachments/document.pdf +0 -0
- data/examples/rails_root/attachments/image.png +0 -0
- data/examples/rails_root/config/boot.rb +110 -0
- data/examples/rails_root/config/cucumber.yml +7 -0
- data/examples/rails_root/config/database.yml +25 -0
- data/examples/rails_root/config/environment.rb +28 -0
- data/examples/rails_root/config/environments/cucumber.rb +29 -0
- data/examples/rails_root/config/environments/development.rb +17 -0
- data/examples/rails_root/config/environments/production.rb +28 -0
- data/examples/rails_root/config/environments/test.rb +28 -0
- data/examples/rails_root/config/initializers/inflections.rb +10 -0
- data/examples/rails_root/config/initializers/mime_types.rb +5 -0
- data/examples/rails_root/config/initializers/new_rails_defaults.rb +17 -0
- data/examples/rails_root/config/routes.rb +45 -0
- data/examples/rails_root/db/migrate/20090125013728_create_users.rb +11 -0
- data/examples/rails_root/db/migrate/20090908054656_create_delayed_jobs.rb +20 -0
- data/examples/rails_root/db/schema.rb +32 -0
- data/examples/rails_root/doc/README_FOR_APP +5 -0
- data/examples/rails_root/features/attachments.feature +27 -0
- data/examples/rails_root/features/delayed_job.feature +13 -0
- data/examples/rails_root/features/errors.feature +32 -0
- data/examples/rails_root/features/example.feature +62 -0
- data/examples/rails_root/features/step_definitions/user_steps.rb +26 -0
- data/examples/rails_root/features/step_definitions/web_steps.rb +273 -0
- data/examples/rails_root/features/support/env.rb +58 -0
- data/examples/rails_root/features/support/env_ext.rb +6 -0
- data/examples/rails_root/features/support/paths.rb +33 -0
- data/examples/rails_root/lib/tasks/cucumber.rake +47 -0
- data/examples/rails_root/public/404.html +30 -0
- data/examples/rails_root/public/422.html +30 -0
- data/examples/rails_root/public/500.html +33 -0
- data/examples/rails_root/public/dispatch.rb +10 -0
- data/examples/rails_root/public/favicon.ico +0 -0
- data/examples/rails_root/public/images/rails.png +0 -0
- data/examples/rails_root/public/javascripts/application.js +2 -0
- data/examples/rails_root/public/javascripts/controls.js +963 -0
- data/examples/rails_root/public/javascripts/dragdrop.js +973 -0
- data/examples/rails_root/public/javascripts/effects.js +1128 -0
- data/examples/rails_root/public/javascripts/prototype.js +4320 -0
- data/examples/rails_root/public/robots.txt +5 -0
- data/examples/rails_root/script/about +4 -0
- data/examples/rails_root/script/autospec +5 -0
- data/examples/rails_root/script/console +3 -0
- data/examples/rails_root/script/cucumber +10 -0
- data/examples/rails_root/script/dbconsole +3 -0
- data/examples/rails_root/script/delayed_job +5 -0
- data/examples/rails_root/script/destroy +3 -0
- data/examples/rails_root/script/generate +3 -0
- data/examples/rails_root/script/performance/benchmarker +3 -0
- data/examples/rails_root/script/performance/profiler +3 -0
- data/examples/rails_root/script/performance/request +3 -0
- data/examples/rails_root/script/plugin +3 -0
- data/examples/rails_root/script/process/inspector +3 -0
- data/examples/rails_root/script/process/reaper +3 -0
- data/examples/rails_root/script/process/spawner +3 -0
- data/examples/rails_root/script/runner +3 -0
- data/examples/rails_root/script/server +3 -0
- data/examples/rails_root/script/spec +5 -0
- data/examples/rails_root/script/spec_server +125 -0
- data/examples/rails_root/spec/controllers/welcome_controller_spec.rb +15 -0
- data/examples/rails_root/spec/model_factory.rb +6 -0
- data/examples/rails_root/spec/models/user_mailer_spec.rb +58 -0
- data/examples/rails_root/spec/models/user_spec.rb +5 -0
- data/examples/rails_root/spec/rcov.opts +2 -0
- data/examples/rails_root/spec/spec.opts +4 -0
- data/examples/rails_root/spec/spec_helper.rb +51 -0
- data/examples/sinatra/app.rb +33 -0
- data/examples/sinatra/features/errors.feature +32 -0
- data/examples/sinatra/features/example.feature +62 -0
- data/examples/sinatra/features/step_definitions/user_steps.rb +26 -0
- data/examples/sinatra/features/step_definitions/web_steps.rb +273 -0
- data/examples/sinatra/features/support/env.rb +39 -0
- data/examples/sinatra/features/support/paths.rb +24 -0
- data/install.rb +0 -0
- data/lib/email-spec.rb +1 -0
- data/lib/email_spec.rb +15 -0
- data/lib/email_spec/address_converter.rb +29 -0
- data/lib/email_spec/background_processes.rb +45 -0
- data/lib/email_spec/cucumber.rb +26 -0
- data/lib/email_spec/deliveries.rb +87 -0
- data/lib/email_spec/email_viewer.rb +87 -0
- data/lib/email_spec/helpers.rb +160 -0
- data/lib/email_spec/matchers.rb +217 -0
- data/rails_generators/email_spec/email_spec_generator.rb +17 -0
- data/rails_generators/email_spec/templates/email_steps.rb +182 -0
- data/spec/email_spec/helpers_spec.rb +23 -0
- data/spec/email_spec/matchers_spec.rb +240 -0
- data/spec/spec.opts +4 -0
- data/spec/spec_helper.rb +4 -0
- metadata +268 -0
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
# These settings change the behavior of Rails 2 apps and will be defaults
|
|
2
|
+
# for Rails 3. You can remove this initializer when Rails 3 is released.
|
|
3
|
+
|
|
4
|
+
if defined?(ActiveRecord)
|
|
5
|
+
# Include Active Record class name as root for JSON serialized output.
|
|
6
|
+
ActiveRecord::Base.include_root_in_json = true
|
|
7
|
+
|
|
8
|
+
# Store the full class name (including module namespace) in STI type column.
|
|
9
|
+
ActiveRecord::Base.store_full_sti_class = true
|
|
10
|
+
end
|
|
11
|
+
|
|
12
|
+
# Use ISO 8601 format for JSON serialized times and dates.
|
|
13
|
+
ActiveSupport.use_standard_json_time_format = true
|
|
14
|
+
|
|
15
|
+
# Don't escape HTML entities in JSON, leave that for the #json_escape helper.
|
|
16
|
+
# if you're including raw json in an HTML page.
|
|
17
|
+
ActiveSupport.escape_html_entities_in_json = false
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
ActionController::Routing::Routes.draw do |map|
|
|
2
|
+
# The priority is based upon order of creation: first created -> highest priority.
|
|
3
|
+
|
|
4
|
+
# Sample of regular route:
|
|
5
|
+
# map.connect 'products/:id', :controller => 'catalog', :action => 'view'
|
|
6
|
+
# Keep in mind you can assign values other than :controller and :action
|
|
7
|
+
|
|
8
|
+
# Sample of named route:
|
|
9
|
+
# map.purchase 'products/:id/purchase', :controller => 'catalog', :action => 'purchase'
|
|
10
|
+
# This route can be invoked with purchase_url(:id => product.id)
|
|
11
|
+
|
|
12
|
+
# Sample resource route (maps HTTP verbs to controller actions automatically):
|
|
13
|
+
# map.resources :products
|
|
14
|
+
|
|
15
|
+
# Sample resource route with options:
|
|
16
|
+
# map.resources :products, :member => { :short => :get, :toggle => :post }, :collection => { :sold => :get }
|
|
17
|
+
|
|
18
|
+
# Sample resource route with sub-resources:
|
|
19
|
+
# map.resources :products, :has_many => [ :comments, :sales ], :has_one => :seller
|
|
20
|
+
|
|
21
|
+
# Sample resource route with more complex sub-resources
|
|
22
|
+
# map.resources :products do |products|
|
|
23
|
+
# products.resources :comments
|
|
24
|
+
# products.resources :sales, :collection => { :recent => :get }
|
|
25
|
+
# end
|
|
26
|
+
|
|
27
|
+
# Sample resource route within a namespace:
|
|
28
|
+
# map.namespace :admin do |admin|
|
|
29
|
+
# # Directs /admin/products/* to Admin::ProductsController (app/controllers/admin/products_controller.rb)
|
|
30
|
+
# admin.resources :products
|
|
31
|
+
# end
|
|
32
|
+
|
|
33
|
+
# You can have the root of your site routed with map.root -- just remember to delete public/index.html.
|
|
34
|
+
map.root :controller => "welcome", :action => "index"
|
|
35
|
+
map.confirm_account "/confirm", :controller => "welcome", :action => "confirm"
|
|
36
|
+
map.request_newsletter "/newsletter", :controller => "welcome", :action => "newsletter"
|
|
37
|
+
map.request_attachments "/attachments", :controller => "welcome", :action => "attachments"
|
|
38
|
+
# See how all your routes lay out with "rake routes"
|
|
39
|
+
|
|
40
|
+
# Install the default routes as the lowest priority.
|
|
41
|
+
# Note: These default routes make all actions in every controller accessible via GET requests. You should
|
|
42
|
+
# consider removing the them or commenting them out if you're using named routes and resources.
|
|
43
|
+
map.connect ':controller/:action/:id'
|
|
44
|
+
map.connect ':controller/:action/:id.:format'
|
|
45
|
+
end
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
class CreateDelayedJobs < ActiveRecord::Migration
|
|
2
|
+
def self.up
|
|
3
|
+
create_table :delayed_jobs, :force => true do |table|
|
|
4
|
+
table.integer :priority, :default => 0 # Allows some jobs to jump to the front of the queue
|
|
5
|
+
table.integer :attempts, :default => 0 # Provides for retries, but still fail eventually.
|
|
6
|
+
table.text :handler # YAML-encoded string of the object that will do work
|
|
7
|
+
table.text :last_error # reason for last failure (See Note below)
|
|
8
|
+
table.datetime :run_at # When to run. Could be Time.now for immediately, or sometime in the future.
|
|
9
|
+
table.datetime :locked_at # Set when a client is working on this object
|
|
10
|
+
table.datetime :failed_at # Set when all retries have failed (actually, by default, the record is deleted instead)
|
|
11
|
+
table.string :locked_by # Who is working on this object (if locked)
|
|
12
|
+
table.timestamps
|
|
13
|
+
end
|
|
14
|
+
|
|
15
|
+
end
|
|
16
|
+
|
|
17
|
+
def self.down
|
|
18
|
+
drop_table :delayed_jobs
|
|
19
|
+
end
|
|
20
|
+
end
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
# This file is auto-generated from the current state of the database. Instead of editing this file,
|
|
2
|
+
# please use the migrations feature of Active Record to incrementally modify your database, and
|
|
3
|
+
# then regenerate this schema definition.
|
|
4
|
+
#
|
|
5
|
+
# Note that this schema.rb definition is the authoritative source for your database schema. If you need
|
|
6
|
+
# to create the application database on another system, you should be using db:schema:load, not running
|
|
7
|
+
# all the migrations from scratch. The latter is a flawed and unsustainable approach (the more migrations
|
|
8
|
+
# you'll amass, the slower it'll run and the greater likelihood for issues).
|
|
9
|
+
#
|
|
10
|
+
# It's strongly recommended to check this file into your version control system.
|
|
11
|
+
|
|
12
|
+
ActiveRecord::Schema.define(:version => 20090908054656) do
|
|
13
|
+
|
|
14
|
+
create_table "delayed_jobs", :force => true do |t|
|
|
15
|
+
t.integer "priority", :default => 0
|
|
16
|
+
t.integer "attempts", :default => 0
|
|
17
|
+
t.text "handler"
|
|
18
|
+
t.text "last_error"
|
|
19
|
+
t.datetime "run_at"
|
|
20
|
+
t.datetime "locked_at"
|
|
21
|
+
t.datetime "failed_at"
|
|
22
|
+
t.string "locked_by"
|
|
23
|
+
t.datetime "created_at"
|
|
24
|
+
t.datetime "updated_at"
|
|
25
|
+
end
|
|
26
|
+
|
|
27
|
+
create_table "users", :force => true do |t|
|
|
28
|
+
t.string "email"
|
|
29
|
+
t.string "name"
|
|
30
|
+
end
|
|
31
|
+
|
|
32
|
+
end
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
Feature: Attachment testing support
|
|
2
|
+
In order for developers to test attachments in emails
|
|
3
|
+
I want to be able to provide working steps which inspect attachments
|
|
4
|
+
|
|
5
|
+
Scenario: Email with Attachments
|
|
6
|
+
Given no emails have been sent
|
|
7
|
+
And I go to request attachments be sent to me
|
|
8
|
+
Then I should receive an email
|
|
9
|
+
When I open the email
|
|
10
|
+
Then I should see 2 attachments with the email
|
|
11
|
+
And there should be an attachment named "image.png"
|
|
12
|
+
And there should be an attachment named "document.pdf"
|
|
13
|
+
And attachment 1 should be named "image.png"
|
|
14
|
+
And attachment 2 should be named "document.pdf"
|
|
15
|
+
And there should be an attachment of type "image/png"
|
|
16
|
+
And there should be an attachment of type "application/pdf"
|
|
17
|
+
And attachment 1 should be of type "image/png"
|
|
18
|
+
And attachment 2 should be of type "application/pdf"
|
|
19
|
+
And all attachments should not be blank
|
|
20
|
+
|
|
21
|
+
Scenario: Email without Attachments
|
|
22
|
+
Given no emails have been sent
|
|
23
|
+
And I am on the homepage
|
|
24
|
+
And I submit my registration information
|
|
25
|
+
Then I should receive an email
|
|
26
|
+
When I open the email
|
|
27
|
+
Then I should see no attachments with the email
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
Feature: Delayed Job support
|
|
2
|
+
In order for developers using delayed_job to test emails
|
|
3
|
+
I want to be able to provide a compatibility layer, which
|
|
4
|
+
should run all delayed jobs before checking email boxes
|
|
5
|
+
In order to populate deliveries done via send_later
|
|
6
|
+
|
|
7
|
+
Scenario: Newsletter
|
|
8
|
+
Given no emails have been sent
|
|
9
|
+
And I go to request a newsletter
|
|
10
|
+
Then I should receive an email
|
|
11
|
+
And I should have 1 email
|
|
12
|
+
When I open the email
|
|
13
|
+
Then I should see "Newsletter sent" in the email subject
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
Feature: Email-spec errors example
|
|
2
|
+
In order to help alleviate email testing in apps
|
|
3
|
+
As a email-spec contributor I a newcomer
|
|
4
|
+
Should be able to easily determine where I have gone wrong
|
|
5
|
+
These scenarios should fail with helpful messages
|
|
6
|
+
|
|
7
|
+
Background:
|
|
8
|
+
Given I am on the homepage
|
|
9
|
+
And no emails have been sent
|
|
10
|
+
When I fill in "Email" with "example@example.com"
|
|
11
|
+
And I press "Sign up"
|
|
12
|
+
|
|
13
|
+
Scenario: I fail to open an email with incorrect subject
|
|
14
|
+
Then I should receive an email
|
|
15
|
+
When "example@example.com" opens the email with subject "no email"
|
|
16
|
+
|
|
17
|
+
Scenario: I fail to open an email with incorrect text
|
|
18
|
+
Then I should receive an email
|
|
19
|
+
When "example@example.com" opens the email with text "no email"
|
|
20
|
+
|
|
21
|
+
Scenario: I fail to receive an email with the expected link
|
|
22
|
+
Then I should receive an email
|
|
23
|
+
When I open the email
|
|
24
|
+
When I follow "link that doesn't exist" in the email
|
|
25
|
+
|
|
26
|
+
Scenario: I attempt to operate on an email that is not opened
|
|
27
|
+
Then I should receive an email
|
|
28
|
+
When I follow "confirm" in the email
|
|
29
|
+
|
|
30
|
+
Scenario: I attempt to check out an unopened email
|
|
31
|
+
Then I should see "confirm" in the email body
|
|
32
|
+
And I should see "Account confirmation" in the email subject
|
|
@@ -0,0 +1,62 @@
|
|
|
1
|
+
Feature: EmailSpec Example -- Prevent Bots from creating accounts
|
|
2
|
+
|
|
3
|
+
In order to help alleviate email testing in apps
|
|
4
|
+
As an email-spec contributor I want new users of the library
|
|
5
|
+
to easily adopt email-spec in their app by following this example
|
|
6
|
+
|
|
7
|
+
In order to prevent bots from setting up new accounts
|
|
8
|
+
As a site manager I want new users
|
|
9
|
+
to verify their email address with a confirmation link
|
|
10
|
+
|
|
11
|
+
Background:
|
|
12
|
+
Given no emails have been sent
|
|
13
|
+
And I am a real person wanting to sign up for an account
|
|
14
|
+
And I am on the homepage
|
|
15
|
+
And I submit my registration information
|
|
16
|
+
|
|
17
|
+
Scenario: First person signup (as myself) with two ways of opening email
|
|
18
|
+
Then I should receive an email
|
|
19
|
+
And I should have 1 email
|
|
20
|
+
|
|
21
|
+
# Opening email #1
|
|
22
|
+
When I open the email
|
|
23
|
+
Then I should see "Account confirmation" in the email subject
|
|
24
|
+
And I should see "Joe Someone" in the email body
|
|
25
|
+
And I should see "confirm" in the email body
|
|
26
|
+
|
|
27
|
+
# Opening email #2
|
|
28
|
+
When I open the email with subject "Account confirmation"
|
|
29
|
+
Then I should see "Account confirmation" in the email subject
|
|
30
|
+
And I should see "Joe Someone" in the email body
|
|
31
|
+
And I should see "confirm" in the email body
|
|
32
|
+
|
|
33
|
+
When I follow "Click here to confirm your account!" in the email
|
|
34
|
+
Then I should see "Confirm your new account"
|
|
35
|
+
|
|
36
|
+
And "foo@bar.com" should have no emails
|
|
37
|
+
|
|
38
|
+
Scenario: Third person signup (emails sent to others) with two ways of opening email
|
|
39
|
+
Then "foo@bar.com" should have no emails
|
|
40
|
+
And "example@example.com" should receive an email
|
|
41
|
+
And "example@example.com" should have 1 email
|
|
42
|
+
|
|
43
|
+
# Opening email #1
|
|
44
|
+
When they open the email
|
|
45
|
+
Then they should see "Account confirmation" in the email subject
|
|
46
|
+
And they should see "Joe Someone" in the email body
|
|
47
|
+
And they should see "confirm" in the email body
|
|
48
|
+
|
|
49
|
+
# Opening email #2
|
|
50
|
+
When "example@example.com" opens the email with subject "Account confirmation"
|
|
51
|
+
Then they should see "Account confirmation" in the email subject
|
|
52
|
+
And they should see "Joe Someone" in the email body
|
|
53
|
+
And they should see "confirm" in the email body
|
|
54
|
+
|
|
55
|
+
When they follow "Click here to confirm your account!" in the email
|
|
56
|
+
Then they should see "Confirm your new account"
|
|
57
|
+
|
|
58
|
+
Scenario: Declarative First Person signup
|
|
59
|
+
Then I should receive an email with a link to a confirmation page
|
|
60
|
+
|
|
61
|
+
Scenario: Declarative First Person signup
|
|
62
|
+
Then they should receive an email with a link to a confirmation page
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
Given "I am a real person wanting to sign up for an account" do
|
|
2
|
+
# no-op.. for documentation purposes only!
|
|
3
|
+
end
|
|
4
|
+
|
|
5
|
+
When /^I submit my registration information$/ do
|
|
6
|
+
fill_in "Name", :with => 'Joe Someone'
|
|
7
|
+
fill_in "Email", :with => 'example@example.com'
|
|
8
|
+
click_button
|
|
9
|
+
end
|
|
10
|
+
|
|
11
|
+
Then /^(?:I|they) should receive an email with a link to a confirmation page$/ do
|
|
12
|
+
unread_emails_for(current_email_address).size.should == 1
|
|
13
|
+
|
|
14
|
+
# this call will store the email and you can access it with current_email
|
|
15
|
+
open_last_email_for(last_email_address)
|
|
16
|
+
current_email.should have_subject(/Account confirmation/)
|
|
17
|
+
current_email.should have_body_text('Joe Someone')
|
|
18
|
+
|
|
19
|
+
click_email_link_matching /confirm/
|
|
20
|
+
response_body.should contain("Confirm your new account")
|
|
21
|
+
end
|
|
22
|
+
|
|
23
|
+
# Basically aliases "I should see [text]", but for third person
|
|
24
|
+
Then /^they should see "([^\"]*)"$/ do |text|
|
|
25
|
+
Then "I should see \"#{text}\""
|
|
26
|
+
end
|
|
@@ -0,0 +1,273 @@
|
|
|
1
|
+
# IMPORTANT: This file is generated by cucumber-rails - edit at your own peril.
|
|
2
|
+
# It is recommended to regenerate this file in the future when you upgrade to a
|
|
3
|
+
# newer version of cucumber-rails. Consider adding your own code to a new file
|
|
4
|
+
# instead of editing this one. Cucumber will automatically load all features/**/*.rb
|
|
5
|
+
# files.
|
|
6
|
+
|
|
7
|
+
|
|
8
|
+
require 'uri'
|
|
9
|
+
require File.expand_path(File.join(File.dirname(__FILE__), "..", "support", "paths"))
|
|
10
|
+
|
|
11
|
+
# Commonly used webrat steps
|
|
12
|
+
# http://github.com/brynary/webrat
|
|
13
|
+
|
|
14
|
+
Given /^(?:|I )am on (.+)$/ do |page_name|
|
|
15
|
+
visit path_to(page_name)
|
|
16
|
+
end
|
|
17
|
+
|
|
18
|
+
When /^(?:|I )go to (.+)$/ do |page_name|
|
|
19
|
+
visit path_to(page_name)
|
|
20
|
+
end
|
|
21
|
+
|
|
22
|
+
When /^(?:|I )press "([^\"]*)"$/ do |button|
|
|
23
|
+
click_button(button)
|
|
24
|
+
end
|
|
25
|
+
|
|
26
|
+
When /^(?:|I )follow "([^\"]*)"$/ do |link|
|
|
27
|
+
click_link(link)
|
|
28
|
+
end
|
|
29
|
+
|
|
30
|
+
When /^(?:|I )follow "([^\"]*)" within "([^\"]*)"$/ do |link, parent|
|
|
31
|
+
click_link_within(parent, link)
|
|
32
|
+
end
|
|
33
|
+
|
|
34
|
+
When /^(?:|I )fill in "([^\"]*)" with "([^\"]*)"$/ do |field, value|
|
|
35
|
+
fill_in(field, :with => value)
|
|
36
|
+
end
|
|
37
|
+
|
|
38
|
+
When /^(?:|I )fill in "([^\"]*)" for "([^\"]*)"$/ do |value, field|
|
|
39
|
+
fill_in(field, :with => value)
|
|
40
|
+
end
|
|
41
|
+
|
|
42
|
+
# Use this to fill in an entire form with data from a table. Example:
|
|
43
|
+
#
|
|
44
|
+
# When I fill in the following:
|
|
45
|
+
# | Account Number | 5002 |
|
|
46
|
+
# | Expiry date | 2009-11-01 |
|
|
47
|
+
# | Note | Nice guy |
|
|
48
|
+
# | Wants Email? | |
|
|
49
|
+
#
|
|
50
|
+
# TODO: Add support for checkbox, select og option
|
|
51
|
+
# based on naming conventions.
|
|
52
|
+
#
|
|
53
|
+
When /^(?:|I )fill in the following:$/ do |fields|
|
|
54
|
+
fields.rows_hash.each do |name, value|
|
|
55
|
+
When %{I fill in "#{name}" with "#{value}"}
|
|
56
|
+
end
|
|
57
|
+
end
|
|
58
|
+
|
|
59
|
+
When /^(?:|I )select "([^\"]*)" from "([^\"]*)"$/ do |value, field|
|
|
60
|
+
select(value, :from => field)
|
|
61
|
+
end
|
|
62
|
+
|
|
63
|
+
# Use this step in conjunction with Rail's datetime_select helper. For example:
|
|
64
|
+
# When I select "December 25, 2008 10:00" as the date and time
|
|
65
|
+
When /^(?:|I )select "([^\"]*)" as the date and time$/ do |time|
|
|
66
|
+
select_datetime(time)
|
|
67
|
+
end
|
|
68
|
+
|
|
69
|
+
# Use this step when using multiple datetime_select helpers on a page or
|
|
70
|
+
# you want to specify which datetime to select. Given the following view:
|
|
71
|
+
# <%= f.label :preferred %><br />
|
|
72
|
+
# <%= f.datetime_select :preferred %>
|
|
73
|
+
# <%= f.label :alternative %><br />
|
|
74
|
+
# <%= f.datetime_select :alternative %>
|
|
75
|
+
# The following steps would fill out the form:
|
|
76
|
+
# When I select "November 23, 2004 11:20" as the "Preferred" date and time
|
|
77
|
+
# And I select "November 25, 2004 10:30" as the "Alternative" date and time
|
|
78
|
+
When /^(?:|I )select "([^\"]*)" as the "([^\"]*)" date and time$/ do |datetime, datetime_label|
|
|
79
|
+
select_datetime(datetime, :from => datetime_label)
|
|
80
|
+
end
|
|
81
|
+
|
|
82
|
+
# Use this step in conjunction with Rail's time_select helper. For example:
|
|
83
|
+
# When I select "2:20PM" as the time
|
|
84
|
+
# Note: Rail's default time helper provides 24-hour time-- not 12 hour time. Webrat
|
|
85
|
+
# will convert the 2:20PM to 14:20 and then select it.
|
|
86
|
+
When /^(?:|I )select "([^\"]*)" as the time$/ do |time|
|
|
87
|
+
select_time(time)
|
|
88
|
+
end
|
|
89
|
+
|
|
90
|
+
# Use this step when using multiple time_select helpers on a page or you want to
|
|
91
|
+
# specify the name of the time on the form. For example:
|
|
92
|
+
# When I select "7:30AM" as the "Gym" time
|
|
93
|
+
When /^(?:|I )select "([^\"]*)" as the "([^\"]*)" time$/ do |time, time_label|
|
|
94
|
+
select_time(time, :from => time_label)
|
|
95
|
+
end
|
|
96
|
+
|
|
97
|
+
# Use this step in conjunction with Rail's date_select helper. For example:
|
|
98
|
+
# When I select "February 20, 1981" as the date
|
|
99
|
+
When /^(?:|I )select "([^\"]*)" as the date$/ do |date|
|
|
100
|
+
select_date(date)
|
|
101
|
+
end
|
|
102
|
+
|
|
103
|
+
# Use this step when using multiple date_select helpers on one page or
|
|
104
|
+
# you want to specify the name of the date on the form. For example:
|
|
105
|
+
# When I select "April 26, 1982" as the "Date of Birth" date
|
|
106
|
+
When /^(?:|I )select "([^\"]*)" as the "([^\"]*)" date$/ do |date, date_label|
|
|
107
|
+
select_date(date, :from => date_label)
|
|
108
|
+
end
|
|
109
|
+
|
|
110
|
+
When /^(?:|I )check "([^\"]*)"$/ do |field|
|
|
111
|
+
check(field)
|
|
112
|
+
end
|
|
113
|
+
|
|
114
|
+
When /^(?:|I )uncheck "([^\"]*)"$/ do |field|
|
|
115
|
+
uncheck(field)
|
|
116
|
+
end
|
|
117
|
+
|
|
118
|
+
When /^(?:|I )choose "([^\"]*)"$/ do |field|
|
|
119
|
+
choose(field)
|
|
120
|
+
end
|
|
121
|
+
|
|
122
|
+
# Adds support for validates_attachment_content_type. Without the mime-type getting
|
|
123
|
+
# passed to attach_file() you will get a "Photo file is not one of the allowed file types."
|
|
124
|
+
# error message
|
|
125
|
+
When /^(?:|I )attach the file "([^\"]*)" to "([^\"]*)"$/ do |path, field|
|
|
126
|
+
type = path.split(".")[1]
|
|
127
|
+
|
|
128
|
+
case type
|
|
129
|
+
when "jpg"
|
|
130
|
+
type = "image/jpg"
|
|
131
|
+
when "jpeg"
|
|
132
|
+
type = "image/jpeg"
|
|
133
|
+
when "png"
|
|
134
|
+
type = "image/png"
|
|
135
|
+
when "gif"
|
|
136
|
+
type = "image/gif"
|
|
137
|
+
end
|
|
138
|
+
|
|
139
|
+
attach_file(field, path, type)
|
|
140
|
+
end
|
|
141
|
+
|
|
142
|
+
Then /^(?:|I )should see "([^\"]*)"$/ do |text|
|
|
143
|
+
if defined?(Spec::Rails::Matchers)
|
|
144
|
+
response.should contain(text)
|
|
145
|
+
else
|
|
146
|
+
assert_contain text
|
|
147
|
+
end
|
|
148
|
+
end
|
|
149
|
+
|
|
150
|
+
Then /^(?:|I )should see "([^\"]*)" within "([^\"]*)"$/ do |text, selector|
|
|
151
|
+
within(selector) do |content|
|
|
152
|
+
if defined?(Spec::Rails::Matchers)
|
|
153
|
+
content.should contain(text)
|
|
154
|
+
else
|
|
155
|
+
hc = Webrat::Matchers::HasContent.new(text)
|
|
156
|
+
assert hc.matches?(content), hc.failure_message
|
|
157
|
+
end
|
|
158
|
+
end
|
|
159
|
+
end
|
|
160
|
+
|
|
161
|
+
Then /^(?:|I )should see \/([^\/]*)\/$/ do |regexp|
|
|
162
|
+
regexp = Regexp.new(regexp)
|
|
163
|
+
if defined?(Spec::Rails::Matchers)
|
|
164
|
+
response.should contain(regexp)
|
|
165
|
+
else
|
|
166
|
+
assert_match(regexp, response_body)
|
|
167
|
+
end
|
|
168
|
+
end
|
|
169
|
+
|
|
170
|
+
Then /^(?:|I )should see \/([^\/]*)\/ within "([^\"]*)"$/ do |regexp, selector|
|
|
171
|
+
within(selector) do |content|
|
|
172
|
+
regexp = Regexp.new(regexp)
|
|
173
|
+
if defined?(Spec::Rails::Matchers)
|
|
174
|
+
content.should contain(regexp)
|
|
175
|
+
else
|
|
176
|
+
assert_match(regexp, content)
|
|
177
|
+
end
|
|
178
|
+
end
|
|
179
|
+
end
|
|
180
|
+
|
|
181
|
+
Then /^(?:|I )should not see "([^\"]*)"$/ do |text|
|
|
182
|
+
if defined?(Spec::Rails::Matchers)
|
|
183
|
+
response.should_not contain(text)
|
|
184
|
+
else
|
|
185
|
+
assert_not_contain(text)
|
|
186
|
+
end
|
|
187
|
+
end
|
|
188
|
+
|
|
189
|
+
Then /^(?:|I )should not see "([^\"]*)" within "([^\"]*)"$/ do |text, selector|
|
|
190
|
+
within(selector) do |content|
|
|
191
|
+
if defined?(Spec::Rails::Matchers)
|
|
192
|
+
content.should_not contain(text)
|
|
193
|
+
else
|
|
194
|
+
hc = Webrat::Matchers::HasContent.new(text)
|
|
195
|
+
assert !hc.matches?(content), hc.negative_failure_message
|
|
196
|
+
end
|
|
197
|
+
end
|
|
198
|
+
end
|
|
199
|
+
|
|
200
|
+
Then /^(?:|I )should not see \/([^\/]*)\/$/ do |regexp|
|
|
201
|
+
regexp = Regexp.new(regexp)
|
|
202
|
+
if defined?(Spec::Rails::Matchers)
|
|
203
|
+
response.should_not contain(regexp)
|
|
204
|
+
else
|
|
205
|
+
assert_not_contain(regexp)
|
|
206
|
+
end
|
|
207
|
+
end
|
|
208
|
+
|
|
209
|
+
Then /^(?:|I )should not see \/([^\/]*)\/ within "([^\"]*)"$/ do |regexp, selector|
|
|
210
|
+
within(selector) do |content|
|
|
211
|
+
regexp = Regexp.new(regexp)
|
|
212
|
+
if defined?(Spec::Rails::Matchers)
|
|
213
|
+
content.should_not contain(regexp)
|
|
214
|
+
else
|
|
215
|
+
assert_no_match(regexp, content)
|
|
216
|
+
end
|
|
217
|
+
end
|
|
218
|
+
end
|
|
219
|
+
|
|
220
|
+
Then /^the "([^\"]*)" field should contain "([^\"]*)"$/ do |field, value|
|
|
221
|
+
if defined?(Spec::Rails::Matchers)
|
|
222
|
+
field_labeled(field).value.should =~ /#{value}/
|
|
223
|
+
else
|
|
224
|
+
assert_match(/#{value}/, field_labeled(field).value)
|
|
225
|
+
end
|
|
226
|
+
end
|
|
227
|
+
|
|
228
|
+
Then /^the "([^\"]*)" field should not contain "([^\"]*)"$/ do |field, value|
|
|
229
|
+
if defined?(Spec::Rails::Matchers)
|
|
230
|
+
field_labeled(field).value.should_not =~ /#{value}/
|
|
231
|
+
else
|
|
232
|
+
assert_no_match(/#{value}/, field_labeled(field).value)
|
|
233
|
+
end
|
|
234
|
+
end
|
|
235
|
+
|
|
236
|
+
Then /^the "([^\"]*)" checkbox should be checked$/ do |label|
|
|
237
|
+
if defined?(Spec::Rails::Matchers)
|
|
238
|
+
field_labeled(label).should be_checked
|
|
239
|
+
else
|
|
240
|
+
assert field_labeled(label).checked?
|
|
241
|
+
end
|
|
242
|
+
end
|
|
243
|
+
|
|
244
|
+
Then /^the "([^\"]*)" checkbox should not be checked$/ do |label|
|
|
245
|
+
if defined?(Spec::Rails::Matchers)
|
|
246
|
+
field_labeled(label).should_not be_checked
|
|
247
|
+
else
|
|
248
|
+
assert !field_labeled(label).checked?
|
|
249
|
+
end
|
|
250
|
+
end
|
|
251
|
+
|
|
252
|
+
Then /^(?:|I )should be on (.+)$/ do |page_name|
|
|
253
|
+
if defined?(Spec::Rails::Matchers)
|
|
254
|
+
URI.parse(current_url).path.should == path_to(page_name)
|
|
255
|
+
else
|
|
256
|
+
assert_equal path_to(page_name), URI.parse(current_url).path
|
|
257
|
+
end
|
|
258
|
+
end
|
|
259
|
+
|
|
260
|
+
Then /^(?:|I )should have the following query string:$/ do |expected_pairs|
|
|
261
|
+
actual_params = CGI.parse(URI.parse(current_url).query)
|
|
262
|
+
expected_params = Hash[expected_pairs.rows_hash.map{|k,v| [k,[v]]}]
|
|
263
|
+
|
|
264
|
+
if defined?(Spec::Rails::Matchers)
|
|
265
|
+
actual_params.should == expected_params
|
|
266
|
+
else
|
|
267
|
+
assert_equal expected_params, actual_params
|
|
268
|
+
end
|
|
269
|
+
end
|
|
270
|
+
|
|
271
|
+
Then /^show me the page$/ do
|
|
272
|
+
save_and_open_page
|
|
273
|
+
end
|