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
@@ -1,4 +1,4 @@
1
- require 'spec_helper'
1
+ require 'unit_spec_helper'
2
2
 
3
3
  describe Shoulda::Matchers::ActiveRecord::AssociationMatchers::ModelReflection do
4
4
  it 'delegates other methods to the given Reflection object' do
@@ -7,7 +7,7 @@ describe Shoulda::Matchers::ActiveRecord::AssociationMatchers::ModelReflection d
7
7
  belongs_to :country
8
8
  end
9
9
  delegate_reflection = person_model.reflect_on_association(:country)
10
- delegate_reflection.stubs(foo: 'bar')
10
+ allow(delegate_reflection).to receive(:foo).and_return('bar')
11
11
  reflection = described_class.new(delegate_reflection)
12
12
 
13
13
  expect(reflection.foo).to eq 'bar'
@@ -1,6 +1,6 @@
1
- require "spec_helper"
1
+ require "unit_spec_helper"
2
2
 
3
- describe Shoulda::Matchers::ActiveRecord::DefineEnumForMatcher do
3
+ describe Shoulda::Matchers::ActiveRecord::DefineEnumForMatcher, type: :model do
4
4
  if active_record_supports_enum?
5
5
  describe "with only the attribute name specified" do
6
6
  it "accepts a record where the attribute is defined as an enum" do
@@ -1,6 +1,6 @@
1
- require 'spec_helper'
1
+ require 'unit_spec_helper'
2
2
 
3
- describe Shoulda::Matchers::ActiveRecord::HaveDbColumnMatcher do
3
+ describe Shoulda::Matchers::ActiveRecord::HaveDbColumnMatcher, type: :model do
4
4
  it 'accepts an existing database column' do
5
5
  expect(model(nickname: :string)).to have_db_column(:nickname)
6
6
  end
@@ -1,6 +1,6 @@
1
- require 'spec_helper'
1
+ require 'unit_spec_helper'
2
2
 
3
- describe Shoulda::Matchers::ActiveRecord::HaveDbIndexMatcher do
3
+ describe Shoulda::Matchers::ActiveRecord::HaveDbIndexMatcher, type: :model do
4
4
  context 'have_db_index' do
5
5
  it 'accepts an existing index' do
6
6
  expect(with_index_on(:age)).to have_db_index(:age)
@@ -65,10 +65,13 @@ describe Shoulda::Matchers::ActiveRecord::HaveDbIndexMatcher do
65
65
  end
66
66
 
67
67
  it 'allows an IndexDefinition to have a truthy value for unique' do
68
- index_definition = stub('ActiveRecord::ConnectionAdapters::IndexDefinition',
69
- unique: 7, name: :age)
68
+ index_definition = double(
69
+ 'ActiveRecord::ConnectionAdapters::IndexDefinition',
70
+ unique: 7,
71
+ name: :age
72
+ )
70
73
  matcher = have_db_index(:age).unique(true)
71
- matcher.stubs(matched_index: index_definition)
74
+ allow(matcher).to receive(:matched_index).and_return(index_definition)
72
75
 
73
76
  expect(with_index_on(:age)).to matcher
74
77
  end
@@ -1,6 +1,6 @@
1
- require 'spec_helper'
1
+ require 'unit_spec_helper'
2
2
 
3
- describe Shoulda::Matchers::ActiveRecord::HaveReadonlyAttributeMatcher do
3
+ describe Shoulda::Matchers::ActiveRecord::HaveReadonlyAttributeMatcher, type: :model do
4
4
  context 'a read-only attribute' do
5
5
  it 'accepts' do
6
6
  expect(with_readonly_attr).to have_readonly_attribute(:attr)
@@ -1,6 +1,6 @@
1
- require 'spec_helper'
1
+ require 'unit_spec_helper'
2
2
 
3
- describe Shoulda::Matchers::ActiveRecord::SerializeMatcher do
3
+ describe Shoulda::Matchers::ActiveRecord::SerializeMatcher, type: :model do
4
4
  it 'accepts when the attribute is serialized' do
5
5
  expect(with_serialized_attr).to serialize(:attr)
6
6
  end
@@ -39,7 +39,7 @@ describe Shoulda::Matchers::ActiveRecord::SerializeMatcher do
39
39
  end
40
40
  end
41
41
 
42
- context 'an attribute that is serialized as a specific type' do
42
+ context 'an attribute that will end up being serialized as YAML' do
43
43
  it 'accepts when the types match' do
44
44
  expect(with_serialized_attr(Hash)).to serialize(:attr).as(Hash)
