activerecord 2.0.5 → 2.1.0

Sign up to get free protection for your applications and to get access to all the features.

Potentially problematic release.


This version of activerecord might be problematic. Click here for more details.

Files changed (289) hide show
  1. data/CHANGELOG +168 -6
  2. data/README +27 -22
  3. data/RUNNING_UNIT_TESTS +7 -4
  4. data/Rakefile +22 -25
  5. data/lib/active_record.rb +8 -2
  6. data/lib/active_record/aggregations.rb +21 -12
  7. data/lib/active_record/association_preload.rb +277 -0
  8. data/lib/active_record/associations.rb +481 -295
  9. data/lib/active_record/associations/association_collection.rb +162 -37
  10. data/lib/active_record/associations/association_proxy.rb +71 -7
  11. data/lib/active_record/associations/belongs_to_association.rb +5 -3
  12. data/lib/active_record/associations/belongs_to_polymorphic_association.rb +5 -6
  13. data/lib/active_record/associations/has_and_belongs_to_many_association.rb +12 -64
  14. data/lib/active_record/associations/has_many_association.rb +8 -73
  15. data/lib/active_record/associations/has_many_through_association.rb +68 -117
  16. data/lib/active_record/associations/has_one_association.rb +7 -5
  17. data/lib/active_record/associations/has_one_through_association.rb +28 -0
  18. data/lib/active_record/attribute_methods.rb +69 -19
  19. data/lib/active_record/base.rb +496 -275
  20. data/lib/active_record/calculations.rb +28 -21
  21. data/lib/active_record/callbacks.rb +9 -38
  22. data/lib/active_record/connection_adapters/abstract/connection_specification.rb +3 -2
  23. data/lib/active_record/connection_adapters/abstract/database_statements.rb +2 -2
  24. data/lib/active_record/connection_adapters/abstract/query_cache.rb +6 -0
  25. data/lib/active_record/connection_adapters/abstract/schema_definitions.rb +232 -45
  26. data/lib/active_record/connection_adapters/abstract/schema_statements.rb +141 -27
  27. data/lib/active_record/connection_adapters/abstract_adapter.rb +9 -13
  28. data/lib/active_record/connection_adapters/mysql_adapter.rb +57 -24
  29. data/lib/active_record/connection_adapters/postgresql_adapter.rb +143 -42
  30. data/lib/active_record/connection_adapters/sqlite3_adapter.rb +1 -1
  31. data/lib/active_record/connection_adapters/sqlite_adapter.rb +18 -10
  32. data/lib/active_record/dirty.rb +158 -0
  33. data/lib/active_record/fixtures.rb +121 -156
  34. data/lib/active_record/locking/optimistic.rb +14 -11
  35. data/lib/active_record/locking/pessimistic.rb +2 -2
  36. data/lib/active_record/migration.rb +157 -77
  37. data/lib/active_record/named_scope.rb +163 -0
  38. data/lib/active_record/observer.rb +19 -5
  39. data/lib/active_record/reflection.rb +34 -14
  40. data/lib/active_record/schema.rb +7 -14
  41. data/lib/active_record/schema_dumper.rb +4 -4
  42. data/lib/active_record/serialization.rb +5 -5
  43. data/lib/active_record/serializers/json_serializer.rb +37 -28
  44. data/lib/active_record/serializers/xml_serializer.rb +52 -29
  45. data/lib/active_record/test_case.rb +36 -0
  46. data/lib/active_record/timestamp.rb +4 -4
  47. data/lib/active_record/transactions.rb +3 -3
  48. data/lib/active_record/validations.rb +182 -248
  49. data/lib/active_record/version.rb +2 -2
  50. data/test/{fixtures → assets}/example.log +0 -0
  51. data/test/{fixtures → assets}/flowers.jpg +0 -0
  52. data/test/cases/aaa_create_tables_test.rb +24 -0
  53. data/test/cases/active_schema_test_mysql.rb +95 -0
  54. data/test/cases/active_schema_test_postgresql.rb +24 -0
  55. data/test/{adapter_test.rb → cases/adapter_test.rb} +15 -14
  56. data/test/{adapter_test_sqlserver.rb → cases/adapter_test_sqlserver.rb} +95 -95
  57. data/test/{aggregations_test.rb → cases/aggregations_test.rb} +20 -20
  58. data/test/{ar_schema_test.rb → cases/ar_schema_test.rb} +6 -6
  59. data/test/cases/associations/belongs_to_associations_test.rb +412 -0
  60. data/test/{associations → cases/associations}/callbacks_test.rb +24 -10
  61. data/test/{associations → cases/associations}/cascaded_eager_loading_test.rb +18 -17
  62. data/test/cases/associations/eager_load_nested_include_test.rb +83 -0
  63. data/test/{associations → cases/associations}/eager_singularization_test.rb +5 -5
  64. data/test/{associations → cases/associations}/eager_test.rb +216 -51
  65. data/test/{associations → cases/associations}/extension_test.rb +8 -8
  66. data/test/cases/associations/has_and_belongs_to_many_associations_test.rb +684 -0
  67. data/test/cases/associations/has_many_associations_test.rb +932 -0
  68. data/test/cases/associations/has_many_through_associations_test.rb +190 -0
  69. data/test/cases/associations/has_one_associations_test.rb +323 -0
  70. data/test/cases/associations/has_one_through_associations_test.rb +74 -0
  71. data/test/{associations → cases/associations}/inner_join_association_test.rb +20 -20
  72. data/test/{associations → cases/associations}/join_model_test.rb +175 -35
  73. data/test/cases/associations_test.rb +262 -0
  74. data/test/{attribute_methods_test.rb → cases/attribute_methods_test.rb} +103 -11
  75. data/test/{base_test.rb → cases/base_test.rb} +338 -191
  76. data/test/{binary_test.rb → cases/binary_test.rb} +6 -4
  77. data/test/{calculations_test.rb → cases/calculations_test.rb} +35 -23
  78. data/test/{callbacks_test.rb → cases/callbacks_test.rb} +7 -7
  79. data/test/{class_inheritable_attributes_test.rb → cases/class_inheritable_attributes_test.rb} +3 -3
  80. data/test/{column_alias_test.rb → cases/column_alias_test.rb} +3 -3
  81. data/test/{connection_test_firebird.rb → cases/connection_test_firebird.rb} +2 -2
  82. data/test/{connection_test_mysql.rb → cases/connection_test_mysql.rb} +2 -2
  83. data/test/{copy_table_test_sqlite.rb → cases/copy_table_test_sqlite.rb} +13 -13
  84. data/test/{datatype_test_postgresql.rb → cases/datatype_test_postgresql.rb} +8 -8
  85. data/test/{date_time_test.rb → cases/date_time_test.rb} +5 -5
  86. data/test/{default_test_firebird.rb → cases/default_test_firebird.rb} +3 -3
  87. data/test/{defaults_test.rb → cases/defaults_test.rb} +8 -6
  88. data/test/{deprecated_finder_test.rb → cases/deprecated_finder_test.rb} +3 -3
  89. data/test/cases/dirty_test.rb +163 -0
  90. data/test/cases/finder_respond_to_test.rb +76 -0
  91. data/test/{finder_test.rb → cases/finder_test.rb} +266 -33
  92. data/test/{fixtures_test.rb → cases/fixtures_test.rb} +88 -72
  93. data/test/cases/helper.rb +47 -0
  94. data/test/{inheritance_test.rb → cases/inheritance_test.rb} +61 -17
  95. data/test/cases/invalid_date_test.rb +24 -0
  96. data/test/{json_serialization_test.rb → cases/json_serialization_test.rb} +36 -11
  97. data/test/{lifecycle_test.rb → cases/lifecycle_test.rb} +16 -13
  98. data/test/{locking_test.rb → cases/locking_test.rb} +17 -10
  99. data/test/{method_scoping_test.rb → cases/method_scoping_test.rb} +75 -39
  100. data/test/{migration_test.rb → cases/migration_test.rb} +420 -80
  101. data/test/{migration_test_firebird.rb → cases/migration_test_firebird.rb} +3 -3
  102. data/test/{mixin_test.rb → cases/mixin_test.rb} +7 -6
  103. data/test/{modules_test.rb → cases/modules_test.rb} +11 -6
  104. data/test/{multiple_db_test.rb → cases/multiple_db_test.rb} +5 -5
  105. data/test/cases/named_scope_test.rb +157 -0
  106. data/test/{pk_test.rb → cases/pk_test.rb} +10 -10
  107. data/test/{query_cache_test.rb → cases/query_cache_test.rb} +12 -10
  108. data/test/{readonly_test.rb → cases/readonly_test.rb} +11 -11
  109. data/test/{reflection_test.rb → cases/reflection_test.rb} +15 -14
  110. data/test/{reserved_word_test_mysql.rb → cases/reserved_word_test_mysql.rb} +4 -5
  111. data/test/{schema_authorization_test_postgresql.rb → cases/schema_authorization_test_postgresql.rb} +5 -5
  112. data/test/cases/schema_dumper_test.rb +138 -0
  113. data/test/cases/schema_test_postgresql.rb +102 -0
  114. data/test/{serialization_test.rb → cases/serialization_test.rb} +7 -7
  115. data/test/{synonym_test_oracle.rb → cases/synonym_test_oracle.rb} +5 -5
  116. data/test/{table_name_test_sqlserver.rb → cases/table_name_test_sqlserver.rb} +3 -3
  117. data/test/{threaded_connections_test.rb → cases/threaded_connections_test.rb} +7 -7
  118. data/test/{transactions_test.rb → cases/transactions_test.rb} +31 -5
  119. data/test/{unconnected_test.rb → cases/unconnected_test.rb} +2 -2
  120. data/test/{validations_test.rb → cases/validations_test.rb} +141 -39
  121. data/test/{xml_serialization_test.rb → cases/xml_serialization_test.rb} +12 -12
  122. data/test/config.rb +5 -0
  123. data/test/connections/native_db2/connection.rb +1 -1
  124. data/test/connections/native_firebird/connection.rb +1 -1
  125. data/test/connections/native_frontbase/connection.rb +1 -1
  126. data/test/connections/native_mysql/connection.rb +1 -1
  127. data/test/connections/native_openbase/connection.rb +1 -1
  128. data/test/connections/native_oracle/connection.rb +1 -1
  129. data/test/connections/native_postgresql/connection.rb +1 -3
  130. data/test/connections/native_sqlite/connection.rb +2 -2
  131. data/test/connections/native_sqlite3/connection.rb +2 -2
  132. data/test/connections/native_sqlite3/in_memory_connection.rb +3 -3
  133. data/test/connections/native_sybase/connection.rb +1 -1
  134. data/test/fixtures/author_addresses.yml +5 -0
  135. data/test/fixtures/authors.yml +2 -0
  136. data/test/fixtures/clubs.yml +6 -0
  137. data/test/fixtures/jobs.yml +7 -0
  138. data/test/fixtures/members.yml +4 -0
  139. data/test/fixtures/memberships.yml +20 -0
  140. data/test/fixtures/owners.yml +7 -0
  141. data/test/fixtures/people.yml +4 -1
  142. data/test/fixtures/pets.yml +14 -0
  143. data/test/fixtures/posts.yml +1 -0
  144. data/test/fixtures/price_estimates.yml +7 -0
  145. data/test/fixtures/readers.yml +5 -0
  146. data/test/fixtures/references.yml +17 -0
  147. data/test/fixtures/sponsors.yml +9 -0
  148. data/test/fixtures/subscribers.yml +7 -0
  149. data/test/fixtures/subscriptions.yml +12 -0
  150. data/test/fixtures/taggings.yml +4 -1
  151. data/test/fixtures/topics.yml +22 -2
  152. data/test/fixtures/warehouse-things.yml +3 -0
  153. data/test/{fixtures/migrations_with_decimal → migrations/decimal}/1_give_me_big_numbers.rb +0 -0
  154. data/test/{fixtures/migrations_with_duplicate → migrations/duplicate}/1_people_have_last_names.rb +1 -1
  155. data/test/{fixtures/migrations_with_duplicate → migrations/duplicate}/2_we_need_reminders.rb +1 -1
  156. data/test/{fixtures/migrations_with_duplicate → migrations/duplicate}/3_foo.rb +0 -0
  157. data/test/{fixtures/migrations → migrations/duplicate}/3_innocent_jointable.rb +0 -0
  158. data/test/migrations/duplicate_names/20080507052938_chunky.rb +7 -0
  159. data/test/migrations/duplicate_names/20080507053028_chunky.rb +7 -0
  160. data/test/{fixtures/migrations_with_duplicate → migrations/interleaved/pass_1}/3_innocent_jointable.rb +0 -0
  161. data/test/{fixtures/migrations → migrations/interleaved/pass_2}/1_people_have_last_names.rb +1 -1
  162. data/test/{fixtures/migrations_with_missing_versions/4_innocent_jointable.rb → migrations/interleaved/pass_2/3_innocent_jointable.rb} +0 -0
  163. data/test/{fixtures/migrations_with_missing_versions → migrations/interleaved/pass_3}/1_people_have_last_names.rb +1 -1
  164. data/test/migrations/interleaved/pass_3/2_i_raise_on_down.rb +8 -0
  165. data/test/migrations/interleaved/pass_3/3_innocent_jointable.rb +12 -0
  166. data/test/{fixtures/migrations_with_missing_versions → migrations/missing}/1000_people_have_middle_names.rb +1 -1
  167. data/test/migrations/missing/1_people_have_last_names.rb +9 -0
  168. data/test/{fixtures/migrations_with_missing_versions → migrations/missing}/3_we_need_reminders.rb +1 -1
  169. data/test/migrations/missing/4_innocent_jointable.rb +12 -0
  170. data/test/migrations/valid/1_people_have_last_names.rb +9 -0
  171. data/test/{fixtures/migrations → migrations/valid}/2_we_need_reminders.rb +1 -1
  172. data/test/migrations/valid/3_innocent_jointable.rb +12 -0
  173. data/test/{fixtures → models}/author.rb +28 -4
  174. data/test/{fixtures → models}/auto_id.rb +0 -0
  175. data/test/{fixtures → models}/binary.rb +0 -0
  176. data/test/{fixtures → models}/book.rb +0 -0
  177. data/test/{fixtures → models}/categorization.rb +0 -0
  178. data/test/{fixtures → models}/category.rb +8 -5
  179. data/test/{fixtures → models}/citation.rb +0 -0
  180. data/test/models/club.rb +7 -0
  181. data/test/{fixtures → models}/column_name.rb +0 -0
  182. data/test/{fixtures → models}/comment.rb +5 -3
  183. data/test/{fixtures → models}/company.rb +15 -6
  184. data/test/{fixtures → models}/company_in_module.rb +5 -3
  185. data/test/{fixtures → models}/computer.rb +0 -1
  186. data/test/{fixtures → models}/contact.rb +1 -1
  187. data/test/{fixtures → models}/course.rb +0 -0
  188. data/test/{fixtures → models}/customer.rb +8 -8
  189. data/test/{fixtures → models}/default.rb +0 -0
  190. data/test/{fixtures → models}/developer.rb +14 -10
  191. data/test/{fixtures → models}/edge.rb +0 -0
  192. data/test/{fixtures → models}/entrant.rb +0 -0
  193. data/test/models/guid.rb +2 -0
  194. data/test/{fixtures → models}/item.rb +0 -0
  195. data/test/models/job.rb +5 -0
  196. data/test/{fixtures → models}/joke.rb +0 -0
  197. data/test/{fixtures → models}/keyboard.rb +0 -0
  198. data/test/{fixtures → models}/legacy_thing.rb +0 -0
  199. data/test/{fixtures → models}/matey.rb +0 -0
  200. data/test/models/member.rb +9 -0
  201. data/test/models/membership.rb +9 -0
  202. data/test/{fixtures → models}/minimalistic.rb +0 -0
  203. data/test/{fixtures → models}/mixed_case_monkey.rb +0 -0
  204. data/test/{fixtures → models}/movie.rb +0 -0
  205. data/test/{fixtures → models}/order.rb +2 -2
  206. data/test/models/owner.rb +4 -0
  207. data/test/{fixtures → models}/parrot.rb +0 -0
  208. data/test/models/person.rb +10 -0
  209. data/test/models/pet.rb +4 -0
  210. data/test/models/pirate.rb +9 -0
  211. data/test/{fixtures → models}/post.rb +23 -2
  212. data/test/models/price_estimate.rb +3 -0
  213. data/test/{fixtures → models}/project.rb +1 -0
  214. data/test/{fixtures → models}/reader.rb +0 -0
  215. data/test/models/reference.rb +4 -0
  216. data/test/{fixtures → models}/reply.rb +7 -5
  217. data/test/{fixtures → models}/ship.rb +0 -0
  218. data/test/models/sponsor.rb +4 -0
  219. data/test/{fixtures → models}/subject.rb +0 -0
  220. data/test/{fixtures → models}/subscriber.rb +2 -0
  221. data/test/models/subscription.rb +4 -0
  222. data/test/{fixtures → models}/tag.rb +0 -0
  223. data/test/{fixtures → models}/tagging.rb +0 -0
  224. data/test/{fixtures → models}/task.rb +0 -0
  225. data/test/{fixtures → models}/topic.rb +32 -4
  226. data/test/{fixtures → models}/treasure.rb +2 -0
  227. data/test/{fixtures → models}/vertex.rb +0 -0
  228. data/test/models/warehouse_thing.rb +5 -0
  229. data/test/schema/mysql_specific_schema.rb +12 -0
  230. data/test/schema/postgresql_specific_schema.rb +103 -0
  231. data/test/schema/schema.rb +421 -0
  232. data/test/schema/schema2.rb +6 -0
  233. data/test/schema/sqlite_specific_schema.rb +25 -0
  234. data/test/schema/sqlserver_specific_schema.rb +5 -0
  235. metadata +192 -176
  236. data/test/aaa_create_tables_test.rb +0 -72
  237. data/test/abstract_unit.rb +0 -84
  238. data/test/active_schema_test_mysql.rb +0 -46
  239. data/test/all.sh +0 -8
  240. data/test/association_inheritance_reload.rb +0 -14
  241. data/test/associations_test.rb +0 -2177
  242. data/test/fixtures/bad_fixtures/attr_with_numeric_first_char +0 -1
  243. data/test/fixtures/bad_fixtures/attr_with_spaces +0 -1
  244. data/test/fixtures/bad_fixtures/blank_line +0 -3
  245. data/test/fixtures/bad_fixtures/duplicate_attributes +0 -3
  246. data/test/fixtures/bad_fixtures/missing_value +0 -1
  247. data/test/fixtures/db_definitions/db2.drop.sql +0 -33
  248. data/test/fixtures/db_definitions/db2.sql +0 -235
  249. data/test/fixtures/db_definitions/db22.drop.sql +0 -2
  250. data/test/fixtures/db_definitions/db22.sql +0 -5
  251. data/test/fixtures/db_definitions/firebird.drop.sql +0 -65
  252. data/test/fixtures/db_definitions/firebird.sql +0 -310
  253. data/test/fixtures/db_definitions/firebird2.drop.sql +0 -2
  254. data/test/fixtures/db_definitions/firebird2.sql +0 -6
  255. data/test/fixtures/db_definitions/frontbase.drop.sql +0 -33
  256. data/test/fixtures/db_definitions/frontbase.sql +0 -273
  257. data/test/fixtures/db_definitions/frontbase2.drop.sql +0 -1
  258. data/test/fixtures/db_definitions/frontbase2.sql +0 -4
  259. data/test/fixtures/db_definitions/openbase.drop.sql +0 -2
  260. data/test/fixtures/db_definitions/openbase.sql +0 -318
  261. data/test/fixtures/db_definitions/openbase2.drop.sql +0 -2
  262. data/test/fixtures/db_definitions/openbase2.sql +0 -7
  263. data/test/fixtures/db_definitions/oracle.drop.sql +0 -67
  264. data/test/fixtures/db_definitions/oracle.sql +0 -330
  265. data/test/fixtures/db_definitions/oracle2.drop.sql +0 -2
  266. data/test/fixtures/db_definitions/oracle2.sql +0 -6
  267. data/test/fixtures/db_definitions/postgresql.drop.sql +0 -44
  268. data/test/fixtures/db_definitions/postgresql.sql +0 -292
  269. data/test/fixtures/db_definitions/postgresql2.drop.sql +0 -2
  270. data/test/fixtures/db_definitions/postgresql2.sql +0 -4
  271. data/test/fixtures/db_definitions/schema.rb +0 -354
  272. data/test/fixtures/db_definitions/schema2.rb +0 -11
  273. data/test/fixtures/db_definitions/sqlite.drop.sql +0 -33
  274. data/test/fixtures/db_definitions/sqlite.sql +0 -219
  275. data/test/fixtures/db_definitions/sqlite2.drop.sql +0 -2
  276. data/test/fixtures/db_definitions/sqlite2.sql +0 -5
  277. data/test/fixtures/db_definitions/sybase.drop.sql +0 -35
  278. data/test/fixtures/db_definitions/sybase.sql +0 -222
  279. data/test/fixtures/db_definitions/sybase2.drop.sql +0 -4
  280. data/test/fixtures/db_definitions/sybase2.sql +0 -5
  281. data/test/fixtures/developers_projects/david_action_controller +0 -3
  282. data/test/fixtures/developers_projects/david_active_record +0 -3
  283. data/test/fixtures/developers_projects/jamis_active_record +0 -2
  284. data/test/fixtures/person.rb +0 -4
  285. data/test/fixtures/pirate.rb +0 -5
  286. data/test/fixtures/subscribers/first +0 -2
  287. data/test/fixtures/subscribers/second +0 -2
  288. data/test/schema_dumper_test.rb +0 -131
  289. data/test/schema_test_postgresql.rb +0 -64
