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
data/lib/moneta/server.rb CHANGED
@@ -4,14 +4,171 @@ module Moneta
4
4
  # Moneta server to be used together with Moneta::Adapters::Client
5
5
  # @api public
6
6
  class Server
7
+ include Config
8
+
9
+ config :timeout, default: 1
10
+ config :max_size, default: 0x100000
11
+
12
+ # @api private
13
+ class Connection
14
+ def initialize(io, store, max_size)
15
+ @io = io
16
+ @store = store
17
+ @max_size = max_size
18
+ @fiber = Fiber.new { run }
19
+ end
20
+
21
+ def resume(result = nil)
22
+ @fiber.resume result
23
+ end
24
+
25
+ private
26
+
27
+ # The return value of this function will be sent to the reactor.
28
+ #
29
+ # @return [:closed,Exception]
30
+ def run
31
+ catch :closed do
32
+ loop { write_dispatch(read_msg) }
33
+ end
34
+ :closed
35
+ rescue => ex
36
+ ex
37
+ ensure
38
+ @io.close unless @io.closed?
39
+ end
40
+
41
+ def dispatch(method, args)
42
+ case method
43
+ when :key?, :load, :delete, :increment, :create, :features
44
+ @store.public_send(method, *args)
45
+ when :store, :clear
46
+ @store.public_send(method, *args)
47
+ nil
48
+ when :each_key
49
+ yield_each(@store.each_key)
50
+ nil
51
+ end
52
+ rescue => ex
53
+ ex
54
+ end
55
+
56
+ def write_dispatch(msg)
57
+ method, *args = msg
58
+ result = dispatch(method, args)
59
+ write(result)
60
+ end
61
+
62
+ def read_msg
63
+ size = read(4).unpack('N').first
64
+ throw :closed, 'Message too big' if size > @max_size
65
+ Marshal.load(read(size))
66
+ end
67
+
68
+ def read(len)
69
+ buffer = ''
70
+ loop do
71
+ begin
72
+ case received = @io.recv_nonblock(len)
73
+ when '', nil
74
+ throw :closed, 'Closed during read'
75
+ else
76
+ buffer << received
77
+ len -= received.bytesize
78
+ end
79
+ rescue IO::WaitReadable, IO::WaitWritable
80
+ yield_to_reactor(:read)
81
+ rescue Errno::ECONNRESET
82
+ throw :closed, 'Closed during read'
83
+ rescue IOError => ex
84
+ if ex.message =~ /closed stream/
85
+ throw :closed, 'Closed during read'
86
+ else
87
+ raise
88
+ end
89
+ end
90
+ break if len == 0
91
+ end
92
+ buffer
93
+ end
94
+
95
+ def write(obj)
96
+ buffer = pack(obj)
97
+ until buffer.empty?
98
+ begin
99
+ len = sendmsg(buffer)
100
+ buffer = buffer.byteslice(len...buffer.length)
101
+ rescue IO::WaitWritable, Errno::EINTR
102
+ yield_to_reactor(:write)
103
+ end
104
+ end
105
+ nil
106
+ end
107
+
108
+ # Detect support for socket#sendmsg_nonblock
109
+ Socket.new(Socket::AF_INET, Socket::SOCK_STREAM).tap do |socket|
110
+ begin
111
+ socket.sendmsg_nonblock('probe')
112
+ rescue Errno::EPIPE, Errno::ENOTCONN
113
+ def sendmsg(msg)
114
+ @io.sendmsg_nonblock(msg)
115
+ end
116
+ rescue NotImplementedError
117
+ def sendmsg(msg)
118
+ @io.write_nonblock(msg)
119
+ end
120
+ end
121
+ end
122
+
123
+ def yield_to_reactor(mode = :read)
124
+ if Fiber.yield(mode) == :close
125
+ throw :closed, 'Closed by reactor'
126
+ end
127
+ end
128
+
129
+ def pack(obj)
130
+ s = Marshal.dump(obj)
131
+ [s.bytesize].pack('N') << s
132
+ end
133
+
134
+ def yield_each(enumerator)
135
+ received_break = false
136
+ loop do
137
+ case msg = read_msg
138
+ when %w{NEXT}
139
+ # This will raise a StopIteration at the end of the enumeration,
140
+ # which will exit the loop.
141
+ write(enumerator.next)
142
+ when %w{BREAK}
143
+ # This is received when the client wants to stop the enumeration.
144
+ received_break = true
145
+ break
146
+ else
147
+ # Otherwise, the client is attempting to call another method within
148
+ # an `each` block.
149
+ write_dispatch(msg)
150
+ end
151
+ end
152
+ ensure
153
+ # This tells the client to stop enumerating
154
+ write(StopIteration.new("Server initiated stop")) unless received_break
155
+ end
156
+ end
157
+
7
158
  # @param [Hash] options
