sorbet-rails 0.6.2 → 0.7.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (204) hide show
  1. checksums.yaml +4 -4
  2. data/.travis.yml +2 -0
  3. data/README.md +3 -3
  4. data/lib/bundled_rbi/typed_enum.rbi +7 -0
  5. data/lib/sorbet-rails.rb +0 -2
  6. data/lib/sorbet-rails/active_record_rbi_formatter.rb +301 -0
  7. data/lib/sorbet-rails/config.rb +0 -1
  8. data/lib/sorbet-rails/dependent_gem_rbis/activerecord.rbi +11 -0
  9. data/lib/sorbet-rails/deprecation.rb +5 -0
  10. data/lib/sorbet-rails/gem_plugins/active_flag_plugin.rb +0 -1
  11. data/lib/sorbet-rails/gem_plugins/paperclip_plugin.rb +0 -1
  12. data/lib/sorbet-rails/model_plugins/active_record_assoc.rb +36 -8
  13. data/lib/sorbet-rails/model_plugins/active_record_attribute.rb +20 -9
  14. data/lib/sorbet-rails/model_plugins/active_record_enum.rb +0 -1
  15. data/lib/sorbet-rails/model_plugins/active_record_named_scope.rb +15 -6
  16. data/lib/sorbet-rails/model_plugins/active_record_querying.rb +34 -3
  17. data/lib/sorbet-rails/model_plugins/active_storage_methods.rb +1 -1
  18. data/lib/sorbet-rails/model_plugins/base.rb +10 -0
  19. data/lib/sorbet-rails/model_plugins/enumerable_collections.rb +0 -50
  20. data/lib/sorbet-rails/model_plugins/plugins.rb +0 -3
  21. data/lib/sorbet-rails/model_rbi_formatter.rb +6 -10
  22. data/lib/sorbet-rails/model_utils.rb +83 -36
  23. data/lib/sorbet-rails/rails_mixins/generated_url_helpers.rb +2 -3
  24. data/lib/sorbet-rails/railtie.rb +0 -2
  25. data/lib/sorbet-rails/tasks/rails_rbi.rake +32 -24
  26. data/sorbet-rails.gemspec +2 -2
  27. data/spec/active_record_rbi_formatter_spec.rb +24 -0
  28. data/spec/generators/rails-template.rb +90 -6
  29. data/spec/generators/sorbet_test_cases.rb +204 -122
  30. data/spec/model_rbi_formatter_spec.rb +1 -1
  31. data/spec/rails_helper.rb +14 -1
  32. data/spec/rake_rails_rbi_active_record_spec.rb +21 -0
  33. data/spec/rake_rails_rbi_models_spec.rb +7 -0
  34. data/spec/sorbet_spec.rb +12 -1
  35. data/spec/support/v5.0/Gemfile.lock +8 -8
  36. data/spec/support/v5.0/app/models/headmaster.rb +8 -0
  37. data/spec/support/v5.0/app/models/school.rb +2 -0
  38. data/spec/support/v5.0/app/models/spell.rb +5 -0
  39. data/spec/support/v5.0/app/models/spell_book.rb +5 -0
  40. data/spec/support/v5.0/app/models/subject.rb +5 -0
  41. data/spec/support/v5.0/app/models/wizard.rb +6 -1
  42. data/spec/support/v5.0/db/migrate/20190620000010_add_subject.rb +8 -0
  43. data/spec/support/v5.0/db/migrate/20190620000011_add_subjects_wizards.rb +8 -0
  44. data/spec/support/v5.0/db/migrate/20190620000012_add_spell.rb +8 -0
  45. data/spec/support/v5.0/db/migrate/20190620000013_add_spells_spell_books.rb +8 -0
  46. data/spec/support/v5.0/db/migrate/20190620000014_create_headmasters.rb +9 -0
  47. data/spec/support/v5.0/db/schema.rb +28 -1
  48. data/spec/support/v5.0/lib/mythical_rbi_plugin.rb +1 -1
  49. data/spec/support/v5.0/sorbet_test_cases.rb +204 -122
  50. data/spec/support/v5.1/Gemfile.lock +8 -8
  51. data/spec/support/v5.1/app/models/headmaster.rb +8 -0
  52. data/spec/support/v5.1/app/models/school.rb +2 -0
  53. data/spec/support/v5.1/app/models/spell.rb +5 -0
  54. data/spec/support/v5.1/app/models/spell_book.rb +5 -0
  55. data/spec/support/v5.1/app/models/subject.rb +5 -0
  56. data/spec/support/v5.1/app/models/wizard.rb +6 -1
  57. data/spec/support/v5.1/db/migrate/20190620000010_add_subject.rb +8 -0
  58. data/spec/support/v5.1/db/migrate/20190620000011_add_subjects_wizards.rb +8 -0
  59. data/spec/support/v5.1/db/migrate/20190620000012_add_spell.rb +8 -0
  60. data/spec/support/v5.1/db/migrate/20190620000013_add_spells_spell_books.rb +8 -0
  61. data/spec/support/v5.1/db/migrate/20190620000014_create_headmasters.rb +9 -0
  62. data/spec/support/v5.1/db/schema.rb +28 -1
  63. data/spec/support/v5.1/lib/mythical_rbi_plugin.rb +1 -1
  64. data/spec/support/v5.1/sorbet_test_cases.rb +204 -122
  65. data/spec/support/v5.2/Gemfile +1 -1
  66. data/spec/support/v5.2/Gemfile.lock +9 -9
  67. data/spec/support/v5.2/app/models/headmaster.rb +8 -0
  68. data/spec/support/v5.2/app/models/school.rb +2 -0
  69. data/spec/support/v5.2/app/models/spell.rb +5 -0
  70. data/spec/support/v5.2/app/models/spell_book.rb +5 -0
  71. data/spec/support/v5.2/app/models/subject.rb +5 -0
  72. data/spec/support/v5.2/app/models/wizard.rb +5 -0
  73. data/spec/support/v5.2/config/puma.rb +3 -0
  74. data/spec/support/v5.2/db/migrate/20190620000010_add_subject.rb +8 -0
  75. data/spec/support/v5.2/db/migrate/20190620000011_add_subjects_wizards.rb +8 -0
  76. data/spec/support/v5.2/db/migrate/20190620000012_add_spell.rb +8 -0
  77. data/spec/support/v5.2/db/migrate/20190620000013_add_spells_spell_books.rb +8 -0
  78. data/spec/support/v5.2/db/migrate/20190620000014_create_headmasters.rb +9 -0
  79. data/spec/support/v5.2/db/schema.rb +28 -1
  80. data/spec/support/v5.2/lib/mythical_rbi_plugin.rb +1 -1
  81. data/spec/support/v5.2/sorbet_test_cases.rb +204 -122
  82. data/spec/support/v6.0/Gemfile.lock +8 -8
  83. data/spec/support/v6.0/app/models/headmaster.rb +8 -0
  84. data/spec/support/v6.0/app/models/school.rb +2 -0
  85. data/spec/support/v6.0/app/models/spell.rb +5 -0
  86. data/spec/support/v6.0/app/models/spell_book.rb +5 -0
  87. data/spec/support/v6.0/app/models/subject.rb +5 -0
  88. data/spec/support/v6.0/app/models/wizard.rb +6 -1
  89. data/spec/support/v6.0/db/migrate/20190620000010_add_subject.rb +8 -0
  90. data/spec/support/v6.0/db/migrate/20190620000011_add_subjects_wizards.rb +8 -0
  91. data/spec/support/v6.0/db/migrate/20190620000012_add_spell.rb +8 -0
  92. data/spec/support/v6.0/db/migrate/20190620000013_add_spells_spell_books.rb +8 -0
  93. data/spec/support/v6.0/db/migrate/20190620000014_create_headmasters.rb +9 -0
  94. data/spec/support/v6.0/db/schema.rb +28 -1
  95. data/spec/support/v6.0/lib/mythical_rbi_plugin.rb +1 -1
  96. data/spec/support/v6.0/sorbet_test_cases.rb +204 -122
  97. data/spec/test_data/v5.0/expected_active_record_base.rbi +113 -0
  98. data/spec/test_data/v5.0/expected_active_record_relation.rbi +199 -0
  99. data/spec/test_data/v5.0/expected_habtm_subjects.rbi +660 -0
  100. data/spec/test_data/v5.0/expected_habtm_wizards.rbi +660 -0
  101. data/spec/test_data/v5.0/expected_headmaster.rbi +304 -0
  102. data/spec/test_data/v5.0/expected_internal_metadata.rbi +38 -401
  103. data/spec/test_data/v5.0/expected_potion.rbi +38 -401
  104. data/spec/test_data/v5.0/expected_robe.rbi +38 -403
  105. data/spec/test_data/v5.0/expected_schema_migration.rbi +38 -401
  106. data/spec/test_data/v5.0/expected_school.rbi +47 -401
  107. data/spec/test_data/v5.0/expected_spell.rbi +292 -0
  108. data/spec/test_data/v5.0/expected_spell/habtm_spell_books.rbi +295 -0
  109. data/spec/test_data/v5.0/expected_spell_book.rbi +86 -432
  110. data/spec/test_data/v5.0/expected_spell_book/habtm_spell_books.rbi +637 -0
  111. data/spec/test_data/v5.0/expected_spell_book/habtm_spells.rbi +295 -0
  112. data/spec/test_data/v5.0/expected_squib.rbi +122 -477
  113. data/spec/test_data/v5.0/expected_subject.rbi +292 -0
  114. data/spec/test_data/v5.0/expected_subject/habtm_wizards.rbi +295 -0
  115. data/spec/test_data/v5.0/expected_wand.rbi +75 -442
  116. data/spec/test_data/v5.0/expected_wizard.rbi +144 -498
  117. data/spec/test_data/v5.0/expected_wizard/habtm_subjects.rbi +295 -0
  118. data/spec/test_data/v5.0/expected_wizard_wo_spellbook.rbi +138 -498
  119. data/spec/test_data/v5.1/expected_active_record_base.rbi +113 -0
  120. data/spec/test_data/v5.1/expected_active_record_relation.rbi +178 -0
  121. data/spec/test_data/v5.1/expected_habtm_subjects.rbi +672 -0
  122. data/spec/test_data/v5.1/expected_habtm_wizards.rbi +672 -0
  123. data/spec/test_data/v5.1/expected_headmaster.rbi +310 -0
  124. data/spec/test_data/v5.1/expected_internal_metadata.rbi +38 -407
  125. data/spec/test_data/v5.1/expected_potion.rbi +38 -407
  126. data/spec/test_data/v5.1/expected_robe.rbi +38 -409
  127. data/spec/test_data/v5.1/expected_schema_migration.rbi +38 -407
  128. data/spec/test_data/v5.1/expected_school.rbi +47 -407
  129. data/spec/test_data/v5.1/expected_spell.rbi +298 -0
  130. data/spec/test_data/v5.1/expected_spell/habtm_spell_books.rbi +301 -0
  131. data/spec/test_data/v5.1/expected_spell_book.rbi +86 -438
  132. data/spec/test_data/v5.1/expected_spell_book/habtm_spell_books.rbi +649 -0
  133. data/spec/test_data/v5.1/expected_spell_book/habtm_spells.rbi +301 -0
  134. data/spec/test_data/v5.1/expected_squib.rbi +123 -484
  135. data/spec/test_data/v5.1/expected_subject.rbi +298 -0
  136. data/spec/test_data/v5.1/expected_subject/habtm_wizards.rbi +301 -0
  137. data/spec/test_data/v5.1/expected_wand.rbi +75 -448
  138. data/spec/test_data/v5.1/expected_wizard.rbi +145 -505
  139. data/spec/test_data/v5.1/expected_wizard/habtm_subjects.rbi +301 -0
  140. data/spec/test_data/v5.1/expected_wizard_wo_spellbook.rbi +139 -505
  141. data/spec/test_data/v5.2/expected_active_record_base.rbi +113 -0
  142. data/spec/test_data/v5.2/expected_active_record_relation.rbi +175 -0
  143. data/spec/test_data/v5.2/expected_attachment.rbi +38 -407
  144. data/spec/test_data/v5.2/expected_blob.rbi +60 -426
  145. data/spec/test_data/v5.2/expected_habtm_subjects.rbi +672 -0
  146. data/spec/test_data/v5.2/expected_habtm_wizards.rbi +672 -0
  147. data/spec/test_data/v5.2/expected_headmaster.rbi +310 -0
  148. data/spec/test_data/v5.2/expected_internal_metadata.rbi +38 -407
  149. data/spec/test_data/v5.2/expected_potion.rbi +38 -407
  150. data/spec/test_data/v5.2/expected_robe.rbi +38 -409
  151. data/spec/test_data/v5.2/expected_schema_migration.rbi +38 -407
  152. data/spec/test_data/v5.2/expected_school.rbi +47 -407
  153. data/spec/test_data/v5.2/expected_spell.rbi +298 -0
  154. data/spec/test_data/v5.2/expected_spell/habtm_spell_books.rbi +301 -0
  155. data/spec/test_data/v5.2/expected_spell_book.rbi +86 -438
  156. data/spec/test_data/v5.2/expected_spell_book/habtm_spell_books.rbi +649 -0
  157. data/spec/test_data/v5.2/expected_spell_book/habtm_spells.rbi +301 -0
  158. data/spec/test_data/v5.2/expected_squib.rbi +133 -488
  159. data/spec/test_data/v5.2/expected_subject.rbi +298 -0
  160. data/spec/test_data/v5.2/expected_subject/habtm_wizards.rbi +301 -0
  161. data/spec/test_data/v5.2/expected_wand.rbi +75 -448
  162. data/spec/test_data/v5.2/expected_wizard.rbi +155 -509
  163. data/spec/test_data/v5.2/expected_wizard/habtm_subjects.rbi +301 -0
  164. data/spec/test_data/v5.2/expected_wizard_wo_spellbook.rbi +149 -509
  165. data/spec/test_data/v6.0/expected_active_record_base.rbi +113 -0
  166. data/spec/test_data/v6.0/expected_active_record_relation.rbi +175 -0
  167. data/spec/test_data/v6.0/expected_attachment.rbi +38 -431
  168. data/spec/test_data/v6.0/expected_blob.rbi +60 -450
  169. data/spec/test_data/v6.0/expected_habtm_subjects.rbi +720 -0
  170. data/spec/test_data/v6.0/expected_habtm_wizards.rbi +720 -0
  171. data/spec/test_data/v6.0/expected_headmaster.rbi +334 -0
  172. data/spec/test_data/v6.0/expected_internal_metadata.rbi +38 -431
  173. data/spec/test_data/v6.0/expected_potion.rbi +38 -431
  174. data/spec/test_data/v6.0/expected_robe.rbi +38 -433
  175. data/spec/test_data/v6.0/expected_routes.rbi +14 -7
  176. data/spec/test_data/v6.0/expected_schema_migration.rbi +38 -431
  177. data/spec/test_data/v6.0/expected_school.rbi +47 -431
  178. data/spec/test_data/v6.0/expected_spell.rbi +322 -0
  179. data/spec/test_data/v6.0/expected_spell/habtm_spell_books.rbi +325 -0
  180. data/spec/test_data/v6.0/expected_spell_book.rbi +98 -474
  181. data/spec/test_data/v6.0/expected_spell_book/habtm_spell_books.rbi +697 -0
  182. data/spec/test_data/v6.0/expected_spell_book/habtm_spells.rbi +325 -0
  183. data/spec/test_data/v6.0/expected_squib.rbi +162 -541
  184. data/spec/test_data/v6.0/expected_subject.rbi +322 -0
  185. data/spec/test_data/v6.0/expected_subject/habtm_wizards.rbi +325 -0
  186. data/spec/test_data/v6.0/expected_wand.rbi +91 -488
  187. data/spec/test_data/v6.0/expected_wizard.rbi +184 -562
  188. data/spec/test_data/v6.0/expected_wizard/habtm_subjects.rbi +325 -0
  189. data/spec/test_data/v6.0/expected_wizard_wo_spellbook.rbi +178 -562
  190. metadata +170 -24
  191. data/lib/bundled_rbi/active_record_base.rbi +0 -83
  192. data/lib/bundled_rbi/active_record_relation.rbi +0 -122
  193. data/lib/bundled_rbi/parameters.rbi +0 -28
  194. data/lib/sorbet-rails/custom_types/boolean_string.rb +0 -32
  195. data/lib/sorbet-rails/custom_types/integer_string.rb +0 -35
  196. data/lib/sorbet-rails/model_plugins/active_record_finder_methods.rb +0 -131
  197. data/lib/sorbet-rails/rails_mixins/custom_params_methods.rb +0 -46
  198. data/spec/boolean_string_spec.rb +0 -59
  199. data/spec/custom_params_methods_spec.rb +0 -138
  200. data/spec/integer_string_spec.rb +0 -46
  201. data/spec/support/v5.0/typed-override.yaml +0 -2
  202. data/spec/support/v5.1/typed-override.yaml +0 -2
  203. data/spec/support/v5.2/typed-override.yaml +0 -2
  204. data/spec/support/v6.0/typed-override.yaml +0 -2