45
45
  end
@@ -1,34 +1,56 @@
1
- require 'spec_helper'
1
+ require 'unit_spec_helper'
2
2
 
3
3
  module Shoulda::Matchers::Doublespeak
4
4
  describe DoubleCollection do
5
5
  describe '#register_stub' do
6
6
  it 'calls DoubleImplementationRegistry.find correctly' do
7
+ allow(DoubleImplementationRegistry).to receive(:find)
7
8
  double_collection = described_class.new(:klass)
8
- DoubleImplementationRegistry.expects(:find).with(:stub)
9
+
9
10
  double_collection.register_stub(:a_method)
11
+
12
+ expect(DoubleImplementationRegistry).to have_received(:find).with(:stub)
10
13
  end
11
14
 
12
15
  it 'calls Double.new correctly' do
13
- DoubleImplementationRegistry.stubs(:find).returns(:implementation)
16
+ allow(DoubleImplementationRegistry).
17
+ to receive(:find).
18
+ and_return(:implementation)
19
+ allow(Double).to receive(:new)
14
20
  double_collection = described_class.new(:klass)
15
- Double.expects(:new).with(:klass, :a_method, :implementation)
21
+
16
22
  double_collection.register_stub(:a_method)
23
+
24
+ expect(Double).
25
+ to have_received(:new).
26
+ with(:klass, :a_method, :implementation)
17
27
  end
18
28
  end
19
29
 
20
30
  describe '#register_proxy' do
21
31
  it 'calls DoubleImplementationRegistry.find correctly' do
32
+ allow(DoubleImplementationRegistry).to receive(:find)
22
33
  double_collection = described_class.new(:klass)
23
- DoubleImplementationRegistry.expects(:find).with(:proxy)
34
+
24
35
  double_collection.register_proxy(:a_method)
36
+
37
+ expect(DoubleImplementationRegistry).
38
+ to have_received(:find).
39
+ with(:proxy)
25
40
  end
26
41
 
27
42
  it 'calls Double.new correctly' do
28
- DoubleImplementationRegistry.stubs(:find).returns(:implementation)
43
+ allow(DoubleImplementationRegistry).
44
+ to receive(:find).
45
+ and_return(:implementation)
46
+ allow(Double).to receive(:new)
29
47
  double_collection = described_class.new(:klass)
30
- Double.expects(:new).with(:klass, :a_method, :implementation)
48
+
31
49
  double_collection.register_proxy(:a_method)
50
+
51
+ expect(Double).
52
+ to have_received(:new).
53
+ with(:klass, :a_method, :implementation)
32
54
  end
33
55
  end
34
56
 
@@ -1,4 +1,4 @@
1
- require 'spec_helper'
1
+ require 'unit_spec_helper'
2
2
 
3
3
  module Shoulda::Matchers::Doublespeak
4
4
  describe DoubleImplementationRegistry do
@@ -1,4 +1,4 @@
1
- require 'spec_helper'
1
+ require 'unit_spec_helper'
2
2
 
3
3
  module Shoulda::Matchers::Doublespeak
4
4
  describe Double do
@@ -6,7 +6,8 @@ module Shoulda::Matchers::Doublespeak
6
6
  it 'tells its implementation to call the given block' do
7
7
  sent_block = -> { }
8
8
  actual_block = nil
9
- implementation = stub
9
+ implementation = build_implementation
10
+ implementation.singleton_class.__send__(:undef_method, :returns)
10
11
  implementation.singleton_class.__send__(:define_method, :returns) do |&block|
11
12
  actual_block = block
12
13
  end
@@ -16,16 +17,18 @@ module Shoulda::Matchers::Doublespeak
16
17
  end
17
18
 
18
19
  it 'tells its implementation to return the given value' do
19
- implementation = mock()
20
- implementation.expects(:returns).with(:implementation)
20
+ implementation = build_implementation
21
21
  double = described_class.new(:klass, :a_method, implementation)
22
22
  double.to_return(:implementation)
23
+
24
+ expect(implementation).to have_received(:returns).with(:implementation)
23
25
  end
24
26
 
25
27
  it 'prefers a block over a non-block' do
26
28
  sent_block = -> { }
27
29
  actual_block = nil
28
- implementation = stub
30
+ implementation = build_implementation
31
+ implementation.singleton_class.__send__(:undef_method, :returns)
29
32
  implementation.singleton_class.__send__(:define_method, :returns) do |&block|
30
33
  actual_block = block
31
34
  end
@@ -37,22 +40,25 @@ module Shoulda::Matchers::Doublespeak
37
40
 