8
159
  # @option options [Integer] :port (9000) TCP port
9
160
  # @option options [String] :socket Alternative Unix socket file name
161
+ # @option options [Integer] :timeout (1) Number of seconds to timeout on IO.select
162
+ # @option options [Integer] :max_size (0x100000) Maximum number of bytes
163
+ # allowed to be sent by clients in requests
10
164
  def initialize(store, options = {})
165
+ options = configure(**options)
11
166
  @store = store
12
- @server = start(options)
167
+ @server = start(**options)
13
168
  @ios = [@server]
14
- @clients = {}
169
+ @reads = @ios.dup
170
+ @writes = []
171
+ @connections = {}
15
172
  @running = false
16
173
  end
17
174
 
@@ -26,111 +183,116 @@ module Moneta
26
183
  #
27
184
  # @note This method blocks!
28
185
  def run
29
- raise 'Already running' if @running
186
+ raise 'Already running' if running?
30
187
  @stop = false
31
188
  @running = true
32
189
  begin
33
- until @stop
34
- mainloop
35
- end
190
+ mainloop until @stop
36
191
  ensure
37
- File.unlink(@socket) if @socket
192
+ @running = false
193
+ @server.close unless @server.closed?
194
+ @ios
195
+ .reject { |io| io == @server }
196
+ .each { |io| close_connection(io) }
197
+ File.unlink(config.socket) if config.socket rescue nil
38
198
  end
39
199
  end
40
200
 
41
201
  # Stop the server
42
202
  def stop
43
- raise 'Not running' unless @running
203
+ raise 'Not running' unless running?
44
204
  @stop = true
45
205
  @server.close
46
- @server = nil
206
+ nil
47
207
  end
48
208
 
49
209
  private
50
210
 
51
- TIMEOUT = 1
52
- MAXSIZE = 0x100000
53
-
54
211
  def mainloop
55
- if ios = IO.select(@ios, nil, @ios, TIMEOUT)
56
- ios[2].each do |io|
57
- io.close
58
- delete_client(io)
59
- end
60
- ios[0].each do |io|
61
- if io == @server
62
- if client = @server.accept
63
- @ios << client
64
- @clients[client] = ''
65
- end
66
- elsif io.closed? || io.eof?
67
- delete_client(io)
68
- else
69
- handle(io, @clients[io] << io.readpartial(0xFFFF))
70
- end
212
+ if ready = IO.select(@reads, @writes, @ios, config.timeout)
213
+ reads, writes, errors = ready
214
+ errors.each { |io| close_connection(io) }
215
+
216
+ @reads -= reads
217
+ reads.each do |io|
218
+ io == @server ? accept_connection : resume(io)
71
219
  end
220
+
221
+ @writes -= writes
222
+ writes.each { |io| resume(io) }
72
223
  end
73
- rescue SignalException => ex
74
- warn "Moneta::Server - #{ex.message}"
75
- raise if ex.signo == 15 || ex.signo == 2 # SIGTERM or SIGINT
76
- rescue Exception => ex
224
+ rescue SignalException => signal
225
+ warn "Moneta::Server - received #{signal}"
226
+ case signal.signo
227
+ when Signal.list['INT'], Signal.list['TERM']
228
+ @stop = true # graceful exit
229
+ end
230
+ rescue IOError => ex
231
+ # We get a lot of these "closed stream" errors, which we ignore
232
+ raise unless ex.message =~ /closed stream/
233
+ rescue Errno::EBADF => ex
77
234
  warn "Moneta::Server - #{ex.message}"
78
235
  end
79
236
 
80
- def delete_client(io)
237
+ def accept_connection
238
+ io = @server.accept
239
+ @connections[io] = Connection.new(io, @store, config.max_size)
240
+ @ios << io
241
+ resume(io)
242
+ ensure
243
+ @reads << @server
244
+ end
245
+
246
+ def delete_connection(io)
81
247
  @ios.delete(io)
82
- @clients.delete(io)
248
+ @reads.delete(io)
249
+ @writes.delete(io)
83
250
  end
84
251
 
85
- def pack(o)
86
- s = Marshal.dump(o)
87
- [s.bytesize].pack('N') << s
252
+ def close_connection(io)
253
+ delete_connection(io)
254
+ @connections.delete(io).resume(:close)
88
255
  end
89
256
 
