redis 4.1.0.beta1 → 4.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
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