shoulda-matchers 2.7.0 → 2.8.0.rc1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (190) hide show
  1. checksums.yaml +4 -4
  2. data/.travis.yml +13 -3
  3. data/Appraisals +18 -0
  4. data/CONTRIBUTING.md +13 -29
  5. data/Gemfile +1 -4
  6. data/Gemfile.lock +2 -10
  7. data/NEWS.md +100 -14
  8. data/README.md +62 -58
  9. data/Rakefile +9 -16
  10. data/gemfiles/3.0.gemfile +11 -12
  11. data/gemfiles/3.0.gemfile.lock +15 -10
  12. data/gemfiles/3.1.gemfile +11 -12
  13. data/gemfiles/3.1.gemfile.lock +14 -10
  14. data/gemfiles/3.1_1.9.2.gemfile +12 -11
  15. data/gemfiles/3.1_1.9.2.gemfile.lock +14 -3
  16. data/gemfiles/3.2.gemfile +11 -12
  17. data/gemfiles/3.2.gemfile.lock +15 -10
  18. data/gemfiles/3.2_1.9.2.gemfile +12 -11
  19. data/gemfiles/3.2_1.9.2.gemfile.lock +14 -2
  20. data/gemfiles/4.0.0.gemfile +10 -12
  21. data/gemfiles/4.0.0.gemfile.lock +13 -10
  22. data/gemfiles/4.0.1.gemfile +10 -12
  23. data/gemfiles/4.0.1.gemfile.lock +13 -10
  24. data/gemfiles/4.1.gemfile +13 -15
  25. data/gemfiles/4.1.gemfile.lock +45 -50
  26. data/gemfiles/4.2.gemfile +36 -0
  27. data/gemfiles/4.2.gemfile.lock +245 -0
  28. data/lib/shoulda/matchers.rb +3 -1
  29. data/lib/shoulda/matchers/action_controller.rb +1 -1
  30. data/lib/shoulda/matchers/action_controller/redirect_to_matcher.rb +1 -1
  31. data/lib/shoulda/matchers/action_controller/route_params.rb +9 -4
  32. data/lib/shoulda/matchers/action_controller/{set_the_flash_matcher.rb → set_flash_matcher.rb} +34 -26
  33. data/lib/shoulda/matchers/action_controller/set_session_matcher.rb +125 -69
  34. data/lib/shoulda/matchers/active_model.rb +1 -2
  35. data/lib/shoulda/matchers/active_model/allow_value_matcher.rb +18 -5
  36. data/lib/shoulda/matchers/active_model/exception_message_finder.rb +2 -2
  37. data/lib/shoulda/matchers/active_model/helpers.rb +4 -4
  38. data/lib/shoulda/matchers/active_model/validate_confirmation_of_matcher.rb +10 -3
  39. data/lib/shoulda/matchers/active_model/validate_exclusion_of_matcher.rb +1 -1
  40. data/lib/shoulda/matchers/active_model/validate_inclusion_of_matcher.rb +3 -1
  41. data/lib/shoulda/matchers/active_model/{ensure_length_of_matcher.rb → validate_length_of_matcher.rb} +30 -20
  42. data/lib/shoulda/matchers/active_model/validate_presence_of_matcher.rb +21 -0
  43. data/lib/shoulda/matchers/active_model/validation_message_finder.rb +2 -2
  44. data/lib/shoulda/matchers/active_record.rb +2 -0
  45. data/lib/shoulda/matchers/active_record/association_matcher.rb +96 -2
  46. data/lib/shoulda/matchers/active_record/association_matchers/join_table_matcher.rb +1 -1
  47. data/lib/shoulda/matchers/active_record/association_matchers/model_reflection.rb +3 -3
  48. data/lib/shoulda/matchers/active_record/association_matchers/option_verifier.rb +22 -2
  49. data/lib/shoulda/matchers/active_record/have_db_column_matcher.rb +30 -4
  50. data/lib/shoulda/matchers/active_record/serialize_matcher.rb +19 -3
  51. data/lib/shoulda/matchers/active_record/uniqueness.rb +14 -0
  52. data/lib/shoulda/matchers/active_record/uniqueness/model.rb +45 -0
  53. data/lib/shoulda/matchers/active_record/uniqueness/namespace.rb +36 -0
  54. data/lib/shoulda/matchers/active_record/uniqueness/test_model_creator.rb +50 -0
  55. data/lib/shoulda/matchers/active_record/uniqueness/test_models.rb +24 -0
  56. data/lib/shoulda/matchers/{active_model → active_record}/validate_uniqueness_of_matcher.rb +76 -16
  57. data/lib/shoulda/matchers/independent/delegate_method_matcher.rb +117 -51
  58. data/lib/shoulda/matchers/independent/delegate_method_matcher/target_not_defined_error.rb +1 -1
  59. data/lib/shoulda/matchers/matcher_context.rb +35 -0
  60. data/lib/shoulda/matchers/rails_shim.rb +23 -0
  61. data/lib/shoulda/matchers/util.rb +28 -0
  62. data/lib/shoulda/matchers/version.rb +1 -1
  63. data/script/SUPPORTED_VERSIONS +1 -1
  64. data/spec/acceptance/active_model_integration_spec.rb +20 -0
  65. data/spec/acceptance/independent_matchers_spec.rb +64 -0
  66. data/spec/acceptance/rails_integration_spec.rb +142 -0
  67. data/spec/acceptance_spec_helper.rb +23 -0
  68. data/spec/support/acceptance/helpers.rb +29 -0
  69. data/spec/support/acceptance/helpers/active_model_helpers.rb +11 -0
  70. data/spec/support/acceptance/helpers/array_helpers.rb +13 -0
  71. data/spec/support/acceptance/helpers/base_helpers.rb +14 -0
  72. data/spec/support/acceptance/helpers/command_helpers.rb +51 -0
  73. data/spec/support/acceptance/helpers/file_helpers.rb +19 -0
  74. data/spec/support/acceptance/helpers/gem_helpers.rb +31 -0
  75. data/spec/support/acceptance/helpers/minitest_helpers.rb +19 -0
  76. data/spec/support/acceptance/helpers/pluralization_helpers.rb +13 -0
  77. data/spec/support/acceptance/helpers/rails_version_helpers.rb +11 -0
  78. data/spec/support/acceptance/helpers/rspec_helpers.rb +26 -0
  79. data/spec/support/acceptance/helpers/ruby_version_helpers.rb +9 -0
  80. data/spec/support/acceptance/helpers/step_helpers.rb +117 -0
  81. data/spec/support/acceptance/matchers/have_output.rb +31 -0
  82. data/spec/support/acceptance/matchers/indicate_number_of_tests_was_run_matcher.rb +55 -0
  83. data/spec/support/acceptance/matchers/indicate_that_tests_were_run_matcher.rb +103 -0
  84. data/spec/support/tests/bundle.rb +94 -0
  85. data/spec/support/tests/command_runner.rb +214 -0
  86. data/spec/support/tests/filesystem.rb +77 -0
  87. data/spec/support/tests/version.rb +45 -0
  88. data/spec/support/unit/capture.rb +34 -0
  89. data/spec/support/unit/helpers/active_model_helpers.rb +25 -0
  90. data/spec/support/unit/helpers/active_model_versions.rb +20 -0
  91. data/spec/support/unit/helpers/active_resource_builder.rb +27 -0
  92. data/spec/support/unit/helpers/allow_value_matcher_helpers.rb +15 -0
  93. data/spec/support/unit/helpers/class_builder.rb +72 -0
  94. data/spec/support/unit/helpers/confirmation_matcher_helpers.rb +17 -0
  95. data/spec/support/unit/helpers/controller_builder.rb +91 -0
  96. data/spec/support/unit/helpers/i18n_faker.rb +15 -0
  97. data/spec/support/unit/helpers/mailer_builder.rb +12 -0
  98. data/spec/support/unit/helpers/model_builder.rb +102 -0
  99. data/spec/support/unit/helpers/rails_versions.rb +28 -0
  100. data/spec/support/unit/i18n.rb +7 -0
  101. data/spec/support/unit/matchers/deprecate.rb +60 -0
  102. data/spec/support/unit/matchers/fail_with_message_including_matcher.rb +50 -0
  103. data/spec/support/unit/matchers/fail_with_message_matcher.rb +50 -0
  104. data/spec/support/unit/matchers/print_warning_including.rb +59 -0
  105. data/spec/support/unit/rails_application.rb +110 -0
  106. data/spec/support/unit/record_builder_with_i18n_validation_message.rb +69 -0
  107. data/spec/support/unit/record_validating_confirmation_builder.rb +56 -0
  108. data/spec/support/unit/record_with_different_error_attribute_builder.rb +92 -0
  109. data/spec/support/{shared_examples → unit/shared_examples}/numerical_submatcher.rb +0 -2
  110. data/spec/support/{shared_examples → unit/shared_examples}/numerical_type_submatcher.rb +0 -2
  111. data/spec/{shoulda → unit/shoulda}/matchers/action_controller/callback_matcher_spec.rb +2 -2
  112. data/spec/{shoulda → unit/shoulda}/matchers/action_controller/filter_param_matcher_spec.rb +2 -2
  113. data/spec/{shoulda → unit/shoulda}/matchers/action_controller/redirect_to_matcher_spec.rb +3 -3
  114. data/spec/{shoulda → unit/shoulda}/matchers/action_controller/render_template_matcher_spec.rb +2 -4
  115. data/spec/{shoulda → unit/shoulda}/matchers/action_controller/render_with_layout_matcher_spec.rb +9 -6
  116. data/spec/{shoulda → unit/shoulda}/matchers/action_controller/rescue_from_matcher_spec.rb +2 -2
  117. data/spec/{shoulda → unit/shoulda}/matchers/action_controller/respond_with_matcher_spec.rb +2 -2
  118. data/spec/unit/shoulda/matchers/action_controller/route_matcher_spec.rb +126 -0
  119. data/spec/{shoulda → unit/shoulda}/matchers/action_controller/route_params_spec.rb +2 -2
  120. data/spec/unit/shoulda/matchers/action_controller/set_flash_matcher_spec.rb +167 -0
  121. data/spec/unit/shoulda/matchers/action_controller/set_session_matcher_spec.rb +294 -0
  122. data/spec/{shoulda → unit/shoulda}/matchers/action_controller/strong_parameters_matcher_spec.rb +19 -11
  123. data/spec/{shoulda → unit/shoulda}/matchers/active_model/allow_mass_assignment_of_matcher_spec.rb +2 -2
  124. data/spec/{shoulda → unit/shoulda}/matchers/active_model/allow_value_matcher_spec.rb +49 -21
  125. data/spec/{shoulda → unit/shoulda}/matchers/active_model/disallow_value_matcher_spec.rb +8 -4
  126. data/spec/{shoulda → unit/shoulda}/matchers/active_model/exception_message_finder_spec.rb +4 -4
  127. data/spec/{shoulda → unit/shoulda}/matchers/active_model/have_secure_password_matcher_spec.rb +2 -2
  128. data/spec/{shoulda → unit/shoulda}/matchers/active_model/helpers_spec.rb +7 -3
  129. data/spec/{shoulda → unit/shoulda}/matchers/active_model/numericality_matchers/comparison_matcher_spec.rb +1 -1
  130. data/spec/{shoulda → unit/shoulda}/matchers/active_model/numericality_matchers/even_number_matcher_spec.rb +1 -1
  131. data/spec/{shoulda → unit/shoulda}/matchers/active_model/numericality_matchers/odd_number_matcher_spec.rb +1 -1
  132. data/spec/{shoulda → unit/shoulda}/matchers/active_model/numericality_matchers/only_integer_matcher_spec.rb +1 -1
  133. data/spec/{shoulda → unit/shoulda}/matchers/active_model/validate_absence_of_matcher_spec.rb +3 -3
  134. data/spec/{shoulda → unit/shoulda}/matchers/active_model/validate_acceptance_of_matcher_spec.rb +2 -2
  135. data/spec/unit/shoulda/matchers/active_model/validate_confirmation_of_matcher_spec.rb +63 -0
  136. data/spec/{shoulda → unit/shoulda}/matchers/active_model/validate_exclusion_of_matcher_spec.rb +5 -4
  137. data/spec/{shoulda → unit/shoulda}/matchers/active_model/validate_inclusion_of_matcher_spec.rb +7 -14
  138. data/spec/{shoulda/matchers/active_model/ensure_length_of_matcher_spec.rb → unit/shoulda/matchers/active_model/validate_length_of_matcher_spec.rb} +43 -23
  139. data/spec/{shoulda → unit/shoulda}/matchers/active_model/validate_numericality_of_matcher_spec.rb +3 -4
  140. data/spec/{shoulda → unit/shoulda}/matchers/active_model/validate_presence_of_matcher_spec.rb +3 -3
  141. data/spec/{shoulda → unit/shoulda}/matchers/active_model/validate_uniqueness_of_matcher_spec.rb +127 -2
  142. data/spec/{shoulda → unit/shoulda}/matchers/active_model/validation_message_finder_spec.rb +8 -6
  143. data/spec/{shoulda → unit/shoulda}/matchers/active_record/accept_nested_attributes_for_matcher_spec.rb +2 -2
  144. data/spec/{shoulda → unit/shoulda}/matchers/active_record/association_matcher_spec.rb +217 -26
  145. data/spec/{shoulda → unit/shoulda}/matchers/active_record/association_matchers/model_reflection_spec.rb +2 -2
  146. data/spec/{shoulda → unit/shoulda}/matchers/active_record/define_enum_for_matcher_spec.rb +2 -2
  147. data/spec/{shoulda → unit/shoulda}/matchers/active_record/have_db_column_matcher_spec.rb +2 -2
  148. data/spec/{shoulda → unit/shoulda}/matchers/active_record/have_db_index_matcher_spec.rb +8 -5
  149. data/spec/{shoulda → unit/shoulda}/matchers/active_record/have_readonly_attributes_matcher_spec.rb +2 -2
  150. data/spec/{shoulda → unit/shoulda}/matchers/active_record/serialize_matcher_spec.rb +3 -3
  151. data/spec/{shoulda → unit/shoulda}/matchers/doublespeak/double_collection_spec.rb +29 -7
  152. data/spec/{shoulda → unit/shoulda}/matchers/doublespeak/double_implementation_registry_spec.rb +1 -1
  153. data/spec/{shoulda → unit/shoulda}/matchers/doublespeak/double_spec.rb +20 -10
  154. data/spec/{shoulda → unit/shoulda}/matchers/doublespeak/object_double_spec.rb +1 -1
  155. data/spec/{shoulda → unit/shoulda}/matchers/doublespeak/proxy_implementation_spec.rb +13 -6
  156. data/spec/{shoulda → unit/shoulda}/matchers/doublespeak/stub_implementation_spec.rb +2 -2
  157. data/spec/unit/shoulda/matchers/doublespeak/world_spec.rb +77 -0
  158. data/spec/{shoulda → unit/shoulda}/matchers/doublespeak_spec.rb +11 -3
  159. data/spec/{shoulda → unit/shoulda}/matchers/independent/delegate_method_matcher/stubbed_target_spec.rb +1 -1
  160. data/spec/unit/shoulda/matchers/independent/delegate_method_matcher_spec.rb +517 -0
  161. data/spec/unit_spec_helper.rb +66 -0
  162. data/spec/warnings_spy/partitioner.rb +10 -3
  163. data/spec/warnings_spy/reader.rb +9 -20
  164. data/spec/warnings_spy/reporter.rb +2 -1
  165. metadata +212 -149
  166. data/features/activemodel_integration.feature +0 -15
  167. data/features/rails_integration.feature +0 -160
  168. data/features/step_definitions/activemodel_steps.rb +0 -21
  169. data/features/step_definitions/rails_steps.rb +0 -227
  170. data/features/support/env.rb +0 -6
  171. data/spec/shoulda/matchers/action_controller/route_matcher_spec.rb +0 -70
  172. data/spec/shoulda/matchers/action_controller/set_session_matcher_spec.rb +0 -113
  173. data/spec/shoulda/matchers/action_controller/set_the_flash_matcher_spec.rb +0 -153
  174. data/spec/shoulda/matchers/active_model/validate_confirmation_of_matcher_spec.rb +0 -47
  175. data/spec/shoulda/matchers/doublespeak/world_spec.rb +0 -70
  176. data/spec/shoulda/matchers/independent/delegate_method_matcher_spec.rb +0 -309
  177. data/spec/spec_helper.rb +0 -42
  178. data/spec/support/active_model_versions.rb +0 -13
  179. data/spec/support/active_resource_builder.rb +0 -29
  180. data/spec/support/activemodel_helpers.rb +0 -23
  181. data/spec/support/capture_helpers.rb +0 -19
  182. data/spec/support/class_builder.rb +0 -46
  183. data/spec/support/controller_builder.rb +0 -102
  184. data/spec/support/fail_with_message_including_matcher.rb +0 -44
  185. data/spec/support/fail_with_message_matcher.rb +0 -44
  186. data/spec/support/i18n_faker.rb +0 -10
  187. data/spec/support/mailer_builder.rb +0 -10
  188. data/spec/support/model_builder.rb +0 -81
  189. data/spec/support/rails_versions.rb +0 -26
  190. data/spec/support/test_application.rb +0 -120