@@ -1,12 +1,12 @@
1
1
  print "Using native SQLite3\n"
2
- require_dependency 'fixtures/course'
2
+ require_dependency 'models/course'
3
3
  require 'logger'
4
4
  ActiveRecord::Base.logger = Logger.new("debug.log")
5
5
 
6
6
  class SqliteError < StandardError
7
7
  end
8
8
 
9
- BASE_DIR = File.expand_path(File.dirname(__FILE__) + '/../../fixtures')
9
+ BASE_DIR = FIXTURES_ROOT
10
10
  sqlite_test_db = "#{BASE_DIR}/fixture_database.sqlite3"
11
11
  sqlite_test_db2 = "#{BASE_DIR}/fixture_database_2.sqlite3"
12
12
 
@@ -1,5 +1,5 @@
1
1
  print "Using native SQLite3\n"
2
- require_dependency 'fixtures/course'
2
+ require_dependency 'models/course'
3
3
  require 'logger'
4
4
  ActiveRecord::Base.logger = Logger.new("debug.log")
5
5
 
@@ -8,11 +8,11 @@ end
8
8
 
9
9
  def make_connection(clazz, db_definitions_file)
10
10
  clazz.establish_connection(:adapter => 'sqlite3', :database => ':memory:')
11
- File.read("#{File.dirname(__FILE__)}/../../fixtures/db_definitions/#{db_definitions_file}").split(';').each do |command|
11
+ File.read(SCHEMA_ROOT + "/#{db_definitions_file}").split(';').each do |command|
12
12
  clazz.connection.execute(command) unless command.strip.empty?
