asana2flowdock 1.0.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (1601) hide show
  1. checksums.yaml +15 -0
  2. data/Gemfile +4 -0
  3. data/Gemfile.lock +58 -0
  4. data/README.md +85 -0
  5. data/Rakefile +394 -0
  6. data/a.rb +336 -0
  7. data/a.yml +6 -0
  8. data/asana2flowdock.gemspec +1878 -0
  9. data/bin/amalgalite-pack +16 -0
  10. data/bin/asana2flowdock +274 -0
  11. data/bin/asana2flowdock-daemon +16 -0
  12. data/bin/coderay +16 -0
  13. data/bin/httparty +16 -0
  14. data/bin/pry +16 -0
  15. data/bin/sekrets +16 -0
  16. data/bin/sequel +16 -0
  17. data/config/asana2flowdock.yml.enc +2 -0
  18. data/lib/asana2flowdock.rb +98 -0
  19. data/lib/asana2flowdock/asana.rb +225 -0
  20. data/vendor/bundle/ruby/1.9.1/bin/amalgalite-pack +23 -0
  21. data/vendor/bundle/ruby/1.9.1/bin/asana2flowdock +23 -0
  22. data/vendor/bundle/ruby/1.9.1/bin/asana2flowdock-daemon +23 -0
  23. data/vendor/bundle/ruby/1.9.1/bin/coderay +23 -0
  24. data/vendor/bundle/ruby/1.9.1/bin/httparty +23 -0
  25. data/vendor/bundle/ruby/1.9.1/bin/pry +23 -0
  26. data/vendor/bundle/ruby/1.9.1/bin/sekrets +23 -0
  27. data/vendor/bundle/ruby/1.9.1/bin/sequel +23 -0
  28. data/vendor/bundle/ruby/1.9.1/build_info/amalgalite-1.3.0.info +1 -0
  29. data/vendor/bundle/ruby/1.9.1/build_info/arrayfields-4.7.4.info +1 -0
  30. data/vendor/bundle/ruby/1.9.1/build_info/chronic-0.10.2.info +1 -0
  31. data/vendor/bundle/ruby/1.9.1/build_info/coderay-1.1.0.info +1 -0
  32. data/vendor/bundle/ruby/1.9.1/build_info/coerce-0.0.6.info +1 -0
  33. data/vendor/bundle/ruby/1.9.1/build_info/daemons-1.1.9.info +1 -0
  34. data/vendor/bundle/ruby/1.9.1/build_info/fastercsv-1.5.5.info +1 -0
  35. data/vendor/bundle/ruby/1.9.1/build_info/fattr-2.2.2.info +1 -0
  36. data/vendor/bundle/ruby/1.9.1/build_info/flowdock-0.5.0.info +1 -0
  37. data/vendor/bundle/ruby/1.9.1/build_info/highline-1.6.21.info +1 -0
  38. data/vendor/bundle/ruby/1.9.1/build_info/httparty-0.13.1.info +1 -0
  39. data/vendor/bundle/ruby/1.9.1/build_info/json-1.8.1.info +1 -0
  40. data/vendor/bundle/ruby/1.9.1/build_info/main-6.0.0.info +1 -0
  41. data/vendor/bundle/ruby/1.9.1/build_info/main-6.1.0.info +1 -0
  42. data/vendor/bundle/ruby/1.9.1/build_info/map-6.5.5.info +1 -0
  43. data/vendor/bundle/ruby/1.9.1/build_info/method_source-0.8.2.info +1 -0
  44. data/vendor/bundle/ruby/1.9.1/build_info/multi_json-1.10.1.info +1 -0
  45. data/vendor/bundle/ruby/1.9.1/build_info/multi_xml-0.5.5.info +1 -0
  46. data/vendor/bundle/ruby/1.9.1/build_info/pry-0.9.12.6.info +1 -0
  47. data/vendor/bundle/ruby/1.9.1/build_info/sekrets-1.7.0.info +1 -0
  48. data/vendor/bundle/ruby/1.9.1/build_info/sequel-4.15.0.info +1 -0
  49. data/vendor/bundle/ruby/1.9.1/build_info/slop-3.5.0.info +1 -0
  50. data/vendor/bundle/ruby/1.9.1/build_info/threadify-1.3.0.info +1 -0
  51. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/CONTRIBUTING.md +49 -0
  52. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/HISTORY.md +315 -0
  53. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/LICENSE +29 -0
  54. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/Manifest.txt +104 -0
  55. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/README.md +73 -0
  56. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/Rakefile +25 -0
  57. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/TODO.md +50 -0
  58. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/bin/amalgalite-pack +147 -0
  59. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/examples/a.rb +9 -0
  60. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/examples/blob.rb +88 -0
  61. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/examples/bootstrap.rb +36 -0
  62. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/examples/define_aggregate.rb +75 -0
  63. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/examples/define_function.rb +104 -0
  64. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/examples/fts3.rb +144 -0
  65. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/examples/gem-db.rb +94 -0
  66. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/examples/require_me.rb +11 -0
  67. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/examples/requires.rb +42 -0
  68. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/examples/schema-info.rb +34 -0
  69. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/ext/amalgalite/c/Makefile +220 -0
  70. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/ext/amalgalite/c/amalgalite.bundle +0 -0
  71. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/ext/amalgalite/c/amalgalite.c +329 -0
  72. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/ext/amalgalite/c/amalgalite.h +151 -0
  73. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/ext/amalgalite/c/amalgalite.o +0 -0
  74. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/ext/amalgalite/c/amalgalite_blob.c +240 -0
  75. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/ext/amalgalite/c/amalgalite_blob.o +0 -0
  76. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/ext/amalgalite/c/amalgalite_constants.c +378 -0
  77. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/ext/amalgalite/c/amalgalite_constants.o +0 -0
  78. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/ext/amalgalite/c/amalgalite_database.c +1177 -0
  79. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/ext/amalgalite/c/amalgalite_database.o +0 -0
  80. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/ext/amalgalite/c/amalgalite_requires_bootstrap.c +282 -0
  81. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/ext/amalgalite/c/amalgalite_requires_bootstrap.o +0 -0
  82. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/ext/amalgalite/c/amalgalite_statement.c +649 -0
  83. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/ext/amalgalite/c/amalgalite_statement.o +0 -0
  84. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/ext/amalgalite/c/extconf.rb +36 -0
  85. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/ext/amalgalite/c/gen_constants.rb +193 -0
  86. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/ext/amalgalite/c/notes.txt +134 -0
  87. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/ext/amalgalite/c/sqlite3.c +137414 -0
  88. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/ext/amalgalite/c/sqlite3.h +7160 -0
  89. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/ext/amalgalite/c/sqlite3.o +0 -0
  90. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/ext/amalgalite/c/sqlite3_options.h +4 -0
  91. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/ext/amalgalite/c/sqlite3ext.h +447 -0
  92. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/lib/amalgalite.rb +51 -0
  93. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/lib/amalgalite/1.9/amalgalite.bundle +0 -0
  94. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/lib/amalgalite/aggregate.rb +67 -0
  95. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/lib/amalgalite/blob.rb +186 -0
  96. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/lib/amalgalite/boolean.rb +42 -0
  97. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/lib/amalgalite/busy_timeout.rb +47 -0
  98. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/lib/amalgalite/column.rb +99 -0
  99. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/lib/amalgalite/core_ext/kernel/require.rb +21 -0
  100. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/lib/amalgalite/csv_table_importer.rb +74 -0
  101. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/lib/amalgalite/database.rb +984 -0
  102. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/lib/amalgalite/function.rb +61 -0
  103. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/lib/amalgalite/index.rb +43 -0
  104. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/lib/amalgalite/memory_database.rb +15 -0
  105. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/lib/amalgalite/packer.rb +231 -0
  106. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/lib/amalgalite/paths.rb +80 -0
  107. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/lib/amalgalite/profile_tap.rb +131 -0
  108. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/lib/amalgalite/progress_handler.rb +21 -0
  109. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/lib/amalgalite/requires.rb +151 -0
  110. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/lib/amalgalite/schema.rb +225 -0
  111. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/lib/amalgalite/sqlite3.rb +6 -0
  112. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/lib/amalgalite/sqlite3/constants.rb +95 -0
  113. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/lib/amalgalite/sqlite3/database/function.rb +48 -0
  114. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/lib/amalgalite/sqlite3/database/status.rb +68 -0
  115. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/lib/amalgalite/sqlite3/status.rb +60 -0
  116. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/lib/amalgalite/sqlite3/version.rb +55 -0
  117. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/lib/amalgalite/statement.rb +418 -0
  118. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/lib/amalgalite/table.rb +91 -0
  119. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/lib/amalgalite/taps.rb +2 -0
  120. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/lib/amalgalite/taps/console.rb +27 -0
  121. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/lib/amalgalite/taps/io.rb +71 -0
  122. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/lib/amalgalite/trace_tap.rb +35 -0
  123. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/lib/amalgalite/type_map.rb +63 -0
  124. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/lib/amalgalite/type_maps/default_map.rb +166 -0
  125. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/lib/amalgalite/type_maps/storage_map.rb +38 -0
  126. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/lib/amalgalite/type_maps/text_map.rb +21 -0
  127. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/lib/amalgalite/version.rb +8 -0
  128. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/lib/amalgalite/view.rb +26 -0
  129. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/spec/aggregate_spec.rb +150 -0
  130. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/spec/amalgalite_spec.rb +4 -0
  131. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/spec/blob_spec.rb +78 -0
  132. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/spec/boolean_spec.rb +24 -0
  133. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/spec/busy_handler.rb +157 -0
  134. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/spec/data/iso-3166-country.txt +242 -0
  135. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/spec/data/iso-3166-schema.sql +22 -0
  136. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/spec/data/iso-3166-subcountry.txt +3995 -0
  137. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/spec/data/make-iso-db.sh +12 -0
  138. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/spec/database_spec.rb +510 -0
  139. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/spec/default_map_spec.rb +92 -0
  140. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/spec/function_spec.rb +78 -0
  141. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/spec/integeration_spec.rb +97 -0
  142. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/spec/iso_3166_database.rb +58 -0
  143. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/spec/packer_spec.rb +60 -0
  144. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/spec/paths_spec.rb +28 -0
  145. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/spec/progress_handler_spec.rb +91 -0
  146. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/spec/requires_spec.rb +54 -0
  147. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/spec/rtree_spec.rb +66 -0
  148. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/spec/schema_spec.rb +131 -0
  149. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/spec/spec_helper.rb +43 -0
  150. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/spec/sqlite3/constants_spec.rb +108 -0
  151. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/spec/sqlite3/database_status_spec.rb +36 -0
  152. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/spec/sqlite3/status_spec.rb +22 -0
  153. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/spec/sqlite3/version_spec.rb +22 -0
  154. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/spec/sqlite3_spec.rb +53 -0
  155. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/spec/statement_spec.rb +168 -0
  156. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/spec/storage_map_spec.rb +38 -0
  157. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/spec/tap_spec.rb +57 -0
  158. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/spec/text_map_spec.rb +20 -0
  159. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/spec/type_map_spec.rb +14 -0
  160. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/spec/version_spec.rb +8 -0
  161. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/tasks/custom.rake +99 -0
  162. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/tasks/default.rake +277 -0
  163. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/tasks/extension.rake +38 -0
  164. data/vendor/bundle/ruby/1.9.1/gems/amalgalite-1.3.0/tasks/this.rb +209 -0
  165. data/vendor/bundle/ruby/1.9.1/gems/arrayfields-4.7.4/README +378 -0
  166. data/vendor/bundle/ruby/1.9.1/gems/arrayfields-4.7.4/arrayfields.gemspec +26 -0
  167. data/vendor/bundle/ruby/1.9.1/gems/arrayfields-4.7.4/gemspec.rb +62 -0
  168. data/vendor/bundle/ruby/1.9.1/gems/arrayfields-4.7.4/install.rb +206 -0
  169. data/vendor/bundle/ruby/1.9.1/gems/arrayfields-4.7.4/lib/arrayfields.rb +443 -0
  170. data/vendor/bundle/ruby/1.9.1/gems/arrayfields-4.7.4/readme.rb +248 -0
  171. data/vendor/bundle/ruby/1.9.1/gems/arrayfields-4.7.4/sample/a.rb +40 -0
  172. data/vendor/bundle/ruby/1.9.1/gems/arrayfields-4.7.4/sample/b.rb +16 -0
  173. data/vendor/bundle/ruby/1.9.1/gems/arrayfields-4.7.4/sample/c.rb +9 -0
  174. data/vendor/bundle/ruby/1.9.1/gems/arrayfields-4.7.4/sample/d.rb +25 -0
  175. data/vendor/bundle/ruby/1.9.1/gems/arrayfields-4.7.4/sample/e.rb +15 -0
  176. data/vendor/bundle/ruby/1.9.1/gems/arrayfields-4.7.4/test/arrayfields.rb +324 -0
  177. data/vendor/bundle/ruby/1.9.1/gems/arrayfields-4.7.4/test/memtest.rb +41 -0
  178. data/vendor/bundle/ruby/1.9.1/gems/chronic-0.10.2/HISTORY.md +243 -0
  179. data/vendor/bundle/ruby/1.9.1/gems/chronic-0.10.2/LICENSE +21 -0
  180. data/vendor/bundle/ruby/1.9.1/gems/chronic-0.10.2/README.md +182 -0
  181. data/vendor/bundle/ruby/1.9.1/gems/chronic-0.10.2/Rakefile +66 -0
  182. data/vendor/bundle/ruby/1.9.1/gems/chronic-0.10.2/chronic.gemspec +23 -0
  183. data/vendor/bundle/ruby/1.9.1/gems/chronic-0.10.2/lib/chronic.rb +150 -0
  184. data/vendor/bundle/ruby/1.9.1/gems/chronic-0.10.2/lib/chronic/date.rb +82 -0
  185. data/vendor/bundle/ruby/1.9.1/gems/chronic-0.10.2/lib/chronic/grabber.rb +33 -0
  186. data/vendor/bundle/ruby/1.9.1/gems/chronic-0.10.2/lib/chronic/handler.rb +97 -0
  187. data/vendor/bundle/ruby/1.9.1/gems/chronic-0.10.2/lib/chronic/handlers.rb +647 -0
  188. data/vendor/bundle/ruby/1.9.1/gems/chronic-0.10.2/lib/chronic/mini_date.rb +38 -0
  189. data/vendor/bundle/ruby/1.9.1/gems/chronic-0.10.2/lib/chronic/numerizer.rb +130 -0
  190. data/vendor/bundle/ruby/1.9.1/gems/chronic-0.10.2/lib/chronic/ordinal.rb +49 -0
  191. data/vendor/bundle/ruby/1.9.1/gems/chronic-0.10.2/lib/chronic/parser.rb +268 -0
  192. data/vendor/bundle/ruby/1.9.1/gems/chronic-0.10.2/lib/chronic/pointer.rb +32 -0
  193. data/vendor/bundle/ruby/1.9.1/gems/chronic-0.10.2/lib/chronic/repeater.rb +145 -0
  194. data/vendor/bundle/ruby/1.9.1/gems/chronic-0.10.2/lib/chronic/repeaters/repeater_day.rb +54 -0
  195. data/vendor/bundle/ruby/1.9.1/gems/chronic-0.10.2/lib/chronic/repeaters/repeater_day_name.rb +53 -0
  196. data/vendor/bundle/ruby/1.9.1/gems/chronic-0.10.2/lib/chronic/repeaters/repeater_day_portion.rb +109 -0
  197. data/vendor/bundle/ruby/1.9.1/gems/chronic-0.10.2/lib/chronic/repeaters/repeater_fortnight.rb +72 -0
  198. data/vendor/bundle/ruby/1.9.1/gems/chronic-0.10.2/lib/chronic/repeaters/repeater_hour.rb +59 -0
  199. data/vendor/bundle/ruby/1.9.1/gems/chronic-0.10.2/lib/chronic/repeaters/repeater_minute.rb +59 -0
  200. data/vendor/bundle/ruby/1.9.1/gems/chronic-0.10.2/lib/chronic/repeaters/repeater_month.rb +80 -0
  201. data/vendor/bundle/ruby/1.9.1/gems/chronic-0.10.2/lib/chronic/repeaters/repeater_month_name.rb +95 -0
  202. data/vendor/bundle/ruby/1.9.1/gems/chronic-0.10.2/lib/chronic/repeaters/repeater_season.rb +111 -0
  203. data/vendor/bundle/ruby/1.9.1/gems/chronic-0.10.2/lib/chronic/repeaters/repeater_season_name.rb +43 -0
  204. data/vendor/bundle/ruby/1.9.1/gems/chronic-0.10.2/lib/chronic/repeaters/repeater_second.rb +43 -0
  205. data/vendor/bundle/ruby/1.9.1/gems/chronic-0.10.2/lib/chronic/repeaters/repeater_time.rb +138 -0
  206. data/vendor/bundle/ruby/1.9.1/gems/chronic-0.10.2/lib/chronic/repeaters/repeater_week.rb +75 -0
  207. data/vendor/bundle/ruby/1.9.1/gems/chronic-0.10.2/lib/chronic/repeaters/repeater_weekday.rb +86 -0
  208. data/vendor/bundle/ruby/1.9.1/gems/chronic-0.10.2/lib/chronic/repeaters/repeater_weekend.rb +67 -0
  209. data/vendor/bundle/ruby/1.9.1/gems/chronic-0.10.2/lib/chronic/repeaters/repeater_year.rb +78 -0
  210. data/vendor/bundle/ruby/1.9.1/gems/chronic-0.10.2/lib/chronic/scalar.rb +81 -0
  211. data/vendor/bundle/ruby/1.9.1/gems/chronic-0.10.2/lib/chronic/season.rb +26 -0
  212. data/vendor/bundle/ruby/1.9.1/gems/chronic-0.10.2/lib/chronic/separator.rb +207 -0
  213. data/vendor/bundle/ruby/1.9.1/gems/chronic-0.10.2/lib/chronic/sign.rb +49 -0
  214. data/vendor/bundle/ruby/1.9.1/gems/chronic-0.10.2/lib/chronic/span.rb +31 -0
  215. data/vendor/bundle/ruby/1.9.1/gems/chronic-0.10.2/lib/chronic/tag.rb +37 -0
  216. data/vendor/bundle/ruby/1.9.1/gems/chronic-0.10.2/lib/chronic/time.rb +40 -0
  217. data/vendor/bundle/ruby/1.9.1/gems/chronic-0.10.2/lib/chronic/time_zone.rb +32 -0
  218. data/vendor/bundle/ruby/1.9.1/gems/chronic-0.10.2/lib/chronic/token.rb +51 -0
  219. data/vendor/bundle/ruby/1.9.1/gems/chronic-0.10.2/test/helper.rb +12 -0
  220. data/vendor/bundle/ruby/1.9.1/gems/chronic-0.10.2/test/test_chronic.rb +183 -0
  221. data/vendor/bundle/ruby/1.9.1/gems/chronic-0.10.2/test/test_daylight_savings.rb +118 -0
  222. data/vendor/bundle/ruby/1.9.1/gems/chronic-0.10.2/test/test_handler.rb +128 -0
  223. data/vendor/bundle/ruby/1.9.1/gems/chronic-0.10.2/test/test_mini_date.rb +32 -0
  224. data/vendor/bundle/ruby/1.9.1/gems/chronic-0.10.2/test/test_numerizer.rb +86 -0
  225. data/vendor/bundle/ruby/1.9.1/gems/chronic-0.10.2/test/test_parsing.rb +1235 -0
  226. data/vendor/bundle/ruby/1.9.1/gems/chronic-0.10.2/test/test_repeater_day_name.rb +51 -0
  227. data/vendor/bundle/ruby/1.9.1/gems/chronic-0.10.2/test/test_repeater_day_portion.rb +254 -0
  228. data/vendor/bundle/ruby/1.9.1/gems/chronic-0.10.2/test/test_repeater_fortnight.rb +62 -0
  229. data/vendor/bundle/ruby/1.9.1/gems/chronic-0.10.2/test/test_repeater_hour.rb +68 -0
  230. data/vendor/bundle/ruby/1.9.1/gems/chronic-0.10.2/test/test_repeater_minute.rb +34 -0
  231. data/vendor/bundle/ruby/1.9.1/gems/chronic-0.10.2/test/test_repeater_month.rb +50 -0
  232. data/vendor/bundle/ruby/1.9.1/gems/chronic-0.10.2/test/test_repeater_month_name.rb +56 -0
  233. data/vendor/bundle/ruby/1.9.1/gems/chronic-0.10.2/test/test_repeater_season.rb +40 -0
  234. data/vendor/bundle/ruby/1.9.1/gems/chronic-0.10.2/test/test_repeater_time.rb +88 -0
  235. data/vendor/bundle/ruby/1.9.1/gems/chronic-0.10.2/test/test_repeater_week.rb +62 -0
  236. data/vendor/bundle/ruby/1.9.1/gems/chronic-0.10.2/test/test_repeater_weekday.rb +55 -0
  237. data/vendor/bundle/ruby/1.9.1/gems/chronic-0.10.2/test/test_repeater_weekend.rb +74 -0
  238. data/vendor/bundle/ruby/1.9.1/gems/chronic-0.10.2/test/test_repeater_year.rb +69 -0
  239. data/vendor/bundle/ruby/1.9.1/gems/chronic-0.10.2/test/test_span.rb +23 -0
  240. data/vendor/bundle/ruby/1.9.1/gems/chronic-0.10.2/test/test_token.rb +25 -0
  241. data/vendor/bundle/ruby/1.9.1/gems/coderay-1.1.0/README_INDEX.rdoc +123 -0
  242. data/vendor/bundle/ruby/1.9.1/gems/coderay-1.1.0/Rakefile +37 -0
  243. data/vendor/bundle/ruby/1.9.1/gems/coderay-1.1.0/bin/coderay +215 -0
  244. data/vendor/bundle/ruby/1.9.1/gems/coderay-1.1.0/lib/coderay.rb +284 -0
  245. data/vendor/bundle/ruby/1.9.1/gems/coderay-1.1.0/lib/coderay/duo.rb +81 -0
  246. data/vendor/bundle/ruby/1.9.1/gems/coderay-1.1.0/lib/coderay/encoder.rb +201 -0
  247. data/vendor/bundle/ruby/1.9.1/gems/coderay-1.1.0/lib/coderay/encoders/_map.rb +17 -0
  248. data/vendor/bundle/ruby/1.9.1/gems/coderay-1.1.0/lib/coderay/encoders/comment_filter.rb +25 -0
  249. data/vendor/bundle/ruby/1.9.1/gems/coderay-1.1.0/lib/coderay/encoders/count.rb +39 -0
  250. data/vendor/bundle/ruby/1.9.1/gems/coderay-1.1.0/lib/coderay/encoders/debug.rb +49 -0
  251. data/vendor/bundle/ruby/1.9.1/gems/coderay-1.1.0/lib/coderay/encoders/debug_lint.rb +63 -0
  252. data/vendor/bundle/ruby/1.9.1/gems/coderay-1.1.0/lib/coderay/encoders/div.rb +23 -0
  253. data/vendor/bundle/ruby/1.9.1/gems/coderay-1.1.0/lib/coderay/encoders/filter.rb +58 -0
  254. data/vendor/bundle/ruby/1.9.1/gems/coderay-1.1.0/lib/coderay/encoders/html.rb +332 -0
  255. data/vendor/bundle/ruby/1.9.1/gems/coderay-1.1.0/lib/coderay/encoders/html/css.rb +65 -0
  256. data/vendor/bundle/ruby/1.9.1/gems/coderay-1.1.0/lib/coderay/encoders/html/numbering.rb +108 -0
  257. data/vendor/bundle/ruby/1.9.1/gems/coderay-1.1.0/lib/coderay/encoders/html/output.rb +166 -0
  258. data/vendor/bundle/ruby/1.9.1/gems/coderay-1.1.0/lib/coderay/encoders/json.rb +83 -0
  259. data/vendor/bundle/ruby/1.9.1/gems/coderay-1.1.0/lib/coderay/encoders/lines_of_code.rb +45 -0
  260. data/vendor/bundle/ruby/1.9.1/gems/coderay-1.1.0/lib/coderay/encoders/lint.rb +59 -0
  261. data/vendor/bundle/ruby/1.9.1/gems/coderay-1.1.0/lib/coderay/encoders/null.rb +18 -0
  262. data/vendor/bundle/ruby/1.9.1/gems/coderay-1.1.0/lib/coderay/encoders/page.rb +24 -0
  263. data/vendor/bundle/ruby/1.9.1/gems/coderay-1.1.0/lib/coderay/encoders/span.rb +23 -0
  264. data/vendor/bundle/ruby/1.9.1/gems/coderay-1.1.0/lib/coderay/encoders/statistic.rb +95 -0
  265. data/vendor/bundle/ruby/1.9.1/gems/coderay-1.1.0/lib/coderay/encoders/terminal.rb +195 -0
  266. data/vendor/bundle/ruby/1.9.1/gems/coderay-1.1.0/lib/coderay/encoders/text.rb +46 -0
  267. data/vendor/bundle/ruby/1.9.1/gems/coderay-1.1.0/lib/coderay/encoders/token_kind_filter.rb +111 -0
  268. data/vendor/bundle/ruby/1.9.1/gems/coderay-1.1.0/lib/coderay/encoders/xml.rb +72 -0
  269. data/vendor/bundle/ruby/1.9.1/gems/coderay-1.1.0/lib/coderay/encoders/yaml.rb +50 -0
  270. data/vendor/bundle/ruby/1.9.1/gems/coderay-1.1.0/lib/coderay/for_redcloth.rb +95 -0
  271. data/vendor/bundle/ruby/1.9.1/gems/coderay-1.1.0/lib/coderay/helpers/file_type.rb +151 -0
  272. data/vendor/bundle/ruby/1.9.1/gems/coderay-1.1.0/lib/coderay/helpers/plugin.rb +274 -0
  273. data/vendor/bundle/ruby/1.9.1/gems/coderay-1.1.0/lib/coderay/helpers/word_list.rb +72 -0
  274. data/vendor/bundle/ruby/1.9.1/gems/coderay-1.1.0/lib/coderay/scanner.rb +355 -0
  275. data/vendor/bundle/ruby/1.9.1/gems/coderay-1.1.0/lib/coderay/scanners/_map.rb +24 -0
  276. data/vendor/bundle/ruby/1.9.1/gems/coderay-1.1.0/lib/coderay/scanners/c.rb +189 -0
  277. data/vendor/bundle/ruby/1.9.1/gems/coderay-1.1.0/lib/coderay/scanners/clojure.rb +217 -0
  278. data/vendor/bundle/ruby/1.9.1/gems/coderay-1.1.0/lib/coderay/scanners/cpp.rb +215 -0
  279. data/vendor/bundle/ruby/1.9.1/gems/coderay-1.1.0/lib/coderay/scanners/css.rb +196 -0
  280. data/vendor/bundle/ruby/1.9.1/gems/coderay-1.1.0/lib/coderay/scanners/debug.rb +75 -0
  281. data/vendor/bundle/ruby/1.9.1/gems/coderay-1.1.0/lib/coderay/scanners/delphi.rb +144 -0
  282. data/vendor/bundle/ruby/1.9.1/gems/coderay-1.1.0/lib/coderay/scanners/diff.rb +221 -0
  283. data/vendor/bundle/ruby/1.9.1/gems/coderay-1.1.0/lib/coderay/scanners/erb.rb +81 -0
  284. data/vendor/bundle/ruby/1.9.1/gems/coderay-1.1.0/lib/coderay/scanners/go.rb +208 -0
  285. data/vendor/bundle/ruby/1.9.1/gems/coderay-1.1.0/lib/coderay/scanners/groovy.rb +268 -0
  286. data/vendor/bundle/ruby/1.9.1/gems/coderay-1.1.0/lib/coderay/scanners/haml.rb +168 -0
  287. data/vendor/bundle/ruby/1.9.1/gems/coderay-1.1.0/lib/coderay/scanners/html.rb +275 -0
  288. data/vendor/bundle/ruby/1.9.1/gems/coderay-1.1.0/lib/coderay/scanners/java.rb +174 -0
  289. data/vendor/bundle/ruby/1.9.1/gems/coderay-1.1.0/lib/coderay/scanners/java/builtin_types.rb +421 -0
  290. data/vendor/bundle/ruby/1.9.1/gems/coderay-1.1.0/lib/coderay/scanners/java_script.rb +237 -0
  291. data/vendor/bundle/ruby/1.9.1/gems/coderay-1.1.0/lib/coderay/scanners/json.rb +98 -0
  292. data/vendor/bundle/ruby/1.9.1/gems/coderay-1.1.0/lib/coderay/scanners/lua.rb +280 -0
  293. data/vendor/bundle/ruby/1.9.1/gems/coderay-1.1.0/lib/coderay/scanners/php.rb +527 -0
  294. data/vendor/bundle/ruby/1.9.1/gems/coderay-1.1.0/lib/coderay/scanners/python.rb +287 -0
  295. data/vendor/bundle/ruby/1.9.1/gems/coderay-1.1.0/lib/coderay/scanners/raydebug.rb +75 -0
  296. data/vendor/bundle/ruby/1.9.1/gems/coderay-1.1.0/lib/coderay/scanners/ruby.rb +470 -0
  297. data/vendor/bundle/ruby/1.9.1/gems/coderay-1.1.0/lib/coderay/scanners/ruby/patterns.rb +178 -0
  298. data/vendor/bundle/ruby/1.9.1/gems/coderay-1.1.0/lib/coderay/scanners/ruby/string_state.rb +71 -0
  299. data/vendor/bundle/ruby/1.9.1/gems/coderay-1.1.0/lib/coderay/scanners/sass.rb +232 -0
  300. data/vendor/bundle/ruby/1.9.1/gems/coderay-1.1.0/lib/coderay/scanners/sql.rb +177 -0
  301. data/vendor/bundle/ruby/1.9.1/gems/coderay-1.1.0/lib/coderay/scanners/taskpaper.rb +36 -0
  302. data/vendor/bundle/ruby/1.9.1/gems/coderay-1.1.0/lib/coderay/scanners/text.rb +26 -0
  303. data/vendor/bundle/ruby/1.9.1/gems/coderay-1.1.0/lib/coderay/scanners/xml.rb +17 -0
  304. data/vendor/bundle/ruby/1.9.1/gems/coderay-1.1.0/lib/coderay/scanners/yaml.rb +140 -0
  305. data/vendor/bundle/ruby/1.9.1/gems/coderay-1.1.0/lib/coderay/style.rb +23 -0
  306. data/vendor/bundle/ruby/1.9.1/gems/coderay-1.1.0/lib/coderay/styles/_map.rb +7 -0
  307. data/vendor/bundle/ruby/1.9.1/gems/coderay-1.1.0/lib/coderay/styles/alpha.rb +152 -0
  308. data/vendor/bundle/ruby/1.9.1/gems/coderay-1.1.0/lib/coderay/token_kinds.rb +85 -0
  309. data/vendor/bundle/ruby/1.9.1/gems/coderay-1.1.0/lib/coderay/tokens.rb +161 -0
  310. data/vendor/bundle/ruby/1.9.1/gems/coderay-1.1.0/lib/coderay/tokens_proxy.rb +55 -0
  311. data/vendor/bundle/ruby/1.9.1/gems/coderay-1.1.0/lib/coderay/version.rb +3 -0
  312. data/vendor/bundle/ruby/1.9.1/gems/coderay-1.1.0/test/functional/basic.rb +318 -0
  313. data/vendor/bundle/ruby/1.9.1/gems/coderay-1.1.0/test/functional/examples.rb +129 -0
  314. data/vendor/bundle/ruby/1.9.1/gems/coderay-1.1.0/test/functional/for_redcloth.rb +78 -0
  315. data/vendor/bundle/ruby/1.9.1/gems/coderay-1.1.0/test/functional/suite.rb +15 -0
  316. data/vendor/bundle/ruby/1.9.1/gems/coerce-0.0.6/README +28 -0
  317. data/vendor/bundle/ruby/1.9.1/gems/coerce-0.0.6/Rakefile +392 -0
  318. data/vendor/bundle/ruby/1.9.1/gems/coerce-0.0.6/coerce.gemspec +31 -0
  319. data/vendor/bundle/ruby/1.9.1/gems/coerce-0.0.6/lib/coerce.rb +210 -0
  320. data/vendor/bundle/ruby/1.9.1/gems/daemons-1.1.9/LICENSE +22 -0
  321. data/vendor/bundle/ruby/1.9.1/gems/daemons-1.1.9/README +214 -0
  322. data/vendor/bundle/ruby/1.9.1/gems/daemons-1.1.9/Rakefile +90 -0
  323. data/vendor/bundle/ruby/1.9.1/gems/daemons-1.1.9/Releases +195 -0
  324. data/vendor/bundle/ruby/1.9.1/gems/daemons-1.1.9/TODO +2 -0
  325. data/vendor/bundle/ruby/1.9.1/gems/daemons-1.1.9/examples/call/call.rb +57 -0
  326. data/vendor/bundle/ruby/1.9.1/gems/daemons-1.1.9/examples/call/call_monitor.rb +55 -0
  327. data/vendor/bundle/ruby/1.9.1/gems/daemons-1.1.9/examples/daemonize/daemonize.rb +27 -0
  328. data/vendor/bundle/ruby/1.9.1/gems/daemons-1.1.9/examples/run/ctrl_crash.rb +17 -0
  329. data/vendor/bundle/ruby/1.9.1/gems/daemons-1.1.9/examples/run/ctrl_exec.rb +16 -0
  330. data/vendor/bundle/ruby/1.9.1/gems/daemons-1.1.9/examples/run/ctrl_exit.rb +15 -0
  331. data/vendor/bundle/ruby/1.9.1/gems/daemons-1.1.9/examples/run/ctrl_hanging.rb +19 -0
  332. data/vendor/bundle/ruby/1.9.1/gems/daemons-1.1.9/examples/run/ctrl_keep_pid_files.rb +17 -0
  333. data/vendor/bundle/ruby/1.9.1/gems/daemons-1.1.9/examples/run/ctrl_monitor.rb +16 -0
  334. data/vendor/bundle/ruby/1.9.1/gems/daemons-1.1.9/examples/run/ctrl_multiple.rb +16 -0
  335. data/vendor/bundle/ruby/1.9.1/gems/daemons-1.1.9/examples/run/ctrl_normal.rb +11 -0
  336. data/vendor/bundle/ruby/1.9.1/gems/daemons-1.1.9/examples/run/ctrl_ontop.rb +16 -0
  337. data/vendor/bundle/ruby/1.9.1/gems/daemons-1.1.9/examples/run/ctrl_optionparser.rb +43 -0
  338. data/vendor/bundle/ruby/1.9.1/gems/daemons-1.1.9/examples/run/ctrl_proc.rb +25 -0
  339. data/vendor/bundle/ruby/1.9.1/gems/daemons-1.1.9/examples/run/ctrl_proc_multiple.rb +22 -0
  340. data/vendor/bundle/ruby/1.9.1/gems/daemons-1.1.9/examples/run/ctrl_proc_rand.rb +23 -0
  341. data/vendor/bundle/ruby/1.9.1/gems/daemons-1.1.9/examples/run/ctrl_proc_simple.rb +17 -0
  342. data/vendor/bundle/ruby/1.9.1/gems/daemons-1.1.9/examples/run/ctrl_slowstop.rb +16 -0
  343. data/vendor/bundle/ruby/1.9.1/gems/daemons-1.1.9/examples/run/myserver.rb +12 -0
  344. data/vendor/bundle/ruby/1.9.1/gems/daemons-1.1.9/examples/run/myserver_crashing.rb +14 -0
  345. data/vendor/bundle/ruby/1.9.1/gems/daemons-1.1.9/examples/run/myserver_exiting.rb +8 -0
  346. data/vendor/bundle/ruby/1.9.1/gems/daemons-1.1.9/examples/run/myserver_hanging.rb +21 -0
  347. data/vendor/bundle/ruby/1.9.1/gems/daemons-1.1.9/examples/run/myserver_slowstop.rb +21 -0
  348. data/vendor/bundle/ruby/1.9.1/gems/daemons-1.1.9/lib/daemons.rb +315 -0
  349. data/vendor/bundle/ruby/1.9.1/gems/daemons-1.1.9/lib/daemons/application.rb +477 -0
  350. data/vendor/bundle/ruby/1.9.1/gems/daemons-1.1.9/lib/daemons/application_group.rb +194 -0
  351. data/vendor/bundle/ruby/1.9.1/gems/daemons-1.1.9/lib/daemons/change_privilege.rb +19 -0
  352. data/vendor/bundle/ruby/1.9.1/gems/daemons-1.1.9/lib/daemons/cmdline.rb +121 -0
  353. data/vendor/bundle/ruby/1.9.1/gems/daemons-1.1.9/lib/daemons/controller.rb +140 -0
  354. data/vendor/bundle/ruby/1.9.1/gems/daemons-1.1.9/lib/daemons/daemonize.rb +169 -0
  355. data/vendor/bundle/ruby/1.9.1/gems/daemons-1.1.9/lib/daemons/etc_extension.rb +12 -0
  356. data/vendor/bundle/ruby/1.9.1/gems/daemons-1.1.9/lib/daemons/exceptions.rb +28 -0
  357. data/vendor/bundle/ruby/1.9.1/gems/daemons-1.1.9/lib/daemons/monitor.rb +138 -0
  358. data/vendor/bundle/ruby/1.9.1/gems/daemons-1.1.9/lib/daemons/pid.rb +108 -0
  359. data/vendor/bundle/ruby/1.9.1/gems/daemons-1.1.9/lib/daemons/pidfile.rb +116 -0
  360. data/vendor/bundle/ruby/1.9.1/gems/daemons-1.1.9/lib/daemons/pidmem.rb +19 -0
  361. data/vendor/bundle/ruby/1.9.1/gems/daemons-1.1.9/setup.rb +1360 -0
  362. data/vendor/bundle/ruby/1.9.1/gems/fastercsv-1.5.5/AUTHORS +1 -0
  363. data/vendor/bundle/ruby/1.9.1/gems/fastercsv-1.5.5/CHANGELOG +182 -0
  364. data/vendor/bundle/ruby/1.9.1/gems/fastercsv-1.5.5/COPYING +340 -0
  365. data/vendor/bundle/ruby/1.9.1/gems/fastercsv-1.5.5/INSTALL +33 -0
  366. data/vendor/bundle/ruby/1.9.1/gems/fastercsv-1.5.5/LICENSE +9 -0
  367. data/vendor/bundle/ruby/1.9.1/gems/fastercsv-1.5.5/README +71 -0
  368. data/vendor/bundle/ruby/1.9.1/gems/fastercsv-1.5.5/Rakefile +94 -0
  369. data/vendor/bundle/ruby/1.9.1/gems/fastercsv-1.5.5/TODO +6 -0
  370. data/vendor/bundle/ruby/1.9.1/gems/fastercsv-1.5.5/examples/csv_converters.rb +28 -0
  371. data/vendor/bundle/ruby/1.9.1/gems/fastercsv-1.5.5/examples/csv_filter.rb +23 -0
  372. data/vendor/bundle/ruby/1.9.1/gems/fastercsv-1.5.5/examples/csv_reading.rb +57 -0
  373. data/vendor/bundle/ruby/1.9.1/gems/fastercsv-1.5.5/examples/csv_table.rb +56 -0
  374. data/vendor/bundle/ruby/1.9.1/gems/fastercsv-1.5.5/examples/csv_writing.rb +67 -0
  375. data/vendor/bundle/ruby/1.9.1/gems/fastercsv-1.5.5/examples/purchase.csv +3 -0
  376. data/vendor/bundle/ruby/1.9.1/gems/fastercsv-1.5.5/examples/shortcut_interface.rb +36 -0
  377. data/vendor/bundle/ruby/1.9.1/gems/fastercsv-1.5.5/lib/faster_csv.rb +2025 -0
  378. data/vendor/bundle/ruby/1.9.1/gems/fastercsv-1.5.5/lib/fastercsv.rb +10 -0
  379. data/vendor/bundle/ruby/1.9.1/gems/fastercsv-1.5.5/test/line_endings.gz +0 -0
  380. data/vendor/bundle/ruby/1.9.1/gems/fastercsv-1.5.5/test/tc_csv_parsing.rb +191 -0
  381. data/vendor/bundle/ruby/1.9.1/gems/fastercsv-1.5.5/test/tc_csv_writing.rb +96 -0
  382. data/vendor/bundle/ruby/1.9.1/gems/fastercsv-1.5.5/test/tc_data_converters.rb +260 -0
  383. data/vendor/bundle/ruby/1.9.1/gems/fastercsv-1.5.5/test/tc_encodings.rb +23 -0
  384. data/vendor/bundle/ruby/1.9.1/gems/fastercsv-1.5.5/test/tc_features.rb +212 -0
  385. data/vendor/bundle/ruby/1.9.1/gems/fastercsv-1.5.5/test/tc_headers.rb +277 -0
  386. data/vendor/bundle/ruby/1.9.1/gems/fastercsv-1.5.5/test/tc_interface.rb +376 -0
  387. data/vendor/bundle/ruby/1.9.1/gems/fastercsv-1.5.5/test/tc_row.rb +305 -0
  388. data/vendor/bundle/ruby/1.9.1/gems/fastercsv-1.5.5/test/tc_serialization.rb +154 -0
  389. data/vendor/bundle/ruby/1.9.1/gems/fastercsv-1.5.5/test/tc_speed.rb +65 -0
  390. data/vendor/bundle/ruby/1.9.1/gems/fastercsv-1.5.5/test/tc_table.rb +408 -0
  391. data/vendor/bundle/ruby/1.9.1/gems/fastercsv-1.5.5/test/test_data.csv +1000 -0
  392. data/vendor/bundle/ruby/1.9.1/gems/fastercsv-1.5.5/test/ts_all.rb +20 -0
  393. data/vendor/bundle/ruby/1.9.1/gems/fattr-2.2.2/LICENSE +1 -0
  394. data/vendor/bundle/ruby/1.9.1/gems/fattr-2.2.2/README +347 -0
  395. data/vendor/bundle/ruby/1.9.1/gems/fattr-2.2.2/README.erb +82 -0
  396. data/vendor/bundle/ruby/1.9.1/gems/fattr-2.2.2/Rakefile +376 -0
  397. data/vendor/bundle/ruby/1.9.1/gems/fattr-2.2.2/lib/fattr.rb +206 -0
  398. data/vendor/bundle/ruby/1.9.1/gems/fattr-2.2.2/samples/a.rb +21 -0
  399. data/vendor/bundle/ruby/1.9.1/gems/fattr-2.2.2/samples/b.rb +22 -0
  400. data/vendor/bundle/ruby/1.9.1/gems/fattr-2.2.2/samples/c.rb +12 -0
  401. data/vendor/bundle/ruby/1.9.1/gems/fattr-2.2.2/samples/d.rb +34 -0
  402. data/vendor/bundle/ruby/1.9.1/gems/fattr-2.2.2/samples/e.rb +17 -0
  403. data/vendor/bundle/ruby/1.9.1/gems/fattr-2.2.2/samples/f.rb +21 -0
  404. data/vendor/bundle/ruby/1.9.1/gems/fattr-2.2.2/samples/g.rb +15 -0
  405. data/vendor/bundle/ruby/1.9.1/gems/fattr-2.2.2/samples/h.rb +29 -0
  406. data/vendor/bundle/ruby/1.9.1/gems/fattr-2.2.2/test/fattr_test.rb +173 -0
  407. data/vendor/bundle/ruby/1.9.1/gems/flowdock-0.5.0/Gemfile +16 -0
  408. data/vendor/bundle/ruby/1.9.1/gems/flowdock-0.5.0/LICENSE +20 -0
  409. data/vendor/bundle/ruby/1.9.1/gems/flowdock-0.5.0/README.md +145 -0
  410. data/vendor/bundle/ruby/1.9.1/gems/flowdock-0.5.0/Rakefile +43 -0
  411. data/vendor/bundle/ruby/1.9.1/gems/flowdock-0.5.0/VERSION +1 -0
  412. data/vendor/bundle/ruby/1.9.1/gems/flowdock-0.5.0/flowdock.gemspec +73 -0
  413. data/vendor/bundle/ruby/1.9.1/gems/flowdock-0.5.0/lib/flowdock.rb +181 -0
  414. data/vendor/bundle/ruby/1.9.1/gems/flowdock-0.5.0/lib/flowdock/capistrano.rb +1 -0
  415. data/vendor/bundle/ruby/1.9.1/gems/flowdock-0.5.0/spec/flowdock_spec.rb +435 -0
  416. data/vendor/bundle/ruby/1.9.1/gems/flowdock-0.5.0/spec/spec_helper.rb +14 -0
  417. data/vendor/bundle/ruby/1.9.1/gems/highline-1.6.21/AUTHORS +3 -0
  418. data/vendor/bundle/ruby/1.9.1/gems/highline-1.6.21/CHANGELOG +357 -0
  419. data/vendor/bundle/ruby/1.9.1/gems/highline-1.6.21/COPYING +340 -0
  420. data/vendor/bundle/ruby/1.9.1/gems/highline-1.6.21/INSTALL +55 -0
  421. data/vendor/bundle/ruby/1.9.1/gems/highline-1.6.21/LICENSE +7 -0
  422. data/vendor/bundle/ruby/1.9.1/gems/highline-1.6.21/README.rdoc +67 -0
  423. data/vendor/bundle/ruby/1.9.1/gems/highline-1.6.21/Rakefile +50 -0
  424. data/vendor/bundle/ruby/1.9.1/gems/highline-1.6.21/TODO +6 -0
  425. data/vendor/bundle/ruby/1.9.1/gems/highline-1.6.21/examples/ansi_colors.rb +38 -0
  426. data/vendor/bundle/ruby/1.9.1/gems/highline-1.6.21/examples/asking_for_arrays.rb +18 -0
  427. data/vendor/bundle/ruby/1.9.1/gems/highline-1.6.21/examples/basic_usage.rb +75 -0
  428. data/vendor/bundle/ruby/1.9.1/gems/highline-1.6.21/examples/color_scheme.rb +32 -0
  429. data/vendor/bundle/ruby/1.9.1/gems/highline-1.6.21/examples/get_character.rb +12 -0
  430. data/vendor/bundle/ruby/1.9.1/gems/highline-1.6.21/examples/limit.rb +12 -0
  431. data/vendor/bundle/ruby/1.9.1/gems/highline-1.6.21/examples/menus.rb +65 -0
  432. data/vendor/bundle/ruby/1.9.1/gems/highline-1.6.21/examples/overwrite.rb +19 -0
  433. data/vendor/bundle/ruby/1.9.1/gems/highline-1.6.21/examples/page_and_wrap.rb +322 -0
  434. data/vendor/bundle/ruby/1.9.1/gems/highline-1.6.21/examples/password.rb +7 -0
  435. data/vendor/bundle/ruby/1.9.1/gems/highline-1.6.21/examples/repeat_entry.rb +21 -0
  436. data/vendor/bundle/ruby/1.9.1/gems/highline-1.6.21/examples/trapping_eof.rb +22 -0
  437. data/vendor/bundle/ruby/1.9.1/gems/highline-1.6.21/examples/using_readline.rb +17 -0
  438. data/vendor/bundle/ruby/1.9.1/gems/highline-1.6.21/highline.gemspec +37 -0
  439. data/vendor/bundle/ruby/1.9.1/gems/highline-1.6.21/lib/highline.rb +1034 -0
  440. data/vendor/bundle/ruby/1.9.1/gems/highline-1.6.21/lib/highline/color_scheme.rb +134 -0
  441. data/vendor/bundle/ruby/1.9.1/gems/highline-1.6.21/lib/highline/compatibility.rb +16 -0
  442. data/vendor/bundle/ruby/1.9.1/gems/highline-1.6.21/lib/highline/import.rb +41 -0
  443. data/vendor/bundle/ruby/1.9.1/gems/highline-1.6.21/lib/highline/menu.rb +381 -0
  444. data/vendor/bundle/ruby/1.9.1/gems/highline-1.6.21/lib/highline/question.rb +481 -0
  445. data/vendor/bundle/ruby/1.9.1/gems/highline-1.6.21/lib/highline/simulate.rb +48 -0
  446. data/vendor/bundle/ruby/1.9.1/gems/highline-1.6.21/lib/highline/string_extensions.rb +111 -0
  447. data/vendor/bundle/ruby/1.9.1/gems/highline-1.6.21/lib/highline/style.rb +181 -0
  448. data/vendor/bundle/ruby/1.9.1/gems/highline-1.6.21/lib/highline/system_extensions.rb +242 -0
  449. data/vendor/bundle/ruby/1.9.1/gems/highline-1.6.21/setup.rb +1360 -0
  450. data/vendor/bundle/ruby/1.9.1/gems/highline-1.6.21/site/highline.css +65 -0
  451. data/vendor/bundle/ruby/1.9.1/gems/highline-1.6.21/site/images/logo.png +0 -0
  452. data/vendor/bundle/ruby/1.9.1/gems/highline-1.6.21/site/index.html +58 -0
  453. data/vendor/bundle/ruby/1.9.1/gems/highline-1.6.21/test/string_methods.rb +32 -0
  454. data/vendor/bundle/ruby/1.9.1/gems/highline-1.6.21/test/tc_color_scheme.rb +96 -0
  455. data/vendor/bundle/ruby/1.9.1/gems/highline-1.6.21/test/tc_highline.rb +1134 -0
  456. data/vendor/bundle/ruby/1.9.1/gems/highline-1.6.21/test/tc_import.rb +52 -0
  457. data/vendor/bundle/ruby/1.9.1/gems/highline-1.6.21/test/tc_menu.rb +439 -0
  458. data/vendor/bundle/ruby/1.9.1/gems/highline-1.6.21/test/tc_string_extension.rb +20 -0
  459. data/vendor/bundle/ruby/1.9.1/gems/highline-1.6.21/test/tc_string_highline.rb +38 -0
  460. data/vendor/bundle/ruby/1.9.1/gems/highline-1.6.21/test/tc_style.rb +567 -0
  461. data/vendor/bundle/ruby/1.9.1/gems/highline-1.6.21/test/ts_all.rb +16 -0
  462. data/vendor/bundle/ruby/1.9.1/gems/httparty-0.13.1/Gemfile +14 -0
  463. data/vendor/bundle/ruby/1.9.1/gems/httparty-0.13.1/Guardfile +16 -0
  464. data/vendor/bundle/ruby/1.9.1/gems/httparty-0.13.1/History +303 -0
  465. data/vendor/bundle/ruby/1.9.1/gems/httparty-0.13.1/MIT-LICENSE +20 -0
  466. data/vendor/bundle/ruby/1.9.1/gems/httparty-0.13.1/README.md +74 -0
  467. data/vendor/bundle/ruby/1.9.1/gems/httparty-0.13.1/Rakefile +12 -0
  468. data/vendor/bundle/ruby/1.9.1/gems/httparty-0.13.1/bin/httparty +117 -0
  469. data/vendor/bundle/ruby/1.9.1/gems/httparty-0.13.1/cucumber.yml +1 -0
  470. data/vendor/bundle/ruby/1.9.1/gems/httparty-0.13.1/examples/aaws.rb +32 -0
  471. data/vendor/bundle/ruby/1.9.1/gems/httparty-0.13.1/examples/basic.rb +28 -0
  472. data/vendor/bundle/ruby/1.9.1/gems/httparty-0.13.1/examples/crack.rb +19 -0
  473. data/vendor/bundle/ruby/1.9.1/gems/httparty-0.13.1/examples/custom_parsers.rb +67 -0
  474. data/vendor/bundle/ruby/1.9.1/gems/httparty-0.13.1/examples/delicious.rb +37 -0
  475. data/vendor/bundle/ruby/1.9.1/gems/httparty-0.13.1/examples/google.rb +16 -0
  476. data/vendor/bundle/ruby/1.9.1/gems/httparty-0.13.1/examples/headers_and_user_agents.rb +6 -0
  477. data/vendor/bundle/ruby/1.9.1/gems/httparty-0.13.1/examples/nokogiri_html_parser.rb +22 -0
  478. data/vendor/bundle/ruby/1.9.1/gems/httparty-0.13.1/examples/rubyurl.rb +14 -0
  479. data/vendor/bundle/ruby/1.9.1/gems/httparty-0.13.1/examples/stackexchange.rb +24 -0
  480. data/vendor/bundle/ruby/1.9.1/gems/httparty-0.13.1/examples/tripit_sign_in.rb +33 -0
  481. data/vendor/bundle/ruby/1.9.1/gems/httparty-0.13.1/examples/twitter.rb +31 -0
  482. data/vendor/bundle/ruby/1.9.1/gems/httparty-0.13.1/examples/whoismyrep.rb +10 -0
  483. data/vendor/bundle/ruby/1.9.1/gems/httparty-0.13.1/features/basic_authentication.feature +20 -0
  484. data/vendor/bundle/ruby/1.9.1/gems/httparty-0.13.1/features/command_line.feature +7 -0
  485. data/vendor/bundle/ruby/1.9.1/gems/httparty-0.13.1/features/deals_with_http_error_codes.feature +26 -0
  486. data/vendor/bundle/ruby/1.9.1/gems/httparty-0.13.1/features/digest_authentication.feature +20 -0
  487. data/vendor/bundle/ruby/1.9.1/gems/httparty-0.13.1/features/handles_compressed_responses.feature +27 -0
  488. data/vendor/bundle/ruby/1.9.1/gems/httparty-0.13.1/features/handles_multiple_formats.feature +57 -0
  489. data/vendor/bundle/ruby/1.9.1/gems/httparty-0.13.1/features/steps/env.rb +22 -0
  490. data/vendor/bundle/ruby/1.9.1/gems/httparty-0.13.1/features/steps/httparty_response_steps.rb +52 -0
  491. data/vendor/bundle/ruby/1.9.1/gems/httparty-0.13.1/features/steps/httparty_steps.rb +43 -0
  492. data/vendor/bundle/ruby/1.9.1/gems/httparty-0.13.1/features/steps/mongrel_helper.rb +94 -0
  493. data/vendor/bundle/ruby/1.9.1/gems/httparty-0.13.1/features/steps/remote_service_steps.rb +74 -0
  494. data/vendor/bundle/ruby/1.9.1/gems/httparty-0.13.1/features/supports_read_timeout_option.feature +13 -0
  495. data/vendor/bundle/ruby/1.9.1/gems/httparty-0.13.1/features/supports_redirection.feature +22 -0
  496. data/vendor/bundle/ruby/1.9.1/gems/httparty-0.13.1/features/supports_timeout_option.feature +13 -0
  497. data/vendor/bundle/ruby/1.9.1/gems/httparty-0.13.1/httparty.gemspec +26 -0
  498. data/vendor/bundle/ruby/1.9.1/gems/httparty-0.13.1/lib/httparty.rb +600 -0
  499. data/vendor/bundle/ruby/1.9.1/gems/httparty-0.13.1/lib/httparty/connection_adapter.rb +187 -0
  500. data/vendor/bundle/ruby/1.9.1/gems/httparty-0.13.1/lib/httparty/cookie_hash.rb +22 -0
  501. data/vendor/bundle/ruby/1.9.1/gems/httparty-0.13.1/lib/httparty/core_extensions.rb +32 -0
  502. data/vendor/bundle/ruby/1.9.1/gems/httparty-0.13.1/lib/httparty/exceptions.rb +29 -0
  503. data/vendor/bundle/ruby/1.9.1/gems/httparty-0.13.1/lib/httparty/hash_conversions.rb +51 -0
  504. data/vendor/bundle/ruby/1.9.1/gems/httparty-0.13.1/lib/httparty/logger/apache_logger.rb +22 -0
  505. data/vendor/bundle/ruby/1.9.1/gems/httparty-0.13.1/lib/httparty/logger/curl_logger.rb +48 -0
  506. data/vendor/bundle/ruby/1.9.1/gems/httparty-0.13.1/lib/httparty/logger/logger.rb +18 -0
  507. data/vendor/bundle/ruby/1.9.1/gems/httparty-0.13.1/lib/httparty/module_inheritable_attributes.rb +56 -0
  508. data/vendor/bundle/ruby/1.9.1/gems/httparty-0.13.1/lib/httparty/net_digest_auth.rb +84 -0
  509. data/vendor/bundle/ruby/1.9.1/gems/httparty-0.13.1/lib/httparty/parser.rb +141 -0
  510. data/vendor/bundle/ruby/1.9.1/gems/httparty-0.13.1/lib/httparty/request.rb +331 -0
  511. data/vendor/bundle/ruby/1.9.1/gems/httparty-0.13.1/lib/httparty/response.rb +72 -0
  512. data/vendor/bundle/ruby/1.9.1/gems/httparty-0.13.1/lib/httparty/response/headers.rb +31 -0
  513. data/vendor/bundle/ruby/1.9.1/gems/httparty-0.13.1/lib/httparty/version.rb +3 -0
  514. data/vendor/bundle/ruby/1.9.1/gems/httparty-0.13.1/script/release +42 -0
  515. data/vendor/bundle/ruby/1.9.1/gems/httparty-0.13.1/spec/fixtures/delicious.xml +23 -0
  516. data/vendor/bundle/ruby/1.9.1/gems/httparty-0.13.1/spec/fixtures/empty.xml +0 -0
  517. data/vendor/bundle/ruby/1.9.1/gems/httparty-0.13.1/spec/fixtures/google.html +3 -0
  518. data/vendor/bundle/ruby/1.9.1/gems/httparty-0.13.1/spec/fixtures/ssl/generate.sh +29 -0
  519. data/vendor/bundle/ruby/1.9.1/gems/httparty-0.13.1/spec/fixtures/ssl/generated/1fe462c2.0 +16 -0
  520. data/vendor/bundle/ruby/1.9.1/gems/httparty-0.13.1/spec/fixtures/ssl/generated/bogushost.crt +13 -0
  521. data/vendor/bundle/ruby/1.9.1/gems/httparty-0.13.1/spec/fixtures/ssl/generated/ca.crt +16 -0
  522. data/vendor/bundle/ruby/1.9.1/gems/httparty-0.13.1/spec/fixtures/ssl/generated/ca.key +15 -0
  523. data/vendor/bundle/ruby/1.9.1/gems/httparty-0.13.1/spec/fixtures/ssl/generated/selfsigned.crt +14 -0
  524. data/vendor/bundle/ruby/1.9.1/gems/httparty-0.13.1/spec/fixtures/ssl/generated/server.crt +13 -0
  525. data/vendor/bundle/ruby/1.9.1/gems/httparty-0.13.1/spec/fixtures/ssl/generated/server.key +15 -0
  526. data/vendor/bundle/ruby/1.9.1/gems/httparty-0.13.1/spec/fixtures/ssl/openssl-exts.cnf +9 -0
  527. data/vendor/bundle/ruby/1.9.1/gems/httparty-0.13.1/spec/fixtures/twitter.csv +2 -0
  528. data/vendor/bundle/ruby/1.9.1/gems/httparty-0.13.1/spec/fixtures/twitter.json +1 -0
  529. data/vendor/bundle/ruby/1.9.1/gems/httparty-0.13.1/spec/fixtures/twitter.xml +403 -0
  530. data/vendor/bundle/ruby/1.9.1/gems/httparty-0.13.1/spec/fixtures/undefined_method_add_node_for_nil.xml +2 -0
  531. data/vendor/bundle/ruby/1.9.1/gems/httparty-0.13.1/spec/httparty/connection_adapter_spec.rb +354 -0
  532. data/vendor/bundle/ruby/1.9.1/gems/httparty-0.13.1/spec/httparty/cookie_hash_spec.rb +83 -0
  533. data/vendor/bundle/ruby/1.9.1/gems/httparty-0.13.1/spec/httparty/exception_spec.rb +23 -0
  534. data/vendor/bundle/ruby/1.9.1/gems/httparty-0.13.1/spec/httparty/logger/apache_logger_spec.rb +26 -0
  535. data/vendor/bundle/ruby/1.9.1/gems/httparty-0.13.1/spec/httparty/logger/curl_logger_spec.rb +18 -0
  536. data/vendor/bundle/ruby/1.9.1/gems/httparty-0.13.1/spec/httparty/logger/logger_spec.rb +22 -0
  537. data/vendor/bundle/ruby/1.9.1/gems/httparty-0.13.1/spec/httparty/net_digest_auth_spec.rb +152 -0
  538. data/vendor/bundle/ruby/1.9.1/gems/httparty-0.13.1/spec/httparty/parser_spec.rb +165 -0
  539. data/vendor/bundle/ruby/1.9.1/gems/httparty-0.13.1/spec/httparty/request_spec.rb +638 -0
  540. data/vendor/bundle/ruby/1.9.1/gems/httparty-0.13.1/spec/httparty/response_spec.rb +221 -0
  541. data/vendor/bundle/ruby/1.9.1/gems/httparty-0.13.1/spec/httparty/ssl_spec.rb +74 -0
  542. data/vendor/bundle/ruby/1.9.1/gems/httparty-0.13.1/spec/httparty_spec.rb +764 -0
  543. data/vendor/bundle/ruby/1.9.1/gems/httparty-0.13.1/spec/spec.opts +2 -0
  544. data/vendor/bundle/ruby/1.9.1/gems/httparty-0.13.1/spec/spec_helper.rb +37 -0
  545. data/vendor/bundle/ruby/1.9.1/gems/httparty-0.13.1/spec/support/ssl_test_helper.rb +47 -0
  546. data/vendor/bundle/ruby/1.9.1/gems/httparty-0.13.1/spec/support/ssl_test_server.rb +80 -0
  547. data/vendor/bundle/ruby/1.9.1/gems/httparty-0.13.1/spec/support/stub_response.rb +43 -0
  548. data/vendor/bundle/ruby/1.9.1/gems/httparty-0.13.1/website/css/common.css +47 -0
  549. data/vendor/bundle/ruby/1.9.1/gems/httparty-0.13.1/website/index.html +73 -0
  550. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/CHANGES +284 -0
  551. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/COPYING +58 -0
  552. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/COPYING-json-jruby +57 -0
  553. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/GPL +340 -0
  554. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/Gemfile +11 -0
  555. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/README-json-jruby.markdown +33 -0
  556. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/README.rdoc +358 -0
  557. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/Rakefile +412 -0
  558. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/TODO +1 -0
  559. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/VERSION +1 -0
  560. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/data/example.json +1 -0
  561. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/data/index.html +38 -0
  562. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/data/prototype.js +4184 -0
  563. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/ext/json/ext/fbuffer/fbuffer.h +181 -0
  564. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/ext/json/ext/generator/Makefile +221 -0
  565. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/ext/json/ext/generator/depend +1 -0
  566. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/ext/json/ext/generator/extconf.rb +14 -0
  567. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/ext/json/ext/generator/generator.bundle +0 -0
  568. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/ext/json/ext/generator/generator.c +1435 -0
  569. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/ext/json/ext/generator/generator.h +148 -0
  570. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/ext/json/ext/generator/generator.o +0 -0
  571. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/ext/json/ext/parser/Makefile +221 -0
  572. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/ext/json/ext/parser/depend +1 -0
  573. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/ext/json/ext/parser/extconf.rb +13 -0
  574. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/ext/json/ext/parser/parser.bundle +0 -0
  575. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/ext/json/ext/parser/parser.c +2204 -0
  576. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/ext/json/ext/parser/parser.h +77 -0
  577. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/ext/json/ext/parser/parser.o +0 -0
  578. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/ext/json/ext/parser/parser.rl +927 -0
  579. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/install.rb +23 -0
  580. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/java/src/json/ext/ByteListTranscoder.java +167 -0
  581. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/java/src/json/ext/Generator.java +444 -0
  582. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/java/src/json/ext/GeneratorMethods.java +232 -0
  583. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/java/src/json/ext/GeneratorService.java +43 -0
  584. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/java/src/json/ext/GeneratorState.java +543 -0
  585. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/java/src/json/ext/OptionsReader.java +114 -0
  586. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/java/src/json/ext/Parser.java +2644 -0
  587. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/java/src/json/ext/Parser.rl +968 -0
  588. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/java/src/json/ext/ParserService.java +35 -0
  589. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/java/src/json/ext/RuntimeInfo.java +121 -0
  590. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/java/src/json/ext/StringDecoder.java +167 -0
  591. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/java/src/json/ext/StringEncoder.java +106 -0
  592. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/java/src/json/ext/Utils.java +89 -0
  593. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/json-java.gemspec +23 -0
  594. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/json.gemspec +38 -0
  595. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/json_pure.gemspec +40 -0
  596. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/lib/json.rb +62 -0
  597. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/lib/json/add/bigdecimal.rb +28 -0
  598. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/lib/json/add/complex.rb +22 -0
  599. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/lib/json/add/core.rb +11 -0
  600. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/lib/json/add/date.rb +34 -0
  601. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/lib/json/add/date_time.rb +50 -0
  602. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/lib/json/add/exception.rb +31 -0
  603. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/lib/json/add/ostruct.rb +31 -0
  604. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/lib/json/add/range.rb +29 -0
  605. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/lib/json/add/rational.rb +22 -0
  606. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/lib/json/add/regexp.rb +30 -0
  607. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/lib/json/add/struct.rb +30 -0
  608. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/lib/json/add/symbol.rb +25 -0
  609. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/lib/json/add/time.rb +38 -0
  610. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/lib/json/common.rb +484 -0
  611. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/lib/json/ext.rb +21 -0
  612. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/lib/json/ext/generator.bundle +0 -0
  613. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/lib/json/ext/parser.bundle +0 -0
  614. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/lib/json/generic_object.rb +70 -0
  615. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/lib/json/pure.rb +21 -0
  616. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/lib/json/pure/generator.rb +522 -0
  617. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/lib/json/pure/parser.rb +359 -0
  618. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/lib/json/version.rb +8 -0
  619. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/tests/fixtures/fail1.json +1 -0
  620. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/tests/fixtures/fail10.json +1 -0
  621. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/tests/fixtures/fail11.json +1 -0
  622. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/tests/fixtures/fail12.json +1 -0
  623. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/tests/fixtures/fail13.json +1 -0
  624. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/tests/fixtures/fail14.json +1 -0
  625. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/tests/fixtures/fail18.json +1 -0
  626. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/tests/fixtures/fail19.json +1 -0
  627. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/tests/fixtures/fail2.json +1 -0
  628. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/tests/fixtures/fail20.json +1 -0
  629. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/tests/fixtures/fail21.json +1 -0
  630. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/tests/fixtures/fail22.json +1 -0
  631. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/tests/fixtures/fail23.json +1 -0
  632. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/tests/fixtures/fail24.json +1 -0
  633. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/tests/fixtures/fail25.json +1 -0
  634. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/tests/fixtures/fail27.json +2 -0
  635. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/tests/fixtures/fail28.json +2 -0
  636. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/tests/fixtures/fail3.json +1 -0
  637. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/tests/fixtures/fail4.json +1 -0
  638. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/tests/fixtures/fail5.json +1 -0
  639. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/tests/fixtures/fail6.json +1 -0
  640. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/tests/fixtures/fail7.json +1 -0
  641. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/tests/fixtures/fail8.json +1 -0
  642. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/tests/fixtures/fail9.json +1 -0
  643. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/tests/fixtures/pass1.json +56 -0
  644. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/tests/fixtures/pass15.json +1 -0
  645. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/tests/fixtures/pass16.json +1 -0
  646. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/tests/fixtures/pass17.json +1 -0
  647. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/tests/fixtures/pass2.json +1 -0
  648. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/tests/fixtures/pass26.json +1 -0
  649. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/tests/fixtures/pass3.json +6 -0
  650. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/tests/setup_variant.rb +11 -0
  651. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/tests/test_json.rb +545 -0
  652. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/tests/test_json_addition.rb +196 -0
  653. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/tests/test_json_encoding.rb +65 -0
  654. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/tests/test_json_fixtures.rb +35 -0
  655. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/tests/test_json_generate.rb +322 -0
  656. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/tests/test_json_generic_object.rb +75 -0
  657. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/tests/test_json_string_matching.rb +39 -0
  658. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/tests/test_json_unicode.rb +72 -0
  659. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/tools/fuzz.rb +139 -0
  660. data/vendor/bundle/ruby/1.9.1/gems/json-1.8.1/tools/server.rb +62 -0
  661. data/vendor/bundle/ruby/1.9.1/gems/main-6.0.0/LICENSE +1 -0
  662. data/vendor/bundle/ruby/1.9.1/gems/main-6.0.0/README +1177 -0
  663. data/vendor/bundle/ruby/1.9.1/gems/main-6.0.0/README.erb +881 -0
  664. data/vendor/bundle/ruby/1.9.1/gems/main-6.0.0/Rakefile +394 -0
  665. data/vendor/bundle/ruby/1.9.1/gems/main-6.0.0/TODO +23 -0
  666. data/vendor/bundle/ruby/1.9.1/gems/main-6.0.0/a.rb +3 -0
  667. data/vendor/bundle/ruby/1.9.1/gems/main-6.0.0/lib/main.rb +93 -0
  668. data/vendor/bundle/ruby/1.9.1/gems/main-6.0.0/lib/main/cast.rb +163 -0
  669. data/vendor/bundle/ruby/1.9.1/gems/main-6.0.0/lib/main/dsl.rb +77 -0
  670. data/vendor/bundle/ruby/1.9.1/gems/main-6.0.0/lib/main/factories.rb +28 -0
  671. data/vendor/bundle/ruby/1.9.1/gems/main-6.0.0/lib/main/getoptlong.rb +470 -0
  672. data/vendor/bundle/ruby/1.9.1/gems/main-6.0.0/lib/main/logger.rb +51 -0
  673. data/vendor/bundle/ruby/1.9.1/gems/main-6.0.0/lib/main/mode.rb +46 -0
  674. data/vendor/bundle/ruby/1.9.1/gems/main-6.0.0/lib/main/parameter.rb +735 -0
  675. data/vendor/bundle/ruby/1.9.1/gems/main-6.0.0/lib/main/program.rb +6 -0
  676. data/vendor/bundle/ruby/1.9.1/gems/main-6.0.0/lib/main/program/class_methods.rb +381 -0
  677. data/vendor/bundle/ruby/1.9.1/gems/main-6.0.0/lib/main/program/instance_methods.rb +303 -0
  678. data/vendor/bundle/ruby/1.9.1/gems/main-6.0.0/lib/main/softspoken.rb +12 -0
  679. data/vendor/bundle/ruby/1.9.1/gems/main-6.0.0/lib/main/stdext.rb +36 -0
  680. data/vendor/bundle/ruby/1.9.1/gems/main-6.0.0/lib/main/test.rb +89 -0
  681. data/vendor/bundle/ruby/1.9.1/gems/main-6.0.0/lib/main/usage.rb +212 -0
  682. data/vendor/bundle/ruby/1.9.1/gems/main-6.0.0/lib/main/util.rb +109 -0
  683. data/vendor/bundle/ruby/1.9.1/gems/main-6.0.0/main.gemspec +74 -0
  684. data/vendor/bundle/ruby/1.9.1/gems/main-6.0.0/samples/a.rb +17 -0
  685. data/vendor/bundle/ruby/1.9.1/gems/main-6.0.0/samples/b.rb +17 -0
  686. data/vendor/bundle/ruby/1.9.1/gems/main-6.0.0/samples/c.rb +21 -0
  687. data/vendor/bundle/ruby/1.9.1/gems/main-6.0.0/samples/d.rb +26 -0
  688. data/vendor/bundle/ruby/1.9.1/gems/main-6.0.0/samples/e.rb +27 -0
  689. data/vendor/bundle/ruby/1.9.1/gems/main-6.0.0/samples/f.rb +29 -0
  690. data/vendor/bundle/ruby/1.9.1/gems/main-6.0.0/samples/g.rb +10 -0
  691. data/vendor/bundle/ruby/1.9.1/gems/main-6.0.0/samples/h.rb +36 -0
  692. data/vendor/bundle/ruby/1.9.1/gems/main-6.0.0/samples/j.rb +31 -0
  693. data/vendor/bundle/ruby/1.9.1/gems/main-6.0.0/test/main_test.rb +954 -0
  694. data/vendor/bundle/ruby/1.9.1/gems/main-6.1.0/LICENSE +1 -0
  695. data/vendor/bundle/ruby/1.9.1/gems/main-6.1.0/README +1177 -0
  696. data/vendor/bundle/ruby/1.9.1/gems/main-6.1.0/README.erb +881 -0
  697. data/vendor/bundle/ruby/1.9.1/gems/main-6.1.0/Rakefile +394 -0
  698. data/vendor/bundle/ruby/1.9.1/gems/main-6.1.0/TODO +23 -0
  699. data/vendor/bundle/ruby/1.9.1/gems/main-6.1.0/a.rb +28 -0
  700. data/vendor/bundle/ruby/1.9.1/gems/main-6.1.0/lib/main.rb +94 -0
  701. data/vendor/bundle/ruby/1.9.1/gems/main-6.1.0/lib/main/cast.rb +163 -0
  702. data/vendor/bundle/ruby/1.9.1/gems/main-6.1.0/lib/main/daemon.rb +525 -0
  703. data/vendor/bundle/ruby/1.9.1/gems/main-6.1.0/lib/main/dsl.rb +77 -0
  704. data/vendor/bundle/ruby/1.9.1/gems/main-6.1.0/lib/main/factories.rb +28 -0
  705. data/vendor/bundle/ruby/1.9.1/gems/main-6.1.0/lib/main/getoptlong.rb +470 -0
  706. data/vendor/bundle/ruby/1.9.1/gems/main-6.1.0/lib/main/logger.rb +51 -0
  707. data/vendor/bundle/ruby/1.9.1/gems/main-6.1.0/lib/main/mode.rb +46 -0
  708. data/vendor/bundle/ruby/1.9.1/gems/main-6.1.0/lib/main/parameter.rb +735 -0
  709. data/vendor/bundle/ruby/1.9.1/gems/main-6.1.0/lib/main/program.rb +6 -0
  710. data/vendor/bundle/ruby/1.9.1/gems/main-6.1.0/lib/main/program/class_methods.rb +392 -0
  711. data/vendor/bundle/ruby/1.9.1/gems/main-6.1.0/lib/main/program/instance_methods.rb +308 -0
  712. data/vendor/bundle/ruby/1.9.1/gems/main-6.1.0/lib/main/softspoken.rb +12 -0
  713. data/vendor/bundle/ruby/1.9.1/gems/main-6.1.0/lib/main/stdext.rb +36 -0
  714. data/vendor/bundle/ruby/1.9.1/gems/main-6.1.0/lib/main/test.rb +89 -0
  715. data/vendor/bundle/ruby/1.9.1/gems/main-6.1.0/lib/main/usage.rb +212 -0
  716. data/vendor/bundle/ruby/1.9.1/gems/main-6.1.0/lib/main/util.rb +109 -0
  717. data/vendor/bundle/ruby/1.9.1/gems/main-6.1.0/main.gemspec +75 -0
  718. data/vendor/bundle/ruby/1.9.1/gems/main-6.1.0/samples/a.rb +17 -0
  719. data/vendor/bundle/ruby/1.9.1/gems/main-6.1.0/samples/b.rb +17 -0
  720. data/vendor/bundle/ruby/1.9.1/gems/main-6.1.0/samples/c.rb +21 -0
  721. data/vendor/bundle/ruby/1.9.1/gems/main-6.1.0/samples/d.rb +26 -0
  722. data/vendor/bundle/ruby/1.9.1/gems/main-6.1.0/samples/e.rb +27 -0
  723. data/vendor/bundle/ruby/1.9.1/gems/main-6.1.0/samples/f.rb +29 -0
  724. data/vendor/bundle/ruby/1.9.1/gems/main-6.1.0/samples/g.rb +10 -0
  725. data/vendor/bundle/ruby/1.9.1/gems/main-6.1.0/samples/h.rb +36 -0
  726. data/vendor/bundle/ruby/1.9.1/gems/main-6.1.0/samples/j.rb +31 -0
  727. data/vendor/bundle/ruby/1.9.1/gems/main-6.1.0/test/main_test.rb +954 -0
  728. data/vendor/bundle/ruby/1.9.1/gems/map-6.5.5/LICENSE +1 -0
  729. data/vendor/bundle/ruby/1.9.1/gems/map-6.5.5/README +145 -0
  730. data/vendor/bundle/ruby/1.9.1/gems/map-6.5.5/Rakefile +394 -0
  731. data/vendor/bundle/ruby/1.9.1/gems/map-6.5.5/a.rb +22 -0
  732. data/vendor/bundle/ruby/1.9.1/gems/map-6.5.5/lib/map.rb +1190 -0
  733. data/vendor/bundle/ruby/1.9.1/gems/map-6.5.5/lib/map/integrations/active_record.rb +140 -0
  734. data/vendor/bundle/ruby/1.9.1/gems/map-6.5.5/lib/map/options.rb +188 -0
  735. data/vendor/bundle/ruby/1.9.1/gems/map-6.5.5/lib/map/params.rb +79 -0
  736. data/vendor/bundle/ruby/1.9.1/gems/map-6.5.5/lib/map/struct.rb +52 -0
  737. data/vendor/bundle/ruby/1.9.1/gems/map-6.5.5/map.gemspec +46 -0
  738. data/vendor/bundle/ruby/1.9.1/gems/map-6.5.5/test/leak.rb +61 -0
  739. data/vendor/bundle/ruby/1.9.1/gems/map-6.5.5/test/lib/testing.rb +74 -0
  740. data/vendor/bundle/ruby/1.9.1/gems/map-6.5.5/test/map_test.rb +802 -0
  741. data/vendor/bundle/ruby/1.9.1/gems/method_source-0.8.2/Gemfile +2 -0
  742. data/vendor/bundle/ruby/1.9.1/gems/method_source-0.8.2/LICENSE +25 -0
  743. data/vendor/bundle/ruby/1.9.1/gems/method_source-0.8.2/README.markdown +91 -0
  744. data/vendor/bundle/ruby/1.9.1/gems/method_source-0.8.2/Rakefile +79 -0
  745. data/vendor/bundle/ruby/1.9.1/gems/method_source-0.8.2/lib/method_source.rb +141 -0
  746. data/vendor/bundle/ruby/1.9.1/gems/method_source-0.8.2/lib/method_source/code_helpers.rb +154 -0
  747. data/vendor/bundle/ruby/1.9.1/gems/method_source-0.8.2/lib/method_source/source_location.rb +138 -0
  748. data/vendor/bundle/ruby/1.9.1/gems/method_source-0.8.2/lib/method_source/version.rb +3 -0
  749. data/vendor/bundle/ruby/1.9.1/gems/method_source-0.8.2/method_source.gemspec +33 -0
  750. data/vendor/bundle/ruby/1.9.1/gems/method_source-0.8.2/test/test.rb +138 -0
  751. data/vendor/bundle/ruby/1.9.1/gems/method_source-0.8.2/test/test_code_helpers.rb +41 -0
  752. data/vendor/bundle/ruby/1.9.1/gems/method_source-0.8.2/test/test_helper.rb +98 -0
  753. data/vendor/bundle/ruby/1.9.1/gems/multi_json-1.10.1/CHANGELOG.md +220 -0
  754. data/vendor/bundle/ruby/1.9.1/gems/multi_json-1.10.1/CONTRIBUTING.md +46 -0
  755. data/vendor/bundle/ruby/1.9.1/gems/multi_json-1.10.1/Gemfile +29 -0
  756. data/vendor/bundle/ruby/1.9.1/gems/multi_json-1.10.1/LICENSE.md +20 -0
  757. data/vendor/bundle/ruby/1.9.1/gems/multi_json-1.10.1/README.md +119 -0
  758. data/vendor/bundle/ruby/1.9.1/gems/multi_json-1.10.1/Rakefile +25 -0
  759. data/vendor/bundle/ruby/1.9.1/gems/multi_json-1.10.1/lib/multi_json.rb +158 -0
  760. data/vendor/bundle/ruby/1.9.1/gems/multi_json-1.10.1/lib/multi_json/adapter.rb +37 -0
  761. data/vendor/bundle/ruby/1.9.1/gems/multi_json-1.10.1/lib/multi_json/adapter_error.rb +15 -0
  762. data/vendor/bundle/ruby/1.9.1/gems/multi_json-1.10.1/lib/multi_json/adapters/gson.rb +21 -0
  763. data/vendor/bundle/ruby/1.9.1/gems/multi_json-1.10.1/lib/multi_json/adapters/jr_jackson.rb +19 -0
  764. data/vendor/bundle/ruby/1.9.1/gems/multi_json-1.10.1/lib/multi_json/adapters/json_common.rb +25 -0
  765. data/vendor/bundle/ruby/1.9.1/gems/multi_json-1.10.1/lib/multi_json/adapters/json_gem.rb +11 -0
  766. data/vendor/bundle/ruby/1.9.1/gems/multi_json-1.10.1/lib/multi_json/adapters/json_pure.rb +11 -0
  767. data/vendor/bundle/ruby/1.9.1/gems/multi_json-1.10.1/lib/multi_json/adapters/nsjsonserialization.rb +34 -0
  768. data/vendor/bundle/ruby/1.9.1/gems/multi_json-1.10.1/lib/multi_json/adapters/oj.rb +25 -0
  769. data/vendor/bundle/ruby/1.9.1/gems/multi_json-1.10.1/lib/multi_json/adapters/ok_json.rb +24 -0
  770. data/vendor/bundle/ruby/1.9.1/gems/multi_json-1.10.1/lib/multi_json/adapters/yajl.rb +19 -0
  771. data/vendor/bundle/ruby/1.9.1/gems/multi_json-1.10.1/lib/multi_json/convertible_hash_keys.rb +43 -0
  772. data/vendor/bundle/ruby/1.9.1/gems/multi_json-1.10.1/lib/multi_json/options.rb +38 -0
  773. data/vendor/bundle/ruby/1.9.1/gems/multi_json-1.10.1/lib/multi_json/parse_error.rb +17 -0
  774. data/vendor/bundle/ruby/1.9.1/gems/multi_json-1.10.1/lib/multi_json/vendor/okjson.rb +606 -0
  775. data/vendor/bundle/ruby/1.9.1/gems/multi_json-1.10.1/lib/multi_json/version.rb +20 -0
  776. data/vendor/bundle/ruby/1.9.1/gems/multi_json-1.10.1/multi_json.gemspec +22 -0
  777. data/vendor/bundle/ruby/1.9.1/gems/multi_json-1.10.1/spec/gson_adapter_spec.rb +10 -0
  778. data/vendor/bundle/ruby/1.9.1/gems/multi_json-1.10.1/spec/jr_jackson_adapter_spec.rb +10 -0
  779. data/vendor/bundle/ruby/1.9.1/gems/multi_json-1.10.1/spec/json_gem_adapter_spec.rb +9 -0
  780. data/vendor/bundle/ruby/1.9.1/gems/multi_json-1.10.1/spec/json_pure_adapter_spec.rb +9 -0
  781. data/vendor/bundle/ruby/1.9.1/gems/multi_json-1.10.1/spec/multi_json_spec.rb +200 -0
  782. data/vendor/bundle/ruby/1.9.1/gems/multi_json-1.10.1/spec/nsjsonserialization_adapter_spec.rb +10 -0
  783. data/vendor/bundle/ruby/1.9.1/gems/multi_json-1.10.1/spec/oj_adapter_spec.rb +20 -0
  784. data/vendor/bundle/ruby/1.9.1/gems/multi_json-1.10.1/spec/ok_json_adapter_spec.rb +7 -0
  785. data/vendor/bundle/ruby/1.9.1/gems/multi_json-1.10.1/spec/shared/adapter.rb +236 -0
  786. data/vendor/bundle/ruby/1.9.1/gems/multi_json-1.10.1/spec/shared/json_common_adapter.rb +30 -0
  787. data/vendor/bundle/ruby/1.9.1/gems/multi_json-1.10.1/spec/shared/options.rb +119 -0
  788. data/vendor/bundle/ruby/1.9.1/gems/multi_json-1.10.1/spec/spec_helper.rb +77 -0
  789. data/vendor/bundle/ruby/1.9.1/gems/multi_json-1.10.1/spec/yajl_adapter_spec.rb +10 -0
  790. data/vendor/bundle/ruby/1.9.1/gems/multi_xml-0.5.5/CHANGELOG.md +93 -0
  791. data/vendor/bundle/ruby/1.9.1/gems/multi_xml-0.5.5/CONTRIBUTING.md +49 -0
  792. data/vendor/bundle/ruby/1.9.1/gems/multi_xml-0.5.5/LICENSE.md +20 -0
  793. data/vendor/bundle/ruby/1.9.1/gems/multi_xml-0.5.5/README.md +97 -0
  794. data/vendor/bundle/ruby/1.9.1/gems/multi_xml-0.5.5/Rakefile +21 -0
  795. data/vendor/bundle/ruby/1.9.1/gems/multi_xml-0.5.5/lib/multi_xml.rb +296 -0
  796. data/vendor/bundle/ruby/1.9.1/gems/multi_xml-0.5.5/lib/multi_xml/parsers/libxml.rb +30 -0
  797. data/vendor/bundle/ruby/1.9.1/gems/multi_xml-0.5.5/lib/multi_xml/parsers/libxml2_parser.rb +74 -0
  798. data/vendor/bundle/ruby/1.9.1/gems/multi_xml-0.5.5/lib/multi_xml/parsers/nokogiri.rb +32 -0
  799. data/vendor/bundle/ruby/1.9.1/gems/multi_xml-0.5.5/lib/multi_xml/parsers/ox.rb +97 -0
  800. data/vendor/bundle/ruby/1.9.1/gems/multi_xml-0.5.5/lib/multi_xml/parsers/rexml.rb +113 -0
  801. data/vendor/bundle/ruby/1.9.1/gems/multi_xml-0.5.5/lib/multi_xml/version.rb +3 -0
  802. data/vendor/bundle/ruby/1.9.1/gems/multi_xml-0.5.5/multi_xml.gemspec +24 -0
  803. data/vendor/bundle/ruby/1.9.1/gems/multi_xml-0.5.5/spec/helper.rb +17 -0
  804. data/vendor/bundle/ruby/1.9.1/gems/multi_xml-0.5.5/spec/multi_xml_spec.rb +43 -0
  805. data/vendor/bundle/ruby/1.9.1/gems/multi_xml-0.5.5/spec/parser_shared_example.rb +694 -0
  806. data/vendor/bundle/ruby/1.9.1/gems/multi_xml-0.5.5/spec/speed.rb +63 -0
  807. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/CHANGELOG +534 -0
  808. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/CONTRIBUTORS +55 -0
  809. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/Gemfile +12 -0
  810. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/LICENSE +25 -0
  811. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/README.markdown +400 -0
  812. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/Rakefile +140 -0
  813. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/TODO +117 -0
  814. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/bin/pry +16 -0
  815. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/lib/pry.rb +274 -0
  816. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/lib/pry/cli.rb +202 -0
  817. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/lib/pry/code.rb +385 -0
  818. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/lib/pry/code/code_range.rb +70 -0
  819. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/lib/pry/code/loc.rb +92 -0
  820. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/lib/pry/code_object.rb +153 -0
  821. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/lib/pry/command.rb +689 -0
  822. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/lib/pry/command_set.rb +400 -0
  823. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/lib/pry/commands.rb +6 -0
  824. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/lib/pry/commands/amend_line.rb +99 -0
  825. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/lib/pry/commands/bang.rb +20 -0
  826. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/lib/pry/commands/bang_pry.rb +17 -0
  827. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/lib/pry/commands/cat.rb +53 -0
  828. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/lib/pry/commands/cat/abstract_formatter.rb +27 -0
  829. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/lib/pry/commands/cat/exception_formatter.rb +78 -0
  830. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/lib/pry/commands/cat/file_formatter.rb +84 -0
  831. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/lib/pry/commands/cat/input_expression_formatter.rb +43 -0
  832. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/lib/pry/commands/cd.rb +30 -0
  833. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/lib/pry/commands/code_collector.rb +165 -0
  834. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/lib/pry/commands/disable_pry.rb +27 -0
  835. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/lib/pry/commands/disabled_commands.rb +2 -0
  836. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/lib/pry/commands/easter_eggs.rb +112 -0
  837. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/lib/pry/commands/edit.rb +207 -0
  838. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/lib/pry/commands/edit/exception_patcher.rb +25 -0
  839. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/lib/pry/commands/edit/file_and_line_locator.rb +38 -0
  840. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/lib/pry/commands/edit/method_patcher.rb +122 -0
  841. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/lib/pry/commands/exit.rb +42 -0
  842. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/lib/pry/commands/exit_all.rb +29 -0
  843. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/lib/pry/commands/exit_program.rb +24 -0
  844. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/lib/pry/commands/find_method.rb +199 -0
  845. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/lib/pry/commands/fix_indent.rb +19 -0
  846. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/lib/pry/commands/gem_cd.rb +26 -0
  847. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/lib/pry/commands/gem_install.rb +29 -0
  848. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/lib/pry/commands/gem_list.rb +33 -0
  849. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/lib/pry/commands/gem_open.rb +29 -0
  850. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/lib/pry/commands/gist.rb +102 -0
  851. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/lib/pry/commands/help.rb +164 -0
  852. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/lib/pry/commands/hist.rb +161 -0
  853. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/lib/pry/commands/import_set.rb +22 -0
  854. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/lib/pry/commands/install_command.rb +51 -0
  855. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/lib/pry/commands/jump_to.rb +29 -0
  856. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/lib/pry/commands/ls.rb +338 -0
  857. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/lib/pry/commands/nesting.rb +25 -0
  858. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/lib/pry/commands/play.rb +69 -0
  859. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/lib/pry/commands/pry_backtrace.rb +26 -0
  860. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/lib/pry/commands/pry_version.rb +17 -0
  861. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/lib/pry/commands/raise_up.rb +32 -0
  862. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/lib/pry/commands/reload_code.rb +65 -0
  863. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/lib/pry/commands/reset.rb +18 -0
  864. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/lib/pry/commands/ri.rb +56 -0
  865. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/lib/pry/commands/save_file.rb +61 -0
  866. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/lib/pry/commands/shell_command.rb +43 -0
  867. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/lib/pry/commands/shell_mode.rb +27 -0
  868. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/lib/pry/commands/show_doc.rb +78 -0
  869. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/lib/pry/commands/show_info.rb +200 -0
  870. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/lib/pry/commands/show_input.rb +17 -0
  871. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/lib/pry/commands/show_source.rb +38 -0
  872. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/lib/pry/commands/simple_prompt.rb +22 -0
  873. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/lib/pry/commands/stat.rb +40 -0
  874. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/lib/pry/commands/switch_to.rb +23 -0
  875. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/lib/pry/commands/toggle_color.rb +20 -0
  876. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/lib/pry/commands/whereami.rb +182 -0
  877. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/lib/pry/commands/wtf.rb +57 -0
  878. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/lib/pry/completion.rb +321 -0
  879. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/lib/pry/config.rb +258 -0
  880. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/lib/pry/core_extensions.rb +121 -0
  881. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/lib/pry/custom_completions.rb +6 -0
  882. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/lib/pry/editor.rb +129 -0
  883. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/lib/pry/helpers.rb +5 -0
  884. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/lib/pry/helpers/base_helpers.rb +200 -0
  885. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/lib/pry/helpers/command_helpers.rb +154 -0
  886. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/lib/pry/helpers/documentation_helpers.rb +76 -0
  887. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/lib/pry/helpers/options_helpers.rb +27 -0
  888. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/lib/pry/helpers/table.rb +109 -0
  889. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/lib/pry/helpers/text.rb +108 -0
  890. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/lib/pry/history.rb +124 -0
  891. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/lib/pry/history_array.rb +116 -0
  892. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/lib/pry/hooks.rb +250 -0
  893. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/lib/pry/indent.rb +406 -0
  894. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/lib/pry/method.rb +551 -0
  895. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/lib/pry/method/disowned.rb +53 -0
  896. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/lib/pry/method/weird_method_locator.rb +186 -0
  897. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/lib/pry/module_candidate.rb +146 -0
  898. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/lib/pry/pager.rb +90 -0
  899. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/lib/pry/plugins.rb +103 -0
  900. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/lib/pry/pry_class.rb +456 -0
  901. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/lib/pry/pry_instance.rb +765 -0
  902. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/lib/pry/rbx_method.rb +13 -0
  903. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/lib/pry/rbx_path.rb +22 -0
  904. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/lib/pry/repl_file_loader.rb +80 -0
  905. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/lib/pry/rubygem.rb +74 -0
  906. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/lib/pry/terminal.rb +78 -0
  907. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/lib/pry/test/helper.rb +185 -0
  908. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/lib/pry/version.rb +3 -0
  909. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/lib/pry/wrapped_module.rb +387 -0
  910. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/man/pry.1 +195 -0
  911. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/man/pry.1.html +204 -0
  912. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/man/pry.1.ronn +141 -0
  913. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/pry.gemspec +29 -0
  914. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/spec/Procfile +3 -0
  915. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/spec/cli_spec.rb +78 -0
  916. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/spec/code_object_spec.rb +277 -0
  917. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/spec/code_spec.rb +219 -0
  918. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/spec/command_helpers_spec.rb +29 -0
  919. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/spec/command_integration_spec.rb +644 -0
  920. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/spec/command_set_spec.rb +627 -0
  921. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/spec/command_spec.rb +821 -0
  922. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/spec/commands/amend_line_spec.rb +247 -0
  923. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/spec/commands/bang_spec.rb +19 -0
  924. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/spec/commands/cat_spec.rb +164 -0
  925. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/spec/commands/cd_spec.rb +250 -0
  926. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/spec/commands/disable_pry_spec.rb +25 -0
  927. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/spec/commands/edit_spec.rb +727 -0
  928. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/spec/commands/exit_all_spec.rb +34 -0
  929. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/spec/commands/exit_program_spec.rb +19 -0
  930. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/spec/commands/exit_spec.rb +34 -0
  931. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/spec/commands/find_method_spec.rb +70 -0
  932. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/spec/commands/gem_list_spec.rb +26 -0
  933. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/spec/commands/gist_spec.rb +79 -0
  934. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/spec/commands/help_spec.rb +56 -0
  935. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/spec/commands/hist_spec.rb +181 -0
  936. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/spec/commands/jump_to_spec.rb +15 -0
  937. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/spec/commands/ls_spec.rb +181 -0
  938. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/spec/commands/play_spec.rb +140 -0
  939. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/spec/commands/raise_up_spec.rb +56 -0
  940. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/spec/commands/save_file_spec.rb +177 -0
  941. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/spec/commands/show_doc_spec.rb +510 -0
  942. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/spec/commands/show_input_spec.rb +17 -0
  943. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/spec/commands/show_source_spec.rb +782 -0
  944. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/spec/commands/whereami_spec.rb +203 -0
  945. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/spec/completion_spec.rb +241 -0
  946. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/spec/control_d_handler_spec.rb +58 -0
  947. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/spec/documentation_helper_spec.rb +73 -0
  948. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/spec/editor_spec.rb +79 -0
  949. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/spec/exception_whitelist_spec.rb +21 -0
  950. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/spec/fixtures/candidate_helper1.rb +11 -0
  951. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/spec/fixtures/candidate_helper2.rb +8 -0
  952. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/spec/fixtures/example.erb +5 -0
  953. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/spec/fixtures/example_nesting.rb +33 -0
  954. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/spec/fixtures/show_source_doc_examples.rb +15 -0
  955. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/spec/fixtures/testrc +2 -0
  956. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/spec/fixtures/testrcbad +2 -0
  957. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/spec/fixtures/whereami_helper.rb +6 -0
  958. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/spec/helper.rb +34 -0
  959. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/spec/helpers/bacon.rb +86 -0
  960. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/spec/helpers/mock_pry.rb +43 -0
  961. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/spec/helpers/table_spec.rb +105 -0
  962. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/spec/history_array_spec.rb +67 -0
  963. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/spec/hooks_spec.rb +522 -0
  964. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/spec/indent_spec.rb +301 -0
  965. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/spec/input_stack_spec.rb +90 -0
  966. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/spec/method_spec.rb +482 -0
  967. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/spec/prompt_spec.rb +60 -0
  968. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/spec/pry_defaults_spec.rb +419 -0
  969. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/spec/pry_history_spec.rb +99 -0
  970. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/spec/pry_output_spec.rb +95 -0
  971. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/spec/pry_spec.rb +515 -0
  972. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/spec/run_command_spec.rb +25 -0
  973. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/spec/sticky_locals_spec.rb +157 -0
  974. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/spec/syntax_checking_spec.rb +81 -0
  975. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/spec/wrapped_module_spec.rb +261 -0
  976. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/wiki/Customizing-pry.md +397 -0
  977. data/vendor/bundle/ruby/1.9.1/gems/pry-0.9.12.6/wiki/Home.md +4 -0
  978. data/vendor/bundle/ruby/1.9.1/gems/sekrets-1.7.0/README +144 -0
  979. data/vendor/bundle/ruby/1.9.1/gems/sekrets-1.7.0/Rakefile +390 -0
  980. data/vendor/bundle/ruby/1.9.1/gems/sekrets-1.7.0/bin/sekrets +372 -0
  981. data/vendor/bundle/ruby/1.9.1/gems/sekrets-1.7.0/lib/sekrets.rb +511 -0
  982. data/vendor/bundle/ruby/1.9.1/gems/sekrets-1.7.0/lib/sekrets/capistrano.rb +37 -0
  983. data/vendor/bundle/ruby/1.9.1/gems/sekrets-1.7.0/sekrets.gemspec +50 -0
  984. data/vendor/bundle/ruby/1.9.1/gems/sekrets-1.7.0/test/lib/testing.rb +75 -0
  985. data/vendor/bundle/ruby/1.9.1/gems/sekrets-1.7.0/test/sekrets_test.rb +167 -0
  986. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/CHANGELOG +5790 -0
  987. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/MIT-LICENSE +19 -0
  988. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/README.rdoc +815 -0
  989. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/Rakefile +186 -0
  990. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/bin/sequel +244 -0
  991. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/active_record.rdoc +912 -0
  992. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/advanced_associations.rdoc +818 -0
  993. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/association_basics.rdoc +1763 -0
  994. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/bin_sequel.rdoc +144 -0
  995. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/cheat_sheet.rdoc +220 -0
  996. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/code_order.rdoc +96 -0
  997. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/core_extensions.rdoc +364 -0
  998. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/dataset_basics.rdoc +105 -0
  999. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/dataset_filtering.rdoc +191 -0
  1000. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/extensions.rdoc +84 -0
  1001. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/mass_assignment.rdoc +55 -0
  1002. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/migration.rdoc +611 -0
  1003. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/model_hooks.rdoc +262 -0
  1004. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/model_plugins.rdoc +270 -0
  1005. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/mssql_stored_procedures.rdoc +43 -0
  1006. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/object_model.rdoc +573 -0
  1007. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/opening_databases.rdoc +489 -0
  1008. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/postgresql.rdoc +326 -0
  1009. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/prepared_statements.rdoc +139 -0
  1010. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/querying.rdoc +1017 -0
  1011. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/reflection.rdoc +121 -0
  1012. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/release_notes/1.0.txt +38 -0
  1013. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/release_notes/1.1.txt +143 -0
  1014. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/release_notes/1.3.txt +101 -0
  1015. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/release_notes/1.4.0.txt +53 -0
  1016. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/release_notes/1.5.0.txt +155 -0
  1017. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/release_notes/2.0.0.txt +298 -0
  1018. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/release_notes/2.1.0.txt +271 -0
  1019. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/release_notes/2.10.0.txt +328 -0
  1020. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/release_notes/2.11.0.txt +215 -0
  1021. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/release_notes/2.12.0.txt +534 -0
  1022. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/release_notes/2.2.0.txt +253 -0
  1023. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/release_notes/2.3.0.txt +88 -0
  1024. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/release_notes/2.4.0.txt +106 -0
  1025. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/release_notes/2.5.0.txt +137 -0
  1026. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/release_notes/2.6.0.txt +157 -0
  1027. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/release_notes/2.7.0.txt +166 -0
  1028. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/release_notes/2.8.0.txt +171 -0
  1029. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/release_notes/2.9.0.txt +97 -0
  1030. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/release_notes/3.0.0.txt +221 -0
  1031. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/release_notes/3.1.0.txt +406 -0
  1032. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/release_notes/3.10.0.txt +286 -0
  1033. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/release_notes/3.11.0.txt +254 -0
  1034. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/release_notes/3.12.0.txt +304 -0
  1035. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/release_notes/3.13.0.txt +210 -0
  1036. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/release_notes/3.14.0.txt +118 -0
  1037. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/release_notes/3.15.0.txt +78 -0
  1038. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/release_notes/3.16.0.txt +45 -0
  1039. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/release_notes/3.17.0.txt +58 -0
  1040. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/release_notes/3.18.0.txt +120 -0
  1041. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/release_notes/3.19.0.txt +67 -0
  1042. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/release_notes/3.2.0.txt +268 -0
  1043. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/release_notes/3.20.0.txt +41 -0
  1044. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/release_notes/3.21.0.txt +87 -0
  1045. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/release_notes/3.22.0.txt +39 -0
  1046. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/release_notes/3.23.0.txt +172 -0
  1047. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/release_notes/3.24.0.txt +420 -0
  1048. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/release_notes/3.25.0.txt +88 -0
  1049. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/release_notes/3.26.0.txt +88 -0
  1050. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/release_notes/3.27.0.txt +82 -0
  1051. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/release_notes/3.28.0.txt +304 -0
  1052. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/release_notes/3.29.0.txt +459 -0
  1053. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/release_notes/3.3.0.txt +192 -0
  1054. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/release_notes/3.30.0.txt +135 -0
  1055. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/release_notes/3.31.0.txt +146 -0
  1056. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/release_notes/3.32.0.txt +202 -0
  1057. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/release_notes/3.33.0.txt +157 -0
  1058. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/release_notes/3.34.0.txt +671 -0
  1059. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/release_notes/3.35.0.txt +144 -0
  1060. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/release_notes/3.36.0.txt +245 -0
  1061. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/release_notes/3.37.0.txt +338 -0
  1062. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/release_notes/3.38.0.txt +234 -0
  1063. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/release_notes/3.39.0.txt +237 -0
  1064. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/release_notes/3.4.0.txt +325 -0
  1065. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/release_notes/3.40.0.txt +73 -0
  1066. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/release_notes/3.41.0.txt +155 -0
  1067. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/release_notes/3.42.0.txt +74 -0
  1068. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/release_notes/3.43.0.txt +105 -0
  1069. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/release_notes/3.44.0.txt +152 -0
  1070. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/release_notes/3.45.0.txt +179 -0
  1071. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/release_notes/3.46.0.txt +122 -0
  1072. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/release_notes/3.47.0.txt +270 -0
  1073. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/release_notes/3.48.0.txt +477 -0
  1074. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/release_notes/3.5.0.txt +510 -0
  1075. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/release_notes/3.6.0.txt +366 -0
  1076. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/release_notes/3.7.0.txt +179 -0
  1077. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/release_notes/3.8.0.txt +151 -0
  1078. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/release_notes/3.9.0.txt +233 -0
  1079. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/release_notes/4.0.0.txt +262 -0
  1080. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/release_notes/4.1.0.txt +85 -0
  1081. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/release_notes/4.10.0.txt +226 -0
  1082. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/release_notes/4.11.0.txt +147 -0
  1083. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/release_notes/4.12.0.txt +105 -0
  1084. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/release_notes/4.13.0.txt +169 -0
  1085. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/release_notes/4.14.0.txt +68 -0
  1086. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/release_notes/4.15.0.txt +56 -0
  1087. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/release_notes/4.2.0.txt +129 -0
  1088. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/release_notes/4.3.0.txt +40 -0
  1089. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/release_notes/4.4.0.txt +92 -0
  1090. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/release_notes/4.5.0.txt +34 -0
  1091. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/release_notes/4.6.0.txt +30 -0
  1092. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/release_notes/4.7.0.txt +103 -0
  1093. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/release_notes/4.8.0.txt +175 -0
  1094. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/release_notes/4.9.0.txt +190 -0
  1095. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/schema_modification.rdoc +654 -0
  1096. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/security.rdoc +370 -0
  1097. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/sharding.rdoc +245 -0
  1098. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/sql.rdoc +589 -0
  1099. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/testing.rdoc +176 -0
  1100. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/thread_safety.rdoc +17 -0
  1101. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/transactions.rdoc +168 -0
  1102. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/validations.rdoc +540 -0
  1103. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/doc/virtual_rows.rdoc +272 -0
  1104. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel.rb +1 -0
  1105. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/adapters/ado.rb +151 -0
  1106. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/adapters/ado/access.rb +335 -0
  1107. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/adapters/ado/mssql.rb +69 -0
  1108. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/adapters/amalgalite.rb +179 -0
  1109. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/adapters/cubrid.rb +143 -0
  1110. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/adapters/db2.rb +229 -0
  1111. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/adapters/dbi.rb +101 -0
  1112. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/adapters/do.rb +156 -0
  1113. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/adapters/do/mysql.rb +64 -0
  1114. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/adapters/do/postgres.rb +42 -0
  1115. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/adapters/do/sqlite3.rb +40 -0
  1116. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/adapters/fdbsql.rb +285 -0
  1117. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/adapters/firebird.rb +104 -0
  1118. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/adapters/ibmdb.rb +476 -0
  1119. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/adapters/informix.rb +67 -0
  1120. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/adapters/jdbc.rb +794 -0
  1121. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/adapters/jdbc/as400.rb +82 -0
  1122. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/adapters/jdbc/cubrid.rb +62 -0
  1123. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/adapters/jdbc/db2.rb +91 -0
  1124. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/adapters/jdbc/derby.rb +312 -0
  1125. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/adapters/jdbc/fdbsql.rb +65 -0
  1126. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/adapters/jdbc/firebirdsql.rb +34 -0
  1127. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/adapters/jdbc/h2.rb +227 -0
  1128. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/adapters/jdbc/hsqldb.rb +231 -0
  1129. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/adapters/jdbc/informix-sqli.rb +31 -0
  1130. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/adapters/jdbc/jdbcprogress.rb +31 -0
  1131. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/adapters/jdbc/jtds.rb +45 -0
  1132. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/adapters/jdbc/mssql.rb +47 -0
  1133. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/adapters/jdbc/mysql.rb +90 -0
  1134. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/adapters/jdbc/oracle.rb +140 -0
  1135. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/adapters/jdbc/postgresql.rb +215 -0
  1136. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/adapters/jdbc/sqlanywhere.rb +82 -0
  1137. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/adapters/jdbc/sqlite.rb +82 -0
  1138. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/adapters/jdbc/sqlserver.rb +61 -0
  1139. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/adapters/jdbc/transactions.rb +109 -0
  1140. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/adapters/mock.rb +391 -0
  1141. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/adapters/mysql.rb +372 -0
  1142. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/adapters/mysql2.rb +200 -0
  1143. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/adapters/odbc.rb +149 -0
  1144. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/adapters/odbc/db2.rb +9 -0
  1145. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/adapters/odbc/mssql.rb +61 -0
  1146. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/adapters/odbc/progress.rb +8 -0
  1147. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/adapters/openbase.rb +53 -0
  1148. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/adapters/oracle.rb +459 -0
  1149. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/adapters/postgres.rb +877 -0
  1150. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/adapters/shared/access.rb +299 -0
  1151. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/adapters/shared/cubrid.rb +243 -0
  1152. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/adapters/shared/db2.rb +403 -0
  1153. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/adapters/shared/fdbsql.rb +550 -0
  1154. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/adapters/shared/firebird.rb +245 -0
  1155. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/adapters/shared/informix.rb +52 -0
  1156. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/adapters/shared/mssql.rb +1037 -0
  1157. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/adapters/shared/mysql.rb +984 -0
  1158. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/adapters/shared/mysql_prepared_statements.rb +182 -0
  1159. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/adapters/shared/oracle.rb +522 -0
  1160. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/adapters/shared/postgres.rb +1617 -0
  1161. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/adapters/shared/progress.rb +38 -0
  1162. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/adapters/shared/sqlanywhere.rb +470 -0
  1163. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/adapters/shared/sqlite.rb +729 -0
  1164. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/adapters/sqlanywhere.rb +177 -0
  1165. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/adapters/sqlite.rb +413 -0
  1166. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/adapters/swift.rb +150 -0
  1167. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/adapters/swift/mysql.rb +47 -0
  1168. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/adapters/swift/postgres.rb +45 -0
  1169. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/adapters/swift/sqlite.rb +35 -0
  1170. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/adapters/tinytds.rb +282 -0
  1171. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/adapters/utils/emulate_offset_with_reverse_and_count.rb +75 -0
  1172. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/adapters/utils/emulate_offset_with_row_number.rb +62 -0
  1173. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/adapters/utils/pg_types.rb +68 -0
  1174. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/adapters/utils/replace.rb +36 -0
  1175. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/adapters/utils/split_alter_table.rb +44 -0
  1176. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/adapters/utils/stored_procedures.rb +74 -0
  1177. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/ast_transformer.rb +200 -0
  1178. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/connection_pool.rb +110 -0
  1179. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/connection_pool/sharded_single.rb +98 -0
  1180. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/connection_pool/sharded_threaded.rb +265 -0
  1181. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/connection_pool/single.rb +38 -0
  1182. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/connection_pool/threaded.rb +198 -0
  1183. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/core.rb +394 -0
  1184. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/database.rb +20 -0
  1185. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/database/connecting.rb +318 -0
  1186. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/database/dataset.rb +69 -0
  1187. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/database/dataset_defaults.rb +175 -0
  1188. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/database/features.rb +134 -0
  1189. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/database/logging.rb +73 -0
  1190. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/database/misc.rb +534 -0
  1191. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/database/query.rb +329 -0
  1192. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/database/schema_generator.rb +525 -0
  1193. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/database/schema_methods.rb +964 -0
  1194. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/database/transactions.rb +353 -0
  1195. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/dataset.rb +40 -0
  1196. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/dataset/actions.rb +1045 -0
  1197. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/dataset/features.rb +203 -0
  1198. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/dataset/graph.rb +272 -0
  1199. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/dataset/misc.rb +279 -0
  1200. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/dataset/mutation.rb +109 -0
  1201. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/dataset/placeholder_literalizer.rb +179 -0
  1202. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/dataset/prepared_statements.rb +283 -0
  1203. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/dataset/query.rb +1136 -0
  1204. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/dataset/sql.rb +1555 -0
  1205. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/deprecated.rb +58 -0
  1206. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/exceptions.rb +77 -0
  1207. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/extensions/_pretty_table.rb +84 -0
  1208. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/extensions/arbitrary_servers.rb +110 -0
  1209. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/extensions/blank.rb +47 -0
  1210. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/extensions/columns_introspection.rb +83 -0
  1211. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/extensions/connection_validator.rb +110 -0
  1212. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/extensions/constraint_validations.rb +455 -0
  1213. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/extensions/core_extensions.rb +230 -0
  1214. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/extensions/core_refinements.rb +221 -0
  1215. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/extensions/current_datetime_timestamp.rb +58 -0
  1216. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/extensions/dataset_source_alias.rb +91 -0
  1217. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/extensions/date_arithmetic.rb +192 -0
  1218. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/extensions/empty_array_ignore_nulls.rb +34 -0
  1219. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/extensions/error_sql.rb +72 -0
  1220. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/extensions/eval_inspect.rb +182 -0
  1221. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/extensions/filter_having.rb +59 -0
  1222. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/extensions/from_block.rb +32 -0
  1223. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/extensions/graph_each.rb +75 -0
  1224. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/extensions/hash_aliases.rb +45 -0
  1225. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/extensions/inflector.rb +246 -0
  1226. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/extensions/looser_typecasting.rb +44 -0
  1227. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/extensions/meta_def.rb +31 -0
  1228. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/extensions/migration.rb +736 -0
  1229. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/extensions/mssql_emulate_lateral_with_apply.rb +80 -0
  1230. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/extensions/named_timezones.rb +99 -0
  1231. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/extensions/null_dataset.rb +105 -0
  1232. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/extensions/pagination.rb +121 -0
  1233. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/extensions/pg_array.rb +606 -0
  1234. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/extensions/pg_array_ops.rb +324 -0
  1235. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/extensions/pg_enum.rb +136 -0
  1236. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/extensions/pg_hstore.rb +357 -0
  1237. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/extensions/pg_hstore_ops.rb +349 -0
  1238. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/extensions/pg_inet.rb +118 -0
  1239. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/extensions/pg_interval.rb +198 -0
  1240. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/extensions/pg_json.rb +365 -0
  1241. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/extensions/pg_json_ops.rb +434 -0
  1242. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/extensions/pg_loose_count.rb +33 -0
  1243. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/extensions/pg_range.rb +546 -0
  1244. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/extensions/pg_range_ops.rb +162 -0
  1245. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/extensions/pg_row.rb +615 -0
  1246. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/extensions/pg_row_ops.rb +194 -0
  1247. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/extensions/pg_static_cache_updater.rb +140 -0
  1248. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/extensions/pretty_table.rb +36 -0
  1249. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/extensions/query.rb +78 -0
  1250. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/extensions/query_literals.rb +80 -0
  1251. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/extensions/round_timestamps.rb +52 -0
  1252. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/extensions/ruby18_symbol_extensions.rb +22 -0
  1253. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/extensions/schema_caching.rb +75 -0
  1254. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/extensions/schema_dumper.rb +476 -0
  1255. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/extensions/select_remove.rb +48 -0
  1256. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/extensions/sequel_3_dataset_methods.rb +118 -0
  1257. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/extensions/server_block.rb +149 -0
  1258. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/extensions/set_overrides.rb +72 -0
  1259. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/extensions/split_array_nil.rb +66 -0
  1260. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/extensions/sql_expr.rb +20 -0
  1261. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/extensions/string_date_time.rb +50 -0
  1262. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/extensions/thread_local_timezones.rb +55 -0
  1263. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/extensions/to_dot.rb +154 -0
  1264. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/model.rb +175 -0
  1265. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/model/associations.rb +3171 -0
  1266. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/model/base.rb +2306 -0
  1267. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/model/dataset_module.rb +30 -0
  1268. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/model/default_inflections.rb +45 -0
  1269. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/model/errors.rb +58 -0
  1270. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/model/exceptions.rb +46 -0
  1271. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/model/inflections.rb +162 -0
  1272. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/model/plugins.rb +49 -0
  1273. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/no_core_ext.rb +1 -0
  1274. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/plugins/active_model.rb +99 -0
  1275. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/plugins/after_initialize.rb +37 -0
  1276. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/plugins/association_autoreloading.rb +7 -0
  1277. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/plugins/association_dependencies.rb +97 -0
  1278. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/plugins/association_pks.rb +167 -0
  1279. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/plugins/association_proxies.rb +105 -0
  1280. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/plugins/auto_validations.rb +161 -0
  1281. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/plugins/blacklist_security.rb +93 -0
  1282. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/plugins/boolean_readers.rb +56 -0
  1283. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/plugins/caching.rb +153 -0
  1284. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/plugins/class_table_inheritance.rb +292 -0
  1285. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/plugins/column_select.rb +57 -0
  1286. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/plugins/composition.rb +187 -0
  1287. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/plugins/constraint_validations.rb +229 -0
  1288. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/plugins/dataset_associations.rb +107 -0
  1289. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/plugins/defaults_setter.rb +69 -0
  1290. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/plugins/dirty.rb +231 -0
  1291. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/plugins/eager_each.rb +64 -0
  1292. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/plugins/error_splitter.rb +54 -0
  1293. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/plugins/force_encoding.rb +81 -0
  1294. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/plugins/hook_class_methods.rb +125 -0
  1295. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/plugins/input_transformer.rb +79 -0
  1296. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/plugins/insert_returning_select.rb +70 -0
  1297. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/plugins/instance_filters.rb +131 -0
  1298. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/plugins/instance_hooks.rb +96 -0
  1299. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/plugins/json_serializer.rb +352 -0
  1300. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/plugins/lazy_attributes.rb +117 -0
  1301. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/plugins/list.rb +189 -0
  1302. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/plugins/many_through_many.rb +317 -0
  1303. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/plugins/many_to_one_pk_lookup.rb +7 -0
  1304. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/plugins/modification_detection.rb +90 -0
  1305. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/plugins/mssql_optimistic_locking.rb +92 -0
  1306. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/plugins/nested_attributes.rb +323 -0
  1307. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/plugins/optimistic_locking.rb +83 -0
  1308. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/plugins/pg_array_associations.rb +528 -0
  1309. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/plugins/pg_row.rb +123 -0
  1310. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/plugins/pg_typecast_on_load.rb +78 -0
  1311. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/plugins/prepared_statements.rb +205 -0
  1312. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/plugins/prepared_statements_associations.rb +116 -0
  1313. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/plugins/prepared_statements_safe.rb +73 -0
  1314. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/plugins/prepared_statements_with_pk.rb +59 -0
  1315. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/plugins/rcte_tree.rb +343 -0
  1316. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/plugins/schema.rb +80 -0
  1317. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/plugins/scissors.rb +33 -0
  1318. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/plugins/serialization.rb +235 -0
  1319. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/plugins/serialization_modification_detection.rb +84 -0
  1320. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/plugins/sharding.rb +117 -0
  1321. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/plugins/single_table_inheritance.rb +230 -0
  1322. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/plugins/skip_create_refresh.rb +35 -0
  1323. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/plugins/split_values.rb +64 -0
  1324. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/plugins/static_cache.rb +215 -0
  1325. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/plugins/string_stripper.rb +57 -0
  1326. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/plugins/subclasses.rb +61 -0
  1327. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/plugins/table_select.rb +41 -0
  1328. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/plugins/tactical_eager_loading.rb +85 -0
  1329. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/plugins/timestamps.rb +95 -0
  1330. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/plugins/touch.rb +140 -0
  1331. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/plugins/tree.rb +156 -0
  1332. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/plugins/typecast_on_load.rb +80 -0
  1333. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/plugins/unlimited_update.rb +31 -0
  1334. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/plugins/update_or_create.rb +60 -0
  1335. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/plugins/update_primary_key.rb +70 -0
  1336. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/plugins/validation_class_methods.rb +439 -0
  1337. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/plugins/validation_helpers.rb +291 -0
  1338. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/plugins/xml_serializer.rb +410 -0
  1339. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/sql.rb +1865 -0
  1340. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/timezones.rb +221 -0
  1341. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/version.rb +18 -0
  1342. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/adapters/db2_spec.rb +148 -0
  1343. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/adapters/fdbsql_spec.rb +429 -0
  1344. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/adapters/firebird_spec.rb +417 -0
  1345. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/adapters/informix_spec.rb +100 -0
  1346. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/adapters/mssql_spec.rb +722 -0
  1347. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/adapters/mysql_spec.rb +1304 -0
  1348. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/adapters/oracle_spec.rb +315 -0
  1349. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/adapters/postgres_spec.rb +3537 -0
  1350. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/adapters/spec_helper.rb +76 -0
  1351. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/adapters/sqlanywhere_spec.rb +170 -0
  1352. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/adapters/sqlite_spec.rb +650 -0
  1353. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/bin_spec.rb +256 -0
  1354. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/core/connection_pool_spec.rb +982 -0
  1355. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/core/database_spec.rb +2487 -0
  1356. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/core/dataset_spec.rb +4970 -0
  1357. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/core/deprecated_spec.rb +70 -0
  1358. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/core/expression_filters_spec.rb +1197 -0
  1359. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/core/mock_adapter_spec.rb +462 -0
  1360. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/core/object_graph_spec.rb +303 -0
  1361. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/core/placeholder_literalizer_spec.rb +163 -0
  1362. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/core/schema_generator_spec.rb +179 -0
  1363. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/core/schema_spec.rb +1610 -0
  1364. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/core/spec_helper.rb +49 -0
  1365. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/core/version_spec.rb +7 -0
  1366. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/core_extensions_spec.rb +695 -0
  1367. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/active_model_spec.rb +123 -0
  1368. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/after_initialize_spec.rb +24 -0
  1369. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/arbitrary_servers_spec.rb +109 -0
  1370. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/association_dependencies_spec.rb +117 -0
  1371. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/association_pks_spec.rb +281 -0
  1372. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/association_proxies_spec.rb +86 -0
  1373. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/auto_validations_spec.rb +158 -0
  1374. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/blacklist_security_spec.rb +87 -0
  1375. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/blank_spec.rb +69 -0
  1376. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/boolean_readers_spec.rb +93 -0
  1377. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/caching_spec.rb +270 -0
  1378. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/class_table_inheritance_spec.rb +274 -0
  1379. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/column_select_spec.rb +108 -0
  1380. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/columns_introspection_spec.rb +91 -0
  1381. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/composition_spec.rb +242 -0
  1382. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/connection_validator_spec.rb +118 -0
  1383. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/constraint_validations_plugin_spec.rb +274 -0
  1384. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/constraint_validations_spec.rb +325 -0
  1385. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/core_refinements_spec.rb +519 -0
  1386. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/current_datetime_timestamp_spec.rb +27 -0
  1387. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/dataset_associations_spec.rb +311 -0
  1388. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/dataset_source_alias_spec.rb +51 -0
  1389. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/date_arithmetic_spec.rb +157 -0
  1390. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/defaults_setter_spec.rb +101 -0
  1391. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/dirty_spec.rb +180 -0
  1392. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/eager_each_spec.rb +42 -0
  1393. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/empty_array_ignore_nulls_spec.rb +24 -0
  1394. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/error_splitter_spec.rb +18 -0
  1395. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/error_sql_spec.rb +20 -0
  1396. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/eval_inspect_spec.rb +73 -0
  1397. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/filter_having_spec.rb +40 -0
  1398. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/force_encoding_spec.rb +114 -0
  1399. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/from_block_spec.rb +21 -0
  1400. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/graph_each_spec.rb +109 -0
  1401. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/hash_aliases_spec.rb +24 -0
  1402. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/hook_class_methods_spec.rb +416 -0
  1403. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/inflector_spec.rb +183 -0
  1404. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/input_transformer_spec.rb +54 -0
  1405. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/insert_returning_select_spec.rb +46 -0
  1406. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/instance_filters_spec.rb +79 -0
  1407. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/instance_hooks_spec.rb +276 -0
  1408. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/json_serializer_spec.rb +267 -0
  1409. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/lazy_attributes_spec.rb +170 -0
  1410. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/list_spec.rb +265 -0
  1411. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/looser_typecasting_spec.rb +43 -0
  1412. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/many_through_many_spec.rb +2159 -0
  1413. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/meta_def_spec.rb +21 -0
  1414. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/migration_spec.rb +709 -0
  1415. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/modification_detection_spec.rb +80 -0
  1416. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/mssql_optimistic_locking_spec.rb +91 -0
  1417. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/named_timezones_spec.rb +108 -0
  1418. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/nested_attributes_spec.rb +697 -0
  1419. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/null_dataset_spec.rb +85 -0
  1420. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/optimistic_locking_spec.rb +128 -0
  1421. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/pagination_spec.rb +118 -0
  1422. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/pg_array_associations_spec.rb +736 -0
  1423. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/pg_array_ops_spec.rb +143 -0
  1424. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/pg_array_spec.rb +390 -0
  1425. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/pg_enum_spec.rb +64 -0
  1426. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/pg_hstore_ops_spec.rb +236 -0
  1427. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/pg_hstore_spec.rb +206 -0
  1428. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/pg_inet_spec.rb +52 -0
  1429. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/pg_interval_spec.rb +76 -0
  1430. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/pg_json_ops_spec.rb +226 -0
  1431. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/pg_json_spec.rb +218 -0
  1432. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/pg_loose_count_spec.rb +17 -0
  1433. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/pg_range_ops_spec.rb +58 -0
  1434. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/pg_range_spec.rb +404 -0
  1435. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/pg_row_ops_spec.rb +60 -0
  1436. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/pg_row_plugin_spec.rb +62 -0
  1437. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/pg_row_spec.rb +360 -0
  1438. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/pg_static_cache_updater_spec.rb +92 -0
  1439. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/pg_typecast_on_load_spec.rb +63 -0
  1440. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/prepared_statements_associations_spec.rb +151 -0
  1441. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/prepared_statements_safe_spec.rb +61 -0
  1442. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/prepared_statements_spec.rb +103 -0
  1443. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/prepared_statements_with_pk_spec.rb +31 -0
  1444. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/pretty_table_spec.rb +92 -0
  1445. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/query_literals_spec.rb +167 -0
  1446. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/query_spec.rb +102 -0
  1447. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/rcte_tree_spec.rb +387 -0
  1448. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/round_timestamps_spec.rb +43 -0
  1449. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/schema_caching_spec.rb +41 -0
  1450. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/schema_dumper_spec.rb +788 -0
  1451. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/schema_spec.rb +113 -0
  1452. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/scissors_spec.rb +26 -0
  1453. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/select_remove_spec.rb +38 -0
  1454. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/sequel_3_dataset_methods_spec.rb +101 -0
  1455. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/serialization_modification_detection_spec.rb +98 -0
  1456. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/serialization_spec.rb +340 -0
  1457. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/server_block_spec.rb +90 -0
  1458. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/set_overrides_spec.rb +61 -0
  1459. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/sharding_spec.rb +198 -0
  1460. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/shared_caching_spec.rb +175 -0
  1461. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/single_table_inheritance_spec.rb +276 -0
  1462. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/skip_create_refresh_spec.rb +17 -0
  1463. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/spec_helper.rb +96 -0
  1464. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/split_array_nil_spec.rb +24 -0
  1465. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/split_values_spec.rb +22 -0
  1466. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/sql_expr_spec.rb +60 -0
  1467. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/static_cache_spec.rb +355 -0
  1468. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/string_date_time_spec.rb +95 -0
  1469. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/string_stripper_spec.rb +68 -0
  1470. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/subclasses_spec.rb +66 -0
  1471. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/table_select_spec.rb +71 -0
  1472. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/tactical_eager_loading_spec.rb +82 -0
  1473. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/thread_local_timezones_spec.rb +67 -0
  1474. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/timestamps_spec.rb +175 -0
  1475. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/to_dot_spec.rb +154 -0
  1476. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/touch_spec.rb +203 -0
  1477. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/tree_spec.rb +270 -0
  1478. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/typecast_on_load_spec.rb +80 -0
  1479. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/unlimited_update_spec.rb +20 -0
  1480. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/update_or_create_spec.rb +81 -0
  1481. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/update_primary_key_spec.rb +100 -0
  1482. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/validation_class_methods_spec.rb +1030 -0
  1483. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/validation_helpers_spec.rb +520 -0
  1484. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/extensions/xml_serializer_spec.rb +207 -0
  1485. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/files/bad_down_migration/001_create_alt_basic.rb +4 -0
  1486. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/files/bad_down_migration/002_create_alt_advanced.rb +4 -0
  1487. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/files/bad_timestamped_migrations/1273253849_create_sessions.rb +9 -0
  1488. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/files/bad_timestamped_migrations/1273253851_create_nodes.rb +9 -0
  1489. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/files/bad_timestamped_migrations/1273253853_3_create_users.rb +3 -0
  1490. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/files/bad_up_migration/001_create_alt_basic.rb +4 -0
  1491. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/files/bad_up_migration/002_create_alt_advanced.rb +3 -0
  1492. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/files/convert_to_timestamp_migrations/001_create_sessions.rb +9 -0
  1493. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/files/convert_to_timestamp_migrations/002_create_nodes.rb +9 -0
  1494. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/files/convert_to_timestamp_migrations/003_3_create_users.rb +4 -0
  1495. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/files/convert_to_timestamp_migrations/1273253850_create_artists.rb +9 -0
  1496. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/files/convert_to_timestamp_migrations/1273253852_create_albums.rb +9 -0
  1497. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/files/duplicate_integer_migrations/001_create_alt_advanced.rb +4 -0
  1498. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/files/duplicate_integer_migrations/001_create_alt_basic.rb +4 -0
  1499. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/files/duplicate_timestamped_migrations/1273253849_create_sessions.rb +9 -0
  1500. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/files/duplicate_timestamped_migrations/1273253853_create_nodes.rb +9 -0
  1501. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/files/duplicate_timestamped_migrations/1273253853_create_users.rb +4 -0
  1502. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/files/integer_migrations/001_create_sessions.rb +9 -0
  1503. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/files/integer_migrations/002_create_nodes.rb +9 -0
  1504. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/files/integer_migrations/003_3_create_users.rb +4 -0
  1505. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/files/interleaved_timestamped_migrations/1273253849_create_sessions.rb +9 -0
  1506. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/files/interleaved_timestamped_migrations/1273253850_create_artists.rb +9 -0
  1507. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/files/interleaved_timestamped_migrations/1273253851_create_nodes.rb +9 -0
  1508. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/files/interleaved_timestamped_migrations/1273253852_create_albums.rb +9 -0
  1509. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/files/interleaved_timestamped_migrations/1273253853_3_create_users.rb +4 -0
  1510. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/files/missing_integer_migrations/001_create_alt_basic.rb +4 -0
  1511. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/files/missing_integer_migrations/003_create_alt_advanced.rb +4 -0
  1512. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/files/missing_timestamped_migrations/1273253849_create_sessions.rb +9 -0
  1513. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/files/missing_timestamped_migrations/1273253853_3_create_users.rb +4 -0
  1514. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/files/reversible_migrations/001_reversible.rb +5 -0
  1515. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/files/reversible_migrations/002_reversible.rb +5 -0
  1516. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/files/reversible_migrations/003_reversible.rb +5 -0
  1517. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/files/reversible_migrations/004_reversible.rb +5 -0
  1518. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/files/reversible_migrations/005_reversible.rb +10 -0
  1519. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/files/timestamped_migrations/1273253849_create_sessions.rb +9 -0
  1520. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/files/timestamped_migrations/1273253851_create_nodes.rb +9 -0
  1521. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/files/timestamped_migrations/1273253853_3_create_users.rb +4 -0
  1522. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/files/transaction_specified_migrations/001_create_alt_basic.rb +4 -0
  1523. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/files/transaction_specified_migrations/002_create_basic.rb +4 -0
  1524. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/files/transaction_unspecified_migrations/001_create_alt_basic.rb +3 -0
  1525. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/files/transaction_unspecified_migrations/002_create_basic.rb +3 -0
  1526. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/files/uppercase_timestamped_migrations/1273253849_CREATE_SESSIONS.RB +9 -0
  1527. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/files/uppercase_timestamped_migrations/1273253851_CREATE_NODES.RB +9 -0
  1528. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/files/uppercase_timestamped_migrations/1273253853_3_CREATE_USERS.RB +4 -0
  1529. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/integration/associations_test.rb +2453 -0
  1530. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/integration/database_test.rb +113 -0
  1531. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/integration/dataset_test.rb +1798 -0
  1532. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/integration/eager_loader_test.rb +687 -0
  1533. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/integration/migrator_test.rb +240 -0
  1534. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/integration/model_test.rb +226 -0
  1535. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/integration/plugin_test.rb +2162 -0
  1536. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/integration/prepared_statement_test.rb +426 -0
  1537. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/integration/schema_test.rb +801 -0
  1538. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/integration/spec_helper.rb +111 -0
  1539. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/integration/timezone_test.rb +86 -0
  1540. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/integration/transaction_test.rb +374 -0
  1541. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/integration/type_test.rb +133 -0
  1542. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/model/association_reflection_spec.rb +500 -0
  1543. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/model/associations_spec.rb +4316 -0
  1544. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/model/base_spec.rb +746 -0
  1545. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/model/class_dataset_methods_spec.rb +145 -0
  1546. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/model/dataset_methods_spec.rb +149 -0
  1547. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/model/eager_loading_spec.rb +2080 -0
  1548. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/model/hooks_spec.rb +536 -0
  1549. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/model/inflector_spec.rb +26 -0
  1550. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/model/model_spec.rb +992 -0
  1551. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/model/plugins_spec.rb +299 -0
  1552. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/model/record_spec.rb +2053 -0
  1553. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/model/spec_helper.rb +64 -0
  1554. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/model/validations_spec.rb +191 -0
  1555. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/rspec_helper.rb +22 -0
  1556. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/sequel_coverage.rb +15 -0
  1557. data/vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/spec/spec_config.rb +2 -0
  1558. data/vendor/bundle/ruby/1.9.1/gems/slop-3.5.0/CHANGES.md +303 -0
  1559. data/vendor/bundle/ruby/1.9.1/gems/slop-3.5.0/Gemfile +3 -0
  1560. data/vendor/bundle/ruby/1.9.1/gems/slop-3.5.0/LICENSE +20 -0
  1561. data/vendor/bundle/ruby/1.9.1/gems/slop-3.5.0/README.md +182 -0
  1562. data/vendor/bundle/ruby/1.9.1/gems/slop-3.5.0/Rakefile +29 -0
  1563. data/vendor/bundle/ruby/1.9.1/gems/slop-3.5.0/lib/slop.rb +687 -0
  1564. data/vendor/bundle/ruby/1.9.1/gems/slop-3.5.0/lib/slop/commands.rb +196 -0
  1565. data/vendor/bundle/ruby/1.9.1/gems/slop-3.5.0/lib/slop/option.rb +209 -0
  1566. data/vendor/bundle/ruby/1.9.1/gems/slop-3.5.0/slop.gemspec +17 -0
  1567. data/vendor/bundle/ruby/1.9.1/gems/slop-3.5.0/test/commands_test.rb +26 -0
  1568. data/vendor/bundle/ruby/1.9.1/gems/slop-3.5.0/test/helper.rb +12 -0
  1569. data/vendor/bundle/ruby/1.9.1/gems/slop-3.5.0/test/option_test.rb +138 -0
  1570. data/vendor/bundle/ruby/1.9.1/gems/slop-3.5.0/test/slop_test.rb +518 -0
  1571. data/vendor/bundle/ruby/1.9.1/gems/threadify-1.3.0/README +151 -0
  1572. data/vendor/bundle/ruby/1.9.1/gems/threadify-1.3.0/README.erb +43 -0
  1573. data/vendor/bundle/ruby/1.9.1/gems/threadify-1.3.0/lib/threadify.rb +176 -0
  1574. data/vendor/bundle/ruby/1.9.1/gems/threadify-1.3.0/rakefile +222 -0
  1575. data/vendor/bundle/ruby/1.9.1/gems/threadify-1.3.0/sample/a.rb +37 -0
  1576. data/vendor/bundle/ruby/1.9.1/gems/threadify-1.3.0/sample/b.rb +41 -0
  1577. data/vendor/bundle/ruby/1.9.1/gems/threadify-1.3.0/threadify.gemspec +26 -0
  1578. data/vendor/bundle/ruby/1.9.1/specifications/amalgalite-1.3.0.gemspec +52 -0
  1579. data/vendor/bundle/ruby/1.9.1/specifications/arrayfields-4.7.4.gemspec +16 -0
  1580. data/vendor/bundle/ruby/1.9.1/specifications/chronic-0.10.2.gemspec +42 -0
  1581. data/vendor/bundle/ruby/1.9.1/specifications/coderay-1.1.0.gemspec +23 -0
  1582. data/vendor/bundle/ruby/1.9.1/specifications/coerce-0.0.6.gemspec +30 -0
  1583. data/vendor/bundle/ruby/1.9.1/specifications/daemons-1.1.9.gemspec +19 -0
  1584. data/vendor/bundle/ruby/1.9.1/specifications/fastercsv-1.5.5.gemspec +20 -0
  1585. data/vendor/bundle/ruby/1.9.1/specifications/fattr-2.2.2.gemspec +18 -0
  1586. data/vendor/bundle/ruby/1.9.1/specifications/flowdock-0.5.0.gemspec +51 -0
  1587. data/vendor/bundle/ruby/1.9.1/specifications/highline-1.6.21.gemspec +21 -0
  1588. data/vendor/bundle/ruby/1.9.1/specifications/httparty-0.13.1.gemspec +35 -0
  1589. data/vendor/bundle/ruby/1.9.1/specifications/json-1.8.1.gemspec +36 -0
  1590. data/vendor/bundle/ruby/1.9.1/specifications/main-6.0.0.gemspec +39 -0
  1591. data/vendor/bundle/ruby/1.9.1/specifications/main-6.1.0.gemspec +39 -0
  1592. data/vendor/bundle/ruby/1.9.1/specifications/map-6.5.5.gemspec +18 -0
  1593. data/vendor/bundle/ruby/1.9.1/specifications/method_source-0.8.2.gemspec +31 -0
  1594. data/vendor/bundle/ruby/1.9.1/specifications/multi_json-1.10.1.gemspec +30 -0
  1595. data/vendor/bundle/ruby/1.9.1/specifications/multi_xml-0.5.5.gemspec +30 -0
  1596. data/vendor/bundle/ruby/1.9.1/specifications/pry-0.9.12.6.gemspec +51 -0
  1597. data/vendor/bundle/ruby/1.9.1/specifications/sekrets-1.7.0.gemspec +43 -0
  1598. data/vendor/bundle/ruby/1.9.1/specifications/sequel-4.15.0.gemspec +22 -0
  1599. data/vendor/bundle/ruby/1.9.1/specifications/slop-3.5.0.gemspec +33 -0
  1600. data/vendor/bundle/ruby/1.9.1/specifications/threadify-1.3.0.gemspec +16 -0
  1601. metadata +1804 -0