@@ -5,45 +5,53 @@ module Shoulda
5
5
  # `session` hash.
6
6
  #
7
7
  # class PostsController < ApplicationController
8
- # def show
9
- # session[:foo] = 'bar'
8
+ # def index
9
+ # session[:foo] = 'A candy bar'
10
+ # end
11
+ #
12
+ # def destroy
10
13
  # end
11
14
  # end
12
15
  #
13
16
  # # RSpec
14
17
  # describe PostsController do
15
- # describe 'GET #show' do
16
- # before { get :show }
18
+ # describe 'GET #index' do
19
+ # before { get :index }
17
20
  #
18
- # it { should set_session(:foo) }
19
- # it { should_not set_session(:baz) }
21
+ # it { should set_session }
22
+ # end
23
+ #
24
+ # describe 'DELETE #destroy' do
25
+ # before { delete :destroy }
26
+ #
27
+ # it { should_not set_session }
20
28
  # end
21
29
  # end
22
30
  #
23
31
  # # Test::Unit
24
32
  # class PostsControllerTest < ActionController::TestCase
25
- # context 'GET #show' do
26
- # setup { get :show }
33
+ # context 'GET #index' do
34
+ # setup { get :index }
27
35
  #
28
- # should set_session(:foo)
29
- # should_not set_session(:baz)
36
+ # should set_session
37
+ # end
38
+ #
39
+ # context 'DELETE #destroy' do
40
+ # setup { delete :destroy }
41
+ #
42
+ # should_not set_session
30
43
  # end
