moneta 1.0.0 → 1.1.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +5 -5
- data/.gitignore +1 -0
- data/.rspec +4 -0
- data/.travis.yml +83 -32
- data/.yardopts +6 -1
- data/CHANGES +30 -0
- data/CONTRIBUTORS +4 -0
- data/Gemfile +28 -36
- data/LICENSE +1 -1
- data/README.md +136 -67
- data/SPEC.md +70 -0
- data/feature_matrix.yaml +235 -0
- data/lib/active_support/cache/moneta_store.rb +102 -6
- data/lib/moneta.rb +9 -2
- data/lib/moneta/adapters/activerecord.rb +258 -98
- data/lib/moneta/adapters/activesupportcache.rb +133 -0
- data/lib/moneta/adapters/cassandra.rb +290 -44
- data/lib/moneta/adapters/client.rb +11 -2
- data/lib/moneta/adapters/couch.rb +179 -25
- data/lib/moneta/adapters/datamapper.rb +1 -0
- data/lib/moneta/adapters/daybreak.rb +21 -4
- data/lib/moneta/adapters/dbm.rb +7 -7
- data/lib/moneta/adapters/file.rb +11 -1
- data/lib/moneta/adapters/gdbm.rb +7 -7
- data/lib/moneta/adapters/kyotocabinet.rb +66 -1
- data/lib/moneta/adapters/leveldb.rb +27 -1
- data/lib/moneta/adapters/lmdb.rb +29 -1
- data/lib/moneta/adapters/lruhash.rb +30 -0
- data/lib/moneta/adapters/memcached/dalli.rb +50 -5
- data/lib/moneta/adapters/memcached/native.rb +11 -4
- data/lib/moneta/adapters/memory.rb +2 -0
- data/lib/moneta/adapters/mongo/base.rb +32 -7
- data/lib/moneta/adapters/mongo/moped.rb +59 -2
- data/lib/moneta/adapters/mongo/official.rb +40 -0
- data/lib/moneta/adapters/pstore.rb +56 -8
- data/lib/moneta/adapters/redis.rb +79 -19
- data/lib/moneta/adapters/sdbm.rb +7 -7
- data/lib/moneta/adapters/sequel.rb +440 -39
- data/lib/moneta/adapters/sqlite.rb +74 -10
- data/lib/moneta/adapters/tdb.rb +16 -1
- data/lib/moneta/adapters/tokyocabinet.rb +7 -1
- data/lib/moneta/adapters/tokyotyrant.rb +22 -0
- data/lib/moneta/cache.rb +11 -1
- data/lib/moneta/expires.rb +110 -8
- data/lib/moneta/lock.rb +21 -2
- data/lib/moneta/mixins.rb +279 -3
- data/lib/moneta/pool.rb +15 -6
- data/lib/moneta/proxy.rb +46 -2
- data/lib/moneta/server.rb +5 -1
- data/lib/moneta/shared.rb +27 -11
- data/lib/moneta/stack.rb +1 -1
- data/lib/moneta/synchronize.rb +2 -8
- data/lib/moneta/transformer.rb +152 -2
- data/lib/moneta/transformer/config.rb +2 -0
- data/lib/moneta/transformer/helper.rb +2 -2
- data/lib/moneta/version.rb +1 -1
- data/lib/moneta/weak_each_key.rb +74 -0
- data/lib/moneta/wrapper.rb +25 -0
- data/moneta.gemspec +2 -2
- data/script/benchmarks +174 -62
- data/script/parallel-tests +58 -83
- data/script/start-hbase +46 -0
- data/script/start-services +9 -2
- data/script/update-feature-matrix +148 -0
- data/spec/active_support/cache_moneta_store_spec.rb +132 -109
- data/spec/features/concurrent_create.rb +21 -0
- data/spec/features/concurrent_increment.rb +32 -0
- data/spec/features/create.rb +25 -0
- data/spec/features/create_expires.rb +19 -0
- data/spec/features/default_expires.rb +15 -0
- data/spec/features/each_key.rb +119 -0
- data/spec/features/expires.rb +291 -0
- data/spec/features/features.rb +16 -0
- data/spec/features/increment.rb +98 -0
- data/spec/features/marshallable_key.rb +43 -0
- data/spec/features/marshallable_value.rb +7 -0
- data/spec/features/multiprocess.rb +8 -0
- data/spec/features/not_create.rb +7 -0
- data/spec/features/not_each_key.rb +7 -0
- data/spec/features/not_increment.rb +13 -0
- data/spec/features/not_persist.rb +9 -0
- data/spec/features/null.rb +66 -0
- data/spec/features/persist.rb +14 -0
- data/spec/features/returndifferent.rb +9 -0
- data/spec/features/returnsame.rb +9 -0
- data/spec/features/store.rb +261 -0
- data/spec/features/store_large.rb +13 -0
- data/spec/features/transform_value.rb +44 -0
- data/spec/features/transform_value_expires.rb +41 -0
- data/spec/helper.rb +391 -74
- data/spec/moneta/adapters/activerecord/adapter_activerecord_existing_connection_spec.rb +59 -0
- data/spec/moneta/adapters/activerecord/adapter_activerecord_spec.rb +118 -0
- data/spec/moneta/adapters/activerecord/standard_activerecord_spec.rb +18 -0
- data/spec/moneta/adapters/activerecord/standard_activerecord_with_expires_spec.rb +24 -0
- data/spec/moneta/adapters/activesupportcache/adapter_activesupportcache_spec.rb +51 -0
- data/spec/moneta/adapters/activesupportcache/adapter_activesupportcache_with_default_expires_spec.rb +51 -0
- data/spec/moneta/adapters/cassandra/adapter_cassandra_spec.rb +17 -0
- data/spec/moneta/adapters/cassandra/adapter_cassandra_with_default_expires_spec.rb +18 -0
- data/spec/moneta/adapters/cassandra/helper.rb +18 -0
- data/spec/moneta/adapters/cassandra/standard_cassandra_spec.rb +18 -0
- data/spec/moneta/adapters/client/adapter_client_spec.rb +11 -0
- data/spec/moneta/adapters/client/standard_client_tcp_spec.rb +23 -0
- data/spec/moneta/adapters/client/standard_client_unix_spec.rb +12 -0
- data/spec/moneta/adapters/cookie/adapter_cookie_spec.rb +7 -0
- data/spec/moneta/adapters/couch/adapter_couch_spec.rb +7 -0
- data/spec/moneta/adapters/couch/standard_couch_spec.rb +9 -0
- data/spec/moneta/adapters/couch/standard_couch_with_expires_spec.rb +13 -0
- data/spec/moneta/adapters/datamapper/adapter_datamapper_spec.rb +43 -0
- data/spec/moneta/adapters/datamapper/standard_datamapper_spec.rb +21 -0
- data/spec/moneta/adapters/datamapper/standard_datamapper_with_expires_spec.rb +26 -0
- data/spec/moneta/adapters/datamapper/standard_datamapper_with_repository_spec.rb +22 -0
- data/spec/moneta/adapters/daybreak/adapter_daybreak_spec.rb +7 -0
- data/spec/moneta/adapters/daybreak/standard_daybreak_spec.rb +7 -0
- data/spec/moneta/adapters/daybreak/standard_daybreak_with_expires_spec.rb +11 -0
- data/spec/moneta/adapters/dbm/adapter_dbm_spec.rb +7 -0
- data/spec/moneta/adapters/dbm/standard_dbm_spec.rb +7 -0
- data/spec/moneta/adapters/dbm/standard_dbm_with_expires_spec.rb +12 -0
- data/spec/moneta/adapters/file/adapter_file_spec.rb +7 -0
- data/spec/moneta/adapters/file/standard_file_spec.rb +7 -0
- data/spec/moneta/adapters/file/standard_file_with_expires_spec.rb +11 -0
- data/spec/moneta/adapters/fog/adapter_fog_spec.rb +16 -0
- data/spec/moneta/adapters/fog/standard_fog_spec.rb +15 -0
- data/spec/moneta/adapters/fog/standard_fog_with_expires_spec.rb +20 -0
- data/spec/moneta/adapters/gdbm/adapter_gdbm_spec.rb +7 -0
- data/spec/moneta/adapters/gdbm/standard_gdbm_spec.rb +7 -0
- data/spec/moneta/adapters/gdbm/standard_gdbm_with_expires_spec.rb +11 -0
- data/spec/moneta/adapters/hashfile/standard_hashfile_spec.rb +7 -0
- data/spec/moneta/adapters/hashfile/standard_hashfile_with_expires_spec.rb +12 -0
- data/spec/moneta/adapters/hbase/adapter_hbase_spec.rb +7 -0
- data/spec/moneta/adapters/hbase/standard_hbase_spec.rb +4 -0
- data/spec/moneta/adapters/hbase/standard_hbase_with_expires_spec.rb +8 -0
- data/spec/moneta/adapters/kyotocabinet/adapter_kyotocabinet_spec.rb +7 -0
- data/spec/moneta/adapters/kyotocabinet/standard_kyotocabinet_spec.rb +7 -0
- data/spec/moneta/adapters/kyotocabinet/standard_kyotocabinet_with_expires_spec.rb +14 -0
- data/spec/moneta/adapters/leveldb/adapter_leveldb_spec.rb +7 -0
- data/spec/moneta/adapters/leveldb/standard_leveldb_spec.rb +7 -0
- data/spec/moneta/adapters/leveldb/standard_leveldb_with_expires_spec.rb +11 -0
- data/spec/moneta/adapters/lmdb/adapter_lmdb_spec.rb +7 -0
- data/spec/moneta/adapters/lmdb/adapter_lmdb_with_db_spec.rb +7 -0
- data/spec/moneta/adapters/lmdb/standard_lmdb_spec.rb +7 -0
- data/spec/moneta/adapters/lmdb/standard_lmdb_with_expires_spec.rb +11 -0
- data/spec/moneta/adapters/localmemcache/adapter_localmemcache_spec.rb +7 -0
- data/spec/moneta/adapters/localmemcache/standard_localmemcache_spec.rb +7 -0
- data/spec/moneta/adapters/localmemcache/standard_localmemcache_with_expires_spec.rb +11 -0
- data/spec/moneta/{adapter_lruhash_spec.rb → adapters/lruhash/adapter_lruhash_spec.rb} +3 -25
- data/spec/moneta/adapters/lruhash/standard_lruhash_spec.rb +4 -0
- data/spec/moneta/adapters/lruhash/standard_lruhash_with_expires_spec.rb +8 -0
- data/spec/moneta/adapters/memcached/adapter_memcached_spec.rb +13 -0
- data/spec/moneta/adapters/memcached/dalli/adapter_memcached_dalli_spec.rb +15 -0
- data/spec/moneta/adapters/memcached/dalli/adapter_memcached_dalli_with_default_expires_spec.rb +15 -0
- data/spec/moneta/adapters/memcached/dalli/standard_memcached_dalli_spec.rb +11 -0
- data/spec/moneta/adapters/memcached/helper.rb +20 -0
- data/spec/moneta/adapters/memcached/native/adapter_memcached_native_spec.rb +15 -0
- data/spec/moneta/adapters/memcached/native/adapter_memcached_native_with_default_expires_spec.rb +15 -0
- data/spec/moneta/adapters/memcached/native/standard_memcached_native_spec.rb +11 -0
- data/spec/moneta/adapters/memcached/standard_memcached_spec.rb +17 -0
- data/spec/moneta/adapters/memory/adapter_memory_spec.rb +7 -0
- data/spec/moneta/adapters/memory/standard_memory_spec.rb +4 -0
- data/spec/moneta/adapters/memory/standard_memory_with_compress_spec.rb +9 -0
- data/spec/moneta/adapters/memory/standard_memory_with_expires_spec.rb +8 -0
- data/spec/moneta/adapters/memory/standard_memory_with_json_key_serializer_spec.rb +4 -0
- data/spec/moneta/adapters/memory/standard_memory_with_json_serializer_spec.rb +9 -0
- data/spec/moneta/adapters/memory/standard_memory_with_json_value_serializer_spec.rb +9 -0
- data/spec/moneta/adapters/memory/standard_memory_with_prefix_spec.rb +4 -0
- data/spec/moneta/adapters/memory/standard_memory_with_snappy_compress_spec.rb +9 -0
- data/spec/moneta/adapters/mongo/adapter_mongo_moped_spec.rb +25 -0
- data/spec/moneta/adapters/mongo/adapter_mongo_moped_with_default_expires_spec.rb +12 -0
- data/spec/moneta/adapters/mongo/adapter_mongo_official_spec.rb +25 -0
- data/spec/moneta/adapters/mongo/adapter_mongo_official_with_default_expires_spec.rb +12 -0
- data/spec/moneta/adapters/mongo/adapter_mongo_spec.rb +11 -0
- data/spec/moneta/adapters/mongo/adapter_mongo_with_default_expires_spec.rb +12 -0
- data/spec/moneta/adapters/mongo/standard_mongo_moped_spec.rb +7 -0
- data/spec/moneta/adapters/mongo/standard_mongo_official_spec.rb +7 -0
- data/spec/moneta/adapters/mongo/standard_mongo_spec.rb +7 -0
- data/spec/moneta/adapters/null/null_adapter_spec.rb +7 -0
- data/spec/moneta/adapters/null/standard_null_spec.rb +4 -0
- data/spec/moneta/adapters/pstore/adapter_pstore_spec.rb +7 -0
- data/spec/moneta/adapters/pstore/standard_pstore_spec.rb +9 -0
- data/spec/moneta/adapters/pstore/standard_pstore_with_expires_spec.rb +13 -0
- data/spec/moneta/adapters/redis/adapter_redis_spec.rb +10 -0
- data/spec/moneta/adapters/redis/adapter_redis_with_default_expires_spec.rb +10 -0
- data/spec/moneta/adapters/redis/standard_redis_spec.rb +7 -0
- data/spec/moneta/adapters/restclient/adapter_restclient_spec.rb +11 -0
- data/spec/moneta/adapters/restclient/standard_restclient_spec.rb +10 -0
- data/spec/moneta/adapters/riak/adapter_riak_spec.rb +14 -0
- data/spec/moneta/adapters/riak/standard_riak_spec.rb +10 -0
- data/spec/moneta/adapters/riak/standard_riak_with_expires_spec.rb +10 -0
- data/spec/moneta/adapters/sdbm/adapter_sdbm_spec.rb +7 -0
- data/spec/moneta/adapters/sdbm/standard_sdbm_spec.rb +7 -0
- data/spec/moneta/adapters/sdbm/standard_sdbm_with_expires_spec.rb +11 -0
- data/spec/moneta/adapters/sequel/adapter_sequel_spec.rb +181 -0
- data/spec/moneta/adapters/sequel/standard_sequel_spec.rb +14 -0
- data/spec/moneta/adapters/sequel/standard_sequel_with_expires_spec.rb +19 -0
- data/spec/moneta/adapters/sqlite/adapter_sqlite_spec.rb +7 -0
- data/spec/moneta/adapters/sqlite/standard_sqlite_spec.rb +7 -0
- data/spec/moneta/adapters/sqlite/standard_sqlite_with_expires_spec.rb +15 -0
- data/spec/moneta/adapters/tdb/adapter_tdb_spec.rb +7 -0
- data/spec/moneta/adapters/tdb/standard_tdb_spec.rb +7 -0
- data/spec/moneta/adapters/tdb/standard_tdb_with_expires_spec.rb +11 -0
- data/spec/moneta/adapters/tokyocabinet/adapter_tokyocabinet_bdb_spec.rb +7 -0
- data/spec/moneta/adapters/tokyocabinet/adapter_tokyocabinet_hdb_spec.rb +7 -0
- data/spec/moneta/adapters/tokyocabinet/standard_tokyocabinet_spec.rb +7 -0
- data/spec/moneta/adapters/tokyocabinet/standard_tokyocabinet_with_expires_spec.rb +11 -0
- data/spec/moneta/adapters/tokyotyrant/adapter_tokyotyrant_spec.rb +7 -0
- data/spec/moneta/adapters/tokyotyrant/standard_tokyotyrant_spec.rb +4 -0
- data/spec/moneta/adapters/tokyotyrant/standard_tokyotyrant_with_expires_spec.rb +8 -0
- data/spec/moneta/adapters/yaml/adapter_yaml_spec.rb +7 -0
- data/spec/moneta/adapters/yaml/standard_yaml_spec.rb +9 -0
- data/spec/moneta/adapters/yaml/standard_yaml_with_expires_spec.rb +13 -0
- data/spec/moneta/builder_spec.rb +0 -1
- data/spec/moneta/mutex_spec.rb +6 -23
- data/spec/moneta/proxies/cache/cache_file_memory_spec.rb +24 -0
- data/spec/moneta/proxies/cache/cache_memory_null_spec.rb +12 -0
- data/spec/moneta/proxies/expires/expires_file_spec.rb +28 -0
- data/spec/moneta/proxies/expires/expires_memory_spec.rb +15 -0
- data/spec/moneta/proxies/expires/expires_memory_with_default_expires_spec.rb +16 -0
- data/spec/moneta/proxies/lock/lock_spec.rb +10 -0
- data/spec/moneta/{optionmerger_spec.rb → proxies/optionmerger/optionmerger_spec.rb} +2 -18
- data/spec/moneta/proxies/pool/pool_spec.rb +12 -0
- data/spec/moneta/proxies/proxy/proxy_expires_memory_spec.rb +16 -0
- data/spec/moneta/proxies/proxy/proxy_redis_spec.rb +13 -0
- data/spec/moneta/proxies/shared/shared_tcp_spec.rb +49 -0
- data/spec/moneta/proxies/shared/shared_unix_spec.rb +48 -0
- data/spec/moneta/proxies/transformer/transformer_bencode_spec.rb +19 -0
- data/spec/moneta/proxies/transformer/transformer_bert_spec.rb +19 -0
- data/spec/moneta/proxies/transformer/transformer_bson_spec.rb +23 -0
- data/spec/moneta/proxies/transformer/transformer_bzip2_spec.rb +19 -0
- data/spec/moneta/proxies/transformer/transformer_json_spec.rb +19 -0
- data/spec/moneta/proxies/transformer/transformer_key_inspect_spec.rb +17 -0
- data/spec/moneta/proxies/transformer/transformer_key_marshal_spec.rb +17 -0
- data/spec/moneta/proxies/transformer/transformer_key_to_s_spec.rb +17 -0
- data/spec/moneta/proxies/transformer/transformer_key_yaml_spec.rb +17 -0
- data/spec/moneta/proxies/transformer/transformer_lz4_spec.rb +19 -0
- data/spec/moneta/proxies/transformer/transformer_lzma_spec.rb +19 -0
- data/spec/moneta/proxies/transformer/transformer_lzo_spec.rb +19 -0
- data/spec/moneta/proxies/transformer/transformer_marshal_base64_spec.rb +20 -0
- data/spec/moneta/proxies/transformer/transformer_marshal_city128_spec.rb +15 -0
- data/spec/moneta/proxies/transformer/transformer_marshal_city32_spec.rb +15 -0
- data/spec/moneta/proxies/transformer/transformer_marshal_city64_spec.rb +15 -0
- data/spec/moneta/proxies/transformer/transformer_marshal_escape_spec.rb +15 -0
- data/spec/moneta/proxies/transformer/transformer_marshal_hex_spec.rb +20 -0
- data/spec/moneta/proxies/transformer/transformer_marshal_hmac_spec.rb +19 -0
- data/spec/moneta/proxies/transformer/transformer_marshal_md5_spec.rb +15 -0
- data/spec/moneta/proxies/transformer/transformer_marshal_md5_spread_spec.rb +15 -0
- data/spec/moneta/proxies/transformer/transformer_marshal_prefix_spec.rb +15 -0
- data/spec/moneta/proxies/transformer/transformer_marshal_qp_spec.rb +20 -0
- data/spec/moneta/proxies/transformer/transformer_marshal_rmd160_spec.rb +15 -0
- data/spec/moneta/proxies/transformer/transformer_marshal_sha1_spec.rb +15 -0
- data/spec/moneta/proxies/transformer/transformer_marshal_sha256_spec.rb +15 -0
- data/spec/moneta/proxies/transformer/transformer_marshal_sha384_spec.rb +15 -0
- data/spec/moneta/proxies/transformer/transformer_marshal_sha512_spec.rb +15 -0
- data/spec/moneta/proxies/transformer/transformer_marshal_spec.rb +19 -0
- data/spec/moneta/proxies/transformer/transformer_marshal_truncate_spec.rb +15 -0
- data/spec/moneta/proxies/transformer/transformer_marshal_urlsafe_base64_spec.rb +20 -0
- data/spec/moneta/proxies/transformer/transformer_marshal_uuencode_spec.rb +19 -0
- data/spec/moneta/proxies/transformer/transformer_msgpack_spec.rb +19 -0
- data/spec/moneta/proxies/transformer/transformer_ox_spec.rb +19 -0
- data/spec/moneta/proxies/transformer/transformer_php_spec.rb +19 -0
- data/spec/moneta/proxies/transformer/transformer_quicklz_spec.rb +19 -0
- data/spec/moneta/proxies/transformer/transformer_snappy_spec.rb +19 -0
- data/spec/moneta/proxies/transformer/transformer_tnet_spec.rb +19 -0
- data/spec/moneta/proxies/transformer/transformer_value_marshal_spec.rb +19 -0
- data/spec/moneta/proxies/transformer/transformer_value_yaml_spec.rb +19 -0
- data/spec/moneta/proxies/transformer/transformer_yaml_spec.rb +19 -0
- data/spec/moneta/proxies/transformer/transformer_zlib_spec.rb +19 -0
- data/spec/moneta/proxies/weak_create/weak_create_spec.rb +21 -0
- data/spec/moneta/proxies/weak_each_key/weak_each_key_spec.rb +24 -0
- data/spec/moneta/proxies/weak_increment/weak_increment_spec.rb +21 -0
- data/spec/moneta/semaphore_spec.rb +6 -23
- data/spec/moneta/stack_file_memory_spec.rb +5 -29
- data/spec/moneta/stack_memory_file_spec.rb +5 -31
- data/spec/quality_spec.rb +1 -1
- data/{spec → test}/action_dispatch/fixtures/session_autoload_test/foo.rb +0 -0
- data/{spec/action_dispatch/session_moneta_store_spec.rb → test/action_dispatch/session_moneta_store_test.rb} +13 -5
- metadata +415 -355
- data/script/generate-specs +0 -2696
- data/spec/moneta/adapter_activerecord_exisiting_connection_spec.rb +0 -36
- data/spec/moneta/adapter_activerecord_spec.rb +0 -65
- data/spec/moneta/adapter_cassandra_spec.rb +0 -33
- data/spec/moneta/adapter_cassandra_with_default_expires_spec.rb +0 -34
- data/spec/moneta/adapter_client_spec.rb +0 -35
- data/spec/moneta/adapter_cookie_spec.rb +0 -30
- data/spec/moneta/adapter_couch_spec.rb +0 -36
- data/spec/moneta/adapter_datamapper_spec.rb +0 -64
- data/spec/moneta/adapter_daybreak_spec.rb +0 -31
- data/spec/moneta/adapter_dbm_spec.rb +0 -31
- data/spec/moneta/adapter_file_spec.rb +0 -34
- data/spec/moneta/adapter_fog_spec.rb +0 -37
- data/spec/moneta/adapter_gdbm_spec.rb +0 -31
- data/spec/moneta/adapter_hbase_spec.rb +0 -33
- data/spec/moneta/adapter_kyotocabinet_spec.rb +0 -31
- data/spec/moneta/adapter_leveldb_spec.rb +0 -31
- data/spec/moneta/adapter_lmdb_spec.rb +0 -32
- data/spec/moneta/adapter_lmdb_with_db_spec.rb +0 -32
- data/spec/moneta/adapter_localmemcache_spec.rb +0 -32
- data/spec/moneta/adapter_memcached_dalli_spec.rb +0 -36
- data/spec/moneta/adapter_memcached_dalli_with_default_expires_spec.rb +0 -37
- data/spec/moneta/adapter_memcached_native_spec.rb +0 -36
- data/spec/moneta/adapter_memcached_native_with_default_expires_spec.rb +0 -37
- data/spec/moneta/adapter_memcached_spec.rb +0 -36
- data/spec/moneta/adapter_memcached_with_default_expires_spec.rb +0 -37
- data/spec/moneta/adapter_memory_spec.rb +0 -184
- data/spec/moneta/adapter_mongo_moped_spec.rb +0 -64
- data/spec/moneta/adapter_mongo_moped_with_default_expires_spec.rb +0 -53
- data/spec/moneta/adapter_mongo_official_spec.rb +0 -64
- data/spec/moneta/adapter_mongo_official_with_default_expires_spec.rb +0 -53
- data/spec/moneta/adapter_mongo_spec.rb +0 -51
- data/spec/moneta/adapter_mongo_with_default_expires_spec.rb +0 -53
- data/spec/moneta/adapter_pstore_spec.rb +0 -250
- data/spec/moneta/adapter_redis_spec.rb +0 -36
- data/spec/moneta/adapter_redis_with_default_expires_spec.rb +0 -37
- data/spec/moneta/adapter_restclient_spec.rb +0 -33
- data/spec/moneta/adapter_riak_spec.rb +0 -36
- data/spec/moneta/adapter_sdbm_spec.rb +0 -30
- data/spec/moneta/adapter_sequel_spec.rb +0 -34
- data/spec/moneta/adapter_sqlite_spec.rb +0 -32
- data/spec/moneta/adapter_tdb_spec.rb +0 -31
- data/spec/moneta/adapter_tokyocabinet_bdb_spec.rb +0 -31
- data/spec/moneta/adapter_tokyocabinet_hdb_spec.rb +0 -31
- data/spec/moneta/adapter_tokyotyrant_spec.rb +0 -34
- data/spec/moneta/adapter_yaml_spec.rb +0 -57
- data/spec/moneta/cache_file_memory_spec.rb +0 -50
- data/spec/moneta/cache_memory_null_spec.rb +0 -35
- data/spec/moneta/expires_file_spec.rb +0 -78
- data/spec/moneta/expires_memory_spec.rb +0 -189
- data/spec/moneta/expires_memory_with_default_expires_spec.rb +0 -190
- data/spec/moneta/lock_spec.rb +0 -187
- data/spec/moneta/null_adapter_spec.rb +0 -86
- data/spec/moneta/pool_spec.rb +0 -38
- data/spec/moneta/proxy_expires_memory_spec.rb +0 -191
- data/spec/moneta/proxy_redis_spec.rb +0 -40
- data/spec/moneta/shared_tcp_spec.rb +0 -46
- data/spec/moneta/shared_unix_spec.rb +0 -46
- data/spec/moneta/standard_activerecord_spec.rb +0 -253
- data/spec/moneta/standard_activerecord_with_expires_spec.rb +0 -255
- data/spec/moneta/standard_cassandra_spec.rb +0 -252
- data/spec/moneta/standard_client_tcp_spec.rb +0 -269
- data/spec/moneta/standard_client_unix_spec.rb +0 -254
- data/spec/moneta/standard_couch_spec.rb +0 -252
- data/spec/moneta/standard_couch_with_expires_spec.rb +0 -254
- data/spec/moneta/standard_datamapper_spec.rb +0 -254
- data/spec/moneta/standard_datamapper_with_expires_spec.rb +0 -256
- data/spec/moneta/standard_datamapper_with_repository_spec.rb +0 -254
- data/spec/moneta/standard_daybreak_spec.rb +0 -250
- data/spec/moneta/standard_daybreak_with_expires_spec.rb +0 -252
- data/spec/moneta/standard_dbm_spec.rb +0 -250
- data/spec/moneta/standard_dbm_with_expires_spec.rb +0 -252
- data/spec/moneta/standard_file_spec.rb +0 -253
- data/spec/moneta/standard_file_with_expires_spec.rb +0 -255
- data/spec/moneta/standard_fog_spec.rb +0 -256
- data/spec/moneta/standard_fog_with_expires_spec.rb +0 -258
- data/spec/moneta/standard_gdbm_spec.rb +0 -250
- data/spec/moneta/standard_gdbm_with_expires_spec.rb +0 -252
- data/spec/moneta/standard_hashfile_spec.rb +0 -253
- data/spec/moneta/standard_hashfile_with_expires_spec.rb +0 -255
- data/spec/moneta/standard_hbase_spec.rb +0 -252
- data/spec/moneta/standard_hbase_with_expires_spec.rb +0 -255
- data/spec/moneta/standard_kyotocabinet_spec.rb +0 -250
- data/spec/moneta/standard_kyotocabinet_with_expires_spec.rb +0 -252
- data/spec/moneta/standard_leveldb_spec.rb +0 -250
- data/spec/moneta/standard_leveldb_with_expires_spec.rb +0 -252
- data/spec/moneta/standard_lmdb_spec.rb +0 -251
- data/spec/moneta/standard_lmdb_with_expires_spec.rb +0 -253
- data/spec/moneta/standard_localmemcache_spec.rb +0 -251
- data/spec/moneta/standard_localmemcache_with_expires_spec.rb +0 -252
- data/spec/moneta/standard_lruhash_spec.rb +0 -187
- data/spec/moneta/standard_lruhash_with_expires_spec.rb +0 -189
- data/spec/moneta/standard_memcached_dalli_spec.rb +0 -255
- data/spec/moneta/standard_memcached_native_spec.rb +0 -255
- data/spec/moneta/standard_memcached_spec.rb +0 -255
- data/spec/moneta/standard_memory_spec.rb +0 -187
- data/spec/moneta/standard_memory_with_compress_spec.rb +0 -187
- data/spec/moneta/standard_memory_with_expires_spec.rb +0 -189
- data/spec/moneta/standard_memory_with_json_key_serializer_spec.rb +0 -86
- data/spec/moneta/standard_memory_with_json_serializer_spec.rb +0 -49
- data/spec/moneta/standard_memory_with_json_value_serializer_spec.rb +0 -90
- data/spec/moneta/standard_memory_with_prefix_spec.rb +0 -187
- data/spec/moneta/standard_memory_with_snappy_compress_spec.rb +0 -187
- data/spec/moneta/standard_mongo_moped_spec.rb +0 -255
- data/spec/moneta/standard_mongo_official_spec.rb +0 -255
- data/spec/moneta/standard_mongo_spec.rb +0 -255
- data/spec/moneta/standard_null_spec.rb +0 -120
- data/spec/moneta/standard_pstore_spec.rb +0 -253
- data/spec/moneta/standard_pstore_with_expires_spec.rb +0 -255
- data/spec/moneta/standard_redis_spec.rb +0 -255
- data/spec/moneta/standard_restclient_spec.rb +0 -252
- data/spec/moneta/standard_riak_spec.rb +0 -255
- data/spec/moneta/standard_riak_with_expires_spec.rb +0 -256
- data/spec/moneta/standard_sdbm_spec.rb +0 -249
- data/spec/moneta/standard_sdbm_with_expires_spec.rb +0 -251
- data/spec/moneta/standard_sequel_spec.rb +0 -253
- data/spec/moneta/standard_sequel_with_expires_spec.rb +0 -255
- data/spec/moneta/standard_sqlite_spec.rb +0 -251
- data/spec/moneta/standard_sqlite_with_expires_spec.rb +0 -253
- data/spec/moneta/standard_tdb_spec.rb +0 -250
- data/spec/moneta/standard_tdb_with_expires_spec.rb +0 -252
- data/spec/moneta/standard_tokyocabinet_spec.rb +0 -250
- data/spec/moneta/standard_tokyocabinet_with_expires_spec.rb +0 -252
- data/spec/moneta/standard_tokyotyrant_spec.rb +0 -253
- data/spec/moneta/standard_tokyotyrant_with_expires_spec.rb +0 -255
- data/spec/moneta/standard_yaml_spec.rb +0 -250
- data/spec/moneta/standard_yaml_with_expires_spec.rb +0 -252
- data/spec/moneta/transformer_bencode_spec.rb +0 -55
- data/spec/moneta/transformer_bert_spec.rb +0 -55
- data/spec/moneta/transformer_bson_spec.rb +0 -60
- data/spec/moneta/transformer_bzip2_spec.rb +0 -55
- data/spec/moneta/transformer_json_spec.rb +0 -55
- data/spec/moneta/transformer_key_inspect_spec.rb +0 -91
- data/spec/moneta/transformer_key_marshal_spec.rb +0 -191
- data/spec/moneta/transformer_key_to_s_spec.rb +0 -91
- data/spec/moneta/transformer_key_yaml_spec.rb +0 -191
- data/spec/moneta/transformer_lz4_spec.rb +0 -55
- data/spec/moneta/transformer_lzma_spec.rb +0 -55
- data/spec/moneta/transformer_lzo_spec.rb +0 -55
- data/spec/moneta/transformer_marshal_base64_spec.rb +0 -194
- data/spec/moneta/transformer_marshal_city128_spec.rb +0 -194
- data/spec/moneta/transformer_marshal_city32_spec.rb +0 -194
- data/spec/moneta/transformer_marshal_city64_spec.rb +0 -194
- data/spec/moneta/transformer_marshal_escape_spec.rb +0 -194
- data/spec/moneta/transformer_marshal_hex_spec.rb +0 -194
- data/spec/moneta/transformer_marshal_hmac_spec.rb +0 -194
- data/spec/moneta/transformer_marshal_md5_spec.rb +0 -194
- data/spec/moneta/transformer_marshal_md5_spread_spec.rb +0 -194
- data/spec/moneta/transformer_marshal_prefix_spec.rb +0 -194
- data/spec/moneta/transformer_marshal_qp_spec.rb +0 -194
- data/spec/moneta/transformer_marshal_rmd160_spec.rb +0 -194
- data/spec/moneta/transformer_marshal_sha1_spec.rb +0 -194
- data/spec/moneta/transformer_marshal_sha256_spec.rb +0 -194
- data/spec/moneta/transformer_marshal_sha384_spec.rb +0 -194
- data/spec/moneta/transformer_marshal_sha512_spec.rb +0 -194
- data/spec/moneta/transformer_marshal_spec.rb +0 -191
- data/spec/moneta/transformer_marshal_truncate_spec.rb +0 -194
- data/spec/moneta/transformer_marshal_uuencode_spec.rb +0 -194
- data/spec/moneta/transformer_msgpack_spec.rb +0 -55
- data/spec/moneta/transformer_ox_spec.rb +0 -191
- data/spec/moneta/transformer_php_spec.rb +0 -55
- data/spec/moneta/transformer_quicklz_spec.rb +0 -55
- data/spec/moneta/transformer_snappy_spec.rb +0 -55
- data/spec/moneta/transformer_tnet_spec.rb +0 -55
- data/spec/moneta/transformer_value_marshal_spec.rb +0 -191
- data/spec/moneta/transformer_value_yaml_spec.rb +0 -191
- data/spec/moneta/transformer_yaml_spec.rb +0 -191
- data/spec/moneta/transformer_zlib_spec.rb +0 -55
- data/spec/moneta/weak_create_spec.rb +0 -41
- data/spec/moneta/weak_increment_spec.rb +0 -41
- data/spec/monetaspecs.rb +0 -51267
@@ -4,7 +4,13 @@ module Moneta
|
|
4
4
|
module Adapters
|
5
5
|
# LevelDB backend
|
6
6
|
# @api public
|
7
|
-
class LevelDB
|
7
|
+
class LevelDB
|
8
|
+
include Defaults
|
9
|
+
include HashAdapter
|
10
|
+
include IncrementSupport
|
11
|
+
include CreateSupport
|
12
|
+
include EachKeySupport
|
13
|
+
|
8
14
|
# @param [Hash] options
|
9
15
|
# @option options [String] :dir - Database path
|
10
16
|
# @option options All other options passed to `LevelDB::DB#new`
|
@@ -33,6 +39,26 @@ module Moneta
|
|
33
39
|
@backend.close
|
34
40
|
nil
|
35
41
|
end
|
42
|
+
|
43
|
+
# (see Proxy#each_key)
|
44
|
+
def each_key
|
45
|
+
return enum_for(:each_key) { @backend.size } unless block_given?
|
46
|
+
@backend.each { |key, _| yield key }
|
47
|
+
self
|
48
|
+
end
|
49
|
+
|
50
|
+
# (see Proxy#values_at)
|
51
|
+
def values_at(*keys, **options)
|
52
|
+
ret = nil
|
53
|
+
@backend.batch { ret = super }
|
54
|
+
ret
|
55
|
+
end
|
56
|
+
|
57
|
+
# (see Proxy#merge!)
|
58
|
+
def merge!(*keys, **options)
|
59
|
+
@backend.batch { super }
|
60
|
+
self
|
61
|
+
end
|
36
62
|
end
|
37
63
|
end
|
38
64
|
end
|
data/lib/moneta/adapters/lmdb.rb
CHANGED
@@ -8,7 +8,7 @@ module Moneta
|
|
8
8
|
class LMDB
|
9
9
|
include Defaults
|
10
10
|
|
11
|
-
supports :create, :increment
|
11
|
+
supports :create, :increment, :each_key
|
12
12
|
attr_reader :backend, :db
|
13
13
|
|
14
14
|
PUT_FLAGS = [:nooverwrite, :nodupdata, :current, :append, :appenddup]
|
@@ -88,6 +88,34 @@ module Moneta
|
|
88
88
|
@backend.close
|
89
89
|
nil
|
90
90
|
end
|
91
|
+
|
92
|
+
# (see Proxy#each_key)
|
93
|
+
def each_key
|
94
|
+
return enum_for(:each_key) { @db.size } unless block_given?
|
95
|
+
|
96
|
+
@db.cursor do |cursor|
|
97
|
+
while record = cursor.next
|
98
|
+
yield record[0]
|
99
|
+
end
|
100
|
+
end
|
101
|
+
|
102
|
+
self
|
103
|
+
end
|
104
|
+
|
105
|
+
# (see Proxy#values_at)
|
106
|
+
def values_at(*keys, **options)
|
107
|
+
@backend.transaction { super }
|
108
|
+
end
|
109
|
+
|
110
|
+
# (see Proxy#slice)
|
111
|
+
def slice(*keys, **options)
|
112
|
+
@backend.transaction { super }
|
113
|
+
end
|
114
|
+
|
115
|
+
# (see Proxy#merge!)
|
116
|
+
def merge!(pairs, options = {})
|
117
|
+
@backend.transaction { super }
|
118
|
+
end
|
91
119
|
end
|
92
120
|
end
|
93
121
|
end
|
@@ -13,6 +13,8 @@ module Moneta
|
|
13
13
|
DEFAULT_MAX_SIZE = 1024000
|
14
14
|
DEFAULT_MAX_COUNT = 10240
|
15
15
|
|
16
|
+
supports :each_key
|
17
|
+
|
16
18
|
# @param [Hash] options
|
17
19
|
# @option options [Integer] :max_size (1024000) Maximum byte size of all values, nil disables the limit
|
18
20
|
# @option options [Integer] :max_value (options[:max_size]) Maximum byte size of one value, nil disables the limit
|
@@ -29,6 +31,14 @@ module Moneta
|
|
29
31
|
@entry.key?(key)
|
30
32
|
end
|
31
33
|
|
34
|
+
# (see Proxy#each_key)
|
35
|
+
def each_key(&block)
|
36
|
+
return enum_for(:each_key) { @entry.length } unless block_given?
|
37
|
+
|
38
|
+
@entry.each_key { |k| yield(k) }
|
39
|
+
self
|
40
|
+
end
|
41
|
+
|
32
42
|
# (see Proxy#load)
|
33
43
|
def load(key, options = {})
|
34
44
|
if entry = @entry[key]
|
@@ -73,6 +83,26 @@ module Moneta
|
|
73
83
|
self
|
74
84
|
end
|
75
85
|
|
86
|
+
# (see Proxy#values_at)
|
87
|
+
def values_at(*keys, **options)
|
88
|
+
@entry.values_at(*keys).map do |entry|
|
89
|
+
if entry
|
90
|
+
entry.insert_after(@list)
|
91
|
+
entry.value
|
92
|
+
end
|
93
|
+
end
|
94
|
+
end
|
95
|
+
|
96
|
+
# (see Proxy#slice)
|
97
|
+
def slice(*keys, **options)
|
98
|
+
return super unless @entry.respond_to?(:slice)
|
99
|
+
hash = @entry.slice(*keys)
|
100
|
+
hash.each do |key, entry|
|
101
|
+
entry.insert_after(@list)
|
102
|
+
hash[key] = entry.value
|
103
|
+
end
|
104
|
+
end
|
105
|
+
|
76
106
|
private
|
77
107
|
|
78
108
|
class Entry
|
@@ -50,14 +50,11 @@ module Moneta
|
|
50
50
|
|
51
51
|
# (see Proxy#increment)
|
52
52
|
def increment(key, amount = 1, options = {})
|
53
|
-
# FIXME: There is a Dalli bug, load(key) returns a wrong value after increment
|
54
|
-
# therefore we set default = nil and create the counter manually
|
55
|
-
# See https://github.com/mperham/dalli/issues/309
|
56
53
|
result =
|
57
54
|
if amount >= 0
|
58
|
-
@backend.incr(key, amount, expires_value(options) || nil
|
55
|
+
@backend.incr(key, amount, expires_value(options) || nil)
|
59
56
|
else
|
60
|
-
@backend.decr(key, -amount, expires_value(options) || nil
|
57
|
+
@backend.decr(key, -amount, expires_value(options) || nil)
|
61
58
|
end
|
62
59
|
if result
|
63
60
|
result
|
@@ -84,6 +81,54 @@ module Moneta
|
|
84
81
|
@backend.close
|
85
82
|
nil
|
86
83
|
end
|
84
|
+
|
85
|
+
# (see Defaults#slice)
|
86
|
+
def slice(*keys, **options)
|
87
|
+
@backend.get_multi(keys).tap do |pairs|
|
88
|
+
next if pairs.empty?
|
89
|
+
expires = expires_value(options, nil)
|
90
|
+
next if expires.nil?
|
91
|
+
expires = expires.to_i if Numeric === expires
|
92
|
+
expires ||= 0
|
93
|
+
@backend.multi do
|
94
|
+
pairs.each do |key, value|
|
95
|
+
@backend.set(key, value, expires, false)
|
96
|
+
end
|
97
|
+
end
|
98
|
+
end
|
99
|
+
end
|
100
|
+
|
101
|
+
# (see Defaults#values_at)
|
102
|
+
def values_at(*keys, **options)
|
103
|
+
pairs = slice(*keys, **options)
|
104
|
+
keys.map { |key| pairs.delete(key) }
|
105
|
+
end
|
106
|
+
|
107
|
+
# (see Defaults#merge!)
|
108
|
+
def merge!(pairs, options = {})
|
109
|
+
expires = expires_value(options)
|
110
|
+
expires = expires.to_i if Numeric === expires
|
111
|
+
expires ||= nil
|
112
|
+
|
113
|
+
if block_given?
|
114
|
+
keys = pairs.map { |key, _| key }.to_a
|
115
|
+
old_pairs = @backend.get_multi(keys)
|
116
|
+
pairs = pairs.map do |key, new_value|
|
117
|
+
if old_pairs.key? key
|
118
|
+
new_value = yield(key, old_pairs[key], new_value)
|
119
|
+
end
|
120
|
+
[key, new_value]
|
121
|
+
end
|
122
|
+
end
|
123
|
+
|
124
|
+
@backend.multi do
|
125
|
+
pairs.each do |key, value|
|
126
|
+
@backend.set(key, value, expires, raw: true)
|
127
|
+
end
|
128
|
+
end
|
129
|
+
|
130
|
+
self
|
131
|
+
end
|
87
132
|
end
|
88
133
|
end
|
89
134
|
end
|
@@ -35,7 +35,10 @@ module Moneta
|
|
35
35
|
value = @backend.get(key, false)
|
36
36
|
if value
|
37
37
|
expires = expires_value(options, nil)
|
38
|
-
|
38
|
+
unless expires.nil?
|
39
|
+
Numeric === expires and expires = expires.to_i
|
40
|
+
@backend.set(key, value, expires || 0, false)
|
41
|
+
end
|
39
42
|
value
|
40
43
|
end
|
41
44
|
rescue ::Memcached::NotFound
|
@@ -43,8 +46,10 @@ module Moneta
|
|
43
46
|
|
44
47
|
# (see Proxy#store)
|
45
48
|
def store(key, value, options = {})
|
46
|
-
# TTL must be
|
47
|
-
|
49
|
+
# TTL must be Integer
|
50
|
+
expires = expires_value(options)
|
51
|
+
Numeric === expires and expires = expires.to_i
|
52
|
+
@backend.set(key, value, expires || 0, false)
|
48
53
|
value
|
49
54
|
end
|
50
55
|
|
@@ -74,7 +79,9 @@ module Moneta
|
|
74
79
|
|
75
80
|
# (see Defaults#create)
|
76
81
|
def create(key, value, options = {})
|
77
|
-
|
82
|
+
expires = expires_value(options)
|
83
|
+
Numeric === expires and expires = expires.to_i
|
84
|
+
@backend.add(key, value, expires || 0, false)
|
78
85
|
true
|
79
86
|
rescue ::Memcached::ConnectionDataExists
|
80
87
|
false
|
@@ -4,9 +4,11 @@ module Moneta
|
|
4
4
|
# @api public
|
5
5
|
class Memory
|
6
6
|
include Defaults
|
7
|
+
include NilValues
|
7
8
|
include HashAdapter
|
8
9
|
include IncrementSupport
|
9
10
|
include CreateSupport
|
11
|
+
include EachKeySupport
|
10
12
|
|
11
13
|
# @param [Hash] options Options hash
|
12
14
|
# @option options [Hash] :backend Use existing backend instance
|
@@ -7,7 +7,7 @@ module Moneta
|
|
7
7
|
include Defaults
|
8
8
|
include ExpiresSupport
|
9
9
|
|
10
|
-
supports :create, :increment
|
10
|
+
supports :each_key, :create, :increment
|
11
11
|
attr_reader :backend
|
12
12
|
|
13
13
|
DEFAULT_PORT = 27017
|
@@ -19,6 +19,25 @@ module Moneta
|
|
19
19
|
@type_field = options.delete(:type_field) || 'type'
|
20
20
|
end
|
21
21
|
|
22
|
+
# (see Proxy#fetch_values)
|
23
|
+
def fetch_values(*keys, **options)
|
24
|
+
return values_at(*keys, **options) unless block_given?
|
25
|
+
hash = Hash[slice(*keys, **options)]
|
26
|
+
keys.map do |key|
|
27
|
+
if hash.key?(key)
|
28
|
+
hash[key]
|
29
|
+
else
|
30
|
+
yield key
|
31
|
+
end
|
32
|
+
end
|
33
|
+
end
|
34
|
+
|
35
|
+
# (see Proxy#values_at)
|
36
|
+
def values_at(*keys, **options)
|
37
|
+
hash = Hash[slice(*keys, **options)]
|
38
|
+
keys.map { |key| hash[key] }
|
39
|
+
end
|
40
|
+
|
22
41
|
protected
|
23
42
|
|
24
43
|
def doc_to_value(doc)
|
@@ -33,11 +52,7 @@ module Moneta
|
|
33
52
|
doc[@value_field]
|
34
53
|
else
|
35
54
|
# In ruby_bson version 2 (and probably up), #to_s no longer returns the binary data
|
36
|
-
|
37
|
-
doc[@value_field].data
|
38
|
-
else
|
39
|
-
doc[@value_field].to_s
|
40
|
-
end
|
55
|
+
from_binary(doc[@value_field])
|
41
56
|
end
|
42
57
|
end
|
43
58
|
|
@@ -48,7 +63,7 @@ module Moneta
|
|
48
63
|
@type_field => 'Hash',
|
49
64
|
# @expires_field must be a Time object (BSON date datatype)
|
50
65
|
@expires_field => expires_at(options) || nil)
|
51
|
-
when Float,
|
66
|
+
when Float, Integer
|
52
67
|
{ '_id' => key,
|
53
68
|
@type_field => 'Number',
|
54
69
|
@value_field => value,
|
@@ -73,6 +88,16 @@ module Moneta
|
|
73
88
|
s = s.dup if s.frozen? || s.encoding != Encoding::ASCII_8BIT
|
74
89
|
::BSON::Binary.new(s)
|
75
90
|
end
|
91
|
+
|
92
|
+
if defined?(::BSON::VERSION) and ::BSON::VERSION[0].to_i >= 2
|
93
|
+
def from_binary(binary)
|
94
|
+
binary.is_a?(::BSON::Binary) ? binary.data : binary.to_s
|
95
|
+
end
|
96
|
+
else
|
97
|
+
def from_binary(binary)
|
98
|
+
binary.to_s
|
99
|
+
end
|
100
|
+
end
|
76
101
|
end
|
77
102
|
end
|
78
103
|
end
|
@@ -70,6 +70,13 @@ module Moneta
|
|
70
70
|
value
|
71
71
|
end
|
72
72
|
|
73
|
+
# (see Proxy#each_key)
|
74
|
+
def each_key
|
75
|
+
return enum_for(:each_key) unless block_given?
|
76
|
+
@collection.find.each { |doc| yield from_binary(doc[:_id]) }
|
77
|
+
self
|
78
|
+
end
|
79
|
+
|
73
80
|
# (see Proxy#delete)
|
74
81
|
def delete(key, options = {})
|
75
82
|
value = load(key, options)
|
@@ -80,9 +87,17 @@ module Moneta
|
|
80
87
|
# (see Proxy#increment)
|
81
88
|
def increment(key, amount = 1, options = {})
|
82
89
|
@backend.with(safe: true, consistency: :strong) do |safe|
|
83
|
-
safe[@collection.name].
|
84
|
-
|
90
|
+
safe[@collection.name].
|
91
|
+
find(_id: to_binary(key)).
|
92
|
+
modify({:$inc => { @value_field => amount }},
|
93
|
+
new: true,
|
94
|
+
upsert: true)[@value_field]
|
85
95
|
end
|
96
|
+
rescue ::Moped::Errors::OperationFailure
|
97
|
+
tries ||= 0
|
98
|
+
tries += 1
|
99
|
+
retry if tries < 3
|
100
|
+
raise # otherwise
|
86
101
|
end
|
87
102
|
|
88
103
|
# (see Proxy#create)
|
@@ -102,6 +117,48 @@ module Moneta
|
|
102
117
|
@collection.find.remove_all
|
103
118
|
self
|
104
119
|
end
|
120
|
+
|
121
|
+
# (see Proxy#slice)
|
122
|
+
def slice(*keys, **options)
|
123
|
+
query = @collection.find(_id: {:$in => keys.map(&method(:to_binary))})
|
124
|
+
pairs = query.map do |doc|
|
125
|
+
next if doc[@expires_field] && doc[@expires_field] < Time.now
|
126
|
+
[from_binary(doc[:_id]), doc_to_value(doc)]
|
127
|
+
end.compact
|
128
|
+
|
129
|
+
if (expires = expires_at(options, nil)) != nil
|
130
|
+
query.update_all(:$set => { @expires_field => expires || nil })
|
131
|
+
end
|
132
|
+
|
133
|
+
pairs
|
134
|
+
end
|
135
|
+
|
136
|
+
# (see Proxy#merge!)
|
137
|
+
def merge!(pairs, options = {})
|
138
|
+
@backend.with(safe: true, consistency: :strong) do |safe|
|
139
|
+
collection = safe[@collection.name]
|
140
|
+
existing = collection.
|
141
|
+
find(_id: {:$in => pairs.map { |key, _| to_binary(key) }.to_a}).
|
142
|
+
map{ |doc| [from_binary(doc[:_id]), doc_to_value(doc)] }.
|
143
|
+
to_h
|
144
|
+
|
145
|
+
update_pairs, insert_pairs = pairs.partition { |key, _| existing.key?(key) }
|
146
|
+
unless insert_pairs.empty?
|
147
|
+
collection.insert(insert_pairs.map do |key, value|
|
148
|
+
value_to_doc(to_binary(key), value, options)
|
149
|
+
end)
|
150
|
+
end
|
151
|
+
|
152
|
+
update_pairs.each do |key, value|
|
153
|
+
value = yield(key, existing[key], value) if block_given?
|
154
|
+
binary = to_binary(key)
|
155
|
+
collection.
|
156
|
+
find(_id: binary).
|
157
|
+
update(value_to_doc(binary, value, options))
|
158
|
+
end
|
159
|
+
end
|
160
|
+
self
|
161
|
+
end
|
105
162
|
end
|
106
163
|
end
|
107
164
|
end
|
@@ -73,6 +73,13 @@ module Moneta
|
|
73
73
|
value
|
74
74
|
end
|
75
75
|
|
76
|
+
# (see Proxy#each_key)
|
77
|
+
def each_key
|
78
|
+
return enum_for(:each_key) unless block_given?
|
79
|
+
@collection.find.each { |doc| yield from_binary(doc[:_id]) }
|
80
|
+
self
|
81
|
+
end
|
82
|
+
|
76
83
|
# (see Proxy#delete)
|
77
84
|
def delete(key, options = {})
|
78
85
|
key = to_binary(key)
|
@@ -112,6 +119,39 @@ module Moneta
|
|
112
119
|
@backend.close
|
113
120
|
nil
|
114
121
|
end
|
122
|
+
|
123
|
+
# (see Proxy#slice)
|
124
|
+
def slice(*keys, **options)
|
125
|
+
query = @collection.find(_id: {:$in => keys.map(&method(:to_binary))})
|
126
|
+
pairs = query.map do |doc|
|
127
|
+
next if doc[@expires_field] && doc[@expires_field] < Time.now
|
128
|
+
[from_binary(doc[:_id]), doc_to_value(doc)]
|
129
|
+
end.compact
|
130
|
+
|
131
|
+
if (expires = expires_at(options, nil)) != nil
|
132
|
+
query.update_many(:$set => { @expires_field => expires || nil })
|
133
|
+
end
|
134
|
+
|
135
|
+
pairs
|
136
|
+
end
|
137
|
+
|
138
|
+
# (see Proxy#merge!)
|
139
|
+
def merge!(pairs, options = {})
|
140
|
+
existing = Hash[slice(*pairs.map { |key, _| key })]
|
141
|
+
update_pairs, insert_pairs = pairs.partition { |key, _| existing.key?(key) }
|
142
|
+
|
143
|
+
@collection.insert_many(insert_pairs.map do |key, value|
|
144
|
+
value_to_doc(to_binary(key), value, options)
|
145
|
+
end)
|
146
|
+
|
147
|
+
update_pairs.each do |key, value|
|
148
|
+
value = yield(key, existing[key], value) if block_given?
|
149
|
+
binary = to_binary(key)
|
150
|
+
@collection.replace_one({_id: binary}, value_to_doc(binary, value, options))
|
151
|
+
end
|
152
|
+
|
153
|
+
self
|
154
|
+
end
|
115
155
|
end
|
116
156
|
end
|
117
157
|
end
|