@@ -8,11 +8,12 @@ module ActiveStorage::Blob::ActiveRelation_WhereNot
8
8
  end
9
9
 
10
10
  module ActiveStorage::Blob::GeneratedAssociationMethods
11
- extend T::Sig
12
-
13
11
  sig { returns(::ActiveStorage::Attachment::ActiveRecord_Associations_CollectionProxy) }
14
12
  def attachments; end
15
13
 
14
+ sig { returns(T::Array[Integer]) }
15
+ def attachment_ids; end
16
+
16
17
  sig { params(value: T::Enumerable[::ActiveStorage::Attachment]).void }
17
18
  def attachments=(value); end
18
19
 
@@ -49,8 +50,7 @@ end
49
50
  class ActiveStorage::Blob < ActiveRecord::Base
50
51
  include ActiveStorage::Blob::GeneratedAssociationMethods
51
52
  extend ActiveStorage::Blob::CustomFinderMethods
52
- extend T::Sig
53
- extend T::Generic
53
+ extend ActiveStorage::Blob::QueryMethodsReturningRelation
54
54
  RelationType = T.type_alias { T.any(ActiveStorage::Blob::ActiveRecord_Relation, ActiveStorage::Blob::ActiveRecord_Associations_CollectionProxy, ActiveStorage::Blob::ActiveRecord_AssociationRelation) }