31
44
  # end
32
45
  #
33
46
  # #### Qualifiers
34
47
  #
35
- # ##### to
48
+ # ##### []
36
49
  #
37
- # Use `to` to assert that the key in the session hash was set to a
38
- # particular value.
50
+ # Use `[]` to narrow the scope of the matcher to a particular key.
39
51
  #
40
52
  # class PostsController < ApplicationController
41
53
  # def index
42
- # session[:foo] = 'bar'
43
- # end
44
- #
45
- # def show
46
- # session[:foo] = nil
54
+ # session[:foo] = 'A candy bar'
47
55
  # end
48
56
  # end
49
57
  #
@@ -52,48 +60,81 @@ module Shoulda
52
60
  # describe 'GET #index' do
53
61
  # before { get :index }
54
62
  #
55
- # it { should set_session(:foo).to('bar') }
56
- # it { should_not set_session(:foo).to('something else') }
57
- # it { should_not set_session(:foo).to(nil) }
58
- # end
59
- #
60
- # describe 'GET #show' do
61
- # before { get :show }
62
- #
63
- # it { should set_session(:foo).to(nil) }
63
+ # it { should set_session[:foo] }
64
+ # it { should_not set_session[:bar] }
64
65
  # end
65
66
  # end
66
67
  #
67
68
  # # Test::Unit
