gpt4 book ai didi

ruby-on-rails - rspec 中的操作邮件链接检查

转载 作者:行者123 更新时间:2023-12-04 05:59:03 28 4
gpt4 key购买 nike

我在我的 rspec 测试中进行了这样的比较:

expect(new_mail.body.encoded).to match(url_for(controller:'some_controller',action:'some_action',some_param:some_param))

但它失败了,因为 ActionMailer 将 html 正文编码为如下所示:
   +<a href=3D"http://localhost:3000/some_controller/some_action/wgt1p468ersmkq=
+gbvmfv5wgmifj13u894dfjrhc0hzczk71pcw3hrk5907iqfolc6onhxvik6apuuwgm1rng7ro=
+rt8qih43thql3spyp5ajjdugy9jvx0xc5hvpi015z" style=3D"display: inline-block=
+; background-color: #71B344; color: #FFF; border-radius: 4px; font-weight=
+: bold; text-decoration: none; padding: 6px 12px; white-space: nowrap">
+ Go to Your Account
+ </a>

如何比较邮件正文中的预期链接和编码链接?

最佳答案

您可以使用 new_mail.body.to_s而是获得非编码版本,如 Guide to Rails Testing 所示.

您也可以使用 Capybara 对呈现的电子邮件(或 any html fragment )进行断言,如果您真的想确保链接在那里,这比仅使用字符串匹配更好:

let(:email){ Capybara::Node::Simple.new(new_mail.body.to_s) }

it "has a link" do
url = url_for(controller:'some_controller',action:'some_action',some_param:some_param)
expect(email).to have_link('A link', href: url)
end

补充:

要从多部分电子邮件中获取正确的部分:
def get_message_part(mail, content_type)
mail.body.parts.find { |p| p.content_type.match content_type }.body.raw_source
end

let(:email) { Capybara::Node::Simple.new(get_message_part(new_mail, /html/)) }

关于ruby-on-rails - rspec 中的操作邮件链接检查,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29753123/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com