13
13
  end
14
14
  end
15
15
 
16
16
  make_connection(ActiveRecord::Base, 'sqlite.sql')
17
17
  make_connection(Course, 'sqlite2.sql')
18
- load("#{File.dirname(__FILE__)}/../../fixtures/db_definitions/schema.rb")
18
+ load(SCHEMA_ROOT + "/schema.rb")
@@ -1,5 +1,5 @@
1
1
  print "Using native Sybase Open Client\n"
2
- require_dependency 'fixtures/course'
2
+ require_dependency 'models/course'
3
3
  require 'logger'
4
4
 
5
5
  ActiveRecord::Base.logger = Logger.new("debug.log")
@@ -0,0 +1,5 @@
1
+ david_address:
2
+ id: 1
3
+
4
+ david_address_extra:
5
+ id: 2
@@ -1,6 +1,8 @@
1
1
  david:
2
2
  id: 1
3
3
  name: David
4
+ author_address_id: 1
5
+ author_address_extra_id: 2
4
6
 
5
7
  mary:
6
8
  id: 2
@@ -0,0 +1,6 @@
1
+ boring_club:
2
+ name: Banana appreciation society
3
+ moustache_club:
4
+ name: Moustache and Eyebrow Fancier Club
5
+ crazy_club:
6
+ name: Skull and bones
@@ -0,0 +1,7 @@
1
+ unicyclist:
2
+ id: 1
3
+ ideal_reference_id: 2
4
+ clown:
5
+ id: 2
6
+ magician:
7
+ id: 3
@@ -0,0 +1,4 @@
1
+ groucho:
2
+ name: Groucho Marx
3
+ some_other_guy:
4
+ name: Englebert Humperdink
@@ -0,0 +1,20 @@
1
+ membership_of_boring_club:
2
+ joined_on: <%= 3.weeks.ago.to_s(:db) %>
3
+ club: boring_club
4
+ member: groucho
5
+ favourite: false
6
+ type: CurrentMembership
7
+
8
+ membership_of_favourite_club:
9
+ joined_on: <%= 3.weeks.ago.to_s(:db) %>
10
+ club: moustache_club
11
+ member: groucho
12
+ favourite: true
13
+ type: Membership
14
+
15
+ other_guys_membership:
16
+ joined_on: <%= 4.weeks.ago.to_s(:db) %>
17
+ club: boring_club
18
+ member: some_other_guy
19
+ favourite: false
20
+ type: CurrentMembership
@@ -0,0 +1,7 @@
1
+ blackbeard:
2
+ owner_id: 1
3
+ name: blackbeard
4
+
5
+ ashley:
6
+ owner_id: 2
7
+ name: ashley
@@ -1,3 +1,6 @@
1
1
  michael:
