Lapine
Speak to RabbitMQ. This gem serves as a wrapper for publishing messages to RabbitMQ via the Bunny gem, and for consuming messages using the AMQP gem.
Configuration
Initialization can be done inline in a daemon, or if used in Rails
an initializer should be made at config/initializers/lapine.rb
Register a connection. This connection should be given a name, and a hash of connection options that will be passed through to Bunny.
Lapine.add_connection 'my-connection', { host: 'my-rabbitmq.mine.com', port: 5672, user: 'rabbit', password: 'meow' }
Then register an exchange.
Lapine.add_exchange 'efrafa', durable: true, connection: 'my-connection', # required type: 'topic' # required
Publisher Usage
Define a class that configures which exchange is used. This class
must define #to_hash
require 'lapine' class Worker include Lapine::Publisher exchange 'efrafa' def initialize(action) @action = action end def to_hash { 'action' => @action } end end
This class can be used to publish messages onto its exchange:
Worker.new('dig').publish
Publishing can take a routing key for topic exchanges:
Worker.new('dig').publish('rabbits.drones')
Note that the #initialize method and the contents of #to_hash
are arbitrary.
Consumer Usage
Please see the Lapine wiki for documentation on defining and configuring consumers.
But... WHY
- This should be dead simple, but everything else was either too complex or assumed very specific configurations different from what we want.
Testing
Lapine comes with helpers to stub out calls to RabbitMQ. This allows you to write tests using Lapine, without having to actually run RabbitMQ in your test suite.
require 'lapine/test/rspec_helper' RSpec.configure do |config| config.include Lapine::Test::RSpecHelper, fake_rabbit: true config.before :each, :fake_rabbit do |example| Lapine::Test::RSpecHelper.setup(example) end config.after :each, :fake_rabbit do Lapine::Test::RSpecHelper.teardown end end
An example test would look something like this:
RSpec.describe MyPublisher, fake_rabbit: true do let(:exchange) { Lapine.find_exchange('my.topic') } let(:queue) { exchange.channel.queue.bind(exchange) } describe 'publishing' do it 'adds a message to a queue' do MyPublisher.new.publish('my.things') expect(queue.message_count).to eq(1) end end end
Contributing
- Fork it ( https://github.com/[my-github-username]/lapine/fork )
- Create your feature branch (
git checkout -b my-new-feature) - Commit your changes (
git commit -am 'Add some feature') - Push to the branch (
git push origin my-new-feature) - Create a new Pull Request