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
data/script/parallel-tests
CHANGED
@@ -1,105 +1,80 @@
|
|
1
1
|
#!/usr/bin/env ruby
|
2
2
|
|
3
|
-
def rspec(spec)
|
4
|
-
if system("rspec #{spec}")
|
5
|
-
true
|
6
|
-
elsif sig = $?.termsig
|
7
|
-
found = Signal.list.to_a.select {|name, id| id == sig }.first
|
8
|
-
puts "\e[31m########## SIG#{found ? found.first : sig} rspec #{spec} ##########\e[0m"
|
9
|
-
false
|
10
|
-
else
|
11
|
-
puts "rspec terminated with #{$?.exitstatus}"
|
12
|
-
false
|
13
|
-
end
|
14
|
-
end
|
15
|
-
|
16
3
|
ENV['PARALLEL_TESTS'] = 'yes'
|
17
4
|
|
18
|
-
|
5
|
+
require 'multi_json'
|
19
6
|
|
20
|
-
|
21
|
-
|
22
|
-
|
23
|
-
old_seed = srand(43)
|
24
|
-
specs.shuffle!
|
25
|
-
srand(old_seed)
|
7
|
+
def tag_args tags
|
8
|
+
tags.flat_map{ |tag| ['--tag', tag] }
|
9
|
+
end
|
26
10
|
|
27
|
-
|
28
|
-
#
|
29
|
-
|
30
|
-
|
31
|
-
|
32
|
-
#
|
33
|
-
# * PStore increment/locking doesn't work correctly on JRuby
|
34
|
-
#
|
35
|
-
unstable = %w(quicklz riak cassandra)
|
36
|
-
unstable += %w(pstore) if defined?(JRUBY_VERSION)
|
11
|
+
def example_ids tags, specs
|
12
|
+
json = `bundle exec rspec -f j --dry-run #{tag_args(tags).join(' ')} -- #{specs.join(' ')}`
|
13
|
+
data = MultiJson.load(json)
|
14
|
+
data['examples'].map{ |example| example['id'] }
|
15
|
+
end
|
37
16
|
|
38
|
-
|
39
|
-
|
40
|
-
|
17
|
+
def run(*args)
|
18
|
+
pid = spawn(*args)
|
19
|
+
Signal.trap("INT") { Process.kill("INT", pid) }
|
20
|
+
Process.wait(pid)
|
21
|
+
$? == 0
|
22
|
+
ensure
|
23
|
+
Signal.trap("INT", "DEFAULT")
|
24
|
+
end
|
41
25
|
|
42
|
-
|
43
|
-
|
44
|
-
|
45
|
-
|
46
|
-
|
47
|
-
|
48
|
-
|
26
|
+
tags = ARGV.take_while { |arg| arg[0] != '-' }
|
27
|
+
ARGV.shift(tags.length)
|
28
|
+
opts = []
|
29
|
+
files = nil
|
30
|
+
while arg = ARGV.shift
|
31
|
+
case arg
|
32
|
+
when '--'
|
33
|
+
files = ARGV
|
34
|
+
break
|
35
|
+
when '--remainder'
|
36
|
+
files = Dir['spec/**/*_spec.rb', 'test/**/*_test.rb']
|
37
|
+
existing = File.open('.travis.yml').each_line.flat_map do |line|
|
38
|
+
next unless matches = line.match(%r{((?:test|spec)/(?:[\w\.]+/?)*)})
|
39
|
+
path = matches[1]
|
40
|
+
path[-3..-1] == '.rb' ? path : path + '/**/*.rb'
|
41
|
+
end.compact
|
42
|
+
files -= Dir[*existing]
|
49
43
|
else
|
50
|
-
|
44
|
+
opts << arg
|
51
45
|
end
|
52
|
-
when 'unstable'
|
53
|
-
specs = unstable
|
54
|
-
else
|
55
|
-
puts "Invalid test group #{group}"
|
56
|
-
exit 1
|
57
46
|
end
|
58
47
|
|
59
|
-
|
48
|
+
files ||= Dir['spec', 'test/**/*_test.rb']
|
49
|
+
specs, tests = files.partition { |file| file.match /^spec/ }
|
60
50
|
|
61
|
-
|
62
|
-
|
63
|
-
parallel = []
|
64
|
-
%w(memcached redis client shared riak tokyotyrant couch cassandra).each do |name|
|
65
|
-
serial = specs.select { |s| s.include?(name) }
|
66
|
-
unless serial.empty?
|
67
|
-
specs -= serial
|
68
|
-
parallel << serial
|
69
|
-
end
|
70
|
-
end
|
51
|
+
puts "The following specs will be executed:\n\t#{specs.join "\n\t"}\n\n" unless specs.empty?
|
52
|
+
puts "The following tests will be executed:\n\t#{tests.join "\n\t"}\n\n" unless tests.empty?
|
71
53
|
|
72
|
-
|
73
|
-
|
74
|
-
|
54
|
+
results = []
|
55
|
+
unless specs.empty?
|
56
|
+
# run all non :isolate examples in parallel
|
57
|
+
results << run(*%w{bundle exec parallel_rspec --},
|
58
|
+
*opts,
|
59
|
+
*tag_args(tags | %w{~isolate}),
|
60
|
+
'--',
|
61
|
+
*specs)
|
75
62
|
|
76
|
-
|
77
|
-
|
78
|
-
|
79
|
-
|
63
|
+
# find the example IDs of the isolate examples to be run in serial
|
64
|
+
ids = example_ids(tags, specs) - example_ids(tags | %w{~isolate}, specs)
|
65
|
+
unless ids.empty?
|
66
|
+
results << run(*%w{bundle exec rspec},
|
67
|
+
*opts,
|
68
|
+
'--',
|
69
|
+
*ids)
|
70
|
+
end
|
80
71
|
end
|
81
72
|
|
82
|
-
|
83
|
-
|
84
|
-
|
85
|
-
threads = []
|
86
|
-
failed = false
|
87
|
-
parallel.each do |serial|
|
88
|
-
threads << Thread.new do
|
89
|
-
begin
|
90
|
-
serial.each do |spec|
|
91
|
-
failed = true unless rspec(spec)
|
92
|
-
end
|
93
|
-
ensure
|
94
|
-
threads.delete Thread.current
|
95
|
-
end
|
96
|
-
end
|
97
|
-
sleep 0.1
|
98
|
-
sleep 0.1 while threads.size >= 5
|
73
|
+
tests.each do |test|
|
74
|
+
results << run(*%w{bundle exec ruby}, test)
|
99
75
|
end
|
100
|
-
sleep 0.1 until threads.empty?
|
101
76
|
|
102
|
-
if
|
77
|
+
if results.any?{ |result| !result }
|
103
78
|
puts "\e[31m########## MONETA TESTSUITE FAILED ##########\e[0m"
|
104
79
|
exit 1
|
105
80
|
end
|
data/script/start-hbase
ADDED
@@ -0,0 +1,46 @@
|
|
1
|
+
#!/bin/sh
|
2
|
+
|
3
|
+
cd $(dirname $(dirname $0))
|
4
|
+
|
5
|
+
mkdir -p hbase
|
6
|
+
mkdir -p zookeeper
|
7
|
+
mkdir -p downloads
|
8
|
+
root=$(pwd)
|
9
|
+
|
10
|
+
version=$(curl -sS https://www-us.apache.org/dist/hbase/stable/ | grep -oP '(?<=hbase-)(\d+\.?)+' | head -n1)
|
11
|
+
|
12
|
+
echo HBase stable version is $version
|
13
|
+
|
14
|
+
if [ ! -f downloads/hbase-$version-bin.tar.gz ]; then
|
15
|
+
echo Downloading HBase ...
|
16
|
+
wget -P downloads http://www-us.apache.org/dist/hbase/stable/hbase-$version-bin.tar.gz
|
17
|
+
fi
|
18
|
+
|
19
|
+
echo Extracting HBase ...
|
20
|
+
cd hbase
|
21
|
+
tar -zxf $root/downloads/hbase-$version-bin.tar.gz
|
22
|
+
|
23
|
+
echo Configuring HBase ...
|
24
|
+
echo "export JAVA_HOME=/usr" >> hbase-$version/conf/hbase-env.sh
|
25
|
+
tee <<-EOF > hbase-$version/conf/hbase-site.xml
|
26
|
+
<configuration>
|
27
|
+
<property>
|
28
|
+
<name>hbase.rootdir</name>
|
29
|
+
<value>file://$root/hbase</value>
|
30
|
+
</property>
|
31
|
+
<property>
|
32
|
+
<name>hbase.zookeeper.property.dataDir</name>
|
33
|
+
<value>$root/zookeeper</value>
|
34
|
+
</property>
|
35
|
+
<property>
|
36
|
+
<name>hbase.unsafe.stream.capability.enforce</name>
|
37
|
+
<value>false</value>
|
38
|
+
</property>
|
39
|
+
</configuration>
|
40
|
+
EOF
|
41
|
+
|
42
|
+
echo Launching HBase ...
|
43
|
+
./hbase-$version/bin/start-hbase.sh
|
44
|
+
./hbase-$version/bin/hbase-daemon.sh start thrift
|
45
|
+
|
46
|
+
cd $root
|
data/script/start-services
CHANGED
@@ -1,11 +1,18 @@
|
|
1
1
|
#!/bin/bash
|
2
2
|
|
3
|
-
echo
|
3
|
+
echo Starting TokyoTyrant ...
|
4
4
|
/usr/sbin/ttserver -dmn -pid /tmp/ttserver.pid -log /tmp/ttserver.log -port 1978
|
5
5
|
|
6
|
+
# Reconfigure CouchDB to use delayed commits for speed: http://guide.couchdb.org/draft/performance.html
|
7
|
+
sudo sed -i '/\[couchdb\]/a delayed_commits = true' /etc/couchdb/local.ini
|
8
|
+
sudo service couchdb restart
|
9
|
+
|
10
|
+
# Start HBase
|
11
|
+
$(dirname $0)/start-hbase
|
12
|
+
|
6
13
|
# Waiting for servers to start
|
7
14
|
sleep 3
|
8
15
|
|
9
|
-
echo
|
16
|
+
echo TokyoTyrant status:
|
10
17
|
ps aux | grep ttserver
|
11
18
|
cat /tmp/ttserver.log
|
@@ -0,0 +1,148 @@
|
|
1
|
+
#!/usr/bin/env ruby
|
2
|
+
# coding: utf-8
|
3
|
+
|
4
|
+
require 'rubygems'
|
5
|
+
require 'bundler/setup'
|
6
|
+
Bundler.require(:doc)
|
7
|
+
|
8
|
+
require 'yaml'
|
9
|
+
|
10
|
+
output = "<table>\n"
|
11
|
+
output << <<-TAB.lines.map(&:strip).join
|
12
|
+
<tr>
|
13
|
+
<th>Adapter</th><th>Required gems</th>
|
14
|
+
<th style="writing-mode:tb">MRI support<sup>1</sup></th>
|
15
|
+
<th style="writing-mode:tb">JRuby support<sup>1</sup></th>
|
16
|
+
<th style="writing-mode:tb">Multi-thread safe<sup>2</sup></th>
|
17
|
+
<th style="writing-mode:tb">Multi-process safe<sup>3</sup></th>
|
18
|
+
<th style="writing-mode:tb">Atomic increment<sup>4</sup></th>
|
19
|
+
<th style="writing-mode:tb">Atomic create<sup>5</sup></th>
|
20
|
+
<th style="writing-mode:tb">Native expires<sup>6</sup></th>
|
21
|
+
<th style="writing-mode:tb">Persistent</th>
|
22
|
+
<th style="writing-mode:tb">Key Traversal</th>
|
23
|
+
<th style="writing-mode:tb">Bulk read<sup>7</sup></th>
|
24
|
+
<th style="writing-mode:tb">Bulk write<sup>8</sup></th>
|
25
|
+
<th>Description</th>
|
26
|
+
</tr>
|
27
|
+
TAB
|
28
|
+
output << "\n\n"
|
29
|
+
|
30
|
+
footnotes = {
|
31
|
+
"platform" => <<-EOF,
|
32
|
+
Indicates that the adapter is expected to work on this platform. Most adapters will at least
|
33
|
+
work on MRI, but some are curently considered unstable, in which case they are not supported
|
34
|
+
on any platform.
|
35
|
+
EOF
|
36
|
+
"multi-thread safe" => <<-EOF,
|
37
|
+
Make adapters thread-safe by using `Moneta::Lock` or by passing the option `threadsafe: true` to
|
38
|
+
`Moneta#new`. There is also `Moneta::Pool` which can be used to share a store between multiple
|
39
|
+
threads if the store is multi-process safe. I recommend to add the option `:threadsafe` to
|
40
|
+
ensure thread-safety since for example under JRuby and Rubinius even the basic datastructures
|
41
|
+
are not thread safe due to the lack of a global interpreter lock (GIL). This differs from MRI
|
42
|
+
where some adapters might appear thread safe already but only due to the GIL.
|
43
|
+
EOF
|
44
|
+
"multi-process safe" => <<-EOF,
|
45
|
+
Share a Moneta store between multiple processes using `Moneta::Shared` (See below).
|
46
|
+
EOF
|
47
|
+
"atomic increment" => <<-EOF,
|
48
|
+
If a store provides atomic increment it can be used with `Moneta::Semaphore`. You can add weak
|
49
|
+
`#increment` support using the `Moneta::WeakIncrement` proxy.
|
50
|
+
EOF
|
51
|
+
"atomic create" => <<-EOF,
|
52
|
+
If a store provides atomic creation it can be used with `Moneta::Mutex`. You can add weak
|
53
|
+
`#create` support using the `Moneta::WeakCreate` proxy.
|
54
|
+
EOF
|
55
|
+
"native expires" => <<-EOF,
|
56
|
+
Add expiration support by using `Moneta::Expires` or by passing the option `expires: true` to
|
57
|
+
`Moneta#new`.
|
58
|
+
EOF
|
59
|
+
"bulk read" => <<-EOF,
|
60
|
+
This indicates that there is some performance gain when fetching
|
61
|
+
multiple values at once using `#values_at`/`#fetch_values` or `#slice`.
|
62
|
+
For instance, the `MGET` instruction in Redis, or the ability to retrieve
|
63
|
+
several rows in one query in SQL.
|
64
|
+
EOF
|
65
|
+
"bulk write" => <<-EOF
|
66
|
+
This indicates that there is some performance gain when storing multiple
|
67
|
+
key/value pairs at once using `#merge!`/`#update`.
|
68
|
+
EOF
|
69
|
+
}
|
70
|
+
|
71
|
+
YAML.parse_stream(File.read(File.join(File.dirname(File.dirname(__FILE__)), 'feature_matrix.yaml'))) do |document|
|
72
|
+
feature_group = document.to_ruby
|
73
|
+
|
74
|
+
output << %{<tr><th colspan="2">#{feature_group['group']}</th><th colspan="12"></th></tr>\n\n}
|
75
|
+
|
76
|
+
feature_group['notes'].each do |k,v|
|
77
|
+
footnotes[k] = v
|
78
|
+
end
|
79
|
+
|
80
|
+
feature_group['backends'].each do |backend|
|
81
|
+
output << '<tr>'
|
82
|
+
output << "<td>#{backend['adapter']}</td>"
|
83
|
+
output << "<td>#{backend['gems'] || '-'}</td>"
|
84
|
+
|
85
|
+
features = backend['features'] | (feature_group['features'] || [])
|
86
|
+
features += backend['platforms'] || []
|
87
|
+
%w{MRI JRuby threadsafe multiprocess increment create expires persist each_key bulk_read bulk_write}.each do |feature|
|
88
|
+
supported = if features.include? feature
|
89
|
+
"yes"
|
90
|
+
elsif backend['unknown'] && backend['unknown'].include?(feature)
|
91
|
+
"unknown"
|
92
|
+
else
|
93
|
+
"no"
|
94
|
+
end
|
95
|
+
|
96
|
+
note = if backend['notes'] && backend['notes'][feature]
|
97
|
+
"<sup>#{footnotes.keys.index(backend['notes'][feature]) + 1}</sup>"
|
98
|
+
else
|
99
|
+
''
|
100
|
+
end
|
101
|
+
|
102
|
+
mark = case supported
|
103
|
+
when "yes"
|
104
|
+
"✓"
|
105
|
+
when "no"
|
106
|
+
"✗"
|
107
|
+
when "unknown"
|
108
|
+
'?'
|
109
|
+
end
|
110
|
+
|
111
|
+
colour = case supported
|
112
|
+
when "yes"
|
113
|
+
'#5F5'
|
114
|
+
when "no"
|
115
|
+
'#F44'
|
116
|
+
when "unknown"
|
117
|
+
'#55F'
|
118
|
+
end
|
119
|
+
|
120
|
+
output << %{<td style="text-align:center;background:#{colour}">#{mark}#{note}</td>}
|
121
|
+
end
|
122
|
+
|
123
|
+
html_description = if backend['description']
|
124
|
+
Kramdown::Document.new(backend['description']).to_html.match('<p>(.*)</p>')[1]
|
125
|
+
else
|
126
|
+
''
|
127
|
+
end
|
128
|
+
output << "<td>#{html_description}</td>"
|
129
|
+
|
130
|
+
output << '</tr>'
|
131
|
+
output << "\n\n"
|
132
|
+
end
|
133
|
+
|
134
|
+
|
135
|
+
end
|
136
|
+
|
137
|
+
output << "</table>\n\n"
|
138
|
+
|
139
|
+
footnotes.each_value.each_with_index do |note, idx|
|
140
|
+
output << "#{idx+1}. #{note.lines.map(&:strip).join(" ")}\n"
|
141
|
+
end
|
142
|
+
|
143
|
+
readme = File.open('README.md', 'r+')
|
144
|
+
new_readme = readme.read.sub(/(name="backend-matrix".*?\n).*?(------)/m, "\\1\n#{output}\n\\2")
|
145
|
+
readme.rewind
|
146
|
+
readme << new_readme
|
147
|
+
readme.truncate(readme.tell)
|
148
|
+
|
@@ -3,19 +3,6 @@ require 'active_support'
|
|
3
3
|
require 'active_support/cache/moneta_store'
|
4
4
|
require 'ostruct'
|
5
5
|
|
6
|
-
module MonetaStoreHelpers
|
7
|
-
def with_notifications
|
8
|
-
described_class.instrument = true
|
9
|
-
yield
|
10
|
-
ensure
|
11
|
-
described_class.instrument = false
|
12
|
-
end
|
13
|
-
end
|
14
|
-
|
15
|
-
RSpec.configure do |config|
|
16
|
-
config.include(MonetaStoreHelpers)
|
17
|
-
end
|
18
|
-
|
19
6
|
describe "cache_moneta_store" do
|
20
7
|
before(:all) do
|
21
8
|
@events = []
|
@@ -30,75 +17,101 @@ describe "cache_moneta_store" do
|
|
30
17
|
|
31
18
|
# All stores should implement this basic behavior.
|
32
19
|
shared_examples :basic_store do
|
33
|
-
|
34
|
-
|
35
|
-
@white_rabbit = OpenStruct.new color: 'white'
|
20
|
+
let(:rabbit) { OpenStruct.new name: 'bunny' }
|
21
|
+
let(:white_rabbit) { OpenStruct.new color: 'white' }
|
36
22
|
|
23
|
+
before(:each) do
|
37
24
|
store.clear
|
38
|
-
store.write 'rabbit',
|
25
|
+
store.write 'rabbit', rabbit
|
26
|
+
@events.clear
|
39
27
|
end
|
40
28
|
|
41
29
|
it 'reads the data' do
|
42
|
-
store.read('rabbit').
|
30
|
+
expect(store.read('rabbit')).to eq rabbit
|
43
31
|
end
|
44
32
|
|
45
33
|
it 'writes the data' do
|
46
|
-
store.write 'rabbit',
|
47
|
-
store.read('rabbit').
|
34
|
+
store.write 'rabbit', white_rabbit
|
35
|
+
expect(store.read('rabbit')).to eq white_rabbit
|
48
36
|
end
|
49
37
|
|
50
38
|
it 'deletes data' do
|
51
39
|
store.delete 'rabbit'
|
52
|
-
store.read('rabbit').
|
40
|
+
expect(store.read('rabbit')).to be_nil
|
53
41
|
end
|
54
42
|
|
55
43
|
it 'verifies existence of an object in the store' do
|
56
|
-
store.exist?('rabbit').
|
57
|
-
(!!store.exist?('rab-a-dub')).
|
44
|
+
expect(store.exist?('rabbit')).to be true
|
45
|
+
expect(!!store.exist?('rab-a-dub')).to be false
|
58
46
|
end
|
59
47
|
|
60
48
|
it 'fetches data' do
|
61
|
-
store.fetch('rabbit').
|
62
|
-
store.fetch('rub-a-dub').
|
49
|
+
expect(store.fetch('rabbit')).to eq rabbit
|
50
|
+
expect(store.fetch('rub-a-dub')).to be_nil
|
63
51
|
store.fetch('rub-a-dub') { 'Flora de Cana' }
|
64
|
-
store.fetch('rub-a-dub').
|
52
|
+
expect(store.fetch('rub-a-dub')).to eq 'Flora de Cana'
|
65
53
|
end
|
66
54
|
|
67
55
|
it 'reads multiple keys' do
|
68
56
|
store.write 'irish whisky', 'Jameson'
|
69
57
|
result = store.read_multi 'rabbit', 'irish whisky'
|
70
|
-
result['rabbit'].
|
71
|
-
result['irish whisky'].
|
58
|
+
expect(result['rabbit']).to eq rabbit
|
59
|
+
expect(result['irish whisky']).to eq 'Jameson'
|
72
60
|
end
|
73
61
|
|
74
62
|
it 'reads multiple keys and returns only the matched ones' do
|
75
63
|
store.delete 'irish whisky'
|
76
64
|
result = store.read_multi 'rabbit', 'irish whisky'
|
77
|
-
result.
|
78
|
-
result.
|
65
|
+
expect(result).not_to include('irish whisky')
|
66
|
+
expect(result).to include('rabbit')
|
67
|
+
end
|
68
|
+
|
69
|
+
it 'fetches multiple keys and fills in the missing ones' do
|
70
|
+
store.delete 'irish whisky'
|
71
|
+
result = store.fetch_multi('rabbit', 'irish whisky') do |k|
|
72
|
+
k + ' was missing'
|
73
|
+
end
|
74
|
+
expect(result['rabbit']).to eq rabbit
|
75
|
+
expect(result['irish whisky']).to eq 'irish whisky was missing'
|
76
|
+
expect(store.fetch 'irish whisky').to eq 'irish whisky was missing'
|
79
77
|
end
|
80
78
|
end
|
81
79
|
|
82
80
|
shared_examples :expiry do
|
83
|
-
|
84
|
-
|
85
|
-
|
86
|
-
|
87
|
-
|
88
|
-
|
81
|
+
at_each_usec do
|
82
|
+
it 'writes the data with expiration time' do
|
83
|
+
store.write 'rabbit', white_rabbit, expires_in: 0.2.second
|
84
|
+
expect(store.read('rabbit')).to eq white_rabbit
|
85
|
+
sleep 0.3
|
86
|
+
expect(store.read('rabbit')).to be_nil
|
87
|
+
end
|
89
88
|
|
90
|
-
|
91
|
-
|
92
|
-
|
93
|
-
|
94
|
-
|
95
|
-
store.fetch('rabbit').should be_nil
|
96
|
-
end
|
89
|
+
it 'writes multiple values with expiration time' do
|
90
|
+
store.write_multi({
|
91
|
+
'rabbit' => white_rabbit,
|
92
|
+
'irish whisky' => 'Jameson'
|
93
|
+
}, expires_in: 0.2.second)
|
97
94
|
|
98
|
-
|
99
|
-
|
100
|
-
|
101
|
-
|
95
|
+
expect(store.read_multi('rabbit', 'irish whisky')).to eq \
|
96
|
+
'rabbit' => white_rabbit,
|
97
|
+
'irish whisky' => 'Jameson'
|
98
|
+
|
99
|
+
sleep 0.3
|
100
|
+
expect(store.read_multi('rabbit', 'irish whisky')).to be_empty
|
101
|
+
end
|
102
|
+
|
103
|
+
it "sets expiry on cache miss" do
|
104
|
+
store.fetch('rabbit', force: true, expires_in: 0.2.second) { white_rabbit }
|
105
|
+
expect(store.fetch('rabbit')).to eq white_rabbit
|
106
|
+
sleep 0.3
|
107
|
+
expect(store.fetch('rabbit')).to be_nil
|
108
|
+
end
|
109
|
+
|
110
|
+
it 'does not set expiry on cache hit' do
|
111
|
+
expect(store.fetch('rabbit', expires_in: 0.2.second) { white_rabbit }).to eq rabbit
|
112
|
+
sleep 0.3
|
113
|
+
expect(store.fetch('rabbit')).to eq rabbit
|
114
|
+
end
|
102
115
|
end
|
103
116
|
end
|
104
117
|
|
@@ -106,135 +119,134 @@ describe "cache_moneta_store" do
|
|
106
119
|
shared_examples :increment_decrement do
|
107
120
|
it 'increments a key' do
|
108
121
|
store.write 'counter', 0, raw: true
|
109
|
-
3.
|
110
|
-
|
122
|
+
(1..3).each do |i|
|
123
|
+
expect(store.increment('counter')).to eq i
|
124
|
+
end
|
125
|
+
expect(store.read('counter', raw: true).to_i).to eq 3
|
111
126
|
end
|
112
127
|
|
113
128
|
it 'decrements a key' do
|
114
129
|
store.write 'counter', 0, raw: true
|
115
130
|
3.times { store.increment 'counter' }
|
116
131
|
2.times { store.decrement 'counter' }
|
117
|
-
store.read('counter', raw: true).to_i.
|
132
|
+
expect(store.read('counter', raw: true).to_i).to eq 1
|
118
133
|
end
|
119
134
|
|
120
135
|
it 'increments a key by given value' do
|
121
136
|
store.write 'counter', 0, raw: true
|
122
137
|
store.increment 'counter', 3
|
123
|
-
store.read('counter', raw: true).to_i.
|
138
|
+
expect(store.read('counter', raw: true).to_i).to eq 3
|
124
139
|
end
|
125
140
|
|
126
141
|
it 'decrements a key by given value' do
|
127
142
|
store.write 'counter', 0, raw: true
|
128
143
|
3.times { store.increment 'counter' }
|
129
144
|
store.decrement 'counter', 2
|
130
|
-
store.read('counter', raw: true).to_i.
|
145
|
+
expect(store.read('counter', raw: true).to_i).to eq 1
|
131
146
|
end
|
132
147
|
end
|
133
148
|
|
134
149
|
shared_examples :basic_instrumentation do
|
135
150
|
it 'notifies on #fetch' do
|
136
|
-
|
137
|
-
store.fetch('radiohead') { 'House Of Cards' }
|
138
|
-
end
|
151
|
+
store.fetch('radiohead') { 'House Of Cards' }
|
139
152
|
|
140
153
|
read = @events.shift
|
141
|
-
read.name.
|
142
|
-
read.payload.
|
154
|
+
expect(read.name).to eq 'cache_read.active_support'
|
155
|
+
expect(read.payload).to include(key: 'radiohead', super_operation: :fetch, hit: false)
|
143
156
|
|
144
157
|
generate = @events.shift
|
145
|
-
generate.name.
|
146
|
-
generate.payload.
|
158
|
+
expect(generate.name).to eq 'cache_generate.active_support'
|
159
|
+
expect(generate.payload).to include(key: 'radiohead')
|
147
160
|
|
148
161
|
write = @events.shift
|
149
|
-
write.name.
|
150
|
-
write.payload.
|
162
|
+
expect(write.name).to eq 'cache_write.active_support'
|
163
|
+
expect(write.payload).to include(key: 'radiohead')
|
151
164
|
end
|
152
165
|
|
153
166
|
it 'notifies on #read' do
|
154
|
-
|
155
|
-
store.read 'metallica'
|
156
|
-
end
|
167
|
+
store.read 'metallica'
|
157
168
|
|
158
169
|
read = @events.shift
|
159
|
-
read.name.
|
160
|
-
read.payload.
|
170
|
+
expect(read.name).to eq 'cache_read.active_support'
|
171
|
+
expect(read.payload).to include(key: 'metallica', hit: false)
|
161
172
|
end
|
162
173
|
|
163
174
|
it 'notifies on #write' do
|
164
|
-
|
165
|
-
store.write 'depeche mode', 'Enjoy The Silence'
|
166
|
-
end
|
175
|
+
store.write 'depeche mode', 'Enjoy The Silence'
|
167
176
|
|
168
177
|
write = @events.shift
|
169
|
-
write.name.
|
170
|
-
write.payload.
|
178
|
+
expect(write.name).to eq 'cache_write.active_support'
|
179
|
+
expect(write.payload).to include(key: 'depeche mode')
|
171
180
|
end
|
172
181
|
|
173
182
|
it 'notifies on #delete' do
|
174
|
-
|
175
|
-
store.delete 'the new cardigans'
|
176
|
-
end
|
183
|
+
store.delete 'the new cardigans'
|
177
184
|
|
178
185
|
delete = @events.shift
|
179
|
-
delete.name.
|
180
|
-
delete.payload.
|
186
|
+
expect(delete.name).to eq 'cache_delete.active_support'
|
187
|
+
expect(delete.payload).to include(key: 'the new cardigans')
|
181
188
|
end
|
182
189
|
|
183
190
|
it 'notifies on #exist?' do
|
184
|
-
|
185
|
-
store.exist? 'the smiths'
|
186
|
-
end
|
191
|
+
store.exist? 'the smiths'
|
187
192
|
|
188
193
|
exist = @events.shift
|
189
|
-
exist.name.
|
190
|
-
exist.payload.
|
194
|
+
expect(exist.name).to eq 'cache_exist?.active_support'
|
195
|
+
expect(exist.payload).to include(key: 'the smiths')
|
191
196
|
end
|
192
|
-
|
193
197
|
end
|
194
198
|
|
195
199
|
# This doesn't seem to be documented at all, so we follow the
|
196
200
|
# behavior of MemCacheStore.
|
197
201
|
shared_examples :increment_decrement_instrumentation do
|
198
202
|
it 'notifies on #increment' do
|
199
|
-
|
200
|
-
store.increment 'pearl jam'
|
201
|
-
end
|
203
|
+
store.increment 'pearl jam'
|
202
204
|
|
203
205
|
increment = @events.shift
|
204
|
-
increment.name.
|
205
|
-
increment.payload.
|
206
|
+
expect(increment.name).to eq 'cache_increment.active_support'
|
207
|
+
expect(increment.payload).to eq(key: 'pearl jam', amount: 1)
|
206
208
|
end
|
207
209
|
|
208
210
|
it 'notifies on #decrement' do
|
209
|
-
|
210
|
-
store.decrement 'placebo'
|
211
|
-
end
|
212
|
-
|
211
|
+
store.decrement 'placebo'
|
213
212
|
decrement = @events.shift
|
214
|
-
decrement.name.
|
215
|
-
decrement.payload.
|
213
|
+
expect(decrement.name).to eq 'cache_decrement.active_support'
|
214
|
+
expect(decrement.payload).to eq(key: 'placebo', amount: 1)
|
216
215
|
end
|
217
216
|
end
|
218
217
|
|
219
218
|
describe ActiveSupport::Cache::MonetaStore do
|
220
|
-
|
221
|
-
|
222
|
-
|
223
|
-
|
224
|
-
|
225
|
-
|
226
|
-
|
227
|
-
|
228
|
-
|
229
|
-
|
230
|
-
it 'notifies on #clear' do
|
231
|
-
with_notifications do
|
219
|
+
shared_examples :moneta_store do
|
220
|
+
include_examples :basic_store
|
221
|
+
include_examples :expiry
|
222
|
+
include_examples :increment_decrement
|
223
|
+
include_examples :basic_instrumentation
|
224
|
+
include_examples :increment_decrement_instrumentation
|
225
|
+
|
226
|
+
# FIXME: no other store does this -- perhaps this should be
|
227
|
+
# removed.
|
228
|
+
it 'notifies on #clear' do
|
232
229
|
store.clear
|
230
|
+
|
231
|
+
clear = @events.shift
|
232
|
+
expect(clear.name).to eq 'cache_clear.active_support'
|
233
|
+
expect(clear.payload).to eq(key: nil)
|
233
234
|
end
|
235
|
+
end
|
234
236
|
|
235
|
-
|
236
|
-
|
237
|
-
|
237
|
+
context "with :Memory store" do
|
238
|
+
let(:store){ described_class.new(store: :Memory) }
|
239
|
+
include_examples :moneta_store
|
240
|
+
end
|
241
|
+
|
242
|
+
context "with existing :Memory store" do
|
243
|
+
let(:store){ described_class.new(store: ::Moneta.new(:Memory)) }
|
244
|
+
include_examples :moneta_store
|
245
|
+
end
|
246
|
+
|
247
|
+
context "with Redis store" do
|
248
|
+
let(:store) {described_class.new(store: :Redis) }
|
249
|
+
include_examples :moneta_store
|
238
250
|
end
|
239
251
|
end
|
240
252
|
|
@@ -248,7 +260,18 @@ describe "cache_moneta_store" do
|
|
248
260
|
end
|
249
261
|
|
250
262
|
describe ActiveSupport::Cache::MemCacheStore do
|
251
|
-
let(:store){ described_class.new }
|
263
|
+
let(:store){ described_class.new('127.0.0.1:11213') }
|
264
|
+
start_memcached 11213
|
265
|
+
|
266
|
+
include_examples :basic_store
|
267
|
+
include_examples :expiry
|
268
|
+
include_examples :increment_decrement
|
269
|
+
include_examples :basic_instrumentation
|
270
|
+
include_examples :increment_decrement_instrumentation
|
271
|
+
end
|
272
|
+
|
273
|
+
describe ActiveSupport::Cache::RedisCacheStore do
|
274
|
+
let(:store){ described_class.new(url: 'redis:///3') }
|
252
275
|
|
253
276
|
include_examples :basic_store
|
254
277
|
include_examples :expiry
|