2
2
  id: 1
3
- first_name: Michael
3
+ first_name: Michael
4
+ david:
5
+ id: 2
6
+ first_name: David
@@ -0,0 +1,14 @@
1
+ parrot:
2
+ pet_id: 1
3
+ name: parrot
4
+ owner_id: 1
5
+
6
+ chew:
7
+ pet_id: 2
8
+ name: chew
9
+ owner_id: 2
10
+
11
+ mochi:
12
+ pet_id: 3
13
+ name: mochi
14
+ owner_id: 2
@@ -3,6 +3,7 @@ welcome:
3
3
  author_id: 1
4
4
  title: Welcome to the weblog
5
5
  body: Such a lovely day
6
+ comments_count: 2
6
7
  type: Post
7
8
 
8
9
  thinking:
@@ -0,0 +1,7 @@
1
+ saphire_1:
2
+ price: 10
3
+ estimate_of: sapphire (Treasure)
4
+
5
+ sapphire_2:
6
+ price: 20
7
+ estimate_of: sapphire (Treasure)
@@ -2,3 +2,8 @@ michael_welcome:
2
2
  id: 1
3
3
  post_id: 1
4
4
  person_id: 1
5
+
6
+ michael_authorless:
7
+ id: 2
8
+ post_id: 3
9
+ person_id: 1
@@ -0,0 +1,17 @@
1
+ michael_magician:
2
+ id: 1
3
+ person_id: 1
4
+ job_id: 3
5
+ favourite: false
6
+
7
+ michael_unicyclist:
8
+ id: 2
9
+ person_id: 1
10
+ job_id: 1
11
+ favourite: true
12
+
13
+ david_unicyclist:
14
+ id: 3
15
+ person_id: 2
16
+ job_id: 1
17
+ favourite: false
@@ -0,0 +1,9 @@
1
+ moustache_club_sponsor_for_groucho:
2
+ sponsor_club: moustache_club
3
+ sponsorable: groucho (Member)
4
+ boring_club_sponsor_for_groucho:
5
+ sponsor_club: boring_club
6
+ sponsorable: some_other_guy (Member)
7
+ crazy_club_sponsor_for_groucho:
8
+ sponsor_club: crazy_club
9
+ sponsorable: some_other_guy (Member)
@@ -0,0 +1,7 @@
1
+ first:
2
+ nick: alterself
3
+ name: Luke Holden
4
+
5
+ second:
6
+ nick: webster132
7
+ name: David Heinemeier Hansson
@@ -0,0 +1,12 @@
1
+ webster_awdr:
2
+ id: 1
3
+ subscriber_id: webster132
4
+ book_id: 1
5
+ webster_rfr:
6
+ id: 2
7
+ subscriber_id: webster132
8
+ book_id: 2
9
+ alterself_awdr:
10
+ id: 3
11
+ subscriber_id: alterself
12
+ book_id: 3
@@ -22,4 +22,7 @@ godfather:
22
22
  tag_id: 1
