redis 4.1.0.beta1 → 4.1.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (142) hide show
  1. checksums.yaml +4 -4
  2. data/CHANGELOG.md +13 -2
  3. data/README.md +45 -0
  4. data/lib/redis.rb +497 -20
  5. data/lib/redis/client.rb +14 -6
  6. data/lib/redis/cluster.rb +1 -0
  7. data/lib/redis/cluster/command_loader.rb +2 -0
  8. data/lib/redis/cluster/node_loader.rb +2 -0
  9. data/lib/redis/cluster/option.rb +1 -0
  10. data/lib/redis/cluster/slot_loader.rb +2 -0
  11. data/lib/redis/distributed.rb +3 -4
  12. data/lib/redis/version.rb +1 -1
  13. metadata +20 -243
  14. data/.gitignore +0 -19
  15. data/.travis.yml +0 -61
  16. data/.travis/Gemfile +0 -18
  17. data/.yardopts +0 -3
  18. data/Gemfile +0 -8
  19. data/benchmarking/logging.rb +0 -71
  20. data/benchmarking/pipeline.rb +0 -51
  21. data/benchmarking/speed.rb +0 -21
  22. data/benchmarking/suite.rb +0 -24
  23. data/benchmarking/worker.rb +0 -71
  24. data/bin/build +0 -71
  25. data/bors.toml +0 -14
  26. data/examples/basic.rb +0 -15
  27. data/examples/consistency.rb +0 -114
  28. data/examples/dist_redis.rb +0 -43
  29. data/examples/incr-decr.rb +0 -17
  30. data/examples/list.rb +0 -26
  31. data/examples/pubsub.rb +0 -37
  32. data/examples/sentinel.rb +0 -41
  33. data/examples/sentinel/start +0 -49
  34. data/examples/sets.rb +0 -36
  35. data/examples/unicorn/config.ru +0 -3
  36. data/examples/unicorn/unicorn.rb +0 -20
  37. data/makefile +0 -74
  38. data/redis.gemspec +0 -42
  39. data/test/bitpos_test.rb +0 -63
  40. data/test/blocking_commands_test.rb +0 -40
  41. data/test/client_test.rb +0 -76
  42. data/test/cluster_abnormal_state_test.rb +0 -38
  43. data/test/cluster_blocking_commands_test.rb +0 -15
  44. data/test/cluster_client_internals_test.rb +0 -77
  45. data/test/cluster_client_key_hash_tags_test.rb +0 -88
  46. data/test/cluster_client_options_test.rb +0 -147
  47. data/test/cluster_client_pipelining_test.rb +0 -59
  48. data/test/cluster_client_replicas_test.rb +0 -36
  49. data/test/cluster_client_slots_test.rb +0 -94
  50. data/test/cluster_client_transactions_test.rb +0 -71
  51. data/test/cluster_commands_on_cluster_test.rb +0 -165
  52. data/test/cluster_commands_on_connection_test.rb +0 -40
  53. data/test/cluster_commands_on_geo_test.rb +0 -74
  54. data/test/cluster_commands_on_hashes_test.rb +0 -11
  55. data/test/cluster_commands_on_hyper_log_log_test.rb +0 -17
  56. data/test/cluster_commands_on_keys_test.rb +0 -134
  57. data/test/cluster_commands_on_lists_test.rb +0 -15
  58. data/test/cluster_commands_on_pub_sub_test.rb +0 -101
  59. data/test/cluster_commands_on_scripting_test.rb +0 -56
  60. data/test/cluster_commands_on_server_test.rb +0 -221
  61. data/test/cluster_commands_on_sets_test.rb +0 -39
  62. data/test/cluster_commands_on_sorted_sets_test.rb +0 -35
  63. data/test/cluster_commands_on_streams_test.rb +0 -196
  64. data/test/cluster_commands_on_strings_test.rb +0 -15
  65. data/test/cluster_commands_on_transactions_test.rb +0 -41
  66. data/test/cluster_commands_on_value_types_test.rb +0 -14
  67. data/test/command_map_test.rb +0 -28
  68. data/test/commands_on_geo_test.rb +0 -116
  69. data/test/commands_on_hashes_test.rb +0 -7
  70. data/test/commands_on_hyper_log_log_test.rb +0 -7
  71. data/test/commands_on_lists_test.rb +0 -7
  72. data/test/commands_on_sets_test.rb +0 -7
  73. data/test/commands_on_sorted_sets_test.rb +0 -7
  74. data/test/commands_on_strings_test.rb +0 -7
  75. data/test/commands_on_value_types_test.rb +0 -207
  76. data/test/connection_handling_test.rb +0 -275
  77. data/test/connection_test.rb +0 -57
  78. data/test/distributed_blocking_commands_test.rb +0 -52
  79. data/test/distributed_commands_on_hashes_test.rb +0 -21
  80. data/test/distributed_commands_on_hyper_log_log_test.rb +0 -26
  81. data/test/distributed_commands_on_lists_test.rb +0 -19
  82. data/test/distributed_commands_on_sets_test.rb +0 -105
  83. data/test/distributed_commands_on_sorted_sets_test.rb +0 -59
  84. data/test/distributed_commands_on_strings_test.rb +0 -79
  85. data/test/distributed_commands_on_value_types_test.rb +0 -129
  86. data/test/distributed_commands_requiring_clustering_test.rb +0 -162
  87. data/test/distributed_connection_handling_test.rb +0 -21
  88. data/test/distributed_internals_test.rb +0 -68
  89. data/test/distributed_key_tags_test.rb +0 -50
  90. data/test/distributed_persistence_control_commands_test.rb +0 -24
  91. data/test/distributed_publish_subscribe_test.rb +0 -90
  92. data/test/distributed_remote_server_control_commands_test.rb +0 -64
  93. data/test/distributed_scripting_test.rb +0 -100
  94. data/test/distributed_sorting_test.rb +0 -18
  95. data/test/distributed_test.rb +0 -56
  96. data/test/distributed_transactions_test.rb +0 -30
  97. data/test/encoding_test.rb +0 -14
  98. data/test/error_replies_test.rb +0 -57
  99. data/test/fork_safety_test.rb +0 -60
  100. data/test/helper.rb +0 -344
  101. data/test/helper_test.rb +0 -22
  102. data/test/internals_test.rb +0 -395
  103. data/test/lint/blocking_commands.rb +0 -174
  104. data/test/lint/hashes.rb +0 -203
  105. data/test/lint/hyper_log_log.rb +0 -74
  106. data/test/lint/lists.rb +0 -159
  107. data/test/lint/sets.rb +0 -282
  108. data/test/lint/sorted_sets.rb +0 -497
  109. data/test/lint/strings.rb +0 -348
  110. data/test/lint/value_types.rb +0 -130
  111. data/test/persistence_control_commands_test.rb +0 -24
  112. data/test/pipelining_commands_test.rb +0 -246
  113. data/test/publish_subscribe_test.rb +0 -280
  114. data/test/remote_server_control_commands_test.rb +0 -175
  115. data/test/scanning_test.rb +0 -407
  116. data/test/scripting_test.rb +0 -76
  117. data/test/sentinel_command_test.rb +0 -78
  118. data/test/sentinel_test.rb +0 -253
  119. data/test/sorting_test.rb +0 -57
  120. data/test/ssl_test.rb +0 -69
  121. data/test/support/cluster/orchestrator.rb +0 -199
  122. data/test/support/connection/hiredis.rb +0 -1
  123. data/test/support/connection/ruby.rb +0 -1
  124. data/test/support/connection/synchrony.rb +0 -17
  125. data/test/support/redis_mock.rb +0 -130
  126. data/test/support/ssl/gen_certs.sh +0 -31
  127. data/test/support/ssl/trusted-ca.crt +0 -25
  128. data/test/support/ssl/trusted-ca.key +0 -27
  129. data/test/support/ssl/trusted-cert.crt +0 -81
  130. data/test/support/ssl/trusted-cert.key +0 -28
  131. data/test/support/ssl/untrusted-ca.crt +0 -26
  132. data/test/support/ssl/untrusted-ca.key +0 -27
  133. data/test/support/ssl/untrusted-cert.crt +0 -82
  134. data/test/support/ssl/untrusted-cert.key +0 -28
  135. data/test/support/wire/synchrony.rb +0 -24
  136. data/test/support/wire/thread.rb +0 -5
  137. data/test/synchrony_driver.rb +0 -85
  138. data/test/test.conf.erb +0 -9
  139. data/test/thread_safety_test.rb +0 -60
  140. data/test/transactions_test.rb +0 -272
  141. data/test/unknown_commands_test.rb +0 -12
  142. data/test/url_param_test.rb +0 -136
