@thisisagile/easy-test 12.12.2 → 12.13.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,7 +1,23 @@
1
+ import { AsymmetricMatcher } from 'expect';
2
+ import { Uri } from '../utils/Types';
3
+ export declare class ObjectContainingText extends AsymmetricMatcher<string> {
4
+ asymmetricMatch(other: any): any;
5
+ toString(): string;
6
+ }
7
+ export declare class ObjectContainingTextExact extends AsymmetricMatcher<string> {
8
+ asymmetricMatch(other: any): boolean;
9
+ toString(): string;
10
+ }
11
+ export declare class ObjectContainingJson extends AsymmetricMatcher<any> {
12
+ asymmetricMatch(other: any): boolean;
13
+ toString(): string;
14
+ }
1
15
  export declare const fits: {
2
16
  any: () => any;
3
17
  type: (type?: unknown) => any;
4
18
  with: (o: unknown) => any;
5
19
  text: (s: any) => any;
20
+ textExact: (s: any) => any;
21
+ uri: (u: Uri) => any;
6
22
  json: (s: any) => any;
7
23
  };
package/dist/mock/Fits.js CHANGED
@@ -1,6 +1,6 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.fits = void 0;
3
+ exports.fits = exports.ObjectContainingJson = exports.ObjectContainingTextExact = exports.ObjectContainingText = void 0;
4
4
  const Utils_1 = require("../utils/Utils");
5
5
  const Eq_1 = require("../utils/Eq");
6
6
  const expect_1 = require("expect");
@@ -12,6 +12,16 @@ class ObjectContainingText extends expect_1.AsymmetricMatcher {
12
12
  return `String${this.inverse ? 'Not' : ''}Containing`;
13
13
  }
14
14
  }
