加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

ruby-on-rails – RSpec:测试邮件程序只调用一次

发布时间:2020-12-17 01:42:37 所属栏目:百科 来源:网络整理
导读:我有一个看起来像这样的邮件: class EventMailer BaseMailer def event_added(user_id,event_id) # do stuff and email user about the event endend 我在Event类中调用了这个EventMailer: class Event Task def notify_by_email(user) EmailLog.send_once
我有一个看起来像这样的邮件:

class EventMailer < BaseMailer
  def event_added(user_id,event_id)
    # do stuff and email user about the event
  end
end

我在Event类中调用了这个EventMailer:

class Event < Task
  def notify_by_email(user)
    EmailLog.send_once(user.id,id) do
      EventMailer.delay(queue: 'mailer').event_added(user.id,id)
    end
  end
end

EmailLog是一个记录已发送电子邮件的类. .delay由Sidekiq添加.

但是当我尝试测试每个事件和用户只调用一次#notify_by_email时,我的规范失败了:

1) Event#notify_by_email only sends once per user
     Failure/Error: expect(EventMailer).to receive(:event_added).once
       (<EventMailer (class)>).event_added(any args)
           expected: 1 time with any arguments
           received: 0 times with any arguments

规范如下:

let(:owner) { User.make! }
let(:product) { Product.make! }
let(:event) { Task.make!(user: owner,product: product) }

describe '#notify_by_email' do
  before do
    EventMailer.stub(:delay).and_return(EventMailer)
  end

  it 'only sends once per user' do
    event.notify_by_email(owner)
    event.notify_by_email(owner)

    expect(EventMailer).to receive(:event_added).once
  end
end

有关此规范失败的原因以及我如何修复它的任何见解?奇怪的是,如果我将一个puts语句放在传递给EmailLog.send_once的块中,它只打印一次,规范仍然报告没有调用EventMailer.event_added.

解决方法

您的期望应在您正在测试的代码之前声明.使用expect(…).接收(…)基本上意味着“应该在此规范的现在和结束之间接收此消息”.因为期望是您的规范的最后一行,它失败了.

尝试之前移动它,你应该好好去:

it 'only sends once per user' do
  expect(EventMailer).to receive(:event_added).once

  event.notify_by_email(owner)
  event.notify_by_email(owner)
end

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读