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.
- checksums.yaml +4 -4
- data/.travis.yml +13 -3
- data/Appraisals +18 -0
- data/CONTRIBUTING.md +13 -29
- data/Gemfile +1 -4
- data/Gemfile.lock +2 -10
- data/NEWS.md +100 -14
- data/README.md +62 -58
- data/Rakefile +9 -16
- data/gemfiles/3.0.gemfile +11 -12
- data/gemfiles/3.0.gemfile.lock +15 -10
- data/gemfiles/3.1.gemfile +11 -12
- data/gemfiles/3.1.gemfile.lock +14 -10
- data/gemfiles/3.1_1.9.2.gemfile +12 -11
- data/gemfiles/3.1_1.9.2.gemfile.lock +14 -3
- data/gemfiles/3.2.gemfile +11 -12
- data/gemfiles/3.2.gemfile.lock +15 -10
- data/gemfiles/3.2_1.9.2.gemfile +12 -11
- data/gemfiles/3.2_1.9.2.gemfile.lock +14 -2
- data/gemfiles/4.0.0.gemfile +10 -12
- data/gemfiles/4.0.0.gemfile.lock +13 -10
- data/gemfiles/4.0.1.gemfile +10 -12
- data/gemfiles/4.0.1.gemfile.lock +13 -10
- data/gemfiles/4.1.gemfile +13 -15
- data/gemfiles/4.1.gemfile.lock +45 -50
- data/gemfiles/4.2.gemfile +36 -0
- data/gemfiles/4.2.gemfile.lock +245 -0
- data/lib/shoulda/matchers.rb +3 -1
- data/lib/shoulda/matchers/action_controller.rb +1 -1
- data/lib/shoulda/matchers/action_controller/redirect_to_matcher.rb +1 -1
- data/lib/shoulda/matchers/action_controller/route_params.rb +9 -4
- data/lib/shoulda/matchers/action_controller/{set_the_flash_matcher.rb → set_flash_matcher.rb} +34 -26
- data/lib/shoulda/matchers/action_controller/set_session_matcher.rb +125 -69
- data/lib/shoulda/matchers/active_model.rb +1 -2
- data/lib/shoulda/matchers/active_model/allow_value_matcher.rb +18 -5
- data/lib/shoulda/matchers/active_model/exception_message_finder.rb +2 -2
- data/lib/shoulda/matchers/active_model/helpers.rb +4 -4
- data/lib/shoulda/matchers/active_model/validate_confirmation_of_matcher.rb +10 -3
- data/lib/shoulda/matchers/active_model/validate_exclusion_of_matcher.rb +1 -1
- data/lib/shoulda/matchers/active_model/validate_inclusion_of_matcher.rb +3 -1
- data/lib/shoulda/matchers/active_model/{ensure_length_of_matcher.rb → validate_length_of_matcher.rb} +30 -20
- data/lib/shoulda/matchers/active_model/validate_presence_of_matcher.rb +21 -0
- data/lib/shoulda/matchers/active_model/validation_message_finder.rb +2 -2
- data/lib/shoulda/matchers/active_record.rb +2 -0
- data/lib/shoulda/matchers/active_record/association_matcher.rb +96 -2
- data/lib/shoulda/matchers/active_record/association_matchers/join_table_matcher.rb +1 -1
- data/lib/shoulda/matchers/active_record/association_matchers/model_reflection.rb +3 -3
- data/lib/shoulda/matchers/active_record/association_matchers/option_verifier.rb +22 -2
- data/lib/shoulda/matchers/active_record/have_db_column_matcher.rb +30 -4
- data/lib/shoulda/matchers/active_record/serialize_matcher.rb +19 -3
- data/lib/shoulda/matchers/active_record/uniqueness.rb +14 -0
- data/lib/shoulda/matchers/active_record/uniqueness/model.rb +45 -0
- data/lib/shoulda/matchers/active_record/uniqueness/namespace.rb +36 -0
- data/lib/shoulda/matchers/active_record/uniqueness/test_model_creator.rb +50 -0
- data/lib/shoulda/matchers/active_record/uniqueness/test_models.rb +24 -0
- data/lib/shoulda/matchers/{active_model → active_record}/validate_uniqueness_of_matcher.rb +76 -16
- data/lib/shoulda/matchers/independent/delegate_method_matcher.rb +117 -51
- data/lib/shoulda/matchers/independent/delegate_method_matcher/target_not_defined_error.rb +1 -1
- data/lib/shoulda/matchers/matcher_context.rb +35 -0
- data/lib/shoulda/matchers/rails_shim.rb +23 -0
- data/lib/shoulda/matchers/util.rb +28 -0
- data/lib/shoulda/matchers/version.rb +1 -1
- data/script/SUPPORTED_VERSIONS +1 -1
- data/spec/acceptance/active_model_integration_spec.rb +20 -0
- data/spec/acceptance/independent_matchers_spec.rb +64 -0
- data/spec/acceptance/rails_integration_spec.rb +142 -0
- data/spec/acceptance_spec_helper.rb +23 -0
- data/spec/support/acceptance/helpers.rb +29 -0
- data/spec/support/acceptance/helpers/active_model_helpers.rb +11 -0
- data/spec/support/acceptance/helpers/array_helpers.rb +13 -0
- data/spec/support/acceptance/helpers/base_helpers.rb +14 -0
- data/spec/support/acceptance/helpers/command_helpers.rb +51 -0
- data/spec/support/acceptance/helpers/file_helpers.rb +19 -0
- data/spec/support/acceptance/helpers/gem_helpers.rb +31 -0
- data/spec/support/acceptance/helpers/minitest_helpers.rb +19 -0
- data/spec/support/acceptance/helpers/pluralization_helpers.rb +13 -0
- data/spec/support/acceptance/helpers/rails_version_helpers.rb +11 -0
- data/spec/support/acceptance/helpers/rspec_helpers.rb +26 -0
- data/spec/support/acceptance/helpers/ruby_version_helpers.rb +9 -0
- data/spec/support/acceptance/helpers/step_helpers.rb +117 -0
- data/spec/support/acceptance/matchers/have_output.rb +31 -0
- data/spec/support/acceptance/matchers/indicate_number_of_tests_was_run_matcher.rb +55 -0
- data/spec/support/acceptance/matchers/indicate_that_tests_were_run_matcher.rb +103 -0
- data/spec/support/tests/bundle.rb +94 -0
- data/spec/support/tests/command_runner.rb +214 -0
- data/spec/support/tests/filesystem.rb +77 -0
- data/spec/support/tests/version.rb +45 -0
- data/spec/support/unit/capture.rb +34 -0
- data/spec/support/unit/helpers/active_model_helpers.rb +25 -0
- data/spec/support/unit/helpers/active_model_versions.rb +20 -0
- data/spec/support/unit/helpers/active_resource_builder.rb +27 -0
- data/spec/support/unit/helpers/allow_value_matcher_helpers.rb +15 -0
- data/spec/support/unit/helpers/class_builder.rb +72 -0
- data/spec/support/unit/helpers/confirmation_matcher_helpers.rb +17 -0
- data/spec/support/unit/helpers/controller_builder.rb +91 -0
- data/spec/support/unit/helpers/i18n_faker.rb +15 -0
- data/spec/support/unit/helpers/mailer_builder.rb +12 -0
- data/spec/support/unit/helpers/model_builder.rb +102 -0
- data/spec/support/unit/helpers/rails_versions.rb +28 -0
- data/spec/support/unit/i18n.rb +7 -0
- data/spec/support/unit/matchers/deprecate.rb +60 -0
- data/spec/support/unit/matchers/fail_with_message_including_matcher.rb +50 -0
- data/spec/support/unit/matchers/fail_with_message_matcher.rb +50 -0
- data/spec/support/unit/matchers/print_warning_including.rb +59 -0
- data/spec/support/unit/rails_application.rb +110 -0
- data/spec/support/unit/record_builder_with_i18n_validation_message.rb +69 -0
- data/spec/support/unit/record_validating_confirmation_builder.rb +56 -0
- data/spec/support/unit/record_with_different_error_attribute_builder.rb +92 -0
- data/spec/support/{shared_examples → unit/shared_examples}/numerical_submatcher.rb +0 -2
- data/spec/support/{shared_examples → unit/shared_examples}/numerical_type_submatcher.rb +0 -2
- data/spec/{shoulda → unit/shoulda}/matchers/action_controller/callback_matcher_spec.rb +2 -2
- data/spec/{shoulda → unit/shoulda}/matchers/action_controller/filter_param_matcher_spec.rb +2 -2
- data/spec/{shoulda → unit/shoulda}/matchers/action_controller/redirect_to_matcher_spec.rb +3 -3
- data/spec/{shoulda → unit/shoulda}/matchers/action_controller/render_template_matcher_spec.rb +2 -4
- data/spec/{shoulda → unit/shoulda}/matchers/action_controller/render_with_layout_matcher_spec.rb +9 -6
- data/spec/{shoulda → unit/shoulda}/matchers/action_controller/rescue_from_matcher_spec.rb +2 -2
- data/spec/{shoulda → unit/shoulda}/matchers/action_controller/respond_with_matcher_spec.rb +2 -2
- data/spec/unit/shoulda/matchers/action_controller/route_matcher_spec.rb +126 -0
- data/spec/{shoulda → unit/shoulda}/matchers/action_controller/route_params_spec.rb +2 -2
- data/spec/unit/shoulda/matchers/action_controller/set_flash_matcher_spec.rb +167 -0
- data/spec/unit/shoulda/matchers/action_controller/set_session_matcher_spec.rb +294 -0
- data/spec/{shoulda → unit/shoulda}/matchers/action_controller/strong_parameters_matcher_spec.rb +19 -11
- data/spec/{shoulda → unit/shoulda}/matchers/active_model/allow_mass_assignment_of_matcher_spec.rb +2 -2
- data/spec/{shoulda → unit/shoulda}/matchers/active_model/allow_value_matcher_spec.rb +49 -21
- data/spec/{shoulda → unit/shoulda}/matchers/active_model/disallow_value_matcher_spec.rb +8 -4
- data/spec/{shoulda → unit/shoulda}/matchers/active_model/exception_message_finder_spec.rb +4 -4
- data/spec/{shoulda → unit/shoulda}/matchers/active_model/have_secure_password_matcher_spec.rb +2 -2
- data/spec/{shoulda → unit/shoulda}/matchers/active_model/helpers_spec.rb +7 -3
- data/spec/{shoulda → unit/shoulda}/matchers/active_model/numericality_matchers/comparison_matcher_spec.rb +1 -1
- data/spec/{shoulda → unit/shoulda}/matchers/active_model/numericality_matchers/even_number_matcher_spec.rb +1 -1
- data/spec/{shoulda → unit/shoulda}/matchers/active_model/numericality_matchers/odd_number_matcher_spec.rb +1 -1
- data/spec/{shoulda → unit/shoulda}/matchers/active_model/numericality_matchers/only_integer_matcher_spec.rb +1 -1
- data/spec/{shoulda → unit/shoulda}/matchers/active_model/validate_absence_of_matcher_spec.rb +3 -3
- data/spec/{shoulda → unit/shoulda}/matchers/active_model/validate_acceptance_of_matcher_spec.rb +2 -2
- data/spec/unit/shoulda/matchers/active_model/validate_confirmation_of_matcher_spec.rb +63 -0
- data/spec/{shoulda → unit/shoulda}/matchers/active_model/validate_exclusion_of_matcher_spec.rb +5 -4
- data/spec/{shoulda → unit/shoulda}/matchers/active_model/validate_inclusion_of_matcher_spec.rb +7 -14
- 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
- data/spec/{shoulda → unit/shoulda}/matchers/active_model/validate_numericality_of_matcher_spec.rb +3 -4
- data/spec/{shoulda → unit/shoulda}/matchers/active_model/validate_presence_of_matcher_spec.rb +3 -3
- data/spec/{shoulda → unit/shoulda}/matchers/active_model/validate_uniqueness_of_matcher_spec.rb +127 -2
- data/spec/{shoulda → unit/shoulda}/matchers/active_model/validation_message_finder_spec.rb +8 -6
- data/spec/{shoulda → unit/shoulda}/matchers/active_record/accept_nested_attributes_for_matcher_spec.rb +2 -2
- data/spec/{shoulda → unit/shoulda}/matchers/active_record/association_matcher_spec.rb +217 -26
- data/spec/{shoulda → unit/shoulda}/matchers/active_record/association_matchers/model_reflection_spec.rb +2 -2
- data/spec/{shoulda → unit/shoulda}/matchers/active_record/define_enum_for_matcher_spec.rb +2 -2
- data/spec/{shoulda → unit/shoulda}/matchers/active_record/have_db_column_matcher_spec.rb +2 -2
- data/spec/{shoulda → unit/shoulda}/matchers/active_record/have_db_index_matcher_spec.rb +8 -5
- data/spec/{shoulda → unit/shoulda}/matchers/active_record/have_readonly_attributes_matcher_spec.rb +2 -2
- data/spec/{shoulda → unit/shoulda}/matchers/active_record/serialize_matcher_spec.rb +3 -3
- data/spec/{shoulda → unit/shoulda}/matchers/doublespeak/double_collection_spec.rb +29 -7
- data/spec/{shoulda → unit/shoulda}/matchers/doublespeak/double_implementation_registry_spec.rb +1 -1
- data/spec/{shoulda → unit/shoulda}/matchers/doublespeak/double_spec.rb +20 -10
- data/spec/{shoulda → unit/shoulda}/matchers/doublespeak/object_double_spec.rb +1 -1
- data/spec/{shoulda → unit/shoulda}/matchers/doublespeak/proxy_implementation_spec.rb +13 -6
- data/spec/{shoulda → unit/shoulda}/matchers/doublespeak/stub_implementation_spec.rb +2 -2
- data/spec/unit/shoulda/matchers/doublespeak/world_spec.rb +77 -0
- data/spec/{shoulda → unit/shoulda}/matchers/doublespeak_spec.rb +11 -3
- data/spec/{shoulda → unit/shoulda}/matchers/independent/delegate_method_matcher/stubbed_target_spec.rb +1 -1
- data/spec/unit/shoulda/matchers/independent/delegate_method_matcher_spec.rb +517 -0
- data/spec/unit_spec_helper.rb +66 -0
- data/spec/warnings_spy/partitioner.rb +10 -3
- data/spec/warnings_spy/reader.rb +9 -20
- data/spec/warnings_spy/reporter.rb +2 -1
- metadata +212 -149
- data/features/activemodel_integration.feature +0 -15
- data/features/rails_integration.feature +0 -160
- data/features/step_definitions/activemodel_steps.rb +0 -21
- data/features/step_definitions/rails_steps.rb +0 -227
- data/features/support/env.rb +0 -6
- data/spec/shoulda/matchers/action_controller/route_matcher_spec.rb +0 -70
- data/spec/shoulda/matchers/action_controller/set_session_matcher_spec.rb +0 -113
- data/spec/shoulda/matchers/action_controller/set_the_flash_matcher_spec.rb +0 -153
- data/spec/shoulda/matchers/active_model/validate_confirmation_of_matcher_spec.rb +0 -47
- data/spec/shoulda/matchers/doublespeak/world_spec.rb +0 -70
- data/spec/shoulda/matchers/independent/delegate_method_matcher_spec.rb +0 -309
- data/spec/spec_helper.rb +0 -42
- data/spec/support/active_model_versions.rb +0 -13
- data/spec/support/active_resource_builder.rb +0 -29
- data/spec/support/activemodel_helpers.rb +0 -23
- data/spec/support/capture_helpers.rb +0 -19
- data/spec/support/class_builder.rb +0 -46
- data/spec/support/controller_builder.rb +0 -102
- data/spec/support/fail_with_message_including_matcher.rb +0 -44
- data/spec/support/fail_with_message_matcher.rb +0 -44
- data/spec/support/i18n_faker.rb +0 -10
- data/spec/support/mailer_builder.rb +0 -10
- data/spec/support/model_builder.rb +0 -81
- data/spec/support/rails_versions.rb +0 -26
- data/spec/support/test_application.rb +0 -120
@@ -1,4 +1,4 @@
|
|
1
|
-
require '
|
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.
|
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 "
|
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 '
|
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 '
|
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 =
|
69
|
-
|
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.
|
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
|
data/spec/{shoulda → unit/shoulda}/matchers/active_record/have_readonly_attributes_matcher_spec.rb
RENAMED
@@ -1,6 +1,6 @@
|
|
1
|
-
require '
|
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 '
|
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
|
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 '
|
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
|
-
|
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
|
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
|
-
|
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
|
-
|
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
|
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
|
-
|
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 '
|
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 =
|
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 =
|
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 =
|
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 =
|
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 =
|
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 =
|
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 =
|
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,13 +1,14 @@
|
|
1
|
-
require '
|
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
|
-
|
40
|
+
double('stub_implementation', returns: nil, call: nil)
|
34
41
|
end
|
35
42
|
|
36
43
|
def build_double
|
37
|
-
|
44
|
+
double('double', call_original_method: nil)
|
38
45
|
end
|
39
46
|
end
|
40
47
|
end
|
@@ -1,4 +1,4 @@
|
|
1
|
-
require '
|
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
|
-
|
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 '
|
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.
|
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.
|
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
|