moneta 1.1.1 → 1.4.1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (207) hide show
  1. checksums.yaml +4 -4
  2. data/.gitignore +2 -0
  3. data/.rubocop.yml +194 -0
  4. data/.travis.yml +65 -25
  5. data/CHANGES +36 -0
  6. data/CONTRIBUTORS +4 -2
  7. data/Gemfile +94 -65
  8. data/README.md +50 -25
  9. data/feature_matrix.yaml +3 -11
  10. data/lib/action_dispatch/middleware/session/moneta_store.rb +1 -0
  11. data/lib/active_support/cache/moneta_store.rb +5 -5
  12. data/lib/moneta.rb +18 -10
  13. data/lib/moneta/adapters/activerecord.rb +35 -19
  14. data/lib/moneta/adapters/activesupportcache.rb +3 -7
  15. data/lib/moneta/adapters/cassandra.rb +24 -16
  16. data/lib/moneta/adapters/client.rb +62 -21
  17. data/lib/moneta/adapters/couch.rb +225 -80
  18. data/lib/moneta/adapters/datamapper.rb +1 -0
  19. data/lib/moneta/adapters/file.rb +9 -6
  20. data/lib/moneta/adapters/hbase.rb +1 -1
  21. data/lib/moneta/adapters/kyotocabinet.rb +8 -7
  22. data/lib/moneta/adapters/leveldb.rb +1 -1
  23. data/lib/moneta/adapters/lmdb.rb +3 -4
  24. data/lib/moneta/adapters/lruhash.rb +29 -62
  25. data/lib/moneta/adapters/memcached.rb +1 -0
  26. data/lib/moneta/adapters/memcached/dalli.rb +1 -1
  27. data/lib/moneta/adapters/memcached/native.rb +10 -8
  28. data/lib/moneta/adapters/mongo.rb +264 -6
  29. data/lib/moneta/adapters/null.rb +1 -2
  30. data/lib/moneta/adapters/pstore.rb +3 -2
  31. data/lib/moneta/adapters/redis.rb +8 -4
  32. data/lib/moneta/adapters/restclient.rb +12 -3
  33. data/lib/moneta/adapters/riak.rb +2 -2
  34. data/lib/moneta/adapters/sequel.rb +68 -494
  35. data/lib/moneta/adapters/sequel/mysql.rb +66 -0
  36. data/lib/moneta/adapters/sequel/postgres.rb +80 -0
  37. data/lib/moneta/adapters/sequel/postgres_hstore.rb +240 -0
  38. data/lib/moneta/adapters/sequel/sqlite.rb +57 -0
  39. data/lib/moneta/adapters/sqlite.rb +10 -10
  40. data/lib/moneta/adapters/tokyotyrant.rb +1 -1
  41. data/lib/moneta/builder.rb +2 -3
  42. data/lib/moneta/create_support.rb +21 -0
  43. data/lib/moneta/dbm_adapter.rb +31 -0
  44. data/lib/moneta/{mixins.rb → defaults.rb} +3 -302
  45. data/lib/moneta/each_key_support.rb +27 -0
  46. data/lib/moneta/enumerable.rb +38 -0
  47. data/lib/moneta/expires.rb +12 -12
  48. data/lib/moneta/expires_support.rb +60 -0
  49. data/lib/moneta/fallback.rb +84 -0
  50. data/lib/moneta/hash_adapter.rb +68 -0
  51. data/lib/moneta/increment_support.rb +16 -0
  52. data/lib/moneta/lock.rb +7 -2
  53. data/lib/moneta/logger.rb +2 -2
  54. data/lib/moneta/nil_values.rb +35 -0
  55. data/lib/moneta/option_support.rb +51 -0
  56. data/lib/moneta/optionmerger.rb +0 -1
  57. data/lib/moneta/pool.rb +312 -30
  58. data/lib/moneta/proxy.rb +3 -3
  59. data/lib/moneta/server.rb +216 -65
  60. data/lib/moneta/shared.rb +13 -7
  61. data/lib/moneta/stack.rb +6 -6
  62. data/lib/moneta/synchronize.rb +3 -3
  63. data/lib/moneta/transformer.rb +68 -24
  64. data/lib/moneta/transformer/config.rb +63 -43
  65. data/lib/moneta/transformer/helper.rb +3 -3
  66. data/lib/moneta/transformer/helper/bson.rb +7 -14
  67. data/lib/moneta/utils.rb +3 -9
  68. data/lib/moneta/version.rb +1 -1
  69. data/lib/moneta/weak_each_key.rb +2 -4
  70. data/lib/rack/cache/moneta.rb +13 -11
  71. data/lib/rack/moneta_rest.rb +2 -2
  72. data/lib/rack/session/moneta.rb +3 -4
  73. data/moneta.gemspec +18 -4
  74. data/script/benchmarks +61 -34
  75. data/script/contributors +11 -6
  76. data/script/start-couchdb +27 -0
  77. data/script/start-hbase +3 -2
  78. data/script/start-services +3 -11
  79. data/spec/active_support/cache_moneta_store_spec.rb +30 -30
  80. data/spec/features/concurrent_create.rb +31 -10
  81. data/spec/features/concurrent_increment.rb +26 -19
  82. data/spec/features/create_expires.rb +15 -15
  83. data/spec/features/default_expires.rb +11 -12
  84. data/spec/features/expires.rb +215 -210
  85. data/spec/features/increment.rb +41 -41
  86. data/spec/features/store.rb +3 -3
  87. data/spec/helper.rb +21 -82
  88. data/spec/moneta/adapters/activerecord/standard_activerecord_spec.rb +1 -1
  89. data/spec/moneta/adapters/activerecord/standard_activerecord_with_expires_spec.rb +1 -1
  90. data/spec/moneta/adapters/activesupportcache/adapter_activesupportcache_spec.rb +4 -1
  91. data/spec/moneta/adapters/activesupportcache/adapter_activesupportcache_with_default_expires_spec.rb +4 -1
  92. data/spec/moneta/adapters/activesupportcache/standard_activesupportcache_spec.rb +14 -0
  93. data/spec/moneta/adapters/cassandra/standard_cassandra_spec.rb +1 -1
  94. data/spec/moneta/adapters/client/adapter_client_spec.rb +6 -6
  95. data/spec/moneta/adapters/client/client_helper.rb +24 -0
  96. data/spec/moneta/adapters/client/standard_client_tcp_spec.rb +8 -8
  97. data/spec/moneta/adapters/client/standard_client_unix_spec.rb +23 -7
  98. data/spec/moneta/adapters/couch/adapter_couch_spec.rb +199 -2
  99. data/spec/moneta/adapters/couch/standard_couch_spec.rb +9 -3
  100. data/spec/moneta/adapters/couch/standard_couch_with_expires_spec.rb +8 -2
  101. data/spec/moneta/adapters/daybreak/standard_daybreak_spec.rb +1 -1
  102. data/spec/moneta/adapters/daybreak/standard_daybreak_with_expires_spec.rb +1 -1
  103. data/spec/moneta/adapters/dbm/standard_dbm_spec.rb +1 -1
  104. data/spec/moneta/adapters/dbm/standard_dbm_with_expires_spec.rb +1 -1
  105. data/spec/moneta/adapters/faraday_helper.rb +9 -0
  106. data/spec/moneta/adapters/file/standard_file_spec.rb +2 -2
  107. data/spec/moneta/adapters/file/standard_file_with_expires_spec.rb +1 -1
  108. data/spec/moneta/adapters/gdbm/standard_gdbm_spec.rb +1 -1
  109. data/spec/moneta/adapters/gdbm/standard_gdbm_with_expires_spec.rb +1 -1
  110. data/spec/moneta/adapters/kyotocabinet/adapter_kyotocabinet_spec.rb +1 -1
  111. data/spec/moneta/adapters/kyotocabinet/standard_kyotocabinet_spec.rb +2 -2
  112. data/spec/moneta/adapters/kyotocabinet/standard_kyotocabinet_with_expires_spec.rb +2 -2
  113. data/spec/moneta/adapters/leveldb/standard_leveldb_spec.rb +1 -1
  114. data/spec/moneta/adapters/leveldb/standard_leveldb_with_expires_spec.rb +1 -1
  115. data/spec/moneta/adapters/lmdb/standard_lmdb_spec.rb +1 -1
  116. data/spec/moneta/adapters/lmdb/standard_lmdb_with_expires_spec.rb +1 -1
  117. data/spec/moneta/adapters/lruhash/adapter_lruhash_spec.rb +2 -2
  118. data/spec/moneta/adapters/lruhash/standard_lruhash_spec.rb +1 -1
  119. data/spec/moneta/adapters/lruhash/standard_lruhash_with_expires_spec.rb +1 -1
  120. data/spec/moneta/adapters/memcached/adapter_memcached_spec.rb +1 -1
  121. data/spec/moneta/adapters/memcached/dalli/adapter_memcached_dalli_spec.rb +1 -1
  122. data/spec/moneta/adapters/memcached/dalli/adapter_memcached_dalli_with_default_expires_spec.rb +1 -1
  123. data/spec/moneta/adapters/memcached/dalli/standard_memcached_dalli_spec.rb +1 -1
  124. data/spec/moneta/adapters/memcached/native/adapter_memcached_native_spec.rb +1 -1
  125. data/spec/moneta/adapters/memcached/native/adapter_memcached_native_with_default_expires_spec.rb +1 -1
  126. data/spec/moneta/adapters/memcached/native/standard_memcached_native_spec.rb +1 -1
  127. data/spec/moneta/adapters/memcached/standard_memcached_spec.rb +1 -1
  128. data/spec/moneta/adapters/{memcached/helper.rb → memcached_helper.rb} +0 -0
  129. data/spec/moneta/adapters/memory/standard_memory_spec.rb +1 -1
  130. data/spec/moneta/adapters/memory/standard_memory_with_compress_spec.rb +1 -1
  131. data/spec/moneta/adapters/memory/standard_memory_with_expires_spec.rb +1 -1
  132. data/spec/moneta/adapters/memory/standard_memory_with_json_key_serializer_spec.rb +1 -1
  133. data/spec/moneta/adapters/memory/standard_memory_with_json_serializer_spec.rb +1 -1
  134. data/spec/moneta/adapters/memory/standard_memory_with_json_value_serializer_spec.rb +2 -2
  135. data/spec/moneta/adapters/memory/standard_memory_with_prefix_spec.rb +39 -2
  136. data/spec/moneta/adapters/memory/standard_memory_with_snappy_compress_spec.rb +2 -2
  137. data/spec/moneta/adapters/mongo/adapter_mongo_spec.rb +32 -2
  138. data/spec/moneta/adapters/mongo/adapter_mongo_with_default_expires_spec.rb +5 -3
  139. data/spec/moneta/adapters/mongo/standard_mongo_spec.rb +2 -2
  140. data/spec/moneta/adapters/null/null_adapter_spec.rb +1 -1
  141. data/spec/moneta/adapters/pstore/standard_pstore_spec.rb +1 -1
  142. data/spec/moneta/adapters/pstore/standard_pstore_with_expires_spec.rb +1 -1
  143. data/spec/moneta/adapters/redis/standard_redis_spec.rb +1 -1
  144. data/spec/moneta/adapters/restclient/adapter_restclient_spec.rb +7 -5
  145. data/spec/moneta/adapters/restclient/helper.rb +12 -0
  146. data/spec/moneta/adapters/restclient/standard_restclient_spec.rb +9 -6
  147. data/spec/moneta/adapters/riak/standard_riak_with_expires_spec.rb +4 -0
  148. data/spec/moneta/adapters/sdbm/standard_sdbm_spec.rb +1 -1
  149. data/spec/moneta/adapters/sdbm/standard_sdbm_with_expires_spec.rb +1 -1
  150. data/spec/moneta/adapters/sequel/adapter_sequel_spec.rb +7 -34
  151. data/spec/moneta/adapters/sequel/helper.rb +37 -0
  152. data/spec/moneta/adapters/sequel/standard_sequel_spec.rb +5 -11
  153. data/spec/moneta/adapters/sequel/standard_sequel_with_expires_spec.rb +8 -9
  154. data/spec/moneta/adapters/sqlite/standard_sqlite_spec.rb +1 -1
  155. data/spec/moneta/adapters/sqlite/standard_sqlite_with_expires_spec.rb +1 -1
  156. data/spec/moneta/adapters/tdb/standard_tdb_spec.rb +1 -1
  157. data/spec/moneta/adapters/tdb/standard_tdb_with_expires_spec.rb +1 -1
  158. data/spec/moneta/adapters/tokyocabinet/standard_tokyocabinet_spec.rb +1 -1
  159. data/spec/moneta/adapters/tokyocabinet/standard_tokyocabinet_with_expires_spec.rb +1 -1
  160. data/spec/moneta/adapters/tokyotyrant/adapter_tokyotyrant_spec.rb +6 -2
  161. data/spec/moneta/adapters/tokyotyrant/helper.rb +12 -0
  162. data/spec/moneta/adapters/tokyotyrant/standard_tokyotyrant_spec.rb +5 -2
  163. data/spec/moneta/adapters/tokyotyrant/standard_tokyotyrant_with_expires_spec.rb +5 -1
  164. data/spec/moneta/adapters/yaml/standard_yaml_spec.rb +1 -1
  165. data/spec/moneta/adapters/yaml/standard_yaml_with_expires_spec.rb +1 -1
  166. data/spec/moneta/builder_spec.rb +22 -0
  167. data/spec/moneta/proxies/enumerable/enumerable_spec.rb +26 -0
  168. data/spec/moneta/proxies/expires/expires_file_spec.rb +1 -1
  169. data/spec/moneta/proxies/fallback/fallback_spec.rb +42 -0
  170. data/spec/moneta/proxies/pool/pool_spec.rb +319 -6
  171. data/spec/moneta/proxies/shared/shared_tcp_spec.rb +14 -4
  172. data/spec/moneta/proxies/shared/shared_unix_spec.rb +14 -4
  173. data/spec/moneta/proxies/transformer/transformer_bencode_spec.rb +1 -1
  174. data/spec/moneta/proxies/transformer/transformer_bert_spec.rb +3 -3
  175. data/spec/moneta/proxies/transformer/transformer_bson_spec.rb +2 -2
  176. data/spec/moneta/proxies/transformer/transformer_json_spec.rb +1 -1
  177. data/spec/moneta/proxies/transformer/transformer_key_marshal_spec.rb +1 -1
  178. data/spec/moneta/proxies/transformer/transformer_key_yaml_spec.rb +1 -1
  179. data/spec/moneta/proxies/transformer/transformer_marshal_base64_spec.rb +1 -1
  180. data/spec/moneta/proxies/transformer/transformer_marshal_escape_spec.rb +8 -4
  181. data/spec/moneta/proxies/transformer/transformer_marshal_hex_spec.rb +1 -1
  182. data/spec/moneta/proxies/transformer/transformer_marshal_hmac_spec.rb +1 -1
  183. data/spec/moneta/proxies/transformer/transformer_marshal_prefix_base64_spec.rb +33 -0
  184. data/spec/moneta/proxies/transformer/transformer_marshal_prefix_spec.rb +1 -1
  185. data/spec/moneta/proxies/transformer/transformer_marshal_qp_spec.rb +1 -1
  186. data/spec/moneta/proxies/transformer/transformer_marshal_spec.rb +1 -1
  187. data/spec/moneta/proxies/transformer/transformer_marshal_urlsafe_base64_spec.rb +1 -1
  188. data/spec/moneta/proxies/transformer/transformer_marshal_uuencode_spec.rb +1 -1
  189. data/spec/moneta/proxies/transformer/transformer_msgpack_spec.rb +1 -1
  190. data/spec/moneta/proxies/transformer/transformer_ox_spec.rb +1 -1
  191. data/spec/moneta/proxies/transformer/transformer_php_spec.rb +1 -1
  192. data/spec/moneta/proxies/transformer/transformer_tnet_spec.rb +1 -1
  193. data/spec/moneta/proxies/transformer/transformer_yaml_spec.rb +2 -2
  194. data/spec/moneta/proxies/weak_each_key/weak_each_key_spec.rb +0 -2
  195. data/spec/restserver.rb +55 -0
  196. metadata +136 -32
  197. data/lib/moneta/adapters/mongo/base.rb +0 -103
  198. data/lib/moneta/adapters/mongo/moped.rb +0 -164
  199. data/lib/moneta/adapters/mongo/official.rb +0 -157
  200. data/script/install-kyotocabinet +0 -17
  201. data/spec/moneta/adapters/mongo/adapter_mongo_moped_spec.rb +0 -25
  202. data/spec/moneta/adapters/mongo/adapter_mongo_moped_with_default_expires_spec.rb +0 -12
  203. data/spec/moneta/adapters/mongo/adapter_mongo_official_spec.rb +0 -25
  204. data/spec/moneta/adapters/mongo/adapter_mongo_official_with_default_expires_spec.rb +0 -12
  205. data/spec/moneta/adapters/mongo/standard_mongo_moped_spec.rb +0 -7
  206. data/spec/moneta/adapters/mongo/standard_mongo_official_spec.rb +0 -7
  207. data/spec/quality_spec.rb +0 -51