68
69
  # class PostsControllerTest < ActionController::TestCase
69
70
  # context 'GET #index' do
70
- # setup { get :index }
71
+ # setup { get :show }
72
+ #
73
+ # should set_session[:foo]
74
+ # should_not set_session[:bar]
75
+ # end
76
+ # end
77
+ #
78
+ # ##### to
79
+ #
80
+ # Use `to` to assert that some key was set to a particular value, or that
81
+ # some key matches a particular regex.
71
82
  #
72
- # should set_session(:foo).to('bar')
73
- # should_not set_session(:foo).to('something else')
74
- # should_not set_session(:foo).to(nil)
83
+ # class PostsController < ApplicationController
84
+ # def index
85
+ # session[:foo] = 'A candy bar'
75
86
  # end
87
+ # end
76
88
  #
77
- # context 'GET #show' do
89
+ # # RSpec
90
+ # describe PostsController do
91
+ # describe 'GET #index' do
92
+ # before { get :index }
93
+ #
94
+ # it { should set_session.to('A candy bar') }
95
+ # it { should set_session.to(/bar/) }
96
+ # it { should set_session[:foo].to('bar') }
97
+ # it { should_not set_session[:foo].to('something else') }
98
+ # end
99
+ # end
100
+ #
101
+ # # Test::Unit
102
+ # class PostsControllerTest < ActionController::TestCase
103
+ # context 'GET #index' do
78
104
  # setup { get :show }
