moneta 1.0.0 → 1.5.1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (488) hide show
  1. checksums.yaml +5 -5
  2. data/.github/workflows/ruby.yml +425 -0
  3. data/.gitignore +3 -0
  4. data/.rspec +4 -0
  5. data/.rubocop.yml +194 -0
  6. data/.yardopts +6 -1
  7. data/CHANGES +88 -0
  8. data/CONTRIBUTORS +10 -2
  9. data/Gemfile +198 -76
  10. data/LICENSE +1 -1
  11. data/README.md +181 -83
  12. data/SPEC.md +70 -0
  13. data/feature_matrix.yaml +227 -0
  14. data/lib/action_dispatch/middleware/session/moneta_store.rb +1 -0
  15. data/lib/active_support/cache/moneta_store.rb +102 -6
  16. data/lib/moneta/adapter.rb +52 -0
  17. data/lib/moneta/adapters/activerecord.rb +284 -99
  18. data/lib/moneta/adapters/activesupportcache.rb +120 -0
  19. data/lib/moneta/adapters/cassandra.rb +303 -51
  20. data/lib/moneta/adapters/client.rb +72 -23
  21. data/lib/moneta/adapters/couch.rb +353 -49
  22. data/lib/moneta/adapters/datamapper.rb +11 -5
  23. data/lib/moneta/adapters/daybreak.rb +31 -20
  24. data/lib/moneta/adapters/dbm.rb +10 -16
  25. data/lib/moneta/adapters/file.rb +34 -13
  26. data/lib/moneta/adapters/fog.rb +5 -6
  27. data/lib/moneta/adapters/gdbm.rb +10 -16
  28. data/lib/moneta/adapters/hbase.rb +11 -13
  29. data/lib/moneta/adapters/kyotocabinet.rb +78 -17
  30. data/lib/moneta/adapters/leveldb.rb +35 -15
  31. data/lib/moneta/adapters/lmdb.rb +47 -23
  32. data/lib/moneta/adapters/localmemcache.rb +7 -13
  33. data/lib/moneta/adapters/lruhash.rb +45 -48
  34. data/lib/moneta/adapters/memcached/dalli.rb +67 -30
  35. data/lib/moneta/adapters/memcached/native.rb +33 -30
  36. data/lib/moneta/adapters/memcached.rb +1 -0
  37. data/lib/moneta/adapters/memory.rb +7 -7
  38. data/lib/moneta/adapters/mongo.rb +265 -6
  39. data/lib/moneta/adapters/null.rb +1 -2
  40. data/lib/moneta/adapters/pstore.rb +68 -25
  41. data/lib/moneta/adapters/redis.rb +101 -32
  42. data/lib/moneta/adapters/restclient.rb +17 -16
  43. data/lib/moneta/adapters/riak.rb +10 -11
  44. data/lib/moneta/adapters/sdbm.rb +10 -16
  45. data/lib/moneta/adapters/sequel/mysql.rb +66 -0
  46. data/lib/moneta/adapters/sequel/postgres.rb +80 -0
  47. data/lib/moneta/adapters/sequel/postgres_hstore.rb +240 -0
  48. data/lib/moneta/adapters/sequel/sqlite.rb +57 -0
  49. data/lib/moneta/adapters/sequel.rb +253 -52
  50. data/lib/moneta/adapters/sqlite.rb +103 -23
  51. data/lib/moneta/adapters/tdb.rb +21 -12
  52. data/lib/moneta/adapters/tokyocabinet.rb +24 -16
  53. data/lib/moneta/adapters/tokyotyrant.rb +49 -28
  54. data/lib/moneta/adapters/yaml.rb +1 -5
  55. data/lib/moneta/builder.rb +2 -3
  56. data/lib/moneta/cache.rb +11 -1
  57. data/lib/moneta/config.rb +101 -0
  58. data/lib/moneta/create_support.rb +21 -0
  59. data/lib/moneta/dbm_adapter.rb +31 -0
  60. data/lib/moneta/defaults.rb +320 -0
  61. data/lib/moneta/each_key_support.rb +27 -0
  62. data/lib/moneta/enumerable.rb +38 -0
  63. data/lib/moneta/expires.rb +112 -11
  64. data/lib/moneta/expires_support.rb +59 -0
  65. data/lib/moneta/fallback.rb +84 -0
  66. data/lib/moneta/hash_adapter.rb +68 -0
  67. data/lib/moneta/increment_support.rb +16 -0
  68. data/lib/moneta/lock.rb +26 -2
  69. data/lib/moneta/logger.rb +2 -2
  70. data/lib/moneta/nil_values.rb +35 -0
  71. data/lib/moneta/option_support.rb +51 -0
  72. data/lib/moneta/optionmerger.rb +0 -1
  73. data/lib/moneta/pool.rb +339 -28
  74. data/lib/moneta/proxy.rb +75 -2
  75. data/lib/moneta/server.rb +230 -68
  76. data/lib/moneta/shared.rb +36 -14
  77. data/lib/moneta/stack.rb +7 -7
  78. data/lib/moneta/synchronize.rb +5 -11
  79. data/lib/moneta/transformer/config.rb +64 -42
  80. data/lib/moneta/transformer/helper/bson.rb +7 -14
  81. data/lib/moneta/transformer/helper.rb +5 -5
  82. data/lib/moneta/transformer.rb +217 -23
  83. data/lib/moneta/utils.rb +3 -9
  84. data/lib/moneta/version.rb +1 -1
  85. data/lib/moneta/weak_each_key.rb +72 -0
  86. data/lib/moneta/wrapper.rb +30 -0
  87. data/lib/moneta.rb +29 -10
  88. data/lib/rack/cache/moneta.rb +13 -11
  89. data/lib/rack/moneta_rest.rb +2 -2
  90. data/lib/rack/session/moneta.rb +3 -4
  91. data/moneta.gemspec +19 -4
  92. data/script/benchmarks +311 -100
  93. data/script/contributors +11 -6
  94. data/script/parallel-tests +58 -83
  95. data/script/start-couchdb +27 -0
  96. data/script/start-hbase +47 -0
  97. data/script/start-services +5 -6
  98. data/script/update-feature-matrix +148 -0
  99. data/spec/active_support/cache_moneta_store_spec.rb +129 -106
  100. data/spec/features/concurrent_create.rb +42 -0
  101. data/spec/features/concurrent_increment.rb +39 -0
  102. data/spec/features/create.rb +25 -0
  103. data/spec/features/create_expires.rb +19 -0
  104. data/spec/features/default_expires.rb +14 -0
  105. data/spec/features/each_key.rb +119 -0
  106. data/spec/features/expires.rb +296 -0
  107. data/spec/features/features.rb +16 -0
  108. data/spec/features/increment.rb +98 -0
  109. data/spec/features/marshallable_key.rb +43 -0
  110. data/spec/features/marshallable_value.rb +7 -0
  111. data/spec/features/multiprocess.rb +8 -0
  112. data/spec/features/not_create.rb +7 -0
  113. data/spec/features/not_each_key.rb +7 -0
  114. data/spec/features/not_increment.rb +13 -0
  115. data/spec/features/not_persist.rb +9 -0
  116. data/spec/features/null.rb +66 -0
  117. data/spec/features/persist.rb +14 -0
  118. data/spec/features/returndifferent.rb +9 -0
  119. data/spec/features/returnsame.rb +9 -0
  120. data/spec/features/store.rb +261 -0
  121. data/spec/features/store_large.rb +13 -0
  122. data/spec/features/transform_value.rb +44 -0
  123. data/spec/features/transform_value_expires.rb +41 -0
  124. data/spec/helper.rb +345 -78
  125. data/spec/moneta/adapters/activerecord/adapter_activerecord_existing_connection_spec.rb +61 -0
  126. data/spec/moneta/adapters/activerecord/adapter_activerecord_spec.rb +126 -0
  127. data/spec/moneta/adapters/activerecord/standard_activerecord_spec.rb +21 -0
  128. data/spec/moneta/adapters/activerecord/standard_activerecord_with_expires_spec.rb +27 -0
  129. data/spec/moneta/adapters/activesupportcache/adapter_activesupportcache_spec.rb +54 -0
  130. data/spec/moneta/adapters/activesupportcache/adapter_activesupportcache_with_default_expires_spec.rb +54 -0
  131. data/spec/moneta/adapters/activesupportcache/standard_activesupportcache_spec.rb +14 -0
  132. data/spec/moneta/adapters/cassandra/adapter_cassandra_spec.rb +17 -0
  133. data/spec/moneta/adapters/cassandra/adapter_cassandra_with_default_expires_spec.rb +18 -0
  134. data/spec/moneta/adapters/cassandra/helper.rb +18 -0
  135. data/spec/moneta/adapters/cassandra/standard_cassandra_spec.rb +18 -0
  136. data/spec/moneta/adapters/client/adapter_client_spec.rb +11 -0
  137. data/spec/moneta/adapters/client/client_helper.rb +25 -0
  138. data/spec/moneta/adapters/client/standard_client_tcp_spec.rb +23 -0
  139. data/spec/moneta/adapters/client/standard_client_unix_spec.rb +28 -0
  140. data/spec/moneta/adapters/cookie/adapter_cookie_spec.rb +7 -0
  141. data/spec/moneta/adapters/couch/adapter_couch_spec.rb +204 -0
  142. data/spec/moneta/adapters/couch/standard_couch_spec.rb +15 -0
  143. data/spec/moneta/adapters/couch/standard_couch_with_expires_spec.rb +19 -0
  144. data/spec/moneta/adapters/datamapper/adapter_datamapper_spec.rb +60 -0
  145. data/spec/moneta/adapters/datamapper/standard_datamapper_spec.rb +21 -0
  146. data/spec/moneta/adapters/datamapper/standard_datamapper_with_expires_spec.rb +26 -0
  147. data/spec/moneta/adapters/datamapper/standard_datamapper_with_repository_spec.rb +22 -0
  148. data/spec/moneta/adapters/daybreak/adapter_daybreak_spec.rb +7 -0
  149. data/spec/moneta/adapters/daybreak/standard_daybreak_spec.rb +7 -0
  150. data/spec/moneta/adapters/daybreak/standard_daybreak_with_expires_spec.rb +11 -0
  151. data/spec/moneta/adapters/dbm/adapter_dbm_spec.rb +7 -0
  152. data/spec/moneta/adapters/dbm/standard_dbm_spec.rb +7 -0
  153. data/spec/moneta/adapters/dbm/standard_dbm_with_expires_spec.rb +12 -0
  154. data/spec/moneta/adapters/faraday_helper.rb +10 -0
  155. data/spec/moneta/adapters/file/adapter_file_spec.rb +7 -0
  156. data/spec/moneta/adapters/file/standard_file_spec.rb +7 -0
  157. data/spec/moneta/adapters/file/standard_file_with_expires_spec.rb +11 -0
  158. data/spec/moneta/adapters/fog/adapter_fog_spec.rb +16 -0
  159. data/spec/moneta/adapters/fog/standard_fog_spec.rb +15 -0
  160. data/spec/moneta/adapters/fog/standard_fog_with_expires_spec.rb +20 -0
  161. data/spec/moneta/adapters/gdbm/adapter_gdbm_spec.rb +7 -0
  162. data/spec/moneta/adapters/gdbm/standard_gdbm_spec.rb +7 -0
  163. data/spec/moneta/adapters/gdbm/standard_gdbm_with_expires_spec.rb +11 -0
  164. data/spec/moneta/adapters/hashfile/standard_hashfile_spec.rb +7 -0
  165. data/spec/moneta/adapters/hashfile/standard_hashfile_with_expires_spec.rb +12 -0
  166. data/spec/moneta/adapters/hbase/adapter_hbase_spec.rb +7 -0
  167. data/spec/moneta/adapters/hbase/standard_hbase_spec.rb +4 -0
  168. data/spec/moneta/adapters/hbase/standard_hbase_with_expires_spec.rb +8 -0
  169. data/spec/moneta/adapters/kyotocabinet/adapter_kyotocabinet_spec.rb +7 -0
  170. data/spec/moneta/adapters/kyotocabinet/standard_kyotocabinet_spec.rb +7 -0
  171. data/spec/moneta/adapters/kyotocabinet/standard_kyotocabinet_with_expires_spec.rb +14 -0
  172. data/spec/moneta/adapters/leveldb/adapter_leveldb_spec.rb +7 -0
  173. data/spec/moneta/adapters/leveldb/standard_leveldb_spec.rb +7 -0
  174. data/spec/moneta/adapters/leveldb/standard_leveldb_with_expires_spec.rb +11 -0
  175. data/spec/moneta/adapters/lmdb/adapter_lmdb_spec.rb +7 -0
  176. data/spec/moneta/adapters/lmdb/adapter_lmdb_with_db_spec.rb +7 -0
  177. data/spec/moneta/adapters/lmdb/standard_lmdb_spec.rb +7 -0
  178. data/spec/moneta/adapters/lmdb/standard_lmdb_with_expires_spec.rb +11 -0
  179. data/spec/moneta/adapters/localmemcache/adapter_localmemcache_spec.rb +7 -0
  180. data/spec/moneta/adapters/localmemcache/standard_localmemcache_spec.rb +7 -0
  181. data/spec/moneta/adapters/localmemcache/standard_localmemcache_with_expires_spec.rb +11 -0
  182. data/spec/moneta/{adapter_lruhash_spec.rb → adapters/lruhash/adapter_lruhash_spec.rb} +15 -33
  183. data/spec/moneta/adapters/lruhash/standard_lruhash_spec.rb +4 -0
  184. data/spec/moneta/adapters/lruhash/standard_lruhash_with_expires_spec.rb +8 -0
  185. data/spec/moneta/adapters/memcached/adapter_memcached_spec.rb +13 -0
  186. data/spec/moneta/adapters/memcached/dalli/adapter_memcached_dalli_spec.rb +25 -0
  187. data/spec/moneta/adapters/memcached/dalli/standard_memcached_dalli_spec.rb +11 -0
  188. data/spec/moneta/adapters/memcached/native/adapter_memcached_native_spec.rb +25 -0
  189. data/spec/moneta/adapters/memcached/native/standard_memcached_native_spec.rb +11 -0
  190. data/spec/moneta/adapters/memcached/standard_memcached_spec.rb +17 -0
  191. data/spec/moneta/adapters/memcached_helper.rb +20 -0
  192. data/spec/moneta/adapters/memory/adapter_memory_spec.rb +7 -0
  193. data/spec/moneta/adapters/memory/standard_memory_spec.rb +4 -0
  194. data/spec/moneta/adapters/memory/standard_memory_with_compress_spec.rb +9 -0
  195. data/spec/moneta/adapters/memory/standard_memory_with_expires_spec.rb +8 -0
  196. data/spec/moneta/adapters/memory/standard_memory_with_json_key_serializer_spec.rb +4 -0
  197. data/spec/moneta/adapters/memory/standard_memory_with_json_serializer_spec.rb +9 -0
  198. data/spec/moneta/adapters/memory/standard_memory_with_json_value_serializer_spec.rb +9 -0
  199. data/spec/moneta/adapters/memory/standard_memory_with_prefix_spec.rb +41 -0
  200. data/spec/moneta/adapters/memory/standard_memory_with_snappy_compress_spec.rb +9 -0
  201. data/spec/moneta/adapters/mongo/adapter_mongo_spec.rb +41 -0
  202. data/spec/moneta/adapters/mongo/adapter_mongo_with_default_expires_spec.rb +14 -0
  203. data/spec/moneta/adapters/mongo/standard_mongo_spec.rb +7 -0
  204. data/spec/moneta/adapters/null/null_adapter_spec.rb +7 -0
  205. data/spec/moneta/adapters/null/standard_null_spec.rb +4 -0
  206. data/spec/moneta/adapters/pstore/adapter_pstore_spec.rb +7 -0
  207. data/spec/moneta/adapters/pstore/standard_pstore_spec.rb +9 -0
  208. data/spec/moneta/adapters/pstore/standard_pstore_with_expires_spec.rb +13 -0
  209. data/spec/moneta/adapters/redis/adapter_redis_spec.rb +20 -0
  210. data/spec/moneta/adapters/redis/standard_redis_spec.rb +14 -0
  211. data/spec/moneta/adapters/restclient/adapter_restclient_spec.rb +13 -0
  212. data/spec/moneta/adapters/restclient/helper.rb +12 -0
  213. data/spec/moneta/adapters/restclient/standard_restclient_spec.rb +13 -0
  214. data/spec/moneta/adapters/riak/adapter_riak_spec.rb +14 -0
  215. data/spec/moneta/adapters/riak/standard_riak_spec.rb +10 -0
  216. data/spec/moneta/adapters/riak/standard_riak_with_expires_spec.rb +14 -0
  217. data/spec/moneta/adapters/sdbm/adapter_sdbm_spec.rb +7 -0
  218. data/spec/moneta/adapters/sdbm/standard_sdbm_spec.rb +7 -0
  219. data/spec/moneta/adapters/sdbm/standard_sdbm_with_expires_spec.rb +11 -0
  220. data/spec/moneta/adapters/sequel/adapter_sequel_spec.rb +133 -0
  221. data/spec/moneta/adapters/sequel/helper.rb +80 -0
  222. data/spec/moneta/adapters/sequel/standard_sequel_spec.rb +8 -0
  223. data/spec/moneta/adapters/sequel/standard_sequel_with_expires_spec.rb +18 -0
  224. data/spec/moneta/adapters/sqlite/adapter_sqlite_spec.rb +7 -0
  225. data/spec/moneta/adapters/sqlite/standard_sqlite_spec.rb +7 -0
  226. data/spec/moneta/adapters/sqlite/standard_sqlite_with_expires_spec.rb +15 -0
  227. data/spec/moneta/adapters/tdb/adapter_tdb_spec.rb +7 -0
  228. data/spec/moneta/adapters/tdb/standard_tdb_spec.rb +7 -0
  229. data/spec/moneta/adapters/tdb/standard_tdb_with_expires_spec.rb +11 -0
  230. data/spec/moneta/adapters/tokyocabinet/adapter_tokyocabinet_bdb_spec.rb +7 -0
  231. data/spec/moneta/adapters/tokyocabinet/adapter_tokyocabinet_hdb_spec.rb +7 -0
  232. data/spec/moneta/adapters/tokyocabinet/standard_tokyocabinet_spec.rb +7 -0
  233. data/spec/moneta/adapters/tokyocabinet/standard_tokyocabinet_with_expires_spec.rb +11 -0
  234. data/spec/moneta/adapters/tokyotyrant/adapter_tokyotyrant_spec.rb +11 -0
  235. data/spec/moneta/adapters/tokyotyrant/helper.rb +12 -0
  236. data/spec/moneta/adapters/tokyotyrant/standard_tokyotyrant_spec.rb +7 -0
  237. data/spec/moneta/adapters/tokyotyrant/standard_tokyotyrant_with_expires_spec.rb +12 -0
  238. data/spec/moneta/adapters/yaml/adapter_yaml_spec.rb +7 -0
  239. data/spec/moneta/adapters/yaml/standard_yaml_spec.rb +9 -0
  240. data/spec/moneta/adapters/yaml/standard_yaml_with_expires_spec.rb +13 -0
  241. data/spec/moneta/builder_spec.rb +22 -1
  242. data/spec/moneta/config_spec.rb +219 -0
  243. data/spec/moneta/mutex_spec.rb +6 -23
  244. data/spec/moneta/proxies/cache/cache_file_memory_spec.rb +24 -0
  245. data/spec/moneta/proxies/cache/cache_memory_null_spec.rb +12 -0
  246. data/spec/moneta/proxies/enumerable/enumerable_spec.rb +26 -0
  247. data/spec/moneta/proxies/expires/expires_file_spec.rb +28 -0
  248. data/spec/moneta/proxies/expires/expires_memory_spec.rb +15 -0
  249. data/spec/moneta/proxies/expires/expires_memory_with_default_expires_spec.rb +16 -0
  250. data/spec/moneta/proxies/fallback/fallback_spec.rb +42 -0
  251. data/spec/moneta/proxies/lock/lock_spec.rb +10 -0
  252. data/spec/moneta/{optionmerger_spec.rb → proxies/optionmerger/optionmerger_spec.rb} +2 -18
  253. data/spec/moneta/proxies/pool/pool_spec.rb +353 -0
  254. data/spec/moneta/proxies/proxy/proxy_expires_memory_spec.rb +16 -0
  255. data/spec/moneta/proxies/shared/shared_tcp_spec.rb +59 -0
  256. data/spec/moneta/proxies/shared/shared_unix_spec.rb +58 -0
  257. data/spec/moneta/proxies/transformer/transformer_bencode_spec.rb +19 -0
  258. data/spec/moneta/proxies/transformer/transformer_bert_spec.rb +19 -0
  259. data/spec/moneta/proxies/transformer/transformer_bson_spec.rb +25 -0
  260. data/spec/moneta/proxies/transformer/transformer_bzip2_spec.rb +19 -0
  261. data/spec/moneta/proxies/transformer/transformer_json_spec.rb +19 -0
  262. data/spec/moneta/proxies/transformer/transformer_key_inspect_spec.rb +17 -0
  263. data/spec/moneta/proxies/transformer/transformer_key_marshal_spec.rb +17 -0
  264. data/spec/moneta/proxies/transformer/transformer_key_to_s_spec.rb +17 -0
  265. data/spec/moneta/proxies/transformer/transformer_key_yaml_spec.rb +17 -0
  266. data/spec/moneta/proxies/transformer/transformer_lz4_spec.rb +19 -0
  267. data/spec/moneta/proxies/transformer/transformer_lzma_spec.rb +19 -0
  268. data/spec/moneta/proxies/transformer/transformer_lzo_spec.rb +19 -0
  269. data/spec/moneta/proxies/transformer/transformer_marshal_base64_spec.rb +20 -0
  270. data/spec/moneta/proxies/transformer/transformer_marshal_city128_spec.rb +15 -0
  271. data/spec/moneta/proxies/transformer/transformer_marshal_city32_spec.rb +15 -0
  272. data/spec/moneta/proxies/transformer/transformer_marshal_city64_spec.rb +15 -0
  273. data/spec/moneta/proxies/transformer/transformer_marshal_escape_spec.rb +21 -0
  274. data/spec/moneta/proxies/transformer/transformer_marshal_hex_spec.rb +20 -0
  275. data/spec/moneta/proxies/transformer/transformer_marshal_hmac_spec.rb +19 -0
  276. data/spec/moneta/proxies/transformer/transformer_marshal_md5_spec.rb +15 -0
  277. data/spec/moneta/proxies/transformer/transformer_marshal_md5_spread_spec.rb +15 -0
  278. data/spec/moneta/proxies/transformer/transformer_marshal_prefix_base64_spec.rb +33 -0
  279. data/spec/moneta/proxies/transformer/transformer_marshal_prefix_spec.rb +15 -0
  280. data/spec/moneta/proxies/transformer/transformer_marshal_qp_spec.rb +20 -0
  281. data/spec/moneta/proxies/transformer/transformer_marshal_rmd160_spec.rb +15 -0
  282. data/spec/moneta/proxies/transformer/transformer_marshal_sha1_spec.rb +15 -0
  283. data/spec/moneta/proxies/transformer/transformer_marshal_sha256_spec.rb +15 -0
  284. data/spec/moneta/proxies/transformer/transformer_marshal_sha384_spec.rb +15 -0
  285. data/spec/moneta/proxies/transformer/transformer_marshal_sha512_spec.rb +15 -0
  286. data/spec/moneta/proxies/transformer/transformer_marshal_spec.rb +19 -0
  287. data/spec/moneta/proxies/transformer/transformer_marshal_truncate_spec.rb +15 -0
  288. data/spec/moneta/proxies/transformer/transformer_marshal_urlsafe_base64_spec.rb +20 -0
  289. data/spec/moneta/proxies/transformer/transformer_marshal_uuencode_spec.rb +19 -0
  290. data/spec/moneta/proxies/transformer/transformer_msgpack_spec.rb +19 -0
  291. data/spec/moneta/proxies/transformer/transformer_ox_spec.rb +19 -0
  292. data/spec/moneta/proxies/transformer/transformer_php_spec.rb +19 -0
  293. data/spec/moneta/proxies/transformer/transformer_quicklz_spec.rb +19 -0
  294. data/spec/moneta/proxies/transformer/transformer_snappy_spec.rb +19 -0
  295. data/spec/moneta/proxies/transformer/transformer_tnet_spec.rb +19 -0
  296. data/spec/moneta/proxies/transformer/transformer_value_marshal_spec.rb +19 -0
  297. data/spec/moneta/proxies/transformer/transformer_value_yaml_spec.rb +19 -0
  298. data/spec/moneta/proxies/transformer/transformer_yaml_spec.rb +19 -0
  299. data/spec/moneta/proxies/transformer/transformer_zlib_spec.rb +19 -0
  300. data/spec/moneta/proxies/weak_create/weak_create_spec.rb +21 -0
  301. data/spec/moneta/proxies/weak_each_key/weak_each_key_spec.rb +22 -0
  302. data/spec/moneta/proxies/weak_increment/weak_increment_spec.rb +21 -0
  303. data/spec/moneta/semaphore_spec.rb +6 -23
  304. data/spec/moneta/stack_file_memory_spec.rb +5 -29
  305. data/spec/moneta/stack_memory_file_spec.rb +5 -31
  306. data/spec/rack/session_moneta_spec.rb +44 -25
  307. data/spec/restserver.rb +44 -0
  308. data/{spec → test}/action_dispatch/fixtures/session_autoload_test/foo.rb +0 -0
  309. data/{spec/action_dispatch/session_moneta_store_spec.rb → test/action_dispatch/session_moneta_store_test.rb} +13 -5
  310. metadata +545 -369
  311. data/.travis.yml +0 -55
  312. data/lib/moneta/adapters/mongo/base.rb +0 -78
  313. data/lib/moneta/adapters/mongo/moped.rb +0 -107
  314. data/lib/moneta/adapters/mongo/official.rb +0 -117
  315. data/lib/moneta/mixins.rb +0 -343
  316. data/script/generate-specs +0 -2696
  317. data/script/install-kyotocabinet +0 -17
  318. data/spec/moneta/adapter_activerecord_exisiting_connection_spec.rb +0 -36
  319. data/spec/moneta/adapter_activerecord_spec.rb +0 -65
  320. data/spec/moneta/adapter_cassandra_spec.rb +0 -33
  321. data/spec/moneta/adapter_cassandra_with_default_expires_spec.rb +0 -34
  322. data/spec/moneta/adapter_client_spec.rb +0 -35
  323. data/spec/moneta/adapter_cookie_spec.rb +0 -30
  324. data/spec/moneta/adapter_couch_spec.rb +0 -36
  325. data/spec/moneta/adapter_datamapper_spec.rb +0 -64
  326. data/spec/moneta/adapter_daybreak_spec.rb +0 -31
  327. data/spec/moneta/adapter_dbm_spec.rb +0 -31
  328. data/spec/moneta/adapter_file_spec.rb +0 -34
  329. data/spec/moneta/adapter_fog_spec.rb +0 -37
  330. data/spec/moneta/adapter_gdbm_spec.rb +0 -31
  331. data/spec/moneta/adapter_hbase_spec.rb +0 -33
  332. data/spec/moneta/adapter_kyotocabinet_spec.rb +0 -31
  333. data/spec/moneta/adapter_leveldb_spec.rb +0 -31
  334. data/spec/moneta/adapter_lmdb_spec.rb +0 -32
  335. data/spec/moneta/adapter_lmdb_with_db_spec.rb +0 -32
  336. data/spec/moneta/adapter_localmemcache_spec.rb +0 -32
  337. data/spec/moneta/adapter_memcached_dalli_spec.rb +0 -36
  338. data/spec/moneta/adapter_memcached_dalli_with_default_expires_spec.rb +0 -37
  339. data/spec/moneta/adapter_memcached_native_spec.rb +0 -36
  340. data/spec/moneta/adapter_memcached_native_with_default_expires_spec.rb +0 -37
  341. data/spec/moneta/adapter_memcached_spec.rb +0 -36
  342. data/spec/moneta/adapter_memcached_with_default_expires_spec.rb +0 -37
  343. data/spec/moneta/adapter_memory_spec.rb +0 -184
  344. data/spec/moneta/adapter_mongo_moped_spec.rb +0 -64
  345. data/spec/moneta/adapter_mongo_moped_with_default_expires_spec.rb +0 -53
  346. data/spec/moneta/adapter_mongo_official_spec.rb +0 -64
  347. data/spec/moneta/adapter_mongo_official_with_default_expires_spec.rb +0 -53
  348. data/spec/moneta/adapter_mongo_spec.rb +0 -51
  349. data/spec/moneta/adapter_mongo_with_default_expires_spec.rb +0 -53
  350. data/spec/moneta/adapter_pstore_spec.rb +0 -250
  351. data/spec/moneta/adapter_redis_spec.rb +0 -36
  352. data/spec/moneta/adapter_redis_with_default_expires_spec.rb +0 -37
  353. data/spec/moneta/adapter_restclient_spec.rb +0 -33
  354. data/spec/moneta/adapter_riak_spec.rb +0 -36
  355. data/spec/moneta/adapter_sdbm_spec.rb +0 -30
  356. data/spec/moneta/adapter_sequel_spec.rb +0 -34
  357. data/spec/moneta/adapter_sqlite_spec.rb +0 -32
  358. data/spec/moneta/adapter_tdb_spec.rb +0 -31
  359. data/spec/moneta/adapter_tokyocabinet_bdb_spec.rb +0 -31
  360. data/spec/moneta/adapter_tokyocabinet_hdb_spec.rb +0 -31
  361. data/spec/moneta/adapter_tokyotyrant_spec.rb +0 -34
  362. data/spec/moneta/adapter_yaml_spec.rb +0 -57
  363. data/spec/moneta/cache_file_memory_spec.rb +0 -50
  364. data/spec/moneta/cache_memory_null_spec.rb +0 -35
  365. data/spec/moneta/expires_file_spec.rb +0 -78
  366. data/spec/moneta/expires_memory_spec.rb +0 -189
  367. data/spec/moneta/expires_memory_with_default_expires_spec.rb +0 -190
  368. data/spec/moneta/lock_spec.rb +0 -187
  369. data/spec/moneta/null_adapter_spec.rb +0 -86
  370. data/spec/moneta/pool_spec.rb +0 -38
  371. data/spec/moneta/proxy_expires_memory_spec.rb +0 -191
  372. data/spec/moneta/proxy_redis_spec.rb +0 -40
  373. data/spec/moneta/shared_tcp_spec.rb +0 -46
  374. data/spec/moneta/shared_unix_spec.rb +0 -46
  375. data/spec/moneta/standard_activerecord_spec.rb +0 -253
  376. data/spec/moneta/standard_activerecord_with_expires_spec.rb +0 -255
  377. data/spec/moneta/standard_cassandra_spec.rb +0 -252
  378. data/spec/moneta/standard_client_tcp_spec.rb +0 -269
  379. data/spec/moneta/standard_client_unix_spec.rb +0 -254
  380. data/spec/moneta/standard_couch_spec.rb +0 -252
  381. data/spec/moneta/standard_couch_with_expires_spec.rb +0 -254
  382. data/spec/moneta/standard_datamapper_spec.rb +0 -254
  383. data/spec/moneta/standard_datamapper_with_expires_spec.rb +0 -256
  384. data/spec/moneta/standard_datamapper_with_repository_spec.rb +0 -254
  385. data/spec/moneta/standard_daybreak_spec.rb +0 -250
  386. data/spec/moneta/standard_daybreak_with_expires_spec.rb +0 -252
  387. data/spec/moneta/standard_dbm_spec.rb +0 -250
  388. data/spec/moneta/standard_dbm_with_expires_spec.rb +0 -252
  389. data/spec/moneta/standard_file_spec.rb +0 -253
  390. data/spec/moneta/standard_file_with_expires_spec.rb +0 -255
  391. data/spec/moneta/standard_fog_spec.rb +0 -256
  392. data/spec/moneta/standard_fog_with_expires_spec.rb +0 -258
  393. data/spec/moneta/standard_gdbm_spec.rb +0 -250
  394. data/spec/moneta/standard_gdbm_with_expires_spec.rb +0 -252
  395. data/spec/moneta/standard_hashfile_spec.rb +0 -253
  396. data/spec/moneta/standard_hashfile_with_expires_spec.rb +0 -255
  397. data/spec/moneta/standard_hbase_spec.rb +0 -252
  398. data/spec/moneta/standard_hbase_with_expires_spec.rb +0 -255
  399. data/spec/moneta/standard_kyotocabinet_spec.rb +0 -250
  400. data/spec/moneta/standard_kyotocabinet_with_expires_spec.rb +0 -252
  401. data/spec/moneta/standard_leveldb_spec.rb +0 -250
  402. data/spec/moneta/standard_leveldb_with_expires_spec.rb +0 -252
  403. data/spec/moneta/standard_lmdb_spec.rb +0 -251
  404. data/spec/moneta/standard_lmdb_with_expires_spec.rb +0 -253
  405. data/spec/moneta/standard_localmemcache_spec.rb +0 -251
  406. data/spec/moneta/standard_localmemcache_with_expires_spec.rb +0 -252
  407. data/spec/moneta/standard_lruhash_spec.rb +0 -187
  408. data/spec/moneta/standard_lruhash_with_expires_spec.rb +0 -189
  409. data/spec/moneta/standard_memcached_dalli_spec.rb +0 -255
  410. data/spec/moneta/standard_memcached_native_spec.rb +0 -255
  411. data/spec/moneta/standard_memcached_spec.rb +0 -255
  412. data/spec/moneta/standard_memory_spec.rb +0 -187
  413. data/spec/moneta/standard_memory_with_compress_spec.rb +0 -187
  414. data/spec/moneta/standard_memory_with_expires_spec.rb +0 -189
  415. data/spec/moneta/standard_memory_with_json_key_serializer_spec.rb +0 -86
  416. data/spec/moneta/standard_memory_with_json_serializer_spec.rb +0 -49
  417. data/spec/moneta/standard_memory_with_json_value_serializer_spec.rb +0 -90
  418. data/spec/moneta/standard_memory_with_prefix_spec.rb +0 -187
  419. data/spec/moneta/standard_memory_with_snappy_compress_spec.rb +0 -187
  420. data/spec/moneta/standard_mongo_moped_spec.rb +0 -255
  421. data/spec/moneta/standard_mongo_official_spec.rb +0 -255
  422. data/spec/moneta/standard_mongo_spec.rb +0 -255
  423. data/spec/moneta/standard_null_spec.rb +0 -120
  424. data/spec/moneta/standard_pstore_spec.rb +0 -253
  425. data/spec/moneta/standard_pstore_with_expires_spec.rb +0 -255
  426. data/spec/moneta/standard_redis_spec.rb +0 -255
  427. data/spec/moneta/standard_restclient_spec.rb +0 -252
  428. data/spec/moneta/standard_riak_spec.rb +0 -255
  429. data/spec/moneta/standard_riak_with_expires_spec.rb +0 -256
  430. data/spec/moneta/standard_sdbm_spec.rb +0 -249
  431. data/spec/moneta/standard_sdbm_with_expires_spec.rb +0 -251
  432. data/spec/moneta/standard_sequel_spec.rb +0 -253
  433. data/spec/moneta/standard_sequel_with_expires_spec.rb +0 -255
  434. data/spec/moneta/standard_sqlite_spec.rb +0 -251
  435. data/spec/moneta/standard_sqlite_with_expires_spec.rb +0 -253
  436. data/spec/moneta/standard_tdb_spec.rb +0 -250
  437. data/spec/moneta/standard_tdb_with_expires_spec.rb +0 -252
  438. data/spec/moneta/standard_tokyocabinet_spec.rb +0 -250
  439. data/spec/moneta/standard_tokyocabinet_with_expires_spec.rb +0 -252
  440. data/spec/moneta/standard_tokyotyrant_spec.rb +0 -253
  441. data/spec/moneta/standard_tokyotyrant_with_expires_spec.rb +0 -255
  442. data/spec/moneta/standard_yaml_spec.rb +0 -250
  443. data/spec/moneta/standard_yaml_with_expires_spec.rb +0 -252
  444. data/spec/moneta/transformer_bencode_spec.rb +0 -55
  445. data/spec/moneta/transformer_bert_spec.rb +0 -55
  446. data/spec/moneta/transformer_bson_spec.rb +0 -60
  447. data/spec/moneta/transformer_bzip2_spec.rb +0 -55
  448. data/spec/moneta/transformer_json_spec.rb +0 -55
  449. data/spec/moneta/transformer_key_inspect_spec.rb +0 -91
  450. data/spec/moneta/transformer_key_marshal_spec.rb +0 -191
  451. data/spec/moneta/transformer_key_to_s_spec.rb +0 -91
  452. data/spec/moneta/transformer_key_yaml_spec.rb +0 -191
  453. data/spec/moneta/transformer_lz4_spec.rb +0 -55
  454. data/spec/moneta/transformer_lzma_spec.rb +0 -55
  455. data/spec/moneta/transformer_lzo_spec.rb +0 -55
  456. data/spec/moneta/transformer_marshal_base64_spec.rb +0 -194
  457. data/spec/moneta/transformer_marshal_city128_spec.rb +0 -194
  458. data/spec/moneta/transformer_marshal_city32_spec.rb +0 -194
  459. data/spec/moneta/transformer_marshal_city64_spec.rb +0 -194
  460. data/spec/moneta/transformer_marshal_escape_spec.rb +0 -194
  461. data/spec/moneta/transformer_marshal_hex_spec.rb +0 -194
  462. data/spec/moneta/transformer_marshal_hmac_spec.rb +0 -194
  463. data/spec/moneta/transformer_marshal_md5_spec.rb +0 -194
  464. data/spec/moneta/transformer_marshal_md5_spread_spec.rb +0 -194
  465. data/spec/moneta/transformer_marshal_prefix_spec.rb +0 -194
  466. data/spec/moneta/transformer_marshal_qp_spec.rb +0 -194
  467. data/spec/moneta/transformer_marshal_rmd160_spec.rb +0 -194
  468. data/spec/moneta/transformer_marshal_sha1_spec.rb +0 -194
  469. data/spec/moneta/transformer_marshal_sha256_spec.rb +0 -194
  470. data/spec/moneta/transformer_marshal_sha384_spec.rb +0 -194
  471. data/spec/moneta/transformer_marshal_sha512_spec.rb +0 -194
  472. data/spec/moneta/transformer_marshal_spec.rb +0 -191
  473. data/spec/moneta/transformer_marshal_truncate_spec.rb +0 -194
  474. data/spec/moneta/transformer_marshal_uuencode_spec.rb +0 -194
  475. data/spec/moneta/transformer_msgpack_spec.rb +0 -55
  476. data/spec/moneta/transformer_ox_spec.rb +0 -191
  477. data/spec/moneta/transformer_php_spec.rb +0 -55
  478. data/spec/moneta/transformer_quicklz_spec.rb +0 -55
  479. data/spec/moneta/transformer_snappy_spec.rb +0 -55
  480. data/spec/moneta/transformer_tnet_spec.rb +0 -55
  481. data/spec/moneta/transformer_value_marshal_spec.rb +0 -191
  482. data/spec/moneta/transformer_value_yaml_spec.rb +0 -191
  483. data/spec/moneta/transformer_yaml_spec.rb +0 -191
  484. data/spec/moneta/transformer_zlib_spec.rb +0 -55
  485. data/spec/moneta/weak_create_spec.rb +0 -41
  486. data/spec/moneta/weak_increment_spec.rb +0 -41
  487. data/spec/monetaspecs.rb +0 -51267
  488. data/spec/quality_spec.rb +0 -51
