ibm_db 3.0.4-x86-mingw32 → 5.0.4-x86-mingw32

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.
Files changed (593) hide show
  1. checksums.yaml +5 -5
  2. data/CHANGES +8 -1
  3. data/LICENSE +1 -1
  4. data/MANIFEST +14 -14
  5. data/ParameterizedQueries README +6 -6
  6. data/README +208 -225
  7. data/ext/Makefile +269 -0
  8. data/ext/Makefile.nt32 +181 -181
  9. data/ext/Makefile.nt32.191 +212 -212
  10. data/ext/extconf.rb +322 -291
  11. data/ext/gil_release_version +3 -0
  12. data/ext/ibm_db-i386-mingw32.def +2 -0
  13. data/ext/ibm_db.c +11879 -11884
  14. data/ext/ibm_db.o +0 -0
  15. data/ext/ibm_db.so +0 -0
  16. data/ext/mkmf.log +110 -0
  17. data/ext/ruby_ibm_db.h +241 -241
  18. data/ext/ruby_ibm_db_cli.c +866 -866
  19. data/ext/ruby_ibm_db_cli.h +500 -500
  20. data/ext/ruby_ibm_db_cli.o +0 -0
  21. data/ext/unicode_support_version +3 -0
  22. data/init.rb +41 -41
  23. data/lib/IBM_DB.rb +27 -27
  24. data/lib/active_record/connection_adapters/ibm_db_adapter.rb +3561 -3177
  25. data/lib/active_record/connection_adapters/ibmdb_adapter.rb +5 -2
  26. data/lib/active_record/vendor/db2-i5-zOS.yaml +328 -328
  27. data/lib/mswin32/ibm_db.rb +91 -123
  28. data/lib/mswin32/rb2x/i386/ibm_db.so +0 -0
  29. data/test/active_record/connection_adapters/fake_adapter.rb +49 -46
  30. data/test/assets/example.log +1 -1
  31. data/test/assets/test.txt +1 -1
  32. data/test/cases/adapter_test.rb +351 -261
  33. data/test/cases/adapters/mysql2/active_schema_test.rb +193 -0
  34. data/test/cases/adapters/mysql2/bind_parameter_test.rb +50 -0
  35. data/test/cases/adapters/mysql2/boolean_test.rb +100 -0
  36. data/test/cases/adapters/mysql2/case_sensitivity_test.rb +63 -0
  37. data/test/cases/adapters/mysql2/charset_collation_test.rb +54 -0
  38. data/test/cases/adapters/mysql2/connection_test.rb +210 -0
  39. data/test/cases/adapters/mysql2/datetime_precision_quoting_test.rb +45 -0
  40. data/test/cases/adapters/mysql2/enum_test.rb +26 -0
  41. data/test/cases/adapters/mysql2/explain_test.rb +21 -0
  42. data/test/cases/adapters/mysql2/json_test.rb +195 -0
  43. data/test/cases/adapters/mysql2/mysql2_adapter_test.rb +83 -0
  44. data/test/cases/adapters/mysql2/reserved_word_test.rb +152 -0
  45. data/test/cases/adapters/mysql2/schema_migrations_test.rb +59 -0
  46. data/test/cases/adapters/mysql2/schema_test.rb +126 -0
  47. data/test/cases/adapters/mysql2/sp_test.rb +36 -0
  48. data/test/cases/adapters/mysql2/sql_types_test.rb +14 -0
  49. data/test/cases/adapters/mysql2/table_options_test.rb +42 -0
  50. data/test/cases/adapters/mysql2/unsigned_type_test.rb +66 -0
  51. data/test/cases/adapters/postgresql/active_schema_test.rb +98 -0
  52. data/test/cases/adapters/postgresql/array_test.rb +339 -0
  53. data/test/cases/adapters/postgresql/bit_string_test.rb +82 -0
  54. data/test/cases/adapters/postgresql/bytea_test.rb +134 -0
  55. data/test/cases/adapters/postgresql/case_insensitive_test.rb +26 -0
  56. data/test/cases/adapters/postgresql/change_schema_test.rb +38 -0
  57. data/test/cases/adapters/postgresql/cidr_test.rb +25 -0
  58. data/test/cases/adapters/postgresql/citext_test.rb +78 -0
  59. data/test/cases/adapters/postgresql/collation_test.rb +53 -0
  60. data/test/cases/adapters/postgresql/composite_test.rb +132 -0
  61. data/test/cases/adapters/postgresql/connection_test.rb +257 -0
  62. data/test/cases/adapters/postgresql/datatype_test.rb +92 -0
  63. data/test/cases/adapters/postgresql/domain_test.rb +47 -0
  64. data/test/cases/adapters/postgresql/enum_test.rb +91 -0
  65. data/test/cases/adapters/postgresql/explain_test.rb +20 -0
  66. data/test/cases/adapters/postgresql/extension_migration_test.rb +63 -0
  67. data/test/cases/adapters/postgresql/full_text_test.rb +44 -0
  68. data/test/cases/adapters/postgresql/geometric_test.rb +378 -0
  69. data/test/cases/adapters/postgresql/hstore_test.rb +382 -0
  70. data/test/cases/adapters/postgresql/infinity_test.rb +69 -0
  71. data/test/cases/adapters/postgresql/integer_test.rb +25 -0
  72. data/test/cases/adapters/postgresql/json_test.rb +237 -0
  73. data/test/cases/adapters/postgresql/ltree_test.rb +53 -0
  74. data/test/cases/adapters/postgresql/money_test.rb +96 -0
  75. data/test/cases/adapters/postgresql/network_test.rb +94 -0
  76. data/test/cases/adapters/postgresql/numbers_test.rb +49 -0
  77. data/test/cases/adapters/postgresql/postgresql_adapter_test.rb +405 -0
  78. data/test/cases/adapters/postgresql/prepared_statements_test.rb +22 -0
  79. data/test/cases/adapters/postgresql/quoting_test.rb +44 -0
  80. data/test/cases/adapters/postgresql/range_test.rb +343 -0
  81. data/test/cases/adapters/postgresql/referential_integrity_test.rb +111 -0
  82. data/test/cases/adapters/postgresql/rename_table_test.rb +34 -0
  83. data/test/cases/adapters/postgresql/schema_authorization_test.rb +119 -0
  84. data/test/cases/adapters/postgresql/schema_test.rb +597 -0
  85. data/test/cases/adapters/postgresql/serial_test.rb +154 -0
  86. data/test/cases/adapters/postgresql/statement_pool_test.rb +41 -0
  87. data/test/cases/adapters/postgresql/timestamp_test.rb +90 -0
  88. data/test/cases/adapters/postgresql/type_lookup_test.rb +33 -0
  89. data/test/cases/adapters/postgresql/utils_test.rb +62 -0
  90. data/test/cases/adapters/postgresql/uuid_test.rb +294 -0
  91. data/test/cases/adapters/postgresql/xml_test.rb +54 -0
  92. data/test/cases/adapters/sqlite3/collation_test.rb +53 -0
  93. data/test/cases/adapters/sqlite3/copy_table_test.rb +98 -0
  94. data/test/cases/adapters/sqlite3/explain_test.rb +21 -0
  95. data/test/cases/adapters/sqlite3/quoting_test.rb +101 -0
  96. data/test/cases/adapters/sqlite3/sqlite3_adapter_test.rb +441 -0
  97. data/test/cases/adapters/sqlite3/sqlite3_create_folder_test.rb +24 -0
  98. data/test/cases/adapters/sqlite3/statement_pool_test.rb +20 -0
  99. data/test/cases/aggregations_test.rb +168 -158
  100. data/test/cases/ar_schema_test.rb +146 -161
  101. data/test/cases/associations/association_scope_test.rb +16 -21
  102. data/test/cases/associations/belongs_to_associations_test.rb +1141 -1029
  103. data/test/cases/associations/bidirectional_destroy_dependencies_test.rb +41 -0
  104. data/test/cases/associations/callbacks_test.rb +190 -192
  105. data/test/cases/associations/cascaded_eager_loading_test.rb +188 -188
  106. data/test/cases/associations/eager_load_includes_full_sti_class_test.rb +36 -36
  107. data/test/cases/associations/eager_load_nested_include_test.rb +126 -128
  108. data/test/cases/associations/eager_singularization_test.rb +148 -148
  109. data/test/cases/associations/eager_test.rb +1514 -1411
  110. data/test/cases/associations/extension_test.rb +87 -82
  111. data/test/cases/associations/has_and_belongs_to_many_associations_test.rb +1004 -932
  112. data/test/cases/associations/has_many_associations_test.rb +2501 -2162
  113. data/test/cases/associations/has_many_through_associations_test.rb +1271 -1204
  114. data/test/cases/associations/has_one_associations_test.rb +707 -610
  115. data/test/cases/associations/has_one_through_associations_test.rb +383 -380
  116. data/test/cases/associations/inner_join_association_test.rb +139 -139
  117. data/test/cases/associations/inverse_associations_test.rb +733 -693
  118. data/test/cases/associations/join_model_test.rb +777 -754
  119. data/test/cases/associations/left_outer_join_association_test.rb +88 -0
  120. data/test/cases/associations/nested_through_associations_test.rb +579 -579
  121. data/test/cases/associations/required_test.rb +102 -82
  122. data/test/cases/associations_test.rb +385 -380
  123. data/test/cases/attribute_decorators_test.rb +126 -125
  124. data/test/cases/attribute_methods/read_test.rb +60 -60
  125. data/test/cases/attribute_methods_test.rb +1009 -952
  126. data/test/cases/attribute_set_test.rb +270 -200
  127. data/test/cases/attribute_test.rb +246 -180
  128. data/test/cases/attributes_test.rb +253 -136
  129. data/test/cases/autosave_association_test.rb +1708 -1595
  130. data/test/cases/base_test.rb +1713 -1638
  131. data/test/cases/batches_test.rb +489 -212
  132. data/test/cases/binary_test.rb +44 -52
  133. data/test/cases/bind_parameter_test.rb +110 -100
  134. data/test/cases/cache_key_test.rb +26 -0
  135. data/test/cases/calculations_test.rb +798 -646
  136. data/test/cases/callbacks_test.rb +636 -543
  137. data/test/cases/clone_test.rb +40 -40
  138. data/test/cases/coders/json_test.rb +15 -0
  139. data/test/cases/coders/yaml_column_test.rb +63 -63
  140. data/test/cases/collection_cache_key_test.rb +115 -0
  141. data/test/cases/column_alias_test.rb +17 -17
  142. data/test/cases/column_definition_test.rb +92 -123
  143. data/test/cases/comment_test.rb +145 -0
  144. data/test/cases/connection_adapters/adapter_leasing_test.rb +56 -54
  145. data/test/cases/connection_adapters/connection_handler_test.rb +160 -53
  146. data/test/cases/connection_adapters/connection_specification_test.rb +12 -12
  147. data/test/cases/connection_adapters/merge_and_resolve_default_url_config_test.rb +255 -293
  148. data/test/cases/connection_adapters/mysql_type_lookup_test.rb +69 -65
  149. data/test/cases/connection_adapters/quoting_test.rb +13 -13
  150. data/test/cases/connection_adapters/schema_cache_test.rb +61 -56
  151. data/test/cases/connection_adapters/type_lookup_test.rb +118 -110
  152. data/test/cases/connection_management_test.rb +112 -122
  153. data/test/cases/connection_pool_test.rb +521 -346
  154. data/test/cases/connection_specification/resolver_test.rb +131 -116
  155. data/test/cases/core_test.rb +112 -112
  156. data/test/cases/counter_cache_test.rb +214 -209
  157. data/test/cases/custom_locking_test.rb +17 -17
  158. data/test/cases/database_statements_test.rb +34 -19
  159. data/test/cases/{invalid_date_test.rb → date_test.rb} +44 -32
  160. data/test/cases/date_time_precision_test.rb +107 -0
  161. data/test/cases/date_time_test.rb +61 -61
  162. data/test/cases/defaults_test.rb +219 -223
  163. data/test/cases/dirty_test.rb +763 -775
  164. data/test/cases/disconnected_test.rb +30 -28
  165. data/test/cases/dup_test.rb +157 -157
  166. data/test/cases/enum_test.rb +444 -290
  167. data/test/cases/errors_test.rb +16 -0
  168. data/test/cases/explain_subscriber_test.rb +64 -64
  169. data/test/cases/explain_test.rb +87 -76
  170. data/test/cases/finder_respond_to_test.rb +60 -60
  171. data/test/cases/finder_test.rb +1294 -1166
  172. data/test/cases/fixture_set/file_test.rb +156 -138
  173. data/test/cases/fixtures_test.rb +988 -897
  174. data/test/cases/forbidden_attributes_protection_test.rb +165 -99
  175. data/test/cases/habtm_destroy_order_test.rb +61 -61
  176. data/test/cases/helper.rb +204 -210
  177. data/test/cases/hot_compatibility_test.rb +142 -54
  178. data/test/cases/i18n_test.rb +45 -45
  179. data/test/cases/inheritance_test.rb +606 -375
  180. data/test/cases/integration_test.rb +155 -139
  181. data/test/cases/invalid_connection_test.rb +24 -22
  182. data/test/cases/invertible_migration_test.rb +387 -295
  183. data/test/cases/json_serialization_test.rb +311 -302
  184. data/test/cases/locking_test.rb +493 -477
  185. data/test/cases/log_subscriber_test.rb +225 -136
  186. data/test/cases/migration/change_schema_test.rb +458 -472
  187. data/test/cases/migration/change_table_test.rb +256 -224
  188. data/test/cases/migration/column_attributes_test.rb +176 -192
  189. data/test/cases/migration/column_positioning_test.rb +56 -56
  190. data/test/cases/migration/columns_test.rb +310 -304
  191. data/test/cases/migration/command_recorder_test.rb +350 -305
  192. data/test/cases/migration/compatibility_test.rb +118 -0
  193. data/test/cases/migration/create_join_table_test.rb +157 -148
  194. data/test/cases/migration/foreign_key_test.rb +362 -360
  195. data/test/cases/migration/helper.rb +39 -39
  196. data/test/cases/migration/index_test.rb +218 -216
  197. data/test/cases/migration/logger_test.rb +36 -36
  198. data/test/cases/migration/pending_migrations_test.rb +52 -53
  199. data/test/cases/migration/references_foreign_key_test.rb +221 -214
  200. data/test/cases/migration/references_index_test.rb +101 -101
  201. data/test/cases/migration/references_statements_test.rb +136 -116
  202. data/test/cases/migration/rename_table_test.rb +93 -93
  203. data/test/cases/migration_test.rb +1157 -959
  204. data/test/cases/migrator_test.rb +471 -388
  205. data/test/cases/mixin_test.rb +68 -70
  206. data/test/cases/modules_test.rb +172 -173
  207. data/test/cases/multiparameter_attributes_test.rb +372 -350
  208. data/test/cases/multiple_db_test.rb +122 -115
  209. data/test/cases/nested_attributes_test.rb +1098 -1057
  210. data/test/cases/nested_attributes_with_callbacks_test.rb +144 -144
  211. data/test/cases/persistence_test.rb +1001 -909
  212. data/test/cases/pooled_connections_test.rb +81 -81
  213. data/test/cases/primary_keys_test.rb +376 -237
  214. data/test/cases/query_cache_test.rb +446 -326
  215. data/test/cases/quoting_test.rb +202 -156
  216. data/test/cases/readonly_test.rb +119 -118
  217. data/test/cases/reaper_test.rb +85 -85
  218. data/test/cases/reflection_test.rb +509 -454
  219. data/test/cases/relation/delegation_test.rb +63 -68
  220. data/test/cases/relation/merging_test.rb +157 -161
  221. data/test/cases/relation/mutation_test.rb +183 -165
  222. data/test/cases/relation/or_test.rb +92 -0
  223. data/test/cases/relation/predicate_builder_test.rb +16 -14
  224. data/test/cases/relation/record_fetch_warning_test.rb +40 -0
  225. data/test/cases/relation/where_chain_test.rb +105 -181
  226. data/test/cases/relation/where_clause_test.rb +182 -0
  227. data/test/cases/relation/where_test.rb +322 -300
  228. data/test/cases/relation_test.rb +328 -297
  229. data/test/cases/relations_test.rb +2026 -1815
  230. data/test/cases/reload_models_test.rb +22 -22
  231. data/test/cases/result_test.rb +90 -80
  232. data/test/cases/sanitize_test.rb +176 -83
  233. data/test/cases/schema_dumper_test.rb +457 -463
  234. data/test/cases/schema_loading_test.rb +52 -0
  235. data/test/cases/scoping/default_scoping_test.rb +528 -454
  236. data/test/cases/scoping/named_scoping_test.rb +561 -524
  237. data/test/cases/scoping/relation_scoping_test.rb +400 -357
  238. data/test/cases/secure_token_test.rb +32 -0
  239. data/test/cases/serialization_test.rb +104 -104
  240. data/test/cases/serialized_attribute_test.rb +364 -277
  241. data/test/cases/statement_cache_test.rb +136 -98
  242. data/test/cases/store_test.rb +195 -194
  243. data/test/cases/suppressor_test.rb +63 -0
  244. data/test/cases/tasks/database_tasks_test.rb +462 -396
  245. data/test/cases/tasks/mysql_rake_test.rb +345 -311
  246. data/test/cases/tasks/postgresql_rake_test.rb +304 -245
  247. data/test/cases/tasks/sqlite_rake_test.rb +220 -193
  248. data/test/cases/test_case.rb +131 -123
  249. data/test/cases/test_fixtures_test.rb +36 -0
  250. data/test/cases/time_precision_test.rb +103 -0
  251. data/test/cases/timestamp_test.rb +501 -468
  252. data/test/cases/touch_later_test.rb +121 -0
  253. data/test/cases/transaction_callbacks_test.rb +518 -452
  254. data/test/cases/transaction_isolation_test.rb +106 -106
  255. data/test/cases/transactions_test.rb +835 -817
  256. data/test/cases/type/adapter_specific_registry_test.rb +133 -0
  257. data/test/cases/type/date_time_test.rb +14 -0
  258. data/test/cases/type/integer_test.rb +27 -121
  259. data/test/cases/type/string_test.rb +22 -36
  260. data/test/cases/type/type_map_test.rb +177 -177
  261. data/test/cases/type_test.rb +39 -0
  262. data/test/cases/types_test.rb +24 -141
  263. data/test/cases/unconnected_test.rb +33 -33
  264. data/test/cases/validations/absence_validation_test.rb +73 -0
  265. data/test/cases/validations/association_validation_test.rb +97 -86
  266. data/test/cases/validations/i18n_generate_message_validation_test.rb +84 -84
  267. data/test/cases/validations/i18n_validation_test.rb +86 -90
  268. data/test/cases/validations/length_validation_test.rb +79 -47
  269. data/test/cases/validations/presence_validation_test.rb +103 -68
  270. data/test/cases/validations/uniqueness_validation_test.rb +548 -434
  271. data/test/cases/validations_repair_helper.rb +19 -23
  272. data/test/cases/validations_test.rb +194 -165
  273. data/test/cases/view_test.rb +216 -113
  274. data/test/cases/yaml_serialization_test.rb +121 -86
  275. data/test/config.example.yml +97 -0
  276. data/test/config.rb +5 -5
  277. data/test/config.yml +154 -154
  278. data/test/connections/native_ibm_db/connection.rb +43 -43
  279. data/test/fixtures/accounts.yml +29 -29
  280. data/test/fixtures/admin/accounts.yml +2 -2
  281. data/test/fixtures/admin/randomly_named_a9.yml +7 -7
  282. data/test/fixtures/admin/randomly_named_b0.yml +7 -7
  283. data/test/fixtures/admin/users.yml +10 -10
  284. data/test/fixtures/author_addresses.yml +17 -17
  285. data/test/fixtures/author_favorites.yml +3 -3
  286. data/test/fixtures/authors.yml +23 -23
  287. data/test/fixtures/bad_posts.yml +9 -0
  288. data/test/fixtures/binaries.yml +133 -133
  289. data/test/fixtures/books.yml +31 -11
  290. data/test/fixtures/bulbs.yml +5 -5
  291. data/test/fixtures/cars.yml +9 -9
  292. data/test/fixtures/categories.yml +19 -19
  293. data/test/fixtures/categories/special_categories.yml +9 -9
  294. data/test/fixtures/categories/subsubdir/arbitrary_filename.yml +4 -4
  295. data/test/fixtures/categories_ordered.yml +7 -7
  296. data/test/fixtures/categories_posts.yml +31 -31
  297. data/test/fixtures/categorizations.yml +23 -23
  298. data/test/fixtures/clubs.yml +8 -8
  299. data/test/fixtures/collections.yml +3 -3
  300. data/test/fixtures/colleges.yml +3 -3
  301. data/test/fixtures/comments.yml +65 -65
  302. data/test/fixtures/companies.yml +67 -67
  303. data/test/fixtures/computers.yml +10 -10
  304. data/test/fixtures/content.yml +3 -0
  305. data/test/fixtures/content_positions.yml +3 -0
  306. data/test/fixtures/courses.yml +8 -8
  307. data/test/fixtures/customers.yml +25 -25
  308. data/test/fixtures/dashboards.yml +6 -6
  309. data/test/fixtures/dead_parrots.yml +5 -0
  310. data/test/fixtures/developers.yml +21 -21
  311. data/test/fixtures/developers_projects.yml +16 -16
  312. data/test/fixtures/dog_lovers.yml +7 -7
  313. data/test/fixtures/dogs.yml +4 -4
  314. data/test/fixtures/doubloons.yml +3 -3
  315. data/test/fixtures/edges.yml +5 -5
  316. data/test/fixtures/entrants.yml +14 -14
  317. data/test/fixtures/essays.yml +6 -6
  318. data/test/fixtures/faces.yml +11 -11
  319. data/test/fixtures/fk_test_has_fk.yml +3 -3
  320. data/test/fixtures/fk_test_has_pk.yml +1 -1
  321. data/test/fixtures/friendships.yml +4 -4
  322. data/test/fixtures/funny_jokes.yml +10 -10
  323. data/test/fixtures/interests.yml +33 -33
  324. data/test/fixtures/items.yml +3 -3
  325. data/test/fixtures/jobs.yml +7 -7
  326. data/test/fixtures/legacy_things.yml +3 -3
  327. data/test/fixtures/live_parrots.yml +4 -0
  328. data/test/fixtures/mateys.yml +4 -4
  329. data/test/fixtures/member_details.yml +8 -8
  330. data/test/fixtures/member_types.yml +6 -6
  331. data/test/fixtures/members.yml +11 -11
  332. data/test/fixtures/memberships.yml +34 -34
  333. data/test/fixtures/men.yml +5 -5
  334. data/test/fixtures/minimalistics.yml +2 -2
  335. data/test/fixtures/minivans.yml +5 -5
  336. data/test/fixtures/mixed_case_monkeys.yml +6 -6
  337. data/test/fixtures/mixins.yml +29 -29
  338. data/test/fixtures/movies.yml +7 -7
  339. data/test/fixtures/naked/yml/accounts.yml +1 -1
  340. data/test/fixtures/naked/yml/companies.yml +1 -1
  341. data/test/fixtures/naked/yml/courses.yml +1 -1
  342. data/test/fixtures/naked/yml/parrots.yml +2 -0
  343. data/test/fixtures/naked/yml/trees.yml +3 -0
  344. data/test/fixtures/nodes.yml +29 -0
  345. data/test/fixtures/organizations.yml +5 -5
  346. data/test/fixtures/other_comments.yml +6 -0
  347. data/test/fixtures/other_dogs.yml +2 -0
  348. data/test/fixtures/other_posts.yml +7 -0
  349. data/test/fixtures/other_topics.yml +42 -42
  350. data/test/fixtures/owners.yml +9 -9
  351. data/test/fixtures/parrots.yml +27 -27
  352. data/test/fixtures/parrots_pirates.yml +7 -7
  353. data/test/fixtures/people.yml +24 -24
  354. data/test/fixtures/peoples_treasures.yml +3 -3
  355. data/test/fixtures/pets.yml +19 -19
  356. data/test/fixtures/pirates.yml +12 -12
  357. data/test/fixtures/posts.yml +80 -80
  358. data/test/fixtures/price_estimates.yml +16 -7
  359. data/test/fixtures/products.yml +4 -4
  360. data/test/fixtures/projects.yml +7 -7
  361. data/test/fixtures/randomly_named_a9.yml +7 -7
  362. data/test/fixtures/ratings.yml +14 -14
  363. data/test/fixtures/readers.yml +11 -11
  364. data/test/fixtures/references.yml +17 -17
  365. data/test/fixtures/reserved_words/distinct.yml +5 -5
  366. data/test/fixtures/reserved_words/distinct_select.yml +11 -11
  367. data/test/fixtures/reserved_words/group.yml +14 -14
  368. data/test/fixtures/reserved_words/select.yml +8 -8
  369. data/test/fixtures/reserved_words/values.yml +7 -7
  370. data/test/fixtures/ships.yml +6 -6
  371. data/test/fixtures/speedometers.yml +8 -8
  372. data/test/fixtures/sponsors.yml +12 -12
  373. data/test/fixtures/string_key_objects.yml +7 -7
  374. data/test/fixtures/subscribers.yml +10 -10
  375. data/test/fixtures/subscriptions.yml +12 -12
  376. data/test/fixtures/taggings.yml +78 -78
  377. data/test/fixtures/tags.yml +11 -11
  378. data/test/fixtures/tasks.yml +7 -7
  379. data/test/fixtures/teapots.yml +3 -3
  380. data/test/fixtures/to_be_linked/accounts.yml +2 -2
  381. data/test/fixtures/to_be_linked/users.yml +10 -10
  382. data/test/fixtures/topics.yml +49 -49
  383. data/test/fixtures/toys.yml +14 -14
  384. data/test/fixtures/traffic_lights.yml +9 -9
  385. data/test/fixtures/treasures.yml +10 -10
  386. data/test/fixtures/trees.yml +3 -0
  387. data/test/fixtures/uuid_children.yml +3 -3
  388. data/test/fixtures/uuid_parents.yml +2 -2
  389. data/test/fixtures/variants.yml +4 -4
  390. data/test/fixtures/vegetables.yml +19 -19
  391. data/test/fixtures/vertices.yml +3 -3
  392. data/test/fixtures/warehouse_things.yml +2 -2
  393. data/test/fixtures/zines.yml +5 -5
  394. data/test/ibm_db_test.rb +24 -24
  395. data/test/migrations/10_urban/9_add_expressions.rb +11 -11
  396. data/test/migrations/decimal/1_give_me_big_numbers.rb +15 -15
  397. data/test/migrations/magic/1_currencies_have_symbols.rb +12 -12
  398. data/test/migrations/missing/1000_people_have_middle_names.rb +9 -9
  399. data/test/migrations/missing/1_people_have_last_names.rb +9 -9
  400. data/test/migrations/missing/3_we_need_reminders.rb +12 -12
  401. data/test/migrations/missing/4_innocent_jointable.rb +12 -12
  402. data/test/migrations/rename/1_we_need_things.rb +11 -11
  403. data/test/migrations/rename/2_rename_things.rb +9 -9
  404. data/test/migrations/to_copy/1_people_have_hobbies.rb +9 -9
  405. data/test/migrations/to_copy/2_people_have_descriptions.rb +9 -9
  406. data/test/migrations/to_copy2/1_create_articles.rb +7 -7
  407. data/test/migrations/to_copy2/2_create_comments.rb +7 -7
  408. data/test/migrations/to_copy_with_name_collision/1_people_have_hobbies.rb +9 -9
  409. data/test/migrations/to_copy_with_timestamps/20090101010101_people_have_hobbies.rb +9 -9
  410. data/test/migrations/to_copy_with_timestamps/20090101010202_people_have_descriptions.rb +9 -9
  411. data/test/migrations/to_copy_with_timestamps2/20090101010101_create_articles.rb +7 -7
  412. data/test/migrations/to_copy_with_timestamps2/20090101010202_create_comments.rb +7 -7
  413. data/test/migrations/valid/1_valid_people_have_last_names.rb +9 -9
  414. data/test/migrations/valid/2_we_need_reminders.rb +12 -12
  415. data/test/migrations/valid/3_innocent_jointable.rb +12 -12
  416. data/test/migrations/valid_with_subdirectories/1_valid_people_have_last_names.rb +9 -9
  417. data/test/migrations/valid_with_subdirectories/sub/2_we_need_reminders.rb +12 -12
  418. data/test/migrations/valid_with_subdirectories/sub1/3_innocent_jointable.rb +12 -12
  419. data/test/migrations/valid_with_timestamps/20100101010101_valid_with_timestamps_people_have_last_names.rb +9 -9
  420. data/test/migrations/valid_with_timestamps/20100201010101_valid_with_timestamps_we_need_reminders.rb +12 -12
  421. data/test/migrations/valid_with_timestamps/20100301010101_valid_with_timestamps_innocent_jointable.rb +12 -12
  422. data/test/migrations/version_check/20131219224947_migration_version_check.rb +8 -8
  423. data/test/models/admin.rb +4 -4
  424. data/test/models/admin/account.rb +2 -2
  425. data/test/models/admin/randomly_named_c1.rb +7 -3
  426. data/test/models/admin/user.rb +40 -40
  427. data/test/models/aircraft.rb +5 -4
  428. data/test/models/arunit2_model.rb +3 -3
  429. data/test/models/author.rb +209 -212
  430. data/test/models/auto_id.rb +4 -4
  431. data/test/models/autoloadable/extra_firm.rb +2 -2
  432. data/test/models/binary.rb +1 -1
  433. data/test/models/bird.rb +12 -12
  434. data/test/models/book.rb +23 -18
  435. data/test/models/boolean.rb +2 -2
  436. data/test/models/bulb.rb +52 -51
  437. data/test/models/cake_designer.rb +3 -3
  438. data/test/models/car.rb +29 -26
  439. data/test/models/carrier.rb +2 -2
  440. data/test/models/cat.rb +10 -0
  441. data/test/models/categorization.rb +19 -19
  442. data/test/models/category.rb +35 -35
  443. data/test/models/chef.rb +8 -3
  444. data/test/models/citation.rb +3 -3
  445. data/test/models/club.rb +25 -23
  446. data/test/models/college.rb +10 -10
  447. data/test/models/column.rb +3 -3
  448. data/test/models/column_name.rb +3 -3
  449. data/test/models/comment.rb +76 -64
  450. data/test/models/company.rb +230 -225
  451. data/test/models/company_in_module.rb +98 -98
  452. data/test/models/computer.rb +3 -3
  453. data/test/models/contact.rb +41 -41
  454. data/test/models/content.rb +40 -0
  455. data/test/models/contract.rb +20 -20
  456. data/test/models/country.rb +7 -7
  457. data/test/models/course.rb +6 -6
  458. data/test/models/customer.rb +83 -77
  459. data/test/models/customer_carrier.rb +14 -14
  460. data/test/models/dashboard.rb +3 -3
  461. data/test/models/default.rb +2 -2
  462. data/test/models/department.rb +4 -4
  463. data/test/models/developer.rb +274 -252
  464. data/test/models/dog.rb +5 -5
  465. data/test/models/dog_lover.rb +5 -5
  466. data/test/models/doubloon.rb +12 -12
  467. data/test/models/drink_designer.rb +3 -3
  468. data/test/models/edge.rb +5 -5
  469. data/test/models/electron.rb +5 -5
  470. data/test/models/engine.rb +4 -4
  471. data/test/models/entrant.rb +3 -3
  472. data/test/models/essay.rb +5 -5
  473. data/test/models/event.rb +2 -2
  474. data/test/models/eye.rb +37 -37
  475. data/test/models/face.rb +9 -9
  476. data/test/models/friendship.rb +6 -6
  477. data/test/models/guid.rb +1 -1
  478. data/test/models/guitar.rb +4 -0
  479. data/test/models/hotel.rb +11 -6
  480. data/test/models/image.rb +3 -3
  481. data/test/models/interest.rb +5 -5
  482. data/test/models/invoice.rb +4 -4
  483. data/test/models/item.rb +7 -7
  484. data/test/models/job.rb +7 -7
  485. data/test/models/joke.rb +7 -7
  486. data/test/models/keyboard.rb +3 -3
  487. data/test/models/legacy_thing.rb +3 -3
  488. data/test/models/lesson.rb +11 -11
  489. data/test/models/line_item.rb +3 -3
  490. data/test/models/liquid.rb +4 -4
  491. data/test/models/man.rb +11 -11
  492. data/test/models/matey.rb +4 -4
  493. data/test/models/member.rb +42 -41
  494. data/test/models/member_detail.rb +8 -7
  495. data/test/models/member_type.rb +3 -3
  496. data/test/models/membership.rb +35 -35
  497. data/test/models/mentor.rb +3 -0
  498. data/test/models/minimalistic.rb +2 -2
  499. data/test/models/minivan.rb +9 -9
  500. data/test/models/mixed_case_monkey.rb +3 -3
  501. data/test/models/mocktail_designer.rb +2 -0
  502. data/test/models/molecule.rb +6 -6
  503. data/test/models/movie.rb +5 -5
  504. data/test/models/node.rb +5 -0
  505. data/test/models/non_primary_key.rb +2 -0
  506. data/test/models/notification.rb +3 -0
  507. data/test/models/order.rb +4 -4
  508. data/test/models/organization.rb +14 -14
  509. data/test/models/other_dog.rb +5 -0
  510. data/test/models/owner.rb +37 -34
  511. data/test/models/parrot.rb +28 -29
  512. data/test/models/person.rb +142 -143
  513. data/test/models/personal_legacy_thing.rb +4 -4
  514. data/test/models/pet.rb +18 -15
  515. data/test/models/pet_treasure.rb +6 -0
  516. data/test/models/pirate.rb +92 -92
  517. data/test/models/possession.rb +3 -3
  518. data/test/models/post.rb +273 -264
  519. data/test/models/price_estimate.rb +4 -4
  520. data/test/models/professor.rb +5 -5
  521. data/test/models/project.rb +40 -29
  522. data/test/models/publisher.rb +2 -2
  523. data/test/models/publisher/article.rb +4 -4
  524. data/test/models/publisher/magazine.rb +3 -3
  525. data/test/models/randomly_named_c1.rb +3 -3
  526. data/test/models/rating.rb +4 -4
  527. data/test/models/reader.rb +23 -23
  528. data/test/models/recipe.rb +3 -0
  529. data/test/models/record.rb +2 -2
  530. data/test/models/reference.rb +22 -22
  531. data/test/models/reply.rb +61 -61
  532. data/test/models/ship.rb +39 -33
  533. data/test/models/ship_part.rb +7 -7
  534. data/test/models/shop.rb +17 -17
  535. data/test/models/shop_account.rb +6 -6
  536. data/test/models/speedometer.rb +6 -6
  537. data/test/models/sponsor.rb +7 -7
  538. data/test/models/string_key_object.rb +3 -3
  539. data/test/models/student.rb +4 -4
  540. data/test/models/subject.rb +16 -16
  541. data/test/models/subscriber.rb +8 -8
  542. data/test/models/subscription.rb +4 -4
  543. data/test/models/tag.rb +13 -7
  544. data/test/models/tagging.rb +13 -13
  545. data/test/models/task.rb +5 -5
  546. data/test/models/topic.rb +118 -124
  547. data/test/models/toy.rb +6 -6
  548. data/test/models/traffic_light.rb +4 -4
  549. data/test/models/treasure.rb +14 -14
  550. data/test/models/treaty.rb +7 -7
  551. data/test/models/tree.rb +3 -0
  552. data/test/models/tuning_peg.rb +4 -0
  553. data/test/models/tyre.rb +11 -11
  554. data/test/models/user.rb +14 -0
  555. data/test/models/uuid_child.rb +3 -3
  556. data/test/models/uuid_item.rb +6 -0
  557. data/test/models/uuid_parent.rb +3 -3
  558. data/test/models/vegetables.rb +24 -24
  559. data/test/models/vehicle.rb +6 -6
  560. data/test/models/vertex.rb +9 -9
  561. data/test/models/warehouse_thing.rb +5 -5
  562. data/test/models/wheel.rb +3 -3
  563. data/test/models/without_table.rb +3 -3
  564. data/test/models/zine.rb +3 -3
  565. data/test/schema/mysql2_specific_schema.rb +68 -58
  566. data/test/schema/oracle_specific_schema.rb +40 -43
  567. data/test/schema/postgresql_specific_schema.rb +114 -202
  568. data/test/schema/schema.rb +1057 -938
  569. data/test/schema/schema.rb.original +1057 -0
  570. data/test/schema/sqlite_specific_schema.rb +18 -22
  571. data/test/support/config.rb +43 -43
  572. data/test/support/connection.rb +23 -22
  573. data/test/support/connection_helper.rb +14 -14
  574. data/test/support/ddl_helper.rb +8 -8
  575. data/test/support/schema_dumping_helper.rb +20 -20
  576. data/test/support/yaml_compatibility_fixtures/rails_4_1.yml +22 -0
  577. data/test/support/yaml_compatibility_fixtures/rails_4_2_0.yml +182 -0
  578. metadata +146 -30
  579. data/lib/mswin32/rb19x/ibm_db.so +0 -0
  580. data/lib/mswin32/rb21x/i386/ibm_db.so +0 -0
  581. data/lib/mswin32/rb22x/i386/ibm_db.so +0 -0
  582. data/lib/mswin32/rb23x/i386/ibm_db.so +0 -0
  583. data/test/cases/associations/deprecated_counter_cache_on_has_many_through_test.rb +0 -26
  584. data/test/cases/attribute_methods/serialization_test.rb +0 -29
  585. data/test/cases/migration/change_schema_test - Copy.rb +0 -448
  586. data/test/cases/migration/foreign_key_test - Changed.rb +0 -325
  587. data/test/cases/migration/table_and_index_test.rb +0 -24
  588. data/test/cases/relation/where_test2.rb +0 -36
  589. data/test/cases/type/decimal_test.rb +0 -51
  590. data/test/cases/type/unsigned_integer_test.rb +0 -18
  591. data/test/cases/xml_serialization_test.rb +0 -457
  592. data/test/fixtures/naked/csv/accounts.csv +0 -1
  593. data/test/schema/mysql_specific_schema.rb +0 -70
