2

在测试用例中,我们使用断言来处理错误。将它们的返回值与我们定义的匹配,测试将通过。就像我们有一个参数错误一样,我们使用这个:

 assert_raise ArgumentError, "argument error", fn ->

这将起作用并且测试将通过。如果我们有ArgumentError. 情况也是如此RuntimeError

但是,如果我们有像这样的长错误消息:

 exception Postgrex.Error (ERROR 42703 (undefined_column): column 
 j0.rating does not exist)

我们如何在测试用例中处理这些长异常消息?

谢谢

4

1 回答 1

3

如果您不想在异常中声明消息,可以调用assert_raise/2

assert_raise Postgrex.Error, fn ->
  ...
end

如果您只想匹配异常消息的一部分,可以将正则表达式传递给assert_raise/3

assert_raise Postgrex.Error, ~r/undefined_column/, fn ->
  ...
end
于 2018-01-19T07:53:38.480 回答