38
41
  describe '#activate' do
39
42
  it 'replaces the method with an implementation' do
40
- implementation = stub
43
+ implementation = build_implementation
41
44
  klass = create_class(a_method: 42)
42
45
  instance = klass.new
43
46
  double = described_class.new(klass, :a_method, implementation)
44
47
  args = [:any, :args]
45
48
  block = -> {}
46
- implementation.expects(:call).with(double, instance, args, block)
47
49
 
48
50
  double.activate
49
51
  instance.a_method(*args, &block)
52
+
53
+ expect(implementation).
54
+ to have_received(:call).
55
+ with(double, instance, args, block)
50
56
  end
51
57
  end
52
58
 
53
59
  describe '#deactivate' do
54
60
  it 'restores the original method after being doubled' do
55
- implementation = stub(call: nil)
61
+ implementation = build_implementation
56
62
  klass = create_class(a_method: 42)
57
63
  instance = klass.new
58
64
  double = described_class.new(klass, :a_method, implementation)
@@ -63,7 +69,7 @@ module Shoulda::Matchers::Doublespeak
63
69
  end
64
70
 
65
71
  it 'still restores the original method if #activate was called twice' do
66
- implementation = stub(call: nil)
72
+ implementation = build_implementation
67
73
  klass = create_class(a_method: 42)
68
74
  instance = klass.new
69
75
  double = described_class.new(klass, :a_method, implementation)
@@ -75,7 +81,7 @@ module Shoulda::Matchers::Doublespeak
75
81
  end
76
82
 
77
83
  it 'does nothing if the method has not been doubled' do
78
- implementation = stub(call: nil)
84
+ implementation = build_implementation
79
85
  klass = create_class(a_method: 42)
80
86
  instance = klass.new
81
87
  double = described_class.new(klass, :a_method, implementation)
@@ -140,5 +146,9 @@ module Shoulda::Matchers::Doublespeak
140
146
  end
141
147
  end
142
148
  end
149
+
150
+ def build_implementation
151
+ double('implementation', returns: nil, call: nil)
152
+ end
143
153
  end
144
154
  end
@@ -1,4 +1,4 @@
1
- require 'spec_helper'
1
+ require 'unit_spec_helper'
2
2
 
3
3
  module Shoulda::Matchers::Doublespeak
4
4
  describe ObjectDouble do
@@ -1,13 +1,14 @@
1
- require 'spec_helper'
1
+ require 'unit_spec_helper'
2
2
 
3
3
  module Shoulda::Matchers::Doublespeak
4
4
  describe ProxyImplementation do
5
5
  describe '#returns' do
6
6
  it 'delegates to its stub_implementation' do
7
7
  stub_implementation = build_stub_implementation
8
- stub_implementation.expects(:returns).with(:value)
9
8
  implementation = described_class.new(stub_implementation)
10
9
  implementation.returns(:value)
10
+
11
+ expect(stub_implementation).to have_received(:returns).with(:value)
11
12
  end
12
13
  end
13
14
 
@@ -15,26 +16,32 @@ module Shoulda::Matchers::Doublespeak
15
16
  it 'delegates to its stub_implementation' do
16
17
  stub_implementation = build_stub_implementation
17
18
  double = build_double
18
- stub_implementation.expects(:call).with(double, :object, :args, :block)
19
19
  implementation = described_class.new(stub_implementation)
20
20
  implementation.call(double, :object, :args, :block)
21
+
22
+ expect(stub_implementation).
23
+ to have_received(:call).
24
+ with(double, :object, :args, :block)
21
25
  end
22
26
 
23
27
  it 'calls #call_original_method on the double' do
24
28
  stub_implementation = build_stub_implementation
25
29
  implementation = described_class.new(stub_implementation)
26
30
  double = build_double
27
- double.expects(:call_original_method).with(:object, :args, :block)
28
31
  implementation.call(double, :object, :args, :block)
32
+
33
+ expect(double).
34
+ to have_received(:call_original_method).
35
+ with(:object, :args, :block)
29
36
  end
30
37
  end
31
38
 
32
39
  def build_stub_implementation
33
- stub(returns: nil, call: nil)
40
+ double('stub_implementation', returns: nil, call: nil)
34
41
  end
35
42
 
36
43
  def build_double
37
- stub(call_original_method: nil)
44
+ double('double', call_original_method: nil)
38
45
  end
39
46
  end
40
47
  end
@@ -1,4 +1,4 @@
1
- require 'spec_helper'
1
+ require 'unit_spec_helper'
2
2
 
3
3
  module Shoulda::Matchers::Doublespeak