15
+ exports.ObjectContainingText = ObjectContainingText;
16
+ class ObjectContainingTextExact extends expect_1.AsymmetricMatcher {
17
+ asymmetricMatch(other) {
18
+ return (0, Utils_1.asString)(other) === (0, Utils_1.asString)(this.sample);
19
+ }
20
+ toString() {
21
+ return `String${this.inverse ? 'Not' : ''}Containing`;
22
+ }
23
+ }
24
+ exports.ObjectContainingTextExact = ObjectContainingTextExact;
15
25
  class ObjectContainingJson extends expect_1.AsymmetricMatcher {
16
26
  asymmetricMatch(other) {
17
27
  return Eq_1.eq.subset((0, Utils_1.asJson)(other), (0, Utils_1.asJson)(this.sample));
@@ -20,11 +30,14 @@ class ObjectContainingJson extends expect_1.AsymmetricMatcher {
20
30
  return `Object${this.inverse ? 'Not' : ''}Containing`;
21
31
  }
22
32
  }
33
+ exports.ObjectContainingJson = ObjectContainingJson;
23
34
  exports.fits = {
24
35
  any: () => expect.anything(),
25
36
  type: (type) => expect.any(type),
26
37
  with: (o) => expect.objectContaining(o),
27
38
  text: (s) => new ObjectContainingText(s),
39
+ textExact: (s) => new ObjectContainingTextExact(s),
40
+ uri: (u) => exports.fits.textExact(u),
28
41
  json: (s) => new ObjectContainingJson(s),
29
42
  };
30
43
  //# sourceMappingURL=Fits.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"Fits.js","sourceRoot":"","sources":["../../src/mock/Fits.ts"],"names":[],"mappings":";;;AAAA,0CAAkD;AAClD,oCAAiC;AACjC,mCAA2C;AAE3C,MAAM,oBAAqB,SAAQ,0BAAyB;IAC1D,eAAe,CAAC,KAAU;QACxB,OAAO,IAAA,gBAAQ,EAAC,KAAK,CAAC,CAAC,QAAQ,CAAC,IAAA,gBAAQ,EAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC;IACzD,CAAC;IAED,QAAQ;QACN,OAAO,SAAS,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,YAAY,CAAC;IACxD,CAAC;CACF;AAED,MAAM,oBAAqB,SAAQ,0BAAsB;IACvD,eAAe,CAAC,KAAU;QACxB,OAAO,OAAE,CAAC,MAAM,CAAC,IAAA,cAAM,EAAC,KAAK,CAAC,EAAE,IAAA,cAAM,EAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC;IACvD,CAAC;IAED,QAAQ;QACN,OAAO,SAAS,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,YAAY,CAAC;IACxD,CAAC;CACF;AAEY,QAAA,IAAI,GAAG;IAClB,GAAG,EAAE,GAAQ,EAAE,CAAC,MAAM,CAAC,QAAQ,EAAE;IACjC,IAAI,EAAE,CAAC,IAAc,EAAO,EAAE,CAAC,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC;IAC/C,IAAI,EAAE,CAAC,CAAU,EAAO,EAAE,CAAC,MAAM,CAAC,gBAAgB,CAAC,CAAC,CAAC;IACrD,IAAI,EAAE,CAAC,CAAM,EAAO,EAAE,CAAC,IAAI,oBAAoB,CAAC,CAAC,CAAC;IAClD,IAAI,EAAE,CAAC,CAAM,EAAO,EAAE,CAAC,IAAI,oBAAoB,CAAC,CAAC,CAAC;CACnD,CAAC"}
1
+ {"version":3,"file":"Fits.js","sourceRoot":"","sources":["../../src/mock/Fits.ts"],"names":[],"mappings":";;;AAAA,0CAAkD;AAClD,oCAAiC;AACjC,mCAA2C;AAG3C,MAAa,oBAAqB,SAAQ,0BAAyB;IACjE,eAAe,CAAC,KAAU;QACxB,OAAO,IAAA,gBAAQ,EAAC,KAAK,CAAC,CAAC,QAAQ,CAAC,IAAA,gBAAQ,EAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC;IACzD,CAAC;IAED,QAAQ;QACN,OAAO,SAAS,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,YAAY,CAAC;IACxD,CAAC;CACF;AARD,oDAQC;AAED,MAAa,yBAA0B,SAAQ,0BAAyB;IACtE,eAAe,CAAC,KAAU;QACxB,OAAO,IAAA,gBAAQ,EAAC,KAAK,CAAC,KAAK,IAAA,gBAAQ,EAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IACnD,CAAC;IAED,QAAQ;QACN,OAAO,SAAS,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,YAAY,CAAC;IACxD,CAAC;CACF;AARD,8DAQC;AAED,MAAa,oBAAqB,SAAQ,0BAAsB;IAC9D,eAAe,CAAC,KAAU;QACxB,OAAO,OAAE,CAAC,MAAM,CAAC,IAAA,cAAM,EAAC,KAAK,CAAC,EAAE,IAAA,cAAM,EAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC;IACvD,CAAC;IAED,QAAQ;QACN,OAAO,SAAS,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,YAAY,CAAC;IACxD,CAAC;CACF;AARD,oDAQC;AAEY,QAAA,IAAI,GAAG;IAClB,GAAG,EAAE,GAAQ,EAAE,CAAC,MAAM,CAAC,QAAQ,EAAE;IACjC,IAAI,EAAE,CAAC,IAAc,EAAO,EAAE,CAAC,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC;IAC/C,IAAI,EAAE,CAAC,CAAU,EAAO,EAAE,CAAC,MAAM,CAAC,gBAAgB,CAAC,CAAC,CAAC;IACrD,IAAI,EAAE,CAAC,CAAM,EAAO,EAAE,CAAC,IAAI,oBAAoB,CAAC,CAAC,CAAC;IAClD,SAAS,EAAE,CAAC,CAAM,EAAO,EAAE,CAAC,IAAI,yBAAyB,CAAC,CAAC,CAAC;IAC5D,GAAG,EAAE,CAAC,CAAM,EAAO,EAAE,CAAC,YAAI,CAAC,SAAS,CAAC,CAAC,CAAC;IACvC,IAAI,EAAE,CAAC,CAAM,EAAO,EAAE,CAAC,IAAI,oBAAoB,CAAC,CAAC,CAAC;CACnD,CAAC"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@thisisagile/easy-test",
3
- "version": "12.12.2",
3
+ "version": "12.13.0",
4
4
  "description": "Straightforward library for testing microservices built with @thisisagile/easy",
5
5
  "author": "Sander Hoogendoorn",
6
6
  "license": "MIT",
@@ -41,7 +41,7 @@
41
41
  "@types/node": "^18.11.12",
42
42
  "expect": "^29.3.1",
43
43
  "jest": "^29.3.1",
44
- "jest-junit": "^14.0.1",
44
+ "jest-junit": "^15.0.0",
45
45
  "jest-sonar-reporter": "^2.0.0",
46
46
  "ts-jest": "^29.0.3"
47
47
  }
package/src/mock/Fits.ts CHANGED
@@ -1,8 +1,9 @@
1
1
  import { asJson, asString } from '../utils/Utils';
2
2
  import { eq } from '../utils/Eq';
3
3
  import { AsymmetricMatcher } from 'expect';
4
+ import { Uri } from '../utils/Types';
4
5
 
5
- class ObjectContainingText extends AsymmetricMatcher<string> {
6
+ export class ObjectContainingText extends AsymmetricMatcher<string> {
6
7
  asymmetricMatch(other: any) {
7
8
  return asString(other).includes(asString(this.sample));
8
9
  }
@@ -12,7 +13,17 @@ class ObjectContainingText extends AsymmetricMatcher<string> {
12
13
  }
13
14
  }
14
15
 
15
- class ObjectContainingJson extends AsymmetricMatcher<any> {
16
+ export class ObjectContainingTextExact extends AsymmetricMatcher<string> {
17
+ asymmetricMatch(other: any) {
18
+ return asString(other) === asString(this.sample);
19
+ }
20
+
21
+ toString() {
22
+ return `String${this.inverse ? 'Not' : ''}Containing`;
23
+ }
24
+ }
25
+
26
+ export class ObjectContainingJson extends AsymmetricMatcher<any> {
16
27
  asymmetricMatch(other: any) {
17
28
  return eq.subset(asJson(other), asJson(this.sample));
18
29
  }
@@ -27,5 +38,7 @@ export const fits = {
27
38
  type: (type?: unknown): any => expect.any(type),
28
39
  with: (o: unknown): any => expect.objectContaining(o),
29
40
  text: (s: any): any => new ObjectContainingText(s),
41
+ textExact: (s: any): any => new ObjectContainingTextExact(s),
42
+ uri: (u: Uri): any => fits.textExact(u),
30
43
  json: (s: any): any => new ObjectContainingJson(s),
31
44
  };