2019-04-30 08:27:42 +08:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2016-03-02 22:01:48 +08:00
|
|
|
require 'rails_helper'
|
|
|
|
|
|
|
|
describe DiscourseRedis do
|
2020-06-23 08:41:10 +08:00
|
|
|
it "ignore_readonly returns nil from a pure exception" do
|
|
|
|
result = DiscourseRedis.ignore_readonly { raise Redis::CommandError.new("READONLY") }
|
|
|
|
expect(result).to eq(nil)
|
|
|
|
end
|
2017-10-25 10:19:43 +08:00
|
|
|
|
2020-06-23 08:41:10 +08:00
|
|
|
describe 'redis commands' do
|
|
|
|
let(:raw_redis) { Redis.new(DiscourseRedis.config) }
|
2017-08-02 13:32:01 +08:00
|
|
|
|
2020-06-23 08:41:10 +08:00
|
|
|
before do
|
|
|
|
raw_redis.flushdb
|
|
|
|
end
|
2017-08-02 13:32:01 +08:00
|
|
|
|
2020-06-23 08:41:10 +08:00
|
|
|
after do
|
|
|
|
raw_redis.flushdb
|
|
|
|
end
|
2017-08-02 13:32:01 +08:00
|
|
|
|
2020-06-23 08:41:10 +08:00
|
|
|
describe 'when namespace is enabled' do
|
|
|
|
let(:redis) { DiscourseRedis.new }
|
2017-08-02 13:32:01 +08:00
|
|
|
|
2020-06-23 08:41:10 +08:00
|
|
|
it 'should append namespace to the keys' do
|
|
|
|
raw_redis.set('default:key', 1)
|
|
|
|
raw_redis.set('test:key2', 1)
|
2017-08-02 13:32:01 +08:00
|
|
|
|
2020-06-23 08:41:10 +08:00
|
|
|
expect(redis.keys).to include('key')
|
|
|
|
expect(redis.keys).to_not include('key2')
|
|
|
|
expect(redis.scan_each.to_a).to eq(['key'])
|
2018-12-15 08:53:52 +08:00
|
|
|
|
2020-06-23 08:41:10 +08:00
|
|
|
redis.scan_each.each do |key|
|
|
|
|
expect(key).to eq('key')
|
|
|
|
end
|
2017-08-02 13:32:01 +08:00
|
|
|
|
2020-06-23 08:41:10 +08:00
|
|
|
redis.del('key')
|
2017-08-02 13:32:01 +08:00
|
|
|
|
2020-06-23 08:41:10 +08:00
|
|
|
expect(raw_redis.get('default:key')).to eq(nil)
|
|
|
|
expect(redis.scan_each.to_a).to eq([])
|
2017-08-02 13:32:01 +08:00
|
|
|
|
2020-06-23 08:41:10 +08:00
|
|
|
raw_redis.set('default:key1', '1')
|
|
|
|
raw_redis.set('default:key2', '2')
|
2017-08-02 13:32:01 +08:00
|
|
|
|
2020-06-23 08:41:10 +08:00
|
|
|
expect(redis.mget('key1', 'key2')).to eq(['1', '2'])
|
|
|
|
expect(redis.scan_each.to_a).to contain_exactly('key1', 'key2')
|
2017-08-02 13:32:01 +08:00
|
|
|
end
|
2020-06-23 08:41:10 +08:00
|
|
|
end
|
2017-08-02 13:32:01 +08:00
|
|
|
|
2020-06-23 08:41:10 +08:00
|
|
|
describe 'when namespace is disabled' do
|
|
|
|
let(:redis) { DiscourseRedis.new(nil, namespace: false) }
|
2017-08-02 13:32:01 +08:00
|
|
|
|
2020-06-23 08:41:10 +08:00
|
|
|
it 'should not append any namespace to the keys' do
|
|
|
|
raw_redis.set('default:key', 1)
|
|
|
|
raw_redis.set('test:key2', 1)
|
2017-08-02 13:32:01 +08:00
|
|
|
|
2020-06-23 08:41:10 +08:00
|
|
|
expect(redis.keys).to include('default:key', 'test:key2')
|
2017-08-02 13:32:01 +08:00
|
|
|
|
2020-06-23 08:41:10 +08:00
|
|
|
redis.del('key')
|
2017-08-02 13:32:01 +08:00
|
|
|
|
2020-06-23 08:41:10 +08:00
|
|
|
expect(raw_redis.get('key')).to eq(nil)
|
2017-08-02 13:32:01 +08:00
|
|
|
|
2020-06-23 08:41:10 +08:00
|
|
|
raw_redis.set('key1', '1')
|
|
|
|
raw_redis.set('key2', '2')
|
2017-08-02 13:32:01 +08:00
|
|
|
|
2020-06-23 08:41:10 +08:00
|
|
|
expect(redis.mget('key1', 'key2')).to eq(['1', '2'])
|
|
|
|
end
|
2017-08-02 13:32:01 +08:00
|
|
|
|
2020-06-23 08:41:10 +08:00
|
|
|
it 'should noop a readonly redis' do
|
|
|
|
expect(Discourse.recently_readonly?).to eq(false)
|
2017-08-02 13:32:01 +08:00
|
|
|
|
2020-06-23 08:41:10 +08:00
|
|
|
redis.without_namespace
|
|
|
|
.expects(:set)
|
|
|
|
.raises(Redis::CommandError.new("READONLY"))
|
2017-08-02 13:32:01 +08:00
|
|
|
|
2020-06-23 08:41:10 +08:00
|
|
|
redis.set('key', 1)
|
2017-08-02 13:32:01 +08:00
|
|
|
|
2020-06-23 08:41:10 +08:00
|
|
|
expect(Discourse.recently_readonly?).to eq(true)
|
2017-08-02 13:32:01 +08:00
|
|
|
end
|
|
|
|
end
|
2021-10-06 22:42:04 +08:00
|
|
|
|
|
|
|
describe "#eval" do
|
|
|
|
it "keys and arvg are passed correcty" do
|
|
|
|
keys = ["key1", "key2"]
|
|
|
|
argv = ["arg1", "arg2"]
|
|
|
|
|
|
|
|
expect(Discourse.redis.eval(
|
|
|
|
"return { KEYS, ARGV };",
|
|
|
|
keys: keys,
|
|
|
|
argv: argv,
|
|
|
|
)).to eq([keys, argv])
|
|
|
|
|
|
|
|
expect(Discourse.redis.eval(
|
|
|
|
"return { KEYS, ARGV };",
|
|
|
|
keys,
|
|
|
|
argv: argv,
|
|
|
|
)).to eq([keys, argv])
|
|
|
|
|
|
|
|
expect(Discourse.redis.eval(
|
|
|
|
"return { KEYS, ARGV };",
|
|
|
|
keys,
|
|
|
|
argv,
|
|
|
|
)).to eq([keys, argv])
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe "#evalsha" do
|
|
|
|
it "keys and arvg are passed correcty" do
|
|
|
|
keys = ["key1", "key2"]
|
|
|
|
argv = ["arg1", "arg2"]
|
|
|
|
|
|
|
|
script = "return { KEYS, ARGV };"
|
|
|
|
Discourse.redis.script(:load, script)
|
|
|
|
sha = Digest::SHA1.hexdigest(script)
|
|
|
|
expect(Discourse.redis.evalsha(
|
|
|
|
sha,
|
|
|
|
keys: keys,
|
|
|
|
argv: argv,
|
|
|
|
)).to eq([keys, argv])
|
|
|
|
|
|
|
|
expect(Discourse.redis.evalsha(
|
|
|
|
sha,
|
|
|
|
keys,
|
|
|
|
argv: argv,
|
|
|
|
)).to eq([keys, argv])
|
|
|
|
|
|
|
|
expect(Discourse.redis.evalsha(
|
|
|
|
sha,
|
|
|
|
keys,
|
|
|
|
argv,
|
|
|
|
)).to eq([keys, argv])
|
|
|
|
end
|
|
|
|
end
|
2020-06-23 08:41:10 +08:00
|
|
|
end
|
2016-03-02 22:01:48 +08:00
|
|
|
end
|