55
55
 
56
56
  sig { params(args: T.untyped).returns(ActiveStorage::Blob::ActiveRecord_Relation) }
@@ -58,127 +58,59 @@ class ActiveStorage::Blob < ActiveRecord::Base
58
58
 
59
59
  sig { params(args: T.untyped).returns(ActiveStorage::Blob::ActiveRecord_Relation) }
60
60
  def self.with_attached_preview_image(*args); end
61
+ end
61
62
 
62
- sig { returns(ActiveStorage::Blob::ActiveRecord_Relation) }
63
- def self.all; end
64
-
65
- sig { params(block: T.nilable(T.proc.void)).returns(ActiveStorage::Blob::ActiveRecord_Relation) }
66
- def self.unscoped(&block); end
67
-
68
- sig { params(args: T.untyped).returns(ActiveStorage::Blob::ActiveRecord_Relation) }
69
- def self.select(*args); end
70
-
71
- sig { params(args: T.untyped).returns(ActiveStorage::Blob::ActiveRecord_Relation) }
72
- def self.order(*args); end
73
-
74
- sig { params(args: T.untyped).returns(ActiveStorage::Blob::ActiveRecord_Relation) }
75
- def self.reorder(*args); end
76
-
77
- sig { params(args: T.untyped).returns(ActiveStorage::Blob::ActiveRecord_Relation) }
78
- def self.group(*args); end
79
-
80
- sig { params(args: T.untyped).returns(ActiveStorage::Blob::ActiveRecord_Relation) }
81
- def self.limit(*args); end
82
-
83
- sig { params(args: T.untyped).returns(ActiveStorage::Blob::ActiveRecord_Relation) }
84
- def self.offset(*args); end
85
-
86
- sig { params(args: T.untyped).returns(ActiveStorage::Blob::ActiveRecord_Relation) }
87
- def self.joins(*args); end
88
-
89
- sig { params(args: T.untyped).returns(ActiveStorage::Blob::ActiveRecord_Relation) }
90
- def self.left_joins(*args); end
91
-
92
- sig { params(args: T.untyped).returns(ActiveStorage::Blob::ActiveRecord_Relation) }
93
- def self.left_outer_joins(*args); end
94
-
95
- sig { params(args: T.untyped).returns(ActiveStorage::Blob::ActiveRecord_Relation) }
96
- def self.where(*args); end
97
-
98
- sig { params(args: T.untyped).returns(ActiveStorage::Blob::ActiveRecord_Relation) }
99
- def self.rewhere(*args); end
100
-
101
- sig { params(args: T.untyped).returns(ActiveStorage::Blob::ActiveRecord_Relation) }
102
- def self.preload(*args); end
103
-
104
- sig { params(args: T.untyped).returns(ActiveStorage::Blob::ActiveRecord_Relation) }
105
- def self.eager_load(*args); end
106
-
107
- sig { params(args: T.untyped).returns(ActiveStorage::Blob::ActiveRecord_Relation) }
108
- def self.includes(*args); end
109
-
110
- sig { params(args: T.untyped).returns(ActiveStorage::Blob::ActiveRecord_Relation) }
111
- def self.from(*args); end
112
-
113
- sig { params(args: T.untyped).returns(ActiveStorage::Blob::ActiveRecord_Relation) }
114
- def self.lock(*args); end
115
-
116
- sig { params(args: T.untyped).returns(ActiveStorage::Blob::ActiveRecord_Relation) }
117
- def self.readonly(*args); end
118
-
119
- sig { params(args: T.untyped).returns(ActiveStorage::Blob::ActiveRecord_Relation) }
120
- def self.or(*args); end
121
-
122
- sig { params(args: T.untyped).returns(ActiveStorage::Blob::ActiveRecord_Relation) }
123
- def self.having(*args); end
124
-
125
- sig { params(args: T.untyped).returns(ActiveStorage::Blob::ActiveRecord_Relation) }
126
- def self.create_with(*args); end
127
-
128
- sig { params(args: T.untyped).returns(ActiveStorage::Blob::ActiveRecord_Relation) }
129
- def self.distinct(*args); end
130
-
131
- sig { params(args: T.untyped).returns(ActiveStorage::Blob::ActiveRecord_Relation) }
132
- def self.references(*args); end
133
-
134
- sig { params(args: T.untyped).returns(ActiveStorage::Blob::ActiveRecord_Relation) }
135
- def self.none(*args); end
136
-
137
- sig { params(args: T.untyped).returns(ActiveStorage::Blob::ActiveRecord_Relation) }
138
- def self.unscope(*args); end
63
+ class ActiveStorage::Blob::ActiveRecord_Relation < ActiveRecord::Relation
64
+ include ActiveStorage::Blob::ActiveRelation_WhereNot
65
+ include ActiveStorage::Blob::CustomFinderMethods
66
+ include ActiveStorage::Blob::QueryMethodsReturningRelation
67
+ Elem = type_member(fixed: ActiveStorage::Blob)
139
68
 