4
4
  describe StubImplementation do
@@ -82,7 +82,7 @@ module Shoulda::Matchers::Doublespeak
82
82
  end
83
83
 
84
84
  def build_double
85
- stub(record_call: nil)
85
+ double('double', record_call: nil)
86
86
  end
87
87
  end
88
88
  end
@@ -0,0 +1,77 @@
1
+ require 'unit_spec_helper'
2
+
3
+ module Shoulda::Matchers::Doublespeak
4
+ describe World do
5
+ describe '#double_collection_for' do
6
+ it 'calls DoubleCollection.new once with the given class' do
7
+ allow(DoubleCollection).to receive(:new).and_return(:klass)
8
+ world = described_class.new
9
+
10
+ world.double_collection_for(:klass)
11
+ world.double_collection_for(:klass)
12
+
13
+ expect(DoubleCollection).to have_received(:new).with(:klass).once
14
+ end
15
+
16
+ it 'returns the created DoubleCollection' do
17
+ double_collection = build_double_collection
18
+ allow(DoubleCollection).
19
+ to receive(:new).
20
+ with(:klass).
21
+ and_return(double_collection)
22
+ world = described_class.new
23
+
24
+ expect(world.double_collection_for(:klass)).to be double_collection
25
+ end
26
+ end
27
+
28
+ describe '#with_doubles_activated' do
29
+ it 'installs all doubles, yields the block, then uninstalls them all' do
30
+ block_called = false
31
+ double_collections = Array.new(3) { build_double_collection }
32
+ double_collections.each do |double_collection|
33
+ allow(double_collection).to receive(:activate).ordered
34
+ end
35
+ double_collections.each do |double_collection|
36
+ allow(double_collection).to receive(:deactivate).ordered
37
+ end
38
+ klasses = Array.new(3) { |i| "Klass #{i}" }
39
+ world = described_class.new
40
+ double_collections.zip(klasses).each do |double_collection, klass|
41
+ allow(DoubleCollection).
42
+ to receive(:new).
43
+ with(klass).
44
+ and_return(double_collection)
45
+ world.double_collection_for(klass)
46
+ end
47
+
48
+ world.with_doubles_activated { block_called = true }
49
+
50
+ expect(block_called).to eq true
51
+
52
+ double_collections.each do |double_collection|
53
+ expect(double_collection).to have_received(:activate)
54
+ expect(double_collection).to have_received(:deactivate)
55
+ end
56
+ end
57
+
58
+ it 'still makes sure to uninstall all doubles even if the block raises an error' do
59
+ double_collection = build_double_collection
60
+ allow(DoubleCollection).to receive(:new).and_return(double_collection)
61
+ world = described_class.new
62
+ world.double_collection_for(:klass)
63
+
64
+ begin
65
+ world.with_doubles_activated { raise 'error' }
66
+ rescue RuntimeError
67
+ end
68
+
69
+ expect(double_collection).to have_received(:deactivate)
70
+ end
71
+ end
72
+
73
+ def build_double_collection
74
+ double('double_collection', activate: nil, deactivate: nil)
75
+ end
76
+ end
77
+ end
@@ -1,18 +1,26 @@
1
- require 'spec_helper'
1
+ require 'unit_spec_helper'
2
2
 
3
3
  module Shoulda::Matchers
4
4
  describe Doublespeak do
5
5
  describe '.double_collection_for' do
6
6
  it 'delegates to its world' do
7
- Doublespeak.world.expects(:double_collection_for).with(:klass)
7
+ allow(Doublespeak.world).to receive(:double_collection_for)
8
+
8
9
  described_class.double_collection_for(:klass)
10
+
11
+ expect(Doublespeak.world).
12
+ to have_received(:double_collection_for).
13
+ with(:klass)
9
14
  end
10
15
  end
11
16
 
12
17
  describe '.with_doubles_activated' do
13
18
  it 'delegates to its world' do
14
- Doublespeak.world.expects(:with_doubles_activated)
19
+ allow(Doublespeak.world).to receive(:with_doubles_activated)
20
+
15
21
  described_class.with_doubles_activated
22
+
23
+ expect(Doublespeak.world).to have_received(:with_doubles_activated)
16
24
  end
17
25
  end
18
26
  end
@@ -1,4 +1,4 @@
1
- require 'spec_helper'
1
+ require 'unit_spec_helper'
2
2
 
3
3
  describe Shoulda::Matchers::Independent::DelegateMethodMatcher::StubbedTarget do
4
4
  subject(:target) { described_class.new(:stubbed_method) }