@@ -1,4 +1,4 @@
1
- class PersonalLegacyThing < ActiveRecord::Base
2
- self.locking_column = :version
3
- belongs_to :person, :counter_cache => true
4
- end
1
+ class PersonalLegacyThing < ActiveRecord::Base
2
+ self.locking_column = :version
3
+ belongs_to :person, :counter_cache => true
4
+ end
@@ -1,15 +1,18 @@
1
- class Pet < ActiveRecord::Base
2
- attr_accessor :current_user
3
-
4
- self.primary_key = :pet_id
5
- belongs_to :owner, :touch => true
6
- has_many :toys
7
-
8
- class << self
9
- attr_accessor :after_destroy_output
10
- end
11
-
12
- after_destroy do |record|
13
- Pet.after_destroy_output = record.current_user
14
- end
15
- end
1
+ class Pet < ActiveRecord::Base
2
+ attr_accessor :current_user
3
+
4
+ self.primary_key = :pet_id
5
+ belongs_to :owner, :touch => true
6
+ has_many :toys
7
+ has_many :pet_treasures
8
+ has_many :treasures, through: :pet_treasures
9
+ has_many :persons, through: :treasures, source: :looter, source_type: 'Person'
10
+
11
+ class << self
12
+ attr_accessor :after_destroy_output
13
+ end
14
+
15
+ after_destroy do |record|
16
+ Pet.after_destroy_output = record.current_user
17
+ end
18
+ end
@@ -0,0 +1,6 @@
1
+ class PetTreasure < ActiveRecord::Base
2
+ self.table_name = "pets_treasures"
3
+
4
+ belongs_to :pet
5
+ belongs_to :treasure
6
+ end
@@ -1,92 +1,92 @@
1
- class Pirate < ActiveRecord::Base
2
- belongs_to :parrot, :validate => true
3
- belongs_to :non_validated_parrot, :class_name => 'Parrot'
4
- has_and_belongs_to_many :parrots, -> { order('parrots.id ASC') }, :validate => true
5
- has_and_belongs_to_many :non_validated_parrots, :class_name => 'Parrot'
6
- has_and_belongs_to_many :parrots_with_method_callbacks, :class_name => "Parrot",
7
- :before_add => :log_before_add,
8
- :after_add => :log_after_add,
9
- :before_remove => :log_before_remove,
10
- :after_remove => :log_after_remove
11
- has_and_belongs_to_many :parrots_with_proc_callbacks, :class_name => "Parrot",
12
- :before_add => proc {|p,pa| p.ship_log << "before_adding_proc_parrot_#{pa.id || '<new>'}"},
13
- :after_add => proc {|p,pa| p.ship_log << "after_adding_proc_parrot_#{pa.id || '<new>'}"},
14
- :before_remove => proc {|p,pa| p.ship_log << "before_removing_proc_parrot_#{pa.id}"},
15
- :after_remove => proc {|p,pa| p.ship_log << "after_removing_proc_parrot_#{pa.id}"}
16
- has_and_belongs_to_many :autosaved_parrots, class_name: "Parrot", autosave: true
17
-
18
- has_many :treasures, :as => :looter
19
- has_many :treasure_estimates, :through => :treasures, :source => :price_estimates
20
-
21
- has_one :ship
22
- has_one :update_only_ship, :class_name => 'Ship'
23
- has_one :non_validated_ship, :class_name => 'Ship'
24
- has_many :birds, -> { order('birds.id ASC') }
25
- has_many :birds_with_method_callbacks, :class_name => "Bird",
26
- :before_add => :log_before_add,
27
- :after_add => :log_after_add,
28
- :before_remove => :log_before_remove,
29
- :after_remove => :log_after_remove
30
- has_many :birds_with_proc_callbacks, :class_name => "Bird",
31
- :before_add => proc {|p,b| p.ship_log << "before_adding_proc_bird_#{b.id || '<new>'}"},
32
- :after_add => proc {|p,b| p.ship_log << "after_adding_proc_bird_#{b.id || '<new>'}"},
33
- :before_remove => proc {|p,b| p.ship_log << "before_removing_proc_bird_#{b.id}"},
34
- :after_remove => proc {|p,b| p.ship_log << "after_removing_proc_bird_#{b.id}"}
35
- has_many :birds_with_reject_all_blank, :class_name => "Bird"
36
-
37
- has_one :foo_bulb, -> { where :name => 'foo' }, :foreign_key => :car_id, :class_name => "Bulb"
38
-
39
- accepts_nested_attributes_for :parrots, :birds, :allow_destroy => true, :reject_if => proc { |attributes| attributes.empty? }
40
- accepts_nested_attributes_for :ship, :allow_destroy => true, :reject_if => proc { |attributes| attributes.empty? }
41
- accepts_nested_attributes_for :update_only_ship, :update_only => true
42
- accepts_nested_attributes_for :parrots_with_method_callbacks, :parrots_with_proc_callbacks,
43
- :birds_with_method_callbacks, :birds_with_proc_callbacks, :allow_destroy => true
44
- accepts_nested_attributes_for :birds_with_reject_all_blank, :reject_if => :all_blank
45
-
46
- validates_presence_of :catchphrase
47
-
48
- def ship_log
49
- @ship_log ||= []
50
- end
51
-
52
- def reject_empty_ships_on_create(attributes)
53
- attributes.delete('_reject_me_if_new').present? && !persisted?
54
- end
55
-
56
- attr_accessor :cancel_save_from_callback, :parrots_limit
57
- before_save :cancel_save_callback_method, :if => :cancel_save_from_callback
58
- def cancel_save_callback_method
59
- false
60
- end
61
-
62
- private
63
- def log_before_add(record)
64
- log(record, "before_adding_method")
65
- end
66
-
67
- def log_after_add(record)
68
- log(record, "after_adding_method")
69
- end
70
-
71
- def log_before_remove(record)
72
- log(record, "before_removing_method")
73
- end
74
-
75
- def log_after_remove(record)
76
- log(record, "after_removing_method")
77
- end
78
-
79
- def log(record, callback)
80
- ship_log << "#{callback}_#{record.class.name.downcase}_#{record.id || '<new>'}"
81
- end
82
- end
83
-
84
- class DestructivePirate < Pirate
85
- has_one :dependent_ship, :class_name => 'Ship', :foreign_key => :pirate_id, :dependent => :destroy
86
- end
87
-
88
- class FamousPirate < ActiveRecord::Base
89
- self.table_name = 'pirates'
90
- has_many :famous_ships
91
- validates_presence_of :catchphrase, on: :conference
92
- end
1
+ class Pirate < ActiveRecord::Base
2
+ belongs_to :parrot, :validate => true
3
+ belongs_to :non_validated_parrot, :class_name => 'Parrot'
4
+ has_and_belongs_to_many :parrots, -> { order('parrots.id ASC') }, :validate => true
5
+ has_and_belongs_to_many :non_validated_parrots, :class_name => 'Parrot'
6
+ has_and_belongs_to_many :parrots_with_method_callbacks, :class_name => "Parrot",
7
+ :before_add => :log_before_add,
8
+ :after_add => :log_after_add,
9
+ :before_remove => :log_before_remove,
10
+ :after_remove => :log_after_remove
11
+ has_and_belongs_to_many :parrots_with_proc_callbacks, :class_name => "Parrot",
12
+ :before_add => proc {|p,pa| p.ship_log << "before_adding_proc_parrot_#{pa.id || '<new>'}"},
13
+ :after_add => proc {|p,pa| p.ship_log << "after_adding_proc_parrot_#{pa.id || '<new>'}"},
14
+ :before_remove => proc {|p,pa| p.ship_log << "before_removing_proc_parrot_#{pa.id}"},
15
+ :after_remove => proc {|p,pa| p.ship_log << "after_removing_proc_parrot_#{pa.id}"}
16
+ has_and_belongs_to_many :autosaved_parrots, class_name: "Parrot", autosave: true
17
+
18
+ has_many :treasures, :as => :looter
19
+ has_many :treasure_estimates, :through => :treasures, :source => :price_estimates
20
+
21
+ has_one :ship
22
+ has_one :update_only_ship, :class_name => 'Ship'
23
+ has_one :non_validated_ship, :class_name => 'Ship'
24
+ has_many :birds, -> { order('birds.id ASC') }
25
+ has_many :birds_with_method_callbacks, :class_name => "Bird",
26
+ :before_add => :log_before_add,
27
+ :after_add => :log_after_add,
28
+ :before_remove => :log_before_remove,
29
+ :after_remove => :log_after_remove
30
+ has_many :birds_with_proc_callbacks, :class_name => "Bird",
31
+ :before_add => proc {|p,b| p.ship_log << "before_adding_proc_bird_#{b.id || '<new>'}"},
32
+ :after_add => proc {|p,b| p.ship_log << "after_adding_proc_bird_#{b.id || '<new>'}"},
33
+ :before_remove => proc {|p,b| p.ship_log << "before_removing_proc_bird_#{b.id}"},
34
+ :after_remove => proc {|p,b| p.ship_log << "after_removing_proc_bird_#{b.id}"}
35
+ has_many :birds_with_reject_all_blank, :class_name => "Bird"
36
+
37
+ has_one :foo_bulb, -> { where :name => 'foo' }, :foreign_key => :car_id, :class_name => "Bulb"
38
+
39
+ accepts_nested_attributes_for :parrots, :birds, :allow_destroy => true, :reject_if => proc(&:empty?)
40
+ accepts_nested_attributes_for :ship, :allow_destroy => true, :reject_if => proc(&:empty?)
41
+ accepts_nested_attributes_for :update_only_ship, :update_only => true
42
+ accepts_nested_attributes_for :parrots_with_method_callbacks, :parrots_with_proc_callbacks,
43
+ :birds_with_method_callbacks, :birds_with_proc_callbacks, :allow_destroy => true
44
+ accepts_nested_attributes_for :birds_with_reject_all_blank, :reject_if => :all_blank
45
+
46
+ validates_presence_of :catchphrase
47
+
48
+ def ship_log
49
+ @ship_log ||= []
50
+ end
51
+
52
+ def reject_empty_ships_on_create(attributes)
53
+ attributes.delete('_reject_me_if_new').present? && !persisted?
54
+ end
55
+
56
+ attr_accessor :cancel_save_from_callback, :parrots_limit
57
+ before_save :cancel_save_callback_method, :if => :cancel_save_from_callback
58
+ def cancel_save_callback_method
59
+ throw(:abort)
60
+ end
61
+
62
+ private
63
+ def log_before_add(record)
64
+ log(record, "before_adding_method")
65
+ end
66
+
67
+ def log_after_add(record)
68
+ log(record, "after_adding_method")
69
+ end
70
+
71
+ def log_before_remove(record)
72
+ log(record, "before_removing_method")
73
+ end
74
+
75
+ def log_after_remove(record)
76
+ log(record, "after_removing_method")
77
+ end
78
+
79
+ def log(record, callback)
80
+ ship_log << "#{callback}_#{record.class.name.downcase}_#{record.id || '<new>'}"
81
+ end
82
+ end
83
+
84
+ class DestructivePirate < Pirate
85
+ has_one :dependent_ship, :class_name => 'Ship', :foreign_key => :pirate_id, :dependent => :destroy
86
+ end
87
+
88
+ class FamousPirate < ActiveRecord::Base
89
+ self.table_name = 'pirates'
90
+ has_many :famous_ships
91
+ validates_presence_of :catchphrase, on: :conference
92
+ end
@@ -1,3 +1,3 @@
1
- class Possession < ActiveRecord::Base
2
- self.table_name = 'having'
3
- end
1
+ class Possession < ActiveRecord::Base
2
+ self.table_name = 'having'
3
+ end
@@ -1,264 +1,273 @@
1
- class Post < ActiveRecord::Base
2
- class CategoryPost < ActiveRecord::Base
3
- self.table_name = "categories_posts"
4
- belongs_to :category
5
- belongs_to :post
6
- end
7
-
8
- module NamedExtension
9
- def author
10
- 'lifo'
11
- end
12
- end
13
-
14
- module NamedExtension2
15
- def greeting
16
- "hello"
17
- end
18
- end
19
-
20
- scope :containing_the_letter_a, -> { where("body LIKE '%a%'") }
21
- scope :ranked_by_comments, -> { order("comments_count DESC") }
22
-
23
- scope :limit_by, lambda {|l| limit(l) }
24
-
25
- belongs_to :author
26
-
27
- belongs_to :author_with_posts, -> { includes(:posts) }, :class_name => "Author", :foreign_key => :author_id
28
- belongs_to :author_with_address, -> { includes(:author_address) }, :class_name => "Author", :foreign_key => :author_id
29
-
30
- def first_comment
31
- super.body
32
- end
33
- has_one :first_comment, -> { order('id ASC') }, :class_name => 'Comment'
34
- has_one :last_comment, -> { order('id desc') }, :class_name => 'Comment'
35
-
36
- scope :with_special_comments, -> { joins(:comments).where(:comments => {:type => 'SpecialComment'}) }
37
- scope :with_very_special_comments, -> { joins(:comments).where(:comments => {:type => 'VerySpecialComment'}) }
38
- scope :with_post, ->(post_id) { joins(:comments).where(:comments => { :post_id => post_id }) }
39
-
40
- scope :with_comments, -> { preload(:comments) }
41
- scope :with_tags, -> { preload(:taggings) }
42
-
43
- scope :tagged_with, ->(id) { joins(:taggings).where(taggings: { tag_id: id }) }
44
- scope :tagged_with_comment, ->(comment) { joins(:taggings).where(taggings: { comment: comment }) }
45
-
46
- has_many :comments do
47
- def find_most_recent
48
- order("id DESC").first
49
- end
50
-
51
- def newest
52
- created.last
53
- end
54
-
55
- def the_association
56
- proxy_association
57
- end
58
- end
59
-
60
- has_many :comments_with_extend, extend: NamedExtension, class_name: "Comment", foreign_key: "post_id" do
61
- def greeting
62
- "hello"
63
- end
64
- end
65
-
66
- has_many :comments_with_extend_2, extend: [NamedExtension, NamedExtension2], class_name: "Comment", foreign_key: "post_id"
67
-
68
- has_many :author_favorites, :through => :author
69
- has_many :author_categorizations, :through => :author, :source => :categorizations
70
- has_many :author_addresses, :through => :author
71
- has_many :author_address_extra_with_address,
72
- through: :author_with_address,
73
- source: :author_address_extra
74
-
75
- has_many :comments_with_interpolated_conditions,
76
- ->(p) { where "#{"#{p.aliased_table_name}." rescue ""}body = ?", 'Thank you for the welcome' },
77
- :class_name => 'Comment'
78
-
79
- has_one :very_special_comment
80
- has_one :very_special_comment_with_post, -> { includes(:post) }, :class_name => "VerySpecialComment"
81
- has_one :very_special_comment_with_post_with_joins, -> { joins(:post).order('posts.id') }, class_name: "VerySpecialComment"
82
- has_many :special_comments
83
- has_many :nonexistant_comments, -> { where 'comments.id < 0' }, :class_name => 'Comment'
84
-
85
- has_many :special_comments_ratings, :through => :special_comments, :source => :ratings
86
- has_many :special_comments_ratings_taggings, :through => :special_comments_ratings, :source => :taggings
87
-
88
- has_many :category_posts, :class_name => 'CategoryPost'
89
- has_many :scategories, through: :category_posts, source: :category
90
- has_and_belongs_to_many :categories
91
- has_and_belongs_to_many :special_categories, :join_table => "categories_posts", :association_foreign_key => 'category_id'
92
-
93
- has_many :taggings, :as => :taggable, :counter_cache => :tags_count
94
- has_many :tags, :through => :taggings do
95
- def add_joins_and_select
96
- select('tags.*, authors.id as author_id')
97
- .joins('left outer join posts on taggings.taggable_id = posts.id left outer join authors on posts.author_id = authors.id')
98
- .to_a
99
- end
100
- end
101
-
102
- has_many :taggings_with_delete_all, :class_name => 'Tagging', :as => :taggable, :dependent => :delete_all, counter_cache: :taggings_with_delete_all_count
103
- has_many :taggings_with_destroy, :class_name => 'Tagging', :as => :taggable, :dependent => :destroy, counter_cache: :taggings_with_destroy_count
104
-
105
- has_many :tags_with_destroy, :through => :taggings, :source => :tag, :dependent => :destroy, counter_cache: :tags_with_destroy_count
106
- has_many :tags_with_nullify, :through => :taggings, :source => :tag, :dependent => :nullify, counter_cache: :tags_with_nullify_count
107
-
108
- has_many :misc_tags, -> { where :tags => { :name => 'Misc' } }, :through => :taggings, :source => :tag
109
- has_many :funky_tags, :through => :taggings, :source => :tag
110
- has_many :super_tags, :through => :taggings
111
- has_many :tags_with_primary_key, :through => :taggings, :source => :tag_with_primary_key
112
- has_one :tagging, :as => :taggable
113
-
114
- has_many :first_taggings, -> { where :taggings => { :comment => 'first' } }, :as => :taggable, :class_name => 'Tagging'
115
- has_many :first_blue_tags, -> { where :tags => { :name => 'Blue' } }, :through => :first_taggings, :source => :tag
116
-
117
- has_many :first_blue_tags_2, -> { where :taggings => { :comment => 'first' } }, :through => :taggings, :source => :blue_tag
118
-
119
- has_many :invalid_taggings, -> { where 'taggings.id < 0' }, :as => :taggable, :class_name => "Tagging"
120
- has_many :invalid_tags, :through => :invalid_taggings, :source => :tag
121
-
122
- has_many :categorizations, :foreign_key => :category_id
123
- has_many :authors, :through => :categorizations
124
-
125
- has_many :categorizations_using_author_id, :primary_key => :author_id, :foreign_key => :post_id, :class_name => 'Categorization'
126
- has_many :authors_using_author_id, :through => :categorizations_using_author_id, :source => :author
127
-
128
- has_many :taggings_using_author_id, :primary_key => :author_id, :as => :taggable, :class_name => 'Tagging'
129
- has_many :tags_using_author_id, :through => :taggings_using_author_id, :source => :tag
130
-
131
- has_many :images, :as => :imageable, :foreign_key => :imageable_identifier, :foreign_type => :imageable_class
132
- has_one :main_image, :as => :imageable, :foreign_key => :imageable_identifier, :foreign_type => :imageable_class, :class_name => 'Image'
133
-
134
- has_many :standard_categorizations, :class_name => 'Categorization', :foreign_key => :post_id
135
- has_many :author_using_custom_pk, :through => :standard_categorizations
136
- has_many :authors_using_custom_pk, :through => :standard_categorizations
137
- has_many :named_categories, :through => :standard_categorizations
138
-
139
- has_many :readers
140
- has_many :secure_readers
141
- has_many :readers_with_person, -> { includes(:person) }, :class_name => "Reader"
142
- has_many :people, :through => :readers
143
- has_many :single_people, :through => :readers
144
- has_many :people_with_callbacks, :source=>:person, :through => :readers,
145
- :before_add => lambda {|owner, reader| log(:added, :before, reader.first_name) },
146
- :after_add => lambda {|owner, reader| log(:added, :after, reader.first_name) },
147
- :before_remove => lambda {|owner, reader| log(:removed, :before, reader.first_name) },
148
- :after_remove => lambda {|owner, reader| log(:removed, :after, reader.first_name) }
149
- has_many :skimmers, -> { where :skimmer => true }, :class_name => 'Reader'
150
- has_many :impatient_people, :through => :skimmers, :source => :person
151
-
152
- has_many :lazy_readers
153
- has_many :lazy_readers_skimmers_or_not, -> { where(skimmer: [ true, false ]) }, :class_name => 'LazyReader'
154
-
155
- has_many :lazy_people, :through => :lazy_readers, :source => :person
156
- has_many :lazy_readers_unscope_skimmers, -> { skimmers_or_not }, :class_name => 'LazyReader'
157
- has_many :lazy_people_unscope_skimmers, :through => :lazy_readers_unscope_skimmers, :source => :person
158
-
159
- def self.top(limit)
160
- ranked_by_comments.limit_by(limit)
161
- end
162
-
163
- def self.written_by(author)
164
- where(id: author.posts.pluck(:id))
165
- end
166
-
167
- def self.reset_log
168
- @log = []
169
- end
170
-
171
- def self.log(message=nil, side=nil, new_record=nil)
172
- return @log if message.nil?
173
- @log << [message, side, new_record]
174
- end
175
- end
176
-
177
- class SpecialPost < Post; end
178
-
179
- class StiPost < Post
180
- self.abstract_class = true
181
- has_one :special_comment, :class_name => "SpecialComment"
182
- end
183
-
184
- class SubStiPost < StiPost
185
- self.table_name = Post.table_name
186
- end
187
-
188
- class FirstPost < ActiveRecord::Base
189
- self.table_name = 'posts'
190
- default_scope { where(:id => 1) }
191
-
192
- has_many :comments, :foreign_key => :post_id
193
- has_one :comment, :foreign_key => :post_id
194
- end
195
-
196
- class PostWithDefaultInclude < ActiveRecord::Base
197
- self.table_name = 'posts'
198
- default_scope { includes(:comments) }
199
- has_many :comments, :foreign_key => :post_id
200
- end
201
-
202
- class PostWithSpecialCategorization < Post
203
- has_many :categorizations, :foreign_key => :post_id
204
- default_scope { where(:type => 'PostWithSpecialCategorization').joins(:categorizations).where(:categorizations => { :special => true }) }
205
- end
206
-
207
- class PostWithDefaultScope < ActiveRecord::Base
208
- self.table_name = 'posts'
209
- default_scope { order(:title) }
210
- end
211
-
212
- class PostWithPreloadDefaultScope < ActiveRecord::Base
213
- self.table_name = 'posts'
214
-
215
- has_many :readers, foreign_key: 'post_id'
216
-
217
- default_scope { preload(:readers) }
218
- end
219
-
220
- class PostWithIncludesDefaultScope < ActiveRecord::Base
221
- self.table_name = 'posts'
222
-
223
- has_many :readers, foreign_key: 'post_id'
224
-
225
- default_scope { includes(:readers) }
226
- end
227
-
228
- class SpecialPostWithDefaultScope < ActiveRecord::Base
229
- self.table_name = 'posts'
230
- default_scope { where(:id => [1, 5,6]) }
231
- end
232
-
233
- class PostThatLoadsCommentsInAnAfterSaveHook < ActiveRecord::Base
234
- self.table_name = 'posts'
235
- has_many :comments, class_name: "CommentThatAutomaticallyAltersPostBody", foreign_key: :post_id
236
-
237
- after_save do |post|
238
- post.comments.load
239
- end
240
- end
241
-
242
- class PostWithAfterCreateCallback < ActiveRecord::Base
243
- self.table_name = 'posts'
244
- has_many :comments, foreign_key: :post_id
245
-
246
- after_create do |post|
247
- update_attribute(:author_id, comments.first.id)
248
- end
249
- end
250
-
251
- class PostWithCommentWithDefaultScopeReferencesAssociation < ActiveRecord::Base
252
- self.table_name = 'posts'
253
- has_many :comment_with_default_scope_references_associations, foreign_key: :post_id
254
- has_one :first_comment, class_name: "CommentWithDefaultScopeReferencesAssociation", foreign_key: :post_id
255
- end
256
-
257
- class SerializedPost < ActiveRecord::Base
258
- serialize :title
259
- end
260
-
261
- class PostWithConflictingDefaultScope < Post
262
- default_scope ->{ where(author_id: 42) }
263
- belongs_to :post_with_conflicting_default_scope, foreign_key: :post_id
264
- end
1
+ class Post < ActiveRecord::Base
2
+ class CategoryPost < ActiveRecord::Base
3
+ self.table_name = "categories_posts"
4
+ belongs_to :category
5
+ belongs_to :post
6
+ end
7
+
8
+ module NamedExtension
9
+ def author
10
+ 'lifo'
11
+ end
12
+ end
13
+
14
+ module NamedExtension2
15
+ def greeting
16
+ "hullo"
17
+ end
18
+ end
19
+
20
+ scope :containing_the_letter_a, -> { where("body LIKE '%a%'") }
21
+ scope :titled_with_an_apostrophe, -> { where("title LIKE '%''%'") }
22
+ scope :ranked_by_comments, -> { order("comments_count DESC") }
23
+
24
+ scope :limit_by, lambda {|l| limit(l) }
25
+
26
+ belongs_to :author
27
+ belongs_to :readonly_author, -> { readonly }, class_name: "Author", foreign_key: :author_id
28
+
29
+ belongs_to :author_with_posts, -> { includes(:posts) }, :class_name => "Author", :foreign_key => :author_id
30
+ belongs_to :author_with_address, -> { includes(:author_address) }, :class_name => "Author", :foreign_key => :author_id
31
+
32
+ def first_comment
33
+ super.body
34
+ end
35
+ has_one :first_comment, -> { order('id ASC') }, :class_name => 'Comment'
36
+ has_one :last_comment, -> { order('id desc') }, :class_name => 'Comment'
37
+
38
+ scope :with_special_comments, -> { joins(:comments).where(:comments => {:type => 'SpecialComment'}) }
39
+ scope :with_very_special_comments, -> { joins(:comments).where(:comments => {:type => 'VerySpecialComment'}) }
40
+ scope :with_post, ->(post_id) { joins(:comments).where(:comments => { :post_id => post_id }) }
41
+
42
+ scope :with_comments, -> { preload(:comments) }
43
+ scope :with_tags, -> { preload(:taggings) }
44
+
45
+ scope :tagged_with, ->(id) { joins(:taggings).where(taggings: { tag_id: id }) }
46
+ scope :tagged_with_comment, ->(comment) { joins(:taggings).where(taggings: { comment: comment }) }
47
+
48
+ scope :typographically_interesting, -> { containing_the_letter_a.or(titled_with_an_apostrophe) }
49
+
50
+ has_many :comments do
51
+ def find_most_recent
52
+ order("id DESC").first
53
+ end
54
+
55
+ def newest
56
+ created.last
57
+ end
58
+
59
+ def the_association
60
+ proxy_association
61
+ end
62
+ end
63
+
64
+ has_many :comments_with_extend, extend: NamedExtension, class_name: "Comment", foreign_key: "post_id" do
65
+ def greeting
66
+ "hello"
67
+ end
68
+ end
69
+
70
+ has_many :comments_with_extend_2, extend: [NamedExtension, NamedExtension2], class_name: "Comment", foreign_key: "post_id"
71
+
72
+ has_many :author_favorites, :through => :author
73
+ has_many :author_categorizations, :through => :author, :source => :categorizations
74
+ has_many :author_addresses, :through => :author
75
+ has_many :author_address_extra_with_address,
76
+ through: :author_with_address,
77
+ source: :author_address_extra
78
+
79
+ has_one :very_special_comment
80
+ has_one :very_special_comment_with_post, -> { includes(:post) }, :class_name => "VerySpecialComment"
81
+ has_one :very_special_comment_with_post_with_joins, -> { joins(:post).order('posts.id') }, class_name: "VerySpecialComment"
82
+ has_many :special_comments
83
+ has_many :nonexistent_comments, -> { where 'comments.id < 0' }, :class_name => 'Comment'
84
+
85
+ has_many :special_comments_ratings, :through => :special_comments, :source => :ratings
86
+ has_many :special_comments_ratings_taggings, :through => :special_comments_ratings, :source => :taggings
87
+
88
+ has_many :category_posts, :class_name => 'CategoryPost'
89
+ has_many :scategories, through: :category_posts, source: :category
90
+ has_and_belongs_to_many :categories
91
+ has_and_belongs_to_many :special_categories, :join_table => "categories_posts", :association_foreign_key => 'category_id'
92
+
93
+ has_many :taggings, :as => :taggable, :counter_cache => :tags_count
94
+ has_many :tags, :through => :taggings do
95
+ def add_joins_and_select
96
+ select('tags.*, authors.id as author_id')
97
+ .joins('left outer join posts on taggings.taggable_id = posts.id left outer join authors on posts.author_id = authors.id')
98
+ .to_a
99
+ end
100
+ end
101
+
102
+ has_many :taggings_with_delete_all, :class_name => 'Tagging', :as => :taggable, :dependent => :delete_all, counter_cache: :taggings_with_delete_all_count
103
+ has_many :taggings_with_destroy, :class_name => 'Tagging', :as => :taggable, :dependent => :destroy, counter_cache: :taggings_with_destroy_count
104
+
105
+ has_many :tags_with_destroy, :through => :taggings, :source => :tag, :dependent => :destroy, counter_cache: :tags_with_destroy_count
106
+ has_many :tags_with_nullify, :through => :taggings, :source => :tag, :dependent => :nullify, counter_cache: :tags_with_nullify_count
107
+
108
+ has_many :misc_tags, -> { where :tags => { :name => 'Misc' } }, :through => :taggings, :source => :tag
109
+ has_many :funky_tags, :through => :taggings, :source => :tag
110
+ has_many :super_tags, :through => :taggings
111
+ has_many :tags_with_primary_key, :through => :taggings, :source => :tag_with_primary_key
112
+ has_one :tagging, :as => :taggable
113
+
114
+ has_many :first_taggings, -> { where :taggings => { :comment => 'first' } }, :as => :taggable, :class_name => 'Tagging'
115
+ has_many :first_blue_tags, -> { where :tags => { :name => 'Blue' } }, :through => :first_taggings, :source => :tag
116
+
117
+ has_many :first_blue_tags_2, -> { where :taggings => { :comment => 'first' } }, :through => :taggings, :source => :blue_tag
118
+
119
+ has_many :invalid_taggings, -> { where 'taggings.id < 0' }, :as => :taggable, :class_name => "Tagging"
120
+ has_many :invalid_tags, :through => :invalid_taggings, :source => :tag
121
+
122
+ has_many :categorizations, :foreign_key => :category_id
123
+ has_many :authors, :through => :categorizations
124
+
125
+ has_many :categorizations_using_author_id, :primary_key => :author_id, :foreign_key => :post_id, :class_name => 'Categorization'
126
+ has_many :authors_using_author_id, :through => :categorizations_using_author_id, :source => :author
127
+
128
+ has_many :taggings_using_author_id, :primary_key => :author_id, :as => :taggable, :class_name => 'Tagging'
129
+ has_many :tags_using_author_id, :through => :taggings_using_author_id, :source => :tag
130
+
131
+ has_many :images, :as => :imageable, :foreign_key => :imageable_identifier, :foreign_type => :imageable_class
132
+ has_one :main_image, :as => :imageable, :foreign_key => :imageable_identifier, :foreign_type => :imageable_class, :class_name => 'Image'
133
+
134
+ has_many :standard_categorizations, :class_name => 'Categorization', :foreign_key => :post_id
135
+ has_many :author_using_custom_pk, :through => :standard_categorizations
136
+ has_many :authors_using_custom_pk, :through => :standard_categorizations
137
+ has_many :named_categories, :through => :standard_categorizations
138
+
139
+ has_many :readers
140
+ has_many :secure_readers
141
+ has_many :readers_with_person, -> { includes(:person) }, :class_name => "Reader"
142
+ has_many :people, :through => :readers
143
+ has_many :single_people, :through => :readers
144
+ has_many :people_with_callbacks, :source=>:person, :through => :readers,
145
+ :before_add => lambda {|owner, reader| log(:added, :before, reader.first_name) },
146
+ :after_add => lambda {|owner, reader| log(:added, :after, reader.first_name) },
147
+ :before_remove => lambda {|owner, reader| log(:removed, :before, reader.first_name) },
148
+ :after_remove => lambda {|owner, reader| log(:removed, :after, reader.first_name) }
149
+ has_many :skimmers, -> { where :skimmer => true }, :class_name => 'Reader'
150
+ has_many :impatient_people, :through => :skimmers, :source => :person
151
+
152
+ has_many :lazy_readers
153
+ has_many :lazy_readers_skimmers_or_not, -> { where(skimmer: [ true, false ]) }, :class_name => 'LazyReader'
154
+
155
+ has_many :lazy_people, :through => :lazy_readers, :source => :person
156
+ has_many :lazy_readers_unscope_skimmers, -> { skimmers_or_not }, :class_name => 'LazyReader'
157
+ has_many :lazy_people_unscope_skimmers, :through => :lazy_readers_unscope_skimmers, :source => :person
158
+
159
+ def self.top(limit)
160
+ ranked_by_comments.limit_by(limit)
161
+ end
162
+
163
+ def self.written_by(author)
164
+ where(id: author.posts.pluck(:id))
165
+ end
166
+
167
+ def self.reset_log
168
+ @log = []
169
+ end
170
+
171
+ def self.log(message=nil, side=nil, new_record=nil)
172
+ return @log if message.nil?
173
+ @log << [message, side, new_record]
174
+ end
175
+ end
176
+
177
+ class SpecialPost < Post; end
178
+
179
+ class StiPost < Post
180
+ self.abstract_class = true
181
+ has_one :special_comment, :class_name => "SpecialComment"
182
+ end
183
+
184
+ class SubStiPost < StiPost
185
+ self.table_name = Post.table_name
186
+ end
187
+
188
+ class FirstPost < ActiveRecord::Base
189
+ self.inheritance_column = :disabled
190
+ self.table_name = 'posts'
191
+ default_scope { where(:id => 1) }
192
+
193
+ has_many :comments, :foreign_key => :post_id
194
+ has_one :comment, :foreign_key => :post_id
195
+ end
196
+
197
+ class PostWithDefaultInclude < ActiveRecord::Base
198
+ self.inheritance_column = :disabled
199
+ self.table_name = 'posts'
200
+ default_scope { includes(:comments) }
201
+ has_many :comments, :foreign_key => :post_id
202
+ end
203
+
204
+ class PostWithSpecialCategorization < Post
205
+ has_many :categorizations, :foreign_key => :post_id
206
+ default_scope { where(:type => 'PostWithSpecialCategorization').joins(:categorizations).where(:categorizations => { :special => true }) }
207
+ end
208
+
209
+ class PostWithDefaultScope < ActiveRecord::Base
210
+ self.inheritance_column = :disabled
211
+ self.table_name = 'posts'
212
+ default_scope { order(:title) }
213
+ end
214
+
215
+ class PostWithPreloadDefaultScope < ActiveRecord::Base
216
+ self.table_name = 'posts'
217
+
218
+ has_many :readers, foreign_key: 'post_id'
219
+
220
+ default_scope { preload(:readers) }
221
+ end
222
+
223
+ class PostWithIncludesDefaultScope < ActiveRecord::Base
224
+ self.table_name = 'posts'
225
+
226
+ has_many :readers, foreign_key: 'post_id'
227
+
228
+ default_scope { includes(:readers) }
229
+ end
230
+
231
+ class SpecialPostWithDefaultScope < ActiveRecord::Base
232
+ self.inheritance_column = :disabled
233
+ self.table_name = 'posts'
234
+ default_scope { where(:id => [1, 5,6]) }
235
+ end
236
+
237
+ class PostThatLoadsCommentsInAnAfterSaveHook < ActiveRecord::Base
238
+ self.inheritance_column = :disabled
239
+ self.table_name = 'posts'
240
+ has_many :comments, class_name: "CommentThatAutomaticallyAltersPostBody", foreign_key: :post_id
241
+
242
+ after_save do |post|
243
+ post.comments.load
244
+ end
245
+ end
246
+
247
+ class PostWithAfterCreateCallback < ActiveRecord::Base
248
+ self.inheritance_column = :disabled
249
+ self.table_name = 'posts'
250
+ has_many :comments, foreign_key: :post_id
251
+
252
+ after_create do |post|
253
+ update_attribute(:author_id, comments.first.id)
254
+ end
255
+ end
256
+
257
+ class PostWithCommentWithDefaultScopeReferencesAssociation < ActiveRecord::Base
258
+ self.inheritance_column = :disabled
259
+ self.table_name = 'posts'
260
+ has_many :comment_with_default_scope_references_associations, foreign_key: :post_id
261
+ has_one :first_comment, class_name: "CommentWithDefaultScopeReferencesAssociation", foreign_key: :post_id
262
+ end
263
+
264
+ class SerializedPost < ActiveRecord::Base
265
+ serialize :title
266
+ end
267
+
268
+ class ConditionalStiPost < Post
269
+ default_scope { where(title: 'Untitled') }
270
+ end
271
+
272
+ class SubConditionalStiPost < ConditionalStiPost
273
+ end