sorbet-rails 0.7.3 → 0.7.33
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/.github/dependabot.yml +7 -0
- data/.github/workflows/ci-master.yml +30 -0
- data/.github/workflows/ci.yml +26 -0
- data/.github/workflows/publish-gem.yml +17 -0
- data/CONTRIBUTING.md +1 -2
- data/Gemfile +5 -9
- data/README.md +44 -6
- data/Rakefile +13 -24
- data/lib/sorbet-rails/active_record_rbi_formatter.rb +18 -15
- data/lib/sorbet-rails/dependent_gem_rbis/activerecord.rbi +4 -0
- data/lib/sorbet-rails/dependent_gem_rbis/parlour.rbi +1896 -0
- data/lib/sorbet-rails/gem_plugins/aasm_plugin.rb +55 -0
- data/lib/sorbet-rails/gem_plugins/attr_json_plugin.rb +137 -0
- data/lib/sorbet-rails/gem_plugins/flag_shih_tzu_plugin.rb +201 -0
- data/lib/sorbet-rails/gem_plugins/kaminari_plugin.rb +20 -0
- data/lib/sorbet-rails/gem_plugins/money_rails_plugin.rb +76 -0
- data/lib/sorbet-rails/gem_plugins/shrine_plugin.rb +1 -1
- data/lib/sorbet-rails/job_rbi_formatter.rb +1 -1
- data/lib/sorbet-rails/model_column_utils.rb +1 -1
- data/lib/sorbet-rails/model_plugins/active_record_assoc.rb +1 -1
- data/lib/sorbet-rails/model_plugins/active_record_querying.rb +38 -1
- data/lib/sorbet-rails/model_plugins/active_record_serialized_attribute.rb +3 -2
- data/lib/sorbet-rails/model_plugins/base.rb +8 -1
- data/lib/sorbet-rails/model_plugins/custom_finder_methods.rb +1 -1
- data/lib/sorbet-rails/model_plugins/plugins.rb +12 -0
- data/lib/sorbet-rails/model_rbi_formatter.rb +7 -4
- data/lib/sorbet-rails/model_utils.rb +14 -7
- data/lib/sorbet-rails/rails_mixins/custom_finder_methods.rb +12 -0
- data/lib/sorbet-rails/railtie.rb +1 -1
- data/lib/sorbet-rails/routes_rbi_formatter.rb +8 -0
- data/lib/sorbet-rails/tasks/rails_rbi.rake +12 -8
- data/sorbet-rails.gemspec +3 -3
- data/spec/bin/run_all_specs.sh +3 -4
- data/spec/bin/run_spec.sh +4 -1
- data/spec/custom_finder_methods_spec.rb +23 -0
- data/spec/generators/rails-template.rb +3 -20
- data/spec/generators/sorbet_test_cases.rb +26 -4
- data/spec/rails_helper.rb +6 -10
- data/spec/rake_rails_rbi_models_spec.rb +11 -4
- data/spec/sorbet_spec.rb +5 -1
- data/spec/support/v5.2/Gemfile +1 -3
- data/spec/support/v5.2/Gemfile.lock +88 -81
- data/spec/support/v5.2/app/controllers/application_controller.rb +1 -1
- data/spec/support/v5.2/app/mailers/application_mailer.rb +1 -1
- data/spec/support/v5.2/app/mailers/daily_prophet_mailer.rb +1 -1
- data/spec/support/v5.2/app/mailers/hogwarts_acceptance_mailer.rb +1 -1
- data/spec/support/v5.2/app/models/spell_book.rb +1 -1
- data/spec/support/v5.2/app/models/wand.rb +1 -1
- data/spec/support/v5.2/app/models/wizard.rb +1 -1
- data/spec/support/v5.2/config/environments/development.rb +1 -1
- data/spec/support/v5.2/config/environments/production.rb +1 -1
- data/spec/support/v5.2/config/environments/test.rb +1 -1
- data/spec/support/v5.2/config/initializers/wrap_parameters.rb +1 -1
- data/spec/support/v5.2/config/routes.rb +1 -1
- data/spec/support/v5.2/sorbet_test_cases.rb +26 -4
- data/spec/support/v6.0/Gemfile +1 -1
- data/spec/support/v6.0/Gemfile.lock +103 -96
- data/spec/support/v6.0/app/mailers/application_mailer.rb +1 -1
- data/spec/support/v6.0/config/environments/development.rb +1 -1
- data/spec/support/v6.0/config/environments/test.rb +1 -1
- data/spec/support/v6.0/config/initializers/cookies_serializer.rb +1 -1
- data/spec/support/v6.0/config/initializers/sorbet_rails.rb +1 -1
- data/spec/support/v6.0/config/routes.rb +1 -1
- data/spec/support/v6.0/sorbet_test_cases.rb +26 -4
- data/spec/support/{v5.1 → v6.1}/.gitignore +13 -2
- data/spec/support/{v5.1 → v6.1}/Gemfile +12 -15
- data/spec/support/v6.1/Gemfile.lock +203 -0
- data/spec/support/{v5.0 → v6.1}/README.md +0 -0
- data/spec/support/{v5.0 → v6.1}/Rakefile +0 -0
- data/spec/support/{v5.0 → v6.1}/app/assets/config/manifest.js +0 -0
- data/spec/support/{v5.0 → v6.1}/app/assets/images/.keep +0 -0
- data/spec/support/{v5.1 → v6.1}/app/assets/stylesheets/application.css +0 -0
- data/spec/support/{v5.0 → v6.1}/app/controllers/application_controller.rb +1 -2
- data/spec/support/{v5.0 → v6.1}/app/controllers/concerns/.keep +0 -0
- data/spec/support/{v5.0 → v6.1}/app/helpers/application_helper.rb +0 -0
- data/spec/support/{v5.0 → v6.1}/app/helpers/bar_helper.rb +0 -0
- data/spec/support/{v5.0 → v6.1}/app/helpers/baz_helper.rb +0 -0
- data/spec/support/{v5.0 → v6.1}/app/helpers/foo_helper.rb +0 -0
- data/spec/support/v6.1/app/jobs/application_job.rb +8 -0
- data/spec/support/{v5.0 → v6.1}/app/jobs/award_house_point_hourglasses.rb +0 -0
- data/spec/support/{v5.1 → v6.1}/app/mailers/application_mailer.rb +1 -1
- data/spec/support/{v5.0 → v6.1}/app/mailers/daily_prophet_mailer.rb +0 -0
- data/spec/support/{v5.0 → v6.1}/app/mailers/hogwarts_acceptance_mailer.rb +0 -0
- data/spec/support/{v5.0 → v6.1}/app/models/application_record.rb +0 -0
- data/spec/support/{v5.0 → v6.1}/app/models/concerns/.keep +0 -0
- data/spec/support/{v5.0 → v6.1}/app/models/concerns/mythical.rb +0 -0
- data/spec/support/{v5.1 → v6.1}/app/models/headmaster.rb +1 -1
- data/spec/support/{v5.1 → v6.1}/app/models/potion.rb +0 -0
- data/spec/support/{v5.1 → v6.1}/app/models/robe.rb +0 -0
- data/spec/support/{v5.0 → v6.1}/app/models/school.rb +1 -1
- data/spec/support/{v5.1 → v6.1}/app/models/spell.rb +0 -0
- data/spec/support/{v5.0 → v6.1}/app/models/spell_book.rb +0 -0
- data/spec/support/{v5.0 → v6.1}/app/models/squib.rb +0 -0
- data/spec/support/{v5.1 → v6.1}/app/models/subject.rb +0 -0
- data/spec/support/{v5.0 → v6.1}/app/models/wand.rb +0 -0
- data/spec/support/{v5.0 → v6.1}/app/models/wizard.rb +2 -1
- data/spec/support/{v5.1 → v6.1}/app/views/layouts/application.html.erb +2 -1
- data/spec/support/{v5.0 → v6.1}/app/views/layouts/mailer.html.erb +0 -0
- data/spec/support/{v5.0 → v6.1}/app/views/layouts/mailer.text.erb +0 -0
- data/spec/support/v6.1/bin/bundle +114 -0
- data/spec/support/{v5.0 → v6.1}/bin/rails +0 -0
- data/spec/support/{v5.0 → v6.1}/bin/rake +0 -0
- data/spec/support/{v5.1 → v6.1}/bin/setup +6 -11
- data/spec/support/{v5.1 → v6.1}/config/application.rb +8 -4
- data/spec/support/{v5.0 → v6.1}/config/boot.rb +0 -0
- data/spec/support/{v5.1 → v6.1}/config/database.yml +1 -1
- data/spec/support/{v5.0 → v6.1}/config/environment.rb +0 -0
- data/spec/support/{v5.1 → v6.1}/config/environments/development.rb +12 -4
- data/spec/support/{v5.1 → v6.1}/config/environments/production.rb +29 -7
- data/spec/support/{v5.1 → v6.1}/config/environments/test.rb +13 -7
- data/spec/support/{v5.0 → v6.1}/config/initializers/application_controller_renderer.rb +0 -0
- data/spec/support/{v5.0 → v6.1}/config/initializers/backtrace_silencers.rb +0 -0
- data/spec/support/v6.1/config/initializers/content_security_policy.rb +29 -0
- data/spec/support/{v5.1 → v6.1}/config/initializers/cookies_serializer.rb +1 -1
- data/spec/support/{v5.0 → v6.1}/config/initializers/filter_parameter_logging.rb +0 -0
- data/spec/support/{v5.0 → v6.1}/config/initializers/inflections.rb +0 -0
- data/spec/support/{v5.0 → v6.1}/config/initializers/mime_types.rb +0 -0
- data/spec/support/{v5.0 → v6.1}/config/initializers/sorbet_rails.rb +1 -1
- data/spec/support/{v5.0 → v6.1}/config/initializers/wrap_parameters.rb +1 -1
- data/spec/support/{v5.1 → v6.1}/config/locales/en.yml +1 -1
- data/spec/support/{v5.1 → v6.1}/config/puma.rb +8 -26
- data/spec/support/v6.1/config/routes.rb +5 -0
- data/spec/support/v6.1/config/storage.yml +34 -0
- data/spec/support/{v5.0 → v6.1}/config.ru +0 -0
- data/spec/support/{v5.1 → v6.1}/db/migrate/20190620000001_create_wizards.rb +2 -2
- data/spec/support/{v5.1 → v6.1}/db/migrate/20190620000002_create_wands.rb +2 -2
- data/spec/support/{v5.1 → v6.1}/db/migrate/20190620000003_create_spell_books.rb +2 -2
- data/spec/support/{v5.1 → v6.1}/db/migrate/20190620000004_add_more_column_types_to_wands.rb +2 -2
- data/spec/support/v6.1/db/migrate/20190620000005_add_broom_to_wizard.rb +6 -0
- data/spec/support/{v5.1 → v6.1}/db/migrate/20190620000006_add_more_enums_to_wizard.rb +2 -2
- data/spec/support/{v5.1 → v6.1}/db/migrate/20190620000007_add_type_to_wizard.rb +2 -2
- data/spec/support/{v5.1 → v6.1}/db/migrate/20190620000008_add_robe_to_wizard.rb +2 -2
- data/spec/support/{v5.1 → v6.1}/db/migrate/20190620000009_add_school.rb +2 -2
- data/spec/support/{v5.1 → v6.1}/db/migrate/20190620000010_add_subject.rb +2 -2
- data/spec/support/{v5.1 → v6.1}/db/migrate/20190620000011_add_subjects_wizards.rb +2 -2
- data/spec/support/{v5.1 → v6.1}/db/migrate/20190620000012_add_spell.rb +2 -2
- data/spec/support/{v5.1 → v6.1}/db/migrate/20190620000013_add_spells_spell_books.rb +2 -2
- data/spec/support/{v5.0 → v6.1}/db/migrate/20190620000014_create_headmasters.rb +2 -2
- data/spec/support/{v5.0 → v6.1}/db/migrate/20190620000015_add_serialized_to_wizards.rb +2 -2
- data/spec/support/{v5.1 → v6.1}/db/schema.rb +14 -11
- data/spec/support/{v5.0 → v6.1}/db/seeds.rb +0 -0
- data/spec/support/{v5.0 → v6.1}/lib/assets/.keep +0 -0
- data/spec/support/{v5.0 → v6.1}/lib/mythical_rbi_plugin.rb +0 -0
- data/spec/support/{v5.0 → v6.1}/lib/tasks/.keep +0 -0
- data/spec/support/{v5.0 → v6.1}/log/.keep +0 -0
- data/spec/support/{v5.0 → v6.1}/sorbet_test_cases.rb +29 -4
- data/spec/support/{v5.0/tmp → v6.1/storage}/.keep +0 -0
- data/spec/support/{v5.0/vendor/assets/stylesheets → v6.1/tmp}/.keep +0 -0
- data/spec/support/{v5.1/app/assets/images → v6.1/tmp/pids}/.keep +0 -0
- data/spec/support/{v5.1/app/controllers/concerns → v6.1/vendor}/.keep +0 -0
- data/spec/test_data/v5.2/expected_active_record_base.rbi +10 -10
- data/spec/test_data/v5.2/expected_active_record_relation.rbi +12 -13
- data/spec/test_data/v5.2/expected_attachment.rbi +16 -10
- data/spec/test_data/v5.2/expected_blob.rbi +16 -10
- data/spec/test_data/v5.2/expected_habtm_subjects.rbi +3 -3
- data/spec/test_data/v5.2/expected_habtm_wizards.rbi +3 -3
- data/spec/test_data/v5.2/expected_headmaster.rbi +16 -10
- data/spec/test_data/v5.2/expected_internal_metadata.rbi +16 -10
- data/spec/test_data/v5.2/expected_potion.rbi +16 -10
- data/spec/test_data/v5.2/expected_robe.rbi +16 -10
- data/spec/test_data/v5.2/expected_routes.rbi +8 -0
- data/spec/test_data/v5.2/expected_schema_migration.rbi +16 -10
- data/spec/test_data/v5.2/expected_school.rbi +16 -10
- data/spec/test_data/v5.2/expected_spell/habtm_spell_books.rbi +16 -10
- data/spec/test_data/v5.2/expected_spell.rbi +16 -10
- data/spec/test_data/v5.2/expected_spell_book/habtm_spell_books.rbi +3 -3
- data/spec/test_data/v5.2/expected_spell_book/habtm_spells.rbi +16 -10
- data/spec/test_data/v5.2/expected_spell_book.rbi +16 -10
- data/spec/test_data/v5.2/expected_squib.rbi +18 -12
- data/spec/test_data/v5.2/expected_subject/habtm_wizards.rbi +16 -10
- data/spec/test_data/v5.2/expected_subject.rbi +16 -10
- data/spec/test_data/v5.2/expected_wand.rbi +16 -10
- data/spec/test_data/v5.2/expected_wizard/habtm_subjects.rbi +16 -10
- data/spec/test_data/v5.2/expected_wizard.rbi +18 -12
- data/spec/test_data/v5.2/expected_wizard_wo_spellbook.rbi +21 -15
- data/spec/test_data/v6.0/expected_active_record_base.rbi +10 -10
- data/spec/test_data/v6.0/expected_active_record_relation.rbi +12 -13
- data/spec/test_data/v6.0/expected_attachment.rbi +16 -10
- data/spec/test_data/v6.0/expected_blob.rbi +16 -10
- data/spec/test_data/v6.0/expected_habtm_subjects.rbi +3 -3
- data/spec/test_data/v6.0/expected_habtm_wizards.rbi +3 -3
- data/spec/test_data/v6.0/expected_headmaster.rbi +16 -10
- data/spec/test_data/v6.0/expected_internal_metadata.rbi +16 -10
- data/spec/test_data/v6.0/expected_potion.rbi +16 -10
- data/spec/test_data/v6.0/expected_robe.rbi +16 -10
- data/spec/test_data/v6.0/expected_routes.rbi +8 -0
- data/spec/test_data/v6.0/expected_schema_migration.rbi +16 -10
- data/spec/test_data/v6.0/expected_school.rbi +16 -10
- data/spec/test_data/v6.0/expected_spell/habtm_spell_books.rbi +16 -10
- data/spec/test_data/v6.0/expected_spell.rbi +16 -10
- data/spec/test_data/v6.0/expected_spell_book/habtm_spell_books.rbi +3 -3
- data/spec/test_data/v6.0/expected_spell_book/habtm_spells.rbi +16 -10
- data/spec/test_data/v6.0/expected_spell_book.rbi +16 -10
- data/spec/test_data/v6.0/expected_squib.rbi +18 -12
- data/spec/test_data/v6.0/expected_subject/habtm_wizards.rbi +16 -10
- data/spec/test_data/v6.0/expected_subject.rbi +16 -10
- data/spec/test_data/v6.0/expected_wand.rbi +16 -10
- data/spec/test_data/v6.0/expected_wizard/habtm_subjects.rbi +16 -10
- data/spec/test_data/v6.0/expected_wizard.rbi +18 -12
- data/spec/test_data/v6.0/expected_wizard_wo_spellbook.rbi +21 -15
- data/spec/test_data/{v5.1 → v6.1}/expected_active_record_base.rbi +16 -16
- data/spec/test_data/{v5.1 → v6.1}/expected_active_record_relation.rbi +28 -32
- data/spec/test_data/{v5.0 → v6.1}/expected_application_job.rbi +0 -0
- data/spec/test_data/{v5.0 → v6.1}/expected_application_mailer.rbi +0 -0
- data/spec/test_data/v6.1/expected_attachment.rbi +340 -0
- data/spec/test_data/{v5.0 → v6.1}/expected_award_house_point_hourglasses.rbi +0 -0
- data/spec/test_data/v6.1/expected_blob.rbi +388 -0
- data/spec/test_data/{v5.0 → v6.1}/expected_custom_application_job.rbi +0 -0
- data/spec/test_data/{v5.0 → v6.1}/expected_custom_application_mailer.rbi +0 -0
- data/spec/test_data/{v5.0 → v6.1}/expected_custom_award_house_point_hourglasses.rbi +0 -0
- data/spec/test_data/{v5.0 → v6.1}/expected_custom_daily_prophet_mailer.rbi +0 -0
- data/spec/test_data/{v5.0 → v6.1}/expected_custom_hogwarts_acceptance_mailer.rbi +0 -0
- data/spec/test_data/{v5.0 → v6.1}/expected_daily_prophet_mailer.rbi +0 -0
- data/spec/test_data/{v5.1 → v6.1}/expected_habtm_subjects.rbi +51 -3
- data/spec/test_data/{v5.1 → v6.1}/expected_habtm_wizards.rbi +51 -3
- data/spec/test_data/{v5.1 → v6.1}/expected_headmaster.rbi +42 -6
- data/spec/test_data/{v5.0 → v6.1}/expected_helpers.rbi +0 -0
- data/spec/test_data/{v5.0 → v6.1}/expected_helpers_with_application_and_devise_helpers.rbi +0 -0
- data/spec/test_data/{v5.0 → v6.1}/expected_hogwarts_acceptance_mailer.rbi +0 -0
- data/spec/test_data/{v5.1 → v6.1}/expected_internal_metadata.rbi +42 -6
- data/spec/test_data/{v5.0 → v6.1}/expected_no_routes.rbi +0 -0
- data/spec/test_data/{v5.1 → v6.1}/expected_potion.rbi +42 -6
- data/spec/test_data/v6.1/expected_record.rbi +301 -0
- data/spec/test_data/{v5.1 → v6.1}/expected_robe.rbi +42 -6
- data/spec/test_data/v6.1/expected_routes.rbi +175 -0
- data/spec/test_data/{v5.1 → v6.1}/expected_schema_migration.rbi +42 -6
- data/spec/test_data/{v5.1 → v6.1}/expected_school.rbi +42 -6
- data/spec/test_data/{v5.1 → v6.1}/expected_spell/habtm_spell_books.rbi +42 -6
- data/spec/test_data/{v5.1 → v6.1}/expected_spell.rbi +42 -6
- data/spec/test_data/{v5.1 → v6.1}/expected_spell_book/habtm_spell_books.rbi +51 -3
- data/spec/test_data/{v5.1 → v6.1}/expected_spell_book/habtm_spells.rbi +42 -6
- data/spec/test_data/{v5.1 → v6.1}/expected_spell_book.rbi +78 -6
- data/spec/test_data/{v5.1 → v6.1}/expected_squib.rbi +514 -64
- data/spec/test_data/{v5.0 → v6.1}/expected_srb_tc_output.txt +0 -0
- data/spec/test_data/{v5.1 → v6.1}/expected_subject/habtm_wizards.rbi +42 -6
- data/spec/test_data/{v5.1 → v6.1}/expected_subject.rbi +42 -6
- data/spec/test_data/v6.1/expected_variant_record.rbi +376 -0
- data/spec/test_data/{v5.1 → v6.1}/expected_wand.rbi +108 -6
- data/spec/test_data/{v5.1 → v6.1}/expected_wizard/habtm_subjects.rbi +42 -6
- data/spec/test_data/{v5.1 → v6.1}/expected_wizard.rbi +514 -64
- data/spec/test_data/{v5.1 → v6.1}/expected_wizard_wo_spellbook.rbi +508 -58
- metadata +271 -503
- data/.travis.yml +0 -42
- data/lib/sorbet-rails/type_assert/actionpack.rbi +0 -4
- data/spec/support/v5.0/.gitignore +0 -21
- data/spec/support/v5.0/Gemfile +0 -37
- data/spec/support/v5.0/Gemfile.lock +0 -158
- data/spec/support/v5.0/app/assets/stylesheets/application.css +0 -15
- data/spec/support/v5.0/app/jobs/application_job.rb +0 -3
- data/spec/support/v5.0/app/mailers/application_mailer.rb +0 -5
- data/spec/support/v5.0/app/models/headmaster.rb +0 -8
- data/spec/support/v5.0/app/models/potion.rb +0 -6
- data/spec/support/v5.0/app/models/robe.rb +0 -4
- data/spec/support/v5.0/app/models/spell.rb +0 -5
- data/spec/support/v5.0/app/models/subject.rb +0 -5
- data/spec/support/v5.0/app/views/layouts/application.html.erb +0 -13
- data/spec/support/v5.0/bin/bundle +0 -3
- data/spec/support/v5.0/bin/setup +0 -34
- data/spec/support/v5.0/bin/update +0 -29
- data/spec/support/v5.0/config/application.rb +0 -27
- data/spec/support/v5.0/config/database.yml +0 -25
- data/spec/support/v5.0/config/environments/development.rb +0 -48
- data/spec/support/v5.0/config/environments/production.rb +0 -75
- data/spec/support/v5.0/config/environments/test.rb +0 -43
- data/spec/support/v5.0/config/initializers/cookies_serializer.rb +0 -6
- data/spec/support/v5.0/config/initializers/new_framework_defaults.rb +0 -27
- data/spec/support/v5.0/config/initializers/session_store.rb +0 -4
- data/spec/support/v5.0/config/locales/en.yml +0 -23
- data/spec/support/v5.0/config/puma.rb +0 -48
- data/spec/support/v5.0/config/routes.rb +0 -5
- data/spec/support/v5.0/db/migrate/20190620000001_create_wizards.rb +0 -14
- data/spec/support/v5.0/db/migrate/20190620000002_create_wands.rb +0 -12
- data/spec/support/v5.0/db/migrate/20190620000003_create_spell_books.rb +0 -10
- data/spec/support/v5.0/db/migrate/20190620000004_add_more_column_types_to_wands.rb +0 -17
- data/spec/support/v5.0/db/migrate/20190620000005_add_broom_to_wizard.rb +0 -6
- data/spec/support/v5.0/db/migrate/20190620000006_add_more_enums_to_wizard.rb +0 -9
- data/spec/support/v5.0/db/migrate/20190620000007_add_type_to_wizard.rb +0 -6
- data/spec/support/v5.0/db/migrate/20190620000008_add_robe_to_wizard.rb +0 -8
- data/spec/support/v5.0/db/migrate/20190620000009_add_school.rb +0 -10
- data/spec/support/v5.0/db/migrate/20190620000010_add_subject.rb +0 -8
- data/spec/support/v5.0/db/migrate/20190620000011_add_subjects_wizards.rb +0 -8
- data/spec/support/v5.0/db/migrate/20190620000012_add_spell.rb +0 -8
- data/spec/support/v5.0/db/migrate/20190620000013_add_spells_spell_books.rb +0 -8
- data/spec/support/v5.0/db/schema.rb +0 -96
- data/spec/support/v5.0/public/robots.txt +0 -5
- data/spec/support/v5.1/Gemfile.lock +0 -165
- data/spec/support/v5.1/README.md +0 -24
- data/spec/support/v5.1/Rakefile +0 -6
- data/spec/support/v5.1/app/assets/config/manifest.js +0 -2
- data/spec/support/v5.1/app/controllers/application_controller.rb +0 -4
- data/spec/support/v5.1/app/helpers/application_helper.rb +0 -3
- data/spec/support/v5.1/app/helpers/bar_helper.rb +0 -3
- data/spec/support/v5.1/app/helpers/baz_helper.rb +0 -3
- data/spec/support/v5.1/app/helpers/foo_helper.rb +0 -3
- data/spec/support/v5.1/app/jobs/application_job.rb +0 -3
- data/spec/support/v5.1/app/jobs/award_house_point_hourglasses.rb +0 -12
- data/spec/support/v5.1/app/mailers/daily_prophet_mailer.rb +0 -9
- data/spec/support/v5.1/app/mailers/hogwarts_acceptance_mailer.rb +0 -29
- data/spec/support/v5.1/app/models/application_record.rb +0 -4
- data/spec/support/v5.1/app/models/concerns/.keep +0 -0
- data/spec/support/v5.1/app/models/concerns/mythical.rb +0 -11
- data/spec/support/v5.1/app/models/school.rb +0 -5
- data/spec/support/v5.1/app/models/spell_book.rb +0 -18
- data/spec/support/v5.1/app/models/squib.rb +0 -6
- data/spec/support/v5.1/app/models/wand.rb +0 -19
- data/spec/support/v5.1/app/models/wizard.rb +0 -65
- data/spec/support/v5.1/app/views/layouts/mailer.html.erb +0 -13
- data/spec/support/v5.1/app/views/layouts/mailer.text.erb +0 -1
- data/spec/support/v5.1/bin/bundle +0 -3
- data/spec/support/v5.1/bin/rails +0 -4
- data/spec/support/v5.1/bin/rake +0 -4
- data/spec/support/v5.1/bin/update +0 -29
- data/spec/support/v5.1/bin/yarn +0 -11
- data/spec/support/v5.1/config/boot.rb +0 -4
- data/spec/support/v5.1/config/environment.rb +0 -6
- data/spec/support/v5.1/config/initializers/application_controller_renderer.rb +0 -9
- data/spec/support/v5.1/config/initializers/backtrace_silencers.rb +0 -8
- data/spec/support/v5.1/config/initializers/filter_parameter_logging.rb +0 -5
- data/spec/support/v5.1/config/initializers/inflections.rb +0 -17
- data/spec/support/v5.1/config/initializers/mime_types.rb +0 -5
- data/spec/support/v5.1/config/initializers/sorbet_rails.rb +0 -3
- data/spec/support/v5.1/config/initializers/wrap_parameters.rb +0 -15
- data/spec/support/v5.1/config/routes.rb +0 -5
- data/spec/support/v5.1/config.ru +0 -5
- data/spec/support/v5.1/db/migrate/20190620000005_add_broom_to_wizard.rb +0 -6
- data/spec/support/v5.1/db/migrate/20190620000014_create_headmasters.rb +0 -9
- data/spec/support/v5.1/db/migrate/20190620000015_add_serialized_to_wizards.rb +0 -9
- data/spec/support/v5.1/db/seeds.rb +0 -8
- data/spec/support/v5.1/lib/assets/.keep +0 -0
- data/spec/support/v5.1/lib/mythical_rbi_plugin.rb +0 -16
- data/spec/support/v5.1/lib/tasks/.keep +0 -0
- data/spec/support/v5.1/log/.keep +0 -0
- data/spec/support/v5.1/package.json +0 -5
- data/spec/support/v5.1/public/robots.txt +0 -1
- data/spec/support/v5.1/sorbet_test_cases.rb +0 -409
- data/spec/support/v5.1/tmp/.keep +0 -0
- data/spec/support/v5.1/vendor/.keep +0 -0
- data/spec/test_data/v5.0/expected_active_record_base.rbi +0 -113
- data/spec/test_data/v5.0/expected_active_record_relation.rbi +0 -199
- data/spec/test_data/v5.0/expected_habtm_subjects.rbi +0 -660
- data/spec/test_data/v5.0/expected_habtm_wizards.rbi +0 -660
- data/spec/test_data/v5.0/expected_headmaster.rbi +0 -328
- data/spec/test_data/v5.0/expected_internal_metadata.rbi +0 -298
- data/spec/test_data/v5.0/expected_potion.rbi +0 -280
- data/spec/test_data/v5.0/expected_robe.rbi +0 -301
- data/spec/test_data/v5.0/expected_routes.rbi +0 -27
- data/spec/test_data/v5.0/expected_schema_migration.rbi +0 -271
- data/spec/test_data/v5.0/expected_school.rbi +0 -301
- data/spec/test_data/v5.0/expected_spell/habtm_spell_books.rbi +0 -319
- data/spec/test_data/v5.0/expected_spell.rbi +0 -292
- data/spec/test_data/v5.0/expected_spell_book/habtm_spell_books.rbi +0 -637
- data/spec/test_data/v5.0/expected_spell_book/habtm_spells.rbi +0 -319
- data/spec/test_data/v5.0/expected_spell_book.rbi +0 -415
- data/spec/test_data/v5.0/expected_squib.rbi +0 -832
- data/spec/test_data/v5.0/expected_subject/habtm_wizards.rbi +0 -319
- data/spec/test_data/v5.0/expected_subject.rbi +0 -292
- data/spec/test_data/v5.0/expected_wand.rbi +0 -497
- data/spec/test_data/v5.0/expected_wizard/habtm_subjects.rbi +0 -319
- data/spec/test_data/v5.0/expected_wizard.rbi +0 -908
- data/spec/test_data/v5.0/expected_wizard_wo_spellbook.rbi +0 -902
- data/spec/test_data/v5.1/expected_application_job.rbi +0 -20
- data/spec/test_data/v5.1/expected_application_mailer.rbi +0 -5
- data/spec/test_data/v5.1/expected_award_house_point_hourglasses.rbi +0 -20
- data/spec/test_data/v5.1/expected_custom_application_job.rbi +0 -21
- data/spec/test_data/v5.1/expected_custom_application_mailer.rbi +0 -6
- data/spec/test_data/v5.1/expected_custom_award_house_point_hourglasses.rbi +0 -21
- data/spec/test_data/v5.1/expected_custom_daily_prophet_mailer.rbi +0 -8
- data/spec/test_data/v5.1/expected_custom_hogwarts_acceptance_mailer.rbi +0 -21
- data/spec/test_data/v5.1/expected_daily_prophet_mailer.rbi +0 -7
- data/spec/test_data/v5.1/expected_helpers.rbi +0 -27
- data/spec/test_data/v5.1/expected_helpers_with_application_and_devise_helpers.rbi +0 -34
- data/spec/test_data/v5.1/expected_hogwarts_acceptance_mailer.rbi +0 -20
- data/spec/test_data/v5.1/expected_no_routes.rbi +0 -4
- data/spec/test_data/v5.1/expected_routes.rbi +0 -27
- data/spec/test_data/v5.1/expected_srb_tc_output.txt +0 -1
@@ -90,9 +90,16 @@ module SorbetRails::ModelUtils
|
|
90
90
|
# where, limit, etc and not something like a named scope. It should likely
|
91
91
|
# only be set to `true` when called from the ActiveRecordQuerying plugin.
|
92
92
|
builtin_query_method: T::Boolean,
|
93
|
+
custom_return_value: T.nilable(String),
|
93
94
|
).void
|
94
95
|
}
|
95
|
-
def add_relation_query_method(
|
96
|
+
def add_relation_query_method(
|
97
|
+
root,
|
98
|
+
method_name,
|
99
|
+
parameters: nil,
|
100
|
+
builtin_query_method: false,
|
101
|
+
custom_return_value: nil
|
102
|
+
)
|
96
103
|
# a relation querying method will be available on
|
97
104
|
# - model (as a class method)
|
98
105
|
# - activerecord relation
|
@@ -114,14 +121,14 @@ module SorbetRails::ModelUtils
|
|
114
121
|
relation_module_rbi.create_method(
|
115
122
|
method_name,
|
116
123
|
parameters: parameters,
|
117
|
-
return_type: self.model_relation_class_name,
|
124
|
+
return_type: custom_return_value || self.model_relation_class_name,
|
118
125
|
)
|
119
126
|
|
120
127
|
assoc_relation_module_rbi = root.create_module(self.model_query_methods_returning_assoc_relation_module_name)
|
121
128
|
assoc_relation_module_rbi.create_method(
|
122
129
|
method_name,
|
123
130
|
parameters: parameters,
|
124
|
-
return_type: assoc_return_value,
|
131
|
+
return_type: custom_return_value || assoc_return_value,
|
125
132
|
)
|
126
133
|
else
|
127
134
|
# force generating these methods because sorbet's hidden-definitions generate & override them
|
@@ -129,7 +136,7 @@ module SorbetRails::ModelUtils
|
|
129
136
|
model_class_rbi.create_method(
|
130
137
|
method_name,
|
131
138
|
parameters: parameters,
|
132
|
-
return_type: self.model_relation_class_name,
|
139
|
+
return_type: custom_return_value || self.model_relation_class_name,
|
133
140
|
class_method: true,
|
134
141
|
)
|
135
142
|
|
@@ -137,21 +144,21 @@ module SorbetRails::ModelUtils
|
|
137
144
|
model_relation_rbi.create_method(
|
138
145
|
method_name,
|
139
146
|
parameters: parameters,
|
140
|
-
return_type: self.model_relation_class_name,
|
147
|
+
return_type: custom_return_value || self.model_relation_class_name,
|
141
148
|
)
|
142
149
|
|
143
150
|
model_assoc_relation_rbi = root.create_class(self.model_assoc_relation_class_name)
|
144
151
|
model_assoc_relation_rbi.create_method(
|
145
152
|
method_name,
|
146
153
|
parameters: parameters,
|
147
|
-
return_type: assoc_return_value,
|
154
|
+
return_type: custom_return_value || assoc_return_value,
|
148
155
|
)
|
149
156
|
|
150
157
|
collection_proxy_rbi = root.create_class(self.model_assoc_proxy_class_name)
|
151
158
|
collection_proxy_rbi.create_method(
|
152
159
|
method_name,
|
153
160
|
parameters: parameters,
|
154
|
-
return_type: assoc_return_value,
|
161
|
+
return_type: custom_return_value || assoc_return_value,
|
155
162
|
)
|
156
163
|
end
|
157
164
|
end
|
@@ -13,6 +13,10 @@ module SorbetRails
|
|
13
13
|
last(n)
|
14
14
|
end
|
15
15
|
|
16
|
+
def select_columns(*args)
|
17
|
+
select(*args)
|
18
|
+
end
|
19
|
+
|
16
20
|
# Redeclare these dynamic methods here otherwise they will be generated by
|
17
21
|
# `srb rbi hidden-definitions`
|
18
22
|
def find_by_id(id)
|
@@ -22,5 +26,13 @@ module SorbetRails
|
|
22
26
|
def find_by_id!(id)
|
23
27
|
find_by!(id: id)
|
24
28
|
end
|
29
|
+
|
30
|
+
# where.missing is only available in Rails 6.1 and above
|
31
|
+
if Rails.version >= "6.1"
|
32
|
+
# https://api.rubyonrails.org/v6.1.4/classes/ActiveRecord/QueryMethods/WhereChain.html#method-i-missing
|
33
|
+
def where_missing(*args)
|
34
|
+
where.missing(*args)
|
35
|
+
end
|
36
|
+
end
|
25
37
|
end
|
26
38
|
end
|
data/lib/sorbet-rails/railtie.rb
CHANGED
@@ -39,6 +39,14 @@ class SorbetRails::RoutesRbiFormatter
|
|
39
39
|
@parlour.root.create_class('ActionMailer::Base') do |mod|
|
40
40
|
mod.create_include('GeneratedUrlHelpers')
|
41
41
|
end
|
42
|
+
|
43
|
+
@parlour.root.create_class('ActionDispatch::IntegrationTest') do |mod|
|
44
|
+
mod.create_include('GeneratedUrlHelpers')
|
45
|
+
end
|
46
|
+
|
47
|
+
@parlour.root.create_class('ActionDispatch::SystemTestCase') do |mod|
|
48
|
+
mod.create_include('GeneratedUrlHelpers')
|
49
|
+
end
|
42
50
|
end
|
43
51
|
|
44
52
|
sig { params(routes: T.untyped, filter: T.untyped).void }
|
@@ -16,12 +16,12 @@ namespace :rails_rbi do
|
|
16
16
|
FileUtils.rm_rf(rails_rbi_root_path)
|
17
17
|
|
18
18
|
# run all rake tasks
|
19
|
-
Rake::Task['
|
20
|
-
Rake::Task['
|
21
|
-
Rake::Task['
|
22
|
-
Rake::Task['
|
23
|
-
Rake::Task['
|
24
|
-
Rake::Task['
|
19
|
+
Rake::Task[rails_rbi_task_name(t, 'routes')].invoke
|
20
|
+
Rake::Task[rails_rbi_task_name(t, 'models')].invoke
|
21
|
+
Rake::Task[rails_rbi_task_name(t, 'helpers')].invoke
|
22
|
+
Rake::Task[rails_rbi_task_name(t, 'mailers')].invoke
|
23
|
+
Rake::Task[rails_rbi_task_name(t, 'jobs')].invoke
|
24
|
+
Rake::Task[rails_rbi_task_name(t, 'custom')].invoke
|
25
25
|
end
|
26
26
|
|
27
27
|
desc "Generate rbis for rails routes"
|
@@ -36,7 +36,7 @@ namespace :rails_rbi do
|
|
36
36
|
end
|
37
37
|
|
38
38
|
desc "Copy custom rbis for typed_params, pluck_to_struct, etc."
|
39
|
-
task custom: :environment do
|
39
|
+
task custom: :environment do |t, args|
|
40
40
|
copy_bundled_rbi('type_assert.rbi')
|
41
41
|
copy_bundled_rbi('pluck_to_tstruct.rbi')
|
42
42
|
copy_bundled_rbi('typed_params.rbi')
|
@@ -44,7 +44,7 @@ namespace :rails_rbi do
|
|
44
44
|
|
45
45
|
# These files were previously bundled_rbi but are now generated so this
|
46
46
|
# is needed for backwards compatibility with anyone using `rails_rbi:custom`
|
47
|
-
Rake::Task['
|
47
|
+
Rake::Task[rails_rbi_task_name(t, 'active_record')].invoke
|
48
48
|
end
|
49
49
|
|
50
50
|
desc "Generate rbis for rails active_record base"
|
@@ -182,4 +182,8 @@ namespace :rails_rbi do
|
|
182
182
|
FileUtils.mkdir_p(File.dirname(copy_to_path))
|
183
183
|
FileUtils.cp(bundled_rbi_file_path, copy_to_path)
|
184
184
|
end
|
185
|
+
|
186
|
+
def rails_rbi_task_name(current_task, target_task_suffix)
|
187
|
+
current_task.to_s.sub(/\w+$/, target_task_suffix)
|
188
|
+
end
|
185
189
|
end
|
data/sorbet-rails.gemspec
CHANGED
@@ -1,6 +1,6 @@
|
|
1
1
|
Gem::Specification.new do |s|
|
2
2
|
s.name = %q{sorbet-rails}
|
3
|
-
s.version = "0.7.
|
3
|
+
s.version = "0.7.33"
|
4
4
|
s.date = %q{2019-04-18}
|
5
5
|
s.summary = %q{Set of tools to make Sorbet work with Rails seamlessly.}
|
6
6
|
s.authors = ["Chan Zuckerberg Initiative"]
|
@@ -16,7 +16,7 @@ Gem::Specification.new do |s|
|
|
16
16
|
end
|
17
17
|
|
18
18
|
s.add_dependency 'parlour', '>= 4.0.1'
|
19
|
-
s.add_dependency 'sorbet-runtime', '>= 0.5'
|
19
|
+
s.add_dependency 'sorbet-runtime', '>= 0.5.9892'
|
20
20
|
s.add_dependency 'sorbet-coerce', '>= 0.2.6'
|
21
21
|
s.add_dependency 'method_source', '>= 0.9.2'
|
22
22
|
s.add_dependency 'parser', '>= 2.7'
|
@@ -25,7 +25,7 @@ Gem::Specification.new do |s|
|
|
25
25
|
s.add_development_dependency 'rspec', '~> 3.8', '>= 3.8'
|
26
26
|
# Debugging
|
27
27
|
s.add_development_dependency 'awesome_print', '~>1.8.0', '>=1.8.0'
|
28
|
-
s.add_development_dependency 'byebug', '~>11.
|
28
|
+
s.add_development_dependency 'byebug', '~>11.1.3', '>=11.1.3'
|
29
29
|
|
30
30
|
# for testing a gem with a rails app (controller specs)
|
31
31
|
s.add_development_dependency 'rspec-rails', '>=3.8.2'
|
data/spec/bin/run_all_specs.sh
CHANGED
@@ -3,9 +3,8 @@
|
|
3
3
|
|
4
4
|
wd="$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )"
|
5
5
|
|
6
|
-
RAILS_VERSION=5.
|
7
|
-
RAILS_VERSION=
|
8
|
-
RAILS_VERSION=6.0 bash $wd/run_spec.sh
|
6
|
+
RAILS_VERSION=5.2 bash $wd/run_spec.sh
|
7
|
+
RAILS_VERSION=6.1 bash $wd/run_spec.sh
|
9
8
|
|
10
|
-
# Always end with the default version, which is Rails
|
9
|
+
# Always end with the default version, which is Rails 6.0
|
11
10
|
bash $wd/run_spec.sh
|
data/spec/bin/run_spec.sh
CHANGED
@@ -6,7 +6,7 @@ wd="$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )"
|
|
6
6
|
current_dir=$(pwd)
|
7
7
|
|
8
8
|
if [[ -z $RAILS_VERSION ]]; then
|
9
|
-
rails_dir="$wd/../support/
|
9
|
+
rails_dir="$wd/../support/v6.0"
|
10
10
|
else
|
11
11
|
rails_dir="$wd/../support/v$RAILS_VERSION"
|
12
12
|
fi
|
@@ -15,7 +15,10 @@ fi
|
|
15
15
|
rm $wd/../../Gemfile.lock 2>/dev/null # clean up Gemfile.lock first
|
16
16
|
bundle install
|
17
17
|
|
18
|
+
echo "===================================================================="
|
19
|
+
echo "Run test for folder:"
|
18
20
|
echo $rails_dir
|
21
|
+
echo "===================================================================="
|
19
22
|
|
20
23
|
# update gems in rails_dir
|
21
24
|
cd $rails_dir
|
@@ -77,4 +77,27 @@ RSpec.describe SorbetRails::CustomFinderMethods do
|
|
77
77
|
expect(wizards_3).to eq([harry, ron, hermione])
|
78
78
|
end
|
79
79
|
end
|
80
|
+
|
81
|
+
context 'test where_missing' do
|
82
|
+
# where.missing is only available in Rails 6.1 and above
|
83
|
+
if Rails.version < "6.1"
|
84
|
+
it 'raises an error' do
|
85
|
+
expect { Wizard.where_missing(:wand) }.to raise_error(NoMethodError)
|
86
|
+
end
|
87
|
+
else
|
88
|
+
it 'works with no arguments' do
|
89
|
+
missing_with_no_args = Wizard.where_missing
|
90
|
+
all_wizards = Wizard.all
|
91
|
+
|
92
|
+
expect(missing_with_no_args).to eq(all_wizards)
|
93
|
+
end
|
94
|
+
|
95
|
+
it 'retrieves wizards with missing wands' do
|
96
|
+
elder_wand = Wand.create!(wizard: harry, wood_type: :holly, core_type: :phoenix_feather)
|
97
|
+
wizards_without_wands = Wizard.where_missing(:wand).to_a
|
98
|
+
|
99
|
+
expect(wizards_without_wands).to eq(Wizard.all.to_a - [harry])
|
100
|
+
end
|
101
|
+
end
|
102
|
+
end
|
80
103
|
end
|
@@ -127,7 +127,7 @@ def create_models
|
|
127
127
|
|
128
128
|
# A nasty hack to add has_one_attached and has_many_attached to the models/wizard.rb file.
|
129
129
|
attachments = nil
|
130
|
-
if ['5.2', '6.0'].include?(ENV["RAILS_VERSION"])
|
130
|
+
if ['5.2', '6.0', '6.1'].include?(ENV["RAILS_VERSION"])
|
131
131
|
attachments = "has_one_attached :school_photo\n has_many_attached :hats"
|
132
132
|
end
|
133
133
|
|
@@ -313,11 +313,8 @@ def create_migrations
|
|
313
313
|
add_column :wands, :broken_at, :datetime, null: true
|
314
314
|
add_column :wands, :chosen_at_date, :date
|
315
315
|
add_column :wands, :chosen_at_time, :time
|
316
|
-
|
317
|
-
|
318
|
-
add_column :wands, :spell_history, :json
|
319
|
-
add_column :wands, :maker_info, :json, null: false, default: '{}'
|
320
|
-
end
|
316
|
+
add_column :wands, :spell_history, :json
|
317
|
+
add_column :wands, :maker_info, :json, null: false, default: '{}'
|
321
318
|
end
|
322
319
|
end
|
323
320
|
RUBY
|
@@ -507,20 +504,6 @@ end
|
|
507
504
|
# Main setup
|
508
505
|
source_paths
|
509
506
|
|
510
|
-
if ['5.0'].include?(ENV["RAILS_VERSION"])
|
511
|
-
File.open('Gemfile', 'r+') do |f|
|
512
|
-
out = ""
|
513
|
-
f.each do |line|
|
514
|
-
# We remove sdoc and web-console because they misbehave.
|
515
|
-
# sqlite needs to be limited to 1.3.x or it won't work.
|
516
|
-
out << line.gsub("gem 'sqlite3'", "gem 'sqlite3', '~> 1.3.6'") unless line =~ /gem \'(sdoc|web-console)\'.*/
|
517
|
-
end
|
518
|
-
f.pos = 0
|
519
|
-
f.print out
|
520
|
-
f.truncate(f.pos)
|
521
|
-
end
|
522
|
-
end
|
523
|
-
|
524
507
|
add_gems
|
525
508
|
|
526
509
|
after_bundle do
|
@@ -84,6 +84,8 @@ T.assert_type!(Wizard.where.not(id: 1), Wizard::ActiveRecord_Relation)
|
|
84
84
|
T.assert_type!(Wizard.preload(:spell_books), Wizard::ActiveRecord_Relation)
|
85
85
|
T.assert_type!(Wizard.eager_load(:spell_books), Wizard::ActiveRecord_Relation)
|
86
86
|
T.assert_type!(Wizard.order(:id), Wizard::ActiveRecord_Relation)
|
87
|
+
T.assert_type!(Wizard.select { |r| r.id == 1 }, T::Array[Wizard])
|
88
|
+
T.assert_type!(Wizard.select_columns(:id, :name), Wizard::ActiveRecord_Relation)
|
87
89
|
|
88
90
|
# Finder methods -- ActiveRecord::Relation
|
89
91
|
T.assert_type!(Wizard.all.exists?(name: 'Harry Potter'), T::Boolean)
|
@@ -121,12 +123,17 @@ T.assert_type!(Wizard.all.find_each, T::Enumerator[Wizard])
|
|
121
123
|
Wizard.all.find_in_batches { |w| T.assert_type!(w, T::Array[Wizard]) }
|
122
124
|
T.assert_type!(Wizard.all.find_in_batches, T::Enumerator[T::Array[Wizard]])
|
123
125
|
Wizard.all.in_batches { |w| T.assert_type!(w, Wizard::ActiveRecord_Relation) }
|
124
|
-
T.assert_type!(Wizard.all.in_batches,
|
126
|
+
T.assert_type!(Wizard.all.in_batches, ActiveRecord::Batches::BatchEnumerator)
|
125
127
|
# T.assert_type!(Wizard.all.destroy_all, T::Array[Wizard]) # Ignored until we add support
|
126
128
|
T.assert_type!(Wizard.all.any?, T::Boolean)
|
127
129
|
T.assert_type!(Wizard.all.many?, T::Boolean)
|
128
130
|
T.assert_type!(Wizard.all.none?, T::Boolean)
|
129
131
|
T.assert_type!(Wizard.all.one?, T::Boolean)
|
132
|
+
T.assert_type!(Wizard.all.any? { |r| r.id > 1 }, T::Boolean)
|
133
|
+
T.assert_type!(Wizard.all.many? { |r| r.id > 1 }, T::Boolean)
|
134
|
+
T.assert_type!(Wizard.all.none? { |r| r.id > 1 }, T::Boolean)
|
135
|
+
T.assert_type!(Wizard.all.one? { |r| r.id > 1 }, T::Boolean)
|
136
|
+
|
130
137
|
# T.assert_type!(Wizard.all.update_all(name: 'Harry Potter'), Integer) # Ignored until we add support
|
131
138
|
# T.assert_type!(Wizard.all.delete_all, Integer) # Ignored until we add support
|
132
139
|
# Query methods
|
@@ -141,6 +148,8 @@ T.assert_type!(Wizard.all.where.not(id: 1), Wizard::ActiveRecord_Relation)
|
|
141
148
|
T.assert_type!(Wizard.all.preload(:spell_books), Wizard::ActiveRecord_Relation)
|
142
149
|
T.assert_type!(Wizard.all.eager_load(:spell_books), Wizard::ActiveRecord_Relation)
|
143
150
|
T.assert_type!(Wizard.all.order(:id), Wizard::ActiveRecord_Relation)
|
151
|
+
T.assert_type!(Wizard.all.select { |r| r.id == 1 }, T::Array[Wizard])
|
152
|
+
T.assert_type!(Wizard.all.select_columns(:id, :name), Wizard::ActiveRecord_Relation)
|
144
153
|
# Enumerable methods
|
145
154
|
Wizard.all.each { |w| T.assert_type!(w, Wizard) }
|
146
155
|
Wizard.all.map { |w| T.assert_type!(w, Wizard) }
|
@@ -185,12 +194,16 @@ T.assert_type!(spell_books.find_each, T::Enumerator[SpellBook])
|
|
185
194
|
spell_books.find_in_batches { |s| T.assert_type!(s, T::Array[SpellBook]) }
|
186
195
|
T.assert_type!(spell_books.find_in_batches, T::Enumerator[T::Array[SpellBook]])
|
187
196
|
spell_books.in_batches { |s| T.assert_type!(s, SpellBook::ActiveRecord_AssociationRelation) }
|
188
|
-
T.assert_type!(spell_books.in_batches,
|
197
|
+
T.assert_type!(spell_books.in_batches, ActiveRecord::Batches::BatchEnumerator)
|
189
198
|
# T.assert_type!(spell_books.destroy_all, T::Array[SpellBook]) # Ignored until we add support
|
190
199
|
T.assert_type!(spell_books.any?, T::Boolean)
|
191
200
|
T.assert_type!(spell_books.many?, T::Boolean)
|
192
201
|
T.assert_type!(spell_books.none?, T::Boolean)
|
193
202
|
T.assert_type!(spell_books.one?, T::Boolean)
|
203
|
+
T.assert_type!(spell_books.any? { |r| r.id > 1 }, T::Boolean)
|
204
|
+
T.assert_type!(spell_books.many? { |r| r.id > 1 }, T::Boolean)
|
205
|
+
T.assert_type!(spell_books.none? { |r| r.id > 1 }, T::Boolean)
|
206
|
+
T.assert_type!(spell_books.one? { |r| r.id > 1 }, T::Boolean)
|
194
207
|
# T.assert_type!(spell_books.update_all(name: 'Fantastic Beasts'), Integer) # Ignored until we add support
|
195
208
|
# T.assert_type!(spell_books.delete_all, Integer) # Ignored until we add support
|
196
209
|
# Query methods
|
@@ -205,6 +218,9 @@ T.assert_type!(spell_books.where.not(id: 1), SpellBook::ActiveRecord_Association
|
|
205
218
|
T.assert_type!(spell_books.preload(:wizard), SpellBook::ActiveRecord_AssociationRelation)
|
206
219
|
T.assert_type!(spell_books.eager_load(:wizard), SpellBook::ActiveRecord_AssociationRelation)
|
207
220
|
T.assert_type!(spell_books.order(:id), SpellBook::ActiveRecord_AssociationRelation)
|
221
|
+
T.assert_type!(spell_books.select { |r| r.id == 1 }, T::Array[SpellBook])
|
222
|
+
T.assert_type!(spell_books.select_columns(:id, :name), SpellBook::ActiveRecord_AssociationRelation)
|
223
|
+
|
208
224
|
# Enumerable methods
|
209
225
|
spell_books.each { |s| T.assert_type!(s, SpellBook) }
|
210
226
|
spell_books.map { |s| T.assert_type!(s, SpellBook) }
|
@@ -257,12 +273,16 @@ T.assert_type!(spell_books_query.find_each, T::Enumerator[SpellBook])
|
|
257
273
|
spell_books_query.find_in_batches { |s| T.assert_type!(s, T::Array[SpellBook]) }
|
258
274
|
T.assert_type!(spell_books_query.find_in_batches, T::Enumerator[T::Array[SpellBook]])
|
259
275
|
spell_books_query.in_batches { |s| T.assert_type!(s, SpellBook::ActiveRecord_AssociationRelation) }
|
260
|
-
T.assert_type!(spell_books_query.in_batches,
|
276
|
+
T.assert_type!(spell_books_query.in_batches, ActiveRecord::Batches::BatchEnumerator)
|
261
277
|
# T.assert_type!(spell_books_query.destroy_all, T::Array[SpellBook]) # Ignored until we add support
|
262
278
|
T.assert_type!(spell_books_query.any?, T::Boolean)
|
263
279
|
T.assert_type!(spell_books_query.many?, T::Boolean)
|
264
280
|
T.assert_type!(spell_books_query.none?, T::Boolean)
|
265
281
|
T.assert_type!(spell_books_query.one?, T::Boolean)
|
282
|
+
T.assert_type!(spell_books_query.any? { |r| r.id > 1 }, T::Boolean)
|
283
|
+
T.assert_type!(spell_books_query.many? { |r| r.id > 1 }, T::Boolean)
|
284
|
+
T.assert_type!(spell_books_query.none? { |r| r.id > 1 }, T::Boolean)
|
285
|
+
T.assert_type!(spell_books_query.one? { |r| r.id > 1 }, T::Boolean)
|
266
286
|
# T.assert_type!(spell_books_query.update_all(name: 'Fantastic Beasts'), Integer) # Ignored until we add support
|
267
287
|
# T.assert_type!(spell_books_query.delete_all, Integer) # Ignored until we add support
|
268
288
|
# Query methods
|
@@ -277,6 +297,8 @@ T.assert_type!(spell_books_query.where.not(id: 1), SpellBook::ActiveRecord_Assoc
|
|
277
297
|
T.assert_type!(spell_books_query.preload(:wizard), SpellBook::ActiveRecord_AssociationRelation)
|
278
298
|
T.assert_type!(spell_books_query.eager_load(:wizard), SpellBook::ActiveRecord_AssociationRelation)
|
279
299
|
T.assert_type!(spell_books_query.order(:id), SpellBook::ActiveRecord_AssociationRelation)
|
300
|
+
T.assert_type!(spell_books.select { |r| r.id == 1 }, T::Array[SpellBook])
|
301
|
+
T.assert_type!(spell_books.select_columns(:id, :name), SpellBook::ActiveRecord_AssociationRelation)
|
280
302
|
# Enumerable methods
|
281
303
|
spell_books_query.each { |s| T.assert_type!(s, SpellBook) }
|
282
304
|
spell_books_query.map { |s| T.assert_type!(s, SpellBook) }
|
@@ -316,7 +338,7 @@ T.assert_type!(
|
|
316
338
|
)
|
317
339
|
T.assert_type!(
|
318
340
|
wizard.patronus_characteristics,
|
319
|
-
T.nilable(
|
341
|
+
T.nilable(ActiveRecord::Coders::JSON),
|
320
342
|
)
|
321
343
|
T.assert_type!(wizard.pets, T.nilable(T::Array[T.untyped]))
|
322
344
|
|
data/spec/rails_helper.rb
CHANGED
@@ -13,14 +13,14 @@ rails_version = ENV["RAILS_VERSION"] || "default"
|
|
13
13
|
|
14
14
|
rails_folder =
|
15
15
|
case rails_version
|
16
|
-
when "5.
|
17
|
-
"v5.
|
18
|
-
when "5.1"
|
19
|
-
"v5.1"
|
16
|
+
when "5.2"
|
17
|
+
"v5.2"
|
20
18
|
when "6.0"
|
21
19
|
"v6.0"
|
20
|
+
when "6.1"
|
21
|
+
"v6.1"
|
22
22
|
else
|
23
|
-
"
|
23
|
+
"v6.0"
|
24
24
|
end
|
25
25
|
|
26
26
|
TEST_DATA_FOLDER = "spec/test_data/#{rails_folder}"
|
@@ -36,7 +36,6 @@ RSpec.configure do |config|
|
|
36
36
|
next if ENV["DISABLE_DATABASE_CLEANER"] == 'true'
|
37
37
|
DatabaseCleaner.clean_with(:truncation, {
|
38
38
|
pre_count: true,
|
39
|
-
reset_ids: false,
|
40
39
|
except: %w(ar_internal_metadata),
|
41
40
|
})
|
42
41
|
end
|
@@ -46,10 +45,7 @@ RSpec.configure do |config|
|
|
46
45
|
example.run
|
47
46
|
next
|
48
47
|
end
|
49
|
-
DatabaseCleaner.strategy = :truncation, {
|
50
|
-
pre_count: true,
|
51
|
-
reset_ids: false,
|
52
|
-
}
|
48
|
+
DatabaseCleaner.strategy = :truncation, { pre_count: true }
|
53
49
|
DatabaseCleaner.start
|
54
50
|
example.run
|
55
51
|
DatabaseCleaner.clean
|
@@ -29,12 +29,19 @@ RSpec.describe 'rake rails_rbi:models', type: :task do
|
|
29
29
|
]
|
30
30
|
)
|
31
31
|
if Object.const_defined?('ActiveStorage')
|
32
|
+
files = [
|
33
|
+
'attachment.rbi',
|
34
|
+
'blob.rbi',
|
35
|
+
]
|
36
|
+
if ENV["RAILS_VERSION"] == '6.1'
|
37
|
+
files += [
|
38
|
+
'record.rbi',
|
39
|
+
'variant_record.rbi',
|
40
|
+
]
|
41
|
+
end
|
32
42
|
expect_files(
|
33
43
|
base_dir: generated_dir_path.join('active_storage'),
|
34
|
-
files:
|
35
|
-
'attachment.rbi',
|
36
|
-
'blob.rbi',
|
37
|
-
],
|
44
|
+
files: files,
|
38
45
|
)
|
39
46
|
end
|
40
47
|
if Object.const_defined?('ActiveRecord::InternalMetadata')
|
data/spec/sorbet_spec.rb
CHANGED
@@ -63,6 +63,9 @@ RSpec.describe 'sorbet' do
|
|
63
63
|
# run sorbet-rails rake tasks
|
64
64
|
Rake::Task['rails_rbi:all'].invoke
|
65
65
|
|
66
|
+
# ensure we remove sorbet-rails.rbi as there are conflicts which cause srb tc to fail
|
67
|
+
FileUtils.rm_f(Rails.root.join('sorbet/rbi/gems/sorbet-rails.rbi'))
|
68
|
+
|
66
69
|
# Regenerate hidden-definitions because there might be conflicts between signature
|
67
70
|
# generated by sorbet-rails & by hidden-definitions
|
68
71
|
# They should be resolved when re-running this script
|
@@ -79,7 +82,8 @@ RSpec.describe 'sorbet' do
|
|
79
82
|
|
80
83
|
it 'returns expected sorbet tc result' do
|
81
84
|
stdout, stderr, status = Open3.capture3(
|
82
|
-
'bundle', 'exec', 'srb', 'tc',
|
85
|
+
# 'bundle', 'exec', 'srb', 'tc',
|
86
|
+
'srb', 'tc',
|
83
87
|
chdir: Rails.root.to_path,
|
84
88
|
)
|
85
89
|
expected_file_path = 'expected_srb_tc_output.txt'
|
data/spec/support/v5.2/Gemfile
CHANGED
@@ -1,8 +1,6 @@
|
|
1
1
|
source 'https://rubygems.org'
|
2
2
|
git_source(:github) { |repo| "https://github.com/#{repo}.git" }
|
3
3
|
|
4
|
-
ruby '2.5.5'
|
5
|
-
|
6
4
|
# Bundle edge Rails instead: gem 'rails', github: 'rails/rails'
|
7
5
|
gem 'rails', '~> 5.2.4', '>= 5.2.4.2'
|
8
6
|
# Use sqlite3 as the database for Active Record
|
@@ -36,4 +34,4 @@ gem 'tzinfo-data', platforms: [:mingw, :mswin, :x64_mingw, :jruby]
|
|
36
34
|
|
37
35
|
gem 'sorbet-rails', path: '../../../.'
|
38
36
|
gem 'sorbet'
|
39
|
-
gem 'sorbet-runtime'
|
37
|
+
gem 'sorbet-runtime'
|