moneta 1.0.0 → 1.1.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (446) hide show
  1. checksums.yaml +5 -5
  2. data/.gitignore +1 -0
  3. data/.rspec +4 -0
  4. data/.travis.yml +83 -32
  5. data/.yardopts +6 -1
  6. data/CHANGES +30 -0
  7. data/CONTRIBUTORS +4 -0
  8. data/Gemfile +28 -36
  9. data/LICENSE +1 -1
  10. data/README.md +136 -67
  11. data/SPEC.md +70 -0
  12. data/feature_matrix.yaml +235 -0
  13. data/lib/active_support/cache/moneta_store.rb +102 -6
  14. data/lib/moneta.rb +9 -2
  15. data/lib/moneta/adapters/activerecord.rb +258 -98
  16. data/lib/moneta/adapters/activesupportcache.rb +133 -0
  17. data/lib/moneta/adapters/cassandra.rb +290 -44
  18. data/lib/moneta/adapters/client.rb +11 -2
  19. data/lib/moneta/adapters/couch.rb +179 -25
  20. data/lib/moneta/adapters/datamapper.rb +1 -0
  21. data/lib/moneta/adapters/daybreak.rb +21 -4
  22. data/lib/moneta/adapters/dbm.rb +7 -7
  23. data/lib/moneta/adapters/file.rb +11 -1
  24. data/lib/moneta/adapters/gdbm.rb +7 -7
  25. data/lib/moneta/adapters/kyotocabinet.rb +66 -1
  26. data/lib/moneta/adapters/leveldb.rb +27 -1
  27. data/lib/moneta/adapters/lmdb.rb +29 -1
  28. data/lib/moneta/adapters/lruhash.rb +30 -0
  29. data/lib/moneta/adapters/memcached/dalli.rb +50 -5
  30. data/lib/moneta/adapters/memcached/native.rb +11 -4
  31. data/lib/moneta/adapters/memory.rb +2 -0
  32. data/lib/moneta/adapters/mongo/base.rb +32 -7
  33. data/lib/moneta/adapters/mongo/moped.rb +59 -2
  34. data/lib/moneta/adapters/mongo/official.rb +40 -0
  35. data/lib/moneta/adapters/pstore.rb +56 -8
  36. data/lib/moneta/adapters/redis.rb +79 -19
  37. data/lib/moneta/adapters/sdbm.rb +7 -7
  38. data/lib/moneta/adapters/sequel.rb +440 -39
  39. data/lib/moneta/adapters/sqlite.rb +74 -10
  40. data/lib/moneta/adapters/tdb.rb +16 -1
  41. data/lib/moneta/adapters/tokyocabinet.rb +7 -1
  42. data/lib/moneta/adapters/tokyotyrant.rb +22 -0
  43. data/lib/moneta/cache.rb +11 -1
  44. data/lib/moneta/expires.rb +110 -8
  45. data/lib/moneta/lock.rb +21 -2
  46. data/lib/moneta/mixins.rb +279 -3
  47. data/lib/moneta/pool.rb +15 -6
  48. data/lib/moneta/proxy.rb +46 -2
  49. data/lib/moneta/server.rb +5 -1
  50. data/lib/moneta/shared.rb +27 -11
  51. data/lib/moneta/stack.rb +1 -1
  52. data/lib/moneta/synchronize.rb +2 -8
  53. data/lib/moneta/transformer.rb +152 -2
  54. data/lib/moneta/transformer/config.rb +2 -0
  55. data/lib/moneta/transformer/helper.rb +2 -2
  56. data/lib/moneta/version.rb +1 -1
  57. data/lib/moneta/weak_each_key.rb +74 -0
  58. data/lib/moneta/wrapper.rb +25 -0
  59. data/moneta.gemspec +2 -2
  60. data/script/benchmarks +174 -62
  61. data/script/parallel-tests +58 -83
  62. data/script/start-hbase +46 -0
  63. data/script/start-services +9 -2
  64. data/script/update-feature-matrix +148 -0
  65. data/spec/active_support/cache_moneta_store_spec.rb +132 -109
  66. data/spec/features/concurrent_create.rb +21 -0
  67. data/spec/features/concurrent_increment.rb +32 -0
  68. data/spec/features/create.rb +25 -0
  69. data/spec/features/create_expires.rb +19 -0
  70. data/spec/features/default_expires.rb +15 -0
  71. data/spec/features/each_key.rb +119 -0
  72. data/spec/features/expires.rb +291 -0
  73. data/spec/features/features.rb +16 -0
  74. data/spec/features/increment.rb +98 -0
  75. data/spec/features/marshallable_key.rb +43 -0
  76. data/spec/features/marshallable_value.rb +7 -0
  77. data/spec/features/multiprocess.rb +8 -0
  78. data/spec/features/not_create.rb +7 -0
  79. data/spec/features/not_each_key.rb +7 -0
  80. data/spec/features/not_increment.rb +13 -0
  81. data/spec/features/not_persist.rb +9 -0
  82. data/spec/features/null.rb +66 -0
  83. data/spec/features/persist.rb +14 -0
  84. data/spec/features/returndifferent.rb +9 -0
  85. data/spec/features/returnsame.rb +9 -0
  86. data/spec/features/store.rb +261 -0
  87. data/spec/features/store_large.rb +13 -0
  88. data/spec/features/transform_value.rb +44 -0
  89. data/spec/features/transform_value_expires.rb +41 -0
  90. data/spec/helper.rb +391 -74
  91. data/spec/moneta/adapters/activerecord/adapter_activerecord_existing_connection_spec.rb +59 -0
  92. data/spec/moneta/adapters/activerecord/adapter_activerecord_spec.rb +118 -0
  93. data/spec/moneta/adapters/activerecord/standard_activerecord_spec.rb +18 -0
  94. data/spec/moneta/adapters/activerecord/standard_activerecord_with_expires_spec.rb +24 -0
  95. data/spec/moneta/adapters/activesupportcache/adapter_activesupportcache_spec.rb +51 -0
  96. data/spec/moneta/adapters/activesupportcache/adapter_activesupportcache_with_default_expires_spec.rb +51 -0
  97. data/spec/moneta/adapters/cassandra/adapter_cassandra_spec.rb +17 -0
  98. data/spec/moneta/adapters/cassandra/adapter_cassandra_with_default_expires_spec.rb +18 -0
  99. data/spec/moneta/adapters/cassandra/helper.rb +18 -0
  100. data/spec/moneta/adapters/cassandra/standard_cassandra_spec.rb +18 -0
  101. data/spec/moneta/adapters/client/adapter_client_spec.rb +11 -0
  102. data/spec/moneta/adapters/client/standard_client_tcp_spec.rb +23 -0
  103. data/spec/moneta/adapters/client/standard_client_unix_spec.rb +12 -0
  104. data/spec/moneta/adapters/cookie/adapter_cookie_spec.rb +7 -0
  105. data/spec/moneta/adapters/couch/adapter_couch_spec.rb +7 -0
  106. data/spec/moneta/adapters/couch/standard_couch_spec.rb +9 -0
  107. data/spec/moneta/adapters/couch/standard_couch_with_expires_spec.rb +13 -0
  108. data/spec/moneta/adapters/datamapper/adapter_datamapper_spec.rb +43 -0
  109. data/spec/moneta/adapters/datamapper/standard_datamapper_spec.rb +21 -0
  110. data/spec/moneta/adapters/datamapper/standard_datamapper_with_expires_spec.rb +26 -0
  111. data/spec/moneta/adapters/datamapper/standard_datamapper_with_repository_spec.rb +22 -0
  112. data/spec/moneta/adapters/daybreak/adapter_daybreak_spec.rb +7 -0
  113. data/spec/moneta/adapters/daybreak/standard_daybreak_spec.rb +7 -0
  114. data/spec/moneta/adapters/daybreak/standard_daybreak_with_expires_spec.rb +11 -0
  115. data/spec/moneta/adapters/dbm/adapter_dbm_spec.rb +7 -0
  116. data/spec/moneta/adapters/dbm/standard_dbm_spec.rb +7 -0
  117. data/spec/moneta/adapters/dbm/standard_dbm_with_expires_spec.rb +12 -0
  118. data/spec/moneta/adapters/file/adapter_file_spec.rb +7 -0
  119. data/spec/moneta/adapters/file/standard_file_spec.rb +7 -0
  120. data/spec/moneta/adapters/file/standard_file_with_expires_spec.rb +11 -0
  121. data/spec/moneta/adapters/fog/adapter_fog_spec.rb +16 -0
  122. data/spec/moneta/adapters/fog/standard_fog_spec.rb +15 -0
  123. data/spec/moneta/adapters/fog/standard_fog_with_expires_spec.rb +20 -0
  124. data/spec/moneta/adapters/gdbm/adapter_gdbm_spec.rb +7 -0
  125. data/spec/moneta/adapters/gdbm/standard_gdbm_spec.rb +7 -0
  126. data/spec/moneta/adapters/gdbm/standard_gdbm_with_expires_spec.rb +11 -0
  127. data/spec/moneta/adapters/hashfile/standard_hashfile_spec.rb +7 -0
  128. data/spec/moneta/adapters/hashfile/standard_hashfile_with_expires_spec.rb +12 -0
  129. data/spec/moneta/adapters/hbase/adapter_hbase_spec.rb +7 -0
  130. data/spec/moneta/adapters/hbase/standard_hbase_spec.rb +4 -0
  131. data/spec/moneta/adapters/hbase/standard_hbase_with_expires_spec.rb +8 -0
  132. data/spec/moneta/adapters/kyotocabinet/adapter_kyotocabinet_spec.rb +7 -0
  133. data/spec/moneta/adapters/kyotocabinet/standard_kyotocabinet_spec.rb +7 -0
  134. data/spec/moneta/adapters/kyotocabinet/standard_kyotocabinet_with_expires_spec.rb +14 -0
  135. data/spec/moneta/adapters/leveldb/adapter_leveldb_spec.rb +7 -0
  136. data/spec/moneta/adapters/leveldb/standard_leveldb_spec.rb +7 -0
  137. data/spec/moneta/adapters/leveldb/standard_leveldb_with_expires_spec.rb +11 -0
  138. data/spec/moneta/adapters/lmdb/adapter_lmdb_spec.rb +7 -0
  139. data/spec/moneta/adapters/lmdb/adapter_lmdb_with_db_spec.rb +7 -0
  140. data/spec/moneta/adapters/lmdb/standard_lmdb_spec.rb +7 -0
  141. data/spec/moneta/adapters/lmdb/standard_lmdb_with_expires_spec.rb +11 -0
  142. data/spec/moneta/adapters/localmemcache/adapter_localmemcache_spec.rb +7 -0
  143. data/spec/moneta/adapters/localmemcache/standard_localmemcache_spec.rb +7 -0
  144. data/spec/moneta/adapters/localmemcache/standard_localmemcache_with_expires_spec.rb +11 -0
  145. data/spec/moneta/{adapter_lruhash_spec.rb → adapters/lruhash/adapter_lruhash_spec.rb} +3 -25
  146. data/spec/moneta/adapters/lruhash/standard_lruhash_spec.rb +4 -0
  147. data/spec/moneta/adapters/lruhash/standard_lruhash_with_expires_spec.rb +8 -0
  148. data/spec/moneta/adapters/memcached/adapter_memcached_spec.rb +13 -0
  149. data/spec/moneta/adapters/memcached/dalli/adapter_memcached_dalli_spec.rb +15 -0
  150. data/spec/moneta/adapters/memcached/dalli/adapter_memcached_dalli_with_default_expires_spec.rb +15 -0
  151. data/spec/moneta/adapters/memcached/dalli/standard_memcached_dalli_spec.rb +11 -0
  152. data/spec/moneta/adapters/memcached/helper.rb +20 -0
  153. data/spec/moneta/adapters/memcached/native/adapter_memcached_native_spec.rb +15 -0
  154. data/spec/moneta/adapters/memcached/native/adapter_memcached_native_with_default_expires_spec.rb +15 -0
  155. data/spec/moneta/adapters/memcached/native/standard_memcached_native_spec.rb +11 -0
  156. data/spec/moneta/adapters/memcached/standard_memcached_spec.rb +17 -0
  157. data/spec/moneta/adapters/memory/adapter_memory_spec.rb +7 -0
  158. data/spec/moneta/adapters/memory/standard_memory_spec.rb +4 -0
  159. data/spec/moneta/adapters/memory/standard_memory_with_compress_spec.rb +9 -0
  160. data/spec/moneta/adapters/memory/standard_memory_with_expires_spec.rb +8 -0
  161. data/spec/moneta/adapters/memory/standard_memory_with_json_key_serializer_spec.rb +4 -0
  162. data/spec/moneta/adapters/memory/standard_memory_with_json_serializer_spec.rb +9 -0
  163. data/spec/moneta/adapters/memory/standard_memory_with_json_value_serializer_spec.rb +9 -0
  164. data/spec/moneta/adapters/memory/standard_memory_with_prefix_spec.rb +4 -0
  165. data/spec/moneta/adapters/memory/standard_memory_with_snappy_compress_spec.rb +9 -0
  166. data/spec/moneta/adapters/mongo/adapter_mongo_moped_spec.rb +25 -0
  167. data/spec/moneta/adapters/mongo/adapter_mongo_moped_with_default_expires_spec.rb +12 -0
  168. data/spec/moneta/adapters/mongo/adapter_mongo_official_spec.rb +25 -0
  169. data/spec/moneta/adapters/mongo/adapter_mongo_official_with_default_expires_spec.rb +12 -0
  170. data/spec/moneta/adapters/mongo/adapter_mongo_spec.rb +11 -0
  171. data/spec/moneta/adapters/mongo/adapter_mongo_with_default_expires_spec.rb +12 -0
  172. data/spec/moneta/adapters/mongo/standard_mongo_moped_spec.rb +7 -0
  173. data/spec/moneta/adapters/mongo/standard_mongo_official_spec.rb +7 -0
  174. data/spec/moneta/adapters/mongo/standard_mongo_spec.rb +7 -0
  175. data/spec/moneta/adapters/null/null_adapter_spec.rb +7 -0
  176. data/spec/moneta/adapters/null/standard_null_spec.rb +4 -0
  177. data/spec/moneta/adapters/pstore/adapter_pstore_spec.rb +7 -0
  178. data/spec/moneta/adapters/pstore/standard_pstore_spec.rb +9 -0
  179. data/spec/moneta/adapters/pstore/standard_pstore_with_expires_spec.rb +13 -0
  180. data/spec/moneta/adapters/redis/adapter_redis_spec.rb +10 -0
  181. data/spec/moneta/adapters/redis/adapter_redis_with_default_expires_spec.rb +10 -0
  182. data/spec/moneta/adapters/redis/standard_redis_spec.rb +7 -0
  183. data/spec/moneta/adapters/restclient/adapter_restclient_spec.rb +11 -0
  184. data/spec/moneta/adapters/restclient/standard_restclient_spec.rb +10 -0
  185. data/spec/moneta/adapters/riak/adapter_riak_spec.rb +14 -0
  186. data/spec/moneta/adapters/riak/standard_riak_spec.rb +10 -0
  187. data/spec/moneta/adapters/riak/standard_riak_with_expires_spec.rb +10 -0
  188. data/spec/moneta/adapters/sdbm/adapter_sdbm_spec.rb +7 -0
  189. data/spec/moneta/adapters/sdbm/standard_sdbm_spec.rb +7 -0
  190. data/spec/moneta/adapters/sdbm/standard_sdbm_with_expires_spec.rb +11 -0
  191. data/spec/moneta/adapters/sequel/adapter_sequel_spec.rb +181 -0
  192. data/spec/moneta/adapters/sequel/standard_sequel_spec.rb +14 -0
  193. data/spec/moneta/adapters/sequel/standard_sequel_with_expires_spec.rb +19 -0
  194. data/spec/moneta/adapters/sqlite/adapter_sqlite_spec.rb +7 -0
  195. data/spec/moneta/adapters/sqlite/standard_sqlite_spec.rb +7 -0
  196. data/spec/moneta/adapters/sqlite/standard_sqlite_with_expires_spec.rb +15 -0
  197. data/spec/moneta/adapters/tdb/adapter_tdb_spec.rb +7 -0
  198. data/spec/moneta/adapters/tdb/standard_tdb_spec.rb +7 -0
  199. data/spec/moneta/adapters/tdb/standard_tdb_with_expires_spec.rb +11 -0
  200. data/spec/moneta/adapters/tokyocabinet/adapter_tokyocabinet_bdb_spec.rb +7 -0
  201. data/spec/moneta/adapters/tokyocabinet/adapter_tokyocabinet_hdb_spec.rb +7 -0
  202. data/spec/moneta/adapters/tokyocabinet/standard_tokyocabinet_spec.rb +7 -0
  203. data/spec/moneta/adapters/tokyocabinet/standard_tokyocabinet_with_expires_spec.rb +11 -0
  204. data/spec/moneta/adapters/tokyotyrant/adapter_tokyotyrant_spec.rb +7 -0
  205. data/spec/moneta/adapters/tokyotyrant/standard_tokyotyrant_spec.rb +4 -0
  206. data/spec/moneta/adapters/tokyotyrant/standard_tokyotyrant_with_expires_spec.rb +8 -0
  207. data/spec/moneta/adapters/yaml/adapter_yaml_spec.rb +7 -0
  208. data/spec/moneta/adapters/yaml/standard_yaml_spec.rb +9 -0
  209. data/spec/moneta/adapters/yaml/standard_yaml_with_expires_spec.rb +13 -0
  210. data/spec/moneta/builder_spec.rb +0 -1
  211. data/spec/moneta/mutex_spec.rb +6 -23
  212. data/spec/moneta/proxies/cache/cache_file_memory_spec.rb +24 -0
  213. data/spec/moneta/proxies/cache/cache_memory_null_spec.rb +12 -0
  214. data/spec/moneta/proxies/expires/expires_file_spec.rb +28 -0
  215. data/spec/moneta/proxies/expires/expires_memory_spec.rb +15 -0
  216. data/spec/moneta/proxies/expires/expires_memory_with_default_expires_spec.rb +16 -0
  217. data/spec/moneta/proxies/lock/lock_spec.rb +10 -0
  218. data/spec/moneta/{optionmerger_spec.rb → proxies/optionmerger/optionmerger_spec.rb} +2 -18
  219. data/spec/moneta/proxies/pool/pool_spec.rb +12 -0
  220. data/spec/moneta/proxies/proxy/proxy_expires_memory_spec.rb +16 -0
  221. data/spec/moneta/proxies/proxy/proxy_redis_spec.rb +13 -0
  222. data/spec/moneta/proxies/shared/shared_tcp_spec.rb +49 -0
  223. data/spec/moneta/proxies/shared/shared_unix_spec.rb +48 -0
  224. data/spec/moneta/proxies/transformer/transformer_bencode_spec.rb +19 -0
  225. data/spec/moneta/proxies/transformer/transformer_bert_spec.rb +19 -0
  226. data/spec/moneta/proxies/transformer/transformer_bson_spec.rb +23 -0
  227. data/spec/moneta/proxies/transformer/transformer_bzip2_spec.rb +19 -0
  228. data/spec/moneta/proxies/transformer/transformer_json_spec.rb +19 -0
  229. data/spec/moneta/proxies/transformer/transformer_key_inspect_spec.rb +17 -0
  230. data/spec/moneta/proxies/transformer/transformer_key_marshal_spec.rb +17 -0
  231. data/spec/moneta/proxies/transformer/transformer_key_to_s_spec.rb +17 -0
  232. data/spec/moneta/proxies/transformer/transformer_key_yaml_spec.rb +17 -0
  233. data/spec/moneta/proxies/transformer/transformer_lz4_spec.rb +19 -0
  234. data/spec/moneta/proxies/transformer/transformer_lzma_spec.rb +19 -0
  235. data/spec/moneta/proxies/transformer/transformer_lzo_spec.rb +19 -0
  236. data/spec/moneta/proxies/transformer/transformer_marshal_base64_spec.rb +20 -0
  237. data/spec/moneta/proxies/transformer/transformer_marshal_city128_spec.rb +15 -0
  238. data/spec/moneta/proxies/transformer/transformer_marshal_city32_spec.rb +15 -0
  239. data/spec/moneta/proxies/transformer/transformer_marshal_city64_spec.rb +15 -0
  240. data/spec/moneta/proxies/transformer/transformer_marshal_escape_spec.rb +15 -0
  241. data/spec/moneta/proxies/transformer/transformer_marshal_hex_spec.rb +20 -0
  242. data/spec/moneta/proxies/transformer/transformer_marshal_hmac_spec.rb +19 -0
  243. data/spec/moneta/proxies/transformer/transformer_marshal_md5_spec.rb +15 -0
  244. data/spec/moneta/proxies/transformer/transformer_marshal_md5_spread_spec.rb +15 -0
  245. data/spec/moneta/proxies/transformer/transformer_marshal_prefix_spec.rb +15 -0
  246. data/spec/moneta/proxies/transformer/transformer_marshal_qp_spec.rb +20 -0
  247. data/spec/moneta/proxies/transformer/transformer_marshal_rmd160_spec.rb +15 -0
  248. data/spec/moneta/proxies/transformer/transformer_marshal_sha1_spec.rb +15 -0
  249. data/spec/moneta/proxies/transformer/transformer_marshal_sha256_spec.rb +15 -0
  250. data/spec/moneta/proxies/transformer/transformer_marshal_sha384_spec.rb +15 -0
  251. data/spec/moneta/proxies/transformer/transformer_marshal_sha512_spec.rb +15 -0
  252. data/spec/moneta/proxies/transformer/transformer_marshal_spec.rb +19 -0
  253. data/spec/moneta/proxies/transformer/transformer_marshal_truncate_spec.rb +15 -0
  254. data/spec/moneta/proxies/transformer/transformer_marshal_urlsafe_base64_spec.rb +20 -0
  255. data/spec/moneta/proxies/transformer/transformer_marshal_uuencode_spec.rb +19 -0
  256. data/spec/moneta/proxies/transformer/transformer_msgpack_spec.rb +19 -0
  257. data/spec/moneta/proxies/transformer/transformer_ox_spec.rb +19 -0
  258. data/spec/moneta/proxies/transformer/transformer_php_spec.rb +19 -0
  259. data/spec/moneta/proxies/transformer/transformer_quicklz_spec.rb +19 -0
  260. data/spec/moneta/proxies/transformer/transformer_snappy_spec.rb +19 -0
  261. data/spec/moneta/proxies/transformer/transformer_tnet_spec.rb +19 -0
  262. data/spec/moneta/proxies/transformer/transformer_value_marshal_spec.rb +19 -0
  263. data/spec/moneta/proxies/transformer/transformer_value_yaml_spec.rb +19 -0
  264. data/spec/moneta/proxies/transformer/transformer_yaml_spec.rb +19 -0
  265. data/spec/moneta/proxies/transformer/transformer_zlib_spec.rb +19 -0
  266. data/spec/moneta/proxies/weak_create/weak_create_spec.rb +21 -0
  267. data/spec/moneta/proxies/weak_each_key/weak_each_key_spec.rb +24 -0
  268. data/spec/moneta/proxies/weak_increment/weak_increment_spec.rb +21 -0
  269. data/spec/moneta/semaphore_spec.rb +6 -23
  270. data/spec/moneta/stack_file_memory_spec.rb +5 -29
  271. data/spec/moneta/stack_memory_file_spec.rb +5 -31
  272. data/spec/quality_spec.rb +1 -1
  273. data/{spec → test}/action_dispatch/fixtures/session_autoload_test/foo.rb +0 -0
  274. data/{spec/action_dispatch/session_moneta_store_spec.rb → test/action_dispatch/session_moneta_store_test.rb} +13 -5
  275. metadata +415 -355
  276. data/script/generate-specs +0 -2696
  277. data/spec/moneta/adapter_activerecord_exisiting_connection_spec.rb +0 -36
  278. data/spec/moneta/adapter_activerecord_spec.rb +0 -65
  279. data/spec/moneta/adapter_cassandra_spec.rb +0 -33
  280. data/spec/moneta/adapter_cassandra_with_default_expires_spec.rb +0 -34
  281. data/spec/moneta/adapter_client_spec.rb +0 -35
  282. data/spec/moneta/adapter_cookie_spec.rb +0 -30
  283. data/spec/moneta/adapter_couch_spec.rb +0 -36
  284. data/spec/moneta/adapter_datamapper_spec.rb +0 -64
  285. data/spec/moneta/adapter_daybreak_spec.rb +0 -31
  286. data/spec/moneta/adapter_dbm_spec.rb +0 -31
  287. data/spec/moneta/adapter_file_spec.rb +0 -34
  288. data/spec/moneta/adapter_fog_spec.rb +0 -37
  289. data/spec/moneta/adapter_gdbm_spec.rb +0 -31
  290. data/spec/moneta/adapter_hbase_spec.rb +0 -33
  291. data/spec/moneta/adapter_kyotocabinet_spec.rb +0 -31
  292. data/spec/moneta/adapter_leveldb_spec.rb +0 -31
  293. data/spec/moneta/adapter_lmdb_spec.rb +0 -32
  294. data/spec/moneta/adapter_lmdb_with_db_spec.rb +0 -32
  295. data/spec/moneta/adapter_localmemcache_spec.rb +0 -32
  296. data/spec/moneta/adapter_memcached_dalli_spec.rb +0 -36
  297. data/spec/moneta/adapter_memcached_dalli_with_default_expires_spec.rb +0 -37
  298. data/spec/moneta/adapter_memcached_native_spec.rb +0 -36
  299. data/spec/moneta/adapter_memcached_native_with_default_expires_spec.rb +0 -37
  300. data/spec/moneta/adapter_memcached_spec.rb +0 -36
  301. data/spec/moneta/adapter_memcached_with_default_expires_spec.rb +0 -37
  302. data/spec/moneta/adapter_memory_spec.rb +0 -184
  303. data/spec/moneta/adapter_mongo_moped_spec.rb +0 -64
  304. data/spec/moneta/adapter_mongo_moped_with_default_expires_spec.rb +0 -53
  305. data/spec/moneta/adapter_mongo_official_spec.rb +0 -64
  306. data/spec/moneta/adapter_mongo_official_with_default_expires_spec.rb +0 -53
  307. data/spec/moneta/adapter_mongo_spec.rb +0 -51
  308. data/spec/moneta/adapter_mongo_with_default_expires_spec.rb +0 -53
  309. data/spec/moneta/adapter_pstore_spec.rb +0 -250
  310. data/spec/moneta/adapter_redis_spec.rb +0 -36
  311. data/spec/moneta/adapter_redis_with_default_expires_spec.rb +0 -37
  312. data/spec/moneta/adapter_restclient_spec.rb +0 -33
  313. data/spec/moneta/adapter_riak_spec.rb +0 -36
  314. data/spec/moneta/adapter_sdbm_spec.rb +0 -30
  315. data/spec/moneta/adapter_sequel_spec.rb +0 -34
  316. data/spec/moneta/adapter_sqlite_spec.rb +0 -32
  317. data/spec/moneta/adapter_tdb_spec.rb +0 -31
  318. data/spec/moneta/adapter_tokyocabinet_bdb_spec.rb +0 -31
  319. data/spec/moneta/adapter_tokyocabinet_hdb_spec.rb +0 -31
  320. data/spec/moneta/adapter_tokyotyrant_spec.rb +0 -34
  321. data/spec/moneta/adapter_yaml_spec.rb +0 -57
  322. data/spec/moneta/cache_file_memory_spec.rb +0 -50
  323. data/spec/moneta/cache_memory_null_spec.rb +0 -35
  324. data/spec/moneta/expires_file_spec.rb +0 -78
  325. data/spec/moneta/expires_memory_spec.rb +0 -189
  326. data/spec/moneta/expires_memory_with_default_expires_spec.rb +0 -190
  327. data/spec/moneta/lock_spec.rb +0 -187
  328. data/spec/moneta/null_adapter_spec.rb +0 -86
  329. data/spec/moneta/pool_spec.rb +0 -38
  330. data/spec/moneta/proxy_expires_memory_spec.rb +0 -191
  331. data/spec/moneta/proxy_redis_spec.rb +0 -40
  332. data/spec/moneta/shared_tcp_spec.rb +0 -46
  333. data/spec/moneta/shared_unix_spec.rb +0 -46
  334. data/spec/moneta/standard_activerecord_spec.rb +0 -253
  335. data/spec/moneta/standard_activerecord_with_expires_spec.rb +0 -255
  336. data/spec/moneta/standard_cassandra_spec.rb +0 -252
  337. data/spec/moneta/standard_client_tcp_spec.rb +0 -269
  338. data/spec/moneta/standard_client_unix_spec.rb +0 -254
  339. data/spec/moneta/standard_couch_spec.rb +0 -252
  340. data/spec/moneta/standard_couch_with_expires_spec.rb +0 -254
  341. data/spec/moneta/standard_datamapper_spec.rb +0 -254
  342. data/spec/moneta/standard_datamapper_with_expires_spec.rb +0 -256
  343. data/spec/moneta/standard_datamapper_with_repository_spec.rb +0 -254
  344. data/spec/moneta/standard_daybreak_spec.rb +0 -250
  345. data/spec/moneta/standard_daybreak_with_expires_spec.rb +0 -252
  346. data/spec/moneta/standard_dbm_spec.rb +0 -250
  347. data/spec/moneta/standard_dbm_with_expires_spec.rb +0 -252
  348. data/spec/moneta/standard_file_spec.rb +0 -253
  349. data/spec/moneta/standard_file_with_expires_spec.rb +0 -255
  350. data/spec/moneta/standard_fog_spec.rb +0 -256
  351. data/spec/moneta/standard_fog_with_expires_spec.rb +0 -258
  352. data/spec/moneta/standard_gdbm_spec.rb +0 -250
  353. data/spec/moneta/standard_gdbm_with_expires_spec.rb +0 -252
  354. data/spec/moneta/standard_hashfile_spec.rb +0 -253
  355. data/spec/moneta/standard_hashfile_with_expires_spec.rb +0 -255
  356. data/spec/moneta/standard_hbase_spec.rb +0 -252
  357. data/spec/moneta/standard_hbase_with_expires_spec.rb +0 -255
  358. data/spec/moneta/standard_kyotocabinet_spec.rb +0 -250
  359. data/spec/moneta/standard_kyotocabinet_with_expires_spec.rb +0 -252
  360. data/spec/moneta/standard_leveldb_spec.rb +0 -250
  361. data/spec/moneta/standard_leveldb_with_expires_spec.rb +0 -252
  362. data/spec/moneta/standard_lmdb_spec.rb +0 -251
  363. data/spec/moneta/standard_lmdb_with_expires_spec.rb +0 -253
  364. data/spec/moneta/standard_localmemcache_spec.rb +0 -251
  365. data/spec/moneta/standard_localmemcache_with_expires_spec.rb +0 -252
  366. data/spec/moneta/standard_lruhash_spec.rb +0 -187
  367. data/spec/moneta/standard_lruhash_with_expires_spec.rb +0 -189
  368. data/spec/moneta/standard_memcached_dalli_spec.rb +0 -255
  369. data/spec/moneta/standard_memcached_native_spec.rb +0 -255
  370. data/spec/moneta/standard_memcached_spec.rb +0 -255
  371. data/spec/moneta/standard_memory_spec.rb +0 -187
  372. data/spec/moneta/standard_memory_with_compress_spec.rb +0 -187
  373. data/spec/moneta/standard_memory_with_expires_spec.rb +0 -189
  374. data/spec/moneta/standard_memory_with_json_key_serializer_spec.rb +0 -86
  375. data/spec/moneta/standard_memory_with_json_serializer_spec.rb +0 -49
  376. data/spec/moneta/standard_memory_with_json_value_serializer_spec.rb +0 -90
  377. data/spec/moneta/standard_memory_with_prefix_spec.rb +0 -187
  378. data/spec/moneta/standard_memory_with_snappy_compress_spec.rb +0 -187
  379. data/spec/moneta/standard_mongo_moped_spec.rb +0 -255
  380. data/spec/moneta/standard_mongo_official_spec.rb +0 -255
  381. data/spec/moneta/standard_mongo_spec.rb +0 -255
  382. data/spec/moneta/standard_null_spec.rb +0 -120
  383. data/spec/moneta/standard_pstore_spec.rb +0 -253
  384. data/spec/moneta/standard_pstore_with_expires_spec.rb +0 -255
  385. data/spec/moneta/standard_redis_spec.rb +0 -255
  386. data/spec/moneta/standard_restclient_spec.rb +0 -252
  387. data/spec/moneta/standard_riak_spec.rb +0 -255
  388. data/spec/moneta/standard_riak_with_expires_spec.rb +0 -256
  389. data/spec/moneta/standard_sdbm_spec.rb +0 -249
  390. data/spec/moneta/standard_sdbm_with_expires_spec.rb +0 -251
  391. data/spec/moneta/standard_sequel_spec.rb +0 -253
  392. data/spec/moneta/standard_sequel_with_expires_spec.rb +0 -255
  393. data/spec/moneta/standard_sqlite_spec.rb +0 -251
  394. data/spec/moneta/standard_sqlite_with_expires_spec.rb +0 -253
  395. data/spec/moneta/standard_tdb_spec.rb +0 -250
  396. data/spec/moneta/standard_tdb_with_expires_spec.rb +0 -252
  397. data/spec/moneta/standard_tokyocabinet_spec.rb +0 -250
  398. data/spec/moneta/standard_tokyocabinet_with_expires_spec.rb +0 -252
  399. data/spec/moneta/standard_tokyotyrant_spec.rb +0 -253
  400. data/spec/moneta/standard_tokyotyrant_with_expires_spec.rb +0 -255
  401. data/spec/moneta/standard_yaml_spec.rb +0 -250
  402. data/spec/moneta/standard_yaml_with_expires_spec.rb +0 -252
  403. data/spec/moneta/transformer_bencode_spec.rb +0 -55
  404. data/spec/moneta/transformer_bert_spec.rb +0 -55
  405. data/spec/moneta/transformer_bson_spec.rb +0 -60
  406. data/spec/moneta/transformer_bzip2_spec.rb +0 -55
  407. data/spec/moneta/transformer_json_spec.rb +0 -55
  408. data/spec/moneta/transformer_key_inspect_spec.rb +0 -91
  409. data/spec/moneta/transformer_key_marshal_spec.rb +0 -191
  410. data/spec/moneta/transformer_key_to_s_spec.rb +0 -91
  411. data/spec/moneta/transformer_key_yaml_spec.rb +0 -191
  412. data/spec/moneta/transformer_lz4_spec.rb +0 -55
  413. data/spec/moneta/transformer_lzma_spec.rb +0 -55
  414. data/spec/moneta/transformer_lzo_spec.rb +0 -55
  415. data/spec/moneta/transformer_marshal_base64_spec.rb +0 -194
  416. data/spec/moneta/transformer_marshal_city128_spec.rb +0 -194
  417. data/spec/moneta/transformer_marshal_city32_spec.rb +0 -194
  418. data/spec/moneta/transformer_marshal_city64_spec.rb +0 -194
  419. data/spec/moneta/transformer_marshal_escape_spec.rb +0 -194
  420. data/spec/moneta/transformer_marshal_hex_spec.rb +0 -194
  421. data/spec/moneta/transformer_marshal_hmac_spec.rb +0 -194
  422. data/spec/moneta/transformer_marshal_md5_spec.rb +0 -194
  423. data/spec/moneta/transformer_marshal_md5_spread_spec.rb +0 -194
  424. data/spec/moneta/transformer_marshal_prefix_spec.rb +0 -194
  425. data/spec/moneta/transformer_marshal_qp_spec.rb +0 -194
  426. data/spec/moneta/transformer_marshal_rmd160_spec.rb +0 -194
  427. data/spec/moneta/transformer_marshal_sha1_spec.rb +0 -194
  428. data/spec/moneta/transformer_marshal_sha256_spec.rb +0 -194
  429. data/spec/moneta/transformer_marshal_sha384_spec.rb +0 -194
  430. data/spec/moneta/transformer_marshal_sha512_spec.rb +0 -194
  431. data/spec/moneta/transformer_marshal_spec.rb +0 -191
  432. data/spec/moneta/transformer_marshal_truncate_spec.rb +0 -194
  433. data/spec/moneta/transformer_marshal_uuencode_spec.rb +0 -194
  434. data/spec/moneta/transformer_msgpack_spec.rb +0 -55
  435. data/spec/moneta/transformer_ox_spec.rb +0 -191
  436. data/spec/moneta/transformer_php_spec.rb +0 -55
  437. data/spec/moneta/transformer_quicklz_spec.rb +0 -55
  438. data/spec/moneta/transformer_snappy_spec.rb +0 -55
  439. data/spec/moneta/transformer_tnet_spec.rb +0 -55
  440. data/spec/moneta/transformer_value_marshal_spec.rb +0 -191
  441. data/spec/moneta/transformer_value_yaml_spec.rb +0 -191
  442. data/spec/moneta/transformer_yaml_spec.rb +0 -191
  443. data/spec/moneta/transformer_zlib_spec.rb +0 -55
  444. data/spec/moneta/weak_create_spec.rb +0 -41
  445. data/spec/moneta/weak_increment_spec.rb +0 -41
  446. data/spec/monetaspecs.rb +0 -51267
