RSpec: how to test Rails logger message expectations?

While I agree you generally don’t want to test loggers, there are times it may be useful.

I have had success with expectations on Rails.logger.

Using RSpec’s deprecated should syntax:

Rails.logger.should_receive(:info).with("some message")

Using RSpec’s newer expect syntax:

expect(Rails.logger).to receive(:info).with("some message")

Note: In controller and model specs, you have to put this line before the message is logged. If you put it after, you’ll get an error message like this:

Failure/Error: expect(Rails.logger).to receive(:info).with("some message")
       (#<ActiveSupport::Logger:0x007f27f72136c8>).info("some message")
           expected: 1 time with arguments: ("some message")
           received: 0 times

Leave a Comment

Hata!: SQLSTATE[HY000] [1045] Access denied for user 'divattrend_liink'@'localhost' (using password: YES)