shoulda-matchers 3.1.0 → 5.2.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +5 -5
- data/{MIT-LICENSE → LICENSE} +1 -1
- data/README.md +407 -232
- data/docs/errors/NonCaseSwappableValueError.md +2 -2
- data/lib/shoulda/matchers/action_controller/callback_matcher.rb +7 -80
- data/lib/shoulda/matchers/action_controller/filter_param_matcher.rb +4 -3
- data/lib/shoulda/matchers/action_controller/flash_store.rb +2 -4
- data/lib/shoulda/matchers/action_controller/permit_matcher.rb +36 -30
- data/lib/shoulda/matchers/action_controller/redirect_to_matcher.rb +8 -10
- data/lib/shoulda/matchers/action_controller/render_template_matcher.rb +7 -9
- data/lib/shoulda/matchers/action_controller/render_with_layout_matcher.rb +18 -15
- data/lib/shoulda/matchers/action_controller/rescue_from_matcher.rb +3 -2
- data/lib/shoulda/matchers/action_controller/respond_with_matcher.rb +3 -3
- data/lib/shoulda/matchers/action_controller/route_matcher.rb +88 -29
- data/lib/shoulda/matchers/action_controller/route_params.rb +2 -2
- data/lib/shoulda/matchers/action_controller/set_flash_matcher.rb +4 -4
- data/lib/shoulda/matchers/action_controller/set_session_matcher.rb +3 -3
- data/lib/shoulda/matchers/action_controller/set_session_or_flash_matcher.rb +19 -13
- data/lib/shoulda/matchers/action_controller.rb +2 -0
- data/lib/shoulda/matchers/active_model/allow_value_matcher/attribute_changed_value_error.rb +1 -1
- data/lib/shoulda/matchers/active_model/allow_value_matcher/attribute_setter.rb +5 -9
- data/lib/shoulda/matchers/active_model/allow_value_matcher/attribute_setter_and_validator.rb +2 -2
- data/lib/shoulda/matchers/active_model/allow_value_matcher/attribute_setters.rb +1 -1
- data/lib/shoulda/matchers/active_model/allow_value_matcher/attribute_setters_and_validators.rb +1 -1
- data/lib/shoulda/matchers/active_model/allow_value_matcher.rb +42 -39
- data/lib/shoulda/matchers/active_model/disallow_value_matcher.rb +1 -1
- data/lib/shoulda/matchers/active_model/have_secure_password_matcher.rb +52 -26
- data/lib/shoulda/matchers/active_model/helpers.rb +2 -2
- data/lib/shoulda/matchers/active_model/numericality_matchers/comparison_matcher.rb +32 -30
- data/lib/shoulda/matchers/active_model/numericality_matchers/numeric_type_matcher.rb +2 -1
- data/lib/shoulda/matchers/active_model/qualifiers/allow_blank.rb +26 -0
- data/lib/shoulda/matchers/active_model/qualifiers/allow_nil.rb +26 -0
- data/lib/shoulda/matchers/active_model/qualifiers/ignoring_interference_by_writer.rb +1 -1
- data/lib/shoulda/matchers/active_model/qualifiers.rb +2 -0
- data/lib/shoulda/matchers/active_model/validate_absence_of_matcher.rb +30 -6
- data/lib/shoulda/matchers/active_model/validate_acceptance_of_matcher.rb +8 -3
- data/lib/shoulda/matchers/active_model/validate_confirmation_of_matcher.rb +31 -16
- data/lib/shoulda/matchers/active_model/validate_exclusion_of_matcher.rb +52 -16
- data/lib/shoulda/matchers/active_model/validate_inclusion_of_matcher.rb +137 -84
- data/lib/shoulda/matchers/active_model/validate_length_of_matcher.rb +159 -46
- data/lib/shoulda/matchers/active_model/validate_numericality_of_matcher.rb +130 -66
- data/lib/shoulda/matchers/active_model/validate_presence_of_matcher.rb +251 -24
- data/lib/shoulda/matchers/active_model/validation_matcher/build_description.rb +12 -9
- data/lib/shoulda/matchers/active_model/validation_matcher.rb +38 -6
- data/lib/shoulda/matchers/active_model/validation_message_finder.rb +2 -4
- data/lib/shoulda/matchers/active_model/validator.rb +4 -9
- data/lib/shoulda/matchers/active_model.rb +3 -5
- data/lib/shoulda/matchers/active_record/accept_nested_attributes_for_matcher.rb +10 -7
- data/lib/shoulda/matchers/active_record/association_matcher.rb +386 -111
- data/lib/shoulda/matchers/active_record/association_matchers/counter_cache_matcher.rb +5 -2
- data/lib/shoulda/matchers/active_record/association_matchers/dependent_matcher.rb +4 -4
- data/lib/shoulda/matchers/active_record/association_matchers/inverse_of_matcher.rb +1 -1
- data/lib/shoulda/matchers/active_record/association_matchers/join_table_matcher.rb +11 -6
- data/lib/shoulda/matchers/active_record/association_matchers/model_reflection.rb +14 -15
- data/lib/shoulda/matchers/active_record/association_matchers/model_reflector.rb +30 -8
- data/lib/shoulda/matchers/active_record/association_matchers/option_verifier.rb +34 -11
- data/lib/shoulda/matchers/active_record/association_matchers/optional_matcher.rb +69 -0
- data/lib/shoulda/matchers/active_record/association_matchers/order_matcher.rb +1 -1
- data/lib/shoulda/matchers/active_record/association_matchers/required_matcher.rb +74 -0
- data/lib/shoulda/matchers/active_record/association_matchers/source_matcher.rb +3 -2
- data/lib/shoulda/matchers/active_record/association_matchers/through_matcher.rb +7 -5
- data/lib/shoulda/matchers/active_record/define_enum_for_matcher.rb +458 -42
- data/lib/shoulda/matchers/active_record/have_attached_matcher.rb +185 -0
- data/lib/shoulda/matchers/active_record/have_db_column_matcher.rb +63 -23
- data/lib/shoulda/matchers/active_record/have_db_index_matcher.rb +164 -48
- data/lib/shoulda/matchers/active_record/have_implicit_order_column.rb +106 -0
- data/lib/shoulda/matchers/active_record/have_readonly_attribute_matcher.rb +13 -11
- data/lib/shoulda/matchers/active_record/have_rich_text_matcher.rb +83 -0
- data/lib/shoulda/matchers/active_record/have_secure_token_matcher.rb +132 -0
- data/lib/shoulda/matchers/active_record/serialize_matcher.rb +18 -18
- data/lib/shoulda/matchers/active_record/uniqueness/test_model_creator.rb +1 -3
- data/lib/shoulda/matchers/active_record/uniqueness/test_models.rb +0 -2
- data/lib/shoulda/matchers/active_record/uniqueness.rb +1 -1
- data/lib/shoulda/matchers/active_record/validate_uniqueness_of_matcher.rb +430 -200
- data/lib/shoulda/matchers/active_record.rb +28 -20
- data/lib/shoulda/matchers/configuration.rb +12 -1
- data/lib/shoulda/matchers/doublespeak/double.rb +1 -1
- data/lib/shoulda/matchers/doublespeak/double_collection.rb +3 -3
- data/lib/shoulda/matchers/doublespeak/double_implementation_registry.rb +8 -5
- data/lib/shoulda/matchers/doublespeak/object_double.rb +6 -2
- data/lib/shoulda/matchers/doublespeak/stub_implementation.rb +1 -5
- data/lib/shoulda/matchers/doublespeak/world.rb +2 -2
- data/lib/shoulda/matchers/doublespeak.rb +2 -1
- data/lib/shoulda/matchers/error.rb +1 -1
- data/lib/shoulda/matchers/independent/delegate_method_matcher.rb +109 -29
- data/lib/shoulda/matchers/independent.rb +2 -2
- data/lib/shoulda/matchers/integrations/configuration.rb +8 -4
- data/lib/shoulda/matchers/integrations/libraries/action_controller.rb +1 -1
- data/lib/shoulda/matchers/integrations/libraries/rails.rb +2 -2
- data/lib/shoulda/matchers/integrations/test_frameworks/active_support_test_case.rb +1 -1
- data/lib/shoulda/matchers/integrations/test_frameworks/minitest_4.rb +1 -1
- data/lib/shoulda/matchers/integrations/test_frameworks/minitest_5.rb +1 -1
- data/lib/shoulda/matchers/integrations/test_frameworks/missing_test_framework.rb +1 -1
- data/lib/shoulda/matchers/integrations/test_frameworks/test_unit.rb +1 -1
- data/lib/shoulda/matchers/rails_shim.rb +172 -51
- data/lib/shoulda/matchers/routing.rb +2 -2
- data/lib/shoulda/matchers/util/word_wrap.rb +17 -12
- data/lib/shoulda/matchers/util.rb +39 -5
- data/lib/shoulda/matchers/version.rb +1 -1
- data/lib/shoulda/matchers/warn.rb +4 -3
- data/shoulda-matchers.gemspec +33 -15
- metadata +31 -338
- data/.gitignore +0 -12
- data/.hound.yml +0 -3
- data/.hound_config/ruby.yml +0 -12
- data/.travis.yml +0 -19
- data/.yardopts +0 -10
- data/Appraisals +0 -73
- data/CONTRIBUTING.md +0 -101
- data/Gemfile +0 -15
- data/Gemfile.lock +0 -70
- data/NEWS.md +0 -986
- data/Rakefile +0 -39
- data/custom_plan.rb +0 -88
- data/doc_config/gh-pages/index.html.erb +0 -9
- data/doc_config/yard/setup.rb +0 -22
- data/doc_config/yard/templates/default/fulldoc/html/css/bootstrap.css +0 -5967
- data/doc_config/yard/templates/default/fulldoc/html/css/full_list.css +0 -12
- data/doc_config/yard/templates/default/fulldoc/html/css/global.css +0 -62
- data/doc_config/yard/templates/default/fulldoc/html/css/solarized.css +0 -69
- data/doc_config/yard/templates/default/fulldoc/html/css/style.css +0 -312
- data/doc_config/yard/templates/default/fulldoc/html/full_list.erb +0 -32
- data/doc_config/yard/templates/default/fulldoc/html/full_list_class.erb +0 -1
- data/doc_config/yard/templates/default/fulldoc/html/full_list_method.erb +0 -8
- data/doc_config/yard/templates/default/fulldoc/html/js/app.js +0 -298
- data/doc_config/yard/templates/default/fulldoc/html/js/full_list.js +0 -1
- data/doc_config/yard/templates/default/fulldoc/html/js/jquery.stickyheaders.js +0 -289
- data/doc_config/yard/templates/default/fulldoc/html/js/underscore.min.js +0 -6
- data/doc_config/yard/templates/default/fulldoc/html/setup.rb +0 -8
- data/doc_config/yard/templates/default/layout/html/breadcrumb.erb +0 -14
- data/doc_config/yard/templates/default/layout/html/fonts.erb +0 -1
- data/doc_config/yard/templates/default/layout/html/footer.erb +0 -6
- data/doc_config/yard/templates/default/layout/html/layout.erb +0 -23
- data/doc_config/yard/templates/default/layout/html/search.erb +0 -13
- data/doc_config/yard/templates/default/layout/html/setup.rb +0 -40
- data/doc_config/yard/templates/default/method_details/html/source.erb +0 -10
- data/doc_config/yard/templates/default/module/html/box_info.erb +0 -31
- data/gemfiles/4.0.0.gemfile +0 -38
- data/gemfiles/4.0.0.gemfile.lock +0 -223
- data/gemfiles/4.0.1.gemfile +0 -38
- data/gemfiles/4.0.1.gemfile.lock +0 -225
- data/gemfiles/4.1.gemfile +0 -38
- data/gemfiles/4.1.gemfile.lock +0 -220
- data/gemfiles/4.2.gemfile +0 -38
- data/gemfiles/4.2.gemfile.lock +0 -243
- data/lib/shoulda/matchers/active_model/allow_mass_assignment_of_matcher.rb +0 -159
- data/lib/shoulda/matchers/independent/delegate_method_matcher/stubbed_target.rb +0 -37
- data/script/SUPPORTED_VERSIONS +0 -1
- data/script/install_gems_in_all_appraisals +0 -14
- data/script/run_all_tests +0 -14
- data/script/update_gem_in_all_appraisals +0 -15
- data/script/update_gems_in_all_appraisals +0 -14
- data/spec/acceptance/active_model_integration_spec.rb +0 -23
- data/spec/acceptance/independent_matchers_spec.rb +0 -125
- data/spec/acceptance/multiple_libraries_integration_spec.rb +0 -55
- data/spec/acceptance/rails_integration_spec.rb +0 -156
- data/spec/acceptance_spec_helper.rb +0 -23
- data/spec/doublespeak_spec_helper.rb +0 -2
- data/spec/report_warnings.rb +0 -7
- data/spec/spec_helper.rb +0 -21
- data/spec/support/acceptance/adds_shoulda_matchers_to_project.rb +0 -133
- data/spec/support/acceptance/helpers/active_model_helpers.rb +0 -11
- data/spec/support/acceptance/helpers/array_helpers.rb +0 -13
- data/spec/support/acceptance/helpers/base_helpers.rb +0 -19
- data/spec/support/acceptance/helpers/command_helpers.rb +0 -55
- data/spec/support/acceptance/helpers/file_helpers.rb +0 -19
- data/spec/support/acceptance/helpers/gem_helpers.rb +0 -31
- data/spec/support/acceptance/helpers/minitest_helpers.rb +0 -11
- data/spec/support/acceptance/helpers/n_unit_helpers.rb +0 -25
- data/spec/support/acceptance/helpers/pluralization_helpers.rb +0 -13
- data/spec/support/acceptance/helpers/rails_version_helpers.rb +0 -11
- data/spec/support/acceptance/helpers/rspec_helpers.rb +0 -24
- data/spec/support/acceptance/helpers/ruby_version_helpers.rb +0 -9
- data/spec/support/acceptance/helpers/step_helpers.rb +0 -127
- data/spec/support/acceptance/helpers.rb +0 -31
- data/spec/support/acceptance/matchers/have_output.rb +0 -31
- data/spec/support/acceptance/matchers/indicate_number_of_tests_was_run_matcher.rb +0 -55
- data/spec/support/acceptance/matchers/indicate_that_tests_were_run_matcher.rb +0 -103
- data/spec/support/tests/bundle.rb +0 -94
- data/spec/support/tests/command_runner.rb +0 -230
- data/spec/support/tests/current_bundle.rb +0 -61
- data/spec/support/tests/database.rb +0 -28
- data/spec/support/tests/database_adapters/postgresql.rb +0 -25
- data/spec/support/tests/database_adapters/sqlite3.rb +0 -26
- data/spec/support/tests/database_configuration.rb +0 -33
- data/spec/support/tests/database_configuration_registry.rb +0 -28
- data/spec/support/tests/filesystem.rb +0 -100
- data/spec/support/tests/version.rb +0 -45
- data/spec/support/unit/active_record/create_table.rb +0 -54
- data/spec/support/unit/attribute.rb +0 -47
- data/spec/support/unit/capture.rb +0 -40
- data/spec/support/unit/change_value.rb +0 -111
- data/spec/support/unit/create_model_arguments/basic.rb +0 -135
- data/spec/support/unit/create_model_arguments/has_many.rb +0 -15
- data/spec/support/unit/create_model_arguments/uniqueness_matcher.rb +0 -74
- data/spec/support/unit/helpers/active_model_helpers.rb +0 -27
- data/spec/support/unit/helpers/active_model_versions.rb +0 -28
- data/spec/support/unit/helpers/active_record_versions.rb +0 -24
- data/spec/support/unit/helpers/active_resource_builder.rb +0 -27
- data/spec/support/unit/helpers/allow_value_matcher_helpers.rb +0 -15
- data/spec/support/unit/helpers/class_builder.rb +0 -90
- data/spec/support/unit/helpers/column_type_helpers.rb +0 -26
- data/spec/support/unit/helpers/confirmation_matcher_helpers.rb +0 -17
- data/spec/support/unit/helpers/controller_builder.rb +0 -63
- data/spec/support/unit/helpers/database_helpers.rb +0 -20
- data/spec/support/unit/helpers/i18n_faker.rb +0 -15
- data/spec/support/unit/helpers/mailer_builder.rb +0 -12
- data/spec/support/unit/helpers/model_builder.rb +0 -114
- data/spec/support/unit/helpers/rails_versions.rb +0 -28
- data/spec/support/unit/helpers/validation_matcher_scenario_helpers.rb +0 -44
- data/spec/support/unit/i18n.rb +0 -7
- data/spec/support/unit/load_environment.rb +0 -12
- data/spec/support/unit/matchers/deprecate.rb +0 -60
- data/spec/support/unit/matchers/fail_with_message_including_matcher.rb +0 -51
- data/spec/support/unit/matchers/fail_with_message_matcher.rb +0 -62
- data/spec/support/unit/matchers/print_warning_including.rb +0 -59
- data/spec/support/unit/model_creation_strategies/active_model.rb +0 -111
- data/spec/support/unit/model_creation_strategies/active_record.rb +0 -77
- data/spec/support/unit/model_creators/active_model.rb +0 -39
- data/spec/support/unit/model_creators/active_record/has_and_belongs_to_many.rb +0 -95
- data/spec/support/unit/model_creators/active_record/has_many.rb +0 -67
- data/spec/support/unit/model_creators/active_record/uniqueness_matcher.rb +0 -42
- data/spec/support/unit/model_creators/active_record.rb +0 -43
- data/spec/support/unit/model_creators/basic.rb +0 -97
- data/spec/support/unit/model_creators.rb +0 -19
- data/spec/support/unit/rails_application.rb +0 -126
- data/spec/support/unit/record_builder_with_i18n_validation_message.rb +0 -69
- data/spec/support/unit/record_validating_confirmation_builder.rb +0 -51
- data/spec/support/unit/record_with_different_error_attribute_builder.rb +0 -92
- data/spec/support/unit/shared_examples/ignoring_interference_by_writer.rb +0 -79
- data/spec/support/unit/shared_examples/numerical_submatcher.rb +0 -17
- data/spec/support/unit/shared_examples/set_session_or_flash.rb +0 -360
- data/spec/support/unit/validation_matcher_scenario.rb +0 -62
- data/spec/unit/shoulda/matchers/action_controller/callback_matcher_spec.rb +0 -82
- data/spec/unit/shoulda/matchers/action_controller/filter_param_matcher_spec.rb +0 -28
- data/spec/unit/shoulda/matchers/action_controller/permit_matcher_spec.rb +0 -592
- data/spec/unit/shoulda/matchers/action_controller/redirect_to_matcher_spec.rb +0 -42
- data/spec/unit/shoulda/matchers/action_controller/render_template_matcher_spec.rb +0 -76
- data/spec/unit/shoulda/matchers/action_controller/render_with_layout_matcher_spec.rb +0 -62
- data/spec/unit/shoulda/matchers/action_controller/rescue_from_matcher_spec.rb +0 -90
- data/spec/unit/shoulda/matchers/action_controller/respond_with_matcher_spec.rb +0 -31
- data/spec/unit/shoulda/matchers/action_controller/route_matcher_spec.rb +0 -330
- data/spec/unit/shoulda/matchers/action_controller/route_params_spec.rb +0 -30
- data/spec/unit/shoulda/matchers/action_controller/set_flash_matcher_spec.rb +0 -67
- data/spec/unit/shoulda/matchers/action_controller/set_session_matcher_spec.rb +0 -17
- data/spec/unit/shoulda/matchers/action_controller/set_session_or_flash_matcher_spec.rb +0 -562
- data/spec/unit/shoulda/matchers/active_model/allow_mass_assignment_of_matcher_spec.rb +0 -115
- data/spec/unit/shoulda/matchers/active_model/allow_value_matcher_spec.rb +0 -823
- data/spec/unit/shoulda/matchers/active_model/disallow_value_matcher_spec.rb +0 -86
- data/spec/unit/shoulda/matchers/active_model/have_secure_password_matcher_spec.rb +0 -20
- data/spec/unit/shoulda/matchers/active_model/helpers_spec.rb +0 -162
- data/spec/unit/shoulda/matchers/active_model/validate_absence_of_matcher_spec.rb +0 -266
- data/spec/unit/shoulda/matchers/active_model/validate_acceptance_of_matcher_spec.rb +0 -91
- data/spec/unit/shoulda/matchers/active_model/validate_confirmation_of_matcher_spec.rb +0 -149
- data/spec/unit/shoulda/matchers/active_model/validate_exclusion_of_matcher_spec.rb +0 -207
- data/spec/unit/shoulda/matchers/active_model/validate_inclusion_of_matcher_spec.rb +0 -1015
- data/spec/unit/shoulda/matchers/active_model/validate_length_of_matcher_spec.rb +0 -288
- data/spec/unit/shoulda/matchers/active_model/validate_numericality_of_matcher_spec.rb +0 -1837
- data/spec/unit/shoulda/matchers/active_model/validate_presence_of_matcher_spec.rb +0 -380
- data/spec/unit/shoulda/matchers/active_record/accept_nested_attributes_for_matcher_spec.rb +0 -107
- data/spec/unit/shoulda/matchers/active_record/association_matcher_spec.rb +0 -1242
- data/spec/unit/shoulda/matchers/active_record/association_matchers/model_reflection_spec.rb +0 -251
- data/spec/unit/shoulda/matchers/active_record/define_enum_for_matcher_spec.rb +0 -168
- data/spec/unit/shoulda/matchers/active_record/have_db_column_matcher_spec.rb +0 -111
- data/spec/unit/shoulda/matchers/active_record/have_db_index_matcher_spec.rb +0 -85
- data/spec/unit/shoulda/matchers/active_record/have_readonly_attributes_matcher_spec.rb +0 -41
- data/spec/unit/shoulda/matchers/active_record/serialize_matcher_spec.rb +0 -86
- data/spec/unit/shoulda/matchers/active_record/validate_uniqueness_of_matcher_spec.rb +0 -1418
- data/spec/unit/shoulda/matchers/doublespeak/double_collection_spec.rb +0 -190
- data/spec/unit/shoulda/matchers/doublespeak/double_implementation_registry_spec.rb +0 -21
- data/spec/unit/shoulda/matchers/doublespeak/double_spec.rb +0 -271
- data/spec/unit/shoulda/matchers/doublespeak/object_double_spec.rb +0 -77
- data/spec/unit/shoulda/matchers/doublespeak/proxy_implementation_spec.rb +0 -72
- data/spec/unit/shoulda/matchers/doublespeak/stub_implementation_spec.rb +0 -101
- data/spec/unit/shoulda/matchers/doublespeak/world_spec.rb +0 -80
- data/spec/unit/shoulda/matchers/doublespeak_spec.rb +0 -27
- data/spec/unit/shoulda/matchers/independent/delegate_method_matcher/stubbed_target_spec.rb +0 -43
- data/spec/unit/shoulda/matchers/independent/delegate_method_matcher_spec.rb +0 -517
- data/spec/unit/shoulda/matchers/routing/route_matcher_spec.rb +0 -242
- data/spec/unit/shoulda/matchers/util/word_wrap_spec.rb +0 -252
- data/spec/unit_spec_helper.rb +0 -46
- data/spec/warnings_spy/filesystem.rb +0 -45
- data/spec/warnings_spy/partitioner.rb +0 -36
- data/spec/warnings_spy/reader.rb +0 -53
- data/spec/warnings_spy/reporter.rb +0 -88
- data/spec/warnings_spy.rb +0 -64
- data/tasks/documentation.rb +0 -199
- data/zeus.json +0 -11
@@ -17,15 +17,15 @@ module Shoulda
|
|
17
17
|
# You can use `allow_value` to test one value at a time:
|
18
18
|
#
|
19
19
|
# # RSpec
|
20
|
-
# describe UserProfile do
|
21
|
-
# it { should allow_value('
|
22
|
-
# it { should allow_value('
|
20
|
+
# RSpec.describe UserProfile, type: :model do
|
21
|
+
# it { should allow_value('https://foo.com').for(:website_url) }
|
22
|
+
# it { should allow_value('https://bar.com').for(:website_url) }
|
23
23
|
# end
|
24
24
|
#
|
25
25
|
# # Minitest (Shoulda)
|
26
26
|
# class UserProfileTest < ActiveSupport::TestCase
|
27
|
-
# should allow_value('
|
28
|
-
# should allow_value('
|
27
|
+
# should allow_value('https://foo.com').for(:website_url)
|
28
|
+
# should allow_value('https://bar.com').for(:website_url)
|
29
29
|
# end
|
30
30
|
#
|
31
31
|
# You can also test multiple values in one go, if you like. In the
|
@@ -34,24 +34,24 @@ module Shoulda
|
|
34
34
|
# that none of the values cause the record to be valid:
|
35
35
|
#
|
36
36
|
# # RSpec
|
37
|
-
# describe UserProfile do
|
37
|
+
# RSpec.describe UserProfile, type: :model do
|
38
38
|
# it do
|
39
|
-
# should allow_values('
|
39
|
+
# should allow_values('https://foo.com', 'https://bar.com').
|
40
40
|
# for(:website_url)
|
41
41
|
# end
|
42
42
|
#
|
43
43
|
# it do
|
44
|
-
# should_not allow_values('
|
44
|
+
# should_not allow_values('foo', 'buz').
|
45
45
|
# for(:website_url)
|
46
46
|
# end
|
47
47
|
# end
|
48
48
|
#
|
49
49
|
# # Minitest (Shoulda)
|
50
50
|
# class UserProfileTest < ActiveSupport::TestCase
|
51
|
-
# should allow_values('
|
51
|
+
# should allow_values('https://foo.com', 'https://bar.com/baz').
|
52
52
|
# for(:website_url)
|
53
53
|
#
|
54
|
-
# should_not allow_values('
|
54
|
+
# should_not allow_values('foo', 'buz').
|
55
55
|
# for(:website_url)
|
56
56
|
# end
|
57
57
|
#
|
@@ -82,7 +82,7 @@ module Shoulda
|
|
82
82
|
# end
|
83
83
|
# end
|
84
84
|
#
|
85
|
-
# describe Foo do
|
85
|
+
# RSpec.describe Foo, type: :model do
|
86
86
|
# it do
|
87
87
|
# foo = Foo.new
|
88
88
|
# foo.bar = "baz"
|
@@ -105,7 +105,7 @@ module Shoulda
|
|
105
105
|
# end
|
106
106
|
# end
|
107
107
|
#
|
108
|
-
# describe Foo do
|
108
|
+
# RSpec.describe Foo, type: :model do
|
109
109
|
# it do
|
110
110
|
# foo = Foo.new
|
111
111
|
# # This will raise an AttributeChangedValueError since `foo.bar` is now "123"
|
@@ -116,7 +116,7 @@ module Shoulda
|
|
116
116
|
# * You're passing a value to `allow_value` that the model typecasts into
|
117
117
|
# another value:
|
118
118
|
#
|
119
|
-
# describe Foo do
|
119
|
+
# RSpec.describe Foo, type: :model do
|
120
120
|
# # Assume that `attr` is a string
|
121
121
|
# # This will raise an AttributeChangedValueError since `attr` typecasts `[]` to `"[]"`
|
122
122
|
# it { should_not allow_value([]).for(:attr) }
|
@@ -154,7 +154,7 @@ module Shoulda
|
|
154
154
|
# end
|
155
155
|
#
|
156
156
|
# # RSpec
|
157
|
-
# describe UserProfile do
|
157
|
+
# RSpec.describe UserProfile, type: :model do
|
158
158
|
# it do
|
159
159
|
# should allow_value('2013-01-01').
|
160
160
|
# for(:birthday_as_string).
|
@@ -183,7 +183,7 @@ module Shoulda
|
|
183
183
|
# end
|
184
184
|
#
|
185
185
|
# # RSpec
|
186
|
-
# describe UserProfile do
|
186
|
+
# RSpec.describe UserProfile, type: :model do
|
187
187
|
# it do
|
188
188
|
# should allow_value('open', 'closed').
|
189
189
|
# for(:state).
|
@@ -210,7 +210,7 @@ module Shoulda
|
|
210
210
|
# end
|
211
211
|
#
|
212
212
|
# # RSpec
|
213
|
-
# describe UserProfile do
|
213
|
+
# RSpec.describe UserProfile, type: :model do
|
214
214
|
# it do
|
215
215
|
# should allow_value('open', 'closed').
|
216
216
|
# for(:state).
|
@@ -246,7 +246,7 @@ module Shoulda
|
|
246
246
|
# end
|
247
247
|
#
|
248
248
|
# # RSpec
|
249
|
-
# describe UserProfile do
|
249
|
+
# RSpec.describe UserProfile, type: :model do
|
250
250
|
# it do
|
251
251
|
# should allow_value('Broncos', 'Titans').
|
252
252
|
# for(:sports_team).
|
@@ -276,7 +276,7 @@ module Shoulda
|
|
276
276
|
# end
|
277
277
|
#
|
278
278
|
# # RSpec
|
279
|
-
# describe Address do
|
279
|
+
# RSpec.describe Address, type: :model do
|
280
280
|
# it do
|
281
281
|
# should_not allow_value([]).
|
282
282
|
# for(:zip_code).
|
@@ -313,7 +313,7 @@ module Shoulda
|
|
313
313
|
:attribute_to_check_message_against,
|
314
314
|
:attribute_to_set,
|
315
315
|
:context,
|
316
|
-
:instance
|
316
|
+
:instance,
|
317
317
|
)
|
318
318
|
|
319
319
|
attr_writer(
|
@@ -332,6 +332,7 @@ module Shoulda
|
|
332
332
|
@context = nil
|
333
333
|
@values_to_preset = {}
|
334
334
|
@failure_message_preface = nil
|
335
|
+
@attribute_changed_value_message = nil
|
335
336
|
end
|
336
337
|
|
337
338
|
def for(attribute_name)
|
@@ -422,55 +423,56 @@ module Shoulda
|
|
422
423
|
end
|
423
424
|
|
424
425
|
if include_attribute_changed_value_message?
|
425
|
-
message << "\n\n
|
426
|
+
message << "\n\n#{attribute_changed_value_message.call}"
|
426
427
|
end
|
427
428
|
|
428
429
|
Shoulda::Matchers.word_wrap(message)
|
429
430
|
end
|
430
431
|
|
431
|
-
def failure_message_when_negated
|
432
|
+
def failure_message_when_negated # rubocop:disable Metrics/MethodLength
|
432
433
|
attribute_setter = result.attribute_setter
|
433
434
|
|
434
435
|
if attribute_setter.unsuccessfully_checked?
|
435
436
|
message = attribute_setter.failure_message
|
436
437
|
else
|
437
438
|
validator = result.validator
|
438
|
-
message = failure_message_preface.call
|
439
|
+
message = "#{failure_message_preface.call} invalid"
|
439
440
|
|
440
441
|
if validator.type_of_message_matched?
|
441
442
|
if validator.has_messages?
|
442
443
|
message << ' and to'
|
443
444
|
|
444
|
-
if validator.captured_validation_exception?
|
445
|
+
if validator.captured_validation_exception? # rubocop:disable Metrics/BlockNesting
|
445
446
|
message << ' raise a validation exception with message'
|
446
447
|
else
|
447
448
|
message << ' produce'
|
448
449
|
|
449
|
-
|
450
|
-
|
451
|
-
|
452
|
-
|
453
|
-
|
450
|
+
message <<
|
451
|
+
if expected_message.is_a?(Regexp) # rubocop:disable Metrics/BlockNesting
|
452
|
+
' a'
|
453
|
+
else
|
454
|
+
' the'
|
455
|
+
end
|
454
456
|
|
455
457
|
message << ' validation error'
|
456
458
|
end
|
457
459
|
|
458
|
-
if expected_message.is_a?(Regexp)
|
460
|
+
if expected_message.is_a?(Regexp) # rubocop:disable Metrics/BlockNesting
|
459
461
|
message << ' matching '
|
460
462
|
message << Shoulda::Matchers::Util.inspect_value(
|
461
|
-
expected_message
|
463
|
+
expected_message,
|
462
464
|
)
|
463
465
|
else
|
464
466
|
message << " #{expected_message.inspect}"
|
465
467
|
end
|
466
468
|
|
467
|
-
unless validator.captured_validation_exception?
|
469
|
+
unless validator.captured_validation_exception? # rubocop:disable Metrics/BlockNesting
|
468
470
|
message << " on :#{attribute_to_check_message_against}"
|
469
471
|
end
|
470
472
|
|
471
473
|
message << '. The record was indeed invalid, but'
|
472
474
|
|
473
|
-
if validator.captured_validation_exception?
|
475
|
+
if validator.captured_validation_exception? # rubocop:disable Metrics/BlockNesting
|
474
476
|
message << ' the exception message was '
|
475
477
|
message << validator.validation_exception_message.inspect
|
476
478
|
message << ' instead.'
|
@@ -491,7 +493,7 @@ module Shoulda
|
|
491
493
|
end
|
492
494
|
|
493
495
|
if include_attribute_changed_value_message?
|
494
|
-
message << "\n\n
|
496
|
+
message << "\n\n#{attribute_changed_value_message.call}"
|
495
497
|
end
|
496
498
|
|
497
499
|
Shoulda::Matchers.word_wrap(message)
|
@@ -530,7 +532,8 @@ module Shoulda
|
|
530
532
|
|
531
533
|
def run(strategy)
|
532
534
|
attribute_setters_for_values_to_preset.first_failing ||
|
533
|
-
attribute_setters_and_validators_for_values_to_set.
|
535
|
+
attribute_setters_and_validators_for_values_to_set.
|
536
|
+
public_send(strategy)
|
534
537
|
end
|
535
538
|
|
536
539
|
def failure_message_preface
|
@@ -596,14 +599,14 @@ pass, or do something else entirely.
|
|
596
599
|
@_attribute_setters_and_validators_for_values_to_set ||=
|
597
600
|
AttributeSettersAndValidators.new(
|
598
601
|
self,
|
599
|
-
values_to_set.map { |value| [attribute_to_set, value] }
|
602
|
+
values_to_set.map { |value| [attribute_to_set, value] },
|
600
603
|
)
|
601
604
|
end
|
602
605
|
|
603
606
|
def inspected_values_to_set
|
604
607
|
Shoulda::Matchers::Util.inspect_values(values_to_set).to_sentence(
|
605
|
-
two_words_connector:
|
606
|
-
last_word_connector:
|
608
|
+
two_words_connector: ' or ',
|
609
|
+
last_word_connector: ', or ',
|
607
610
|
)
|
608
611
|
end
|
609
612
|
|
@@ -618,7 +621,7 @@ pass, or do something else entirely.
|
|
618
621
|
def default_attribute_message
|
619
622
|
default_error_message(
|
620
623
|
options[:expected_message],
|
621
|
-
default_attribute_message_values
|
624
|
+
default_attribute_message_values,
|
622
625
|
)
|
623
626
|
end
|
624
627
|
|
@@ -638,7 +641,7 @@ pass, or do something else entirely.
|
|
638
641
|
|
639
642
|
def human_attribute_name
|
640
643
|
instance.class.human_attribute_name(
|
641
|
-
attribute_to_check_message_against
|
644
|
+
attribute_to_check_message_against,
|
642
645
|
)
|
643
646
|
end
|
644
647
|
end
|
@@ -10,49 +10,51 @@ module Shoulda
|
|
10
10
|
# include ActiveModel::Model
|
11
11
|
# include ActiveModel::SecurePassword
|
12
12
|
# attr_accessor :password
|
13
|
+
# attr_accessor :reset_password
|
13
14
|
#
|
14
15
|
# has_secure_password
|
16
|
+
# has_secure_password :reset_password
|
15
17
|
# end
|
16
18
|
#
|
17
19
|
# # RSpec
|
18
|
-
# describe User do
|
20
|
+
# RSpec.describe User, type: :model do
|
19
21
|
# it { should have_secure_password }
|
22
|
+
# it { should have_secure_password(:reset_password) }
|
20
23
|
# end
|
21
24
|
#
|
22
25
|
# # Minitest (Shoulda)
|
23
26
|
# class UserTest < ActiveSupport::TestCase
|
24
27
|
# should have_secure_password
|
28
|
+
# should have_secure_password(:reset_password)
|
25
29
|
# end
|
26
30
|
#
|
27
31
|
# @return [HaveSecurePasswordMatcher]
|
28
32
|
#
|
29
|
-
def have_secure_password
|
30
|
-
HaveSecurePasswordMatcher.new
|
33
|
+
def have_secure_password(attr = :password)
|
34
|
+
HaveSecurePasswordMatcher.new(attr)
|
31
35
|
end
|
32
36
|
|
33
37
|
# @private
|
34
38
|
class HaveSecurePasswordMatcher
|
35
39
|
attr_reader :failure_message
|
36
40
|
|
37
|
-
CORRECT_PASSWORD =
|
38
|
-
INCORRECT_PASSWORD =
|
39
|
-
|
40
|
-
EXPECTED_METHODS = [
|
41
|
-
:authenticate,
|
42
|
-
:password=,
|
43
|
-
:password_confirmation=,
|
44
|
-
:password_digest,
|
45
|
-
:password_digest=,
|
46
|
-
]
|
41
|
+
CORRECT_PASSWORD = 'aBcDe12345'.freeze
|
42
|
+
INCORRECT_PASSWORD = 'password'.freeze
|
47
43
|
|
48
44
|
MESSAGES = {
|
49
|
-
authenticated_incorrect_password:
|
50
|
-
|
51
|
-
|
52
|
-
|
45
|
+
authenticated_incorrect_password: 'expected %{subject} to not'\
|
46
|
+
' authenticate an incorrect %{attribute}',
|
47
|
+
did_not_authenticate_correct_password: 'expected %{subject} to'\
|
48
|
+
' authenticate the correct %{attribute}',
|
49
|
+
method_not_found: 'expected %{subject} to respond to %{methods}',
|
50
|
+
}.freeze
|
51
|
+
|
52
|
+
def initialize(attribute)
|
53
|
+
@attribute = attribute.to_sym
|
54
|
+
end
|
53
55
|
|
54
56
|
def description
|
55
|
-
"have a secure password"
|
57
|
+
"have a secure password, defined on #{@attribute} attribute"
|
56
58
|
end
|
57
59
|
|
58
60
|
def matches?(subject)
|
@@ -60,7 +62,8 @@ module Shoulda
|
|
60
62
|
|
61
63
|
if failure = validate
|
62
64
|
key, params = failure
|
63
|
-
@failure_message =
|
65
|
+
@failure_message =
|
66
|
+
MESSAGES[key] % { subject: subject.class }.merge(params)
|
64
67
|
end
|
65
68
|
|
66
69
|
failure.nil?
|
@@ -71,21 +74,44 @@ module Shoulda
|
|
71
74
|
attr_reader :subject
|
72
75
|
|
73
76
|
def validate
|
74
|
-
missing_methods =
|
77
|
+
missing_methods = expected_methods.reject do |m|
|
78
|
+
subject.respond_to?(m)
|
79
|
+
end
|
75
80
|
|
76
81
|
if missing_methods.present?
|
77
82
|
[:method_not_found, { methods: missing_methods.to_sentence }]
|
78
83
|
else
|
79
|
-
subject.
|
80
|
-
subject.
|
84
|
+
subject.send("#{@attribute}=", CORRECT_PASSWORD)
|
85
|
+
subject.send("#{@attribute}_confirmation=", CORRECT_PASSWORD)
|
81
86
|
|
82
|
-
if not subject.
|
83
|
-
[:did_not_authenticate_correct_password,
|
84
|
-
|
85
|
-
|
87
|
+
if not subject.send(authenticate_method, CORRECT_PASSWORD)
|
88
|
+
[:did_not_authenticate_correct_password,
|
89
|
+
{ attribute: @attribute },]
|
90
|
+
elsif subject.send(authenticate_method, INCORRECT_PASSWORD)
|
91
|
+
[:authenticated_incorrect_password, { attribute: @attribute }]
|
86
92
|
end
|
87
93
|
end
|
88
94
|
end
|
95
|
+
|
96
|
+
private
|
97
|
+
|
98
|
+
def expected_methods
|
99
|
+
@_expected_methods ||= %I[
|
100
|
+
#{authenticate_method}
|
101
|
+
#{@attribute}=
|
102
|
+
#{@attribute}_confirmation=
|
103
|
+
#{@attribute}_digest
|
104
|
+
#{@attribute}_digest=
|
105
|
+
]
|
106
|
+
end
|
107
|
+
|
108
|
+
def authenticate_method
|
109
|
+
if @attribute == :password
|
110
|
+
:authenticate
|
111
|
+
else
|
112
|
+
"authenticate_#{@attribute}".to_sym
|
113
|
+
end
|
114
|
+
end
|
89
115
|
end
|
90
116
|
end
|
91
117
|
end
|
@@ -8,7 +8,7 @@ module Shoulda
|
|
8
8
|
end
|
9
9
|
|
10
10
|
def format_validation_errors(errors)
|
11
|
-
list_items = errors.keys.map do |attribute|
|
11
|
+
list_items = errors.to_hash.keys.map do |attribute|
|
12
12
|
messages = errors[attribute]
|
13
13
|
"* #{attribute}: #{messages}"
|
14
14
|
end
|
@@ -26,7 +26,7 @@ module Shoulda
|
|
26
26
|
attribute.to_sym,
|
27
27
|
type,
|
28
28
|
model_name,
|
29
|
-
options
|
29
|
+
options,
|
30
30
|
)
|
31
31
|
end
|
32
32
|
end
|
@@ -5,22 +5,42 @@ module Shoulda
|
|
5
5
|
# @private
|
6
6
|
class ComparisonMatcher < ValidationMatcher
|
7
7
|
ERROR_MESSAGES = {
|
8
|
-
:> =>
|
9
|
-
|
10
|
-
|
11
|
-
|
12
|
-
|
13
|
-
|
8
|
+
:> => {
|
9
|
+
label: :greater_than,
|
10
|
+
assertions: [false, false, true],
|
11
|
+
},
|
12
|
+
:>= => {
|
13
|
+
label: :greater_than_or_equal_to,
|
14
|
+
assertions: [false, true, true],
|
15
|
+
},
|
16
|
+
:< => {
|
17
|
+
label: :less_than,
|
18
|
+
assertions: [true, false, false],
|
19
|
+
},
|
20
|
+
:<= => {
|
21
|
+
label: :less_than_or_equal_to,
|
22
|
+
assertions: [true, true, false],
|
23
|
+
},
|
24
|
+
:== => {
|
25
|
+
label: :equal_to,
|
26
|
+
assertions: [false, true, false],
|
27
|
+
},
|
28
|
+
:!= => {
|
29
|
+
label: :other_than,
|
30
|
+
assertions: [true, false, true],
|
31
|
+
},
|
32
|
+
}.freeze
|
14
33
|
|
15
34
|
def initialize(numericality_matcher, value, operator)
|
16
35
|
super(nil)
|
17
36
|
unless numericality_matcher.respond_to? :diff_to_compare
|
18
37
|
raise ArgumentError, 'numericality_matcher is invalid'
|
19
38
|
end
|
39
|
+
|
20
40
|
@numericality_matcher = numericality_matcher
|
21
41
|
@value = value
|
22
42
|
@operator = operator
|
23
|
-
@message = ERROR_MESSAGES[operator]
|
43
|
+
@message = ERROR_MESSAGES[operator][:label]
|
24
44
|
end
|
25
45
|
|
26
46
|
def simple_description
|
@@ -93,10 +113,9 @@ module Shoulda
|
|
93
113
|
end
|
94
114
|
|
95
115
|
def submatchers_and_results
|
96
|
-
@_submatchers_and_results ||=
|
97
|
-
|
98
|
-
|
99
|
-
end
|
116
|
+
@_submatchers_and_results ||= submatchers.map do |matcher|
|
117
|
+
{ matcher: matcher, matched: matcher.matches?(@subject) }
|
118
|
+
end
|
100
119
|
end
|
101
120
|
|
102
121
|
def comparison_combos
|
@@ -114,18 +133,7 @@ module Shoulda
|
|
114
133
|
end
|
115
134
|
|
116
135
|
def assertions
|
117
|
-
|
118
|
-
when :>
|
119
|
-
[false, false, true]
|
120
|
-
when :>=
|
121
|
-
[false, true, true]
|
122
|
-
when :==
|
123
|
-
[false, true, false]
|
124
|
-
when :<
|
125
|
-
[true, false, false]
|
126
|
-
when :<=
|
127
|
-
[true, true, false]
|
128
|
-
end
|
136
|
+
ERROR_MESSAGES[@operator][:assertions]
|
129
137
|
end
|
130
138
|
|
131
139
|
def diffs_to_compare
|
@@ -140,13 +148,7 @@ module Shoulda
|
|
140
148
|
end
|
141
149
|
|
142
150
|
def comparison_expectation
|
143
|
-
|
144
|
-
when :> then "greater than"
|
145
|
-
when :>= then "greater than or equal to"
|
146
|
-
when :== then "equal to"
|
147
|
-
when :< then "less than"
|
148
|
-
when :<= then "less than or equal to"
|
149
|
-
end
|
151
|
+
ERROR_MESSAGES[@operator][:label].to_s.tr('_', ' ')
|
150
152
|
end
|
151
153
|
end
|
152
154
|
end
|
@@ -17,6 +17,7 @@ module Shoulda
|
|
17
17
|
:ignore_interference_by_writer,
|
18
18
|
:ignoring_interference_by_writer,
|
19
19
|
:matches?,
|
20
|
+
:does_not_match?,
|
20
21
|
:on,
|
21
22
|
:strict,
|
22
23
|
:with_message,
|
@@ -43,7 +44,7 @@ module Shoulda
|
|
43
44
|
|
44
45
|
attr_reader :attribute
|
45
46
|
|
46
|
-
def wrap_disallow_value_matcher(
|
47
|
+
def wrap_disallow_value_matcher(_matcher)
|
47
48
|
raise NotImplementedError
|
48
49
|
end
|
49
50
|
|
@@ -0,0 +1,26 @@
|
|
1
|
+
module Shoulda
|
2
|
+
module Matchers
|
3
|
+
module ActiveModel
|
4
|
+
module Qualifiers
|
5
|
+
# @private
|
6
|
+
module AllowBlank
|
7
|
+
def initialize(*args)
|
8
|
+
super
|
9
|
+
@expects_to_allow_blank = false
|
10
|
+
end
|
11
|
+
|
12
|
+
def allow_blank
|
13
|
+
@expects_to_allow_blank = true
|
14
|
+
self
|
15
|
+
end
|
16
|
+
|
17
|
+
protected
|
18
|
+
|
19
|
+
def expects_to_allow_blank?
|
20
|
+
@expects_to_allow_blank
|
21
|
+
end
|
22
|
+
end
|
23
|
+
end
|
24
|
+
end
|
25
|
+
end
|
26
|
+
end
|
@@ -0,0 +1,26 @@
|
|
1
|
+
module Shoulda
|
2
|
+
module Matchers
|
3
|
+
module ActiveModel
|
4
|
+
module Qualifiers
|
5
|
+
# @private
|
6
|
+
module AllowNil
|
7
|
+
def initialize(*args)
|
8
|
+
super
|
9
|
+
@expects_to_allow_nil = false
|
10
|
+
end
|
11
|
+
|
12
|
+
def allow_nil
|
13
|
+
@expects_to_allow_nil = true
|
14
|
+
self
|
15
|
+
end
|
16
|
+
|
17
|
+
protected
|
18
|
+
|
19
|
+
def expects_to_allow_nil?
|
20
|
+
@expects_to_allow_nil
|
21
|
+
end
|
22
|
+
end
|
23
|
+
end
|
24
|
+
end
|
25
|
+
end
|
26
|
+
end
|