@@ -69,11 +69,11 @@ module Rack
69
69
  private
70
70
 
71
71
  def empty(status)
72
- [status, {'Content-Type'=>'application/octet-stream', 'Content-Length' => '0'}, []]
72
+ [status, { 'Content-Type' => 'application/octet-stream', 'Content-Length' => '0' }, []]
73
73
  end
74
74
 
75
75
  def respond(status, value)
76
- [status, {'Content-Type'=>'application/octet-stream', 'Content-Length' => value.bytesize.to_s}, [value]]
76
+ [status, { 'Content-Type' => 'application/octet-stream', 'Content-Length' => value.bytesize.to_s }, [value]]
77
77
  end
78
78
  end
79
79
  end
@@ -1,6 +1,5 @@
1
1
  require 'moneta'
2
2
  require 'rack/session/abstract/id'
3
- require 'thread'
4
3
 
5
4
  module Rack
6
5
  module Session
@@ -44,9 +43,10 @@ module Rack
44
43
  with_lock(env) do
45
44
  unless sid && session = @pool[sid]
46
45
  session = {}
47
- begin
46
+ loop do
48
47
  sid = generate_sid
49
- end until @pool.create(sid, session)
48
+ break if @pool.create(sid, session)
49
+ end
50
50
  end
51
51
  [sid, session]
