@squiz/optimization-utils 1.2.0 → 2.0.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.
- package/CHANGELOG.md +12 -0
- package/dist/event/DomainEvent.d.ts +1 -0
- package/dist/event/DomainEvent.js.map +1 -1
- package/dist/event/DynamoDBEventMapper.d.ts +3 -0
- package/dist/event/DynamoDBEventMapper.js +3 -0
- package/dist/event/DynamoDBEventMapper.js.map +1 -1
- package/dist/index.d.ts +1 -0
- package/dist/index.js +1 -0
- package/dist/index.js.map +1 -1
- package/dist/object/getProperty.d.ts +1 -0
- package/dist/object/getProperty.js +15 -0
- package/dist/object/getProperty.js.map +1 -0
- package/package.json +1 -1
- package/src/event/DomainEvent.ts +1 -0
- package/src/event/DynamoDBEventMapper.ts +3 -0
- package/src/event/__tests__/DynamoDBEventMapper.spec.ts +8 -0
- package/src/index.ts +2 -0
- package/src/object/__tests__/getProperty.spec.ts +17 -0
- package/src/object/getProperty.ts +21 -0
- package/src/scheduler/__tests__/EventBridgeScheduler.spec.ts +7 -6
package/CHANGELOG.md
CHANGED
|
@@ -5,6 +5,7 @@ export interface DomainEvent<TData extends Record<string, unknown> = Record<stri
|
|
|
5
5
|
readonly detail: TData;
|
|
6
6
|
readonly time: Date;
|
|
7
7
|
readonly version: string;
|
|
8
|
+
readonly entityId: string;
|
|
8
9
|
}
|
|
9
10
|
export type DomainEventConstructor = new (...any: Array<any>) => DomainEvent;
|
|
10
11
|
export type DomainEventName = string;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"DomainEvent.js","sourceRoot":"","sources":["../../src/event/DomainEvent.ts"],"names":[],"mappings":";;
|
|
1
|
+
{"version":3,"file":"DomainEvent.js","sourceRoot":"","sources":["../../src/event/DomainEvent.ts"],"names":[],"mappings":";;AAmBA,gDAMC;AAED,8CAEC;AAmBD,sCAIC;AApDD,4BAA0B;AAa1B,MAAM,mBAAmB,GAAG,MAAM,EAAE,CAAC;AAMrC,SAAgB,kBAAkB,CAChC,IAAqB;IAErB,MAAM,YAAY,GAAG,iBAAiB,EAAE,CAAC;IAEzC,OAAO,YAAY,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,IAAI,CAAC,CAAC;AACnD,CAAC;AAED,SAAgB,iBAAiB;IAC/B,OAAO,OAAO,CAAC,WAAW,CAAC,mBAAmB,EAAE,MAAM,CAAC,IAAI,EAAE,CAAC;AAChE,CAAC;AAED,SAAS,iBAAiB,CAAC,WAAmC;IAC5D,MAAM,QAAQ,GAAG,iBAAiB,EAAE,CAAC;IACrC,MAAM,kBAAkB,GAAG,kBAAkB,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;IAEhE,IAAI,kBAAkB,EAAE,CAAC;QACvB,MAAM,IAAI,KAAK,CACb,kDAAkD,WAAW,CAAC,IAAI,mCAAmC,CACtG,CAAC;IACJ,CAAC;IAED,OAAO,CAAC,cAAc,CACpB,mBAAmB,EACnB,CAAC,GAAG,QAAQ,EAAE,WAAW,CAAC,EAC1B,MAAM,CACP,CAAC;AACJ,CAAC;AAED,SAAgB,aAAa;IAC3B,OAAO,CAAC,MAAM,EAAE,EAAE;QAChB,iBAAiB,CAAC,MAA2C,CAAC,CAAC;IACjE,CAAC,CAAC;AACJ,CAAC"}
|
|
@@ -9,6 +9,7 @@ declare const EVENT_DYNAMO_DB_MODEL_SCHEMA: z.ZodObject<{
|
|
|
9
9
|
time: z.ZodString;
|
|
10
10
|
version: z.ZodString;
|
|
11
11
|
ttl: z.ZodNumber;
|
|
12
|
+
entityId: z.ZodString;
|
|
12
13
|
}, "strip", z.ZodTypeAny, {
|
|
13
14
|
eventId: string;
|
|
14
15
|
name: string;
|
|
@@ -18,6 +19,7 @@ declare const EVENT_DYNAMO_DB_MODEL_SCHEMA: z.ZodObject<{
|
|
|
18
19
|
time: string;
|
|
19
20
|
version: string;
|
|
20
21
|
ttl: number;
|
|
22
|
+
entityId: string;
|
|
21
23
|
}, {
|
|
22
24
|
eventId: string;
|
|
23
25
|
name: string;
|
|
@@ -27,6 +29,7 @@ declare const EVENT_DYNAMO_DB_MODEL_SCHEMA: z.ZodObject<{
|
|
|
27
29
|
time: string;
|
|
28
30
|
version: string;
|
|
29
31
|
ttl: number;
|
|
32
|
+
entityId: string;
|
|
30
33
|
}>;
|
|
31
34
|
export type EventDynamoDBModel = z.infer<typeof EVENT_DYNAMO_DB_MODEL_SCHEMA>;
|
|
32
35
|
type EventDynamoMarshalledModel = MarshalledResult<EventDynamoDBModel>;
|
|
@@ -13,6 +13,7 @@ const EVENT_DYNAMO_DB_MODEL_SCHEMA = zod_1.z.object({
|
|
|
13
13
|
time: zod_1.z.string().datetime(),
|
|
14
14
|
version: notEmptyString,
|
|
15
15
|
ttl: zod_1.z.number(),
|
|
16
|
+
entityId: zod_1.z.string(),
|
|
16
17
|
});
|
|
17
18
|
const eventToDynamoDB = (event) => {
|
|
18
19
|
const timestampPlus30Days = (0, DateManipulator_1.DateManipulator)(event.time)
|
|
@@ -26,6 +27,7 @@ const eventToDynamoDB = (event) => {
|
|
|
26
27
|
time: event.time.toISOString(),
|
|
27
28
|
version: event.version,
|
|
28
29
|
ttl: timestampPlus30Days / 1000,
|
|
30
|
+
entityId: event.entityId,
|
|
29
31
|
};
|
|
30
32
|
return (0, util_dynamodb_1.marshall)(dynamoDBModel, {
|
|
31
33
|
removeUndefinedValues: true,
|
|
@@ -49,6 +51,7 @@ const toEventFromPlain = (plainObject) => {
|
|
|
49
51
|
time: new Date(dynamoDBModel.time),
|
|
50
52
|
version: dynamoDBModel.version,
|
|
51
53
|
name: dynamoDBModel.name,
|
|
54
|
+
entityId: dynamoDBModel.entityId,
|
|
52
55
|
});
|
|
53
56
|
};
|
|
54
57
|
exports.toEventFromPlain = toEventFromPlain;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"DynamoDBEventMapper.js","sourceRoot":"","sources":["../../src/event/DynamoDBEventMapper.ts"],"names":[],"mappings":";;;AAAA,+CAAgE;AAChE,6BAAwB;AAExB,0DAA8D;AAE9D,6DAA0D;AAE1D,MAAM,cAAc,GAAG,OAAC,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;AACzC,MAAM,4BAA4B,GAAG,OAAC,CAAC,MAAM,CAAC;IAC5C,OAAO,EAAE,cAAc;IACvB,IAAI,EAAE,cAAc;IACpB,MAAM,EAAE,OAAC,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,QAAQ,CAAC,OAAC,CAAC,GAAG,EAAE,CAAC;IACtC,IAAI,EAAE,OAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;IAC3B,OAAO,EAAE,cAAc;IACvB,GAAG,EAAE,OAAC,CAAC,MAAM,EAAE;
|
|
1
|
+
{"version":3,"file":"DynamoDBEventMapper.js","sourceRoot":"","sources":["../../src/event/DynamoDBEventMapper.ts"],"names":[],"mappings":";;;AAAA,+CAAgE;AAChE,6BAAwB;AAExB,0DAA8D;AAE9D,6DAA0D;AAE1D,MAAM,cAAc,GAAG,OAAC,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;AACzC,MAAM,4BAA4B,GAAG,OAAC,CAAC,MAAM,CAAC;IAC5C,OAAO,EAAE,cAAc;IACvB,IAAI,EAAE,cAAc;IACpB,MAAM,EAAE,OAAC,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,QAAQ,CAAC,OAAC,CAAC,GAAG,EAAE,CAAC;IACtC,IAAI,EAAE,OAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;IAC3B,OAAO,EAAE,cAAc;IACvB,GAAG,EAAE,OAAC,CAAC,MAAM,EAAE;IACf,QAAQ,EAAE,OAAC,CAAC,MAAM,EAAE;CACrB,CAAC,CAAC;AAKI,MAAM,eAAe,GAAG,CAC7B,KAAkB,EACU,EAAE;IAC9B,MAAM,mBAAmB,GAAG,IAAA,iCAAe,EAAC,KAAK,CAAC,IAAI,CAAC;SACpD,OAAO,CAAC,EAAE,CAAC;SACX,OAAO,EAAE;SACT,OAAO,EAAE,CAAC;IAEb,MAAM,aAAa,GAAuB;QACxC,OAAO,EAAE,KAAK,CAAC,OAAO;QACtB,IAAI,EAAE,KAAK,CAAC,IAAI;QAChB,MAAM,EAAE,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;QAChD,IAAI,EAAE,KAAK,CAAC,IAAI,CAAC,WAAW,EAAE;QAC9B,OAAO,EAAE,KAAK,CAAC,OAAO;QACtB,GAAG,EAAE,mBAAmB,GAAG,IAAI;QAC/B,QAAQ,EAAE,KAAK,CAAC,QAAQ;KACzB,CAAC;IAEF,OAAO,IAAA,wBAAQ,EAAC,aAAa,EAAE;QAC7B,qBAAqB,EAAE,IAAI;KAC5B,CAA+B,CAAC;AACnC,CAAC,CAAC;AArBW,QAAA,eAAe,mBAqB1B;AAEK,MAAM,mBAAmB,GAAG,CACjC,UAA0C,EACnC,EAAE;IACT,MAAM,YAAY,GAAG,IAAA,0BAAU,EAAC,UAAU,CAAC,CAAC;IAE5C,OAAO,IAAA,wBAAgB,EAAC,YAAY,CAAC,CAAC;AACxC,CAAC,CAAC;AANW,QAAA,mBAAmB,uBAM9B;AAEK,MAAM,gBAAgB,GAAG,CAC9B,WAAoC,EAC7B,EAAE;IACT,MAAM,aAAa,GAAG,4BAA4B,CAAC,IAAI,CAAC,EAAE,GAAG,EAAE,IAAI,EAAE,CAAC,CAAC,KAAK,CAC1E,WAAW,CACZ,CAAC;IACF,MAAM,SAAS,GAAG,IAAA,gCAAkB,EAAC,aAAa,CAAC,IAAI,CAAC,CAAC;IAEzD,IAAI,CAAC,SAAS,EAAE,CAAC;QACf,MAAM,IAAI,KAAK,CACb,yBAAyB,aAAa,CAAC,IAAI,0BAA0B,CACtE,CAAC;IACJ,CAAC;IAED,OAAO,MAAM,CAAC,MAAM,CAAC,IAAI,SAAS,CAAC,EAAE,CAAC,EAAE;QACtC,OAAO,EAAE,aAAa,CAAC,OAAO;QAC9B,MAAM,EAAE,aAAa,CAAC,MAAM;QAC5B,IAAI,EAAE,IAAI,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC;QAClC,OAAO,EAAE,aAAa,CAAC,OAAO;QAC9B,IAAI,EAAE,aAAa,CAAC,IAAI;QACxB,QAAQ,EAAE,aAAa,CAAC,QAAQ;KACjC,CAAU,CAAC;AACd,CAAC,CAAC;AAtBW,QAAA,gBAAgB,oBAsB3B"}
|
package/dist/index.d.ts
CHANGED
package/dist/index.js
CHANGED
|
@@ -38,4 +38,5 @@ __exportStar(require("./event/EventHandler"), exports);
|
|
|
38
38
|
__exportStar(require("./config/ConfigurationLoader"), exports);
|
|
39
39
|
__exportStar(require("./cloudflare/ImplCloudflareKVHttpService"), exports);
|
|
40
40
|
__exportStar(require("./cloudflare/CloudflareKVHttpService"), exports);
|
|
41
|
+
__exportStar(require("./object/getProperty"), exports);
|
|
41
42
|
//# sourceMappingURL=index.js.map
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,yDAAuC;AAEvC,gEAA8C;AAE9C,yDAAuC;AACvC,wDAAsC;AAEtC,iDAA+B;AAE/B,wDAAsC;AACtC,mEAAiD;AAEjD,6DAA2C;AAC3C,wDAAsC;AACtC,yDAAuC;AACvC,kDAAgC;AAChC,6DAA2C;AAE3C,kEAAgD;AAChD,0DAAwC;AACxC,+DAA6C;AAE7C,8DAA4C;AAE5C,8DAA4C;AAC5C,sDAAoC;AACpC,wDAAsC;AAEtC,yDAAuC;AACvC,uDAAqC;AAErC,+DAA6C;AAE7C,2EAAyD;AACzD,uEAAqD"}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,yDAAuC;AAEvC,gEAA8C;AAE9C,yDAAuC;AACvC,wDAAsC;AAEtC,iDAA+B;AAE/B,wDAAsC;AACtC,mEAAiD;AAEjD,6DAA2C;AAC3C,wDAAsC;AACtC,yDAAuC;AACvC,kDAAgC;AAChC,6DAA2C;AAE3C,kEAAgD;AAChD,0DAAwC;AACxC,+DAA6C;AAE7C,8DAA4C;AAE5C,8DAA4C;AAC5C,sDAAoC;AACpC,wDAAsC;AAEtC,yDAAuC;AACvC,uDAAqC;AAErC,+DAA6C;AAE7C,2EAAyD;AACzD,uEAAqD;AAErD,uDAAqC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare const getProperty: (obj: Record<string | symbol | number, unknown>, path: string, defaultValue?: unknown) => unknown;
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.getProperty = void 0;
|
|
4
|
+
const getProperty = (obj, path, defaultValue = undefined) => {
|
|
5
|
+
const travel = (regexp) => path
|
|
6
|
+
.split(regexp)
|
|
7
|
+
.filter(Boolean)
|
|
8
|
+
.reduce((res, key) => res !== null && res !== undefined
|
|
9
|
+
? res[key]
|
|
10
|
+
: res, obj);
|
|
11
|
+
const result = travel(/[,[\]]+?/) || travel(/[,[\].]+?/);
|
|
12
|
+
return result === undefined || result === obj ? defaultValue : result;
|
|
13
|
+
};
|
|
14
|
+
exports.getProperty = getProperty;
|
|
15
|
+
//# sourceMappingURL=getProperty.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"getProperty.js","sourceRoot":"","sources":["../../src/object/getProperty.ts"],"names":[],"mappings":";;;AAAO,MAAM,WAAW,GAAG,CACzB,GAA8C,EAC9C,IAAY,EACZ,eAAwB,SAAS,EACxB,EAAE;IACX,MAAM,MAAM,GAAG,CAAC,MAAc,EAAE,EAAE,CAChC,IAAI;SACD,KAAK,CAAC,MAAM,CAAC;SACb,MAAM,CAAC,OAAO,CAAC;SACf,MAAM,CACL,CAAC,GAAG,EAAE,GAAG,EAAE,EAAE,CACX,GAAG,KAAK,IAAI,IAAI,GAAG,KAAK,SAAS;QAC/B,CAAC,CAAE,GAA+B,CAAC,GAAG,CAAC;QACvC,CAAC,CAAC,GAAG,EACT,GAAG,CACJ,CAAC;IAEN,MAAM,MAAM,GAAG,MAAM,CAAC,UAAU,CAAC,IAAI,MAAM,CAAC,WAAW,CAAC,CAAC;IAEzD,OAAO,MAAM,KAAK,SAAS,IAAI,MAAM,KAAK,GAAG,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,MAAM,CAAC;AACxE,CAAC,CAAC;AApBW,QAAA,WAAW,eAoBtB"}
|
package/package.json
CHANGED
package/src/event/DomainEvent.ts
CHANGED
|
@@ -13,6 +13,7 @@ const EVENT_DYNAMO_DB_MODEL_SCHEMA = z.object({
|
|
|
13
13
|
time: z.string().datetime(),
|
|
14
14
|
version: notEmptyString,
|
|
15
15
|
ttl: z.number(),
|
|
16
|
+
entityId: z.string(),
|
|
16
17
|
});
|
|
17
18
|
|
|
18
19
|
export type EventDynamoDBModel = z.infer<typeof EVENT_DYNAMO_DB_MODEL_SCHEMA>;
|
|
@@ -33,6 +34,7 @@ export const eventToDynamoDB = (
|
|
|
33
34
|
time: event.time.toISOString(),
|
|
34
35
|
version: event.version,
|
|
35
36
|
ttl: timestampPlus30Days / 1000,
|
|
37
|
+
entityId: event.entityId,
|
|
36
38
|
};
|
|
37
39
|
|
|
38
40
|
return marshall(dynamoDBModel, {
|
|
@@ -68,5 +70,6 @@ export const toEventFromPlain = <TData extends DomainEvent>(
|
|
|
68
70
|
time: new Date(dynamoDBModel.time),
|
|
69
71
|
version: dynamoDBModel.version,
|
|
70
72
|
name: dynamoDBModel.name,
|
|
73
|
+
entityId: dynamoDBModel.entityId,
|
|
71
74
|
}) as TData;
|
|
72
75
|
};
|
|
@@ -21,6 +21,7 @@ class ExampleEvent implements DomainEvent<{}> {
|
|
|
21
21
|
readonly name!: string;
|
|
22
22
|
readonly time!: Date;
|
|
23
23
|
readonly version!: string;
|
|
24
|
+
readonly entityId: string;
|
|
24
25
|
|
|
25
26
|
constructor(data: Omit<ExampleEvent, 'name'>) {
|
|
26
27
|
this.detail = data.detail;
|
|
@@ -28,6 +29,7 @@ class ExampleEvent implements DomainEvent<{}> {
|
|
|
28
29
|
this.name = ExampleEvent.name;
|
|
29
30
|
this.time = data.time;
|
|
30
31
|
this.version = data.version;
|
|
32
|
+
this.entityId = data.entityId;
|
|
31
33
|
}
|
|
32
34
|
}
|
|
33
35
|
|
|
@@ -37,6 +39,7 @@ const createPlainExampleEvent: () => {
|
|
|
37
39
|
detail: ExampleEventDetail;
|
|
38
40
|
time: string;
|
|
39
41
|
version: string;
|
|
42
|
+
entityId: string;
|
|
40
43
|
} = () => {
|
|
41
44
|
return {
|
|
42
45
|
detail: {
|
|
@@ -48,6 +51,7 @@ const createPlainExampleEvent: () => {
|
|
|
48
51
|
version: faker.number.int().toString(),
|
|
49
52
|
name: ExampleEvent.name,
|
|
50
53
|
ttl: faker.date.past().getTime() / 1000,
|
|
54
|
+
entityId: 'example-id',
|
|
51
55
|
};
|
|
52
56
|
};
|
|
53
57
|
|
|
@@ -63,6 +67,7 @@ describe('toEventEntityFromDynamoDb', () => {
|
|
|
63
67
|
eventId: event.eventId,
|
|
64
68
|
time: new Date(event.time),
|
|
65
69
|
version: event.version,
|
|
70
|
+
entityId: 'example-id',
|
|
66
71
|
}),
|
|
67
72
|
);
|
|
68
73
|
});
|
|
@@ -80,6 +85,7 @@ describe('toEventFromPlain', () => {
|
|
|
80
85
|
eventId: event.eventId,
|
|
81
86
|
time: new Date(event.time),
|
|
82
87
|
version: event.version,
|
|
88
|
+
entityId: 'example-id',
|
|
83
89
|
}),
|
|
84
90
|
);
|
|
85
91
|
});
|
|
@@ -95,6 +101,7 @@ describe('toDynamoDB', () => {
|
|
|
95
101
|
eventId: faker.string.uuid(),
|
|
96
102
|
time: new Date('2020-01-01T00:00:00.000Z'),
|
|
97
103
|
version: faker.number.int().toString(),
|
|
104
|
+
entityId: 'example-id',
|
|
98
105
|
});
|
|
99
106
|
|
|
100
107
|
const result = eventToDynamoDB(event);
|
|
@@ -107,6 +114,7 @@ describe('toDynamoDB', () => {
|
|
|
107
114
|
version: event.version,
|
|
108
115
|
name: 'ExampleEvent',
|
|
109
116
|
ttl: new Date('2020-01-31T00:00:00.000Z').getTime() / 1000,
|
|
117
|
+
entityId: 'example-id',
|
|
110
118
|
} as EventDynamoDBModel),
|
|
111
119
|
);
|
|
112
120
|
});
|
package/src/index.ts
CHANGED
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { getProperty } from '../getProperty';
|
|
2
|
+
|
|
3
|
+
it('should return a passed property', () => {
|
|
4
|
+
const object = { a: [{ b: { c: 3 } }] };
|
|
5
|
+
|
|
6
|
+
const result = getProperty(object, 'a[0].b.c');
|
|
7
|
+
|
|
8
|
+
expect(result).toBe(3);
|
|
9
|
+
});
|
|
10
|
+
|
|
11
|
+
it('should return undefined if property does not exist', () => {
|
|
12
|
+
const object = { a: [{ b: { c: 3 } }] };
|
|
13
|
+
|
|
14
|
+
const result = getProperty(object, 'a[0].z.c');
|
|
15
|
+
|
|
16
|
+
expect(result).toBeUndefined();
|
|
17
|
+
});
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
export const getProperty = (
|
|
2
|
+
obj: Record<string | symbol | number, unknown>,
|
|
3
|
+
path: string,
|
|
4
|
+
defaultValue: unknown = undefined,
|
|
5
|
+
): unknown => {
|
|
6
|
+
const travel = (regexp: RegExp) =>
|
|
7
|
+
path
|
|
8
|
+
.split(regexp)
|
|
9
|
+
.filter(Boolean)
|
|
10
|
+
.reduce<unknown>(
|
|
11
|
+
(res, key) =>
|
|
12
|
+
res !== null && res !== undefined
|
|
13
|
+
? (res as Record<string, unknown>)[key]
|
|
14
|
+
: res,
|
|
15
|
+
obj,
|
|
16
|
+
);
|
|
17
|
+
|
|
18
|
+
const result = travel(/[,[\]]+?/) || travel(/[,[\].]+?/);
|
|
19
|
+
|
|
20
|
+
return result === undefined || result === obj ? defaultValue : result;
|
|
21
|
+
};
|
|
@@ -41,6 +41,7 @@ class ExampleEvent implements DomainEvent {
|
|
|
41
41
|
readonly name: string = ExampleEvent.name;
|
|
42
42
|
readonly time: Date = new Date();
|
|
43
43
|
readonly version: string = '1';
|
|
44
|
+
readonly entityId = 'uuid';
|
|
44
45
|
}
|
|
45
46
|
|
|
46
47
|
describe('EventBridgeScheduler', () => {
|
|
@@ -299,12 +300,12 @@ describe('EventBridgeScheduler', () => {
|
|
|
299
300
|
expect.objectContaining({
|
|
300
301
|
Name: expectedScheduleName,
|
|
301
302
|
}),
|
|
302
|
-
)
|
|
303
|
-
|
|
304
|
-
|
|
305
|
-
|
|
306
|
-
|
|
307
|
-
|
|
303
|
+
);
|
|
304
|
+
expect(DeleteScheduleCommand).toHaveBeenCalledWith(
|
|
305
|
+
expect.objectContaining({
|
|
306
|
+
Name: expectedScheduleName,
|
|
307
|
+
}),
|
|
308
|
+
);
|
|
308
309
|
});
|
|
309
310
|
});
|
|
310
311
|
});
|