23
23
  taggable_id: 1
24
24
  taggable_type: Item
25
-
25
+
26
+ orphaned:
27
+ id: 5
28
+ tag_id: 1
@@ -12,11 +12,31 @@ first:
12
12
 
13
13
  second:
14
14
  id: 2
15
- title: The Second Topic's of the day
15
+ title: The Second Topic of the day
16
16
  author_name: Mary
17
- written_on: 2003-07-15t15:28:00.0099+01:00
17
+ written_on: 2004-07-15t15:28:00.0099+01:00
18
18
  content: Have a nice day
19
19
  approved: true
20
20
  replies_count: 0
21
21
  parent_id: 1
22
22
  type: Reply
23
+
24
+ third:
25
+ id: 3
26
+ title: The Third Topic of the day
27
+ author_name: Nick
28
+ written_on: 2005-07-15t15:28:00.0099+01:00
29
+ content: I'm a troll
30
+ approved: true
31
+ replies_count: 1
32
+
33
+ fourth:
34
+ id: 4
35
+ title: The Fourth Topic of the day
36
+ author_name: Carl
37
+ written_on: 2006-07-15t15:28:00.0099+01:00
38
+ content: Why not?
39
+ approved: true
40
+ type: Reply
41
+ parent_id: 3
42
+
@@ -0,0 +1,3 @@
1
+ one:
2
+ id: 1
3
+ value: 1000
@@ -2,7 +2,7 @@ class PeopleHaveLastNames < ActiveRecord::Migration
2
2
  def self.up