@@ -1,162 +0,0 @@
1
- require_relative "helper"
2
-
3
- class TestDistributedCommandsRequiringClustering < Test::Unit::TestCase
4
-
5
- include Helper::Distributed
6
-
7
- def test_rename
8
- r.set("{qux}foo", "s1")
9
- r.rename "{qux}foo", "{qux}bar"
10
-
11
- assert_equal "s1", r.get("{qux}bar")
12
- assert_equal nil, r.get("{qux}foo")
13
- end
14
-
15
- def test_renamenx
16
- r.set("{qux}foo", "s1")
17
- r.set("{qux}bar", "s2")
18
-
19
- assert_equal false, r.renamenx("{qux}foo", "{qux}bar")
20
-
21
- assert_equal "s1", r.get("{qux}foo")
22
- assert_equal "s2", r.get("{qux}bar")
23
- end
24
-
25
- def test_brpoplpush
26
- r.rpush "{qux}foo", "s1"
27
- r.rpush "{qux}foo", "s2"
28
-
29
- assert_equal "s2", r.brpoplpush("{qux}foo", "{qux}bar", :timeout => 1)
30
- assert_equal ["s2"], r.lrange("{qux}bar", 0, -1)
31
- end
32
-
33
- def test_rpoplpush
34
- r.rpush "{qux}foo", "s1"
35
- r.rpush "{qux}foo", "s2"
36
-
37
- assert_equal "s2", r.rpoplpush("{qux}foo", "{qux}bar")
38
- assert_equal ["s2"], r.lrange("{qux}bar", 0, -1)
39
- assert_equal "s1", r.rpoplpush("{qux}foo", "{qux}bar")
40
- assert_equal ["s1", "s2"], r.lrange("{qux}bar", 0, -1)
41
- end
42
-
43
- def test_smove
44
- r.sadd "{qux}foo", "s1"
45
- r.sadd "{qux}bar", "s2"
46
-
47
- assert r.smove("{qux}foo", "{qux}bar", "s1")
48
- assert r.sismember("{qux}bar", "s1")
49
- end
50
-
51
- def test_sinter
52
- r.sadd "{qux}foo", "s1"
53
- r.sadd "{qux}foo", "s2"
54
- r.sadd "{qux}bar", "s2"
55
-
56
- assert_equal ["s2"], r.sinter("{qux}foo", "{qux}bar")
57
- end
58
-
59
- def test_sinterstore
60
- r.sadd "{qux}foo", "s1"
61
- r.sadd "{qux}foo", "s2"
62
- r.sadd "{qux}bar", "s2"
63
-
64
- r.sinterstore("{qux}baz", "{qux}foo", "{qux}bar")
65
-
66
- assert_equal ["s2"], r.smembers("{qux}baz")
67
- end
68
-
69
- def test_sunion
70
- r.sadd "{qux}foo", "s1"
71
- r.sadd "{qux}foo", "s2"
72
- r.sadd "{qux}bar", "s2"
73
- r.sadd "{qux}bar", "s3"
74
-
75
- assert_equal ["s1", "s2", "s3"], r.sunion("{qux}foo", "{qux}bar").sort
76
- end
77
-
78
- def test_sunionstore
79
- r.sadd "{qux}foo", "s1"
80
- r.sadd "{qux}foo", "s2"
81
- r.sadd "{qux}bar", "s2"
82
- r.sadd "{qux}bar", "s3"
83
-
84
- r.sunionstore("{qux}baz", "{qux}foo", "{qux}bar")
85
-
86
- assert_equal ["s1", "s2", "s3"], r.smembers("{qux}baz").sort
87
- end
88
-
89
- def test_sdiff
90
- r.sadd "{qux}foo", "s1"
91
- r.sadd "{qux}foo", "s2"
92
- r.sadd "{qux}bar", "s2"
93
- r.sadd "{qux}bar", "s3"
94
-
95
- assert_equal ["s1"], r.sdiff("{qux}foo", "{qux}bar")
96
- assert_equal ["s3"], r.sdiff("{qux}bar", "{qux}foo")
97
- end
98
-
99
- def test_sdiffstore
100
- r.sadd "{qux}foo", "s1"
101
- r.sadd "{qux}foo", "s2"
102
- r.sadd "{qux}bar", "s2"
103
- r.sadd "{qux}bar", "s3"
104
-
105
- r.sdiffstore("{qux}baz", "{qux}foo", "{qux}bar")
106
-
107
- assert_equal ["s1"], r.smembers("{qux}baz")
108
- end
109
-
110
- def test_sort
111
- r.set("{qux}foo:1", "s1")
112
- r.set("{qux}foo:2", "s2")
113
-
114
- r.rpush("{qux}bar", "1")
115
- r.rpush("{qux}bar", "2")
116
-
117
- assert_equal ["s1"], r.sort("{qux}bar", :get => "{qux}foo:*", :limit => [0, 1])
118
- assert_equal ["s2"], r.sort("{qux}bar", :get => "{qux}foo:*", :limit => [0, 1], :order => "desc alpha")
119
- end
120
-
121
- def test_sort_with_an_array_of_gets
122
- r.set("{qux}foo:1:a", "s1a")
123
- r.set("{qux}foo:1:b", "s1b")
124
-
125
- r.set("{qux}foo:2:a", "s2a")
126
- r.set("{qux}foo:2:b", "s2b")
127
-
128
- r.rpush("{qux}bar", "1")
129
- r.rpush("{qux}bar", "2")
130
-
131
- assert_equal [["s1a", "s1b"]], r.sort("{qux}bar", :get => ["{qux}foo:*:a", "{qux}foo:*:b"], :limit => [0, 1])
132
- assert_equal [["s2a", "s2b"]], r.sort("{qux}bar", :get => ["{qux}foo:*:a", "{qux}foo:*:b"], :limit => [0, 1], :order => "desc alpha")
133
- assert_equal [["s1a", "s1b"], ["s2a", "s2b"]], r.sort("{qux}bar", :get => ["{qux}foo:*:a", "{qux}foo:*:b"])
134
- end
135
-
136
- def test_sort_with_store
137
- r.set("{qux}foo:1", "s1")
138
- r.set("{qux}foo:2", "s2")
139
-
140
- r.rpush("{qux}bar", "1")
141
- r.rpush("{qux}bar", "2")
142
-
143
- r.sort("{qux}bar", :get => "{qux}foo:*", :store => "{qux}baz")
144
- assert_equal ["s1", "s2"], r.lrange("{qux}baz", 0, -1)
145
- end
146
-
147
- def test_bitop
148
- target_version "2.5.10" do
149
- r.set("{qux}foo", "a")
150
- r.set("{qux}bar", "b")
151
-
152
- r.bitop(:and, "{qux}foo&bar", "{qux}foo", "{qux}bar")
153
- assert_equal "\x60", r.get("{qux}foo&bar")
154
- r.bitop(:or, "{qux}foo|bar", "{qux}foo", "{qux}bar")
155
- assert_equal "\x63", r.get("{qux}foo|bar")
156
- r.bitop(:xor, "{qux}foo^bar", "{qux}foo", "{qux}bar")
157
- assert_equal "\x03", r.get("{qux}foo^bar")
158
- r.bitop(:not, "{qux}~foo", "{qux}foo")
159
- assert_equal "\x9E", r.get("{qux}~foo")
160
- end
161
- end
162
- end
@@ -1,21 +0,0 @@
1
- require_relative "helper"
2
-
3
- class TestDistributedConnectionHandling < Test::Unit::TestCase
4
-
5
- include Helper::Distributed
6
-
7
- def test_ping
8
- assert_equal ["PONG"], r.ping
9
- end
10
-
11
- def test_select
12
- r.set "foo", "bar"
13
-
14
- r.select 14
15
- assert_equal nil, r.get("foo")
16
-
17
- r.select 15
18
-
19
- assert_equal "bar", r.get("foo")
20
- end
21
- end
@@ -1,68 +0,0 @@
1
- require_relative "helper"
2
-
3
- class TestDistributedInternals < Test::Unit::TestCase
4
-
5
- include Helper::Distributed
6
-
7
- def test_provides_a_meaningful_inspect
8
- nodes = ["redis://127.0.0.1:#{PORT}/15", *NODES]
9
- redis = Redis::Distributed.new nodes
10
-
11
- assert_equal "#<Redis client v#{Redis::VERSION} for #{redis.nodes.map(&:id).join(', ')}>", redis.inspect
12
- end
13
-
14
- def test_default_as_urls
15
- nodes = ["redis://127.0.0.1:#{PORT}/15", *NODES]
16
- redis = Redis::Distributed.new nodes
17
- assert_equal ["redis://127.0.0.1:#{PORT}/15", *NODES], redis.nodes.map { |node| node._client.id }
18
- end
19
-
20
- def test_default_as_config_hashes
21
- nodes = [OPTIONS.merge(:host => '127.0.0.1'), OPTIONS.merge(:host => 'somehost', :port => PORT.next)]
22
- redis = Redis::Distributed.new nodes
23
- assert_equal ["redis://127.0.0.1:#{PORT}/15","redis://somehost:#{PORT.next}/15"], redis.nodes.map { |node| node._client.id }
24
- end
25
-
26
- def test_as_mix_and_match
27
- nodes = ["redis://127.0.0.1:7389/15", OPTIONS.merge(:host => 'somehost'), OPTIONS.merge(:host => 'somehost', :port => PORT.next)]
28
- redis = Redis::Distributed.new nodes
29
- assert_equal ["redis://127.0.0.1:7389/15", "redis://somehost:#{PORT}/15", "redis://somehost:#{PORT.next}/15"], redis.nodes.map { |node| node._client.id }
30
- end
31
-
32
- def test_override_id
33
- nodes = [OPTIONS.merge(:host => '127.0.0.1', :id => "test"), OPTIONS.merge( :host => 'somehost', :port => PORT.next, :id => "test1")]
34
- redis = Redis::Distributed.new nodes
35
- assert_equal redis.nodes.first._client.id, "test"
36
- assert_equal redis.nodes.last._client.id, "test1"
37
- assert_equal "#<Redis client v#{Redis::VERSION} for #{redis.nodes.map(&:id).join(', ')}>", redis.inspect
38
- end
39
-
40
- def test_can_be_duped_to_create_a_new_connection
41
- redis = Redis::Distributed.new(NODES)
42
-
43
- clients = redis.info[0]["connected_clients"].to_i
44
-
45
- r2 = redis.dup
46
- r2.ping
47
-
48
- assert_equal clients + 1, redis.info[0]["connected_clients"].to_i
49
- end
50
-
51
- def test_keeps_options_after_dup
52
- r1 = Redis::Distributed.new(NODES, :tag => /^(\w+):/)
53
-
54
- assert_raise(Redis::Distributed::CannotDistribute) do
55
- r1.sinter("foo", "bar")
56
- end
57
-
58
- assert_equal [], r1.sinter("baz:foo", "baz:bar")
59
-
60
- r2 = r1.dup
61
-
62
- assert_raise(Redis::Distributed::CannotDistribute) do
63
- r2.sinter("foo", "bar")
64
- end
65
-
66
- assert_equal [], r2.sinter("baz:foo", "baz:bar")
67
- end
68
- end
@@ -1,50 +0,0 @@
1
- require_relative "helper"
2
-
3
- class TestDistributedKeyTags < Test::Unit::TestCase
4
-
5
- include Helper
6
- include Helper::Distributed
7
-
8
- def test_hashes_consistently
9
- r1 = Redis::Distributed.new ["redis://127.0.0.1:#{PORT}/15", *NODES]
10
- r2 = Redis::Distributed.new ["redis://127.0.0.1:#{PORT}/15", *NODES]
11
- r3 = Redis::Distributed.new ["redis://127.0.0.1:#{PORT}/15", *NODES]
12
-
13
- assert_equal r1.node_for("foo").id, r2.node_for("foo").id
14
- assert_equal r1.node_for("foo").id, r3.node_for("foo").id
15
- end
16
-
17
- def test_allows_clustering_of_keys
18
- r = Redis::Distributed.new(NODES)
19
- r.add_node("redis://127.0.0.1:#{PORT}/14")
20
- r.flushdb
21
-
22
- 100.times do |i|
23
- r.set "{foo}users:#{i}", i
24
- end
25
-
26
- assert_equal [0, 100], r.nodes.map { |node| node.keys.size }
27
- end
28
-
29
- def test_distributes_keys_if_no_clustering_is_used
30
- r.add_node("redis://127.0.0.1:#{PORT}/14")
31
- r.flushdb
32
-
33
- r.set "users:1", 1
34
- r.set "users:4", 4
35
-
36
- assert_equal [1, 1], r.nodes.map { |node| node.keys.size }
37
- end
38
-
39
- def test_allows_passing_a_custom_tag_extractor
40
- r = Redis::Distributed.new(NODES, :tag => /^(.+?):/)
41
- r.add_node("redis://127.0.0.1:#{PORT}/14")
42
- r.flushdb
43
-
44
- 100.times do |i|
45
- r.set "foo:users:#{i}", i
46
- end
47
-
48
- assert_equal [0, 100], r.nodes.map { |node| node.keys.size }
49
- end
50
- end
@@ -1,24 +0,0 @@
1
- require_relative "helper"
2
-
3
- class TestDistributedPersistenceControlCommands < Test::Unit::TestCase
4
-
5
- include Helper::Distributed
6
-
7
- def test_save
8
- redis_mock(:save => lambda { "+SAVE" }) do |redis|
9
- assert_equal ["SAVE"], redis.save
10
- end
11
- end
12
-
13
- def test_bgsave
14
- redis_mock(:bgsave => lambda { "+BGSAVE" }) do |redis|
15
- assert_equal ["BGSAVE"], redis.bgsave
16
- end
17
- end
18
-
19
- def test_lastsave
20
- redis_mock(:lastsave => lambda { "+LASTSAVE" }) do |redis|
21
- assert_equal ["LASTSAVE"], redis.lastsave
22
- end
23
- end
24
- end
@@ -1,90 +0,0 @@
1
- require_relative "helper"
2
-
3
- class TestDistributedPublishSubscribe < Test::Unit::TestCase
4
-
5
- include Helper::Distributed
6
-
7
- def test_subscribe_and_unsubscribe
8
- assert_raise Redis::Distributed::CannotDistribute do
9
- r.subscribe("foo", "bar") { }
10
- end
11
-
12
- assert_raise Redis::Distributed::CannotDistribute do
13
- r.subscribe("{qux}foo", "bar") { }
14
- end
15
- end
16
-
17
- def test_subscribe_and_unsubscribe_with_tags
18
- @subscribed = false
19
- @unsubscribed = false
20
-
21
- wire = Wire.new do
22
- r.subscribe("foo") do |on|
23
- on.subscribe do |channel, total|
24
- @subscribed = true
25
- @t1 = total
26
- end
27
-
28
- on.message do |channel, message|
29
- if message == "s1"
30
- r.unsubscribe
31
- @message = message
32
- end
33
- end
34
-
35
- on.unsubscribe do |channel, total|
36
- @unsubscribed = true
37
- @t2 = total
38
- end
39
- end
40
- end
41
-
42
- # Wait until the subscription is active before publishing
43
- Wire.pass while !@subscribed
44
-
45
- Redis::Distributed.new(NODES).publish("foo", "s1")
46
-
47
- wire.join
48
-
49
- assert @subscribed
50
- assert_equal 1, @t1
51
- assert @unsubscribed
52
- assert_equal 0, @t2
53
- assert_equal "s1", @message
54
- end
55
-
56
- def test_subscribe_within_subscribe
57
- @channels = []
58
-
59
- wire = Wire.new do
60
- r.subscribe("foo") do |on|
61
- on.subscribe do |channel, total|
62
- @channels << channel
63
-
64
- r.subscribe("bar") if channel == "foo"
65
- r.unsubscribe if channel == "bar"
66
- end
67
- end
68
- end
69
-
70
- wire.join
71
-
72
- assert_equal ["foo", "bar"], @channels
73
- end
74
-
75
- def test_other_commands_within_a_subscribe
76
- assert_raise Redis::CommandError do
77
- r.subscribe("foo") do |on|
78
- on.subscribe do |channel, total|
79
- r.set("bar", "s2")
80
- end
81
- end
82
- end
83
- end
84
-
85
- def test_subscribe_without_a_block
86
- assert_raise LocalJumpError do
87
- r.subscribe("foo")
88
- end
89
- end
90
- end
@@ -1,64 +0,0 @@
1
- require_relative "helper"
2
-
3
- class TestDistributedRemoteServerControlCommands < Test::Unit::TestCase
4
-
5
- include Helper::Distributed
6
-
7
- def test_info
8
- keys = [
9
- "redis_version",
10
- "uptime_in_seconds",
11
- "uptime_in_days",
12
- "connected_clients",
13
- "used_memory",
14
- "total_connections_received",
15
- "total_commands_processed",
16
- ]
17
-
18
- infos = r.info
19
-
20
- infos.each do |info|
21
- keys.each do |k|
22
- msg = "expected #info to include #{k}"
23
- assert info.keys.include?(k), msg
24
- end
25
- end
26
- end
27
-
28
- def test_info_commandstats
29
- target_version "2.5.7" do
30
- r.nodes.each { |n| n.config(:resetstat) }
31
- r.ping # Executed on every node
32
-
33
- r.info(:commandstats).each do |info|
34
- assert_equal "1", info["ping"]["calls"]
35
- end
36
- end
37
- end
38
-
39
- def test_monitor
40
- begin
41
- r.monitor
42
- rescue Exception => ex
43
- ensure
44
- assert ex.kind_of?(NotImplementedError)
45
- end
46
- end
47
-
48
- def test_echo
49
- assert_equal ["foo bar baz\n"], r.echo("foo bar baz\n")
50
- end
51
-
52
- def test_time
53
- target_version "2.5.4" do
54
- # Test that the difference between the time that Ruby reports and the time
55
- # that Redis reports is minimal (prevents the test from being racy).
56
- r.time.each do |rv|
57
- redis_usec = rv[0] * 1_000_000 + rv[1]
58
- ruby_usec = Integer(Time.now.to_f * 1_000_000)
59
-
60
- assert 500_000 > (ruby_usec - redis_usec).abs
61
- end
62
- end
63
- end
64
- end