clearance 0.9.0.rc2 → 0.9.0.rc3

Sign up to get free protection for your applications and to get access to all the features.

Potentially problematic release.


This version of clearance might be problematic. Click here for more details.

Files changed (96) hide show
  1. data/Rakefile +55 -1
  2. data/VERSION +1 -0
  3. data/clearance.gemspec +208 -0
  4. data/cucumber.yml +4 -0
  5. data/lib/rails/generators/clearance_generator.rb +5 -1
  6. data/spec/rails_root/Gemfile +40 -0
  7. data/spec/rails_root/README +244 -0
  8. data/spec/rails_root/Rakefile +10 -0
  9. data/spec/rails_root/app/controllers/accounts_controller.rb +10 -0
  10. data/spec/rails_root/app/controllers/application_controller.rb +6 -0
  11. data/spec/rails_root/app/helpers/application_helper.rb +2 -0
  12. data/spec/rails_root/app/models/user.rb +3 -0
  13. data/spec/rails_root/app/views/accounts/edit.html.erb +0 -0
  14. data/spec/rails_root/app/views/layouts/application.html.erb +24 -0
  15. data/spec/rails_root/config.ru +4 -0
  16. data/spec/rails_root/config/application.rb +46 -0
  17. data/spec/rails_root/config/boot.rb +6 -0
  18. data/spec/rails_root/config/cucumber.yml +8 -0
  19. data/spec/rails_root/config/database.yml +25 -0
  20. data/spec/rails_root/config/environment.rb +7 -0
  21. data/spec/rails_root/config/environments/development.rb +19 -0
  22. data/spec/rails_root/config/environments/production.rb +42 -0
  23. data/spec/rails_root/config/environments/test.rb +32 -0
  24. data/spec/rails_root/config/initializers/backtrace_silencers.rb +7 -0
  25. data/spec/rails_root/config/initializers/clearance.rb +3 -0
  26. data/spec/rails_root/config/initializers/inflections.rb +10 -0
  27. data/spec/rails_root/config/initializers/mime_types.rb +5 -0
  28. data/spec/rails_root/config/initializers/secret_token.rb +7 -0
  29. data/spec/rails_root/config/initializers/session_store.rb +8 -0
  30. data/spec/rails_root/config/locales/en.yml +5 -0
  31. data/spec/rails_root/config/routes.rb +61 -0
  32. data/spec/rails_root/db/schema.rb +28 -0
  33. data/spec/rails_root/doc/README_FOR_APP +2 -0
  34. data/spec/rails_root/features/password_reset.feature +33 -0
  35. data/spec/rails_root/features/sign_in.feature +35 -0
  36. data/spec/rails_root/features/sign_out.feature +15 -0
  37. data/spec/rails_root/features/sign_up.feature +45 -0
  38. data/spec/rails_root/features/step_definitions/clearance_steps.rb +130 -0
  39. data/spec/rails_root/features/step_definitions/web_steps.rb +219 -0
  40. data/spec/rails_root/features/support/env.rb +57 -0
  41. data/spec/rails_root/features/support/paths.rb +45 -0
  42. data/spec/rails_root/lib/tasks/cucumber.rake +53 -0
  43. data/spec/rails_root/public/404.html +26 -0
  44. data/spec/rails_root/public/422.html +26 -0
  45. data/spec/rails_root/public/500.html +26 -0
  46. data/spec/rails_root/public/favicon.ico +0 -0
  47. data/spec/rails_root/public/images/rails.png +0 -0
  48. data/spec/rails_root/public/javascripts/application.js +2 -0
  49. data/spec/rails_root/public/javascripts/controls.js +965 -0
  50. data/spec/rails_root/public/javascripts/dragdrop.js +974 -0
  51. data/spec/rails_root/public/javascripts/effects.js +1123 -0
  52. data/spec/rails_root/public/javascripts/prototype.js +4874 -0
  53. data/spec/rails_root/public/javascripts/rails.js +118 -0
  54. data/spec/rails_root/public/robots.txt +5 -0
  55. data/spec/rails_root/script/cucumber +10 -0
  56. data/spec/rails_root/script/rails +9 -0
  57. data/spec/rails_root/spec/factories/clearance.rb +13 -0
  58. data/spec/rails_root/vendor/plugins/dynamic_form/MIT-LICENSE +20 -0
  59. data/spec/rails_root/vendor/plugins/dynamic_form/README +13 -0
  60. data/spec/rails_root/vendor/plugins/dynamic_form/Rakefile +10 -0
  61. data/spec/rails_root/vendor/plugins/dynamic_form/init.rb +5 -0
  62. data/spec/rails_root/vendor/plugins/dynamic_form/lib/action_view/helpers/dynamic_form.rb +300 -0
  63. data/spec/rails_root/vendor/plugins/dynamic_form/lib/action_view/locale/en.yml +8 -0
  64. data/spec/rails_root/vendor/plugins/dynamic_form/test/dynamic_form_i18n_test.rb +42 -0
  65. data/spec/rails_root/vendor/plugins/dynamic_form/test/dynamic_form_test.rb +370 -0
  66. data/spec/rails_root/vendor/plugins/dynamic_form/test/test_helper.rb +9 -0
  67. data/test/rails_root/Gemfile +40 -0
  68. data/test/rails_root/README +244 -0
  69. data/test/rails_root/Rakefile +10 -0
  70. data/test/rails_root/app/views/accounts/edit.html.erb +0 -0
  71. data/test/rails_root/app/views/layouts/application.html.erb +24 -0
  72. data/test/rails_root/config.ru +4 -0
  73. data/test/rails_root/config/cucumber.yml +8 -0
  74. data/test/rails_root/config/database.yml +25 -0
  75. data/test/rails_root/config/locales/en.yml +5 -0
  76. data/test/rails_root/doc/README_FOR_APP +2 -0
  77. data/test/rails_root/lib/tasks/cucumber.rake +53 -0
  78. data/test/rails_root/public/404.html +26 -0
  79. data/test/rails_root/public/422.html +26 -0
  80. data/test/rails_root/public/500.html +26 -0
  81. data/test/rails_root/public/favicon.ico +0 -0
  82. data/test/rails_root/public/images/rails.png +0 -0
  83. data/test/rails_root/public/javascripts/application.js +2 -0
  84. data/test/rails_root/public/javascripts/controls.js +965 -0
  85. data/test/rails_root/public/javascripts/dragdrop.js +974 -0
  86. data/test/rails_root/public/javascripts/effects.js +1123 -0
  87. data/test/rails_root/public/javascripts/prototype.js +4874 -0
  88. data/test/rails_root/public/javascripts/rails.js +118 -0
  89. data/test/rails_root/public/robots.txt +5 -0
  90. data/test/rails_root/script/cucumber +10 -0
  91. data/test/rails_root/script/rails +9 -0
  92. data/test/rails_root/vendor/plugins/dynamic_form/MIT-LICENSE +20 -0
  93. data/test/rails_root/vendor/plugins/dynamic_form/README +13 -0
  94. data/test/rails_root/vendor/plugins/dynamic_form/Rakefile +10 -0
  95. data/test/rails_root/vendor/plugins/dynamic_form/lib/action_view/locale/en.yml +8 -0
  96. metadata +111 -47