3
3
  add_column "people", "last_name", :string
4
4
  end
5
-
5
+
6
6
  def self.down
7
7
  remove_column "people", "last_name"
8
8
  end
@@ -5,7 +5,7 @@ class WeNeedReminders < ActiveRecord::Migration
5
5
  t.column :remind_at, :datetime
6
6
  end
7
7
  end
8
-
8
+
9
9
  def self.down
10
10
  drop_table "reminders"
11
11
  end
@@ -0,0 +1,7 @@
1
+ class Chunky < ActiveRecord::Migration
2
+ def self.up
3
+ end
4
+
5
+ def self.down
6
+ end
7
+ end
@@ -0,0 +1,7 @@
1
+ class Chunky < ActiveRecord::Migration
2
+ def self.up
3
+ end
4
+
5
+ def self.down
6
+ end
7
+ end
@@ -2,7 +2,7 @@ class PeopleHaveLastNames < ActiveRecord::Migration
2
2
  def self.up
3
3
  add_column "people", "last_name", :string
4
4
  end
5
-
5
+
6
6
  def self.down
7
7
  remove_column "people", "last_name"
8
8
  end
@@ -2,7 +2,7 @@ class PeopleHaveLastNames < ActiveRecord::Migration
2
2
  def self.up
3
3
  add_column "people", "last_name", :string