79
105
  #
80
- # should set_session(:foo).to(nil)
106
+ # should set_session.to('A candy bar')
107
+ # should set_session.to(/bar/)
108
+ # should set_session[:foo].to('bar')
109
+ # should_not set_session[:foo].to('something else')
81
110
  # end
82
111
  # end
83
112
  #
84
113
  # @return [SetSessionMatcher]
85
114
  #
86
- def set_session(key)
115
+ def set_session(key = nil)
87
116
  SetSessionMatcher.new(key)
88
117
  end
89
118
 
90
119
  # @private
91
120
  class SetSessionMatcher
92
121
  def initialize(key)
93
- @key = key.to_s
122
+ if key
123
+ Shoulda::Matchers.warn <<EOT
124
+ Passing a key to set_session is deprecated.
125
+ Please use the hash syntax instead (e.g., `set_session[:foo]`, not `set_session(:foo)`).
126
+ EOT
127
+ self[key]
128
+ end
129
+
94
130
  @value_block = nil
95
131
  end
96
132
 
133
+ def [](key)
134
+ @key = key.to_s
135
+ self
136
+ end
137
+
97
138
  def to(value = nil, &block)
98
139
  @value = value
99
140
  @value_block = block
@@ -102,10 +143,27 @@ module Shoulda
102
143
 