@@ -1,105 +1,80 @@
1
1
  #!/usr/bin/env ruby
2
2
 
3
- def rspec(spec)
4
- if system("rspec #{spec}")
5
- true
6
- elsif sig = $?.termsig
7
- found = Signal.list.to_a.select {|name, id| id == sig }.first
8
- puts "\e[31m########## SIG#{found ? found.first : sig} rspec #{spec} ##########\e[0m"
9
- false
10
- else
11
- puts "rspec terminated with #{$?.exitstatus}"
12
- false
13
- end
14
- end
15
-
16
3
  ENV['PARALLEL_TESTS'] = 'yes'
17
4
 
18
- specs = Dir['spec/*/*_spec.rb'].sort
5
+ require 'multi_json'
19
6
 
20
- # Shuffle specs to ensure equal distribution over the test groups
21
- # We have to shuffle with the same seed every time because rake is started
22
- # multiple times!
23
- old_seed = srand(43)
24
- specs.shuffle!
25
- srand(old_seed)
7
+ def tag_args tags
8
+ tags.flat_map{ |tag| ['--tag', tag] }
9
+ end
26
10
 
27
- # FIXME:
28
- #
29
- # * QuickLZ segfaults because of an assertion
30
- # QuickLZ is also not maintained on Github, but on Bitbucket
31
- # and I don't know where the issue tracker is.
32
- #
33
- # * PStore increment/locking doesn't work correctly on JRuby
34
- #
35
- unstable = %w(quicklz riak cassandra)
36
- unstable += %w(pstore) if defined?(JRUBY_VERSION)
11
+ def example_ids tags, specs
12
+ json = `bundle exec rspec -f j --dry-run #{tag_args(tags).join(' ')} -- #{specs.join(' ')}`
13
+ data = MultiJson.load(json)
14
+ data['examples'].map{ |example| example['id'] }
15
+ end
37
16
 