@@ -0,0 +1,353 @@
1
+ require 'timeout'
2
+
3
+ describe "pool", proxy: :Pool, broken: ::Gem::Version.new(RUBY_ENGINE_VERSION) < ::Gem::Version.new('2.4.0') do
4
+ describe "Moneta::Pool" do
5
+ # To test the pool, we create the store once and pass the same object around
6
+ # whenever a new store is requested.
7
+ before :context do
8
+ tempdir = @pool_tempdir = Dir.mktmpdir
9
+ @pool_store = Moneta.build do
10
+ use :Pool, max: 2, timeout: 5 do
11
+ adapter :File, dir: tempdir
12
+ end
13
+ end
14
+ end
15
+
16
+ # Tell the manager to close all open stores
17
+ after :context do
18
+ @pool_store.stop
19
+ FileUtils.remove_dir(@pool_tempdir)
20
+ end
21
+
22
+ moneta_build { @pool_store }
23
+ moneta_specs ADAPTER_SPECS.with_each_key
24
+
25
+ it "raises an error on check-out the builder fails" do
26
+ store = Moneta.build do
27
+ use :Pool do
28
+ adapter(Class.new do
29
+ def initialize(options = {})
30
+ raise "boom"
31
+ end
32
+ end)
33
+ end
34
+ end
35
+
36
+ expect { store['x'] }.to raise_error "boom"
37
+ end
38
+ end
39
+
40
+ describe "Moneta::Pool::PoolManager" do
41
+ let :builder do
42
+ double('builder').tap do |builder|
43
+ i = -1
44
+ allow(builder).to receive(:build) do
45
+ [stores[i += 1]]
46
+ end
47
+ end
48
+ end
49
+
50
+ let(:stores) { (0...num).map { |i| double("store#{i}") } }
51
+
52
+ after { subject.kill! }
53
+
54
+ shared_examples :no_ttl do
55
+ context "with one store" do
56
+ let(:num) { 1 }
57
+
58
+ it "never expires the store" do
59
+ store = stores.first
60
+ expect(builder).to receive(:build).once
61
+ expect(subject.check_out).to be store
62
+ expect(subject.stats).to include(stores: 1, available: 0)
63
+ expect(subject.check_in(store)).to eq nil
64
+ expect(subject.stats).to include(stores: 1, available: 1)
65
+ sleep 1
66
+ expect(subject.stats).to include(stores: 1, available: 1)
67
+ expect(subject.check_out).to be store
68
+ expect(subject.check_in(store)).to eq nil
69
+ end
70
+ end
71
+ end
72
+
73
+ shared_examples :no_max do
74
+ context "with 1,000 stores" do
75
+ let(:num) { 1_000 }
76
+
77
+ it "never blocks" do
78
+ # Check out 1000 stores in 1000 threads
79
+ threads = (0...num).map do
80
+ Thread.new { subject.check_out }
81
+ end
82
+ expect(threads.map(&:value)).to contain_exactly(*stores)
83
+ expect(subject.stats).to include(stores: num, available: 0, waiting: 0)
84
+
85
+ # Check in the first 50
86
+ expect(stores.take(50).map { |store| subject.check_in(store) }).to all(be nil)
87
+ expect(subject.stats).to include(stores: num, available: 50, waiting: 0)
88
+
89
+ # Now check those 50 out again
90
+ threads = (0...50).map do
91
+ Thread.new { subject.check_out }
92
+ end
93
+ expect(threads.map(&:value)).to contain_exactly(*stores.take(50))
94
+
95
+ # Finally check in all stores
96
+ expect(stores.map { |store| subject.check_in(store) }).to all(be nil)
97
+ end
98
+ end
99
+ end
100
+
101
+ shared_examples :min do |min|
102
+ describe "initial number of stores" do
103
+ let(:num) { min }
104
+
105
+ it "starts with #{min} available stores" do
106
+ expect(subject.stats).to include(stores: min, available: min)
107
+ expect((0...min).map { subject.check_out }).to contain_exactly(*stores)
108
+ end
109
+ end
110
+ end
111
+
112
+ shared_examples :max do |max, timeout: 5|
113
+ describe "maximum number of stores" do
114
+ let(:num) { max }
115
+
116
+ after do
117
+ expect(stores.map { |store| subject.check_in(store) }).to all be_nil
118
+ end
119
+
120
+ it "blocks after #{max} stores have been created" do
121
+ # All stores are checked out
122
+ expect(max.times.map { subject.check_out }).to contain_exactly(*stores)
123
+
124
+ # Launch threads that make checkout requests (in order). These will
125
+ # all block.
126
+ threads = max.times.map { Thread.new { subject.check_out } }
127
+ Timeout.timeout(timeout) { Thread.pass until subject.stats[:waiting] == max }
128
+ expect(threads).to all be_alive
129
+
130
+ # Check all stores except the first one back in. This will cause all
131
+ # but one of the threads to return
132
+ expect(stores.drop(1).map { |store| subject.check_in(store) }).to all be_nil
133
+ Timeout.timeout(timeout) { Thread.pass until threads.select(&:alive?).length == 1 }
134
+ expect(subject.stats).to include(waiting: 1)
135
+
136
+ # Ensure that the stores that were checked back in are the ones that
137
+ # were given to the waiting threads.
138
+ alive, dead = threads.partition(&:alive?)
139
+ expect(dead.map(&:value)).to contain_exactly(*stores.drop(1))
140
+
141
+ # Check the last store back in and make sure it goes to the last
142
+ # waiting thread.
143
+ last_thread = alive.first
144
+ expect(subject.check_in(stores.first)).to eq nil
145
+ Timeout.timeout(timeout) { Thread.pass while last_thread.alive? }
146
+ expect(subject.stats).to include(waiting: 0)
147
+ expect(last_thread.value).to be stores.first
148
+ end
149
+ end
150
+ end
151
+
152
+ shared_examples :ttl do |ttl, min: 0, max: nil|
153
+ describe "closing stores after TTL expiry" do
154
+ let(:num) { max || min + 10 }
155
+
156
+ it "closes unneeded stores after ttl" do
157
+ stores.each do |store|
158
+ allow(store).to receive(:close)
159
+ end
160
+
161
+ Timeout.timeout(5) { Thread.pass until subject.stats[:stores] == min }
162
+ expect(stores.length.times.map { subject.check_out }).to contain_exactly(*stores)
163
+ expect(subject.stats).to include(stores: num, available: 0)
164
+ expect(stores.map { |store| subject.check_in(store) }).to all be_nil
165
+ expect(subject.stats).to include(stores: num, available: num)
166
+ sleep ttl
167
+ expect(subject.stats).to include(stores: min, available: min)
168
+ end
169
+ end
170
+ end
171
+
172
+ shared_examples :ttl_with_nonzero_min do |ttl:, min:, max: nil|
173
+ describe "TTL check" do
174
+ let(:num) { max || min + 10 }
175
+
176
+ # This is testing that a very specific bug is fixed - see
177
+ # https://github.com/moneta-rb/moneta/issues/197. A better long-term
178
+ # solution would be to have more granular tests of the functions in the
179
+ # PoolManager
180
+ it "doesn't cause a busy-loop when there are available stores" do
181
+ # Check a store in and out - now the manager needs to decide whether to close
182
+ # stores after ttl seconds.
183
+ store = subject.check_out
184
+ subject.check_in(store)
185
+ sleep ttl
186
+ expect(subject.stats[:available]).to be > 0
187
+
188
+ # needs to be less than the TTL, but otherwise not important.
189
+ sleep_time = ttl / 2.0
190
+ sleep sleep_time
191
+
192
+ # during the sleep, the pool manager should have been idle.
193
+ expect(subject.stats[:idle_time]).to be >= sleep_time
194
+ end
195
+ end
196
+ end
197
+
198
+ shared_examples :timeout do |timeout, max:|
199
+ describe "raising an error after timeout" do
200
+ let(:num) { max }
201
+
202
+ it "raises a timeout error after waiting too long" do
203
+ expect((0...num).map { subject.check_out }).to contain_exactly(*stores)
204
+ # One extra checkout request in a separate thread
205
+ t = Thread.new do
206
+ Thread.current.report_on_exception = false if Thread.current.respond_to? :report_on_exception
207
+ subject.check_out
208
+ end
209
+ Timeout.timeout(timeout) { Thread.pass until subject.stats[:waiting] == 1 }
210
+ expect(subject.stats[:longest_wait]).to be_a Time
211
+ expect(t).to be_alive
212
+ sleep timeout
213
+ Timeout.timeout(timeout) { Thread.pass while t.alive? }
214
+ expect { t.value }.to raise_error Moneta::Pool::TimeoutError
215
+ expect(subject.stats).to include(waiting: 0, longest_wait: nil)
216
+ expect(stores.map { |store| subject.check_in store }).to all be_nil
217
+ end
218
+ end
219
+ end
220
+
221
+ context "with default arguments" do
222
+ subject { Moneta::Pool::PoolManager.new(builder) }
223
+ after { subject.kill! }
224
+
225
+ include_examples :no_ttl
226
+ include_examples :no_max
227
+ include_examples :min, 0
228
+ end
229
+
230
+ context "with max: 10, timeout: 4" do
231
+ subject { Moneta::Pool::PoolManager.new(builder, max: 10, timeout: 4) }
232
+ after { subject.kill! }
233
+
234
+ include_examples :no_ttl
235
+ include_examples :max, 10, timeout: 4
236
+ include_examples :min, 0
237
+ include_examples :timeout, 4, max: 10
238
+ end
239
+
240
+ context "with min: 10" do
241
+ subject { Moneta::Pool::PoolManager.new(builder, min: 10) }
242
+ after { subject.kill! }
243
+
244
+ include_examples :no_max
245
+ include_examples :min, 10
246
+ end
247
+
248
+ context "with ttl: 1" do
249
+ subject { Moneta::Pool::PoolManager.new(builder, ttl: 1) }
250
+ after { subject.kill! }
251
+
252
+ include_examples :ttl, 1, min: 0
253
+ end
254
+
255
+ context "with min: 10, max: 20, ttl: 1, timeout: 4" do
256
+ subject { Moneta::Pool::PoolManager.new(builder, min: 10, max: 20, ttl: 1, timeout: 4) }
257
+ after { subject.kill! }
258
+
259
+ include_examples :min, 10
260
+ include_examples :max, 20, timeout: 4
261
+ include_examples :ttl, 1, min: 10, max: 20
262
+ include_examples :ttl_with_nonzero_min, ttl: 1, min: 10, max: 20
263
+ include_examples :timeout, 4, max: 20
264
+ end
265
+
266
+ context "with min: 10, max: 10, ttl: 2, timeout: 4" do
267
+ subject { Moneta::Pool::PoolManager.new(builder, min: 10, max: 10, ttl: 2, timeout: 4) }
268
+ after { subject.kill! }
269
+
270
+ include_examples :min, 10
271
+ include_examples :max, 10, timeout: 4
272
+ include_examples :ttl, 2, min: 10, max: 10
273
+ include_examples :ttl_with_nonzero_min, ttl: 2, min: 10, max: 10
274
+ include_examples :timeout, 4, max: 10
275
+ end
276
+
277
+ describe '#check_out' do
278
+ subject { Moneta::Pool::PoolManager.new(builder, max: 1, timeout: 5) }
279
+ after { subject.kill! }
280
+
281
+ let(:num) { 1 }
282
+
283
+ it 'yields the store to requesters first come, first served' do
284
+ store = stores.first
285
+ procs = (0...10)
286
+ .map { |i| double("proc#{i}") }
287
+ .each { |p| expect(p).to receive(:call).with(store).ordered }
288
+
289
+ # Each thread stops immediately after starting. We can then ensure
290
+ # that each checkout is called in order.
291
+ threads = procs.map do |p|
292
+ Thread.new do
293
+ Thread.stop
294
+ p.call(subject.check_out)
295
+ end
296
+ end
297
+
298
+ Timeout.timeout(5) { Thread.pass until threads.all?(&:stop?) }
299
+
300
+ # The first thread should return immediately after waking
301
+ threads.first.wakeup
302
+ Timeout.timeout(5) { threads.first.join }
303
+
304
+ # Wait for the remaining threads to block, one at a time.
305
+ threads.drop(1).each_with_index do |thread, i|
306
+ thread.wakeup
307
+ Timeout.timeout(5) { Thread.pass until subject.stats[:waiting] == i + 1 }
308
+ end
309
+
310
+ # The remaining threads should be waiting for the store to be checked back in
311
+ expect(threads.drop(1)).to all be_alive
312
+ expect(subject.stats).to include(waiting: 9)
313
+
314
+ Timeout.timeout(5) do
315
+ threads.each do |t|
316
+ t.join
317
+ subject.check_in(store)
318
+ end
319
+ end
320
+ end
321
+
322
+ it "raises a ShutdownError if the pool is stopped while waiting for a store" do
323
+ # Exhaust the pool
324
+ store = stores.first
325
+ allow(store).to receive(:close).once
326
+ expect(subject.check_out).to eq store
327
+
328
+ # Simulate a new thread requesting a check-out
329
+ t1 = Thread.new do
330
+ Thread.current.report_on_exception = false if Thread.current.respond_to? :report_on_exception
331
+ subject.check_out
332
+ end
333
+ Timeout.timeout(5) { Thread.pass until subject.stats[:waiting] > 0 }
334
+ expect(t1).to be_alive
335
+
336
+ # Meanwhile in another thread, the pool is stopped.
337
+ t2 = Thread.new { subject.stop }
338
+
339
+ # The requesting thread should error out immediately
340
+ expect { t1.value }.to raise_error Moneta::Pool::ShutdownError
341
+
342
+ # In this thread we return the store to the pool, allowing graceful shutdown to complete.
343
+ subject.check_in(store)
344
+ expect(t2.value).to be_nil
345
+ end
346
+
347
+ it "raises a ShutdownError if a the pool is stopped before requesting a store" do
348
+ subject.stop
349
+ expect { subject.check_out }.to raise_error Moneta::Pool::ShutdownError
350
+ end
351
+ end
352
+ end
353
+ end
@@ -0,0 +1,16 @@
1
+ describe "proxy_expires_memory", isolate: true, proxy: :Proxy do
2
+ let(:t_res) { 0.125 }
3
+ let(:min_ttl) { t_res }
4
+ use_timecop
5
+
6
+ moneta_build do
7
+ Moneta.build do
8
+ use :Proxy
9
+ use :Expires
10
+ use :Proxy
11
+ adapter :Memory
12
+ end
13
+ end
14
+
15
+ moneta_specs STANDARD_SPECS.without_transform.with_expires.returnsame.without_persist.with_each_key
16
+ end
@@ -0,0 +1,59 @@
1
+ describe "shared_tcp", proxy: :Shared do
2
+ moneta_build do
3
+ tempdir = self.tempdir
4
+ Moneta.build do
5
+ use(:Shared, port: 9001) do
6
+ adapter :GDBM, file: File.join(tempdir, 'shared_tcp')
7
+ end
8
+ end
9
+ end
10
+
11
+ shared_examples :shared_tcp do
12
+ moneta_specs ADAPTER_SPECS.with_each_key
13
+
14
+ it 'shares values' do
15
+ store['shared_key'] = 'shared_value'
16
+ second = new_store
17
+ second.key?('shared_key').should be true
18
+ second['shared_key'].should == 'shared_value'
19
+ second.close
20
+ end
21
+ end
22
+
23
+ # The first store initialised will be running the server
24
+ context "running as the server" do
25
+ before do
26
+ store.load('dummy')
27
+ expect(store.server?).to be true
28
+ end
29
+
30
+ include_examples :shared_tcp
31
+
32
+ it 'has the underlying adapter' do
33
+ store.load('dummy')
34
+ expect(store.adapter.adapter).to be_a Moneta::Adapters::GDBM
35
+ end
36
+ end
37
+
38
+ context "running as a client" do
39
+ let!(:server_store) do
40
+ new_store.tap { |store| store.load('dummy') } # Makes a connection
41
+ end
42
+
43
+ before do
44
+ store.load('dummy')
45
+ expect(store.server?).to be false
46
+ end
47
+
48
+ after do
49
+ server_store.close
50
+ end
51
+
52
+ include_examples :shared_tcp
53
+
54
+ it 'has a client adapter' do
55
+ store.load('dummy')
56
+ expect(store.adapter).to be_a Moneta::Adapters::Client
57
+ end
58
+ end
59
+ end
@@ -0,0 +1,58 @@
1
+ describe "shared_unix", proxy: :Shared do
2
+ moneta_build do
3
+ tempdir = self.tempdir
4
+ Moneta.build do
5
+ use(:Shared, socket: File.join(tempdir, 'shared_unix.socket')) do
6
+ adapter :GDBM, file: File.join(tempdir, 'shared_unix')
7
+ end
8
+ end
9
+ end
10
+
11
+ shared_examples :shared_unix do
12
+ moneta_specs ADAPTER_SPECS.with_each_key
13
+
14
+ it 'shares values' do
15
+ store['shared_key'] = 'shared_value'
16
+ second = new_store
17
+ second.key?('shared_key').should be true
18
+ second['shared_key'].should == 'shared_value'
19
+ second.close
20
+ end
21
+ end
22
+
23
+ context "runnning as the server" do
24
+ before do
25
+ store.load('dummy')
26
+ expect(store.server?).to be true
27
+ end
28
+
29
+ include_examples :shared_unix
30
+
31
+ it "has the underlying adapter" do
32
+ store.load('dummy')
33
+ expect(store.adapter.adapter).to be_a Moneta::Adapters::GDBM
34
+ end
35
+ end
36
+
37
+ context "running as a client" do
38
+ let!(:server_store) do
39
+ new_store.tap { |store| store.load('dummy') } # Makes a connection
40
+ end
41
+
42
+ before do
43
+ store.load('dummy')
44
+ expect(store.server?).to be false
45
+ end
46
+
47
+ after do
48
+ server_store.close
49
+ end
50
+
51
+ include_examples :shared_unix
52
+
53
+ it 'has a client adapter' do
54
+ store.load('dummy')
55
+ expect(store.adapter).to be_a Moneta::Adapters::Client
56
+ end
57
+ end
58
+ end
@@ -0,0 +1,19 @@
1
+ describe 'transformer_bencode', proxy: :Transformer do
2
+ moneta_build do
3
+ Moneta.build do
4
+ use :Transformer, key: :bencode, value: :bencode
5
+ adapter :Memory
6
+ end
7
+ end
8
+
9
+ moneta_loader do |value|
10
+ ::BEncode.load(value)
11
+ end
12
+
13
+ moneta_specs TRANSFORMER_SPECS.simplekeys_only.simplevalues_only.with_each_key
14
+
15
+ it 'compile transformer class' do
16
+ store.should_not be_nil
17
+ Moneta::Transformer::BencodeKeyBencodeValue.should_not be_nil
18
+ end
19
+ end
@@ -0,0 +1,19 @@
1
+ describe 'transformer_bert', unsupported: defined?(JRUBY_VERSION), proxy: :Transformer do
2
+ moneta_build do
3
+ Moneta.build do
4
+ use :Transformer, key: :bert, value: :bert
5
+ adapter :Memory
6
+ end
7
+ end
8
+
9
+ moneta_loader do |value|
10
+ ::BERT.decode(value)
11
+ end
12
+
13
+ moneta_specs TRANSFORMER_SPECS.simplekeys_only.simplevalues_only.with_each_key
14
+
15
+ it 'compile transformer class' do
16
+ store.should_not be_nil
17
+ Moneta::Transformer::BertKeyBertValue.should_not be_nil
18
+ end
19
+ end
@@ -0,0 +1,25 @@
1
+ # Currently broken in JRuby 9.3 - see https://github.com/jruby/jruby/issues/6941
2
+
3
+ describe 'transformer_bson', proxy: :Transformer, broken: defined?(JRUBY_VERSION) && ::Gem::Version.new(JRUBY_VERSION) >= ::Gem::Version.new('9.3.0.0') do
4
+ moneta_build do
5
+ Moneta.build do
6
+ use :Transformer, key: :bson, value: :bson
7
+ adapter :Memory
8
+ end
9
+ end
10
+
11
+ moneta_loader do |value|
12
+ if ::BSON::VERSION >= '4.0.0'
13
+ ::BSON::Document.from_bson(::BSON::ByteBuffer.new(value))['v']
14
+ else
15
+ ::BSON::Document.from_bson(::StringIO.new(value))['v']
16
+ end
17
+ end
18
+
19
+ moneta_specs TRANSFORMER_SPECS.simplekeys_only.simplevalues_only.with_each_key
20
+
21
+ it 'compile transformer class' do
22
+ store.should_not be_nil
23
+ Moneta::Transformer::BsonKeyBsonValue.should_not be_nil
24
+ end
25
+ end
@@ -0,0 +1,19 @@
1
+ describe 'transformer_bzip2', proxy: :Transformer do
2
+ moneta_build do
3
+ Moneta.build do
4
+ use :Transformer, value: :bzip2
5
+ adapter :Memory
6
+ end
7
+ end
8
+
9
+ moneta_loader do |value|
10
+ ::RBzip2.default_adapter::Decompressor.new(::StringIO.new(value)).read
11
+ end
12
+
13
+ moneta_specs TRANSFORMER_SPECS.stringvalues_only.with_each_key
14
+
15
+ it 'compile transformer class' do
16
+ store.should_not be_nil
17
+ Moneta::Transformer::Bzip2Value.should_not be_nil
18
+ end
19
+ end
@@ -0,0 +1,19 @@
1
+ describe 'transformer_json', proxy: :Transformer do
2
+ moneta_build do
3
+ Moneta.build do
4
+ use :Transformer, key: :json, value: :json
5
+ adapter :Memory
6
+ end
7
+ end
8
+
9
+ moneta_loader do |value|
10
+ ::MultiJson.load(value)
11
+ end
12
+
13
+ moneta_specs TRANSFORMER_SPECS.simplekeys_only.simplevalues_only.with_each_key
14
+
15
+ it 'compile transformer class' do
16
+ store.should_not be_nil
17
+ Moneta::Transformer::JsonKeyJsonValue.should_not be_nil
18
+ end
19
+ end
@@ -0,0 +1,17 @@
1
+ describe 'transformer_key_inspect', proxy: :Transformer do
2
+ moneta_build do
3
+ Moneta.build do
4
+ use :Transformer, key: :inspect
5
+ adapter :Memory
6
+ end
7
+ end
8
+
9
+ moneta_loader{ |value| value }
10
+
11
+ moneta_specs TRANSFORMER_SPECS.returnsame.simplekeys_only
12
+
13
+ it 'compile transformer class' do
14
+ store.should_not be_nil
15
+ Moneta::Transformer::InspectKey.should_not be_nil
16
+ end
17
+ end
@@ -0,0 +1,17 @@
1
+ describe 'transformer_key_marshal', proxy: :Transformer do
2
+ moneta_build do
3
+ Moneta.build do
4
+ use :Transformer, key: :marshal
5
+ adapter :Memory
6
+ end
7
+ end
8
+
9
+ moneta_loader{ |value| value }
10
+
11
+ moneta_specs TRANSFORMER_SPECS.returnsame.with_each_key
12
+
13
+ it 'compile transformer class' do
14
+ store.should_not be_nil
15
+ Moneta::Transformer::MarshalKey.should_not be_nil
16
+ end
17
+ end
@@ -0,0 +1,17 @@
1
+ describe 'transformer_key_to_s', proxy: :Transformer do
2
+ moneta_build do
3
+ Moneta.build do
4
+ use :Transformer, key: :to_s
5
+ adapter :Memory
6
+ end
7
+ end
8
+
9
+ moneta_loader{ |value| value }
10
+
11
+ moneta_specs TRANSFORMER_SPECS.returnsame.simplekeys_only
12
+
13
+ it 'compile transformer class' do
14
+ store.should_not be_nil
15
+ Moneta::Transformer::ToSKey.should_not be_nil
16
+ end
17
+ end
@@ -0,0 +1,17 @@
1
+ describe 'transformer_key_yaml', proxy: :Transformer do
2
+ moneta_build do
3
+ Moneta.build do
4
+ use :Transformer, key: :yaml
5
+ adapter :Memory
6
+ end
7
+ end
8
+
9
+ moneta_loader{ |value| value }
10
+
11
+ moneta_specs TRANSFORMER_SPECS.returnsame.with_each_key
12
+
13
+ it 'compile transformer class' do
14
+ store.should_not be_nil
15
+ Moneta::Transformer::YamlKey.should_not be_nil
16
+ end
17
+ end
@@ -0,0 +1,19 @@
1
+ describe 'transformer_lz4', unsupported: defined?(JRUBY_VERSION), proxy: :Transformer do
2
+ moneta_build do
3
+ Moneta.build do
4
+ use :Transformer, value: :lz4
5
+ adapter :Memory
6
+ end
7
+ end
8
+
9
+ moneta_loader do |value|
10
+ ::LZ4.uncompress(value)
11
+ end
12
+
13
+ moneta_specs TRANSFORMER_SPECS.stringvalues_only.with_each_key
14
+
15
+ it 'compile transformer class' do
16
+ store.should_not be_nil
17
+ Moneta::Transformer::Lz4Value.should_not be_nil
18
+ end
19
+ end