@@ -0,0 +1,5 @@
1
+ Sequel.migration do
2
+ change do
3
+ create_table(:a){Integer :a}
4
+ end
5
+ end
@@ -0,0 +1,5 @@
1
+ Sequel.migration do
2
+ change do
3
+ add_column :a, :b, String
4
+ end
5
+ end
@@ -0,0 +1,5 @@
1
+ Sequel.migration do
2
+ change do
3
+ rename_column :a, :b, :c
4
+ end
5
+ end
@@ -0,0 +1,5 @@
1
+ Sequel.migration do
2
+ change do
3
+ rename_table :a, :b
4
+ end
5
+ end
@@ -0,0 +1,10 @@
1
+ Sequel.migration do
2
+ change do
3
+ alter_table(:b) do
4
+ add_column :d, String
5
+ end
6
+ alter_table(:b) do
7
+ rename_column :d, :e
8
+ end
9
+ end
10
+ end
@@ -0,0 +1,9 @@
1
+ class CreateSessions < Sequel::Migration
2
+ def up
3
+ create_table(:sm1111){Integer :smc1}
4
+ end
5
+
6
+ def down
7
+ drop_table(:sm1111)
8
+ end
9
+ end
@@ -0,0 +1,9 @@
1
+ Class.new(Sequel::Migration) do
2
+ def up
3
+ create_table(:sm2222){Integer :smc2}
4
+ end
5
+
6
+ def down
7
+ drop_table(:sm2222)
8
+ end
9
+ end
@@ -0,0 +1,4 @@
1
+ Sequel.migration do
2
+ up{create_table(:sm3333){Integer :smc3}}
3
+ down{drop_table(:sm3333)}
4
+ end
@@ -0,0 +1,4 @@
1
+ Sequel.migration do
2
+ transaction
3
+ change{create_table(:sm11111){Integer :smc1}}
4
+ end
@@ -0,0 +1,4 @@
1
+ Sequel.migration do
2
+ no_transaction
3
+ change{create_table(:sm){Integer :smc1}}
4
+ end
@@ -0,0 +1,3 @@
1
+ Sequel.migration do
2
+ change{create_table(:sm11111){Integer :smc1}}
3
+ end
@@ -0,0 +1,3 @@
1
+ Sequel.migration do
2
+ change{create_table(:sm){Integer :smc1}}
3
+ end
@@ -0,0 +1,9 @@
1
+ class CreateSessions < Sequel::Migration
2
+ def up
3
+ create_table(:sm1111){Integer :smc1}
4
+ end
5
+
6
+ def down
7
+ drop_table(:sm1111)
8
+ end
9
+ end
@@ -0,0 +1,9 @@
1
+ Class.new(Sequel::Migration) do
2
+ def up
3
+ create_table(:sm2222){Integer :smc2}
4
+ end
5
+
6
+ def down
7
+ drop_table(:sm2222)
8
+ end
9
+ end
@@ -0,0 +1,4 @@
1
+ Sequel.migration do
2
+ up{create_table(:sm3333){Integer :smc3}}
3
+ down{drop_table(:sm3333)}
4
+ end
@@ -0,0 +1,2453 @@
1
+ require File.join(File.dirname(File.expand_path(__FILE__)), 'spec_helper.rb')
2
+
3
+ shared_examples_for "one_to_one eager limit strategies" do
4
+ specify "eager loading one_to_one associations should work correctly" do
5
+ Artist.one_to_one :first_album, {:clone=>:first_album}.merge(@els) if @els
6
+ Artist.one_to_one :last_album, {:clone=>:last_album}.merge(@els) if @els
7
+ Artist.one_to_one :second_album, {:clone=>:second_album}.merge(@els) if @els && @els[:eager_limit_strategy] != :distinct_on
8
+ @album.update(:artist => @artist)
9
+ diff_album = @diff_album.call
10
+ ar = @pr.call[1]
11
+
12
+ a = Artist.eager(:first_album, :last_album, :second_album).order(:name).all
13
+ a.should == [@artist, ar]
14
+ a.first.first_album.should == @album
15
+ a.first.last_album.should == diff_album
16
+ a.first.second_album.should == diff_album
17
+ a.last.first_album.should == nil
18
+ a.last.last_album.should == nil
19
+ a.last.second_album.should == nil
20
+
21
+ # Check that no extra columns got added by the eager loading
22
+ a.first.first_album.values.should == @album.values
23
+ a.first.last_album.values.should == diff_album.values
24
+ a.first.second_album.values.should == diff_album.values
25
+
26
+ same_album = @same_album.call
27
+ a = Artist.eager(:first_album).order(:name).all
28
+ a.should == [@artist, ar]
29
+ [@album, same_album].should include(a.first.first_album)
30
+ a.last.first_album.should == nil
31
+ end
32
+ end
33
+
34
+ shared_examples_for "one_to_one eager_graph limit strategies" do
35
+ specify "eager graphing one_to_one associations should work correctly" do
36
+ @album.update(:artist => @artist)
37
+ diff_album = @diff_album.call
38
+ ar = @pr.call[1]
39
+ ds = Artist.order(:artists__name)
40
+ limit_strategy = {:limit_strategy=>@els[:eager_limit_strategy]}
41
+
42
+ a = ds.eager_graph_with_options(:first_album, limit_strategy).all
43
+ a.should == [@artist, ar]
44
+ a.first.first_album.should == @album
45
+ a.last.first_album.should == nil
46
+ a.first.first_album.values.should == @album.values
47
+
48
+ a = ds.eager_graph_with_options(:last_album, limit_strategy).all
49
+ a = ds.eager_graph(:last_album).all
50
+ a.should == [@artist, ar]
51
+ a.first.last_album.should == diff_album
52
+ a.last.last_album.should == nil
53
+ a.first.last_album.values.should == diff_album.values
54
+
55
+ if @els[:eager_limit_strategy] != :distinct_on && (@els[:eager_limit_strategy] != :correlated_subquery || Album.dataset.supports_offsets_in_correlated_subqueries?)
56
+ a = ds.eager_graph_with_options(:second_album, limit_strategy).all
57
+ a = ds.eager_graph(:second_album).all
58
+ a.should == [@artist, ar]
59
+ a.first.second_album.should == diff_album
60
+ a.last.second_album.should == nil
61
+ a.first.second_album.values.should == diff_album.values
62
+ end
63
+
64
+ same_album = @same_album.call
65
+ a = ds.eager_graph_with_options(:first_album, limit_strategy).all
66
+ a.should == [@artist, ar]
67
+ [@album, same_album].should include(a.first.first_album)
68
+ a.last.first_album.should == nil
69
+ end
70
+ end
71
+
72
+ shared_examples_for "one_to_many eager limit strategies" do
73
+ specify "should correctly handle limits and offsets when eager loading one_to_many associations" do
74
+ Artist.one_to_many :first_two_albums, {:clone=>:first_two_albums}.merge(@els) if @els
75
+ Artist.one_to_many :second_two_albums, {:clone=>:second_two_albums}.merge(@els) if @els
76
+ Artist.one_to_many :not_first_albums, {:clone=>:not_first_albums}.merge(@els) if @els
77
+ Artist.one_to_many :last_two_albums, {:clone=>:last_two_albums}.merge(@els) if @els
78
+ @album.update(:artist => @artist)
79
+ middle_album = @middle_album.call
80
+ diff_album = @diff_album.call
81
+ ar = @pr.call[1]
82
+
83
+ ars = Artist.eager(:first_two_albums, :second_two_albums, :not_first_albums, :last_two_albums).order(:name).all
84
+ ars.should == [@artist, ar]
85
+ ars.first.first_two_albums.should == [@album, middle_album]
86
+ ars.first.second_two_albums.should == [middle_album, diff_album]
87
+ ars.first.not_first_albums.should == [middle_album, diff_album]
88
+ ars.first.last_two_albums.should == [diff_album, middle_album]
89
+ ars.last.first_two_albums.should == []
90
+ ars.last.second_two_albums.should == []
91
+ ars.last.not_first_albums.should == []
92
+ ars.last.last_two_albums.should == []
93
+
94
+ # Check that no extra columns got added by the eager loading
95
+ ars.first.first_two_albums.map{|x| x.values}.should == [@album, middle_album].map{|x| x.values}
96
+ ars.first.second_two_albums.map{|x| x.values}.should == [middle_album, diff_album].map{|x| x.values}
97
+ ars.first.not_first_albums.map{|x| x.values}.should == [middle_album, diff_album].map{|x| x.values}
98
+ ars.first.last_two_albums.map{|x| x.values}.should == [diff_album, middle_album].map{|x| x.values}
99
+ end
100
+ end
101
+
102
+ shared_examples_for "one_to_many eager_graph limit strategies" do
103
+ specify "should correctly handle limits and offsets when eager graphing one_to_many associations" do
104
+ @album.update(:artist => @artist)
105
+ middle_album = @middle_album.call
106
+ diff_album = @diff_album.call
107
+ ar = @pr.call[1]
108
+ ds = Artist.order(:artists__name)
109
+ limit_strategy = {:limit_strategy=>@els[:eager_limit_strategy]}
110
+
111
+ ars = ds.eager_graph_with_options(:first_two_albums, limit_strategy).all
112
+ ars.should == [@artist, ar]
113
+ ars.first.first_two_albums.should == [@album, middle_album]
114
+ ars.last.first_two_albums.should == []
115
+ ars.first.first_two_albums.map{|x| x.values}.should == [@album, middle_album].map{|x| x.values}
116
+
117
+ if @els[:eager_limit_strategy] != :correlated_subquery || Album.dataset.supports_offsets_in_correlated_subqueries?
118
+ ars = ds.eager_graph_with_options(:second_two_albums, limit_strategy).all
119
+ ars.should == [@artist, ar]
120
+ ars.first.second_two_albums.should == [middle_album, diff_album]
121
+ ars.last.second_two_albums.should == []
122
+ ars.first.second_two_albums.map{|x| x.values}.should == [middle_album, diff_album].map{|x| x.values}
123
+
124
+ ars = ds.eager_graph_with_options(:not_first_albums, limit_strategy).all
125
+ ars.should == [@artist, ar]
126
+ ars.first.not_first_albums.should == [middle_album, diff_album]
127
+ ars.last.not_first_albums.should == []
128
+ ars.first.not_first_albums.map{|x| x.values}.should == [middle_album, diff_album].map{|x| x.values}
129
+ end
130
+
131
+ ars = ds.eager_graph_with_options(:last_two_albums, limit_strategy).all
132
+ ars.should == [@artist, ar]
133
+ ars.first.last_two_albums.should == [diff_album, middle_album]
134
+ ars.last.last_two_albums.should == []
135
+ ars.first.last_two_albums.map{|x| x.values}.should == [diff_album, middle_album].map{|x| x.values}
136
+ end
137
+ end
138
+
139
+ shared_examples_for "one_through_one eager limit strategies" do
140
+ specify "should correctly handle offsets when eager loading one_through_one associations" do
141
+ Album.one_through_one :first_tag, {:clone=>:first_tag}.merge(@els) if @els
142
+ Album.one_through_one :second_tag, {:clone=>:second_tag}.merge(@els) if @els && @els[:eager_limit_strategy] != :distinct_on
143
+ Album.one_through_one :last_tag, {:clone=>:last_tag}.merge(@els) if @els
144
+ tu, tv = @other_tags.call
145
+ al = @pr.call.first
146
+
147
+ als = Album.eager(:first_tag, :second_tag, :last_tag).order(:name).all
148
+ als.should == [@album, al]
149
+ als.first.first_tag.should == @tag
150
+ als.first.second_tag.should == tu
151
+ als.first.last_tag.should == tv
152
+ als.last.first_tag.should == nil
153
+ als.last.second_tag.should == nil
154
+ als.last.last_tag.should == nil
155
+
156
+ # Check that no extra columns got added by the eager loading
157
+ als.first.first_tag.values.should == @tag.values
158
+ als.first.second_tag.values.should == tu.values
159
+ als.first.last_tag.values.should == tv.values
160
+ end
161
+ end
162
+
163
+ shared_examples_for "one_through_one eager_graph limit strategies" do
164
+ specify "should correctly handle offsets when eager graphing one_through_one associations" do
165
+ tu, tv = @other_tags.call
166
+ al = @pr.call.first
167
+ ds = Album.order(:albums__name)
168
+ limit_strategy = {:limit_strategy=>@els[:eager_limit_strategy]}
169
+
170
+ als = ds.eager_graph_with_options(:first_tag, limit_strategy).all
171
+ als.should == [@album, al]
172
+ als.first.first_tag.should == @tag
173
+ als.last.first_tag.should == nil
174
+ als.first.first_tag.values.should == @tag.values
175
+
176
+ als = ds.eager_graph_with_options(:second_tag, @els[:eager_limit_strategy] != :distinct_on ? limit_strategy : {}).all
177
+ als.should == [@album, al]
178
+ als.first.second_tag.should == tu
179
+ als.last.second_tag.should == nil
180
+ als.first.second_tag.values.should == tu.values
181
+
182
+ als = ds.eager_graph_with_options(:last_tag, limit_strategy).all
183
+ als.should == [@album, al]
184
+ als.first.last_tag.should == tv
185
+ als.last.last_tag.should == nil
186
+ als.first.last_tag.values.should == tv.values
187
+ end
188
+ end
189
+
190
+ shared_examples_for "many_to_many eager limit strategies" do
191
+ specify "should correctly handle limits and offsets when eager loading many_to_many associations" do
192
+ Album.send @many_to_many_method||:many_to_many, :first_two_tags, {:clone=>:first_two_tags}.merge(@els) if @els
193
+ Album.send @many_to_many_method||:many_to_many, :second_two_tags, {:clone=>:second_two_tags}.merge(@els) if @els
194
+ Album.send @many_to_many_method||:many_to_many, :not_first_tags, {:clone=>:not_first_tags}.merge(@els) if @els
195
+ Album.send @many_to_many_method||:many_to_many, :last_two_tags, {:clone=>:last_two_tags}.merge(@els) if @els
196
+ tu, tv = @other_tags.call
197
+ al = @pr.call.first
198
+ al.add_tag(tu)
199
+
200
+ als = Album.eager(:first_two_tags, :second_two_tags, :not_first_tags, :last_two_tags).order(:name).all
201
+ als.should == [@album, al]
202
+ als.first.first_two_tags.should == [@tag, tu]
203
+ als.first.second_two_tags.should == [tu, tv]
204
+ als.first.not_first_tags.should == [tu, tv]
205
+ als.first.last_two_tags.should == [tv, tu]
206
+ als.last.first_two_tags.should == [tu]
207
+ als.last.second_two_tags.should == []
208
+ als.last.last_two_tags.should == [tu]
209
+
210
+ # Check that no extra columns got added by the eager loading
211
+ als.first.first_two_tags.map{|x| x.values}.should == [@tag, tu].map{|x| x.values}
212
+ als.first.second_two_tags.map{|x| x.values}.should == [tu, tv].map{|x| x.values}
213
+ als.first.not_first_tags.map{|x| x.values}.should == [tu, tv].map{|x| x.values}
214
+ als.first.last_two_tags.map{|x| x.values}.should == [tv, tu].map{|x| x.values}
215
+ end
216
+ end
217
+
218
+ shared_examples_for "many_to_many eager_graph limit strategies" do
219
+ specify "should correctly handle limits and offsets when eager loading many_to_many associations" do
220
+ tu, tv = @other_tags.call
221
+ al = @pr.call.first
222
+ al.add_tag(tu)
223
+ ds = Album.order(:albums__name)
224
+ limit_strategy = {:limit_strategy=>(@els||{})[:eager_limit_strategy]}
225
+
226
+ als = ds.eager_graph_with_options(:first_two_tags, limit_strategy).all
227
+ als.should == [@album, al]
228
+ als.first.first_two_tags.should == [@tag, tu]
229
+ als.last.first_two_tags.should == [tu]
230
+ als.first.first_two_tags.map{|x| x.values}.should == [@tag, tu].map{|x| x.values}
231
+
232
+ als = ds.eager_graph_with_options(:second_two_tags, limit_strategy).all
233
+ als.should == [@album, al]
234
+ als.first.second_two_tags.should == [tu, tv]
235
+ als.last.second_two_tags.should == []
236
+ als.first.second_two_tags.map{|x| x.values}.should == [tu, tv].map{|x| x.values}
237
+
238
+ als = ds.eager_graph_with_options(:not_first_tags, limit_strategy).all
239
+ als.should == [@album, al]
240
+ als.first.not_first_tags.should == [tu, tv]
241
+ als.last.not_first_tags.should == []
242
+ als.first.not_first_tags.map{|x| x.values}.should == [tu, tv].map{|x| x.values}
243
+
244
+ als = ds.eager_graph_with_options(:last_two_tags, limit_strategy).all
245
+ als.should == [@album, al]
246
+ als.first.last_two_tags.should == [tv, tu]
247
+ als.last.last_two_tags.should == [tu]
248
+ als.first.last_two_tags.map{|x| x.values}.should == [tv, tu].map{|x| x.values}
249
+ end
250
+ end
251
+
252
+ shared_examples_for "many_through_many eager limit strategies" do
253
+ specify "should correctly handle limits and offsets when eager loading many_through_many associations" do
254
+ Artist.many_through_many :first_two_tags, {:clone=>:first_two_tags}.merge(@els) if @els
255
+ Artist.many_through_many :second_two_tags, {:clone=>:second_two_tags}.merge(@els) if @els
256
+ Artist.many_through_many :not_first_tags, {:clone=>:not_first_tags}.merge(@els) if @els
257
+ Artist.many_through_many :last_two_tags, {:clone=>:last_two_tags}.merge(@els) if @els
258
+ @album.update(:artist => @artist)
259
+ tu, tv = @other_tags.call
260
+ al, ar, _ = @pr.call
261
+ al.update(:artist=>ar)
262
+ al.add_tag(tu)
263
+
264
+ ars = Artist.eager(:first_two_tags, :second_two_tags, :not_first_tags, :last_two_tags).order(:name).all
265
+ ars.should == [@artist, ar]
266
+ ars.first.first_two_tags.should == [@tag, tu]
267
+ ars.first.second_two_tags.should == [tu, tv]
268
+ ars.first.not_first_tags.should == [tu, tv]
269
+ ars.first.last_two_tags.should == [tv, tu]
270
+ ars.last.first_two_tags.should == [tu]
271
+ ars.last.second_two_tags.should == []
272
+ ars.last.not_first_tags.should == []
273
+ ars.last.last_two_tags.should == [tu]
274
+
275
+ # Check that no extra columns got added by the eager loading
276
+ ars.first.first_two_tags.map{|x| x.values}.should == [@tag, tu].map{|x| x.values}
277
+ ars.first.second_two_tags.map{|x| x.values}.should == [tu, tv].map{|x| x.values}
278
+ ars.first.not_first_tags.map{|x| x.values}.should == [tu, tv].map{|x| x.values}
279
+ ars.first.last_two_tags.map{|x| x.values}.should == [tv, tu].map{|x| x.values}
280
+ end
281
+ end
282
+
283
+ shared_examples_for "many_through_many eager_graph limit strategies" do
284
+ specify "should correctly handle limits and offsets when eager loading many_through_many associations" do
285
+ @album.update(:artist => @artist)
286
+ tu, tv = @other_tags.call
287
+ al, ar, _ = @pr.call
288
+ al.update(:artist=>ar)
289
+ al.add_tag(tu)
290
+ ds = Artist.order(:artists__name)
291
+ limit_strategy = {:limit_strategy=>@els[:eager_limit_strategy]}
292
+
293
+ ars = ds.eager_graph_with_options(:first_two_tags, limit_strategy).all
294
+ ars.should == [@artist, ar]
295
+ ars.first.first_two_tags.should == [@tag, tu]
296
+ ars.last.first_two_tags.should == [tu]
297
+ ars.first.first_two_tags.map{|x| x.values}.should == [@tag, tu].map{|x| x.values}
298
+
299
+ ars = ds.eager_graph_with_options(:second_two_tags, limit_strategy).all
300
+ ars.should == [@artist, ar]
301
+ ars.first.second_two_tags.should == [tu, tv]
302
+ ars.last.second_two_tags.should == []
303
+ ars.first.second_two_tags.map{|x| x.values}.should == [tu, tv].map{|x| x.values}
304
+
305
+ ars = ds.eager_graph_with_options(:not_first_tags, limit_strategy).all
306
+ ars.should == [@artist, ar]
307
+ ars.first.not_first_tags.should == [tu, tv]
308
+ ars.last.not_first_tags.should == []
309
+ ars.first.not_first_tags.map{|x| x.values}.should == [tu, tv].map{|x| x.values}
310
+
311
+ ars = ds.eager_graph_with_options(:last_two_tags, limit_strategy).all
312
+ ars.should == [@artist, ar]
313
+ ars.first.last_two_tags.should == [tv, tu]
314
+ ars.last.last_two_tags.should == [tu]
315
+ ars.first.last_two_tags.map{|x| x.values}.should == [tv, tu].map{|x| x.values}
316
+ end
317
+ end
318
+
319
+ shared_examples_for "one_through_many eager limit strategies" do
320
+ specify "should correctly handle offsets when eager loading one_through_many associations" do
321
+ Artist.one_through_many :first_tag, {:clone=>:first_tag}.merge(@els) if @els
322
+ Artist.one_through_many :second_tag, {:clone=>:second_tag}.merge(@els) if @els && @els[:eager_limit_strategy] != :distinct_on
323
+ Artist.one_through_many :last_tag, {:clone=>:last_tag}.merge(@els) if @els
324
+ @album.update(:artist => @artist)
325
+ tu, tv = @other_tags.call
326
+ al, ar, _ = @pr.call
327
+ al.update(:artist=>ar)
328
+ al.add_tag(tu)
329
+
330
+ ars = Artist.eager(:first_tag, :second_tag, :last_tag).order(:name).all
331
+ ars.should == [@artist, ar]
332
+ ars.first.first_tag.should == @tag
333
+ ars.first.second_tag.should == tu
334
+ ars.first.last_tag.should == tv
335
+ ars.last.first_tag.should == tu
336
+ ars.last.second_tag.should == nil
337
+ ars.last.last_tag.should == tu
338
+
339
+ # Check that no extra columns got added by the eager loading
340
+ ars.first.first_tag.values.should == @tag.values
341
+ ars.first.second_tag.values.should == tu.values
342
+ ars.first.last_tag.values.should == tv.values
343
+ end
344
+ end
345
+
346
+ shared_examples_for "one_through_many eager_graph limit strategies" do
347
+ specify "should correctly handle offsets when eager graphing one_through_many associations" do
348
+ @album.update(:artist => @artist)
349
+ tu, tv = @other_tags.call
350
+ al, ar, _ = @pr.call
351
+ al.update(:artist=>ar)
352
+ al.add_tag(tu)
353
+ ds = Artist.order(:artists__name)
354
+ limit_strategy = {:limit_strategy=>@els[:eager_limit_strategy]}
355
+
356
+ ars = ds.eager_graph_with_options(:first_tag, limit_strategy).all
357
+ ars.should == [@artist, ar]
358
+ ars.first.first_tag.should == @tag
359
+ ars.last.first_tag.should == tu
360
+ ars.first.first_tag.values.should == @tag.values
361
+
362
+ ars = ds.eager_graph_with_options(:second_tag, @els[:eager_limit_strategy] != :distinct_on ? limit_strategy : {}).all
363
+ ars.should == [@artist, ar]
364
+ ars.first.second_tag.should == tu
365
+ ars.last.second_tag.should == nil
366
+ ars.first.second_tag.values.should == tu.values
367
+
368
+ ars = ds.eager_graph_with_options(:last_tag, limit_strategy).all
369
+ ars.should == [@artist, ar]
370
+ ars.first.last_tag.should == tv
371
+ ars.last.last_tag.should == tu
372
+ ars.first.last_tag.values.should == tv.values
373
+ end
374
+ end
375
+
376
+ shared_examples_for "eager limit strategies" do
377
+ it_should_behave_like "one_to_one eager limit strategies"
378
+ it_should_behave_like "one_to_many eager limit strategies"
379
+ it_should_behave_like "many_to_many eager limit strategies"
380
+ it_should_behave_like "one_through_one eager limit strategies"
381
+ it_should_behave_like "many_through_many eager limit strategies"
382
+ it_should_behave_like "one_through_many eager limit strategies"
383
+ end
384
+
385
+ shared_examples_for "eager_graph limit strategies" do
386
+ it_should_behave_like "one_to_one eager_graph limit strategies"
387
+ it_should_behave_like "one_to_many eager_graph limit strategies"
388
+ it_should_behave_like "many_to_many eager_graph limit strategies"
389
+ it_should_behave_like "one_through_one eager_graph limit strategies"
390
+ it_should_behave_like "many_through_many eager_graph limit strategies"
391
+ it_should_behave_like "one_through_many eager_graph limit strategies"
392
+ end
393
+
394
+ shared_examples_for "filtering/excluding by associations" do
395
+ specify "should handle association inner joins" do
396
+ @Artist.association_join(:albums).all.should == []
397
+ @Artist.association_join(:first_album).all.should == []
398
+ @Album.association_join(:artist).all.should == []
399
+ @Album.association_join(:tags).all.should == []
400
+ @Album.association_join(:alias_tags).all.should == []
401
+ @Tag.association_join(:albums).all.should == []
402
+ unless @no_many_through_many
403
+ @Artist.association_join(:tags).all.should == []
404
+ @Artist.association_join(:first_tag).all.should == []
405
+ end
406
+
407
+ @album.update(:artist => @artist)
408
+ @album.add_tag(@tag)
409
+
410
+ @Artist.association_join(:albums).select_all(:artists).all.should == [@artist]
411
+ @Artist.association_join(:first_album).select_all(:artists).all.should == [@artist]
412
+ @Album.association_join(:artist).select_all(:albums).all.should == [@album]
413
+ @Album.association_join(:tags).select_all(:albums).all.should == [@album]
414
+ @Album.association_join(:alias_tags).select_all(:albums).all.should == [@album]
415
+ @Tag.association_join(:albums).select_all(:tags).all.should == [@tag]
416
+ unless @no_many_through_many
417
+ @Artist.association_join(:tags).select_all(:artists).all.should == [@artist]
418
+ @Artist.association_join(:first_tag).select_all(:artists).all.should == [@artist]
419
+ end
420
+
421
+ @Artist.association_join(:albums).select_all(:albums).naked.all.should == [@album.values]
422
+ @Artist.association_join(:first_album).select_all(:first_album).naked.all.should == [@album.values]
423
+ @Album.association_join(:artist).select_all(:artist).naked.all.should == [@artist.values]
424
+ @Album.association_join(:tags).select_all(:tags).naked.all.should == [@tag.values]
425
+ @Album.association_join(:alias_tags).select_all(:alias_tags).naked.all.should == [@tag.values]
426
+ @Tag.association_join(:albums).select_all(:albums).naked.all.should == [@album.values]
427
+ unless @no_many_through_many
428
+ @Artist.association_join(:tags).select_all(:tags).naked.all.should == [@tag.values]
429
+ @Artist.association_join(:first_tag).select_all(:first_tag).naked.all.should == [@tag.values]
430
+ end
431
+ end
432
+
433
+ specify "should handle association left joins" do
434
+ @Artist.association_left_join(:albums).select_all(:artists).all.should == [@artist]
435
+ @Artist.association_left_join(:first_album).select_all(:artists).all.should == [@artist]
436
+ @Album.association_left_join(:artist).select_all(:albums).all.should == [@album]
437
+ @Album.association_left_join(:tags).select_all(:albums).all.should == [@album]
438
+ @Album.association_left_join(:alias_tags).select_all(:albums).all.should == [@album]
439
+ @Tag.association_left_join(:albums).select_all(:tags).all.should == [@tag]
440
+ unless @no_many_through_many
441
+ @Artist.association_left_join(:tags).select_all(:artists).all.should == [@artist]
442
+ @Artist.association_left_join(:first_tag).select_all(:artists).all.should == [@artist]
443
+ end
444
+
445
+ nil_hash = lambda{|obj| [obj.values.keys.inject({}){|h,k| h[k] = nil; h}]}
446
+ @Artist.association_left_join(:albums).select_all(:albums).naked.all.should == nil_hash[@album]
447
+ @Artist.association_left_join(:first_album).select_all(:first_album).naked.all.should == nil_hash[@album]
448
+ @Album.association_left_join(:artist).select_all(:artist).naked.all.should == nil_hash[@artist]
449
+ @Album.association_left_join(:tags).select_all(:tags).naked.all.should == nil_hash[@tag]
450
+ @Album.association_left_join(:alias_tags).select_all(:alias_tags).naked.all.should == nil_hash[@tag]
451
+ @Tag.association_left_join(:albums).select_all(:albums).naked.all.should == nil_hash[@album]
452
+ unless @no_many_through_many
453
+ @Artist.association_left_join(:tags).select_all(:tags).naked.all.should == nil_hash[@tag]
454
+ @Artist.association_left_join(:first_tag).select_all(:first_tag).naked.all.should == nil_hash[@tag]
455
+ end
456
+
457
+ @album.update(:artist => @artist)
458
+ @album.add_tag(@tag)
459
+
460
+
461
+ @Artist.association_left_join(:albums).select_all(:albums).naked.all.should == [@album.values]
462
+ @Artist.association_left_join(:first_album).select_all(:first_album).naked.all.should == [@album.values]
463
+ @Album.association_left_join(:artist).select_all(:artist).naked.all.should == [@artist.values]
464
+ @Album.association_left_join(:tags).select_all(:tags).naked.all.should == [@tag.values]
465
+ @Album.association_left_join(:alias_tags).select_all(:alias_tags).naked.all.should == [@tag.values]
466
+ @Tag.association_left_join(:albums).select_all(:albums).naked.all.should == [@album.values]
467
+ unless @no_many_through_many
468
+ @Artist.association_left_join(:tags).select_all(:tags).naked.all.should == [@tag.values]
469
+ @Artist.association_left_join(:first_tag).select_all(:first_tag).naked.all.should == [@tag.values]
470
+ end
471
+ end
472
+
473
+ specify "should work correctly when filtering by associations" do
474
+ @album.update(:artist => @artist)
475
+ @album.add_tag(@tag)
476
+
477
+ @Artist.filter(:albums=>@album).all.should == [@artist]
478
+ @Artist.filter(:first_album=>@album).all.should == [@artist]
479
+ unless @no_many_through_many
480
+ @Artist.filter(:tags=>@tag).all.should == [@artist]
481
+ @Artist.filter(:first_tag=>@tag).all.should == [@artist]
482
+ end
483
+ @Album.filter(:artist=>@artist).all.should == [@album]
484
+ @Album.filter(:tags=>@tag).all.should == [@album]
485
+ @Album.filter(:alias_tags=>@tag).all.should == [@album]
486
+ @Tag.filter(:albums=>@album).all.should == [@tag]
487
+ @Album.filter(:artist=>@artist, :tags=>@tag).all.should == [@album]
488
+ @artist.albums_dataset.filter(:tags=>@tag).all.should == [@album]
489
+ end
490
+
491
+ specify "should work correctly when excluding by associations" do
492
+ @album.update(:artist => @artist)
493
+ @album.add_tag(@tag)
494
+ album, artist, tag = @pr.call
495
+
496
+ @Artist.exclude(:albums=>@album).all.should == [artist]
497
+ @Artist.exclude(:first_album=>@album).all.should == [artist]
498
+ unless @no_many_through_many
499
+ @Artist.exclude(:tags=>@tag).all.should == [artist]
500
+ @Artist.exclude(:first_tag=>@tag).all.should == [artist]
501
+ end
502
+ @Album.exclude(:artist=>@artist).all.should == [album]
503
+ @Album.exclude(:tags=>@tag).all.should == [album]
504
+ @Album.exclude(:alias_tags=>@tag).all.should == [album]
505
+ @Tag.exclude(:albums=>@album).all.should == [tag]
506
+ @Album.exclude(:artist=>@artist, :tags=>@tag).all.should == [album]
507
+ end
508
+
509
+ specify "should work correctly when filtering by associations with conditions" do
510
+ @album.update(:artist => @artist)
511
+ @album.add_tag(@tag)
512
+
513
+ @Artist.filter(:a_albums=>@album).all.should == [@artist]
514
+ @Artist.filter(:first_a_album=>@album).all.should == [@artist]
515
+ @album.update(:name=>'Foo')
516
+ @Artist.filter(:a_albums=>@album).all.should == []
517
+ @Artist.filter(:first_a_album=>@album).all.should == []
518
+
519
+ @Album.filter(:a_artist=>@artist).all.should == [@album]
520
+ @artist.update(:name=>'Foo')
521
+ @Album.filter(:a_artist=>@artist).all.should == []
522
+
523
+ @Album.filter(:t_tags=>@tag).all.should == [@album]
524
+ @Album.filter(:alias_t_tags=>@tag).all.should == [@album]
525
+ unless @no_many_through_many
526
+ @Album.filter(:t_tag=>@tag).all.should == [@album]
527
+ @Album.filter(:alias_t_tag=>@tag).all.should == [@album]
528
+ @Artist.filter(:t_tags=>@tag).all.should == [@artist]
529
+ @Artist.filter(:t_tag=>@tag).all.should == [@artist]
530
+ end
531
+ @tag.update(:name=>'Foo')
532
+ @Album.filter(:t_tags=>@tag).all.should == []
533
+ @Album.filter(:alias_t_tags=>@tag).all.should == []
534
+ unless @no_many_through_many
535
+ @Album.filter(:t_tag=>@tag).all.should == []
536
+ @Album.filter(:alias_t_tag=>@tag).all.should == []
537
+ @Artist.filter(:t_tags=>@tag).all.should == []
538
+ @Artist.filter(:t_tag=>@tag).all.should == []
539
+ end
540
+ end
541
+
542
+ specify "should work correctly when excluding by associations with conditions" do
543
+ @album.update(:artist => @artist)
544
+ @album.add_tag(@tag)
545
+
546
+ @Artist.exclude(:a_albums=>@album).all.should == []
547
+ @Artist.exclude(:first_a_album=>@album).all.should == []
548
+ @album.update(:name=>'Foo')
549
+ @Artist.exclude(:a_albums=>@album).all.should == [@artist]
550
+ @Artist.exclude(:first_a_album=>@album).all.should == [@artist]
551
+
552
+ @Album.exclude(:a_artist=>@artist).all.should == []
553
+ @artist.update(:name=>'Foo')
554
+ @Album.exclude(:a_artist=>@artist).all.should == [@album]
555
+
556
+ @Album.exclude(:t_tags=>@tag).all.should == []
557
+ @Album.exclude(:alias_t_tags=>@tag).all.should == []
558
+ unless @no_many_through_many
559
+ @Album.exclude(:t_tag=>@tag).all.should == []
560
+ @Album.exclude(:alias_t_tag=>@tag).all.should == []
561
+ @Artist.exclude(:t_tags=>@tag).all.should == []
562
+ @Artist.exclude(:t_tag=>@tag).all.should == []
563
+ end
564
+ @tag.update(:name=>'Foo')
565
+ @Album.exclude(:t_tags=>@tag).all.should == [@album]
566
+ @Album.exclude(:alias_t_tags=>@tag).all.should == [@album]
567
+ unless @no_many_through_many
568
+ @Album.exclude(:t_tag=>@tag).all.should == [@album]
569
+ @Album.exclude(:alias_t_tag=>@tag).all.should == [@album]
570
+ @Artist.exclude(:t_tags=>@tag).all.should == [@artist]
571
+ @Artist.exclude(:t_tag=>@tag).all.should == [@artist]
572
+ end
573
+ end
574
+
575
+ specify "should work correctly when filtering by multiple associations" do
576
+ album, artist, tag = @pr.call
577
+ @album.update(:artist => @artist)
578
+ @album.add_tag(@tag)
579
+
580
+ @Artist.filter(:albums=>[@album, album]).all.should == [@artist]
581
+ @Artist.filter(:first_album=>[@album, album]).all.should == [@artist]
582
+ @Album.filter(:artist=>[@artist, artist]).all.should == [@album]
583
+ @Album.filter(:tags=>[@tag, tag]).all.should == [@album]
584
+ @Album.filter(:alias_tags=>[@tag, tag]).all.should == [@album]
585
+ @Tag.filter(:albums=>[@album, album]).all.should == [@tag]
586
+ @Album.filter(:artist=>[@artist, artist], :tags=>[@tag, tag]).all.should == [@album]
587
+ @artist.albums_dataset.filter(:tags=>[@tag, tag]).all.should == [@album]
588
+ unless @no_many_through_many
589
+ @Artist.filter(:tags=>[@tag, tag]).all.should == [@artist]
590
+ @Artist.filter(:first_tag=>[@tag, tag]).all.should == [@artist]
591
+ end
592
+
593
+ album.add_tag(tag)
594
+
595
+ @Artist.filter(:albums=>[@album, album]).all.should == [@artist]
596
+ @Artist.filter(:first_album=>[@album, album]).all.should == [@artist]
597
+ @Album.filter(:artist=>[@artist, artist]).all.should == [@album]
598
+ @Album.filter(:tags=>[@tag, tag]).all.sort_by{|x| x.pk}.should == [@album, album]
599
+ @Album.filter(:alias_tags=>[@tag, tag]).all.sort_by{|x| x.pk}.should == [@album, album]
600
+ @Tag.filter(:albums=>[@album, album]).all.sort_by{|x| x.pk}.should == [@tag, tag]
601
+ @Album.filter(:artist=>[@artist, artist], :tags=>[@tag, tag]).all.should == [@album]
602
+ unless @no_many_through_many
603
+ @Artist.filter(:tags=>[@tag, tag]).all.should == [@artist]
604
+ @Artist.filter(:first_tag=>[@tag, tag]).all.should == [@artist]
605
+ end
606
+
607
+ album.update(:artist => artist)
608
+
609
+ @Artist.filter(:albums=>[@album, album]).all.sort_by{|x| x.pk}.should == [@artist, artist]
610
+ @Artist.filter(:first_album=>[@album, album]).all.sort_by{|x| x.pk}.should == [@artist, artist]
611
+ @Album.filter(:artist=>[@artist, artist]).all.sort_by{|x| x.pk}.should == [@album, album]
612
+ @Album.filter(:tags=>[@tag, tag]).all.sort_by{|x| x.pk}.should == [@album, album]
613
+ @Album.filter(:alias_tags=>[@tag, tag]).all.sort_by{|x| x.pk}.should == [@album, album]
614
+ @Tag.filter(:albums=>[@album, album]).all.sort_by{|x| x.pk}.should == [@tag, tag]
615
+ @Album.filter(:artist=>[@artist, artist], :tags=>[@tag, tag]).all.sort_by{|x| x.pk}.should == [@album, album]
616
+ unless @no_many_through_many
617
+ @Artist.filter(:tags=>[@tag, tag]).all.sort_by{|x| x.pk}.should == [@artist, artist]
618
+ @Artist.filter(:first_tag=>[@tag, tag]).all.sort_by{|x| x.pk}.should == [@artist, artist]
619
+ end
620
+ end
621
+
622
+ specify "should work correctly when excluding by multiple associations" do
623
+ album, artist, tag = @pr.call
624
+
625
+ @Artist.exclude(:albums=>[@album, album]).all.sort_by{|x| x.pk}.should == [@artist, artist]
626
+ @Artist.exclude(:first_album=>[@album, album]).all.sort_by{|x| x.pk}.should == [@artist, artist]
627
+ @Album.exclude(:artist=>[@artist, artist]).all.sort_by{|x| x.pk}.should == [@album, album]
628
+ @Album.exclude(:tags=>[@tag, tag]).all.sort_by{|x| x.pk}.should == [@album, album]
629
+ @Album.exclude(:alias_tags=>[@tag, tag]).all.sort_by{|x| x.pk}.should == [@album, album]
630
+ @Tag.exclude(:albums=>[@album, album]).all.sort_by{|x| x.pk}.should == [@tag, tag]
631
+ @Album.exclude(:artist=>[@artist, artist], :tags=>[@tag, tag]).all.sort_by{|x| x.pk}.should == [@album, album]
632
+ unless @no_many_through_many
633
+ @Artist.exclude(:tags=>[@tag, tag]).all.sort_by{|x| x.pk}.should == [@artist, artist]
634
+ @Artist.exclude(:first_tag=>[@tag, tag]).all.sort_by{|x| x.pk}.should == [@artist, artist]
635
+ end
636
+
637
+ @album.update(:artist => @artist)
638
+ @album.add_tag(@tag)
639
+
640
+ @Artist.exclude(:albums=>[@album, album]).all.sort_by{|x| x.pk}.should == [artist]
641
+ @Artist.exclude(:first_album=>[@album, album]).all.sort_by{|x| x.pk}.should == [artist]
642
+ @Album.exclude(:artist=>[@artist, artist]).all.sort_by{|x| x.pk}.should == [album]
643
+ @Album.exclude(:tags=>[@tag, tag]).all.sort_by{|x| x.pk}.should == [album]
644
+ @Album.exclude(:alias_tags=>[@tag, tag]).all.sort_by{|x| x.pk}.should == [album]
645
+ @Tag.exclude(:albums=>[@album, album]).all.sort_by{|x| x.pk}.should == [tag]
646
+ @Album.exclude(:artist=>[@artist, artist], :tags=>[@tag, tag]).all.sort_by{|x| x.pk}.should == [album]
647
+ unless @no_many_through_many
648
+ @Artist.exclude(:tags=>[@tag, tag]).all.should == [artist]
649
+ @Artist.exclude(:first_tag=>[@tag, tag]).all.should == [artist]
650
+ end
651
+
652
+ album.add_tag(tag)
653
+
654
+ @Artist.exclude(:albums=>[@album, album]).all.should == [artist]
655
+ @Artist.exclude(:first_album=>[@album, album]).all.should == [artist]
656
+ @Album.exclude(:artist=>[@artist, artist]).all.should == [album]
657
+ @Album.exclude(:tags=>[@tag, tag]).all.should == []
658
+ @Album.exclude(:alias_tags=>[@tag, tag]).all.should == []
659
+ @Tag.exclude(:albums=>[@album, album]).all.should == []
660
+ @Album.exclude(:artist=>[@artist, artist], :tags=>[@tag, tag]).all.should == [album]
661
+ unless @no_many_through_many
662
+ @Artist.exclude(:tags=>[@tag, tag]).all.should == [artist]
663
+ @Artist.exclude(:first_tag=>[@tag, tag]).all.should == [artist]
664
+ end
665
+
666
+ album.update(:artist => artist)
667
+
668
+ @Artist.exclude(:albums=>[@album, album]).all.should == []
669
+ @Artist.exclude(:first_album=>[@album, album]).all.should == []
670
+ @Album.exclude(:artist=>[@artist, artist]).all.should == []
671
+ @Album.exclude(:tags=>[@tag, tag]).all.should == []
672
+ @Album.exclude(:alias_tags=>[@tag, tag]).all.should == []
673
+ @Tag.exclude(:albums=>[@album, album]).all.should == []
674
+ @Album.exclude(:artist=>[@artist, artist], :tags=>[@tag, tag]).all.should == []
675
+ unless @no_many_through_many
676
+ @Artist.exclude(:tags=>[@tag, tag]).all.should == []
677
+ @Artist.exclude(:first_tag=>[@tag, tag]).all.should == []
678
+ end
679
+ end
680
+
681
+ specify "should work correctly when filtering associations with conditions with multiple objects" do
682
+ album, artist, tag = @pr.call
683
+ album.update(:name=>@album.name)
684
+ artist.update(:name=>@artist.name)
685
+ tag.update(:name=>@tag.name)
686
+
687
+ @album.update(:artist => @artist)
688
+ @album.add_tag(@tag)
689
+ album.update(:artist => @artist)
690
+ tag.add_album(@album)
691
+
692
+ @Artist.filter(:a_albums=>[@album, album]).all.should == [@artist]
693
+ @Artist.filter(:first_a_album=>[@album, album]).all.should == [@artist]
694
+ @album.update(:name=>'Foo')
695
+ @Artist.filter(:a_albums=>[@album, album]).all.should == [@artist]
696
+ @Artist.filter(:first_a_album=>[@album, album]).all.should == [@artist]
697
+ album.update(:name=>'Foo')
698
+ @Artist.filter(:a_albums=>[@album, album]).all.should == []
699
+ @Artist.filter(:first_a_album=>[@album, album]).all.should == []
700
+
701
+ album.update(:artist => nil)
702
+ artist.add_album(@album)
703
+ @Album.filter(:a_artist=>[@artist, artist]).all.should == [@album]
704
+ @artist.update(:name=>'Foo')
705
+ @Album.filter(:a_artist=>[@artist, artist]).all.should == [@album]
706
+ artist.update(:name=>'Foo')
707
+ @Album.filter(:a_artist=>[@artist, artist]).all.should == []
708
+
709
+ @Album.filter(:t_tags=>[@tag, tag]).all.should == [@album]
710
+ @Album.filter(:alias_t_tags=>[@tag, tag]).all.should == [@album]
711
+ unless @no_many_through_many
712
+ @Album.filter(:t_tag=>[@tag, tag]).all.should == [@album]
713
+ @Album.filter(:alias_t_tag=>[@tag, tag]).all.should == [@album]
714
+ @Artist.filter(:t_tags=>[@tag, tag]).all.should == [artist]
715
+ @Artist.filter(:t_tag=>[@tag, tag]).all.should == [artist]
716
+ end
717
+ @tag.update(:name=>'Foo')
718
+ @Album.filter(:t_tags=>[@tag, tag]).all.should == [@album]
719
+ @Album.filter(:alias_t_tags=>[@tag, tag]).all.should == [@album]
720
+ unless @no_many_through_many
721
+ @Album.filter(:t_tag=>[@tag, tag]).all.should == [@album]
722
+ @Album.filter(:alias_t_tag=>[@tag, tag]).all.should == [@album]
723
+ @Artist.filter(:t_tags=>[@tag, tag]).all.should == [artist]
724
+ @Artist.filter(:t_tag=>[@tag, tag]).all.should == [artist]
725
+ end
726
+ tag.update(:name=>'Foo')
727
+ @Album.filter(:t_tags=>[@tag, tag]).all.should == []
728
+ @Album.filter(:alias_t_tags=>[@tag, tag]).all.should == []
729
+ unless @no_many_through_many
730
+ @Album.filter(:t_tag=>[@tag, tag]).all.should == []
731
+ @Album.filter(:alias_t_tag=>[@tag, tag]).all.should == []
732
+ @Artist.filter(:t_tags=>[@tag, tag]).all.should == []
733
+ @Artist.filter(:t_tag=>[@tag, tag]).all.should == []
734
+ end
735
+ end
736
+
737
+ specify "should work correctly when excluding associations with conditions with multiple objects" do
738
+ album, artist, tag = @pr.call
739
+ album.update(:name=>@album.name)
740
+ artist.update(:name=>@artist.name)
741
+ tag.update(:name=>@tag.name)
742
+
743
+ @album.update(:artist => @artist)
744
+ @album.add_tag(@tag)
745
+ album.update(:artist => @artist)
746
+ tag.add_album(@album)
747
+
748
+ artist.add_album(@album)
749
+ @Artist.exclude(:a_albums=>[@album, album]).all.should == []
750
+ @Artist.exclude(:first_a_album=>[@album, album]).all.should == []
751
+ @album.update(:name=>'Foo')
752
+ @Artist.exclude(:a_albums=>[@album, album]).all.should == [artist]
753
+ @Artist.exclude(:first_a_album=>[@album, album]).all.should == [artist]
754
+ album.update(:name=>'Foo')
755
+ @Artist.exclude(:a_albums=>[@album, album]).all.sort_by{|x| x.pk}.should == [@artist, artist]
756
+ @Artist.exclude(:first_a_album=>[@album, album]).all.sort_by{|x| x.pk}.should == [@artist, artist]
757
+
758
+ @Album.exclude(:a_artist=>[@artist, artist]).all.should == []
759
+ album.update(:artist => nil)
760
+ @artist.update(:name=>'Foo')
761
+ @Album.exclude(:a_artist=>[@artist, artist]).all.should == [album]
762
+ artist.update(:name=>'Foo')
763
+ @Album.exclude(:a_artist=>[@artist, artist]).all.sort_by{|x| x.pk}.should == [@album, album]
764
+
765
+ @tag.add_album(album)
766
+ @Album.exclude(:t_tags=>[@tag, tag]).all.should == []
767
+ @Album.exclude(:alias_t_tags=>[@tag, tag]).all.should == []
768
+ unless @no_many_through_many
769
+ @Album.exclude(:t_tag=>[@tag, tag]).all.should == []
770
+ @Album.exclude(:alias_t_tag=>[@tag, tag]).all.should == []
771
+ @Artist.exclude(:t_tags=>[@tag, tag]).all.should == [@artist]
772
+ @Artist.exclude(:t_tag=>[@tag, tag]).all.should == [@artist]
773
+ end
774
+ @tag.update(:name=>'Foo')
775
+ @Album.exclude(:t_tags=>[@tag, tag]).all.should == [album]
776
+ @Album.exclude(:alias_t_tags=>[@tag, tag]).all.should == [album]
777
+ unless @no_many_through_many
778
+ @Album.exclude(:t_tag=>[@tag, tag]).all.should == [album]
779
+ @Album.exclude(:alias_t_tag=>[@tag, tag]).all.should == [album]
780
+ @Artist.exclude(:t_tags=>[@tag, tag]).all.should == [@artist]
781
+ @Artist.exclude(:t_tag=>[@tag, tag]).all.should == [@artist]
782
+ end
783
+ tag.update(:name=>'Foo')
784
+ @Album.exclude(:t_tags=>[@tag, tag]).all.sort_by{|x| x.pk}.should == [@album, album]
785
+ @Album.exclude(:alias_t_tags=>[@tag, tag]).all.sort_by{|x| x.pk}.should == [@album, album]
786
+ unless @no_many_through_many
787
+ @Album.exclude(:t_tag=>[@tag, tag]).all.sort_by{|x| x.pk}.should == [@album, album]
788
+ @Album.exclude(:alias_t_tag=>[@tag, tag]).all.sort_by{|x| x.pk}.should == [@album, album]
789
+ @Artist.exclude(:t_tags=>[@tag, tag]).all.sort_by{|x| x.pk}.should == [@artist, artist]
790
+ @Artist.exclude(:t_tag=>[@tag, tag]).all.sort_by{|x| x.pk}.should == [@artist, artist]
791
+ end
792
+ end
793
+
794
+ specify "should work correctly when excluding by associations in regards to NULL values" do
795
+ @Artist.exclude(:albums=>@album).all.should == [@artist]
796
+ @Artist.exclude(:first_album=>@album).all.should == [@artist]
797
+ @Album.exclude(:artist=>@artist).all.should == [@album]
798
+ @Album.exclude(:tags=>@tag).all.should == [@album]
799
+ @Album.exclude(:alias_tags=>@tag).all.should == [@album]
800
+ @Tag.exclude(:albums=>@album).all.should == [@tag]
801
+ @Album.exclude(:artist=>@artist, :tags=>@tag).all.should == [@album]
802
+
803
+ @Artist.exclude(:a_albums=>@album).all.should == [@artist]
804
+ @Artist.exclude(:first_a_album=>@album).all.should == [@artist]
805
+ @Album.exclude(:a_artist=>@artist).all.should == [@album]
806
+ @Album.exclude(:t_tags=>@tag).all.should == [@album]
807
+ @Album.exclude(:alias_t_tags=>@tag).all.should == [@album]
808
+ unless @no_many_through_many
809
+ @Album.exclude(:t_tag=>@tag).all.should == [@album]
810
+ @Album.exclude(:alias_t_tag=>@tag).all.should == [@album]
811
+ @Artist.exclude(:t_tags=>@tag).all.should == [@artist]
812
+ @Artist.exclude(:t_tag=>@tag).all.should == [@artist]
813
+ end
814
+
815
+ @album.update(:artist => @artist)
816
+ @artist.albums_dataset.exclude(:tags=>@tag).all.should == [@album]
817
+ end
818
+
819
+ specify "should handle NULL values in join table correctly when filtering/excluding many_to_many associations" do
820
+ @ins.call
821
+ @Album.exclude(:tags=>@tag).all.should == [@album]
822
+ @Album.exclude(:alias_tags=>@tag).all.should == [@album]
823
+ @Album.exclude(:t_tags=>@tag).all.should == [@album]
824
+ @Album.exclude(:alias_t_tags=>@tag).all.should == [@album]
825
+ @album.add_tag(@tag)
826
+ @Album.filter(:tags=>@tag).all.should == [@album]
827
+ @Album.filter(:alias_tags=>@tag).all.should == [@album]
828
+ @Album.filter(:t_tags=>@tag).all.should == [@album]
829
+ @Album.filter(:alias_t_tags=>@tag).all.should == [@album]
830
+ album, tag = @pr.call.values_at(0, 2)
831
+ @Album.exclude(:tags=>@tag).all.should == [album]
832
+ @Album.exclude(:alias_tags=>@tag).all.should == [album]
833
+ @Album.exclude(:t_tags=>@tag).all.should == [album]
834
+ @Album.exclude(:alias_t_tags=>@tag).all.should == [album]
835
+ @Album.exclude(:tags=>tag).all.sort_by{|x| x.pk}.should == [@album, album]
836
+ @Album.exclude(:alias_tags=>tag).all.sort_by{|x| x.pk}.should == [@album, album]
837
+ @Album.exclude(:t_tags=>tag).all.sort_by{|x| x.pk}.should == [@album, album]
838
+ @Album.exclude(:alias_t_tags=>tag).all.sort_by{|x| x.pk}.should == [@album, album]
839
+ end
840
+
841
+ specify "should work correctly when filtering by association datasets" do
842
+ album, artist, tag = @pr.call
843
+ @album.update(:artist => @artist)
844
+ @album.add_tag(@tag)
845
+ album.add_tag(tag)
846
+ album.update(:artist => artist)
847
+
848
+ @Artist.filter(:albums=>@Album).all.sort_by{|x| x.pk}.should == [@artist, artist]
849
+ @Artist.filter(:albums=>@Album.filter(Array(Album.primary_key).map{|k| Sequel.qualify(Album.table_name, k)}.zip(Array(album.pk)))).all.sort_by{|x| x.pk}.should == [artist]
850
+ @Artist.filter(:albums=>@Album.filter(1=>0)).all.sort_by{|x| x.pk}.should == []
851
+ @Artist.filter(:first_album=>@Album).all.sort_by{|x| x.pk}.should == [@artist, artist]
852
+ @Artist.filter(:first_album=>@Album.filter(Array(Album.primary_key).map{|k| Sequel.qualify(Album.table_name, k)}.zip(Array(album.pk)))).all.sort_by{|x| x.pk}.should == [artist]
853
+ @Artist.filter(:first_album=>@Album.filter(1=>0)).all.sort_by{|x| x.pk}.should == []
854
+ @Album.filter(:artist=>@Artist).all.sort_by{|x| x.pk}.should == [@album, album]
855
+ @Album.filter(:artist=>@Artist.filter(Array(Artist.primary_key).map{|k| Sequel.qualify(Artist.table_name, k)}.zip(Array(artist.pk)))).all.sort_by{|x| x.pk}.should == [album]
856
+ @Album.filter(:artist=>@Artist.filter(1=>0)).all.sort_by{|x| x.pk}.should == []
857
+ @Album.filter(:tags=>@Tag).all.sort_by{|x| x.pk}.should == [@album, album]
858
+ @Album.filter(:tags=>@Tag.filter(Array(Tag.primary_key).map{|k| Sequel.qualify(Tag.table_name, k)}.zip(Array(tag.pk)))).all.sort_by{|x| x.pk}.should == [album]
859
+ @Album.filter(:tags=>@Tag.filter(1=>0)).all.sort_by{|x| x.pk}.should == []
860
+ @Album.filter(:alias_tags=>@Tag).all.sort_by{|x| x.pk}.should == [@album, album]
861
+ @Album.filter(:alias_tags=>@Tag.filter(Array(Tag.primary_key).map{|k| Sequel.qualify(Tag.table_name, k)}.zip(Array(tag.pk)))).all.sort_by{|x| x.pk}.should == [album]
862
+ @Album.filter(:alias_tags=>@Tag.filter(1=>0)).all.sort_by{|x| x.pk}.should == []
863
+ @Tag.filter(:albums=>@Album).all.sort_by{|x| x.pk}.should == [@tag, tag]
864
+ @Tag.filter(:albums=>@Album.filter(Array(Album.primary_key).map{|k| Sequel.qualify(Album.table_name, k)}.zip(Array(album.pk)))).all.sort_by{|x| x.pk}.should == [tag]
865
+ @Tag.filter(:albums=>@Album.filter(1=>0)).all.sort_by{|x| x.pk}.should == []
866
+
867
+ unless @no_many_through_many
868
+ @Artist.filter(:tags=>@Tag).all.sort_by{|x| x.pk}.should == [@artist, artist]
869
+ @Artist.filter(:tags=>@Tag.filter(Array(Tag.primary_key).map{|k| Sequel.qualify(Tag.table_name, k)}.zip(Array(tag.pk)))).all.sort_by{|x| x.pk}.should == [artist]
870
+ @Artist.filter(:tags=>@Tag.filter(1=>0)).all.sort_by{|x| x.pk}.should == []
871
+ @Artist.filter(:first_tag=>@Tag).all.sort_by{|x| x.pk}.should == [@artist, artist]
872
+ @Artist.filter(:first_tag=>@Tag.filter(Array(Tag.primary_key).map{|k| Sequel.qualify(Tag.table_name, k)}.zip(Array(tag.pk)))).all.sort_by{|x| x.pk}.should == [artist]
873
+ @Artist.filter(:first_tag=>@Tag.filter(1=>0)).all.sort_by{|x| x.pk}.should == []
874
+ end
875
+ end
876
+
877
+ specify "should work correctly when excluding by association datasets" do
878
+ album, artist, tag = @pr.call
879
+ @album.update(:artist => @artist)
880
+ @album.add_tag(@tag)
881
+ album.add_tag(tag)
882
+ album.update(:artist => artist)
883
+
884
+ @Artist.exclude(:albums=>@Album).all.sort_by{|x| x.pk}.should == []
885
+ @Artist.exclude(:albums=>@Album.filter(Array(Album.primary_key).map{|k| Sequel.qualify(Album.table_name, k)}.zip(Array(album.pk)))).all.sort_by{|x| x.pk}.should == [@artist]
886
+ @Artist.exclude(:albums=>@Album.filter(1=>0)).all.sort_by{|x| x.pk}.should == [@artist, artist]
887
+ @Artist.exclude(:first_album=>@Album).all.sort_by{|x| x.pk}.should == []
888
+ @Artist.exclude(:first_album=>@Album.filter(Array(Album.primary_key).map{|k| Sequel.qualify(Album.table_name, k)}.zip(Array(album.pk)))).all.sort_by{|x| x.pk}.should == [@artist]
889
+ @Artist.exclude(:first_album=>@Album.filter(1=>0)).all.sort_by{|x| x.pk}.should == [@artist, artist]
890
+ @Album.exclude(:artist=>@Artist).all.sort_by{|x| x.pk}.should == []
891
+ @Album.exclude(:artist=>@Artist.filter(Array(Artist.primary_key).map{|k| Sequel.qualify(Artist.table_name, k)}.zip(Array(artist.pk)))).all.sort_by{|x| x.pk}.should == [@album]
892
+ @Album.exclude(:artist=>@Artist.filter(1=>0)).all.sort_by{|x| x.pk}.should == [@album, album]
893
+ @Album.exclude(:tags=>@Tag).all.sort_by{|x| x.pk}.should == []
894
+ @Album.exclude(:tags=>@Tag.filter(Array(Tag.primary_key).map{|k| Sequel.qualify(Tag.table_name, k)}.zip(Array(tag.pk)))).all.sort_by{|x| x.pk}.should == [@album]
895
+ @Album.exclude(:tags=>@Tag.filter(1=>0)).all.sort_by{|x| x.pk}.should == [@album, album]
896
+ @Album.exclude(:alias_tags=>@Tag).all.sort_by{|x| x.pk}.should == []
897
+ @Album.exclude(:alias_tags=>@Tag.filter(Array(Tag.primary_key).map{|k| Sequel.qualify(Tag.table_name, k)}.zip(Array(tag.pk)))).all.sort_by{|x| x.pk}.should == [@album]
898
+ @Album.exclude(:alias_tags=>@Tag.filter(1=>0)).all.sort_by{|x| x.pk}.should == [@album, album]
899
+ @Tag.exclude(:albums=>@Album).all.sort_by{|x| x.pk}.should == []
900
+ @Tag.exclude(:albums=>@Album.filter(Array(Album.primary_key).map{|k| Sequel.qualify(Album.table_name, k)}.zip(Array(album.pk)))).all.sort_by{|x| x.pk}.should == [@tag]
901
+ @Tag.exclude(:albums=>@Album.filter(1=>0)).all.sort_by{|x| x.pk}.should == [@tag, tag]
902
+
903
+ unless @no_many_through_many
904
+ @Artist.exclude(:tags=>@Tag).all.sort_by{|x| x.pk}.should == []
905
+ @Artist.exclude(:tags=>@Tag.filter(Array(Tag.primary_key).map{|k| Sequel.qualify(Tag.table_name, k)}.zip(Array(tag.pk)))).all.sort_by{|x| x.pk}.should == [@artist]
906
+ @Artist.exclude(:tags=>@Tag.filter(1=>0)).all.sort_by{|x| x.pk}.should == [@artist, artist]
907
+ @Artist.exclude(:first_tag=>@Tag).all.sort_by{|x| x.pk}.should == []
908
+ @Artist.exclude(:first_tag=>@Tag.filter(Array(Tag.primary_key).map{|k| Sequel.qualify(Tag.table_name, k)}.zip(Array(tag.pk)))).all.sort_by{|x| x.pk}.should == [@artist]
909
+ @Artist.exclude(:first_tag=>@Tag.filter(1=>0)).all.sort_by{|x| x.pk}.should == [@artist, artist]
910
+ end
911
+ end
912
+
913
+ specify "should work correctly when filtering by association datasets with conditions" do
914
+ album, artist, tag = @pr.call
915
+ @album.update(:artist => @artist)
916
+ @album.add_tag(@tag)
917
+ album.add_tag(tag)
918
+ album.update(:artist => artist)
919
+
920
+ @Artist.filter(:a_albums=>@Album).all.sort_by{|x| x.pk}.should == [@artist]
921
+ @Artist.filter(:first_a_album=>@Album).all.sort_by{|x| x.pk}.should == [@artist]
922
+ @Album.filter(:a_artist=>@Artist).all.sort_by{|x| x.pk}.should == [@album]
923
+ @Album.filter(:t_tags=>@Tag).all.sort_by{|x| x.pk}.should == [@album]
924
+ @Album.filter(:alias_t_tags=>@Tag).all.sort_by{|x| x.pk}.should == [@album]
925
+ unless @no_many_through_many
926
+ @Album.filter(:t_tag=>@Tag).all.sort_by{|x| x.pk}.should == [@album]
927
+ @Album.filter(:alias_t_tag=>@Tag).all.sort_by{|x| x.pk}.should == [@album]
928
+ @Artist.filter(:t_tags=>@Tag).all.sort_by{|x| x.pk}.should == [@artist]
929
+ @Artist.filter(:t_tag=>@Tag).all.sort_by{|x| x.pk}.should == [@artist]
930
+ end
931
+
932
+ artist.update(:name=>@artist.name)
933
+ album.update(:name=>@album.name)
934
+ tag.update(:name=>@tag.name)
935
+
936
+ @Artist.filter(:a_albums=>@Album).all.sort_by{|x| x.pk}.should == [@artist, artist]
937
+ @Artist.filter(:first_a_album=>@Album).all.sort_by{|x| x.pk}.should == [@artist, artist]
938
+ @Album.filter(:a_artist=>@Artist).all.sort_by{|x| x.pk}.should == [@album, album]
939
+ @Album.filter(:t_tags=>@Tag).all.sort_by{|x| x.pk}.should == [@album, album]
940
+ @Album.filter(:alias_t_tags=>@Tag).all.sort_by{|x| x.pk}.should == [@album, album]
941
+ unless @no_many_through_many
942
+ @Album.filter(:t_tag=>@Tag).all.sort_by{|x| x.pk}.should == [@album, album]
943
+ @Album.filter(:alias_t_tag=>@Tag).all.sort_by{|x| x.pk}.should == [@album, album]
944
+ @Artist.filter(:t_tags=>@Tag).all.sort_by{|x| x.pk}.should == [@artist, artist]
945
+ @Artist.filter(:t_tag=>@Tag).all.sort_by{|x| x.pk}.should == [@artist, artist]
946
+ end
947
+
948
+ @Artist.filter(:a_albums=>@Album.filter(Array(Album.primary_key).map{|k| Sequel.qualify(Album.table_name, k)}.zip(Array(album.pk)))).all.sort_by{|x| x.pk}.should == [artist]
949
+ @Artist.filter(:first_a_album=>@Album.filter(Array(Album.primary_key).map{|k| Sequel.qualify(Album.table_name, k)}.zip(Array(album.pk)))).all.sort_by{|x| x.pk}.should == [artist]
950
+ @Album.filter(:a_artist=>@Artist.filter(Array(Artist.primary_key).map{|k| Sequel.qualify(Artist.table_name, k)}.zip(Array(artist.pk)))).all.sort_by{|x| x.pk}.should == [album]
951
+ @Album.filter(:t_tags=>@Tag.filter(Array(Tag.primary_key).map{|k| Sequel.qualify(Tag.table_name, k)}.zip(Array(tag.pk)))).all.sort_by{|x| x.pk}.should == [album]
952
+ @Album.filter(:alias_t_tags=>@Tag.filter(Array(Tag.primary_key).map{|k| Sequel.qualify(Tag.table_name, k)}.zip(Array(tag.pk)))).all.sort_by{|x| x.pk}.should == [album]
953
+ unless @no_many_through_many
954
+ @Album.filter(:t_tag=>@Tag.filter(Array(Tag.primary_key).map{|k| Sequel.qualify(Tag.table_name, k)}.zip(Array(tag.pk)))).all.sort_by{|x| x.pk}.should == [album]
955
+ @Album.filter(:alias_t_tag=>@Tag.filter(Array(Tag.primary_key).map{|k| Sequel.qualify(Tag.table_name, k)}.zip(Array(tag.pk)))).all.sort_by{|x| x.pk}.should == [album]
956
+ @Artist.filter(:t_tags=>@Tag.filter(Array(Tag.primary_key).map{|k| Sequel.qualify(Tag.table_name, k)}.zip(Array(tag.pk)))).all.sort_by{|x| x.pk}.should == [artist]
957
+ @Artist.filter(:t_tag=>@Tag.filter(Array(Tag.primary_key).map{|k| Sequel.qualify(Tag.table_name, k)}.zip(Array(tag.pk)))).all.sort_by{|x| x.pk}.should == [artist]
958
+ end
959
+
960
+ @Artist.filter(:a_albums=>@Album.filter(1=>0)).all.sort_by{|x| x.pk}.should == []
961
+ @Artist.filter(:first_a_album=>@Album.filter(1=>0)).all.sort_by{|x| x.pk}.should == []
962
+ @Album.filter(:a_artist=>@Artist.filter(1=>0)).all.sort_by{|x| x.pk}.should == []
963
+ @Album.filter(:t_tags=>@Tag.filter(Array(Tag.primary_key).map{|k| Sequel.qualify(Tag.table_name, k)}.zip(Array(tag.pk)))).all.sort_by{|x| x.pk}.should == [album]
964
+ @Album.filter(:t_tags=>@Tag.filter(1=>0)).all.sort_by{|x| x.pk}.should == []
965
+ @Album.filter(:alias_t_tags=>@Tag.filter(1=>0)).all.sort_by{|x| x.pk}.should == []
966
+ unless @no_many_through_many
967
+ @Album.filter(:t_tag=>@Tag.filter(Array(Tag.primary_key).map{|k| Sequel.qualify(Tag.table_name, k)}.zip(Array(tag.pk)))).all.sort_by{|x| x.pk}.should == [album]
968
+ @Album.filter(:t_tag=>@Tag.filter(1=>0)).all.sort_by{|x| x.pk}.should == []
969
+ @Album.filter(:alias_t_tag=>@Tag.filter(1=>0)).all.sort_by{|x| x.pk}.should == []
970
+ @Artist.filter(:t_tags=>@Tag.filter(1=>0)).all.sort_by{|x| x.pk}.should == []
971
+ @Artist.filter(:t_tag=>@Tag.filter(1=>0)).all.sort_by{|x| x.pk}.should == []
972
+ end
973
+ end
974
+
975
+ specify "should work correctly when excluding by association datasets with conditions" do
976
+ album, artist, tag = @pr.call
977
+ @album.update(:artist => @artist)
978
+ @album.add_tag(@tag)
979
+ album.add_tag(tag)
980
+ album.update(:artist => artist)
981
+
982
+ @Artist.exclude(:a_albums=>@Album).all.sort_by{|x| x.pk}.should == [artist]
983
+ @Artist.exclude(:first_a_album=>@Album).all.sort_by{|x| x.pk}.should == [artist]
984
+ @Album.exclude(:a_artist=>@Artist).all.sort_by{|x| x.pk}.should == [album]
985
+ @Album.exclude(:t_tags=>@Tag).all.sort_by{|x| x.pk}.should == [album]
986
+ @Album.exclude(:alias_t_tags=>@Tag).all.sort_by{|x| x.pk}.should == [album]
987
+ unless @no_many_through_many
988
+ @Album.exclude(:t_tag=>@Tag).all.sort_by{|x| x.pk}.should == [album]
989
+ @Album.exclude(:alias_t_tag=>@Tag).all.sort_by{|x| x.pk}.should == [album]
990
+ @Artist.exclude(:t_tags=>@Tag).all.sort_by{|x| x.pk}.should == [artist]
991
+ @Artist.exclude(:t_tag=>@Tag).all.sort_by{|x| x.pk}.should == [artist]
992
+ end
993
+
994
+ artist.update(:name=>@artist.name)
995
+ album.update(:name=>@album.name)
996
+ tag.update(:name=>@tag.name)
997
+
998
+ @Artist.exclude(:a_albums=>@Album).all.sort_by{|x| x.pk}.should == []
999
+ @Artist.exclude(:first_a_album=>@Album).all.sort_by{|x| x.pk}.should == []
1000
+ @Album.exclude(:a_artist=>@Artist).all.sort_by{|x| x.pk}.should == []
1001
+ @Album.exclude(:t_tags=>@Tag).all.sort_by{|x| x.pk}.should == []
1002
+ @Album.exclude(:alias_t_tags=>@Tag).all.sort_by{|x| x.pk}.should == []
1003
+ unless @no_many_through_many
1004
+ @Album.exclude(:t_tag=>@Tag).all.sort_by{|x| x.pk}.should == []
1005
+ @Album.exclude(:alias_t_tag=>@Tag).all.sort_by{|x| x.pk}.should == []
1006
+ @Artist.exclude(:t_tags=>@Tag).all.sort_by{|x| x.pk}.should == []
1007
+ @Artist.exclude(:t_tag=>@Tag).all.sort_by{|x| x.pk}.should == []
1008
+ end
1009
+
1010
+ @Artist.exclude(:a_albums=>@Album.filter(Array(Album.primary_key).map{|k| Sequel.qualify(Album.table_name, k)}.zip(Array(album.pk)))).all.sort_by{|x| x.pk}.should == [@artist]
1011
+ @Artist.exclude(:first_a_album=>@Album.filter(Array(Album.primary_key).map{|k| Sequel.qualify(Album.table_name, k)}.zip(Array(album.pk)))).all.sort_by{|x| x.pk}.should == [@artist]
1012
+ @Album.exclude(:a_artist=>@Artist.filter(Array(Artist.primary_key).map{|k| Sequel.qualify(Artist.table_name, k)}.zip(Array(artist.pk)))).all.sort_by{|x| x.pk}.should == [@album]
1013
+ @Album.exclude(:t_tags=>@Tag.filter(Array(Tag.primary_key).map{|k| Sequel.qualify(Tag.table_name, k)}.zip(Array(tag.pk)))).all.sort_by{|x| x.pk}.should == [@album]
1014
+ @Album.exclude(:alias_t_tags=>@Tag.filter(Array(Tag.primary_key).map{|k| Sequel.qualify(Tag.table_name, k)}.zip(Array(tag.pk)))).all.sort_by{|x| x.pk}.should == [@album]
1015
+ unless @no_many_through_many
1016
+ @Album.exclude(:t_tag=>@Tag.filter(Array(Tag.primary_key).map{|k| Sequel.qualify(Tag.table_name, k)}.zip(Array(tag.pk)))).all.sort_by{|x| x.pk}.should == [@album]
1017
+ @Album.exclude(:alias_t_tag=>@Tag.filter(Array(Tag.primary_key).map{|k| Sequel.qualify(Tag.table_name, k)}.zip(Array(tag.pk)))).all.sort_by{|x| x.pk}.should == [@album]
1018
+ @Artist.exclude(:t_tags=>@Tag.filter(Array(Tag.primary_key).map{|k| Sequel.qualify(Tag.table_name, k)}.zip(Array(tag.pk)))).all.sort_by{|x| x.pk}.should == [@artist]
1019
+ @Artist.exclude(:t_tag=>@Tag.filter(Array(Tag.primary_key).map{|k| Sequel.qualify(Tag.table_name, k)}.zip(Array(tag.pk)))).all.sort_by{|x| x.pk}.should == [@artist]
1020
+ end
1021
+
1022
+ @Artist.exclude(:a_albums=>@Album.filter(1=>0)).all.sort_by{|x| x.pk}.should == [@artist, artist]
1023
+ @Artist.exclude(:first_a_album=>@Album.filter(1=>0)).all.sort_by{|x| x.pk}.should == [@artist, artist]
1024
+ @Album.exclude(:a_artist=>@Artist.filter(1=>0)).all.sort_by{|x| x.pk}.should == [@album, album]
1025
+ @Album.exclude(:t_tags=>@Tag.filter(1=>0)).all.sort_by{|x| x.pk}.should == [@album, album]
1026
+ @Album.exclude(:alias_t_tags=>@Tag.filter(1=>0)).all.sort_by{|x| x.pk}.should == [@album, album]
1027
+ unless @no_many_through_many
1028
+ @Album.exclude(:t_tag=>@Tag.filter(1=>0)).all.sort_by{|x| x.pk}.should == [@album, album]
1029
+ @Album.exclude(:alias_t_tag=>@Tag.filter(1=>0)).all.sort_by{|x| x.pk}.should == [@album, album]
1030
+ @Artist.exclude(:t_tags=>@Tag.filter(1=>0)).all.sort_by{|x| x.pk}.should == [@artist, artist]
1031
+ @Artist.exclude(:t_tag=>@Tag.filter(1=>0)).all.sort_by{|x| x.pk}.should == [@artist, artist]
1032
+ end
1033
+ end
1034
+ end
1035
+
1036
+ shared_examples_for "filter by associations one_to_one limit strategies" do
1037
+ specify "filter by associations with limited one_to_one associations should work correctly" do
1038
+ Artist.one_to_one :first_album, {:clone=>:first_album}.merge(@els)
1039
+ Artist.one_to_one :last_album, {:clone=>:last_album}.merge(@els)
1040
+ Artist.one_to_one :second_album, {:clone=>:second_album}.merge(@els)
1041
+ @album.update(:artist => @artist)
1042
+ diff_album = @diff_album.call
1043
+ ar = @pr.call[1]
1044
+ ds = Artist.order(:name)
1045
+
1046
+ ds.where(:first_album=>@album).all.should == [@artist]
1047
+ ds.where(:first_album=>diff_album).all.should == []
1048
+ ds.exclude(:first_album=>@album).all.should == [ar]
1049
+ ds.exclude(:first_album=>diff_album).all.should == [@artist, ar]
1050
+
1051
+ if @els[:eager_limit_strategy] != :distinct_on && (@els[:eager_limit_strategy] != :correlated_subquery || Album.dataset.supports_offsets_in_correlated_subqueries?)
1052
+ ds.where(:second_album=>@album).all.should == []
1053
+ ds.where(:second_album=>diff_album).all.should == [@artist]
1054
+ ds.exclude(:second_album=>@album).all.should == [@artist, ar]
1055
+ ds.exclude(:second_album=>diff_album).all.should == [ar]
1056
+ end
1057
+
1058
+ ds.where(:last_album=>@album).all.should == []
1059
+ ds.where(:last_album=>diff_album).all.should == [@artist]
1060
+ ds.exclude(:last_album=>@album).all.should == [@artist, ar]
1061
+ ds.exclude(:last_album=>diff_album).all.should == [ar]
1062
+
1063
+ Artist.one_to_one :first_album, :clone=>:first_album do |ads| ads.where(:albums__name=>diff_album.name) end
1064
+ ar.add_album(diff_album)
1065
+ ds.where(:first_album=>[@album, diff_album]).all.should == [ar]
1066
+ ds.exclude(:first_album=>[@album, diff_album]).all.should == [@artist]
1067
+ end
1068
+ end
1069
+
1070
+ shared_examples_for "filter by associations singular association limit strategies" do
1071
+ it_should_behave_like "filter by associations one_to_one limit strategies"
1072
+
1073
+ specify "dataset associations with limited one_to_one associations should work correctly" do
1074
+ Artist.one_to_one :first_album, {:clone=>:first_album}.merge(@els)
1075
+ Artist.one_to_one :last_album, {:clone=>:last_album}.merge(@els)
1076
+ Artist.one_to_one :second_album, {:clone=>:second_album}.merge(@els) if @els[:eager_limit_strategy] != :distinct_on
1077
+ @album.update(:artist => @artist)
1078
+ diff_album = @diff_album.call
1079
+ ar = @pr.call[1]
1080
+ ds = Artist
1081
+
1082
+ ds.where(@artist.pk_hash).first_albums.all.should == [@album]
1083
+ ds.where(@artist.pk_hash).second_albums.all.should == [diff_album]
1084
+ ds.where(@artist.pk_hash).last_albums.all.should == [diff_album]
1085
+ ds.where(ar.pk_hash).first_albums.all.should == []
1086
+ ds.where(ar.pk_hash).second_albums.all.should == []
1087
+ ds.where(ar.pk_hash).last_albums.all.should == []
1088
+
1089
+ Artist.one_to_one :first_album, :clone=>:first_album do |ads| ads.where(:albums__name=>diff_album.name) end
1090
+ ar.add_album(diff_album)
1091
+ ds.where(@artist.pk_hash).first_albums.all.should == []
1092
+ ds.where(ar.pk_hash).first_albums.all.should == [diff_album]
1093
+ end
1094
+
1095
+ specify "filter by associations with limited one_through_one associations should work correctly" do
1096
+ Album.one_through_one :first_tag, {:clone=>:first_tag}.merge(@els)
1097
+ Album.one_through_one :second_tag, {:clone=>:second_tag}.merge(@els) if @els[:eager_limit_strategy] != :distinct_on
1098
+ Album.one_through_one :last_tag, {:clone=>:last_tag}.merge(@els)
1099
+ tu, tv = @other_tags.call
1100
+ al = @pr.call.first
1101
+ ds = Album.order(:name)
1102
+ al.add_tag(tu)
1103
+
1104
+ ds.where(:first_tag=>@tag).all.should == [@album]
1105
+ ds.where(:first_tag=>tu).all.should == [al]
1106
+ ds.where(:first_tag=>tv).all.should == []
1107
+ ds.exclude(:first_tag=>@tag).all.should == [al]
1108
+ ds.exclude(:first_tag=>tu).all.should == [@album]
1109
+ ds.exclude(:first_tag=>tv).all.should == [@album, al]
1110
+
1111
+ ds.where(:second_tag=>@tag).all.should == []
1112
+ ds.where(:second_tag=>tu).all.should == [@album]
1113
+ ds.where(:second_tag=>tv).all.should == []
1114
+ ds.exclude(:second_tag=>@tag).all.should == [@album, al]
1115
+ ds.exclude(:second_tag=>tu).all.should == [al]
1116
+ ds.exclude(:second_tag=>tv).all.should == [@album, al]
1117
+
1118
+ ds.where(:last_tag=>@tag).all.should == []
1119
+ ds.where(:last_tag=>tu).all.should == [al]
1120
+ ds.where(:last_tag=>tv).all.should == [@album]
1121
+ ds.exclude(:last_tag=>@tag).all.should == [@album, al]
1122
+ ds.exclude(:last_tag=>tu).all.should == [@album]
1123
+ ds.exclude(:last_tag=>tv).all.should == [al]
1124
+
1125
+ Album.one_through_one :first_tag, :clone=>:first_tag do |ads| ads.where(:tags__name=>tu.name) end
1126
+ Album.one_through_one :second_tag, :clone=>:second_tag do |ads| ads.where(:tags__name=>[tu.name, tv.name]) end
1127
+
1128
+ ds.where(:first_tag=>[@tag, tu]).all.should == [@album, al]
1129
+ ds.exclude(:first_tag=>[@tag, tu]).all.should == []
1130
+
1131
+ al.add_tag(tv)
1132
+ ds.where(:second_tag=>[tv, tu]).all.should == [@album, al]
1133
+ ds.exclude(:second_tag=>[tv, tu]).all.should == []
1134
+ end
1135
+
1136
+ specify "dataset associations with limited one_through_one associations should work correctly" do
1137
+ Album.one_through_one :first_tag, {:clone=>:first_tag}.merge(@els)
1138
+ Album.one_through_one :second_tag, {:clone=>:second_tag}.merge(@els) if @els[:eager_limit_strategy] != :distinct_on
1139
+ Album.one_through_one :last_tag, {:clone=>:last_tag}.merge(@els)
1140
+ tu, tv = @other_tags.call
1141
+ al = @pr.call.first
1142
+ ds = Album
1143
+ al.add_tag(tu)
1144
+
1145
+ ds.where(@album.pk_hash).first_tags.all.should == [@tag]
1146
+ ds.where(@album.pk_hash).second_tags.all.should == [tu]
1147
+ ds.where(@album.pk_hash).last_tags.all.should == [tv]
1148
+ ds.where(al.pk_hash).first_tags.all.should == [tu]
1149
+ ds.where(al.pk_hash).second_tags.all.should == []
1150
+ ds.where(al.pk_hash).last_tags.all.should == [tu]
1151
+
1152
+ Album.one_through_one :first_tag, :clone=>:first_tag do |ads| ads.where(:tags__name=>tu.name) end
1153
+ Album.one_through_one :second_tag, :clone=>:second_tag do |ads| ads.where(:tags__name=>[tu.name, tv.name]) end
1154
+
1155
+ ds.where(@album.pk_hash).first_tags.all.should == [tu]
1156
+ ds.where(@album.pk_hash).second_tags.all.should == [tv]
1157
+ ds.where(al.pk_hash).first_tags.all.should == [tu]
1158
+ ds.where(al.pk_hash).second_tags.all.should == []
1159
+
1160
+ al.add_tag(tv)
1161
+ ds.where(@album.pk_hash).first_tags.all.should == [tu]
1162
+ ds.where(@album.pk_hash).second_tags.all.should == [tv]
1163
+ ds.where(al.pk_hash).first_tags.all.should == [tu]
1164
+ ds.where(al.pk_hash).second_tags.all.should == [tv]
1165
+ end
1166
+
1167
+ specify "filter by associations with limited one_through_many associations should work correctly" do
1168
+ Artist.one_through_many :first_tag, {:clone=>:first_tag}.merge(@els)
1169
+ Artist.one_through_many :second_tag, {:clone=>:second_tag}.merge(@els) if @els[:eager_limit_strategy] != :distinct_on
1170
+ Artist.one_through_many :last_tag, {:clone=>:last_tag}.merge(@els)
1171
+ @album.update(:artist => @artist)
1172
+ tu, tv = @other_tags.call
1173
+ al, ar, _ = @pr.call
1174
+ al.update(:artist=>ar)
1175
+ al.add_tag(tu)
1176
+ ds = Artist.order(:name)
1177
+
1178
+ ds.where(:first_tag=>@tag).all.should == [@artist]
1179
+ ds.where(:first_tag=>tu).all.should == [ar]
1180
+ ds.where(:first_tag=>tv).all.should == []
1181
+ ds.exclude(:first_tag=>@tag).all.should == [ar]
1182
+ ds.exclude(:first_tag=>tu).all.should == [@artist]
1183
+ ds.exclude(:first_tag=>tv).all.should == [@artist, ar]
1184
+
1185
+ ds.where(:second_tag=>@tag).all.should == []
1186
+ ds.where(:second_tag=>tu).all.should == [@artist]
1187
+ ds.where(:second_tag=>tv).all.should == []
1188
+ ds.exclude(:second_tag=>@tag).all.should == [@artist, ar]
1189
+ ds.exclude(:second_tag=>tu).all.should == [ar]
1190
+ ds.exclude(:second_tag=>tv).all.should == [@artist, ar]
1191
+
1192
+ ds.where(:last_tag=>@tag).all.should == []
1193
+ ds.where(:last_tag=>tu).all.should == [ar]
1194
+ ds.where(:last_tag=>tv).all.should == [@artist]
1195
+ ds.exclude(:last_tag=>@tag).all.should == [@artist, ar]
1196
+ ds.exclude(:last_tag=>tu).all.should == [@artist]
1197
+ ds.exclude(:last_tag=>tv).all.should == [ar]
1198
+
1199
+ Artist.one_through_many :first_tag, :clone=>:first_tag do |ads| ads.where(:tags__name=>tu.name) end
1200
+ Artist.one_through_many :second_tag, :clone=>:second_tag do |ads| ads.where(:tags__name=>[tu.name, tv.name]) end
1201
+
1202
+ ds.where(:first_tag=>[@tag, tu]).all.should == [@artist, ar]
1203
+ ds.exclude(:first_tag=>[@tag, tu]).all.should == []
1204
+
1205
+ al.add_tag(tv)
1206
+ ds.where(:second_tag=>[tv, tu]).all.should == [@artist, ar]
1207
+ ds.exclude(:second_tag=>[tv, tu]).all.should == []
1208
+ end
1209
+
1210
+ specify "dataset associations with limited one_through_many associations should work correctly" do
1211
+ Artist.one_through_many :first_tag, {:clone=>:first_tag}.merge(@els)
1212
+ Artist.one_through_many :second_tag, {:clone=>:second_tag}.merge(@els) if @els[:eager_limit_strategy] != :distinct_on
1213
+ Artist.one_through_many :last_tag, {:clone=>:last_tag}.merge(@els)
1214
+ @album.update(:artist => @artist)
1215
+ tu, tv = @other_tags.call
1216
+ al, ar, _ = @pr.call
1217
+ al.update(:artist=>ar)
1218
+ al.add_tag(tu)
1219
+ ds = Artist.order(:name)
1220
+
1221
+ ds.where(@artist.pk_hash).first_tags.all.should == [@tag]
1222
+ ds.where(@artist.pk_hash).second_tags.all.should == [tu]
1223
+ ds.where(@artist.pk_hash).last_tags.all.should == [tv]
1224
+ ds.where(ar.pk_hash).first_tags.all.should == [tu]
1225
+ ds.where(ar.pk_hash).second_tags.all.should == []
1226
+ ds.where(ar.pk_hash).last_tags.all.should == [tu]
1227
+
1228
+ Artist.one_through_many :first_tag, :clone=>:first_tag do |ads| ads.where(:tags__name=>tu.name) end
1229
+ Artist.one_through_many :second_tag, :clone=>:second_tag do |ads| ads.where(:tags__name=>[tu.name, tv.name]) end
1230
+
1231
+ ds.where(@artist.pk_hash).first_tags.all.should == [tu]
1232
+ ds.where(@artist.pk_hash).second_tags.all.should == [tv]
1233
+ ds.where(ar.pk_hash).first_tags.all.should == [tu]
1234
+ ds.where(ar.pk_hash).second_tags.all.should == []
1235
+
1236
+ al.add_tag(tv)
1237
+ ds.where(@artist.pk_hash).first_tags.all.should == [tu]
1238
+ ds.where(@artist.pk_hash).second_tags.all.should == [tv]
1239
+ ds.where(ar.pk_hash).first_tags.all.should == [tu]
1240
+ ds.where(ar.pk_hash).second_tags.all.should == [tv]
1241
+ end
1242
+ end
1243
+
1244
+ shared_examples_for "filter by associations one_to_many limit strategies" do
1245
+ specify "filter by associations with limited one_to_many associations should work correctly" do
1246
+ Artist.one_to_many :first_two_albums, {:clone=>:first_two_albums}.merge(@els)
1247
+ Artist.one_to_many :second_two_albums, {:clone=>:second_two_albums}.merge(@els)
1248
+ Artist.one_to_many :not_first_albums, {:clone=>:not_first_albums}.merge(@els)
1249
+ Artist.one_to_many :last_two_albums, {:clone=>:last_two_albums}.merge(@els)
1250
+ @album.update(:artist => @artist)
1251
+ middle_album = @middle_album.call
1252
+ diff_album = @diff_album.call
1253
+ ar = @pr.call[1]
1254
+ ds = Artist.order(:name)
1255
+
1256
+ ds.where(:first_two_albums=>@album).all.should == [@artist]
1257
+ ds.where(:first_two_albums=>middle_album).all.should == [@artist]
1258
+ ds.where(:first_two_albums=>diff_album).all.should == []
1259
+ ds.exclude(:first_two_albums=>@album).all.should == [ar]
1260
+ ds.exclude(:first_two_albums=>middle_album).all.should == [ar]
1261
+ ds.exclude(:first_two_albums=>diff_album).all.should == [@artist, ar]
1262
+
1263
+ assocs = if @els[:eager_limit_strategy] != :correlated_subquery || Album.dataset.supports_offsets_in_correlated_subqueries?
1264
+ [:second_two_albums, :not_first_albums, :last_two_albums]
1265
+ else
1266
+ [:last_two_albums]
1267
+ end
1268
+
1269
+ assocs.each do |a|
1270
+ ds.where(a=>@album).all.should == []
1271
+ ds.where(a=>middle_album).all.should == [@artist]
1272
+ ds.where(a=>diff_album).all.should == [@artist]
1273
+ ds.exclude(a=>@album).all.should == [@artist, ar]
1274
+ ds.exclude(a=>middle_album).all.should == [ar]
1275
+ ds.exclude(a=>diff_album).all.should == [ar]
1276
+ end
1277
+
1278
+ Artist.one_to_one :first_two_albums, :clone=>:first_two_albums do |ads| ads.where(:albums__name=>diff_album.name) end
1279
+ ar.add_album(diff_album)
1280
+ ds.where(:first_two_albums=>[@album, diff_album]).all.should == [ar]
1281
+ ds.exclude(:first_two_albums=>[@album, diff_album]).all.should == [@artist]
1282
+ end
1283
+ end
1284
+
1285
+ shared_examples_for "filter by associations limit strategies" do
1286
+ it_should_behave_like "filter by associations singular association limit strategies"
1287
+ it_should_behave_like "filter by associations one_to_many limit strategies"
1288
+
1289
+ specify "dataset associations with limited one_to_many associations should work correctly" do
1290
+ Artist.one_to_many :first_two_albums, {:clone=>:first_two_albums}.merge(@els)
1291
+ Artist.one_to_many :second_two_albums, {:clone=>:second_two_albums}.merge(@els)
1292
+ Artist.one_to_many :not_first_albums, {:clone=>:not_first_albums}.merge(@els)
1293
+ Artist.one_to_many :last_two_albums, {:clone=>:last_two_albums}.merge(@els)
1294
+ @album.update(:artist => @artist)
1295
+ middle_album = @middle_album.call
1296
+ diff_album = @diff_album.call
1297
+ ar = @pr.call[1]
1298
+ ds = Artist.order(:name)
1299
+
1300
+ ds.where(@artist.pk_hash).first_two_albums.all.should == [@album, middle_album]
1301
+ ds.where(@artist.pk_hash).second_two_albums.all.should == [middle_album, diff_album]
1302
+ ds.where(@artist.pk_hash).not_first_albums.all.should == [middle_album, diff_album]
1303
+ ds.where(@artist.pk_hash).last_two_albums.all.should == [diff_album, middle_album]
1304
+ ds.where(ar.pk_hash).first_two_albums.all.should == []
1305
+ ds.where(ar.pk_hash).second_two_albums.all.should == []
1306
+ ds.where(ar.pk_hash).not_first_albums.all.should == []
1307
+ ds.where(ar.pk_hash).last_two_albums.all.should == []
1308
+
1309
+ Artist.one_to_one :first_two_albums, :clone=>:first_two_albums do |ads| ads.where(:albums__name=>[diff_album.name, middle_album.name]) end
1310
+ ar.add_album(diff_album)
1311
+ ds.where(@artist.pk_hash).first_two_albums.all.should == [middle_album]
1312
+ ds.where(ar.pk_hash).first_two_albums.all.should == [diff_album]
1313
+ end
1314
+
1315
+ specify "filter by associations with limited many_to_many associations should work correctly" do
1316
+ Album.send :many_to_many, :first_two_tags, {:clone=>:first_two_tags}.merge(@els)
1317
+ Album.send :many_to_many, :second_two_tags, {:clone=>:second_two_tags}.merge(@els)
1318
+ Album.send :many_to_many, :not_first_tags, {:clone=>:not_first_tags}.merge(@els)
1319
+ Album.send :many_to_many, :last_two_tags, {:clone=>:last_two_tags}.merge(@els)
1320
+ tu, tv = @other_tags.call
1321
+ al = @pr.call.first
1322
+ al.add_tag(tu)
1323
+ ds = Album.order(:name)
1324
+
1325
+ ds.where(:first_two_tags=>@tag).all.should == [@album]
1326
+ ds.where(:first_two_tags=>tu).all.should == [@album, al]
1327
+ ds.where(:first_two_tags=>tv).all.should == []
1328
+ ds.exclude(:first_two_tags=>@tag).all.should == [al]
1329
+ ds.exclude(:first_two_tags=>tu).all.should == []
1330
+ ds.exclude(:first_two_tags=>tv).all.should == [@album, al]
1331
+
1332
+ ds.where(:second_two_tags=>@tag).all.should == []
1333
+ ds.where(:second_two_tags=>tu).all.should == [@album]
1334
+ ds.where(:second_two_tags=>tv).all.should == [@album]
1335
+ ds.exclude(:second_two_tags=>@tag).all.should == [@album, al]
1336
+ ds.exclude(:second_two_tags=>tu).all.should == [al]
1337
+ ds.exclude(:second_two_tags=>tv).all.should == [al]
1338
+
1339
+ ds.where(:not_first_tags=>@tag).all.should == []
1340
+ ds.where(:not_first_tags=>tu).all.should == [@album]
1341
+ ds.where(:not_first_tags=>tv).all.should == [@album]
1342
+ ds.exclude(:not_first_tags=>@tag).all.should == [@album, al]
1343
+ ds.exclude(:not_first_tags=>tu).all.should == [al]
1344
+ ds.exclude(:not_first_tags=>tv).all.should == [al]
1345
+
1346
+ ds.where(:last_two_tags=>@tag).all.should == []
1347
+ ds.where(:last_two_tags=>tu).all.should == [@album, al]
1348
+ ds.where(:last_two_tags=>tv).all.should == [@album]
1349
+ ds.exclude(:last_two_tags=>@tag).all.should == [@album, al]
1350
+ ds.exclude(:last_two_tags=>tu).all.should == []
1351
+ ds.exclude(:last_two_tags=>tv).all.should == [al]
1352
+
1353
+ Album.many_to_many :first_two_tags, :clone=>:first_two_tags do |ads| ads.where(:tags__name=>tu.name) end
1354
+ Album.many_to_many :second_two_tags, :clone=>:second_two_tags do |ads| ads.where(:tags__name=>[tu.name, tv.name]) end
1355
+
1356
+ ds.where(:first_two_tags=>[@tag, tu]).all.should == [@album, al]
1357
+ ds.exclude(:first_two_tags=>[@tag, tu]).all.should == []
1358
+
1359
+ al.add_tag(tv)
1360
+ ds.where(:second_two_tags=>[tv, tu]).all.should == [@album, al]
1361
+ ds.exclude(:second_two_tags=>[tv, tu]).all.should == []
1362
+ end
1363
+
1364
+ specify "dataset associations with limited many_to_many associations should work correctly" do
1365
+ Album.send :many_to_many, :first_two_tags, {:clone=>:first_two_tags}.merge(@els)
1366
+ Album.send :many_to_many, :second_two_tags, {:clone=>:second_two_tags}.merge(@els)
1367
+ Album.send :many_to_many, :not_first_tags, {:clone=>:not_first_tags}.merge(@els)
1368
+ Album.send :many_to_many, :last_two_tags, {:clone=>:last_two_tags}.merge(@els)
1369
+ tu, tv = @other_tags.call
1370
+ al = @pr.call.first
1371
+ al.add_tag(tu)
1372
+ ds = Album.order(:name)
1373
+
1374
+ ds.where(@album.pk_hash).first_two_tags.all.should == [@tag, tu]
1375
+ ds.where(@album.pk_hash).second_two_tags.all.should == [tu, tv]
1376
+ ds.where(@album.pk_hash).not_first_tags.all.should == [tu, tv]
1377
+ ds.where(@album.pk_hash).last_two_tags.all.should == [tv, tu]
1378
+ ds.where(al.pk_hash).first_two_tags.all.should == [tu]
1379
+ ds.where(al.pk_hash).second_two_tags.all.should == []
1380
+ ds.where(al.pk_hash).not_first_tags.all.should == []
1381
+ ds.where(al.pk_hash).last_two_tags.all.should == [tu]
1382
+
1383
+ Album.many_to_many :first_two_tags, :clone=>:first_two_tags do |ads| ads.where(:tags__name=>tu.name) end
1384
+ Album.many_to_many :second_two_tags, :clone=>:second_two_tags do |ads| ads.where(:tags__name=>[tu.name, tv.name]) end
1385
+
1386
+ ds.where(@album.pk_hash).first_two_tags.all.should == [tu]
1387
+ ds.where(@album.pk_hash).second_two_tags.all.should == [tv]
1388
+ ds.where(al.pk_hash).first_two_tags.all.should == [tu]
1389
+ ds.where(al.pk_hash).second_two_tags.all.should == []
1390
+
1391
+ al.add_tag(tv)
1392
+ ds.where(@album.pk_hash).first_two_tags.all.should == [tu]
1393
+ ds.where(@album.pk_hash).second_two_tags.all.should == [tv]
1394
+ ds.where(al.pk_hash).first_two_tags.all.should == [tu]
1395
+ ds.where(al.pk_hash).second_two_tags.all.should == [tv]
1396
+ end
1397
+
1398
+ specify "filter by associations with limited many_through_many associations should work correctly" do
1399
+ Artist.many_through_many :first_two_tags, {:clone=>:first_two_tags}.merge(@els)
1400
+ Artist.many_through_many :second_two_tags, {:clone=>:second_two_tags}.merge(@els)
1401
+ Artist.many_through_many :not_first_tags, {:clone=>:not_first_tags}.merge(@els)
1402
+ Artist.many_through_many :last_two_tags, {:clone=>:last_two_tags}.merge(@els)
1403
+ @album.update(:artist => @artist)
1404
+ tu, tv = @other_tags.call
1405
+ al, ar, _ = @pr.call
1406
+ al.update(:artist=>ar)
1407
+ al.add_tag(tu)
1408
+ ds = Artist.order(:name)
1409
+
1410
+ ds.where(:first_two_tags=>@tag).all.should == [@artist]
1411
+ ds.where(:first_two_tags=>tu).all.should == [@artist, ar]
1412
+ ds.where(:first_two_tags=>tv).all.should == []
1413
+ ds.exclude(:first_two_tags=>@tag).all.should == [ar]
1414
+ ds.exclude(:first_two_tags=>tu).all.should == []
1415
+ ds.exclude(:first_two_tags=>tv).all.should == [@artist, ar]
1416
+
1417
+ ds.where(:second_two_tags=>@tag).all.should == []
1418
+ ds.where(:second_two_tags=>tu).all.should == [@artist]
1419
+ ds.where(:second_two_tags=>tv).all.should == [@artist]
1420
+ ds.exclude(:second_two_tags=>@tag).all.should == [@artist, ar]
1421
+ ds.exclude(:second_two_tags=>tu).all.should == [ar]
1422
+ ds.exclude(:second_two_tags=>tv).all.should == [ar]
1423
+
1424
+ ds.where(:not_first_tags=>@tag).all.should == []
1425
+ ds.where(:not_first_tags=>tu).all.should == [@artist]
1426
+ ds.where(:not_first_tags=>tv).all.should == [@artist]
1427
+ ds.exclude(:not_first_tags=>@tag).all.should == [@artist, ar]
1428
+ ds.exclude(:not_first_tags=>tu).all.should == [ar]
1429
+ ds.exclude(:not_first_tags=>tv).all.should == [ar]
1430
+
1431
+ ds.where(:last_two_tags=>@tag).all.should == []
1432
+ ds.where(:last_two_tags=>tu).all.should == [@artist, ar]
1433
+ ds.where(:last_two_tags=>tv).all.should == [@artist]
1434
+ ds.exclude(:last_two_tags=>@tag).all.should == [@artist, ar]
1435
+ ds.exclude(:last_two_tags=>tu).all.should == []
1436
+ ds.exclude(:last_two_tags=>tv).all.should == [ar]
1437
+
1438
+ Artist.many_through_many :first_two_tags, :clone=>:first_tag do |ads| ads.where(:tags__name=>tu.name) end
1439
+ Artist.many_through_many :second_two_tags, :clone=>:first_tag do |ads| ads.where(:tags__name=>[tv.name, tu.name]) end
1440
+
1441
+ ds.where(:first_two_tags=>[@tag, tu]).all.should == [@artist, ar]
1442
+ ds.exclude(:first_two_tags=>[@tag, tu]).all.should == []
1443
+
1444
+ al.add_tag(tv)
1445
+ ds.where(:second_two_tags=>[tv, tu]).all.should == [@artist, ar]
1446
+ ds.exclude(:second_two_tags=>[tv, tu]).all.should == []
1447
+ end
1448
+
1449
+ specify "dataset associations with limited many_through_many associations should work correctly" do
1450
+ Artist.many_through_many :first_two_tags, {:clone=>:first_two_tags}.merge(@els)
1451
+ Artist.many_through_many :second_two_tags, {:clone=>:second_two_tags}.merge(@els)
1452
+ Artist.many_through_many :not_first_tags, {:clone=>:not_first_tags}.merge(@els)
1453
+ Artist.many_through_many :last_two_tags, {:clone=>:last_two_tags}.merge(@els)
1454
+ @album.update(:artist => @artist)
1455
+ tu, tv = @other_tags.call
1456
+ al, ar, _ = @pr.call
1457
+ al.update(:artist=>ar)
1458
+ al.add_tag(tu)
1459
+ ds = Artist.order(:name)
1460
+
1461
+ ds.where(@artist.pk_hash).first_two_tags.all.should == [@tag, tu]
1462
+ ds.where(@artist.pk_hash).second_two_tags.all.should == [tu, tv]
1463
+ ds.where(@artist.pk_hash).not_first_tags.all.should == [tu, tv]
1464
+ ds.where(@artist.pk_hash).last_two_tags.all.should == [tv, tu]
1465
+ ds.where(ar.pk_hash).first_two_tags.all.should == [tu]
1466
+ ds.where(ar.pk_hash).second_two_tags.all.should == []
1467
+ ds.where(ar.pk_hash).not_first_tags.all.should == []
1468
+ ds.where(ar.pk_hash).last_two_tags.all.should == [tu]
1469
+
1470
+ Artist.many_through_many :first_two_tags, :clone=>:first_two_tags do |ads| ads.where(:tags__name=>tu.name) end
1471
+ Artist.many_through_many :second_two_tags, :clone=>:second_two_tags do |ads| ads.where(:tags__name=>[tu.name, tv.name]) end
1472
+
1473
+ ds.where(@artist.pk_hash).first_two_tags.all.should == [tu]
1474
+ ds.where(@artist.pk_hash).second_two_tags.all.should == [tv]
1475
+ ds.where(ar.pk_hash).first_two_tags.all.should == [tu]
1476
+ ds.where(ar.pk_hash).second_two_tags.all.should == []
1477
+
1478
+ al.add_tag(tv)
1479
+ ds.where(@artist.pk_hash).first_two_tags.all.should == [tu]
1480
+ ds.where(@artist.pk_hash).second_two_tags.all.should == [tv]
1481
+ ds.where(ar.pk_hash).first_two_tags.all.should == [tu]
1482
+ ds.where(ar.pk_hash).second_two_tags.all.should == [tv]
1483
+ end
1484
+ end
1485
+
1486
+ shared_examples_for "basic regular and composite key associations" do
1487
+ specify "should return no objects if none are associated" do
1488
+ @album.artist.should == nil
1489
+ @artist.first_album.should == nil
1490
+ @artist.albums.should == []
1491
+ @album.tags.should == []
1492
+ @album.alias_tags.should == []
1493
+ @tag.albums.should == []
1494
+ end
1495
+
1496
+ specify "should have add and set methods work any associated objects" do
1497
+ @album.update(:artist => @artist)
1498
+ @album.add_tag(@tag)
1499
+
1500
+ @album.reload
1501
+ @artist.reload
1502
+ @tag.reload
1503
+
1504
+ @album.artist.should == @artist
1505
+ @artist.first_album.should == @album
1506
+ @artist.albums.should == [@album]
1507
+ @album.tags.should == [@tag]
1508
+ @album.alias_tags.should == [@tag]
1509
+ @tag.albums.should == [@album]
1510
+ end
1511
+
1512
+ specify "should work correctly with prepared_statements_association plugin" do
1513
+ @album.update(:artist => @artist)
1514
+ @album.add_tag(@tag)
1515
+
1516
+ @album.reload
1517
+ @artist.reload
1518
+ @tag.reload
1519
+
1520
+ [Tag, Album, Artist].each{|x| x.plugin :prepared_statements_associations}
1521
+ @album.artist.should == @artist
1522
+ @artist.first_album.should == @album
1523
+ @artist.albums.should == [@album]
1524
+ @album.tags.should == [@tag]
1525
+ @album.alias_tags.should == [@tag]
1526
+ @tag.albums.should == [@album]
1527
+ end
1528
+
1529
+ specify "should have working dataset associations" do
1530
+ album, artist, tag = @pr.call
1531
+
1532
+ Tag.albums.all.should == []
1533
+ Album.artists.all.should == []
1534
+ Album.tags.all.should == []
1535
+ Album.alias_tags.all.should == []
1536
+ Artist.albums.all.should == []
1537
+ unless @no_many_through_many
1538
+ Album.first_tags.all.should == []
1539
+ Artist.tags.all.should == []
1540
+ Artist.first_tags.all.should == []
1541
+ end
1542
+ Artist.albums.tags.all.should == []
1543
+
1544
+ @album.update(:artist => @artist)
1545
+ @album.add_tag(@tag)
1546
+
1547
+ Tag.albums.all.should == [@album]
1548
+ Album.artists.all.should == [@artist]
1549
+ Album.tags.all.should == [@tag]
1550
+ Album.alias_tags.all.should == [@tag]
1551
+ Artist.albums.all.should == [@album]
1552
+ unless @no_many_through_many
1553
+ Album.first_tags.all.should == [@tag]
1554
+ Artist.tags.all.should == [@tag]
1555
+ Artist.first_tags.all.should == [@tag]
1556
+ end
1557
+ Artist.albums.tags.all.should == [@tag]
1558
+
1559
+ album.add_tag(tag)
1560
+ album.update(:artist => artist)
1561
+
1562
+ Tag.albums.order(:name).all.should == [@album, album]
1563
+ Album.artists.order(:name).all.should == [@artist, artist]
1564
+ Album.tags.order(:name).all.should == [@tag, tag]
1565
+ Album.alias_tags.order(:name).all.should == [@tag, tag]
1566
+ Artist.albums.order(:name).all.should == [@album, album]
1567
+ unless @no_many_through_many
1568
+ Album.first_tags.order(:name).all.should == [@tag, tag]
1569
+ Artist.tags.order(:name).all.should == [@tag, tag]
1570
+ Artist.first_tags.order(:name).all.should == [@tag, tag]
1571
+ end
1572
+ Artist.albums.tags.order(:name).all.should == [@tag, tag]
1573
+
1574
+ Tag.filter(Tag.qualified_primary_key_hash(tag.pk)).albums.all.should == [album]
1575
+ Album.filter(Album.qualified_primary_key_hash(album.pk)).artists.all.should == [artist]
1576
+ Album.filter(Album.qualified_primary_key_hash(album.pk)).tags.all.should == [tag]
1577
+ Album.filter(Album.qualified_primary_key_hash(album.pk)).alias_tags.all.should == [tag]
1578
+ Artist.filter(Artist.qualified_primary_key_hash(artist.pk)).albums.all.should == [album]
1579
+ unless @no_many_through_many
1580
+ Album.filter(Album.qualified_primary_key_hash(album.pk)).first_tags.all.should == [tag]
1581
+ Artist.filter(Artist.qualified_primary_key_hash(artist.pk)).tags.all.should == [tag]
1582
+ Artist.filter(Artist.qualified_primary_key_hash(artist.pk)).first_tags.all.should == [tag]
1583
+ end
1584
+ Artist.filter(Artist.qualified_primary_key_hash(artist.pk)).albums.tags.all.should == [tag]
1585
+
1586
+ Artist.filter(Artist.qualified_primary_key_hash(artist.pk)).albums.filter(Album.qualified_primary_key_hash(album.pk)).tags.all.should == [tag]
1587
+ Artist.filter(Artist.qualified_primary_key_hash(@artist.pk)).albums.filter(Album.qualified_primary_key_hash(@album.pk)).tags.all.should == [@tag]
1588
+ Artist.filter(Artist.qualified_primary_key_hash(@artist.pk)).albums.filter(Album.qualified_primary_key_hash(album.pk)).tags.all.should == []
1589
+ Artist.filter(Artist.qualified_primary_key_hash(artist.pk)).albums.filter(Album.qualified_primary_key_hash(@album.pk)).tags.all.should == []
1590
+ end
1591
+
1592
+ specify "should have remove methods work" do
1593
+ @album.update(:artist => @artist)
1594
+ @album.add_tag(@tag)
1595
+
1596
+ @album.update(:artist => nil)
1597
+ @album.remove_tag(@tag)
1598
+
1599
+ @album.add_alias_tag(@tag)
1600
+ @album.remove_alias_tag(@tag)
1601
+
1602
+ @album.reload
1603
+ @artist.reload
1604
+ @tag.reload
1605
+
1606
+ @album.artist.should == nil
1607
+ @artist.albums.should == []
1608
+ @album.tags.should == []
1609
+ @tag.albums.should == []
1610
+
1611
+ @album.add_alias_tag(@tag)
1612
+ @album.remove_alias_tag(@tag)
1613
+
1614
+ @album.reload
1615
+ @album.alias_tags.should == []
1616
+ end
1617
+
1618
+ specify "should have remove_all methods work" do
1619
+ @artist.add_album(@album)
1620
+ @album.add_tag(@tag)
1621
+
1622
+ @album.remove_all_tags
1623
+ @artist.remove_all_albums
1624
+
1625
+ @album.reload
1626
+ @artist.reload
1627
+ @tag.reload
1628
+
1629
+ @album.artist.should == nil
1630
+ @artist.albums.should == []
1631
+ @album.tags.should == []
1632
+ @tag.albums.should == []
1633
+
1634
+ @album.add_alias_tag(@tag)
1635
+ @album.remove_all_alias_tags
1636
+
1637
+ @album.reload
1638
+ @album.alias_tags.should == []
1639
+ end
1640
+
1641
+ specify "should eager load via eager correctly" do
1642
+ @album.update(:artist => @artist)
1643
+ @album.add_tag(@tag)
1644
+
1645
+ a = Artist.eager(:albums=>[:tags, :alias_tags]).eager(:first_album).all
1646
+ a.should == [@artist]
1647
+ a.first.albums.should == [@album]
1648
+ a.first.first_album.should == @album
1649
+ a.first.albums.first.tags.should == [@tag]
1650
+ a.first.albums.first.alias_tags.should == [@tag]
1651
+
1652
+ a = Tag.eager(:albums=>:artist).all
1653
+ a.should == [@tag]
1654
+ a.first.albums.should == [@album]
1655
+ a.first.albums.first.artist.should == @artist
1656
+ end
1657
+
1658
+ specify "should eager load via eager_graph correctly" do
1659
+ @album.update(:artist => @artist)
1660
+ @album.add_tag(@tag)
1661
+
1662
+ a = Artist.eager_graph(:albums=>[:tags, :alias_tags]).eager_graph(:first_album).all
1663
+ a.should == [@artist]
1664
+ a.first.albums.should == [@album]
1665
+ a.first.first_album.should == @album
1666
+ a.first.albums.first.tags.should == [@tag]
1667
+ a.first.albums.first.alias_tags.should == [@tag]
1668
+
1669
+ a = Tag.eager_graph(:albums=>:artist).all
1670
+ a.should == [@tag]
1671
+ a.first.albums.should == [@album]
1672
+ a.first.albums.first.artist.should == @artist
1673
+ end
1674
+
1675
+ describe "when filtering/excluding by associations" do
1676
+ before do
1677
+ @Artist = Artist.dataset
1678
+ @Album = Album.dataset
1679
+ @Tag = Tag.dataset
1680
+ end
1681
+
1682
+ it_should_behave_like "filtering/excluding by associations"
1683
+ end
1684
+ end
1685
+
1686
+ shared_examples_for "regular and composite key associations" do
1687
+ it_should_behave_like "basic regular and composite key associations"
1688
+
1689
+ describe "when filtering/excluding by associations when joining" do
1690
+ def self_join(c)
1691
+ c.join(Sequel.as(c.table_name, :b), Array(c.primary_key).zip(Array(c.primary_key))).select_all(c.table_name)
1692
+ end
1693
+
1694
+ before do
1695
+ @Artist = self_join(Artist)
1696
+ @Album = self_join(Album)
1697
+ @Tag = self_join(Tag)
1698
+ end
1699
+
1700
+ it_should_behave_like "filtering/excluding by associations"
1701
+ end
1702
+
1703
+ describe "with default/union :eager_limit_strategy" do
1704
+ before do
1705
+ @els = {}
1706
+ end
1707
+ it_should_behave_like "eager limit strategies"
1708
+ end
1709
+
1710
+ describe "with :eager_limit_strategy=>:ruby" do
1711
+ before do
1712
+ @els = {:eager_limit_strategy=>:ruby}
1713
+ end
1714
+ it_should_behave_like "eager limit strategies"
1715
+ it_should_behave_like "eager_graph limit strategies"
1716
+ end
1717
+
1718
+ describe "with :eager_limit_strategy=>:distinct_on" do
1719
+ before do
1720
+ @els = {:eager_limit_strategy=>:distinct_on}
1721
+ end
1722
+ it_should_behave_like "one_to_one eager limit strategies"
1723
+ it_should_behave_like "one_through_one eager limit strategies"
1724
+ it_should_behave_like "one_through_many eager limit strategies"
1725
+ it_should_behave_like "one_to_one eager_graph limit strategies"
1726
+ it_should_behave_like "one_through_one eager_graph limit strategies"
1727
+ it_should_behave_like "one_through_many eager_graph limit strategies"
1728
+ it_should_behave_like "filter by associations singular association limit strategies"
1729
+ end if DB.dataset.supports_ordered_distinct_on?
1730
+
1731
+ describe "with :eager_limit_strategy=>:window_function" do
1732
+ before do
1733
+ @els = {:eager_limit_strategy=>:window_function}
1734
+ end
1735
+ it_should_behave_like "eager limit strategies"
1736
+ it_should_behave_like "eager_graph limit strategies"
1737
+ it_should_behave_like "filter by associations limit strategies"
1738
+ end if DB.dataset.supports_window_functions?
1739
+
1740
+ specify "should work with a many_through_many association" do
1741
+ @album.update(:artist => @artist)
1742
+ @album.add_tag(@tag)
1743
+
1744
+ @album.reload
1745
+ @artist.reload
1746
+ @tag.reload
1747
+
1748
+ @album.tags.should == [@tag]
1749
+
1750
+ a = Artist.eager(:tags).all
1751
+ a.should == [@artist]
1752
+ a.first.tags.should == [@tag]
1753
+
1754
+ a = Artist.eager_graph(:tags).all
1755
+ a.should == [@artist]
1756
+ a.first.tags.should == [@tag]
1757
+
1758
+ a = Album.eager(:artist=>:tags).all
1759
+ a.should == [@album]
1760
+ a.first.artist.should == @artist
1761
+ a.first.artist.tags.should == [@tag]
1762
+
1763
+ a = Album.eager_graph(:artist=>:tags).all
1764
+ a.should == [@album]
1765
+ a.first.artist.should == @artist
1766
+ a.first.artist.tags.should == [@tag]
1767
+ end
1768
+
1769
+ specify "should work with a one_through_many association" do
1770
+ @album.update(:artist => @artist)
1771
+ @album.add_tag(@tag)
1772
+
1773
+ @album.reload
1774
+ @artist.reload
1775
+ @tag.reload
1776
+
1777
+ @album.tags.should == [@tag]
1778
+
1779
+ a = Artist.eager(:first_tag).all
1780
+ a.should == [@artist]
1781
+ a.first.first_tag.should == @tag
1782
+
1783
+ a = Artist.eager_graph(:first_tag).all
1784
+ a.should == [@artist]
1785
+ a.first.first_tag.should == @tag
1786
+
1787
+ a = Album.eager(:artist=>:first_tag).all
1788
+ a.should == [@album]
1789
+ a.first.artist.should == @artist
1790
+ a.first.artist.first_tag.should == @tag
1791
+
1792
+ a = Album.eager_graph(:artist=>:first_tag).all
1793
+ a.should == [@album]
1794
+ a.first.artist.should == @artist
1795
+ a.first.artist.first_tag.should == @tag
1796
+ end
1797
+ end
1798
+
1799
+ describe "Sequel::Model Simple Associations" do
1800
+ before(:all) do
1801
+ @db = DB
1802
+ @db.drop_table?(:albums_tags, :tags, :albums, :artists)
1803
+ @db.create_table(:artists) do
1804
+ primary_key :id
1805
+ String :name
1806
+ end
1807
+ @db.create_table(:albums) do
1808
+ primary_key :id
1809
+ String :name
1810
+ foreign_key :artist_id, :artists
1811
+ end
1812
+ @db.create_table(:tags) do
1813
+ primary_key :id
1814
+ String :name
1815
+ end
1816
+ @db.create_table(:albums_tags) do
1817
+ foreign_key :album_id, :albums
1818
+ foreign_key :tag_id, :tags
1819
+ end
1820
+ end
1821
+ before do
1822
+ [:albums_tags, :tags, :albums, :artists].each{|t| @db[t].delete}
1823
+ class ::Artist < Sequel::Model(@db)
1824
+ plugin :dataset_associations
1825
+ one_to_many :albums, :order=>:name
1826
+ one_to_one :first_album, :clone=>:albums
1827
+ one_to_one :second_album, :clone=>:albums, :limit=>[nil, 1]
1828
+ one_to_one :last_album, :class=>:Album, :order=>Sequel.desc(:name)
1829
+ one_to_many :first_two_albums, :clone=>:albums, :limit=>2
1830
+ one_to_many :second_two_albums, :clone=>:albums, :limit=>[2, 1]
1831
+ one_to_many :not_first_albums, :clone=>:albums, :limit=>[nil, 1]
1832
+ one_to_many :last_two_albums, :class=>:Album, :order=>Sequel.desc(:name), :limit=>2
1833
+ one_to_many :a_albums, :clone=>:albums, :conditions=>{:name=>'Al'}
1834
+ one_to_one :first_a_album, :clone=>:a_albums
1835
+ plugin :many_through_many
1836
+ many_through_many :tags, [[:albums, :artist_id, :id], [:albums_tags, :album_id, :tag_id]]
1837
+ many_through_many :first_two_tags, :clone=>:tags, :order=>:tags__name, :limit=>2, :graph_order=>:name
1838
+ many_through_many :second_two_tags, :clone=>:tags, :order=>:tags__name, :limit=>[2, 1], :graph_order=>:name
1839
+ many_through_many :not_first_tags, :clone=>:tags, :order=>:tags__name, :limit=>[nil, 1], :graph_order=>:name
1840
+ many_through_many :last_two_tags, :clone=>:tags, :order=>Sequel.desc(:tags__name), :limit=>2, :graph_order=>Sequel.desc(:name)
1841
+ many_through_many :t_tags, :clone=>:tags, :conditions=>{:tags__name=>'T'}
1842
+ one_through_many :first_tag, [[:albums, :artist_id, :id], [:albums_tags, :album_id, :tag_id]], :order=>:tags__name, :graph_order=>:name, :class=>:Tag
1843
+ one_through_many :second_tag, :clone=>:first_tag, :limit=>[nil, 1]
1844
+ one_through_many :last_tag, :clone=>:first_tag, :order=>Sequel.desc(:tags__name), :graph_order=>Sequel.desc(:name)
1845
+ one_through_many :t_tag, :clone=>:first_tag, :conditions=>{:tags__name=>'T'}
1846
+ end
1847
+ class ::Album < Sequel::Model(@db)
1848
+ plugin :dataset_associations
1849
+ many_to_one :artist, :reciprocal=>nil
1850
+ many_to_one :a_artist, :clone=>:artist, :conditions=>{:name=>'Ar'}, :key=>:artist_id
1851
+ many_to_many :tags, :right_key=>:tag_id
1852
+ many_to_many :alias_tags, :clone=>:tags, :join_table=>:albums_tags___at
1853
+ many_to_many :first_two_tags, :clone=>:tags, :order=>:name, :limit=>2
1854
+ many_to_many :second_two_tags, :clone=>:tags, :order=>:name, :limit=>[2, 1]
1855
+ many_to_many :not_first_tags, :clone=>:tags, :order=>:name, :limit=>[nil, 1]
1856
+ many_to_many :last_two_tags, :clone=>:tags, :order=>Sequel.desc(:name), :limit=>2
1857
+ many_to_many :t_tags, :clone=>:tags, :conditions=>{:name=>'T'}
1858
+ many_to_many :alias_t_tags, :clone=>:t_tags, :join_table=>:albums_tags___at
1859
+ one_through_one :first_tag, :clone=>:tags, :order=>:name
1860
+ one_through_one :second_tag, :clone=>:first_tag, :limit=>[nil, 1]
1861
+ one_through_one :last_tag, :clone=>:tags, :order=>Sequel.desc(:name)
1862
+ one_through_one :t_tag, :clone=>:t_tags
1863
+ one_through_one :alias_t_tag, :clone=>:alias_t_tags
1864
+ end
1865
+ class ::Tag < Sequel::Model(@db)
1866
+ plugin :dataset_associations
1867
+ many_to_many :albums
1868
+ end
1869
+ @album = Album.create(:name=>'Al')
1870
+ @artist = Artist.create(:name=>'Ar')
1871
+ @tag = Tag.create(:name=>'T')
1872
+ @same_album = lambda{Album.create(:name=>'Al', :artist_id=>@artist.id)}
1873
+ @diff_album = lambda{Album.create(:name=>'lA', :artist_id=>@artist.id)}
1874
+ @middle_album = lambda{Album.create(:name=>'Bl', :artist_id=>@artist.id)}
1875
+ @other_tags = lambda{t = [Tag.create(:name=>'U'), Tag.create(:name=>'V')]; @db[:albums_tags].insert([:album_id, :tag_id], Tag.select(@album.id, :id)); t}
1876
+ @pr = lambda{[Album.create(:name=>'Al2'),Artist.create(:name=>'Ar2'),Tag.create(:name=>'T2')]}
1877
+ @ins = lambda{@db[:albums_tags].insert(:tag_id=>@tag.id)}
1878
+ end
1879
+ after do
1880
+ [:Tag, :Album, :Artist].each{|x| Object.send(:remove_const, x)}
1881
+ end
1882
+ after(:all) do
1883
+ @db.drop_table?(:albums_tags, :tags, :albums, :artists)
1884
+ end
1885
+
1886
+ it_should_behave_like "regular and composite key associations"
1887
+
1888
+ describe "with :correlated_subquery limit strategy" do
1889
+ before do
1890
+ @els = {:eager_limit_strategy=>:correlated_subquery}
1891
+ end
1892
+
1893
+ it_should_behave_like "one_to_one eager_graph limit strategies"
1894
+ it_should_behave_like "one_to_many eager_graph limit strategies"
1895
+ it_should_behave_like "filter by associations one_to_one limit strategies"
1896
+ it_should_behave_like "filter by associations one_to_many limit strategies"
1897
+ end if DB.dataset.supports_limits_in_correlated_subqueries?
1898
+
1899
+ specify "should handle eager loading limited associations for many objects" do
1900
+ @db[:artists].import([:name], (1..99).map{|i| [i.to_s]})
1901
+ artists = Artist.eager(:albums).all
1902
+ artists.length.should == 100
1903
+ artists.each{|a| a.albums.should == []}
1904
+ artists = Artist.eager(:first_two_albums).all
1905
+ artists.length.should == 100
1906
+ artists.each{|a| a.first_two_albums.should == []}
1907
+ @db[:albums].insert([:artist_id], @db[:artists].select(:id))
1908
+ artists = Artist.eager(:albums).all
1909
+ artists.length.should == 100
1910
+ artists.each{|a| a.albums.length.should == 1}
1911
+ artists = Artist.eager(:first_two_albums).all
1912
+ artists.length.should == 100
1913
+ artists.each{|a| a.first_two_albums.length.should == 1}
1914
+ end
1915
+
1916
+ specify "should handle many_to_one associations with same name as :key" do
1917
+ Album.def_column_alias(:artist_id_id, :artist_id)
1918
+ Album.many_to_one :artist_id, :key_column =>:artist_id, :class=>Artist
1919
+ @album.update(:artist_id_id => @artist.id)
1920
+ @album.artist_id.should == @artist
1921
+
1922
+ as = Album.eager(:artist_id).all
1923
+ as.should == [@album]
1924
+ as.map{|a| a.artist_id}.should == [@artist]
1925
+
1926
+ as = Album.eager_graph(:artist_id).all
1927
+ as.should == [@album]
1928
+ as.map{|a| a.artist_id}.should == [@artist]
1929
+ end
1930
+
1931
+ specify "should handle aliased tables when eager_graphing" do
1932
+ @album.update(:artist => @artist)
1933
+ @album.add_tag(@tag)
1934
+
1935
+ Artist.set_dataset(:artists___ar)
1936
+ Album.set_dataset(:albums___a)
1937
+ Tag.set_dataset(:tags___t)
1938
+ Artist.one_to_many :balbums, :class=>Album, :key=>:artist_id, :reciprocal=>nil
1939
+ Album.many_to_many :btags, :class=>Tag, :join_table=>:albums_tags, :right_key=>:tag_id
1940
+ Album.many_to_one :bartist, :class=>Artist, :key=>:artist_id
1941
+ Tag.many_to_many :balbums, :class=>Album, :join_table=>:albums_tags, :right_key=>:album_id
1942
+
1943
+ a = Artist.eager_graph(:balbums=>:btags).all
1944
+ a.should == [@artist]
1945
+ a.first.balbums.should == [@album]
1946
+ a.first.balbums.first.btags.should == [@tag]
1947
+
1948
+ a = Tag.eager_graph(:balbums=>:bartist).all
1949
+ a.should == [@tag]
1950
+ a.first.balbums.should == [@album]
1951
+ a.first.balbums.first.bartist.should == @artist
1952
+ end
1953
+
1954
+ specify "should have add method accept hashes and create new records" do
1955
+ @artist.remove_all_albums
1956
+ Album.dataset.delete
1957
+ @album = @artist.add_album(:name=>'Al2')
1958
+ Album.first[:name].should == 'Al2'
1959
+ @artist.albums_dataset.first[:name].should == 'Al2'
1960
+
1961
+ @album.remove_all_tags
1962
+ Tag.dataset.delete
1963
+ @album.add_tag(:name=>'T2')
1964
+ Tag.first[:name].should == 'T2'
1965
+ @album.tags_dataset.first[:name].should == 'T2'
1966
+ end
1967
+
1968
+ specify "should have add method accept primary key and add related records" do
1969
+ @artist.remove_all_albums
1970
+ @artist.add_album(@album.id)
1971
+ @artist.albums_dataset.first[:id].should == @album.id
1972
+
1973
+ @album.remove_all_tags
1974
+ @album.add_tag(@tag.id)
1975
+ @album.tags_dataset.first[:id].should == @tag.id
1976
+ end
1977
+
1978
+ specify "should have remove method accept primary key and remove related album" do
1979
+ @artist.add_album(@album)
1980
+ @artist.reload.remove_album(@album.id)
1981
+ @artist.reload.albums.should == []
1982
+
1983
+ @album.add_tag(@tag)
1984
+ @album.reload.remove_tag(@tag.id)
1985
+ @tag.reload.albums.should == []
1986
+ end
1987
+
1988
+ specify "should handle dynamic callbacks for regular loading" do
1989
+ @artist.add_album(@album)
1990
+
1991
+ @artist.albums.should == [@album]
1992
+ @artist.albums(proc{|ds| ds.exclude(:id=>@album.id)}).should == []
1993
+ @artist.albums(proc{|ds| ds.filter(:id=>@album.id)}).should == [@album]
1994
+
1995
+ @album.artist.should == @artist
1996
+ @album.artist(proc{|ds| ds.exclude(:id=>@artist.id)}).should == nil
1997
+ @album.artist(proc{|ds| ds.filter(:id=>@artist.id)}).should == @artist
1998
+
1999
+ @artist.albums{|ds| ds.exclude(:id=>@album.id)}.should == []
2000
+ @artist.albums{|ds| ds.filter(:id=>@album.id)}.should == [@album]
2001
+ @album.artist{|ds| ds.exclude(:id=>@artist.id)}.should == nil
2002
+ @album.artist{|ds| ds.filter(:id=>@artist.id)}.should == @artist
2003
+ end
2004
+
2005
+ specify "should handle dynamic callbacks for eager loading via eager and eager_graph" do
2006
+ @artist.add_album(@album)
2007
+ @album.add_tag(@tag)
2008
+ album2 = @artist.add_album(:name=>'Foo')
2009
+ tag2 = album2.add_tag(:name=>'T2')
2010
+
2011
+ artist = Artist.eager(:albums=>:tags).all.first
2012
+ artist.albums.should == [@album, album2]
2013
+ artist.albums.map{|x| x.tags}.should == [[@tag], [tag2]]
2014
+
2015
+ artist = Artist.eager_graph(:albums=>:tags).all.first
2016
+ artist.albums.should == [@album, album2]
2017
+ artist.albums.map{|x| x.tags}.should == [[@tag], [tag2]]
2018
+
2019
+ artist = Artist.eager(:albums=>{proc{|ds| ds.where(:id=>album2.id)}=>:tags}).all.first
2020
+ artist.albums.should == [album2]
2021
+ artist.albums.first.tags.should == [tag2]
2022
+
2023
+ artist = Artist.eager_graph(:albums=>{proc{|ds| ds.where(:id=>album2.id)}=>:tags}).all.first
2024
+ artist.albums.should == [album2]
2025
+ artist.albums.first.tags.should == [tag2]
2026
+ end
2027
+
2028
+ specify "should have remove method raise an error for one_to_many records if the object isn't already associated" do
2029
+ proc{@artist.remove_album(@album.id)}.should raise_error(Sequel::Error)
2030
+ proc{@artist.remove_album(@album)}.should raise_error(Sequel::Error)
2031
+ end
2032
+ end
2033
+
2034
+ describe "Sequel::Model Composite Key Associations" do
2035
+ before(:all) do
2036
+ @db = DB
2037
+ @db.drop_table?(:albums_tags, :tags, :albums, :artists)
2038
+ @db.create_table(:artists) do
2039
+ Integer :id1
2040
+ Integer :id2
2041
+ String :name
2042
+ primary_key [:id1, :id2]
2043
+ end
2044
+ @db.create_table(:albums) do
2045
+ Integer :id1
2046
+ Integer :id2
2047
+ String :name
2048
+ Integer :artist_id1
2049
+ Integer :artist_id2
2050
+ foreign_key [:artist_id1, :artist_id2], :artists
2051
+ primary_key [:id1, :id2]
2052
+ end
2053
+ @db.create_table(:tags) do
2054
+ Integer :id1
2055
+ Integer :id2
2056
+ String :name
2057
+ primary_key [:id1, :id2]
2058
+ end
2059
+ @db.create_table(:albums_tags) do
2060
+ Integer :album_id1
2061
+ Integer :album_id2
2062
+ Integer :tag_id1
2063
+ Integer :tag_id2
2064
+ foreign_key [:album_id1, :album_id2], :albums
2065
+ foreign_key [:tag_id1, :tag_id2], :tags
2066
+ end
2067
+ end
2068
+ before do
2069
+ [:albums_tags, :tags, :albums, :artists].each{|t| @db[t].delete}
2070
+ class ::Artist < Sequel::Model(@db)
2071
+ plugin :dataset_associations
2072
+ set_primary_key [:id1, :id2]
2073
+ unrestrict_primary_key
2074
+ one_to_many :albums, :key=>[:artist_id1, :artist_id2], :order=>:name
2075
+ one_to_one :first_album, :clone=>:albums
2076
+ one_to_one :last_album, :clone=>:albums, :order=>Sequel.desc(:name)
2077
+ one_to_one :second_album, :clone=>:albums, :limit=>[nil, 1]
2078
+ one_to_many :first_two_albums, :clone=>:albums, :order=>:name, :limit=>2
2079
+ one_to_many :second_two_albums, :clone=>:albums, :order=>:name, :limit=>[2, 1]
2080
+ one_to_many :not_first_albums, :clone=>:albums, :order=>:name, :limit=>[nil, 1]
2081
+ one_to_many :last_two_albums, :clone=>:albums, :order=>Sequel.desc(:name), :limit=>2
2082
+ one_to_many :a_albums, :clone=>:albums do |ds| ds.where(:name=>'Al') end
2083
+ one_to_one :first_a_album, :clone=>:a_albums
2084
+ plugin :many_through_many
2085
+ many_through_many :tags, [[:albums, [:artist_id1, :artist_id2], [:id1, :id2]], [:albums_tags, [:album_id1, :album_id2], [:tag_id1, :tag_id2]]]
2086
+ many_through_many :first_two_tags, :clone=>:tags, :order=>:tags__name, :limit=>2, :graph_order=>:name
2087
+ many_through_many :second_two_tags, :clone=>:tags, :order=>:tags__name, :limit=>[2, 1], :graph_order=>:name
2088
+ many_through_many :not_first_tags, :clone=>:tags, :order=>:tags__name, :limit=>[nil, 1], :graph_order=>:name
2089
+ many_through_many :last_two_tags, :clone=>:tags, :order=>Sequel.desc(:tags__name), :limit=>2, :graph_order=>Sequel.desc(:name)
2090
+ many_through_many :t_tags, :clone=>:tags do |ds| ds.where(:tags__name=>'T') end
2091
+ one_through_many :first_tag, [[:albums, [:artist_id1, :artist_id2], [:id1, :id2]], [:albums_tags, [:album_id1, :album_id2], [:tag_id1, :tag_id2]]], :order=>:tags__name, :graph_order=>:name, :class=>:Tag
2092
+ one_through_many :second_tag, :clone=>:first_tag, :limit=>[nil, 1]
2093
+ one_through_many :last_tag, :clone=>:first_tag, :order=>Sequel.desc(:tags__name), :graph_order=>Sequel.desc(:name)
2094
+ one_through_many :t_tag, :clone=>:first_tag do |ds| ds.where(:tags__name=>'T') end
2095
+ end
2096
+ class ::Album < Sequel::Model(@db)
2097
+ plugin :dataset_associations
2098
+ set_primary_key [:id1, :id2]
2099
+ unrestrict_primary_key
2100
+ many_to_one :artist, :key=>[:artist_id1, :artist_id2], :reciprocal=>nil
2101
+ many_to_one(:a_artist, :clone=>:artist){|ds| ds.where(:name=>'Ar')}
2102
+ many_to_many :tags, :left_key=>[:album_id1, :album_id2], :right_key=>[:tag_id1, :tag_id2]
2103
+ many_to_many :alias_tags, :clone=>:tags, :join_table=>:albums_tags___at
2104
+ many_to_many :first_two_tags, :clone=>:tags, :order=>:name, :limit=>2
2105
+ many_to_many :second_two_tags, :clone=>:tags, :order=>:name, :limit=>[2, 1]
2106
+ many_to_many :not_first_tags, :clone=>:tags, :order=>:name, :limit=>[nil, 1]
2107
+ many_to_many :last_two_tags, :clone=>:tags, :order=>Sequel.desc(:name), :limit=>2
2108
+ many_to_many :t_tags, :clone=>:tags do |ds| ds.where(:name=>'T') end
2109
+ many_to_many :alias_t_tags, :clone=>:t_tags, :join_table=>:albums_tags___at
2110
+ one_through_one :first_tag, :clone=>:tags, :order=>:name
2111
+ one_through_one :second_tag, :clone=>:first_tag, :limit=>[nil, 1]
2112
+ one_through_one :last_tag, :clone=>:tags, :order=>Sequel.desc(:name)
2113
+ one_through_one :t_tag, :clone=>:t_tags
2114
+ one_through_one :alias_t_tag, :clone=>:alias_t_tags
2115
+ end
2116
+ class ::Tag < Sequel::Model(@db)
2117
+ plugin :dataset_associations
2118
+ set_primary_key [:id1, :id2]
2119
+ unrestrict_primary_key
2120
+ many_to_many :albums, :right_key=>[:album_id1, :album_id2], :left_key=>[:tag_id1, :tag_id2]
2121
+ end
2122
+ @album = Album.create(:name=>'Al', :id1=>1, :id2=>2)
2123
+ @artist = Artist.create(:name=>'Ar', :id1=>3, :id2=>4)
2124
+ @tag = Tag.create(:name=>'T', :id1=>5, :id2=>6)
2125
+ @same_album = lambda{Album.create(:name=>'Al', :id1=>7, :id2=>8, :artist_id1=>3, :artist_id2=>4)}
2126
+ @diff_album = lambda{Album.create(:name=>'lA', :id1=>9, :id2=>10, :artist_id1=>3, :artist_id2=>4)}
2127
+ @middle_album = lambda{Album.create(:name=>'Bl', :id1=>13, :id2=>14, :artist_id1=>3, :artist_id2=>4)}
2128
+ @other_tags = lambda{t = [Tag.create(:name=>'U', :id1=>17, :id2=>18), Tag.create(:name=>'V', :id1=>19, :id2=>20)]; @db[:albums_tags].insert([:album_id1, :album_id2, :tag_id1, :tag_id2], Tag.select(1, 2, :id1, :id2)); t}
2129
+ @pr = lambda{[Album.create(:name=>'Al2', :id1=>11, :id2=>12),Artist.create(:name=>'Ar2', :id1=>13, :id2=>14),Tag.create(:name=>'T2', :id1=>15, :id2=>16)]}
2130
+ @ins = lambda{@db[:albums_tags].insert(:tag_id1=>@tag.id1, :tag_id2=>@tag.id2)}
2131
+ end
2132
+ after do
2133
+ [:Tag, :Album, :Artist].each{|x| Object.send(:remove_const, x)}
2134
+ end
2135
+ after(:all) do
2136
+ @db.drop_table?(:albums_tags, :tags, :albums, :artists)
2137
+ end
2138
+
2139
+ it_should_behave_like "regular and composite key associations"
2140
+
2141
+ describe "with :correlated_subquery limit strategy" do
2142
+ before do
2143
+ @els = {:eager_limit_strategy=>:correlated_subquery}
2144
+ end
2145
+
2146
+ it_should_behave_like "one_to_one eager_graph limit strategies"
2147
+ it_should_behave_like "one_to_many eager_graph limit strategies"
2148
+ it_should_behave_like "filter by associations one_to_one limit strategies"
2149
+ it_should_behave_like "filter by associations one_to_many limit strategies"
2150
+ end if DB.dataset.supports_limits_in_correlated_subqueries? && DB.dataset.supports_multiple_column_in?
2151
+
2152
+ specify "should have add method accept hashes and create new records" do
2153
+ @artist.remove_all_albums
2154
+ Album.dataset.delete
2155
+ @artist.add_album(:id1=>1, :id2=>2, :name=>'Al2')
2156
+ Album.first[:name].should == 'Al2'
2157
+ @artist.albums_dataset.first[:name].should == 'Al2'
2158
+
2159
+ @album.remove_all_tags
2160
+ Tag.dataset.delete
2161
+ @album.add_tag(:id1=>1, :id2=>2, :name=>'T2')
2162
+ Tag.first[:name].should == 'T2'
2163
+ @album.tags_dataset.first[:name].should == 'T2'
2164
+ end
2165
+
2166
+ specify "should have add method accept primary key and add related records" do
2167
+ @artist.remove_all_albums
2168
+ @artist.add_album([@album.id1, @album.id2])
2169
+ @artist.albums_dataset.first.pk.should == [@album.id1, @album.id2]
2170
+
2171
+ @album.remove_all_tags
2172
+ @album.add_tag([@tag.id1, @tag.id2])
2173
+ @album.tags_dataset.first.pk.should == [@tag.id1, @tag.id2]
2174
+ end
2175
+
2176
+ specify "should have remove method accept primary key and remove related album" do
2177
+ @artist.add_album(@album)
2178
+ @artist.reload.remove_album([@album.id1, @album.id2])
2179
+ @artist.reload.albums.should == []
2180
+
2181
+ @album.add_tag(@tag)
2182
+ @album.reload.remove_tag([@tag.id1, @tag.id2])
2183
+ @tag.reload.albums.should == []
2184
+ end
2185
+
2186
+ specify "should have remove method raise an error for one_to_many records if the object isn't already associated" do
2187
+ proc{@artist.remove_album([@album.id1, @album.id2])}.should raise_error(Sequel::Error)
2188
+ proc{@artist.remove_album(@album)}.should raise_error(Sequel::Error)
2189
+ end
2190
+ end
2191
+
2192
+ describe "Sequel::Model pg_array_to_many" do
2193
+ before(:all) do
2194
+ @db = DB
2195
+ @db.extension :pg_array
2196
+ Sequel.extension :pg_array_ops
2197
+ @db.drop_table?(:tags, :albums, :artists)
2198
+ @db.create_table(:artists) do
2199
+ primary_key :id
2200
+ String :name
2201
+ end
2202
+ @db.create_table(:albums) do
2203
+ primary_key :id
2204
+ String :name
2205
+ foreign_key :artist_id, :artists
2206
+ column :tag_ids, 'int4[]'
2207
+ end
2208
+ @db.create_table(:tags) do
2209
+ primary_key :id
2210
+ String :name
2211
+ end
2212
+ end
2213
+ before do
2214
+ [:tags, :albums, :artists].each{|t| @db[t].delete}
2215
+ class ::Artist < Sequel::Model(@db)
2216
+ plugin :dataset_associations
2217
+ one_to_many :albums, :order=>:name
2218
+ one_to_one :first_album, :clone=>:albums
2219
+ one_to_many :a_albums, :clone=>:albums do |ds| ds.where(:name=>'Al') end
2220
+ one_to_one :first_a_album, :clone=>:a_albums
2221
+ end
2222
+ class ::Album < Sequel::Model(@db)
2223
+ plugin :dataset_associations
2224
+ plugin :pg_array_associations
2225
+ many_to_one :artist, :reciprocal=>nil
2226
+ many_to_one :a_artist, :clone=>:artist, :key=>:artist_id do |ds| ds.where(:name=>'Ar') end
2227
+ pg_array_to_many :tags, :key=>:tag_ids, :save_after_modify=>true
2228
+ pg_array_to_many :alias_tags, :clone=>:tags
2229
+ pg_array_to_many :first_two_tags, :clone=>:tags, :order=>:name, :limit=>2
2230
+ pg_array_to_many :second_two_tags, :clone=>:tags, :order=>:name, :limit=>[2, 1]
2231
+ pg_array_to_many :not_first_tags, :clone=>:tags, :order=>:name, :limit=>[nil, 1]
2232
+ pg_array_to_many :last_two_tags, :clone=>:tags, :order=>Sequel.desc(:name), :limit=>2
2233
+ pg_array_to_many :t_tags, :clone=>:tags do |ds| ds.where(:tags__name=>'T') end
2234
+ pg_array_to_many :alias_t_tags, :clone=>:t_tags
2235
+ end
2236
+ class ::Tag < Sequel::Model(@db)
2237
+ plugin :dataset_associations
2238
+ plugin :pg_array_associations
2239
+ many_to_pg_array :albums
2240
+ end
2241
+ @album = Album.create(:name=>'Al')
2242
+ @artist = Artist.create(:name=>'Ar')
2243
+ @tag = Tag.create(:name=>'T')
2244
+ @many_to_many_method = :pg_array_to_many
2245
+ @no_many_through_many = true
2246
+ @same_album = lambda{Album.create(:name=>'Al', :artist_id=>@artist.id)}
2247
+ @diff_album = lambda{Album.create(:name=>'lA', :artist_id=>@artist.id)}
2248
+ @middle_album = lambda{Album.create(:name=>'Bl', :artist_id=>@artist.id)}
2249
+ @other_tags = lambda{t = [Tag.create(:name=>'U'), Tag.create(:name=>'V')]; Tag.all{|x| @album.add_tag(x)}; t}
2250
+ @pr = lambda{[Album.create(:name=>'Al2'),Artist.create(:name=>'Ar2'),Tag.create(:name=>'T2')]}
2251
+ @ins = lambda{}
2252
+ end
2253
+ after do
2254
+ [:Tag, :Album, :Artist].each{|x| Object.send(:remove_const, x)}
2255
+ end
2256
+ after(:all) do
2257
+ @db.drop_table?(:tags, :albums, :artists)
2258
+ end
2259
+
2260
+ it_should_behave_like "basic regular and composite key associations"
2261
+ it_should_behave_like "many_to_many eager limit strategies"
2262
+ it_should_behave_like "many_to_many eager_graph limit strategies"
2263
+
2264
+ it "should handle adding and removing entries in array" do
2265
+ a = Album.create
2266
+ a.typecast_on_assignment = false
2267
+ a.add_tag(@tag)
2268
+ a.remove_tag(@tag)
2269
+ a.save
2270
+ end
2271
+ end if DB.database_type == :postgres && [:postgres, :jdbc].include?(DB.adapter_scheme) && DB.server_version >= 90300
2272
+
2273
+ describe "Sequel::Model many_to_pg_array" do
2274
+ before(:all) do
2275
+ @db = DB
2276
+ @db.extension :pg_array
2277
+ Sequel.extension :pg_array_ops
2278
+ @db.drop_table?(:tags, :albums, :artists)
2279
+ @db.create_table(:artists) do
2280
+ primary_key :id
2281
+ String :name
2282
+ end
2283
+ @db.create_table(:albums) do
2284
+ primary_key :id
2285
+ String :name
2286
+ foreign_key :artist_id, :artists
2287
+ end
2288
+ @db.create_table(:tags) do
2289
+ primary_key :id
2290
+ String :name
2291
+ column :album_ids, 'int4[]'
2292
+ end
2293
+ end
2294
+ before do
2295
+ [:tags, :albums, :artists].each{|t| @db[t].delete}
2296
+ class ::Artist < Sequel::Model(@db)
2297
+ plugin :dataset_associations
2298
+ one_to_many :albums, :order=>:name
2299
+ one_to_one :first_album, :class=>:Album, :order=>:name
2300
+ one_to_many :a_albums, :clone=>:albums do |ds| ds.where(:name=>'Al') end
2301
+ one_to_one :first_a_album, :clone=>:a_albums
2302
+ end
2303
+ class ::Album < Sequel::Model(@db)
2304
+ plugin :dataset_associations
2305
+ plugin :pg_array_associations
2306
+ many_to_one :artist, :reciprocal=>nil
2307
+ many_to_one :a_artist, :clone=>:artist, :key=>:artist_id do |ds| ds.where(:name=>'Ar') end
2308
+ many_to_pg_array :tags
2309
+ many_to_pg_array :alias_tags, :clone=>:tags
2310
+ many_to_pg_array :first_two_tags, :clone=>:tags, :order=>:name, :limit=>2
2311
+ many_to_pg_array :second_two_tags, :clone=>:tags, :order=>:name, :limit=>[2, 1]
2312
+ many_to_pg_array :not_first_tags, :clone=>:tags, :order=>:name, :limit=>[nil, 1]
2313
+ many_to_pg_array :last_two_tags, :clone=>:tags, :order=>Sequel.desc(:name), :limit=>2
2314
+ many_to_pg_array :t_tags, :clone=>:tags do |ds| ds.where(:tags__name=>'T') end
2315
+ many_to_pg_array :alias_t_tags, :clone=>:t_tags
2316
+ end
2317
+ class ::Tag < Sequel::Model(@db)
2318
+ plugin :dataset_associations
2319
+ plugin :pg_array_associations
2320
+ pg_array_to_many :albums, :save_after_modify=>true
2321
+ end
2322
+ @album = Album.create(:name=>'Al')
2323
+ @artist = Artist.create(:name=>'Ar')
2324
+ @tag = Tag.create(:name=>'T')
2325
+ @many_to_many_method = :pg_array_to_many
2326
+ @no_many_through_many = true
2327
+ @same_album = lambda{Album.create(:name=>'Al', :artist_id=>@artist.id)}
2328
+ @diff_album = lambda{Album.create(:name=>'lA', :artist_id=>@artist.id)}
2329
+ @middle_album = lambda{Album.create(:name=>'Bl', :artist_id=>@artist.id)}
2330
+ @other_tags = lambda{t = [Tag.create(:name=>'U'), Tag.create(:name=>'V')]; Tag.all{|x| @album.add_tag(x)}; @tag.refresh; t.each{|x| x.refresh}; t}
2331
+ @pr = lambda{[Album.create(:name=>'Al2'),Artist.create(:name=>'Ar2'),Tag.create(:name=>'T2')]}
2332
+ @ins = lambda{}
2333
+ end
2334
+ after do
2335
+ [:Tag, :Album, :Artist].each{|x| Object.send(:remove_const, x)}
2336
+ end
2337
+ after(:all) do
2338
+ @db.drop_table?(:tags, :albums, :artists)
2339
+ end
2340
+
2341
+ it_should_behave_like "basic regular and composite key associations"
2342
+ it_should_behave_like "many_to_many eager limit strategies"
2343
+ it_should_behave_like "many_to_many eager_graph limit strategies"
2344
+
2345
+ it "should handle adding and removing entries in array" do
2346
+ a = Album.create
2347
+ @tag.typecast_on_assignment = false
2348
+ a.add_tag(@tag)
2349
+ a.remove_tag(@tag)
2350
+ end
2351
+ end if DB.database_type == :postgres && [:postgres, :jdbc].include?(DB.adapter_scheme) && DB.server_version >= 90300
2352
+
2353
+ describe "Sequel::Model Associations with clashing column names" do
2354
+ before(:all) do
2355
+ @db = DB
2356
+ @db.drop_table?(:bars_foos, :bars, :foos)
2357
+ @db.create_table(:foos) do
2358
+ primary_key :id
2359
+ Integer :object_id
2360
+ end
2361
+ @db.create_table(:bars) do
2362
+ primary_key :id
2363
+ Integer :object_id
2364
+ end
2365
+ @db.create_table(:bars_foos) do
2366
+ Integer :foo_id
2367
+ Integer :object_id
2368
+ primary_key [:foo_id, :object_id]
2369
+ end
2370
+ end
2371
+ before do
2372
+ [:bars_foos, :bars, :foos].each{|t| @db[t].delete}
2373
+ @Foo = Class.new(Sequel::Model(:foos))
2374
+ @Bar = Class.new(Sequel::Model(:bars))
2375
+ @Foo.def_column_alias(:obj_id, :object_id)
2376
+ @Bar.def_column_alias(:obj_id, :object_id)
2377
+ @Foo.one_to_many :bars, :primary_key=>:obj_id, :primary_key_column=>:object_id, :key=>:object_id, :key_method=>:obj_id, :class=>@Bar
2378
+ @Foo.one_to_one :bar, :primary_key=>:obj_id, :primary_key_column=>:object_id, :key=>:object_id, :key_method=>:obj_id, :class=>@Bar
2379
+ @Bar.many_to_one :foo, :key=>:obj_id, :key_column=>:object_id, :primary_key=>:object_id, :primary_key_method=>:obj_id, :class=>@Foo
2380
+ @Foo.many_to_many :mtmbars, :join_table=>:bars_foos, :left_primary_key=>:obj_id, :left_primary_key_column=>:object_id, :right_primary_key=>:object_id, :right_primary_key_method=>:obj_id, :left_key=>:foo_id, :right_key=>:object_id, :class=>@Bar
2381
+ @Foo.one_through_one :mtmbar, :join_table=>:bars_foos, :left_primary_key=>:obj_id, :left_primary_key_column=>:object_id, :right_primary_key=>:object_id, :right_primary_key_method=>:obj_id, :left_key=>:foo_id, :right_key=>:object_id, :class=>@Bar
2382
+ @Bar.many_to_many :mtmfoos, :join_table=>:bars_foos, :left_primary_key=>:obj_id, :left_primary_key_column=>:object_id, :right_primary_key=>:object_id, :right_primary_key_method=>:obj_id, :left_key=>:object_id, :right_key=>:foo_id, :class=>@Foo
2383
+ @foo = @Foo.create(:obj_id=>2)
2384
+ @bar = @Bar.create(:obj_id=>2)
2385
+ @Foo.db[:bars_foos].insert(2, 2)
2386
+ end
2387
+ after(:all) do
2388
+ @db.drop_table?(:bars_foos, :bars, :foos)
2389
+ end
2390
+
2391
+ it "should have working regular association methods" do
2392
+ @Bar.first.foo.should == @foo
2393
+ @Foo.first.bars.should == [@bar]
2394
+ @Foo.first.bar.should == @bar
2395
+ @Foo.first.mtmbars.should == [@bar]
2396
+ @Foo.first.mtmbar.should == @bar
2397
+ @Bar.first.mtmfoos.should == [@foo]
2398
+ end
2399
+
2400
+ it "should have working eager loading methods" do
2401
+ @Bar.eager(:foo).all.map{|o| [o, o.foo]}.should == [[@bar, @foo]]
2402
+ @Foo.eager(:bars).all.map{|o| [o, o.bars]}.should == [[@foo, [@bar]]]
2403
+ @Foo.eager(:bar).all.map{|o| [o, o.bar]}.should == [[@foo, @bar]]
2404
+ @Foo.eager(:mtmbars).all.map{|o| [o, o.mtmbars]}.should == [[@foo, [@bar]]]
2405
+ @Foo.eager(:mtmbar).all.map{|o| [o, o.mtmbar]}.should == [[@foo, @bar]]
2406
+ @Bar.eager(:mtmfoos).all.map{|o| [o, o.mtmfoos]}.should == [[@bar, [@foo]]]
2407
+ end
2408
+
2409
+ it "should have working eager graphing methods" do
2410
+ @Bar.eager_graph(:foo).all.map{|o| [o, o.foo]}.should == [[@bar, @foo]]
2411
+ @Foo.eager_graph(:bars).all.map{|o| [o, o.bars]}.should == [[@foo, [@bar]]]
2412
+ @Foo.eager_graph(:bar).all.map{|o| [o, o.bar]}.should == [[@foo, @bar]]
2413
+ @Foo.eager_graph(:mtmbars).all.map{|o| [o, o.mtmbars]}.should == [[@foo, [@bar]]]
2414
+ @Foo.eager_graph(:mtmbar).all.map{|o| [o, o.mtmbar]}.should == [[@foo, @bar]]
2415
+ @Bar.eager_graph(:mtmfoos).all.map{|o| [o, o.mtmfoos]}.should == [[@bar, [@foo]]]
2416
+ end
2417
+
2418
+ it "should have working modification methods" do
2419
+ b = @Bar.create(:obj_id=>3)
2420
+ f = @Foo.create(:obj_id=>3)
2421
+
2422
+ @bar.foo = f
2423
+ @bar.obj_id.should == 3
2424
+ @foo.bar = @bar
2425
+ @bar.obj_id.should == 2
2426
+
2427
+ @foo.add_bar(b)
2428
+ @foo.bars.sort_by{|x| x.id}.should == [@bar, b]
2429
+ @foo.remove_bar(b)
2430
+ @foo.bars.should == [@bar]
2431
+ @foo.remove_all_bars
2432
+ @foo.bars.should == []
2433
+
2434
+ @bar.refresh.update(:obj_id=>2)
2435
+ b.refresh.update(:obj_id=>3)
2436
+ @foo.mtmbars.should == [@bar]
2437
+ @foo.remove_all_mtmbars
2438
+ @foo.mtmbars.should == []
2439
+ @foo.add_mtmbar(b)
2440
+ @foo.mtmbars.should == [b]
2441
+ @foo.remove_mtmbar(b)
2442
+ @foo.mtmbars.should == []
2443
+
2444
+ @bar.add_mtmfoo(f)
2445
+ @bar.mtmfoos.should == [f]
2446
+ @bar.remove_all_mtmfoos
2447
+ @bar.mtmfoos.should == []
2448
+ @bar.add_mtmfoo(f)
2449
+ @bar.mtmfoos.should == [f]
2450
+ @bar.remove_mtmfoo(f)
2451
+ @bar.mtmfoos.should == []
2452
+ end
2453
+ end