140
69
  sig { params(args: T.untyped).returns(ActiveStorage::Blob::ActiveRecord_Relation) }
141
- def self.merge(*args); end
70
+ def unattached(*args); end
142
71
 
143
72
  sig { params(args: T.untyped).returns(ActiveStorage::Blob::ActiveRecord_Relation) }
144
- def self.except(*args); end
145
-
146
- sig { params(args: T.untyped, block: T.nilable(T.proc.void)).returns(ActiveStorage::Blob::ActiveRecord_Relation) }
147
- def self.extending(*args, &block); end
148
-
149
- sig { params(conditions: T.untyped).returns(T::Boolean) }
150
- def self.exists?(conditions = nil); end
151
-
152
- sig { params(args: T.untyped).returns(T::Boolean) }
153
- def self.any?(*args); end
154
-
155
- sig { params(args: T.untyped).returns(T::Boolean) }
156
- def self.many?(*args); end
73
+ def with_attached_preview_image(*args); end
74
+ end
157
75
 
158
- sig { params(args: T.untyped).returns(T::Boolean) }
159
- def self.none?(*args); end
76
+ class ActiveStorage::Blob::ActiveRecord_AssociationRelation < ActiveRecord::AssociationRelation
77
+ include ActiveStorage::Blob::ActiveRelation_WhereNot
78
+ include ActiveStorage::Blob::CustomFinderMethods
79
+ include ActiveStorage::Blob::QueryMethodsReturningAssociationRelation
80
+ Elem = type_member(fixed: ActiveStorage::Blob)
160
81
 