4
4
  end
5
-
5
+
6
6
  def self.down
7
7
  remove_column "people", "last_name"
8
8
  end
@@ -0,0 +1,8 @@
1
+ class IRaiseOnDown < ActiveRecord::Migration
2
+ def self.up
3
+ end
4
+
5
+ def self.down
6
+ raise
7
+ end
8
+ end
@@ -0,0 +1,12 @@
1
+ class InnocentJointable < ActiveRecord::Migration
2
+ def self.up
3
+ create_table("people_reminders", :id => false) do |t|
4
+ t.column :reminder_id, :integer
5
+ t.column :person_id, :integer
6
+ end
7
+ end
8
+
9
+ def self.down
10
+ drop_table "people_reminders"
11
+ end
12
+ end
@@ -2,7 +2,7 @@ class PeopleHaveMiddleNames < ActiveRecord::Migration
2
2
  def self.up
3
3
  add_column "people", "middle_name", :string
4
4
  end
5
-
5
+
6
6
  def self.down
7
7
  remove_column "people", "middle_name"
8
8
  end
@@ -0,0 +1,9 @@
1
+ class PeopleHaveLastNames < ActiveRecord::Migration
2
+ def self.up
3
+ add_column "people", "last_name", :string
4
+ end
5
+
6
+ def self.down
7
+ remove_column "people", "last_name"
8
+ end
9
+ end
@@ -5,7 +5,7 @@ class WeNeedReminders < ActiveRecord::Migration
5
5
  t.column :remind_at, :datetime
6
6
  end
7
7
  end
8
-
8
+
9
9
  def self.down
10
10
  drop_table "reminders"
11
11
  end
@@ -0,0 +1,12 @@
1
+ class InnocentJointable < ActiveRecord::Migration
2
+ def self.up
3
+ create_table("people_reminders", :id => false) do |t|
4
+ t.column :reminder_id, :integer
5
+ t.column :person_id, :integer
6
+ end
7
+ end
8
+
9
+ def self.down
10
+ drop_table "people_reminders"
11
+ end
12
+ end
@@ -0,0 +1,9 @@
1
+ class PeopleHaveLastNames < ActiveRecord::Migration
2
+ def self.up
3
+ add_column "people", "last_name", :string
4
+ end
5
+
6
+ def self.down
7
+ remove_column "people", "last_name"
8
+ end
9
+ end
@@ -5,7 +5,7 @@ class WeNeedReminders < ActiveRecord::Migration
5
5
  t.column :remind_at, :datetime