@@ -0,0 +1,35 @@
1
+ Feature: Sign in
2
+ In order to get access to protected sections of the site
3
+ A user
4
+ Should be able to sign in
5
+
6
+ Scenario: User is not signed up
7
+ Given no user exists with an email of "email@person.com"
8
+ When I go to the sign in page
9
+ And I sign in as "email@person.com/password"
10
+ Then I should see "Bad email or password"
11
+ And I should be signed out
12
+
13
+ Scenario: User is not confirmed
14
+ Given I signed up with "email@person.com/password"
15
+ When I go to the sign in page
16
+ And I sign in as "email@person.com/password"
17
+ Then I should see "User has not confirmed email"
18
+ And I should be signed out
19
+
20
+ Scenario: User enters wrong password
21
+ Given I am signed up and confirmed as "email@person.com/password"
22
+ When I go to the sign in page
23
+ And I sign in as "email@person.com/wrongpassword"
24
+ Then I should see "Bad email or password"
25
+ And I should be signed out
26
+
27
+ Scenario: User signs in successfully
28
+ Given I am signed up and confirmed as "email@person.com/password"
29
+ When I go to the sign in page
30
+ And I sign in as "email@person.com/password"
31
+ Then I should see "Signed in"
32
+ And I should be signed in
33
+ When I return next time
34
+ Then I should be signed in
35
+
@@ -0,0 +1,15 @@
1
+ Feature: Sign out
2
+ To protect my account from unauthorized access
3
+ A signed in user
4
+ Should be able to sign out
5
+
6
+ Scenario: User signs out
7
+ Given I am signed up and confirmed as "email@person.com/password"
8
+ When I sign in as "email@person.com/password"
9
+ Then I should be signed in
10
+ And I sign out
11
+ Then I should see "Signed out"
12
+ And I should be signed out
13
+ When I return next time
14
+ Then I should be signed out
15
+
@@ -0,0 +1,45 @@
1
+ Feature: Sign up
2
+ In order to get access to protected sections of the site
3
+ A user
4
+ Should be able to sign up
5
+
6
+ Scenario: User signs up with invalid data
7
+ When I go to the sign up page
8
+ And I fill in "Email" with "invalidemail"
9
+ And I fill in "Password" with "password"
10
+ And I fill in "Confirm password" with ""
11
+ And I press "Sign up"
12
+ Then I should see error messages
13
+
14
+ Scenario: User signs up with valid data
15
+ When I go to the sign up page
16
+ And I fill in "Email" with "email@person.com"
17
+ And I fill in "Password" with "password"
18
+ And I fill in "Confirm password" with "password"
19
+ And I press "Sign up"
20
+ Then I should see "instructions for confirming"
21
+ And a confirmation message should be sent to "email@person.com"
22
+
23
+ Scenario: User confirms his account
24
+ Given I signed up with "email@person.com/password"
25
+ When I follow the confirmation link sent to "email@person.com"
26
+ Then I should see "Confirmed email and signed in"
27
+ And I should be signed in
28
+
29
+ Scenario: Signed in user clicks confirmation link again
30
+ Given I signed up with "email@person.com/password"
31
+ When I follow the confirmation link sent to "email@person.com"
32
+ Then I should be signed in
33
+ When I follow the confirmation link sent to "email@person.com"
34
+ Then I should see "Confirmed email and signed in"
35
+ And I should be signed in
36
+
37
+ Scenario: Signed out user clicks confirmation link again
38
+ Given I signed up with "email@person.com/password"
39
+ When I follow the confirmation link sent to "email@person.com"
40
+ Then I should be signed in
41
+ When I sign out
42
+ And I follow the confirmation link sent to "email@person.com"
43
+ Then I should see "Already confirmed email. Please sign in."
44
+ And I should be signed out
45
+
@@ -0,0 +1,130 @@
1
+ # General
2
+
3
+ Then /^I should see error messages$/ do
4
+ Then %{I should see "errors prohibited"}
5
+ end
6
+
7
+ Then /^I should see an error message$/ do
8
+ Then %{I should see "error prohibited"}
9
+ end
10
+
11
+ # Database
12
+
13
+ Given /^no user exists with an email of "(.*)"$/ do |email|
14
+ assert_nil User.find_by_email(email)
15
+ end
16
+
17
+ Given /^I signed up with "(.*)\/(.*)"$/ do |email, password|
18
+ user = Factory :user,
19
+ :email => email,
20
+ :password => password,
21
+ :password_confirmation => password
22
+ end
23
+
24
+ Given /^I am signed up and confirmed as "(.*)\/(.*)"$/ do |email, password|
25
+ user = Factory :email_confirmed_user,
26
+ :email => email,
27
+ :password => password,
28
+ :password_confirmation => password
29
+ end
30
+
31
+ # Session
32
+
33
+ Then /^I should be signed in$/ do
34
+ Given %{I am on the homepage}
35
+ Then %{I should see "Sign out"}
36
+ end
37
+
38
+ Then /^I should be signed out$/ do
39
+ Given %{I am on the homepage}
40
+ Then %{I should see "Sign in"}
41
+ end
42
+
43
+ When /^session is cleared$/ do
44
+ # TODO: This doesn't work with Capybara
45
+ # TODO: I tried Capybara.reset_sessions! but that didn't work
46
+ #request.reset_session
47
+ #controller.instance_variable_set(:@_current_user, nil)
48
+ end
49
+
50
+ Given /^I have signed in with "(.*)\/(.*)"$/ do |email, password|
51
+ Given %{I am signed up and confirmed as "#{email}/#{password}"}
52
+ And %{I sign in as "#{email}/#{password}"}
53
+ end
54
+
55
+ # Emails
56
+
57
+ Then /^a confirmation message should be sent to "(.*)"$/ do |email|
58
+ user = User.find_by_email(email)
59
+ assert !user.confirmation_token.blank?
60
+ assert !ActionMailer::Base.deliveries.empty?
61
+ result = ActionMailer::Base.deliveries.any? do |email|
62
+ email.to == [user.email] &&
63
+ email.subject =~ /confirm/i &&
64
+ email.body =~ /#{user.confirmation_token}/
65
+ end
66
+ assert result
67
+ end
68
+
69
+ When /^I follow the confirmation link sent to "(.*)"$/ do |email|
70
+ user = User.find_by_email(email)
71
+ visit new_user_confirmation_path(:user_id => user,
72
+ :token => user.confirmation_token)
73
+ end
74
+
75
+ Then /^a password reset message should be sent to "(.*)"$/ do |email|
76
+ user = User.find_by_email(email)
77
+ assert !user.confirmation_token.blank?
78
+ assert !ActionMailer::Base.deliveries.empty?
79
+ result = ActionMailer::Base.deliveries.any? do |email|
80
+ email.to == [user.email] &&
81
+ email.subject =~ /password/i &&
82
+ email.body =~ /#{user.confirmation_token}/
83
+ end
84
+ assert result
85
+ end
86
+
87
+ When /^I follow the password reset link sent to "(.*)"$/ do |email|
88
+ user = User.find_by_email(email)
89
+ visit edit_user_password_path(:user_id => user,
90
+ :token => user.confirmation_token)
91
+ end
92
+
93
+ When /^I try to change the password of "(.*)" without token$/ do |email|
94
+ user = User.find_by_email(email)
95
+ visit edit_user_password_path(:user_id => user)
96
+ end
97
+
98
+ Then /^I should be forbidden$/ do
99
+ assert_response :forbidden
100
+ end
101
+
102
+ # Actions
103
+
104
+ When /^I sign in as "(.*)\/(.*)"$/ do |email, password|
105
+ When %{I go to the sign in page}
106
+ And %{I fill in "Email" with "#{email}"}
107
+ And %{I fill in "Password" with "#{password}"}
108
+ And %{I press "Sign in"}
109
+ end
110
+
111
+ When /^I sign out$/ do
112
+ visit '/sign_out'
113
+ end
114
+
115
+ When /^I request password reset link to be sent to "(.*)"$/ do |email|
116
+ When %{I go to the password reset request page}
117
+ And %{I fill in "Email address" with "#{email}"}
118
+ And %{I press "Reset password"}
119
+ end
120
+
121
+ When /^I update my password with "(.*)\/(.*)"$/ do |password, confirmation|
122
+ And %{I fill in "Choose password" with "#{password}"}
123
+ And %{I fill in "Confirm password" with "#{confirmation}"}
124
+ And %{I press "Save this password"}
125
+ end
126
+
127
+ When /^I return next time$/ do
128
+ When %{session is cleared}
129
+ And %{I go to the homepage}
130
+ end
@@ -0,0 +1,219 @@
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 'cgi'
10
+ require File.expand_path(File.join(File.dirname(__FILE__), "..", "support", "paths"))
11
+
12
+ module WithinHelpers
13
+ def with_scope(locator)
14
+ locator ? within(locator) { yield } : yield
15
+ end
16
+ end
17
+ World(WithinHelpers)
18
+
19
+ Given /^(?:|I )am on (.+)$/ do |page_name|
20
+ visit path_to(page_name)
21
+ end
22
+
23
+ When /^(?:|I )go to (.+)$/ do |page_name|
24
+ visit path_to(page_name)
25
+ end
26
+
27
+ When /^(?:|I )press "([^"]*)"(?: within "([^"]*)")?$/ do |button, selector|
28
+ with_scope(selector) do
29
+ click_button(button)
30
+ end
31
+ end
32
+
33
+ When /^(?:|I )follow "([^"]*)"(?: within "([^"]*)")?$/ do |link, selector|
34
+ with_scope(selector) do
35
+ click_link(link)
36
+ end
37
+ end
38
+
39
+ When /^(?:|I )fill in "([^"]*)" with "([^"]*)"(?: within "([^"]*)")?$/ do |field, value, selector|
40
+ with_scope(selector) do
41
+ fill_in(field, :with => value)
42
+ end
43
+ end
44
+
45
+ When /^(?:|I )fill in "([^"]*)" for "([^"]*)"(?: within "([^"]*)")?$/ do |value, field, selector|
46
+ with_scope(selector) do
47
+ fill_in(field, :with => value)
48
+ end
49
+ end
50
+
51
+ # Use this to fill in an entire form with data from a table. Example:
52
+ #
53
+ # When I fill in the following:
54
+ # | Account Number | 5002 |
55
+ # | Expiry date | 2009-11-01 |
56
+ # | Note | Nice guy |
57
+ # | Wants Email? | |
58
+ #
59
+ # TODO: Add support for checkbox, select og option
60
+ # based on naming conventions.
61
+ #
62
+ When /^(?:|I )fill in the following(?: within "([^"]*)")?:$/ do |selector, fields|
63
+ with_scope(selector) do
64
+ fields.rows_hash.each do |name, value|
65
+ When %{I fill in "#{name}" with "#{value}"}
66
+ end
67
+ end
68
+ end
69
+
70
+ When /^(?:|I )select "([^"]*)" from "([^"]*)"(?: within "([^"]*)")?$/ do |value, field, selector|
71
+ with_scope(selector) do
72
+ select(value, :from => field)
73
+ end
74
+ end
75
+
76
+ When /^(?:|I )check "([^"]*)"(?: within "([^"]*)")?$/ do |field, selector|
77
+ with_scope(selector) do
78
+ check(field)
79
+ end
80
+ end
81
+
82
+ When /^(?:|I )uncheck "([^"]*)"(?: within "([^"]*)")?$/ do |field, selector|
83
+ with_scope(selector) do
84
+ uncheck(field)
85
+ end
86
+ end
87
+
88
+ When /^(?:|I )choose "([^"]*)"(?: within "([^"]*)")?$/ do |field, selector|
89
+ with_scope(selector) do
90
+ choose(field)
91
+ end
92
+ end
93
+
94
+ When /^(?:|I )attach the file "([^"]*)" to "([^"]*)"(?: within "([^"]*)")?$/ do |path, field, selector|
95
+ with_scope(selector) do
96
+ attach_file(field, path)
97
+ end
98
+ end
99
+
100
+ Then /^(?:|I )should see JSON:$/ do |expected_json|
101
+ require 'json'
102
+ expected = JSON.pretty_generate(JSON.parse(expected_json))
103
+ actual = JSON.pretty_generate(JSON.parse(response.body))
104
+ expected.should == actual
105
+ end
106
+
107
+ Then /^(?:|I )should see "([^"]*)"(?: within "([^"]*)")?$/ do |text, selector|
108
+ with_scope(selector) do
109
+ if page.respond_to? :should
110
+ page.should have_content(text)
111
+ else
112
+ assert page.has_content?(text)
113
+ end
114
+ end
115
+ end
116
+
117
+ Then /^(?:|I )should see \/([^\/]*)\/(?: within "([^"]*)")?$/ do |regexp, selector|
118
+ regexp = Regexp.new(regexp)
119
+ with_scope(selector) do
120
+ if page.respond_to? :should
121
+ page.should have_xpath('//*', :text => regexp)
122
+ else
123
+ assert page.has_xpath?('//*', :text => regexp)
124
+ end
125
+ end
126
+ end
127
+
128
+ Then /^(?:|I )should not see "([^"]*)"(?: within "([^"]*)")?$/ do |text, selector|
129
+ with_scope(selector) do
130
+ if page.respond_to? :should
131
+ page.should have_no_content(text)
132
+ else
133
+ assert page.has_no_content?(text)
134
+ end
135
+ end
136
+ end
137
+
138
+ Then /^(?:|I )should not see \/([^\/]*)\/(?: within "([^"]*)")?$/ do |regexp, selector|
139
+ regexp = Regexp.new(regexp)
140
+ with_scope(selector) do
141
+ if page.respond_to? :should
142
+ page.should have_no_xpath('//*', :text => regexp)
143
+ else
144
+ assert page.has_no_xpath?('//*', :text => regexp)
145
+ end
146
+ end
147
+ end
148
+
149
+ Then /^the "([^"]*)" field(?: within "([^"]*)")? should contain "([^"]*)"$/ do |field, selector, value|
150
+ with_scope(selector) do
151
+ field = find_field(field)
152
+ field_value = (field.tag_name == 'textarea') ? field.text : field.value
153
+ if field_value.respond_to? :should
154
+ field_value.should =~ /#{value}/
155
+ else
156
+ assert_match(/#{value}/, field_value)
157
+ end
158
+ end
159
+ end
160
+
161
+ Then /^the "([^"]*)" field(?: within "([^"]*)")? should not contain "([^"]*)"$/ do |field, selector, value|
162
+ with_scope(selector) do
163
+ field = find_field(field)
164
+ field_value = (field.tag_name == 'textarea') ? field.text : field.value
165
+ if field_value.respond_to? :should_not
166
+ field_value.should_not =~ /#{value}/
167
+ else
168
+ assert_no_match(/#{value}/, field_value)
169
+ end
170
+ end
171
+ end
172
+
173
+ Then /^the "([^"]*)" checkbox(?: within "([^"]*)")? should be checked$/ do |label, selector|
174
+ with_scope(selector) do
175
+ field_checked = find_field(label)['checked']
176
+ if field_checked.respond_to? :should
177
+ field_checked.should be_true
178
+ else
179
+ assert field_checked
180
+ end
181
+ end
182
+ end
183
+
184
+ Then /^the "([^"]*)" checkbox(?: within "([^"]*)")? should not be checked$/ do |label, selector|
185
+ with_scope(selector) do
186
+ field_checked = find_field(label)['checked']
187
+ if field_checked.respond_to? :should
188
+ field_checked.should be_false
189
+ else
190
+ assert !field_checked
191
+ end
192
+ end
193
+ end
194
+
195
+ Then /^(?:|I )should be on (.+)$/ do |page_name|
196
+ current_path = URI.parse(current_url).path
197
+ if current_path.respond_to? :should
198
+ current_path.should == path_to(page_name)
199
+ else
200
+ assert_equal path_to(page_name), current_path
201
+ end
202
+ end
203
+
204
+ Then /^(?:|I )should have the following query string:$/ do |expected_pairs|
205
+ query = URI.parse(current_url).query
206
+ actual_params = query ? CGI.parse(query) : {}
207
+ expected_params = {}
208
+ expected_pairs.rows_hash.each_pair{|k,v| expected_params[k] = v.split(',')}
209
+
210
+ if actual_params.respond_to? :should
211
+ actual_params.should == expected_params
212
+ else
213
+ assert_equal expected_params, actual_params
214
+ end
215
+ end
216
+
217
+ Then /^show me the page$/ do
218
+ save_and_open_page
219
+ end