38
- unstable_re = /#{unstable.join('|')}/
39
- unstable = specs.select {|s| s =~ unstable_re }
40
- specs -= unstable
17
+ def run(*args)
18
+ pid = spawn(*args)
19
+ Signal.trap("INT") { Process.kill("INT", pid) }
20
+ Process.wait(pid)
21
+ $? == 0
22
+ ensure
23
+ Signal.trap("INT", "DEFAULT")
24
+ end
41
25
 
42
- group = ARGV.first || '1/1'
43
- case group
44
- when /^(\d+)\/(\d+)$/
45
- n = $1.to_i
46
- max = $2.to_i
47
- if n == max
48
- specs = specs[(n-1)*(specs.size/max)..-1]
26
+ tags = ARGV.take_while { |arg| arg[0] != '-' }
27
+ ARGV.shift(tags.length)
28
+ opts = []
29
+ files = nil
30
+ while arg = ARGV.shift
31
+ case arg
32
+ when '--'
33
+ files = ARGV
34
+ break
35
+ when '--remainder'
36
+ files = Dir['spec/**/*_spec.rb', 'test/**/*_test.rb']
37
+ existing = File.open('.travis.yml').each_line.flat_map do |line|
38
+ next unless matches = line.match(%r{((?:test|spec)/(?:[\w\.]+/?)*)})
39
+ path = matches[1]
40
+ path[-3..-1] == '.rb' ? path : path + '/**/*.rb'
41
+ end.compact
42
+ files -= Dir[*existing]
49
43
  else