52
52
  end
@@ -76,4 +76,3 @@ module Rack
76
76
  end
77
77
  end
78
78
  end
79
-
@@ -1,4 +1,3 @@
1
- # -*- encoding: utf-8 -*-
2
1
  require File.dirname(__FILE__) + '/lib/moneta/version'
3
2
  require 'date'
4
3
 
@@ -7,15 +6,30 @@ Gem::Specification.new do |s|
7
6
  s.version = Moneta::VERSION
8
7
  s.date = Date.today.to_s
9
8
  s.authors = ['Daniel Mendler', 'Yehuda Katz', 'Hannes Georg', 'Alastair Pharo']
10
- s.email = %w{mail@daniel-mendler.de wycats@gmail.com hannes.georg@googlemail.com asppsa@gmail.com}
9
+ s.email = %w{mail@daniel-mendler.de wycats@gmail.com hannes.georg@googlemail.com me@asph.dev}
11
10
  s.description = 'A unified interface to key/value stores'
12
11
  s.extra_rdoc_files = %w{README.md SPEC.md LICENSE}
13
12
  s.files = `git ls-files`.split("\n")
14
13
  s.test_files = `git ls-files -- {test,spec,features}/*`.split("\n")
15
14
  s.executables = `git ls-files -- bin/*`.split("\n").map{ |f| File.basename(f) }