161
- sig { params(args: T.untyped).returns(T::Boolean) }
162
- def self.one?(*args); end
82
+ sig { params(args: T.untyped).returns(ActiveStorage::Blob::ActiveRecord_AssociationRelation) }
83
+ def unattached(*args); end
163
84
 
164
- sig { params(args: T.untyped).returns(T::Boolean) }
165
- def self.empty?(*args); end
85
+ sig { params(args: T.untyped).returns(ActiveStorage::Blob::ActiveRecord_AssociationRelation) }
86
+ def with_attached_preview_image(*args); end
166
87
  end
167
88
 
168
- class ActiveStorage::Blob::ActiveRecord_Relation < ActiveRecord::Relation
169
- include ActiveStorage::Blob::ActiveRelation_WhereNot
89
+ class ActiveStorage::Blob::ActiveRecord_Associations_CollectionProxy < ActiveRecord::Associations::CollectionProxy
170
90
  include ActiveStorage::Blob::CustomFinderMethods
171
- include Enumerable
172
- extend T::Sig
173
- extend T::Generic
91
+ include ActiveStorage::Blob::QueryMethodsReturningAssociationRelation
174
92
  Elem = type_member(fixed: ActiveStorage::Blob)
175
93
 
176
- sig { params(args: T.untyped).returns(ActiveStorage::Blob::ActiveRecord_Relation) }
94
+ sig { params(args: T.untyped).returns(ActiveStorage::Blob::ActiveRecord_AssociationRelation) }
177
95
  def unattached(*args); end
178
96
 
179
- sig { params(args: T.untyped).returns(ActiveStorage::Blob::ActiveRecord_Relation) }
97
+ sig { params(args: T.untyped).returns(ActiveStorage::Blob::ActiveRecord_AssociationRelation) }
180
98
  def with_attached_preview_image(*args); end
181
99
 
100
+ sig { params(records: T.any(ActiveStorage::Blob, T::Array[ActiveStorage::Blob])).returns(T.self_type) }
101
+ def <<(*records); end
102
+
103
+ sig { params(records: T.any(ActiveStorage::Blob, T::Array[ActiveStorage::Blob])).returns(T.self_type) }
104
+ def append(*records); end
105
+
106
+ sig { params(records: T.any(ActiveStorage::Blob, T::Array[ActiveStorage::Blob])).returns(T.self_type) }
107
+ def push(*records); end
108
+
109
+ sig { params(records: T.any(ActiveStorage::Blob, T::Array[ActiveStorage::Blob])).returns(T.self_type) }
110
+ def concat(*records); end
111
+ end
112
+
113
+ module ActiveStorage::Blob::QueryMethodsReturningRelation
182
114
  sig { returns(ActiveStorage::Blob::ActiveRecord_Relation) }
183
115
  def all; end
184
116
 
@@ -266,233 +198,24 @@ class ActiveStorage::Blob::ActiveRecord_Relation < ActiveRecord::Relation
266
198
  sig { params(args: T.untyped, block: T.nilable(T.proc.void)).returns(ActiveStorage::Blob::ActiveRecord_Relation) }
267
199
  def extending(*args, &block); end
268
200
 