50
- specs = specs[(n-1)*(specs.size/max), specs.size/max]
44
+ opts << arg
51
45
  end
52
- when 'unstable'
53
- specs = unstable
54
- else
55
- puts "Invalid test group #{group}"
56
- exit 1
57
46
  end
58
47
 
59
- puts "The following specs will be executed:\n\t#{specs.join "\n\t"}\n\n"
48
+ files ||= Dir['spec', 'test/**/*_test.rb']
49
+ specs, tests = files.partition { |file| file.match /^spec/ }
60
50
 
61
- # Memcached and Redis specs cannot be used in parallel
62
- # because of flushing and lacking namespaces
63
- parallel = []
64
- %w(memcached redis client shared riak tokyotyrant couch cassandra).each do |name|
65
- serial = specs.select { |s| s.include?(name) }
66
- unless serial.empty?
67
- specs -= serial
68
- parallel << serial
69
- end
70
- end
51
+ puts "The following specs will be executed:\n\t#{specs.join "\n\t"}\n\n" unless specs.empty?
52
+ puts "The following tests will be executed:\n\t#{tests.join "\n\t"}\n\n" unless tests.empty?
71
53
 
72
- # The activesupport cache specs also use memcached
73
- activesupport_cache_specs = specs.grep(/active_support.+cache/)
74
- specs -= activesupport_cache_specs
54
+ results = []
55
+ unless specs.empty?
56
+ # run all non :isolate examples in parallel
57
+ results << run(*%w{bundle exec parallel_rspec --},
58
+ *opts,
59
+ *tag_args(tags | %w{~isolate}),
60
+ '--',
61
+ *specs)
75
62
 