103
144
  def matches?(controller)
104
145
  @controller = controller
146
+
105
147
  if @value_block
106
148
  @value = @context.instance_eval(&@value_block)
107
149
  end
108
- assigned_correct_value? || cleared_value?
150
+
151
+ if nil_value_expected_but_actual_value_unset?
152
+ Shoulda::Matchers.warn <<EOT
153
+ Using `should set_session[...].to(nil)` to assert that a variable is unset is deprecated.
154
+ Please use `should_not set_session[...]` instead.
155
+ EOT
156
+ end
157
+
158
+ if key_specified? && value_specified?
159
+ @value === session[@key]
160
+ elsif key_specified?
161
+ session.key?(@key)
162
+ elsif value_specified?
163
+ session.values.any? { |value| @value === value }
164
+ else
165
+ session_present?
166
+ end
109
167
  end
110
168
 
111
169
  def failure_message
@@ -114,16 +172,12 @@ module Shoulda
114
172
  alias failure_message_for_should failure_message
115
173
 
116
174
  def failure_message_when_negated
117
- "Didn't expect #{expectation}, but #{result}"
175
+ "Didn't expect #{expectation}, but it was"
118
176
  end
119
177
  alias failure_message_for_should_not failure_message_when_negated
120
178
 
121
179
  def description
122
- description = "set session variable #{@key.inspect}"
123
- if @value
124
- description << " to #{@value.inspect}"
125
- end
126
- description
180
+ "should #{expectation}"
127
181
  end
128
182
 
129
183
  def in_context(context)
@@ -133,54 +187,56 @@ module Shoulda
133
187
 
134
188
  private
135
189
 
