| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301 | 'use strict';Object.defineProperty(exports, '__esModule', {  value: true});exports.stringNotMatching = exports.stringMatching = exports.stringNotContaining = exports.stringContaining = exports.objectNotContaining = exports.objectContaining = exports.arrayNotContaining = exports.arrayContaining = exports.anything = exports.any = exports.AsymmetricMatcher = void 0;var _jasmineUtils = require('./jasmineUtils');var _utils = require('./utils');var Symbol = global['jest-symbol-do-not-touch'] || global.Symbol;function _defineProperty(obj, key, value) {  if (key in obj) {    Object.defineProperty(obj, key, {      value: value,      enumerable: true,      configurable: true,      writable: true    });  } else {    obj[key] = value;  }  return obj;}class AsymmetricMatcher {  constructor(sample) {    _defineProperty(this, 'sample', void 0);    _defineProperty(this, '$$typeof', void 0);    _defineProperty(this, 'inverse', void 0);    this.$$typeof = Symbol.for('jest.asymmetricMatcher');    this.sample = sample;  }}exports.AsymmetricMatcher = AsymmetricMatcher;class Any extends AsymmetricMatcher {  constructor(sample) {    if (typeof sample === 'undefined') {      throw new TypeError(        'any() expects to be passed a constructor function. ' +          'Please pass one or use anything() to match any object.'      );    }    super(sample);  }  asymmetricMatch(other) {    if (this.sample == String) {      return typeof other == 'string' || other instanceof String;    }    if (this.sample == Number) {      return typeof other == 'number' || other instanceof Number;    }    if (this.sample == Function) {      return typeof other == 'function' || other instanceof Function;    }    if (this.sample == Object) {      return typeof other == 'object';    }    if (this.sample == Boolean) {      return typeof other == 'boolean';    }    return other instanceof this.sample;  }  toString() {    return 'Any';  }  getExpectedType() {    if (this.sample == String) {      return 'string';    }    if (this.sample == Number) {      return 'number';    }    if (this.sample == Function) {      return 'function';    }    if (this.sample == Object) {      return 'object';    }    if (this.sample == Boolean) {      return 'boolean';    }    return (0, _jasmineUtils.fnNameFor)(this.sample);  }  toAsymmetricMatcher() {    return 'Any<' + (0, _jasmineUtils.fnNameFor)(this.sample) + '>';  }}class Anything extends AsymmetricMatcher {  asymmetricMatch(other) {    return !(0, _jasmineUtils.isUndefined)(other) && other !== null;  }  toString() {    return 'Anything';  } // No getExpectedType method, because it matches either null or undefined.  toAsymmetricMatcher() {    return 'Anything';  }}class ArrayContaining extends AsymmetricMatcher {  constructor(sample, inverse = false) {    super(sample);    this.inverse = inverse;  }  asymmetricMatch(other) {    if (!Array.isArray(this.sample)) {      throw new Error(        `You must provide an array to ${this.toString()}, not '` +          typeof this.sample +          "'."      );    }    const result =      this.sample.length === 0 ||      (Array.isArray(other) &&        this.sample.every(item =>          other.some(another => (0, _jasmineUtils.equals)(item, another))        ));    return this.inverse ? !result : result;  }  toString() {    return `Array${this.inverse ? 'Not' : ''}Containing`;  }  getExpectedType() {    return 'array';  }}class ObjectContaining extends AsymmetricMatcher {  constructor(sample, inverse = false) {    super(sample);    this.inverse = inverse;  }  asymmetricMatch(other) {    if (typeof this.sample !== 'object') {      throw new Error(        `You must provide an object to ${this.toString()}, not '` +          typeof this.sample +          "'."      );    }    if (this.inverse) {      for (const property in this.sample) {        if (          (0, _jasmineUtils.hasProperty)(other, property) &&          (0, _jasmineUtils.equals)(this.sample[property], other[property]) &&          !(0, _utils.emptyObject)(this.sample[property]) &&          !(0, _utils.emptyObject)(other[property])        ) {          return false;        }      }      return true;    } else {      for (const property in this.sample) {        if (          !(0, _jasmineUtils.hasProperty)(other, property) ||          !(0, _jasmineUtils.equals)(this.sample[property], other[property])        ) {          return false;        }      }      return true;    }  }  toString() {    return `Object${this.inverse ? 'Not' : ''}Containing`;  }  getExpectedType() {    return 'object';  }}class StringContaining extends AsymmetricMatcher {  constructor(sample, inverse = false) {    if (!(0, _jasmineUtils.isA)('String', sample)) {      throw new Error('Expected is not a string');    }    super(sample);    this.inverse = inverse;  }  asymmetricMatch(other) {    const result =      (0, _jasmineUtils.isA)('String', other) && other.includes(this.sample);    return this.inverse ? !result : result;  }  toString() {    return `String${this.inverse ? 'Not' : ''}Containing`;  }  getExpectedType() {    return 'string';  }}class StringMatching extends AsymmetricMatcher {  constructor(sample, inverse = false) {    if (      !(0, _jasmineUtils.isA)('String', sample) &&      !(0, _jasmineUtils.isA)('RegExp', sample)    ) {      throw new Error('Expected is not a String or a RegExp');    }    super(new RegExp(sample));    this.inverse = inverse;  }  asymmetricMatch(other) {    const result =      (0, _jasmineUtils.isA)('String', other) && this.sample.test(other);    return this.inverse ? !result : result;  }  toString() {    return `String${this.inverse ? 'Not' : ''}Matching`;  }  getExpectedType() {    return 'string';  }}const any = expectedObject => new Any(expectedObject);exports.any = any;const anything = () => new Anything();exports.anything = anything;const arrayContaining = sample => new ArrayContaining(sample);exports.arrayContaining = arrayContaining;const arrayNotContaining = sample => new ArrayContaining(sample, true);exports.arrayNotContaining = arrayNotContaining;const objectContaining = sample => new ObjectContaining(sample);exports.objectContaining = objectContaining;const objectNotContaining = sample => new ObjectContaining(sample, true);exports.objectNotContaining = objectNotContaining;const stringContaining = expected => new StringContaining(expected);exports.stringContaining = stringContaining;const stringNotContaining = expected => new StringContaining(expected, true);exports.stringNotContaining = stringNotContaining;const stringMatching = expected => new StringMatching(expected);exports.stringMatching = stringMatching;const stringNotMatching = expected => new StringMatching(expected, true);exports.stringNotMatching = stringNotMatching;
 |