90
- def handle(io, buffer)
91
- buffer = @clients[io]
92
- return if buffer.bytesize < 8 # At least 4 bytes for the marshalled array
93
- size = buffer[0,4].unpack('N').first
94
- if size > MAXSIZE
95
- delete_client(io)
96
- return
97
- end
98
- return if buffer.bytesize < 4 + size
99
- buffer.slice!(0, 4)
100
- method, *args = Marshal.load(buffer.slice!(0, size))
101
- case method
102
- when :key?, :load, :delete, :increment, :create, :features
103
- io.write(pack @store.send(method, *args))
104
- when :store, :clear
105
- @store.send(method, *args)
106
- io.write(@nil ||= pack(nil))
107
- else
108
- raise 'Invalid method call'
257
+ def resume(io)
258
+ case result = @connections[io].resume
259
+ when :closed # graceful exit
260
+ delete_connection(io)
261
+ when Exception # messy exit
262
+ delete_connection(io)
263
+ raise result
264
+ when :read
265
+ @reads << io
266
+ when :write
267
+ @writes << io
109
268
  end
110
- rescue IOError => ex
111
- warn "Moneta::Server - #{ex.message}" unless ex.message =~ /closed/
112
- delete_client(io)
113
- rescue Exception => ex
114
- warn "Moneta::Server - #{ex.message}"
115
- io.write(pack Exception.new(ex.message))
116
269
  end
117
270
 
118
- def start(options)
119
- if @socket = options[:socket]
271
+ def start(host: '127.0.0.1', port: 9000, socket: nil)
272
+ if socket
120
273
  begin
121
- UNIXServer.open(@socket)
274
+ UNIXServer.open(socket)
122
275
  rescue Errno::EADDRINUSE
123
- if client = (UNIXSocket.open(@socket) rescue nil)
276
+ if client = (UNIXSocket.open(socket) rescue nil)
124
277
  client.close
125
278
  raise
126
279
  end
127
- File.unlink(@socket)
280
+ File.unlink(socket)
128
281
  tries ||= 0
129
282
  (tries += 1) < 3 ? retry : raise
130
283
  end
131
284
  else
132
- TCPServer.open(options[:host] || '127.0.0.1', options[:port] || 9000)
285
+ TCPServer.open(host, port)
133
286
  end
134
287
  end
288
+
289
+ def stats
290
+ {
291
+ connections: @connections.length,
292
+ reading: @reads.length,
293
+ writing: @writes.length,
294
+ total: @ios.length
295
+ }
296
+ end
135
297
  end
136
298
  end
data/lib/moneta/shared.rb CHANGED
@@ -18,11 +18,12 @@ module Moneta
18
18
  def initialize(options = {}, &block)
19
19
  @options = options
20
20
  @builder = Builder.new(&block)
21
+ @connect_lock = ::Mutex.new
21
22
  end
22
23
 
23
24
  # (see Proxy#close)
24
25
  def close
25
- if @server
26
+ if server?
26
27
  @server.stop
27
28
  @thread.join
28
29
  @server = @thread = nil
@@ -33,35 +34,56 @@ module Moneta
33
34
  end
34
35
  end
35
36
 
37
+ # Returns true if this wrapper is running as the server
38
+ #
39
+ # @return [Boolean] wrapper is a server
40
+ def server?
41
+ @server != nil
42
+ end
43
+
36
44
  protected
37
45
 
38
46
  def wrap(*args)
39
47
  connect
40
48
  yield
49
+ rescue Errno::ECONNRESET, Errno::EPIPE, IOError, SystemCallError
50
+ @connect_lock.synchronize { close unless server? }
51
+ tries ||= 0
52
+ (tries += 1) < 3 ? retry : raise
41
53
  end
42
54
 
43
55
  def connect
44
- @adapter ||= Adapters::Client.new(@options)
45
- rescue Errno::ECONNREFUSED, Errno::ENOENT => ex
56
+ return if @adapter
57
+ @connect_lock.synchronize do
58
+ @adapter ||= Adapters::Client.new(@options)
59
+ end
60
+ rescue Errno::ECONNREFUSED, Errno::ENOENT, IOError => ex
46
61
  start_server
47
62
  tries ||= 0
48
63
  warn "Moneta::Shared - Failed to connect: #{ex.message}" if tries > 0
49
- (tries += 1) < 3 ? retry : raise
64
+ (tries += 1) < 10 ? retry : raise
50
65
  end
51
66
 
52
67
  # TODO: Implement this using forking (MRI) and threading (JRuby)
53
68
  # to get maximal performance
54
69
  def start_server
55
- @adapter = Lock.new(@builder.build.last)
56
- @server = Server.new(@adapter, @options)
57
- @thread = Thread.new { @server.run }
58
- sleep 0.1 until @server.running?
59
- rescue Exception => ex
60
- @adapter.close if @adapter
61
- @adapter = nil
62
- @server = nil
63
- @thread = nil
64
- warn "Moneta::Shared - Failed to start server: #{ex.message}"
70
+ @connect_lock.synchronize do
71
+ return if server?
72
+ begin
73
+ raise "Adapter already set" if @adapter
74
+ @adapter = Lock.new(@builder.build.last)
75
+ raise "Server already set" if server?
76
+ @server = Server.new(@adapter, @options)
77
+ @thread = Thread.new { @server.run }
78
+ sleep 0.1 until @server.running?
79
+ rescue => ex
80
+ @adapter.close if @adapter
81
+ @adapter = nil
82
+ @server = nil
83
+ @thread = nil
84
+ warn "Moneta::Shared - Failed to start server: #{ex.message}"
85
+ end
86
+ end
65
87
  end