136
- def value_or_default_value
137
- defined?(@value) && @value
190
+ def key_specified?
191
+ defined?(@key)
138
192
  end
139
193
 
140
- def assigned_value?
141
- !assigned_value.nil?
194
+ def value_specified?
195
+ defined?(@value)
142
196
  end
143
197
 
144
- def cleared_value?
145
- defined?(@value) && @value.nil? && assigned_value.nil?
198
+ def value_or_default_value
199
+ defined?(@value) && @value
146
200
  end
147
201
 
148
- def assigned_correct_value?
149
- if assigned_value?
150
- if !defined?(@value)
151
- true
152
- else
153
- assigned_value == value_or_default_value
154
- end
155
- end
202
+ def nil_value_expected_but_actual_value_unset?
203
+ value_specified? && @value.nil? && !session.key?(@key)
156
204
  end
157
205
 
158
- def assigned_value
159
- session[@key]
206
+ def session_present?
207
+ !session.empty?
160
208
  end
161
209
 
162
210
  def expectation
163
- expectation = "session variable #{@key} to be set"
211
+ expectation = ""
212
+
213
+ if key_specified?
214
+ expectation << "session variable #{@key.inspect}"
215
+ else
216
+ expectation << "any session variable"
217
+ end
164
218
 
165
- if value_or_default_value
166
- expectation << " to #{value_or_default_value.inspect}"
219
+ expectation << " to be"
220
+
221
+ if value_specified? && !@value.nil?
222
+ expectation << " #{@value.inspect}"
223
+ else
224
+ expectation << " set"
167
225
  end
226
+
227
+ expectation
168
228
  end
169
229
 
170
230
  def result
171
- if session.empty?
172
- 'no session variables were set'
173
- else
231
+ if session_present?
174
232
  "the session was #{session.inspect}"
233
+ else
234
+ 'no session variables were set'
175
235
  end
176
236
  end
177
237
 
178
238
  def session
179
- if @controller.request.respond_to?(:session)
180
- @controller.request.session.to_hash
181
- else
182
- @controller.response.session.data
183
- end
239
+ @controller.session
184
240
  end
185
241
  end
186
242
  end
@@ -4,12 +4,11 @@ require 'shoulda/matchers/active_model/validation_message_finder'
4
4
  require 'shoulda/matchers/active_model/exception_message_finder'
5
5
  require 'shoulda/matchers/active_model/allow_value_matcher'
6
6
  require 'shoulda/matchers/active_model/disallow_value_matcher'
7
- require 'shoulda/matchers/active_model/ensure_length_of_matcher'
7
+ require 'shoulda/matchers/active_model/validate_length_of_matcher'
8
8
  require 'shoulda/matchers/active_model/validate_inclusion_of_matcher'
9
9
  require 'shoulda/matchers/active_model/validate_exclusion_of_matcher'
10
10
  require 'shoulda/matchers/active_model/validate_absence_of_matcher'
11
11
  require 'shoulda/matchers/active_model/validate_presence_of_matcher'
12
- require 'shoulda/matchers/active_model/validate_uniqueness_of_matcher'
13
12
  require 'shoulda/matchers/active_model/validate_acceptance_of_matcher'
14
13
  require 'shoulda/matchers/active_model/validate_confirmation_of_matcher'
15
14
  require 'shoulda/matchers/active_model/validate_numericality_of_matcher'
@@ -224,12 +224,12 @@ module Shoulda
224
224
  end
225
225
 
226
226
  def failure_message
227
- "Did not expect #{expectation}, got error: #{matched_error}"
227
+ "Did not expect #{expectation},\ngot error: #{matched_error}"
228
228
  end
229
229
  alias failure_message_for_should failure_message
230
230
 
231
231
  def failure_message_when_negated
232
- "Expected #{expectation}, got #{error_description}"
232
+ "Expected #{expectation},\ngot#{error_description}"
233
233
  end
234
234
  alias failure_message_for_should_not failure_message_when_negated
235
235
 
@@ -281,8 +281,21 @@ module Shoulda
281
281
  end
282
282
 
283
283
  def expectation