76
- if memcache_specs = parallel.find{ |serial| serial.all?{ |s| s.match /memcached/ } }
77
- activesupport_cache_specs.each(&memcache_specs.method(:push))
78
- else
79
- parallel += activesupport_cache_specs
63
+ # find the example IDs of the isolate examples to be run in serial
64
+ ids = example_ids(tags, specs) - example_ids(tags | %w{~isolate}, specs)
65
+ unless ids.empty?
66
+ results << run(*%w{bundle exec rspec},
67
+ *opts,
68
+ '--',
69
+ *ids)
70
+ end
80
71
  end
81
72
 
82
- # All the left-overs
83
- parallel += specs.map {|s| [s] }
84
-
85
- threads = []
86
- failed = false
87
- parallel.each do |serial|
88
- threads << Thread.new do
89
- begin
90
- serial.each do |spec|
91
- failed = true unless rspec(spec)
92
- end
93
- ensure
94
- threads.delete Thread.current
95
- end
96
- end
97
- sleep 0.1
98
- sleep 0.1 while threads.size >= 5
73
+ tests.each do |test|
74
+ results << run(*%w{bundle exec ruby}, test)
99
75
  end
100
- sleep 0.1 until threads.empty?
101
76
 
102
- if failed
77
+ if results.any?{ |result| !result }
103
78
  puts "\e[31m########## MONETA TESTSUITE FAILED ##########\e[0m"