269
- sig { params(conditions: T.untyped).returns(T::Boolean) }
270
- def exists?(conditions = nil); end
271
-
272
- sig { params(args: T.untyped).returns(T::Boolean) }
273
- def any?(*args); end
274
-
275
- sig { params(args: T.untyped).returns(T::Boolean) }
276
- def many?(*args); end
277
-
278
- sig { params(args: T.untyped).returns(T::Boolean) }
279
- def none?(*args); end
280
-
281
- sig { params(args: T.untyped).returns(T::Boolean) }
282
- def one?(*args); end
283
-
284
- sig { params(args: T.untyped).returns(T::Boolean) }
285
- def empty?(*args); end
286
- end
287
-
288
- class ActiveStorage::Blob::ActiveRecord_AssociationRelation < ActiveRecord::AssociationRelation
289
- include ActiveStorage::Blob::ActiveRelation_WhereNot
290
- include ActiveStorage::Blob::CustomFinderMethods
291
- include Enumerable
292
- extend T::Sig
293
- extend T::Generic
294
- Elem = type_member(fixed: ActiveStorage::Blob)
295
-
296
- sig { params(args: T.untyped).returns(ActiveStorage::Blob::ActiveRecord_AssociationRelation) }
297
- def unattached(*args); end
298
-
299
- sig { params(args: T.untyped).returns(ActiveStorage::Blob::ActiveRecord_AssociationRelation) }
300
- def with_attached_preview_image(*args); end
301
-
302
- sig { returns(ActiveStorage::Blob::ActiveRecord_AssociationRelation) }
303
- def all; end
304
-
305
- sig { params(block: T.nilable(T.proc.void)).returns(ActiveStorage::Blob::ActiveRecord_AssociationRelation) }
306
- def unscoped(&block); end
307
-
308
- sig { params(args: T.untyped).returns(ActiveStorage::Blob::ActiveRecord_AssociationRelation) }
309
- def select(*args); end
310
-
311
- sig { params(args: T.untyped).returns(ActiveStorage::Blob::ActiveRecord_AssociationRelation) }
312
- def order(*args); end
313
-
314
- sig { params(args: T.untyped).returns(ActiveStorage::Blob::ActiveRecord_AssociationRelation) }
315
- def reorder(*args); end
316
-
317
- sig { params(args: T.untyped).returns(ActiveStorage::Blob::ActiveRecord_AssociationRelation) }
318
- def group(*args); end
319
-
320
- sig { params(args: T.untyped).returns(ActiveStorage::Blob::ActiveRecord_AssociationRelation) }
321
- def limit(*args); end
322
-
323
- sig { params(args: T.untyped).returns(ActiveStorage::Blob::ActiveRecord_AssociationRelation) }
324
- def offset(*args); end
325
-
326
- sig { params(args: T.untyped).returns(ActiveStorage::Blob::ActiveRecord_AssociationRelation) }
327
- def joins(*args); end
328
-
329
- sig { params(args: T.untyped).returns(ActiveStorage::Blob::ActiveRecord_AssociationRelation) }
330
- def left_joins(*args); end
331
-
332
- sig { params(args: T.untyped).returns(ActiveStorage::Blob::ActiveRecord_AssociationRelation) }
333
- def left_outer_joins(*args); end
334
-
335
- sig { params(args: T.untyped).returns(ActiveStorage::Blob::ActiveRecord_AssociationRelation) }
336
- def where(*args); end
337
-
338
- sig { params(args: T.untyped).returns(ActiveStorage::Blob::ActiveRecord_AssociationRelation) }
339
- def rewhere(*args); end
340
-
341
- sig { params(args: T.untyped).returns(ActiveStorage::Blob::ActiveRecord_AssociationRelation) }
342
- def preload(*args); end
343
-
344
- sig { params(args: T.untyped).returns(ActiveStorage::Blob::ActiveRecord_AssociationRelation) }
345
- def eager_load(*args); end
346
-
347
- sig { params(args: T.untyped).returns(ActiveStorage::Blob::ActiveRecord_AssociationRelation) }
348
- def includes(*args); end
349
-
350
- sig { params(args: T.untyped).returns(ActiveStorage::Blob::ActiveRecord_AssociationRelation) }
351
- def from(*args); end
352
-
353
- sig { params(args: T.untyped).returns(ActiveStorage::Blob::ActiveRecord_AssociationRelation) }
354
- def lock(*args); end
355
-
356
- sig { params(args: T.untyped).returns(ActiveStorage::Blob::ActiveRecord_AssociationRelation) }
357
- def readonly(*args); end
358
-
359
- sig { params(args: T.untyped).returns(ActiveStorage::Blob::ActiveRecord_AssociationRelation) }
360
- def or(*args); end
361
-
362
- sig { params(args: T.untyped).returns(ActiveStorage::Blob::ActiveRecord_AssociationRelation) }
363
- def having(*args); end
364
-
365
- sig { params(args: T.untyped).returns(ActiveStorage::Blob::ActiveRecord_AssociationRelation) }
366
- def create_with(*args); end
367
-
368
- sig { params(args: T.untyped).returns(ActiveStorage::Blob::ActiveRecord_AssociationRelation) }
369
- def distinct(*args); end
370
-
371
- sig { params(args: T.untyped).returns(ActiveStorage::Blob::ActiveRecord_AssociationRelation) }
372
- def references(*args); end
373
-
374
- sig { params(args: T.untyped).returns(ActiveStorage::Blob::ActiveRecord_AssociationRelation) }
375
- def none(*args); end
376
-
377
- sig { params(args: T.untyped).returns(ActiveStorage::Blob::ActiveRecord_AssociationRelation) }
378
- def unscope(*args); end
379
-
380
- sig { params(args: T.untyped).returns(ActiveStorage::Blob::ActiveRecord_AssociationRelation) }
381
- def merge(*args); end
382
-
383
- sig { params(args: T.untyped).returns(ActiveStorage::Blob::ActiveRecord_AssociationRelation) }
384
- def except(*args); end
385
-
386
- sig { params(args: T.untyped, block: T.nilable(T.proc.void)).returns(ActiveStorage::Blob::ActiveRecord_AssociationRelation) }
387
- def extending(*args, &block); end
388
-
389
- sig { params(args: T.untyped).returns(ActiveStorage::Blob) }
390
- def find(*args); end
391
-
392
- sig { params(args: T.untyped).returns(T.nilable(ActiveStorage::Blob)) }
393
- def find_by(*args); end
394
-
395
- sig { params(args: T.untyped).returns(ActiveStorage::Blob) }
396
- def find_by!(*args); end
397
-
398
- sig { params(attributes: T.untyped, block: T.nilable(T.proc.params(object: ActiveStorage::Blob).void)).returns(ActiveStorage::Blob) }
399
- def find_or_initialize_by(attributes, &block); end
400
-
401
- sig { params(attributes: T.untyped, block: T.nilable(T.proc.params(object: ActiveStorage::Blob).void)).returns(ActiveStorage::Blob) }
402
- def find_or_create_by(attributes, &block); end
403
-
404
- sig { params(attributes: T.untyped, block: T.nilable(T.proc.params(object: ActiveStorage::Blob).void)).returns(ActiveStorage::Blob) }
405
- def find_or_create_by!(attributes, &block); end
406
-
407
- sig { returns(T.nilable(ActiveStorage::Blob)) }
408
- def first; end
409
-
410
- sig { returns(ActiveStorage::Blob) }
411
- def first!; end
412
-
413
- sig { returns(T.nilable(ActiveStorage::Blob)) }
414
- def second; end
415
-
416
- sig { returns(ActiveStorage::Blob) }
417
- def second!; end
418
-
419
- sig { returns(T.nilable(ActiveStorage::Blob)) }
420
- def third; end
421
-
422
- sig { returns(ActiveStorage::Blob) }
423
- def third!; end
424
-
425
- sig { returns(T.nilable(ActiveStorage::Blob)) }
426
- def third_to_last; end
427
-
428
- sig { returns(ActiveStorage::Blob) }
429
- def third_to_last!; end
430
-
431
- sig { returns(T.nilable(ActiveStorage::Blob)) }
432
- def second_to_last; end
433
-
434
- sig { returns(ActiveStorage::Blob) }
435
- def second_to_last!; end
436
-
437
- sig { returns(T.nilable(ActiveStorage::Blob)) }
438
- def last; end
439
-
440
- sig { returns(ActiveStorage::Blob) }
441
- def last!; end
442
-
443
- sig { params(conditions: T.untyped).returns(T::Boolean) }
444
- def exists?(conditions = nil); end
445
-
446
- sig { params(args: T.untyped).returns(T::Boolean) }
447
- def any?(*args); end
448
-
449
- sig { params(args: T.untyped).returns(T::Boolean) }
450
- def many?(*args); end
451
-
452
- sig { params(args: T.untyped).returns(T::Boolean) }
453
- def none?(*args); end
454
-
455
- sig { params(args: T.untyped).returns(T::Boolean) }
456
- def one?(*args); end
457
-
458
- sig { params(args: T.untyped).returns(T::Boolean) }
459
- def empty?(*args); end
460
-
461
- sig { override.params(block: T.proc.params(e: ActiveStorage::Blob).void).returns(T::Array[ActiveStorage::Blob]) }
462
- def each(&block); end
463
-
464
- sig { params(level: T.nilable(Integer)).returns(T::Array[ActiveStorage::Blob]) }
465
- def flatten(level); end
466
-
467
- sig { returns(T::Array[ActiveStorage::Blob]) }
468
- def to_a; end
469
-
470
201
  sig do
