强制失败 Jasmine 测试

Force-failing a Jasmine test(强制失败 Jasmine 测试)
本文介绍了强制失败 Jasmine 测试的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着跟版网的小编来一起学习吧!

问题描述

如果我在测试中包含永远不会到达的代码(例如,promise 序列的 fail 子句),我该如何强制测试失败?

If I have code in a test that should never be reached (for example the fail clause of a promise sequence), how can I force-fail the test?

我使用类似 expect(true).toBe(false); 之类的东西,但这并不漂亮.

I use something like expect(true).toBe(false); but this is not pretty.

另一种方法是等待测试超时,我想避免这种情况(因为它很慢).

The alternative is waiting for the test to timeout, which I want to avoid (because it is slow).

推荐答案

Jasmine 提供了一个全局方法 fail(),可以在 spec 块中使用 it()并且还允许使用自定义错误消息:

Jasmine provides a global method fail(), which can be used inside spec blocks it() and also allows to use custom error message:

it('should finish successfully', function (done) {
  MyService.getNumber()
  .success(function (number) {
    expect(number).toBe(2);
    done();
  })
  .fail(function (err) {
    fail('Unwanted code branch');
  });
});

这是 Jasmine 的内置功能,与我在下面提到的错误"方法相比,它在任何地方都能正常工作.

This is built-in Jasmine functionality and it works fine everywhere in comparison with the 'error' method I've mentioned below.

更新前:

您可以从该代码分支抛出错误,它会立即使规范失败,您将能够提供自定义错误消息:

You can throw an error from that code branch, it will fail a spec immediately and you'll be able to provide custom error message:

it('should finish successfully', function (done) {
  MyService.getNumber()
  .success(function (number) {
    expect(number).toBe(2);
    done();
  })
  .fail(function (err) {
    throw new Error('Unwanted code branch');
  });
});

但是你应该小心,如果你想从 Promise 成功处理程序 then() 抛出一个错误,因为错误会被吞没在那里并且永远不会出现.此外,您应该注意应用程序中可能存在的错误处理程序,它们可能会在您的应用程序中捕获此错误,因此它不会导致测试失败.

But you should be careful, if you want to throw an error from Promise success handler then(), because the error will be swallowed in there and will never come up. Also you should be aware of the possible error handlers in your app, which might catch this error inside your app, so as a result it won't be able to fail a test.

这篇关于强制失败 Jasmine 测试的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持跟版网!

本站部分内容来源互联网,如果有图片或者内容侵犯了您的权益,请联系我们,我们会在确认后第一时间进行删除!

相关文档推荐

Drag amp; Drop with Protractor by Repeater(拖动amp;通过中继器使用量角器掉落)
Getting the position of the element in a list when it#39;s drag/dropped (ui.sortable)(拖放时获取元素在列表中的位置(ui.sortable))
Detecting HTML5 Drag And Drop support in javascript(在 javascript 中检测 HTML5 拖放支持)
HTML5 drop event doesn#39;t work unless dragover is handled(除非处理了拖动,否则 HTML5 放置事件不起作用)
How to use jQuery#39;s drop event to upload files dragged from the desktop?(如何使用 jQuery 的 drop 事件上传从桌面拖动的文件?)
Drop image into contenteditable in Chrome to the cursor(将图像拖放到 Chrome 中的 contenteditable 到光标处)