104
79
  exit 1
105
80
  end
@@ -0,0 +1,46 @@
1
+ #!/bin/sh
2
+
3
+ cd $(dirname $(dirname $0))
4
+
5
+ mkdir -p hbase
6
+ mkdir -p zookeeper
7
+ mkdir -p downloads
8
+ root=$(pwd)
9
+
10
+ version=$(curl -sS https://www-us.apache.org/dist/hbase/stable/ | grep -oP '(?<=hbase-)(\d+\.?)+' | head -n1)
11
+
12
+ echo HBase stable version is $version
13
+
14
+ if [ ! -f downloads/hbase-$version-bin.tar.gz ]; then
15
+ echo Downloading HBase ...
16
+ wget -P downloads http://www-us.apache.org/dist/hbase/stable/hbase-$version-bin.tar.gz
17
+ fi
18
+
19
+ echo Extracting HBase ...
20
+ cd hbase
21
+ tar -zxf $root/downloads/hbase-$version-bin.tar.gz
22
+
23
+ echo Configuring HBase ...
24
+ echo "export JAVA_HOME=/usr" >> hbase-$version/conf/hbase-env.sh
25
+ tee <<-EOF > hbase-$version/conf/hbase-site.xml
26
+ <configuration>
27
+ <property>
28
+ <name>hbase.rootdir</name>
29
+ <value>file://$root/hbase</value>
30
+ </property>
31
+ <property>
32
+ <name>hbase.zookeeper.property.dataDir</name>
33
+ <value>$root/zookeeper</value>
34
+ </property>
35
+ <property>
36
+ <name>hbase.unsafe.stream.capability.enforce</name>
37
+ <value>false</value>
38
+ </property>
39
+ </configuration>
40
+ EOF
41
+
42
+ echo Launching HBase ...
43
+ ./hbase-$version/bin/start-hbase.sh
44
+ ./hbase-$version/bin/hbase-daemon.sh start thrift
45
+
46
+ cd $root
@@ -1,11 +1,18 @@
1
1
  #!/bin/bash
2
2
 
3
- echo 'Starting TokyoTyrant'
3
+ echo Starting TokyoTyrant ...
4
4
  /usr/sbin/ttserver -dmn -pid /tmp/ttserver.pid -log /tmp/ttserver.log -port 1978
5
5
 
6
+ # Reconfigure CouchDB to use delayed commits for speed: http://guide.couchdb.org/draft/performance.html
7
+ sudo sed -i '/\[couchdb\]/a delayed_commits = true' /etc/couchdb/local.ini
8
+ sudo service couchdb restart
9
+
10
+ # Start HBase
11
+ $(dirname $0)/start-hbase
12
+
6
13
  # Waiting for servers to start
7
14
  sleep 3
8
15
 
9
- echo 'TokyoTyrant status'
16
+ echo TokyoTyrant status:
10
17
  ps aux | grep ttserver
11
18
  cat /tmp/ttserver.log
@@ -0,0 +1,148 @@
1
+ #!/usr/bin/env ruby
2
+ # coding: utf-8
3
+
4
+ require 'rubygems'
5
+ require 'bundler/setup'
6
+ Bundler.require(:doc)
7
+
8
+ require 'yaml'
9
+
10
+ output = "<table>\n"
11
+ output << <<-TAB.lines.map(&:strip).join
12
+ <tr>
13
+ <th>Adapter</th><th>Required gems</th>
14
+ <th style="writing-mode:tb">MRI support<sup>1</sup></th>
15
+ <th style="writing-mode:tb">JRuby support<sup>1</sup></th>
16
+ <th style="writing-mode:tb">Multi-thread safe<sup>2</sup></th>
17
+ <th style="writing-mode:tb">Multi-process safe<sup>3</sup></th>
18
+ <th style="writing-mode:tb">Atomic increment<sup>4</sup></th>
19
+ <th style="writing-mode:tb">Atomic create<sup>5</sup></th>
20
+ <th style="writing-mode:tb">Native expires<sup>6</sup></th>
21
+ <th style="writing-mode:tb">Persistent</th>
22
+ <th style="writing-mode:tb">Key Traversal</th>
23
+ <th style="writing-mode:tb">Bulk read<sup>7</sup></th>
24
+ <th style="writing-mode:tb">Bulk write<sup>8</sup></th>
25
+ <th>Description</th>
26
+ </tr>
27
+ TAB
28
+ output << "\n\n"
29
+
30
+ footnotes = {
31
+ "platform" => <<-EOF,
32
+ Indicates that the adapter is expected to work on this platform. Most adapters will at least
33
+ work on MRI, but some are curently considered unstable, in which case they are not supported
34
+ on any platform.
35
+ EOF
36
+ "multi-thread safe" => <<-EOF,
37
+ Make adapters thread-safe by using `Moneta::Lock` or by passing the option `threadsafe: true` to
38
+ `Moneta#new`. There is also `Moneta::Pool` which can be used to share a store between multiple
39
+ threads if the store is multi-process safe. I recommend to add the option `:threadsafe` to
40
+ ensure thread-safety since for example under JRuby and Rubinius even the basic datastructures
41
+ are not thread safe due to the lack of a global interpreter lock (GIL). This differs from MRI
42
+ where some adapters might appear thread safe already but only due to the GIL.
43
+ EOF
44
+ "multi-process safe" => <<-EOF,
45
+ Share a Moneta store between multiple processes using `Moneta::Shared` (See below).
46
+ EOF
47
+ "atomic increment" => <<-EOF,
48
+ If a store provides atomic increment it can be used with `Moneta::Semaphore`. You can add weak
49
+ `#increment` support using the `Moneta::WeakIncrement` proxy.
50
+ EOF
51
+ "atomic create" => <<-EOF,
52
+ If a store provides atomic creation it can be used with `Moneta::Mutex`. You can add weak
53
+ `#create` support using the `Moneta::WeakCreate` proxy.
54
+ EOF
55
+ "native expires" => <<-EOF,
56
+ Add expiration support by using `Moneta::Expires` or by passing the option `expires: true` to
57
+ `Moneta#new`.
58
+ EOF
59
+ "bulk read" => <<-EOF,
60
+ This indicates that there is some performance gain when fetching
61
+ multiple values at once using `#values_at`/`#fetch_values` or `#slice`.
62
+ For instance, the `MGET` instruction in Redis, or the ability to retrieve
63
+ several rows in one query in SQL.
64
+ EOF
65
+ "bulk write" => <<-EOF
66
+ This indicates that there is some performance gain when storing multiple
67
+ key/value pairs at once using `#merge!`/`#update`.
68
+ EOF
69
+ }
70
+
71
+ YAML.parse_stream(File.read(File.join(File.dirname(File.dirname(__FILE__)), 'feature_matrix.yaml'))) do |document|
72
+ feature_group = document.to_ruby
73
+
74
+ output << %{<tr><th colspan="2">#{feature_group['group']}</th><th colspan="12"></th></tr>\n\n}
75
+
76
+ feature_group['notes'].each do |k,v|
77
+ footnotes[k] = v
78
+ end
79
+
80
+ feature_group['backends'].each do |backend|
81
+ output << '<tr>'
82
+ output << "<td>#{backend['adapter']}</td>"
83
+ output << "<td>#{backend['gems'] || '-'}</td>"
84
+
85
+ features = backend['features'] | (feature_group['features'] || [])
86
+ features += backend['platforms'] || []
87
+ %w{MRI JRuby threadsafe multiprocess increment create expires persist each_key bulk_read bulk_write}.each do |feature|
88
+ supported = if features.include? feature
89
+ "yes"
90
+ elsif backend['unknown'] && backend['unknown'].include?(feature)
91
+ "unknown"
92
+ else
93
+ "no"
94
+ end
95
+
96
+ note = if backend['notes'] && backend['notes'][feature]
97
+ "<sup>#{footnotes.keys.index(backend['notes'][feature]) + 1}</sup>"
98
+ else
99
+ ''
100
+ end
101
+
102
+ mark = case supported
103
+ when "yes"
104
+ "✓"
105
+ when "no"
106
+ "✗"
107
+ when "unknown"
108
+ '?'
109
+ end
110
+
111
+ colour = case supported
112
+ when "yes"
113
+ '#5F5'
114
+ when "no"
115
+ '#F44'
116
+ when "unknown"
117
+ '#55F'
118
+ end
119
+
120
+ output << %{<td style="text-align:center;background:#{colour}">#{mark}#{note}</td>}
121
+ end
122
+
123
+ html_description = if backend['description']
124
+ Kramdown::Document.new(backend['description']).to_html.match('<p>(.*)</p>')[1]
125
+ else
126
+ ''
127
+ end
128
+ output << "<td>#{html_description}</td>"
129
+
130
+ output << '</tr>'
131
+ output << "\n\n"
132
+ end
133
+
134
+
135
+ end
136
+
137
+ output << "</table>\n\n"
138
+
139
+ footnotes.each_value.each_with_index do |note, idx|
140
+ output << "#{idx+1}. #{note.lines.map(&:strip).join(" ")}\n"
141
+ end
142
+
143
+ readme = File.open('README.md', 'r+')
144
+ new_readme = readme.read.sub(/(name="backend-matrix".*?\n).*?(------)/m, "\\1\n#{output}\n\\2")
145
+ readme.rewind
146
+ readme << new_readme
147
+ readme.truncate(readme.tell)
148
+
@@ -3,19 +3,6 @@ require 'active_support'
3
3
  require 'active_support/cache/moneta_store'
4
4
  require 'ostruct'
5
5
 
6
- module MonetaStoreHelpers
7
- def with_notifications
8
- described_class.instrument = true
9
- yield
10
- ensure
11
- described_class.instrument = false
12
- end
13
- end
14
-
15
- RSpec.configure do |config|
16
- config.include(MonetaStoreHelpers)
17
- end
18
-
19
6
  describe "cache_moneta_store" do
20
7
  before(:all) do
21
8
  @events = []
@@ -30,75 +17,101 @@ describe "cache_moneta_store" do
30
17
 
31
18
  # All stores should implement this basic behavior.
32
19
  shared_examples :basic_store do
33
- before(:each) do
34
- @rabbit = OpenStruct.new name: 'bunny'
35
- @white_rabbit = OpenStruct.new color: 'white'
20
+ let(:rabbit) { OpenStruct.new name: 'bunny' }
21
+ let(:white_rabbit) { OpenStruct.new color: 'white' }
36
22
 
23
+ before(:each) do
37
24
  store.clear
38
- store.write 'rabbit', @rabbit
25
+ store.write 'rabbit', rabbit
26
+ @events.clear
39
27
  end
40
28
 
41
29
  it 'reads the data' do
42
- store.read('rabbit').should == @rabbit
30
+ expect(store.read('rabbit')).to eq rabbit
43
31
  end
44
32
 
45
33
  it 'writes the data' do
46
- store.write 'rabbit', @white_rabbit
47
- store.read('rabbit').should == @white_rabbit
34
+ store.write 'rabbit', white_rabbit
35
+ expect(store.read('rabbit')).to eq white_rabbit
48
36
  end
49
37
 
50
38
  it 'deletes data' do
51
39
  store.delete 'rabbit'
52
- store.read('rabbit').should be_nil
40
+ expect(store.read('rabbit')).to be_nil
53
41
  end
54
42
 
55
43
  it 'verifies existence of an object in the store' do
56
- store.exist?('rabbit').should be true
57
- (!!store.exist?('rab-a-dub')).should be false
44
+ expect(store.exist?('rabbit')).to be true
45
+ expect(!!store.exist?('rab-a-dub')).to be false
58
46
  end
59
47
 
60
48
  it 'fetches data' do
61
- store.fetch('rabbit').should == @rabbit
62
- store.fetch('rub-a-dub').should be_nil
49
+ expect(store.fetch('rabbit')).to eq rabbit
50
+ expect(store.fetch('rub-a-dub')).to be_nil
63
51
  store.fetch('rub-a-dub') { 'Flora de Cana' }
64
- store.fetch('rub-a-dub').should == 'Flora de Cana'
52
+ expect(store.fetch('rub-a-dub')).to eq 'Flora de Cana'
65
53
  end
66
54
 
67
55
  it 'reads multiple keys' do
68
56
  store.write 'irish whisky', 'Jameson'
69
57
  result = store.read_multi 'rabbit', 'irish whisky'
70
- result['rabbit'].should == @rabbit
71
- result['irish whisky'].should == 'Jameson'
58
+ expect(result['rabbit']).to eq rabbit
59
+ expect(result['irish whisky']).to eq 'Jameson'
72
60
  end
73
61
 
74
62
  it 'reads multiple keys and returns only the matched ones' do
75
63
  store.delete 'irish whisky'
76
64
  result = store.read_multi 'rabbit', 'irish whisky'
77
- result.should_not include('irish whisky')
78
- result.should include('rabbit')
65
+ expect(result).not_to include('irish whisky')
66
+ expect(result).to include('rabbit')
67
+ end
68
+
69
+ it 'fetches multiple keys and fills in the missing ones' do
70
+ store.delete 'irish whisky'
71
+ result = store.fetch_multi('rabbit', 'irish whisky') do |k|
72
+ k + ' was missing'
73
+ end
74
+ expect(result['rabbit']).to eq rabbit
75
+ expect(result['irish whisky']).to eq 'irish whisky was missing'
76
+ expect(store.fetch 'irish whisky').to eq 'irish whisky was missing'
79
77
  end
80
78
  end
81
79
 
82
80
  shared_examples :expiry do
83
- it 'writes the data with expiration time' do
84
- store.write 'rabbit', @white_rabbit, expires_in: 1.second
85
- store.read('rabbit').should == @white_rabbit
86
- sleep 2
87
- store.read('rabbit').should be_nil
88
- end
81
+ at_each_usec do
82
+ it 'writes the data with expiration time' do
83
+ store.write 'rabbit', white_rabbit, expires_in: 0.2.second
84
+ expect(store.read('rabbit')).to eq white_rabbit
85
+ sleep 0.3
86
+ expect(store.read('rabbit')).to be_nil
87
+ end
89
88
 
90
- it "sets expiry on cache miss" do
91
- store.fetch('rabbit', force: true) # force cache miss
92
- store.fetch('rabbit', force: true, expires_in: 1.second) { @white_rabbit }
93
- store.fetch('rabbit').should == @white_rabbit
94
- sleep 2
95
- store.fetch('rabbit').should be_nil
96
- end
89
+ it 'writes multiple values with expiration time' do
90
+ store.write_multi({
91
+ 'rabbit' => white_rabbit,
92
+ 'irish whisky' => 'Jameson'
93
+ }, expires_in: 0.2.second)
97
94
 
98
- it 'does not set expiry on cache hit' do
99
- store.fetch('rabbit', expires_in: 1.second) { @white_rabbit }.should == @rabbit
100
- sleep 2
101
- store.fetch('rabbit').should == @rabbit
95
+ expect(store.read_multi('rabbit', 'irish whisky')).to eq \
96
+ 'rabbit' => white_rabbit,
97
+ 'irish whisky' => 'Jameson'
98
+
99
+ sleep 0.3
100
+ expect(store.read_multi('rabbit', 'irish whisky')).to be_empty
101
+ end
102
+
103
+ it "sets expiry on cache miss" do
104
+ store.fetch('rabbit', force: true, expires_in: 0.2.second) { white_rabbit }
105
+ expect(store.fetch('rabbit')).to eq white_rabbit
106
+ sleep 0.3
107
+ expect(store.fetch('rabbit')).to be_nil
108
+ end
109
+
110
+ it 'does not set expiry on cache hit' do
111
+ expect(store.fetch('rabbit', expires_in: 0.2.second) { white_rabbit }).to eq rabbit
112
+ sleep 0.3
113
+ expect(store.fetch('rabbit')).to eq rabbit
114
+ end
102
115
  end
103
116
  end
104
117
 
@@ -106,135 +119,134 @@ describe "cache_moneta_store" do
106
119
  shared_examples :increment_decrement do
107
120
  it 'increments a key' do
108
121
  store.write 'counter', 0, raw: true
109
- 3.times { store.increment 'counter' }
110
- store.read('counter', raw: true).to_i.should == 3
122
+ (1..3).each do |i|
123
+ expect(store.increment('counter')).to eq i
124
+ end
125
+ expect(store.read('counter', raw: true).to_i).to eq 3
111
126
  end
112
127
 
113
128
  it 'decrements a key' do
114
129
  store.write 'counter', 0, raw: true
115
130
  3.times { store.increment 'counter' }
116
131
  2.times { store.decrement 'counter' }
117
- store.read('counter', raw: true).to_i.should == 1
132
+ expect(store.read('counter', raw: true).to_i).to eq 1
118
133
  end
119
134
 
120
135
  it 'increments a key by given value' do
121
136
  store.write 'counter', 0, raw: true
122
137
  store.increment 'counter', 3
123
- store.read('counter', raw: true).to_i.should == 3
138
+ expect(store.read('counter', raw: true).to_i).to eq 3
124
139
  end
125
140
 
126
141
  it 'decrements a key by given value' do
127
142
  store.write 'counter', 0, raw: true
128
143
  3.times { store.increment 'counter' }
129
144
  store.decrement 'counter', 2
130
- store.read('counter', raw: true).to_i.should == 1
145
+ expect(store.read('counter', raw: true).to_i).to eq 1
131
146
  end
132
147
  end
133
148
 
134
149
  shared_examples :basic_instrumentation do
135
150
  it 'notifies on #fetch' do
136
- with_notifications do
137
- store.fetch('radiohead') { 'House Of Cards' }
138
- end
151
+ store.fetch('radiohead') { 'House Of Cards' }
139
152
 
140
153
  read = @events.shift
141
- read.name.should == 'cache_read.active_support'
142
- read.payload.should == { key: 'radiohead', super_operation: :fetch }
154
+ expect(read.name).to eq 'cache_read.active_support'
155
+ expect(read.payload).to include(key: 'radiohead', super_operation: :fetch, hit: false)
143
156
 
144
157
  generate = @events.shift
145
- generate.name.should == 'cache_generate.active_support'
146
- generate.payload.should == { key: 'radiohead' }
158
+ expect(generate.name).to eq 'cache_generate.active_support'
159
+ expect(generate.payload).to include(key: 'radiohead')
147
160
 
148
161
  write = @events.shift
149
- write.name.should == 'cache_write.active_support'
150
- write.payload.should == { key: 'radiohead' }
162
+ expect(write.name).to eq 'cache_write.active_support'
163
+ expect(write.payload).to include(key: 'radiohead')
151
164
  end
152
165
 
153
166
  it 'notifies on #read' do
154
- with_notifications do
155
- store.read 'metallica'
156
- end
167
+ store.read 'metallica'
157
168
 
158
169
  read = @events.shift
159
- read.name.should == 'cache_read.active_support'
160
- read.payload.should == { key: 'metallica', hit: false }
170
+ expect(read.name).to eq 'cache_read.active_support'
171
+ expect(read.payload).to include(key: 'metallica', hit: false)
161
172
  end
162
173
 
163
174
  it 'notifies on #write' do
164
- with_notifications do
165
- store.write 'depeche mode', 'Enjoy The Silence'
166
- end
175
+ store.write 'depeche mode', 'Enjoy The Silence'
167
176
 
168
177
  write = @events.shift
169
- write.name.should == 'cache_write.active_support'
170
- write.payload.should == { key: 'depeche mode' }
178
+ expect(write.name).to eq 'cache_write.active_support'
179
+ expect(write.payload).to include(key: 'depeche mode')
171
180
  end
172
181
 
173
182
  it 'notifies on #delete' do
174
- with_notifications do
175
- store.delete 'the new cardigans'
176
- end
183
+ store.delete 'the new cardigans'
177
184
 
178
185
  delete = @events.shift
179
- delete.name.should == 'cache_delete.active_support'
180
- delete.payload.should == { key: 'the new cardigans' }
186
+ expect(delete.name).to eq 'cache_delete.active_support'
187
+ expect(delete.payload).to include(key: 'the new cardigans')
181
188
  end
182
189
 
183
190
  it 'notifies on #exist?' do
184
- with_notifications do
185
- store.exist? 'the smiths'
186
- end
191
+ store.exist? 'the smiths'
187
192
 
188
193
  exist = @events.shift
189
- exist.name.should == 'cache_exist?.active_support'
190
- exist.payload.should == { key: 'the smiths' }
194
+ expect(exist.name).to eq 'cache_exist?.active_support'
195
+ expect(exist.payload).to include(key: 'the smiths')
191
196
  end
192
-
193
197
  end
194
198
 
195
199
  # This doesn't seem to be documented at all, so we follow the
196
200
  # behavior of MemCacheStore.
197
201
  shared_examples :increment_decrement_instrumentation do
198
202
  it 'notifies on #increment' do
199
- with_notifications do
200
- store.increment 'pearl jam'
201
- end
203
+ store.increment 'pearl jam'
202
204
 
203
205
  increment = @events.shift
204
- increment.name.should == 'cache_increment.active_support'
205
- increment.payload.should == { key: 'pearl jam', amount: 1 }
206
+ expect(increment.name).to eq 'cache_increment.active_support'
207
+ expect(increment.payload).to eq(key: 'pearl jam', amount: 1)
206
208
  end
207
209
 
208
210
  it 'notifies on #decrement' do
209
- with_notifications do
210
- store.decrement 'placebo'
211
- end
212
-
211
+ store.decrement 'placebo'
213
212
  decrement = @events.shift
214
- decrement.name.should == 'cache_decrement.active_support'
215
- decrement.payload.should == { key: 'placebo', amount: 1 }
213
+ expect(decrement.name).to eq 'cache_decrement.active_support'
214
+ expect(decrement.payload).to eq(key: 'placebo', amount: 1)
216
215
  end
217
216
  end
218
217
 
219
218
  describe ActiveSupport::Cache::MonetaStore do
220
- let(:store){ described_class.new(store: Moneta.new(:Memory)) }
221
-
222
- include_examples :basic_store
223
- include_examples :expiry
224
- include_examples :increment_decrement
225
- include_examples :basic_instrumentation
226
- include_examples :increment_decrement_instrumentation
227
-
228
- # FIXME: no other store does this -- perhaps this should be
229
- # removed.
230
- it 'notifies on #clear' do
231
- with_notifications do
219
+ shared_examples :moneta_store do
220
+ include_examples :basic_store
221
+ include_examples :expiry
222
+ include_examples :increment_decrement
223
+ include_examples :basic_instrumentation
224
+ include_examples :increment_decrement_instrumentation
225
+
226
+ # FIXME: no other store does this -- perhaps this should be
227
+ # removed.
228
+ it 'notifies on #clear' do
232
229
  store.clear
230
+
231
+ clear = @events.shift
232
+ expect(clear.name).to eq 'cache_clear.active_support'
233
+ expect(clear.payload).to eq(key: nil)
233
234
  end
235
+ end
234
236
 
235
- clear = @events.shift
236
- clear.name.should == 'cache_clear.active_support'
237
- clear.payload.should == { key: nil }
237
+ context "with :Memory store" do
238
+ let(:store){ described_class.new(store: :Memory) }
239
+ include_examples :moneta_store
240
+ end
241
+
242
+ context "with existing :Memory store" do
243
+ let(:store){ described_class.new(store: ::Moneta.new(:Memory)) }
244
+ include_examples :moneta_store
245
+ end
246
+
247
+ context "with Redis store" do
248
+ let(:store) {described_class.new(store: :Redis) }
249
+ include_examples :moneta_store
238
250
  end
239
251
  end
240
252
 
@@ -248,7 +260,18 @@ describe "cache_moneta_store" do
248
260
  end
249
261
 
250
262
  describe ActiveSupport::Cache::MemCacheStore do
251
- let(:store){ described_class.new }
263
+ let(:store){ described_class.new('127.0.0.1:11213') }
264
+ start_memcached 11213
265
+
266
+ include_examples :basic_store
267
+ include_examples :expiry
268
+ include_examples :increment_decrement
269
+ include_examples :basic_instrumentation
270
+ include_examples :increment_decrement_instrumentation
271
+ end
272
+
273
+ describe ActiveSupport::Cache::RedisCacheStore do
274
+ let(:store){ described_class.new(url: 'redis:///3') }
252
275
 
253
276
  include_examples :basic_store
254
277
  include_examples :expiry