16
- s.homepage = 'http://github.com/moneta-rb/moneta'
15
+ s.homepage = 'https://github.com/moneta-rb/moneta'
17
16
  s.licenses = %w(MIT)
18
17
  s.require_paths = %w(lib)
19
18
  s.summary = %{A unified interface to key/value stores, including Redis, Memcached, TokyoCabinet, ActiveRecord and many more}
20
- s.required_ruby_version = '>= 2.2.2'
19
+
20
+ s.metadata = {
21
+ 'bug_tracker_uri' => 'https://github.com/moneta-rb/moneta/issues',
22
+ 'changelog_uri' => "https://github.com/moneta-rb/moneta/blob/v#{s.version}/CHANGES",
23
+ 'documentation_uri' => "https://www.rubydoc.info/gems/moneta/#{s.version}",
24
+ 'source_code_uri' => "https://github.com/moneta-rb/moneta/tree/v#{s.version}",
25
+ }
26
+
27
+ s.required_ruby_version = '>= 2.3.0'
28
+
29
+ s.add_development_dependency 'parallel_tests', '~> 2.29.2'
30
+ s.add_development_dependency 'rantly', '~> 1.2.0'
31
+ s.add_development_dependency 'rspec', '~> 3.0'
32
+ s.add_development_dependency 'rspec-retry', '~> 0.6.1'
33
+ s.add_development_dependency 'rubocop', '~> 0.81.0'
34
+ s.add_development_dependency 'timecop', '~> 0.9.1'
21
35
  end