471
- type_parameters(:U).params(
472
- blk: T.proc.params(arg0: Elem).returns(T.type_parameter(:U)),
473
- )
474
- .returns(T::Array[T.type_parameter(:U)])
202
+ params(
203
+ of: T.nilable(Integer),
204
+ start: T.nilable(Integer),
205
+ finish: T.nilable(Integer),
206
+ load: T.nilable(T::Boolean),
207
+ error_on_ignore: T.nilable(T::Boolean),
208
+ block: T.nilable(T.proc.params(e: ActiveStorage::Blob::ActiveRecord_Relation).void)
209
+ ).returns(ActiveRecord::Batches::BatchEnumerator)
475
210
  end
476
- def map(&blk); end
211
+ def in_batches(of: 1000, start: nil, finish: nil, load: false, error_on_ignore: nil, &block); end
477
212
  end
478
213
 
479
- class ActiveStorage::Blob::ActiveRecord_Associations_CollectionProxy < ActiveRecord::Associations::CollectionProxy
480
- include ActiveStorage::Blob::CustomFinderMethods
481
- include Enumerable
482
- extend T::Sig
483
- extend T::Generic
484
- Elem = type_member(fixed: ActiveStorage::Blob)
485
-
486
- sig { params(args: T.untyped).returns(ActiveStorage::Blob::ActiveRecord_AssociationRelation) }
487
- def unattached(*args); end
488
-
489
- sig { params(args: T.untyped).returns(ActiveStorage::Blob::ActiveRecord_AssociationRelation) }
490
- def with_attached_preview_image(*args); end
491
-
214
+ module ActiveStorage::Blob::QueryMethodsReturningAssociationRelation
492
215
  sig { returns(ActiveStorage::Blob::ActiveRecord_AssociationRelation) }
493
216
  def all; end
494
217
 
