Sha256: c8b67bbbd824490d3a29c263feb580ec748b834b88768be9590f455e87f71f7f
Contents?: true
Size: 1.48 KB
Versions: 1
Compression:
Stored size: 1.48 KB
Contents
# frozen_string_literal: true require "spec_helper" describe Sidekiq::Grouping::Redis do include Sidekiq::Grouping::RedisDispatcher subject(:redis_service) { described_class.new } let(:queue_name) { "my_queue" } let(:key) { "batching:#{queue_name}" } let(:unique_key) { "batching:#{queue_name}:unique_messages" } describe "#push_msg" do it "adds message to queue", :aggregate_failures do redis_service.push_msg(queue_name, "My message") expect(redis_call(:llen, key)).to eq 1 expect(redis_call(:lrange, key, 0, 1)).to eq ["My message"] expect(redis_call(:smembers, unique_key)).to eq [] end it "remembers unique message if specified" do redis_service.push_msg(queue_name, "My message", remember_unique: true) expect(redis_call(:smembers, unique_key)).to eq ["My message"] end end describe "#pluck" do it "removes messages from queue" do redis_service.push_msg(queue_name, "Message 1") redis_service.push_msg(queue_name, "Message 2") redis_service.pluck(queue_name, 2) expect(redis_call(:llen, key)).to eq 0 end it "forgets unique messages", :aggregate_failures do redis_service.push_msg(queue_name, "Message 1", remember_unique: true) redis_service.push_msg(queue_name, "Message 2", remember_unique: true) expect(redis_call(:scard, unique_key)).to eq 2 redis_service.pluck(queue_name, 2) expect(redis_call(:smembers, unique_key)).to eq [] end end end
Version data entries
1 entries across 1 versions & 1 rubygems
Version | Path |
---|---|
sidekiq-grouping-1.3.0 | spec/modules/redis_spec.rb |