@@ -7,6 +7,8 @@ require 'fileutils'
7
7
  require 'active_support'
8
8
  require 'active_support/cache/moneta_store'
9
9
 
10
+ require_relative '../spec/restserver.rb'
11
+
10
12
  class String
11
13
  def random(n)
12
14
  (1..n).map { self[rand(size),1] }.join
@@ -34,6 +36,9 @@ class MonetaBenchmarks
34
36
  postgres_database1 = ENV['MONETA_POSTGRES_DATABSASE1'] || 'moneta1'
35
37
  postgres_database2 = ENV['MONETA_POSTGRES_DATABSASE1'] || 'moneta2'
36
38
 
39
+ couch_login = ENV['COUCH_LOGIN'] || 'admin'
40
+ couch_password = ENV['COUCH_PASSWORD'] || 'password'
41
+
37
42
  STORES = [
38
43
  # SDBM accepts only very short key/value pairs (1k for both)
39
44
  {name: "SDBM", sizes: [:small], options: {file: "#{DIR}/sdbm"}},
@@ -104,7 +109,18 @@ class MonetaBenchmarks
104
109
  },
105
110
  {name: "Cassandra"},
106
111
  {name: "Client (Memory)", adapter: :Client},
107
- {name: "Couch"},
112
+ {
113
+ name: "Couch",
114
+ options: {
115
+ backend: if defined?(JRUBY_VERSION)
116
+ require 'faraday/adapter/manticore'
117
+ ::Faraday.new("http://127.0.0.1:5984/moneta") { |f| f.adapter :manticore }
118
+ end,
119
+ login: couch_login,
120
+ password: couch_password
121
+ },
122
+ clear_options: { compact: true, await_compact: true },
123
+ },
108
124
  {
109
125
  name: "DBM",
110
126
  options: {file: "#{DIR}/dbm"}
@@ -148,11 +164,20 @@ class MonetaBenchmarks
148
164
  {name: "MemcachedNative"}
149
165
  end,
150
166
  {name: "Memory"},
151
- {name: "MongoMoped"},
152
- {name: "MongoOfficial"},
167
+ {name: "Mongo"},
153
168
  {name: "PStore", options: { file: "#{DIR}/pstore" }},
154
169
  {name: "Redis"},
155
- {name: "RestClient", options: { url: 'http://localhost:8808/' }},
170
+ {
171
+ name: "RestClient (Memory)",
172
+ adapter: :RestClient,
173
+ options: {
174
+ url: 'http://127.0.0.1:8808/moneta',
175
+ backend: if defined?(JRUBY_VERSION)
176
+ require 'faraday/adapter/manticore'
177
+ ::Faraday.new("http://127.0.0.1:8808/moneta") { |f| f.adapter :manticore }
178
+ end
179
+ }
180
+ },
156
181
  {name: "Riak"},
157
182
  {
158
183
  name: "Sequel (MySQL)",
@@ -214,7 +239,7 @@ class MonetaBenchmarks
214
239
  },
215
240
  {name: "TDB", options: { file: "#{DIR}/tdb" }},
216
241
  {name: "TokyoCabinet", options: { file: "#{DIR}/tokyocabinet" }},
217
- {name: "TokyoTyrant"},
242
+ {name: "TokyoTyrant", options: {port: 10431}},
218
243
  ].compact