66
88
  end
67
89
  end
data/lib/moneta/stack.rb CHANGED
@@ -42,7 +42,7 @@ module Moneta
42
42
 
43
43
  # (see Proxy#key?)
44
44
  def key?(key, options = {})
45
- @stack.any? {|s| s.key?(key, options) }
45
+ @stack.any? { |s| s.key?(key, options) }
46
46
  end
47
47
 
48
48
  # (see Proxy#load)
@@ -56,21 +56,21 @@ module Moneta
56
56
 
57
57
  # (see Proxy#store)
58
58
  def store(key, value, options = {})
59
- @stack.each {|s| s.store(key, value, options) }
59
+ @stack.each { |s| s.store(key, value, options) }
60
60
  value
61
61
  end
62
62
 
63
63
  # (see Proxy#increment)
64
64
  def increment(key, amount = 1, options = {})
65
65
  last = nil
66
- @stack.each {|s| last = s.increment(key, amount, options) }
66
+ @stack.each { |s| last = s.increment(key, amount, options) }
67
67
  last
68
68
  end
69
69
 
70
70
  # (see Proxy#create)
71
71
  def create(key, value, options = {})
72
72
  last = false
73
- @stack.each {|s| last = s.create(key, value, options) }
73
+ @stack.each { |s| last = s.create(key, value, options) }
74
74
  last
75
75
  end
76
76
 
@@ -84,13 +84,13 @@ module Moneta
84
84
 
85
85
  # (see Proxy#clear)
86
86
  def clear(options = {})
87
- @stack.each {|s| s.clear(options) }
87
+ @stack.each { |s| s.clear(options) }
88
88
  self
89
89
  end
90
90
 
91
91
  # (see Proxy#close)
92
92
  def close
93
- @stack.each {|s| s.close }
93
+ @stack.each { |s| s.close }
94
94
  nil
95
95
  end
96
96
 
@@ -99,7 +99,7 @@ module Moneta
99
99
  @features ||=
100
100
  begin
101
101
  features = @stack.map(&:features)
102
- features.inject(features.first, &:&).freeze
102
+ (features.inject(features.first, &:&) - [:each_key]).freeze
103
103
  end
104
104
  end
105
105
  end
@@ -1,6 +1,6 @@
1
1
  module Moneta
2
2
  # Base class for {Mutex} and {Semaphore}
3
- # @api private
3
+ # @abstract
4
4
  class SynchronizePrimitive
5
5
  # Synchronize block
6
6
  #
@@ -16,17 +16,15 @@ module Moneta
16
16
 
17
17
  # Try to enter critical section (nonblocking)
18
18
  #
19
- # @api public
20
19
  # @return [Boolean] true if the lock was acquired
21
20
  def try_enter
22
21
  raise 'Already locked' if @locked
23
22
  enter_primitive ? @locked = true : false
24
23
  end
25
- alias_method :try_lock, :try_enter
24
+ alias try_lock try_enter
26
25
 
27
26
  # Enter critical section (blocking)
28
27
  #
29
- # @api public
30
28
  # @param [Number] timeout Maximum time to wait
31
29
  # @param [Number] wait Sleep time between tries to acquire lock
32
30
  # @return [Boolean] true if the lock was aquired
@@ -38,22 +36,18 @@ module Moneta
38
36
  end
39
37
  false
40
38
  end
41
- alias_method :lock, :enter
39
+ alias lock enter
42
40
 
43
41
  # Leave critical section
44
- #
45
- # @api public
46
42
  def leave
47
43
  raise 'Not locked' unless @locked
48
44
  leave_primitive
49
45
  @locked = false
50
46
  nil
51
47
  end
52
- alias_method :unlock, :leave
48
+ alias unlock leave
53
49
 
54
50
  # Is the lock acquired?
55
- #
56
- # @api public
57
51
  def locked?
58
52
  @locked
59
53
  end
@@ -101,7 +95,7 @@ module Moneta
101
95
  class Semaphore < SynchronizePrimitive
102
96
  # @param [Moneta store] store The store we want to lock
103
97
  # @param [Object] counter Key of the counter entry
104
- # @param [Fixnum] max Maximum number of threads which are allowed to enter the critical section
98
+ # @param [Integer] max Maximum number of threads which are allowed to enter the critical section
105
99
  def initialize(store, counter, max = 1)
106
100
  raise 'Store must support feature :increment' unless store.supports?(:increment)
107
101
  @store, @counter, @max = store, counter, max