6
6
  end
7
7
  end
8
-
8
+
9
9
  def self.down
10
10
  drop_table "reminders"
11
11
  end
@@ -0,0 +1,12 @@
1
+ class InnocentJointable < ActiveRecord::Migration
2
+ def self.up
3
+ create_table("people_reminders", :id => false) do |t|
4
+ t.column :reminder_id, :integer
5
+ t.column :person_id, :integer
6
+ end
7
+ end
8
+
9
+ def self.down
10
+ drop_table "people_reminders"
11
+ end
12
+ end
@@ -3,6 +3,7 @@ class Author < ActiveRecord::Base
3
3
  has_many :posts_with_comments, :include => :comments, :class_name => "Post"
4
4
  has_many :posts_with_categories, :include => :categories, :class_name => "Post"
5
5
  has_many :posts_with_comments_and_categories, :include => [ :comments, :categories ], :order => "posts.id", :class_name => "Post"
6
+ has_many :posts_containing_the_letter_a, :class_name => "Post"
6
7
  has_many :posts_with_extension, :class_name => "Post" do #, :extend => ProxyTestExtension
7
8
  def testing_proxy_owner
8
9
  proxy_owner
@@ -15,15 +16,21 @@ class Author < ActiveRecord::Base
15
16
  end
16
17
  end
17
18
  has_many :comments, :through => :posts
19
+ has_many :comments_containing_the_letter_e, :through => :posts, :source => :comments
20
+ has_many :comments_with_order_and_conditions, :through => :posts, :source => :comments, :order => 'comments.body', :conditions => "comments.body like 'Thank%'"
21
+ has_many :comments_with_include, :through => :posts, :source => :comments, :include => :post
22
+
23
+
18
24
  has_many :comments_desc, :through => :posts, :source => :comments, :order => 'comments.id DESC'
19
25
  has_many :limited_comments, :through => :posts, :source => :comments, :limit => 1
20
26
  has_many :funky_comments, :through => :posts, :source => :comments
21
27
  has_many :ordered_uniq_comments, :through => :posts, :source => :comments, :uniq => true, :order => 'comments.id'
22
28
  has_many :ordered_uniq_comments_desc, :through => :posts, :source => :comments, :uniq => true, :order => 'comments.id DESC'
23
-
29
+ has_many :readonly_comments, :through => :posts, :source => :comments, :readonly => true
30
+
24
31
  has_many :special_posts
25
32
  has_many :special_post_comments, :through => :special_posts, :source => :comments
26
-
33
+
27
34
  has_many :special_nonexistant_posts, :class_name => "SpecialPost", :conditions => "posts.body = 'nonexistant'"
28
35
  has_many :special_nonexistant_post_comments, :through => :special_nonexistant_posts, :source => :comments, :conditions => "comments.post_id = 0"
29
36
  has_many :nonexistant_comments, :through => :posts
@@ -32,9 +39,14 @@ class Author < ActiveRecord::Base
32
39
  has_many :hello_post_comments, :through => :hello_posts, :source => :comments
33
40
  has_many :posts_with_no_comments, :class_name => 'Post', :conditions => 'comments.id is null', :include => :comments
34
41
 
42
+ has_many :hello_posts_with_hash_conditions, :class_name => "Post",
43
+ :conditions => {:body => 'hello'}
44
+ has_many :hello_post_comments_with_hash_conditions, :through =>
45
+ :hello_posts_with_hash_conditions, :source => :comments
46
+
35
47
  has_many :other_posts, :class_name => "Post"
36
48
  has_many :posts_with_callbacks, :class_name => "Post", :before_add => :log_before_adding,
37
- :after_add => :log_after_adding,
49
+ :after_add => :log_after_adding,
38
50
  :before_remove => :log_before_removing,
39
51
  :after_remove => :log_after_removing
40
52
  has_many :posts_with_proc_callbacks, :class_name => "Post",
@@ -65,7 +77,8 @@ class Author < ActiveRecord::Base
65
77
  has_many :tags, :through => :posts # through has_many :through
66
78
  has_many :post_categories, :through => :posts, :source => :categories
67
79
 
68
- belongs_to :author_address
80
+ belongs_to :author_address, :dependent => :destroy
81
+ belongs_to :author_address_extra, :dependent => :delete, :class_name => "AuthorAddress"
69
82
 
70
83
  attr_accessor :post_log
71
84
 
@@ -101,6 +114,17 @@ end
101
114
 
102
115
  class AuthorAddress < ActiveRecord::Base
103
116
  has_one :author
117
+
118
+ def self.destroyed_author_address_ids
119
+ @destroyed_author_address_ids ||= Hash.new { |h,k| h[k] = [] }
120
+ end
121
+
122
+ before_destroy do |author_address|
123
+ if author_address.author
124
+ AuthorAddress.destroyed_author_address_ids[author_address.author.id] << author_address.id
125
+ end
126
+ true
127
+ end
104
128
  end
105
129
 
106
130
  class AuthorFavorite < ActiveRecord::Base