GT2/GT2-Android/node_modules/expect/build/asymmetric_matchers.js

250 lines
5.1 KiB
JavaScript

'use strict';Object.defineProperty(exports, "__esModule", { value: true });exports.stringMatching = exports.stringContaining = exports.objectContaining = exports.arrayContaining = exports.anything = exports.any = undefined;
var _jasmine_utils = require('./jasmine_utils');
class AsymmetricMatcher {
constructor() {
this.$$typeof = Symbol.for('jest.asymmetricMatcher');
}} /**
* Copyright (c) 2014-present, Facebook, Inc. All rights reserved.
*
* This source code is licensed under the MIT license found in the
* LICENSE file in the root directory of this source tree.
*
*
*/class Any extends AsymmetricMatcher {constructor(sample) {super();
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.');
}
this.sample = 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, _jasmine_utils.fnNameFor)(this.sample);
}
toAsymmetricMatcher() {
return 'Any<' + (0, _jasmine_utils.fnNameFor)(this.sample) + '>';
}}
class Anything extends AsymmetricMatcher {
asymmetricMatch(other) {
return !(0, _jasmine_utils.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) {
super();
this.sample = sample;
}
asymmetricMatch(other) {
if (!Array.isArray(this.sample)) {
throw new Error(
"You must provide an array to ArrayContaining, not '" +
typeof this.sample +
"'.");
}
return (
this.sample.length === 0 ||
Array.isArray(other) &&
this.sample.every(item => other.some(another => (0, _jasmine_utils.equals)(item, another))));
}
toString() {
return 'ArrayContaining';
}
getExpectedType() {
return 'array';
}}
class ObjectContaining extends AsymmetricMatcher {
constructor(sample) {
super();
this.sample = sample;
}
asymmetricMatch(other) {
if (typeof this.sample !== 'object') {
throw new Error(
"You must provide an object to ObjectContaining, not '" +
typeof this.sample +
"'.");
}
for (const property in this.sample) {
if (
!(0, _jasmine_utils.hasProperty)(other, property) ||
!(0, _jasmine_utils.equals)(this.sample[property], other[property]))
{
return false;
}
}
return true;
}
toString() {
return 'ObjectContaining';
}
getExpectedType() {
return 'object';
}}
class StringContaining extends AsymmetricMatcher {
constructor(sample) {
super();
if (!(0, _jasmine_utils.isA)('String', sample)) {
throw new Error('Expected is not a string');
}
this.sample = sample;
}
asymmetricMatch(other) {
if (!(0, _jasmine_utils.isA)('String', other)) {
return false;
}
return other.includes(this.sample);
}
toString() {
return 'StringContaining';
}
getExpectedType() {
return 'string';
}}
class StringMatching extends AsymmetricMatcher {
constructor(sample) {
super();
if (!(0, _jasmine_utils.isA)('String', sample) && !(0, _jasmine_utils.isA)('RegExp', sample)) {
throw new Error('Expected is not a String or a RegExp');
}
this.sample = new RegExp(sample);
}
asymmetricMatch(other) {
if (!(0, _jasmine_utils.isA)('String', other)) {
return false;
}
return this.sample.test(other);
}
toString() {
return 'StringMatching';
}
getExpectedType() {
return 'string';
}}
const any = exports.any = expectedObject => new Any(expectedObject);
const anything = exports.anything = () => new Anything();
const arrayContaining = exports.arrayContaining = sample =>
new ArrayContaining(sample);
const objectContaining = exports.objectContaining = sample =>
new ObjectContaining(sample);
const stringContaining = exports.stringContaining = expected =>
new StringContaining(expected);
const stringMatching = exports.stringMatching = expected =>
new StringMatching(expected);