Jasmine 期望逻辑(期望 A OR B)

时间:2023-02-15
本文介绍了Jasmine 期望逻辑(期望 A OR B)的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着跟版网的小编来一起学习吧!

问题描述

如果满足两个期望之一,我需要将测试设置为成功:

I need to set the test to succeed if one of the two expectations is met:

expect(mySpy.mostRecentCall.args[0]).toEqual(jasmine.any(Number));
expect(mySpy.mostRecentCall.args[0]).toEqual(false);

我希望它看起来像这样:

I expected it to look like this:

expect(mySpy.mostRecentCall.args[0]).toEqual(jasmine.any(Number)).or.toEqual(false);

我在文档中遗漏了什么还是我必须编写自己的匹配器?

Is there anything I missed in the docs or do I have to write my own matcher?

推荐答案

注意:此解决方案包含 Jasmine v2.0 之前版本的语法.有关自定义匹配器的更多信息,请参阅:https://jasmine.github.io/2.0/custom_matcher.html

Note: This solution contains syntax for versions prior to Jasmine v2.0. For more information on custom matchers now, see: https://jasmine.github.io/2.0/custom_matcher.html

Matchers.js 仅适用于单个结果修饰符" - not:

Matchers.js works with a single 'result modifier' only - not:

核心/Spec.js:

jasmine.Spec.prototype.expect = function(actual) {
  var positive = new (this.getMatchersClass_())(this.env, actual, this);
  positive.not = new (this.getMatchersClass_())(this.env, actual, this, true);
  return positive;

core/Matchers.js:

jasmine.Matchers = function(env, actual, spec, opt_isNot) {
  ...
  this.isNot = opt_isNot || false;
}
...
jasmine.Matchers.matcherFn_ = function(matcherName, matcherFunction) {
  return function() {
    ...
    if (this.isNot) {
      result = !result;
    }
  }
}

所以看起来您确实需要编写自己的匹配器(从 beforeit 块中获取正确的 this).例如:

So it looks like you indeed need to write your own matcher (from within a before or it bloc for correct this). For example:

this.addMatchers({
   toBeAnyOf: function(expecteds) {
      var result = false;
      for (var i = 0, l = expecteds.length; i < l; i++) {
        if (this.actual === expecteds[i]) {
          result = true;
          break;
        }
      }
      return result;
   }
});

这篇关于Jasmine 期望逻辑(期望 A OR B)的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持跟版网!

上一篇:我们如何在 Jasmine 中以编程方式清除间谍? 下一篇:没有使用 jasmine.js 和 sinon.js 调用主干.js 点击事件间谍

相关文章

最新文章