284
- includes_expected_message = expected_message ? "to include #{expected_message.inspect}" : ''
285
- [error_source, includes_expected_message, "when #{attribute_to_set} is set to #{value.inspect}"].join(' ')
284
+ parts = [
285
+ error_source,
286
+ includes_expected_message,
287
+ "when #{attribute_to_set} is set to #{value.inspect}"
288
+ ]
289
+
290
+ parts.join(' ').squeeze(' ')
291
+ end
292
+
293
+ def includes_expected_message
294
+ if expected_message
295
+ "to include #{expected_message.inspect}"
296
+ else
297
+ ''
298
+ end
286
299
  end
287
300
 
288
301
  def error_source
@@ -326,7 +339,7 @@ module Shoulda
326
339
  defaults = {
327
340
  model_name: model_name,
328
341
  instance: instance,
329
- attribute: attribute_to_set,
342
+ attribute: attribute_to_check_message_against,
330
343
  }
331
344
 
332
345
  defaults.merge(options[:expected_message_values])
@@ -15,9 +15,9 @@ module Shoulda
15
15
 
16
16
  def messages_description
17
17
  if has_messages?
18
- messages.join
18
+ ": #{messages.join.inspect}"
19
19
  else
20
- 'no exception'
20
+ ' no exception'
21
21
  end
22
22
  end
23
23
 
@@ -5,11 +5,11 @@ module Shoulda
5
5
  module Helpers
6
6
  def pretty_error_messages(obj)
7
7
  obj.errors.map do |attribute, message|
8
- full_message = message.dup
8
+ full_message = message.dup.inspect
9
9
  parenthetical_parts = []
10
10
 
11
11
  unless attribute.to_sym == :base
12
- parenthetical_parts << "attribute: #{attribute.to_s.inspect}"
12
+ parenthetical_parts << "attribute: #{attribute}"
13
13
 
14
14
  if obj.respond_to?(attribute)
15
15
  parenthetical_parts << "value: #{obj.__send__(attribute).inspect}"
@@ -20,8 +20,8 @@ module Shoulda
20
20
  full_message << " (#{parenthetical_parts.join(', ')})"
21
21
  end
22
22
 
23
- full_message
24
- end
23
+ "* " + full_message
24
+ end.join("\n")
25
25
  end
26
26
 
27
27
  # Helper method that determines the default error message used by Active
@@ -89,24 +89,31 @@ module Shoulda
89
89
  def disallows_different_value
90
90
  set_confirmation('some value')
91
91
  disallows_value_of('different value') do |matcher|
92
- matcher.with_message(@message, against: error_attribute)
92
+ qualify_matcher(matcher)
93
93
  end
94
94
  end
95
95
 
96
96
  def allows_same_value
97
97
  set_confirmation('same value')
98
98
  allows_value_of('same value') do |matcher|
99
- matcher.with_message(@message, against: error_attribute)
99
+ qualify_matcher(matcher)
100
100
  end
101
101
  end
102
102
 
103
103
  def allows_missing_confirmation
104
104
  set_confirmation(nil)
105
105
  allows_value_of('any value') do |matcher|
106
- matcher.with_message(@message, against: error_attribute)
106
+ qualify_matcher(matcher)
107
107
  end
108
108
  end
109
109
 
110
+ def qualify_matcher(matcher)
111
+ matcher.with_message(@message,
112
+ against: error_attribute,
113
+ values: { attribute: attribute }
114
+ )
115
+ end
116
+
110
117
  def set_confirmation(val)
111
118
  setter = :"#{@confirmation_attribute}="
112
119
  if @subject.respond_to?(setter)
@@ -29,7 +29,7 @@ module Shoulda
29
29
  # in_array(['Mac', 'Linux'])
30
30
  # end
31
31
  #
32
- # If your blacklist is a range of values, use `in_rnage`:
32
+ # If your blacklist is a range of values, use `in_range`:
33
33
  #
34
34
  # class Game
35
35
  # include ActiveModel::Model
@@ -409,7 +409,9 @@ EOT
409
409
  end
410
410
  end
411
411
 
412
- !allows_value_of(*values_outside_of_array)
412
+ !values_outside_of_array.any? do |value|
413
+ allows_value_of(value, @low_message)
414
+ end
413
415
  end
414
416
 
415
417
  def values_outside_of_array