219
244
 
220
245
  CONFIGS = {
@@ -349,43 +374,44 @@ class MonetaBenchmarks
349
374
  end
350
375
 
351
376
  def start_servers
352
- parallel do
353
- begin
354
- Moneta::Server.new(Moneta.new(:Memory)).run
355
- rescue Exception => ex
356
- puts "\e[31mFailed to start Moneta server - #{ex.message}\e[0m"
377
+ @moneta_server_handle =
378
+ parallel do
379
+ begin
380
+ Moneta::Server.new(Moneta.new(:Memory)).run
381
+ rescue => ex
382
+ puts "\e[31mFailed to start Moneta server - #{ex.message}\e[0m"
383
+ end
357
384
  end
358
- end
359
385
 
360
- parallel do
361
- begin
362
- require 'rack'
363
- require 'webrick'
364
- require 'rack/moneta_rest'
386
+ @restserver_handle = start_restserver(8808)
365
387
 
366
- # Keep webrick quiet
367
- ::WEBrick::HTTPServer.class_eval do
368
- def access_log(config, req, res); end
369
- end
370
- ::WEBrick::BasicLog.class_eval do
371
- def log(level, data); end
372
- end
388
+ @tokyotyrant_handle = spawn("ttserver -port 10431 -le -log #{DIR}/tokyotyrant.log #{DIR}/tokyotyrant.tch")
373
389
 
374
- Rack::Server.start(app: Rack::Builder.app do
375
- use Rack::Lint
376
- run Rack::MonetaRest.new(store: :Memory)
377
- end,
378
- environment: :none,
379
- server: :webrick,
380
- Port: 8808)
381
- rescue Exception => ex
382
- puts "\e[31mFailed to start Rack server - #{ex.message}\e[0m"
383
- end
390
+ Signal.trap "INT" do
391
+ stop_servers
392
+ exit
384
393
  end
385
394
 
386
395
  sleep 1 # Wait for servers
387
396
  end
388
397
 
398
+ def stop_servers
399
+ if @restserver_handle
400
+ stop_restserver(@restserver_handle)
401
+ @restserver_handle = nil
402
+ end
403
+
404
+ case @moneta_server_handle
405
+ when Thread
406
+ Thread.kill @moneta_server_handle
407
+ when Integer
408
+ Process.kill "TERM", @moneta_server_handle
409
+ Process.wait @moneta_server_handle
410
+ end
411
+
412
+ Process.kill "TERM", @tokyotyrant_handle
413
+ end
414
+
389
415
  def test_stores
390
416
  @stores.select! do |spec|
391
417
  adapter = spec[:adapter] || spec[:name].to_sym
@@ -480,7 +506,7 @@ class MonetaBenchmarks
480
506
  print "%s [%#{2 * @config[:runs]}s] " % [type, state]
481
507
 
482
508
  @config[:runs].times do |run|
483
- store.clear
509
+ store.clear(spec[:clear_options] || {})
484
510
 
485
511
  @data.shuffle!
486
512
  m1 = Benchmark.measure do
@@ -571,6 +597,7 @@ class MonetaBenchmarks
571
597
  generate_data
572
598
  run_benchmarks
573
599
  print_summary
600
+ stop_servers
574
601
  FileUtils.rm_rf(DIR)
575
602
  end
576
603
  end
@@ -1,7 +1,12 @@
1
- #!/bin/sh
2
- git log --format='%aN <%aE>' |\
3
- sed -e 's/hiddenbek/Scott Wadden/g' |\
4
- sed -e 's/Asmod4n/Hendrik Beskow/' |\
5
- grep -v 'hannes.georg@xing.com\|spotapov\|yehuda-katzs-mac\|wycats ' |\
6
- sort -u | sort > CONTRIBUTORS
1
+ #!/usr/bin/env ruby
7
2
 
3
+ contributors = `git log --format='%aN <%aE>'`
4
+ .gsub(/hiddenbek/, 'Scott Wadden')
5
+ .gsub(/Asmod4n/, 'Hendrik Beskow')
6
+ .lines
7
+ .uniq
8
+ .reject { |line| line.match? /asppsa@gmail.com|hannes.georg@xing.com|spotapov|yehuda-katzs-mac|wycats / }
9
+ .sort { |str1, str2| str1.casecmp(str2) }
10
+
11
+ file = File.open('CONTRIBUTORS', 'w')
12
+ file << contributors.join
@@ -0,0 +1,27 @@
1
+ #!/bin/bash
2
+ set -e
3
+
4
+ # Copied from https://github.com/apache/couchdb-pkg/blob/master/debian/README.Debian
5
+ COUCHDB_PASSWORD=password
6
+ echo "couchdb couchdb/mode select standalone
7
+ couchdb couchdb/mode seen true
8
+ couchdb couchdb/bindaddress string 127.0.0.1
9
+ couchdb couchdb/bindaddress seen true
10
+ couchdb couchdb/adminpass password ${COUCHDB_PASSWORD}
11
+ couchdb couchdb/adminpass seen true
12
+ couchdb couchdb/adminpass_again password ${COUCHDB_PASSWORD}
13
+ couchdb couchdb/adminpass_again seen true" | sudo debconf-set-selections
14
+ DEBIAN_FRONTEND=noninteractive sudo apt-get install -y --force-yes couchdb
15
+
16
+ # Reconfigure CouchDB to use delayed commits for speed: http://guide.couchdb.org/draft/performance.html
17
+ sudo sed -i '/\[couchdb\]/a delayed_commits = true' /etc/couchdb/local.ini
18
+
19
+ # (Re)start couchdb
20
+ sudo systemctl restart couchdb
21
+
22
+ # Display some info about CouchDB
23
+ sudo systemctl status couchdb
24
+ until curl http://localhost:5984/; do
25
+ sleep 1
26
+ done
27
+
@@ -1,4 +1,5 @@
1
1
  #!/bin/sh
2
+ set -e
2
3
 
3
4
  cd $(dirname $(dirname $0))
4
5
 
@@ -7,13 +8,13 @@ mkdir -p zookeeper
7
8
  mkdir -p downloads
8
9
  root=$(pwd)
9
10
 
10
- version=$(curl -sS https://www-us.apache.org/dist/hbase/stable/ | grep -oP '(?<=hbase-)(\d+\.?)+' | head -n1)
11
+ version=$(curl -sS https://downloads.apache.org/hbase/stable/RELEASENOTES.md | grep -oP '(?<=# HBASE\s\s)(\d+\.?)+' | head -n1)
11
12
 
12
13
  echo HBase stable version is $version
13
14
 
14
15
  if [ ! -f downloads/hbase-$version-bin.tar.gz ]; then
15
16
  echo Downloading HBase ...
16
- wget -P downloads http://www-us.apache.org/dist/hbase/stable/hbase-$version-bin.tar.gz
17
+ wget -P downloads https://downloads.apache.org/hbase/stable/hbase-$version-bin.tar.gz
17
18
  fi
18
19
 
19
20
  echo Extracting HBase ...
@@ -1,18 +1,10 @@
1
1
  #!/bin/bash
2
2
 
3
- echo Starting TokyoTyrant ...
4
- /usr/sbin/ttserver -dmn -pid /tmp/ttserver.pid -log /tmp/ttserver.log -port 1978
3
+ # Install and start CouchDB
4
+ $(dirname $0)/start-couchdb
5
5
 
6
- # Reconfigure CouchDB to use delayed commits for speed: http://guide.couchdb.org/draft/performance.html
7
- sudo sed -i '/\[couchdb\]/a delayed_commits = true' /etc/couchdb/local.ini
8
- sudo service couchdb restart
9
-
10
- # Start HBase
6
+ # Install and start HBase
11
7
  $(dirname $0)/start-hbase
12
8
 
13
9
  # Waiting for servers to start
14
10
  sleep 3
15
-
16
- echo TokyoTyrant status:
17
- ps aux | grep ttserver
18
- cat /tmp/ttserver.log
@@ -2,6 +2,7 @@ require 'moneta'
2
2
  require 'active_support'
3
3
  require 'active_support/cache/moneta_store'
4
4
  require 'ostruct'
5
+ require_relative '../moneta/adapters/memcached_helper.rb'
5
6
 
6
7
  describe "cache_moneta_store" do
7
8
  before(:all) do
@@ -78,40 +79,38 @@ describe "cache_moneta_store" do
78
79
  end
79
80
 
80
81
  shared_examples :expiry do
81
- at_each_usec do
82
- it 'writes the data with expiration time' do
83
- store.write 'rabbit', white_rabbit, expires_in: 0.2.second
84
- expect(store.read('rabbit')).to eq white_rabbit
85
- sleep 0.3
86
- expect(store.read('rabbit')).to be_nil
87
- end
82
+ it 'writes the data with expiration time' do
83
+ store.write 'rabbit', white_rabbit, expires_in: 0.2.second
84
+ expect(store.read('rabbit')).to eq white_rabbit
85
+ sleep 0.3
86
+ expect(store.read('rabbit')).to be_nil
87
+ end
88
88
 
89
- it 'writes multiple values with expiration time' do
90
- store.write_multi({
91
- 'rabbit' => white_rabbit,
92
- 'irish whisky' => 'Jameson'
93
- }, expires_in: 0.2.second)
89
+ it 'writes multiple values with expiration time' do
90
+ store.write_multi({
91
+ 'rabbit' => white_rabbit,
92
+ 'irish whisky' => 'Jameson'
93
+ }, expires_in: 0.2.second)
94
94
 
95
- expect(store.read_multi('rabbit', 'irish whisky')).to eq \
96
- 'rabbit' => white_rabbit,
97
- 'irish whisky' => 'Jameson'
95
+ expect(store.read_multi('rabbit', 'irish whisky')).to eq \
96
+ 'rabbit' => white_rabbit,
97
+ 'irish whisky' => 'Jameson'
98
98
 
99
- sleep 0.3
100
- expect(store.read_multi('rabbit', 'irish whisky')).to be_empty
101
- end
99
+ sleep 0.3
100
+ expect(store.read_multi('rabbit', 'irish whisky')).to be_empty
101
+ end
102
102
 
103
- it "sets expiry on cache miss" do
104
- store.fetch('rabbit', force: true, expires_in: 0.2.second) { white_rabbit }
105
- expect(store.fetch('rabbit')).to eq white_rabbit
106
- sleep 0.3
107
- expect(store.fetch('rabbit')).to be_nil
108
- end
103
+ it "sets expiry on cache miss" do
104
+ store.fetch('rabbit', force: true, expires_in: 0.2.second) { white_rabbit }
105
+ expect(store.fetch('rabbit')).to eq white_rabbit
106
+ sleep 0.3
107
+ expect(store.fetch('rabbit')).to be_nil
108
+ end
109
109
 
110
- it 'does not set expiry on cache hit' do
111
- expect(store.fetch('rabbit', expires_in: 0.2.second) { white_rabbit }).to eq rabbit
112
- sleep 0.3
113
- expect(store.fetch('rabbit')).to eq rabbit
114
- end
110
+ it 'does not set expiry on cache hit' do
111
+ expect(store.fetch('rabbit', expires_in: 0.2.second) { white_rabbit }).to eq rabbit
112
+ sleep 0.3
113
+ expect(store.fetch('rabbit')).to eq rabbit
115
114
  end
116
115
  end
117
116
 
@@ -261,7 +260,8 @@ describe "cache_moneta_store" do
261
260
 
262
261
  describe ActiveSupport::Cache::MemCacheStore do
263
262
  let(:store){ described_class.new('127.0.0.1:11213') }
264
- start_memcached 11213
263
+
264
+ include_context :start_memcached, 11213
265
265
 
266
266
  include_examples :basic_store
267
267
  include_examples :expiry
@@ -1,21 +1,42 @@
1
1
  shared_examples :concurrent_create do
2
+ # Each thread attempts to create
2
3
  def create_thread(name)
3
4
  Thread.new do
4
5
  s = new_store
5
- 1000.times do |i|
6
- s[i.to_s].should == name if s.create(i.to_s, name, expires: false)
7
- Thread.pass if rand(100) >= 99
6
+ begin
7
+ (0...1000).map do |i|
8
+ s.create(i.to_s, name, expires: false).tap do
9
+ Thread.pass if rand(100) >= 99
10
+ end
11
+ end
12
+ ensure
13
+ s.close
8
14
  end
9
- s.close
10
15
  end
11
16
  end
12
17
 
13
18
  it 'have atomic create across multiple threads', isolate: true do
14
- a = create_thread('a')
15
- b = create_thread('b')
16
- c = create_thread('c')
17
- a.join
18
- b.join
19
- c.join
19
+ names = %w{a b c}
20
+
21
+ # Spawn threads and then group results (lists of true/false values) by
22
+ # store index (0...1000)
23
+ results = names
24
+ .map { |name| create_thread(name) }
25
+ .map(&:value)
26
+ .transpose.each_with_index
27
+ .map { |created_values, i| [i.to_s, created_values] }
28
+ .to_h
29
+
30
+ # Just a quick sanity check
31
+ expect(results.length).to eq 1000
32
+
33
+ # Ensure that for each index, one and only one created value is true
34
+ expect(results.map { |_, created_values| created_values.inject(:^) }).to all(be true)
35
+
36
+ # Check that the when a call to create returned true, that the store
37
+ # contains the correct value as a result
38
+ expect(store.slice(*results.keys).to_h).to eq(results.map do |i, values|
39
+ [i, names[values.index(true)]]
40
+ end.to_h)
20
41
  end
21
42
  end