495
- sig { params(block: T.nilable(T.proc.void)).returns(ActiveStorage::Blob::ActiveRecord_AssociationRelation) }
218
+ sig { params(block: T.nilable(T.proc.void)).returns(ActiveStorage::Blob::ActiveRecord_Relation) }
496
219
  def unscoped(&block); end
497
220
 
498
221
  sig { params(args: T.untyped).returns(ActiveStorage::Blob::ActiveRecord_AssociationRelation) }
@@ -576,104 +299,15 @@ class ActiveStorage::Blob::ActiveRecord_Associations_CollectionProxy < ActiveRec
576
299
  sig { params(args: T.untyped, block: T.nilable(T.proc.void)).returns(ActiveStorage::Blob::ActiveRecord_AssociationRelation) }
577
300
  def extending(*args, &block); end
578
301
 
579
- sig { params(args: T.untyped).returns(ActiveStorage::Blob) }
580
- def find(*args); end
581
-
582
- sig { params(args: T.untyped).returns(T.nilable(ActiveStorage::Blob)) }
583
- def find_by(*args); end
584
-
585
- sig { params(args: T.untyped).returns(ActiveStorage::Blob) }
586
- def find_by!(*args); end
587
-
588
- sig { params(attributes: T.untyped, block: T.nilable(T.proc.params(object: ActiveStorage::Blob).void)).returns(ActiveStorage::Blob) }
589
- def find_or_initialize_by(attributes, &block); end
590
-
591
- sig { params(attributes: T.untyped, block: T.nilable(T.proc.params(object: ActiveStorage::Blob).void)).returns(ActiveStorage::Blob) }
592
- def find_or_create_by(attributes, &block); end
593
-
594
- sig { params(attributes: T.untyped, block: T.nilable(T.proc.params(object: ActiveStorage::Blob).void)).returns(ActiveStorage::Blob) }
595
- def find_or_create_by!(attributes, &block); end
596
-
597
- sig { returns(T.nilable(ActiveStorage::Blob)) }
598
- def first; end
599
-
600
- sig { returns(ActiveStorage::Blob) }
601
- def first!; end
602
-
603
- sig { returns(T.nilable(ActiveStorage::Blob)) }
604
- def second; end
605
-
606
- sig { returns(ActiveStorage::Blob) }
607
- def second!; end
608
-
609
- sig { returns(T.nilable(ActiveStorage::Blob)) }
610
- def third; end
611
-
612
- sig { returns(ActiveStorage::Blob) }
613
- def third!; end
614
-
615
- sig { returns(T.nilable(ActiveStorage::Blob)) }
616
- def third_to_last; end
617
-
618
- sig { returns(ActiveStorage::Blob) }
619
- def third_to_last!; end
620
-
621
- sig { returns(T.nilable(ActiveStorage::Blob)) }
622
- def second_to_last; end
623
-
624
- sig { returns(ActiveStorage::Blob) }
625
- def second_to_last!; end
626
-
627
- sig { returns(T.nilable(ActiveStorage::Blob)) }
628
- def last; end
629
-
630
- sig { returns(ActiveStorage::Blob) }
631
- def last!; end
632
-
633
- sig { params(conditions: T.untyped).returns(T::Boolean) }
634
- def exists?(conditions = nil); end
635
-
636
- sig { params(args: T.untyped).returns(T::Boolean) }
637
- def any?(*args); end
638
-
639
- sig { params(args: T.untyped).returns(T::Boolean) }
640
- def many?(*args); end
641
-
642
- sig { params(args: T.untyped).returns(T::Boolean) }
643
- def none?(*args); end
644
-
645
- sig { params(args: T.untyped).returns(T::Boolean) }
646
- def one?(*args); end
647
-
648
- sig { params(args: T.untyped).returns(T::Boolean) }
649
- def empty?(*args); end
650
-
651
- sig { override.params(block: T.proc.params(e: ActiveStorage::Blob).void).returns(T::Array[ActiveStorage::Blob]) }
652
- def each(&block); end
653
-
654
- sig { params(level: T.nilable(Integer)).returns(T::Array[ActiveStorage::Blob]) }
655
- def flatten(level); end
656
-
657
- sig { returns(T::Array[ActiveStorage::Blob]) }
658
- def to_a; end
659
-
660
302
  sig do
661
- type_parameters(:U).params(
662
- blk: T.proc.params(arg0: Elem).returns(T.type_parameter(:U)),
663
- )
664
- .returns(T::Array[T.type_parameter(:U)])
303
+ params(
304
+ of: T.nilable(Integer),
305
+ start: T.nilable(Integer),
306
+ finish: T.nilable(Integer),
307
+ load: T.nilable(T::Boolean),
308
+ error_on_ignore: T.nilable(T::Boolean),
309
+ block: T.nilable(T.proc.params(e: ActiveStorage::Blob::ActiveRecord_AssociationRelation).void)
310
+ ).returns(ActiveRecord::Batches::BatchEnumerator)
665
311
  end
666
- def map(&blk); end
667
-
668
- sig { params(records: T.any(ActiveStorage::Blob, T::Array[ActiveStorage::Blob])).returns(T.self_type) }
669
- def <<(*records); end
670
-
671
- sig { params(records: T.any(ActiveStorage::Blob, T::Array[ActiveStorage::Blob])).returns(T.self_type) }
672
- def append(*records); end
673
-
674
- sig { params(records: T.any(ActiveStorage::Blob, T::Array[ActiveStorage::Blob])).returns(T.self_type) }
675
- def push(*records); end
676
-
677
- sig { params(records: T.any(ActiveStorage::Blob, T::Array[ActiveStorage::Blob])).returns(T.self_type) }
678
- def concat(*records); end
312
+ def in_batches(of: 1000, start: nil, finish: nil, load: false, error_on_ignore: nil, &block); end
679
313
  end