@expo/entity 0.46.0 → 0.48.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/build/src/AuthorizationResultBasedEntityMutator.d.ts +5 -3
- package/build/src/AuthorizationResultBasedEntityMutator.js +75 -37
- package/build/src/AuthorizationResultBasedEntityMutator.js.map +1 -1
- package/build/src/EntityDeleter.js +1 -1
- package/build/src/EntityDeleter.js.map +1 -1
- package/build/src/EntityFields.d.ts +7 -0
- package/build/src/EntityFields.js +11 -1
- package/build/src/EntityFields.js.map +1 -1
- package/build/src/EntityMutatorFactory.d.ts +3 -2
- package/build/src/EntityMutatorFactory.js +4 -4
- package/build/src/EntityMutatorFactory.js.map +1 -1
- package/build/src/EntityUpdater.js +1 -1
- package/build/src/EntityUpdater.js.map +1 -1
- package/build/src/ViewerScopedEntityMutatorFactory.d.ts +3 -2
- package/build/src/ViewerScopedEntityMutatorFactory.js +4 -4
- package/build/src/ViewerScopedEntityMutatorFactory.js.map +1 -1
- package/package.json +5 -2
- package/src/AuthorizationResultBasedEntityMutator.ts +63 -49
- package/src/EntityDeleter.ts +1 -1
- package/src/EntityFields.ts +13 -0
- package/src/EntityMutatorFactory.ts +5 -0
- package/src/EntityUpdater.ts +1 -1
- package/src/ViewerScopedEntityMutatorFactory.ts +5 -2
- package/src/__tests__/EntityFields-test.ts +7 -0
- package/src/__tests__/EntityMutator-test.ts +217 -16
- package/build/src/__tests__/AuthorizationResultBasedEntityAssociationLoader-test.d.ts +0 -1
- package/build/src/__tests__/AuthorizationResultBasedEntityAssociationLoader-test.js +0 -240
- package/build/src/__tests__/AuthorizationResultBasedEntityAssociationLoader-test.js.map +0 -1
- package/build/src/__tests__/AuthorizationResultBasedEntityLoader-constructor-test.d.ts +0 -26
- package/build/src/__tests__/AuthorizationResultBasedEntityLoader-constructor-test.js +0 -109
- package/build/src/__tests__/AuthorizationResultBasedEntityLoader-constructor-test.js.map +0 -1
- package/build/src/__tests__/AuthorizationResultBasedEntityLoader-test.d.ts +0 -1
- package/build/src/__tests__/AuthorizationResultBasedEntityLoader-test.js +0 -590
- package/build/src/__tests__/AuthorizationResultBasedEntityLoader-test.js.map +0 -1
- package/build/src/__tests__/ComposedCacheAdapter-test.d.ts +0 -1
- package/build/src/__tests__/ComposedCacheAdapter-test.js +0 -259
- package/build/src/__tests__/ComposedCacheAdapter-test.js.map +0 -1
- package/build/src/__tests__/ComposedSecondaryEntityCache-test.d.ts +0 -1
- package/build/src/__tests__/ComposedSecondaryEntityCache-test.js +0 -67
- package/build/src/__tests__/ComposedSecondaryEntityCache-test.js.map +0 -1
- package/build/src/__tests__/EnforcingEntityAssociationLoader-test.d.ts +0 -1
- package/build/src/__tests__/EnforcingEntityAssociationLoader-test.js +0 -113
- package/build/src/__tests__/EnforcingEntityAssociationLoader-test.js.map +0 -1
- package/build/src/__tests__/EnforcingEntityLoader-test.d.ts +0 -1
- package/build/src/__tests__/EnforcingEntityLoader-test.js +0 -316
- package/build/src/__tests__/EnforcingEntityLoader-test.js.map +0 -1
- package/build/src/__tests__/Entity-test.d.ts +0 -1
- package/build/src/__tests__/Entity-test.js +0 -92
- package/build/src/__tests__/Entity-test.js.map +0 -1
- package/build/src/__tests__/EntityAssociationLoader-test.d.ts +0 -1
- package/build/src/__tests__/EntityAssociationLoader-test.js +0 -28
- package/build/src/__tests__/EntityAssociationLoader-test.js.map +0 -1
- package/build/src/__tests__/EntityCommonUseCases-test.d.ts +0 -1
- package/build/src/__tests__/EntityCommonUseCases-test.js +0 -111
- package/build/src/__tests__/EntityCommonUseCases-test.js.map +0 -1
- package/build/src/__tests__/EntityCompanion-test.d.ts +0 -1
- package/build/src/__tests__/EntityCompanion-test.js +0 -42
- package/build/src/__tests__/EntityCompanion-test.js.map +0 -1
- package/build/src/__tests__/EntityCompanionProvider-test.d.ts +0 -1
- package/build/src/__tests__/EntityCompanionProvider-test.js +0 -53
- package/build/src/__tests__/EntityCompanionProvider-test.js.map +0 -1
- package/build/src/__tests__/EntityConfiguration-test.d.ts +0 -1
- package/build/src/__tests__/EntityConfiguration-test.js +0 -164
- package/build/src/__tests__/EntityConfiguration-test.js.map +0 -1
- package/build/src/__tests__/EntityDatabaseAdapter-test.d.ts +0 -1
- package/build/src/__tests__/EntityDatabaseAdapter-test.js +0 -189
- package/build/src/__tests__/EntityDatabaseAdapter-test.js.map +0 -1
- package/build/src/__tests__/EntityEdges-test.d.ts +0 -1
- package/build/src/__tests__/EntityEdges-test.js +0 -680
- package/build/src/__tests__/EntityEdges-test.js.map +0 -1
- package/build/src/__tests__/EntityFields-test.d.ts +0 -1
- package/build/src/__tests__/EntityFields-test.js +0 -61
- package/build/src/__tests__/EntityFields-test.js.map +0 -1
- package/build/src/__tests__/EntityLoader-test.d.ts +0 -1
- package/build/src/__tests__/EntityLoader-test.js +0 -34
- package/build/src/__tests__/EntityLoader-test.js.map +0 -1
- package/build/src/__tests__/EntityMutator-MutationCacheConsistency-test.d.ts +0 -1
- package/build/src/__tests__/EntityMutator-MutationCacheConsistency-test.js +0 -71
- package/build/src/__tests__/EntityMutator-MutationCacheConsistency-test.js.map +0 -1
- package/build/src/__tests__/EntityMutator-SingleCompositeFieldCacheConsistency-test.d.ts +0 -1
- package/build/src/__tests__/EntityMutator-SingleCompositeFieldCacheConsistency-test.js +0 -54
- package/build/src/__tests__/EntityMutator-SingleCompositeFieldCacheConsistency-test.js.map +0 -1
- package/build/src/__tests__/EntityMutator-test.d.ts +0 -1
- package/build/src/__tests__/EntityMutator-test.js +0 -721
- package/build/src/__tests__/EntityMutator-test.js.map +0 -1
- package/build/src/__tests__/EntityPrivacyPolicy-test.d.ts +0 -1
- package/build/src/__tests__/EntityPrivacyPolicy-test.js +0 -429
- package/build/src/__tests__/EntityPrivacyPolicy-test.js.map +0 -1
- package/build/src/__tests__/EntityQueryContext-test.d.ts +0 -1
- package/build/src/__tests__/EntityQueryContext-test.js +0 -181
- package/build/src/__tests__/EntityQueryContext-test.js.map +0 -1
- package/build/src/__tests__/EntitySecondaryCacheLoader-test.d.ts +0 -1
- package/build/src/__tests__/EntitySecondaryCacheLoader-test.js +0 -58
- package/build/src/__tests__/EntitySecondaryCacheLoader-test.js.map +0 -1
- package/build/src/__tests__/EntitySelfReferentialEdges-test.d.ts +0 -1
- package/build/src/__tests__/EntitySelfReferentialEdges-test.js +0 -196
- package/build/src/__tests__/EntitySelfReferentialEdges-test.js.map +0 -1
- package/build/src/__tests__/GenericEntityCacheAdapter-test.d.ts +0 -1
- package/build/src/__tests__/GenericEntityCacheAdapter-test.js +0 -95
- package/build/src/__tests__/GenericEntityCacheAdapter-test.js.map +0 -1
- package/build/src/__tests__/ReadonlyEntity-test.d.ts +0 -1
- package/build/src/__tests__/ReadonlyEntity-test.js +0 -209
- package/build/src/__tests__/ReadonlyEntity-test.js.map +0 -1
- package/build/src/__tests__/ViewerContext-test.d.ts +0 -1
- package/build/src/__tests__/ViewerContext-test.js +0 -28
- package/build/src/__tests__/ViewerContext-test.js.map +0 -1
- package/build/src/__tests__/ViewerScopedEntityCompanion-test.d.ts +0 -1
- package/build/src/__tests__/ViewerScopedEntityCompanion-test.js +0 -18
- package/build/src/__tests__/ViewerScopedEntityCompanion-test.js.map +0 -1
- package/build/src/__tests__/ViewerScopedEntityCompanionProvider-test.d.ts +0 -1
- package/build/src/__tests__/ViewerScopedEntityCompanionProvider-test.js +0 -18
- package/build/src/__tests__/ViewerScopedEntityCompanionProvider-test.js.map +0 -1
- package/build/src/__tests__/ViewerScopedEntityLoaderFactory-test.d.ts +0 -1
- package/build/src/__tests__/ViewerScopedEntityLoaderFactory-test.js +0 -21
- package/build/src/__tests__/ViewerScopedEntityLoaderFactory-test.js.map +0 -1
- package/build/src/__tests__/ViewerScopedEntityMutatorFactory-test.d.ts +0 -1
- package/build/src/__tests__/ViewerScopedEntityMutatorFactory-test.js +0 -20
- package/build/src/__tests__/ViewerScopedEntityMutatorFactory-test.js.map +0 -1
- package/build/src/__tests__/cases/TwoEntitySameTableDisjointRows-test.d.ts +0 -1
- package/build/src/__tests__/cases/TwoEntitySameTableDisjointRows-test.js +0 -121
- package/build/src/__tests__/cases/TwoEntitySameTableDisjointRows-test.js.map +0 -1
- package/build/src/__tests__/cases/TwoEntitySameTableOverlappingRows-test.d.ts +0 -1
- package/build/src/__tests__/cases/TwoEntitySameTableOverlappingRows-test.js +0 -119
- package/build/src/__tests__/cases/TwoEntitySameTableOverlappingRows-test.js.map +0 -1
- package/build/src/__tests__/entityUtils-test.d.ts +0 -1
- package/build/src/__tests__/entityUtils-test.js +0 -88
- package/build/src/__tests__/entityUtils-test.js.map +0 -1
- package/build/src/errors/__tests__/EntityDatabaseAdapterError-test.d.ts +0 -1
- package/build/src/errors/__tests__/EntityDatabaseAdapterError-test.js +0 -21
- package/build/src/errors/__tests__/EntityDatabaseAdapterError-test.js.map +0 -1
- package/build/src/internal/__tests__/CompositeFieldHolder-test.d.ts +0 -1
- package/build/src/internal/__tests__/CompositeFieldHolder-test.js +0 -25
- package/build/src/internal/__tests__/CompositeFieldHolder-test.js.map +0 -1
- package/build/src/internal/__tests__/CompositeFieldValueMap-test.d.ts +0 -1
- package/build/src/internal/__tests__/CompositeFieldValueMap-test.js +0 -40
- package/build/src/internal/__tests__/CompositeFieldValueMap-test.js.map +0 -1
- package/build/src/internal/__tests__/EntityDataManager-test.d.ts +0 -1
- package/build/src/internal/__tests__/EntityDataManager-test.js +0 -666
- package/build/src/internal/__tests__/EntityDataManager-test.js.map +0 -1
- package/build/src/internal/__tests__/EntityFieldTransformationUtils-test.d.ts +0 -1
- package/build/src/internal/__tests__/EntityFieldTransformationUtils-test.js +0 -135
- package/build/src/internal/__tests__/EntityFieldTransformationUtils-test.js.map +0 -1
- package/build/src/internal/__tests__/ReadThroughEntityCache-test.d.ts +0 -1
- package/build/src/internal/__tests__/ReadThroughEntityCache-test.js +0 -217
- package/build/src/internal/__tests__/ReadThroughEntityCache-test.js.map +0 -1
- package/build/src/rules/__tests__/AlwaysAllowPrivacyPolicyRule-test.d.ts +0 -1
- package/build/src/rules/__tests__/AlwaysAllowPrivacyPolicyRule-test.js +0 -18
- package/build/src/rules/__tests__/AlwaysAllowPrivacyPolicyRule-test.js.map +0 -1
- package/build/src/rules/__tests__/AlwaysDenyPrivacyPolicyRule-test.d.ts +0 -1
- package/build/src/rules/__tests__/AlwaysDenyPrivacyPolicyRule-test.js +0 -18
- package/build/src/rules/__tests__/AlwaysDenyPrivacyPolicyRule-test.js.map +0 -1
- package/build/src/rules/__tests__/AlwaysSkipPrivacyPolicyRule-test.d.ts +0 -1
- package/build/src/rules/__tests__/AlwaysSkipPrivacyPolicyRule-test.js +0 -18
- package/build/src/rules/__tests__/AlwaysSkipPrivacyPolicyRule-test.js.map +0 -1
- package/build/src/utils/__testfixtures__/PrivacyPolicyRuleTestUtils.d.ts +0 -28
- package/build/src/utils/__testfixtures__/PrivacyPolicyRuleTestUtils.js +0 -53
- package/build/src/utils/__testfixtures__/PrivacyPolicyRuleTestUtils.js.map +0 -1
- package/build/src/utils/__testfixtures__/SimpleTestEntity.d.ts +0 -20
- package/build/src/utils/__testfixtures__/SimpleTestEntity.js +0 -46
- package/build/src/utils/__testfixtures__/SimpleTestEntity.js.map +0 -1
- package/build/src/utils/__testfixtures__/StubCacheAdapter.d.ts +0 -29
- package/build/src/utils/__testfixtures__/StubCacheAdapter.js +0 -103
- package/build/src/utils/__testfixtures__/StubCacheAdapter.js.map +0 -1
- package/build/src/utils/__testfixtures__/StubDatabaseAdapter.d.ts +0 -26
- package/build/src/utils/__testfixtures__/StubDatabaseAdapter.js +0 -173
- package/build/src/utils/__testfixtures__/StubDatabaseAdapter.js.map +0 -1
- package/build/src/utils/__testfixtures__/StubDatabaseAdapterProvider.d.ts +0 -7
- package/build/src/utils/__testfixtures__/StubDatabaseAdapterProvider.js +0 -12
- package/build/src/utils/__testfixtures__/StubDatabaseAdapterProvider.js.map +0 -1
- package/build/src/utils/__testfixtures__/StubQueryContextProvider.d.ts +0 -7
- package/build/src/utils/__testfixtures__/StubQueryContextProvider.js +0 -17
- package/build/src/utils/__testfixtures__/StubQueryContextProvider.js.map +0 -1
- package/build/src/utils/__testfixtures__/TSMockitoExtensions.d.ts +0 -9
- package/build/src/utils/__testfixtures__/TSMockitoExtensions.js +0 -65
- package/build/src/utils/__testfixtures__/TSMockitoExtensions.js.map +0 -1
- package/build/src/utils/__testfixtures__/TestEntity.d.ts +0 -30
- package/build/src/utils/__testfixtures__/TestEntity.js +0 -96
- package/build/src/utils/__testfixtures__/TestEntity.js.map +0 -1
- package/build/src/utils/__testfixtures__/TestEntity2.d.ts +0 -20
- package/build/src/utils/__testfixtures__/TestEntity2.js +0 -49
- package/build/src/utils/__testfixtures__/TestEntity2.js.map +0 -1
- package/build/src/utils/__testfixtures__/TestEntityWithMutationTriggers.d.ts +0 -36
- package/build/src/utils/__testfixtures__/TestEntityWithMutationTriggers.js +0 -80
- package/build/src/utils/__testfixtures__/TestEntityWithMutationTriggers.js.map +0 -1
- package/build/src/utils/__testfixtures__/TestViewerContext.d.ts +0 -3
- package/build/src/utils/__testfixtures__/TestViewerContext.js +0 -8
- package/build/src/utils/__testfixtures__/TestViewerContext.js.map +0 -1
- package/build/src/utils/__testfixtures__/createUnitTestEntityCompanionProvider.d.ts +0 -7
- package/build/src/utils/__testfixtures__/createUnitTestEntityCompanionProvider.js +0 -33
- package/build/src/utils/__testfixtures__/createUnitTestEntityCompanionProvider.js.map +0 -1
- package/build/src/utils/__testfixtures__/describeFieldTestCase.d.ts +0 -2
- package/build/src/utils/__testfixtures__/describeFieldTestCase.js +0 -19
- package/build/src/utils/__testfixtures__/describeFieldTestCase.js.map +0 -1
- package/build/src/utils/__tests__/EntityCreationUtils-test.d.ts +0 -1
- package/build/src/utils/__tests__/EntityCreationUtils-test.js +0 -144
- package/build/src/utils/__tests__/EntityCreationUtils-test.js.map +0 -1
- package/build/src/utils/__tests__/EntityPrivacyUtils-test.d.ts +0 -1
- package/build/src/utils/__tests__/EntityPrivacyUtils-test.js +0 -460
- package/build/src/utils/__tests__/EntityPrivacyUtils-test.js.map +0 -1
- package/build/src/utils/__tests__/canViewerDeleteAsync-edgeDeletionPermissionInferenceBehavior-test.d.ts +0 -1
- package/build/src/utils/__tests__/canViewerDeleteAsync-edgeDeletionPermissionInferenceBehavior-test.js +0 -180
- package/build/src/utils/__tests__/canViewerDeleteAsync-edgeDeletionPermissionInferenceBehavior-test.js.map +0 -1
- package/build/src/utils/__tests__/mergeEntityMutationTriggerConfigurations-test.d.ts +0 -1
- package/build/src/utils/__tests__/mergeEntityMutationTriggerConfigurations-test.js +0 -27
- package/build/src/utils/__tests__/mergeEntityMutationTriggerConfigurations-test.js.map +0 -1
- package/build/src/utils/collections/__tests__/SerializableKeyMap-test.d.ts +0 -5
- package/build/src/utils/collections/__tests__/SerializableKeyMap-test.js +0 -99
- package/build/src/utils/collections/__tests__/SerializableKeyMap-test.js.map +0 -1
- package/build/src/utils/collections/__tests__/maps-test.d.ts +0 -1
- package/build/src/utils/collections/__tests__/maps-test.js +0 -121
- package/build/src/utils/collections/__tests__/maps-test.js.map +0 -1
- package/build/src/utils/collections/__tests__/sets-test.d.ts +0 -1
- package/build/src/utils/collections/__tests__/sets-test.js +0 -19
- package/build/src/utils/collections/__tests__/sets-test.js.map +0 -1
- package/build/tsconfig.tsbuildinfo +0 -1
|
@@ -1,180 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
const globals_1 = require("@jest/globals");
|
|
4
|
-
const Entity_1 = require("../../Entity");
|
|
5
|
-
const EntityConfiguration_1 = require("../../EntityConfiguration");
|
|
6
|
-
const EntityFieldDefinition_1 = require("../../EntityFieldDefinition");
|
|
7
|
-
const EntityFields_1 = require("../../EntityFields");
|
|
8
|
-
const EntityPrivacyPolicy_1 = require("../../EntityPrivacyPolicy");
|
|
9
|
-
const ViewerContext_1 = require("../../ViewerContext");
|
|
10
|
-
const AlwaysAllowPrivacyPolicyRule_1 = require("../../rules/AlwaysAllowPrivacyPolicyRule");
|
|
11
|
-
const AlwaysDenyPrivacyPolicyRule_1 = require("../../rules/AlwaysDenyPrivacyPolicyRule");
|
|
12
|
-
const EntityPrivacyUtils_1 = require("../EntityPrivacyUtils");
|
|
13
|
-
const createUnitTestEntityCompanionProvider_1 = require("../__testfixtures__/createUnitTestEntityCompanionProvider");
|
|
14
|
-
(0, globals_1.describe)(EntityPrivacyUtils_1.canViewerDeleteAsync, () => {
|
|
15
|
-
(0, globals_1.describe)('edgeDeletionPermissionInferenceBehavior', () => {
|
|
16
|
-
(0, globals_1.it)('optimizes when EntityEdgeDeletionPermissionInferenceBehavior.ONE_IMPLIES_ALL', async () => {
|
|
17
|
-
const companionProvider = (0, createUnitTestEntityCompanionProvider_1.createUnitTestEntityCompanionProvider)();
|
|
18
|
-
const viewerContext = new ViewerContext_1.ViewerContext(companionProvider);
|
|
19
|
-
// create root
|
|
20
|
-
const testEntity = await TestEntity.creator(viewerContext).createAsync();
|
|
21
|
-
// create a bunch of leaves referencing root with
|
|
22
|
-
// edgeDeletionPermissionInferenceBehavior = EntityEdgeDeletionPermissionInferenceBehavior.ONE_IMPLIES_ALL
|
|
23
|
-
for (let i = 0; i < 10; i++) {
|
|
24
|
-
await TestLeafEntity.creator(viewerContext)
|
|
25
|
-
.setField('test_entity_id', testEntity.getID())
|
|
26
|
-
.createAsync();
|
|
27
|
-
}
|
|
28
|
-
for (let i = 0; i < 10; i++) {
|
|
29
|
-
await TestLeafLookupByFieldEntity.creator(viewerContext)
|
|
30
|
-
.setField('test_entity_id', testEntity.getID())
|
|
31
|
-
.createAsync();
|
|
32
|
-
}
|
|
33
|
-
const testLeafEntityCompanion = viewerContext.getViewerScopedEntityCompanionForClass(TestLeafEntity);
|
|
34
|
-
const testLeafEntityAuthorizeDeleteSpy = globals_1.jest.spyOn(testLeafEntityCompanion.entityCompanion.privacyPolicy, 'authorizeDeleteAsync');
|
|
35
|
-
const testLeafLookupByFieldEntityCompanion = viewerContext.getViewerScopedEntityCompanionForClass(TestLeafLookupByFieldEntity);
|
|
36
|
-
const testLeafLookupByFieldEntityAuthorizeDeleteSpy = globals_1.jest.spyOn(testLeafLookupByFieldEntityCompanion.entityCompanion.privacyPolicy, 'authorizeDeleteAsync');
|
|
37
|
-
const canViewerDelete = await (0, EntityPrivacyUtils_1.canViewerDeleteAsync)(TestEntity, testEntity);
|
|
38
|
-
(0, globals_1.expect)(canViewerDelete).toBe(true);
|
|
39
|
-
(0, globals_1.expect)(testLeafEntityAuthorizeDeleteSpy).toHaveBeenCalledTimes(1);
|
|
40
|
-
(0, globals_1.expect)(testLeafLookupByFieldEntityAuthorizeDeleteSpy).toHaveBeenCalledTimes(1);
|
|
41
|
-
});
|
|
42
|
-
(0, globals_1.it)('does not optimize when undefined', async () => {
|
|
43
|
-
const companionProvider = (0, createUnitTestEntityCompanionProvider_1.createUnitTestEntityCompanionProvider)();
|
|
44
|
-
const viewerContext = new ViewerContext_1.ViewerContext(companionProvider);
|
|
45
|
-
// create root
|
|
46
|
-
const testEntity = await TestEntity.creator(viewerContext).createAsync();
|
|
47
|
-
// create a bunch of leaves with no edgeDeletionPermissionInferenceBehavior
|
|
48
|
-
for (let i = 0; i < 10; i++) {
|
|
49
|
-
await TestLeafNoInferenceEntity.creator(viewerContext)
|
|
50
|
-
.setField('test_entity_id', testEntity.getID())
|
|
51
|
-
.createAsync();
|
|
52
|
-
}
|
|
53
|
-
const companion = viewerContext.getViewerScopedEntityCompanionForClass(TestLeafNoInferenceEntity);
|
|
54
|
-
const authorizeDeleteSpy = globals_1.jest.spyOn(companion.entityCompanion.privacyPolicy, 'authorizeDeleteAsync');
|
|
55
|
-
const canViewerDelete = await (0, EntityPrivacyUtils_1.canViewerDeleteAsync)(TestEntity, testEntity);
|
|
56
|
-
(0, globals_1.expect)(canViewerDelete).toBe(true);
|
|
57
|
-
(0, globals_1.expect)(authorizeDeleteSpy).toHaveBeenCalledTimes(10);
|
|
58
|
-
});
|
|
59
|
-
});
|
|
60
|
-
});
|
|
61
|
-
class AlwaysAllowEntityPrivacyPolicy extends EntityPrivacyPolicy_1.EntityPrivacyPolicy {
|
|
62
|
-
readRules = [
|
|
63
|
-
new AlwaysAllowPrivacyPolicyRule_1.AlwaysAllowPrivacyPolicyRule(),
|
|
64
|
-
];
|
|
65
|
-
createRules = [
|
|
66
|
-
new AlwaysAllowPrivacyPolicyRule_1.AlwaysAllowPrivacyPolicyRule(),
|
|
67
|
-
];
|
|
68
|
-
updateRules = [
|
|
69
|
-
new AlwaysDenyPrivacyPolicyRule_1.AlwaysDenyPrivacyPolicyRule(),
|
|
70
|
-
];
|
|
71
|
-
deleteRules = [
|
|
72
|
-
new AlwaysAllowPrivacyPolicyRule_1.AlwaysAllowPrivacyPolicyRule(),
|
|
73
|
-
];
|
|
74
|
-
}
|
|
75
|
-
class TestEntity extends Entity_1.Entity {
|
|
76
|
-
static defineCompanionDefinition() {
|
|
77
|
-
return {
|
|
78
|
-
entityClass: TestEntity,
|
|
79
|
-
entityConfiguration: new EntityConfiguration_1.EntityConfiguration({
|
|
80
|
-
idField: 'id',
|
|
81
|
-
tableName: 'blah',
|
|
82
|
-
inboundEdges: [TestLeafEntity, TestLeafLookupByFieldEntity, TestLeafNoInferenceEntity],
|
|
83
|
-
schema: {
|
|
84
|
-
id: new EntityFields_1.UUIDField({
|
|
85
|
-
columnName: 'custom_id',
|
|
86
|
-
cache: false,
|
|
87
|
-
}),
|
|
88
|
-
},
|
|
89
|
-
databaseAdapterFlavor: 'postgres',
|
|
90
|
-
cacheAdapterFlavor: 'redis',
|
|
91
|
-
}),
|
|
92
|
-
privacyPolicyClass: AlwaysAllowEntityPrivacyPolicy,
|
|
93
|
-
};
|
|
94
|
-
}
|
|
95
|
-
}
|
|
96
|
-
class TestLeafEntity extends Entity_1.Entity {
|
|
97
|
-
static defineCompanionDefinition() {
|
|
98
|
-
return {
|
|
99
|
-
entityClass: TestLeafEntity,
|
|
100
|
-
entityConfiguration: new EntityConfiguration_1.EntityConfiguration({
|
|
101
|
-
idField: 'id',
|
|
102
|
-
tableName: 'blah_2',
|
|
103
|
-
schema: {
|
|
104
|
-
id: new EntityFields_1.UUIDField({
|
|
105
|
-
columnName: 'custom_id',
|
|
106
|
-
cache: false,
|
|
107
|
-
}),
|
|
108
|
-
test_entity_id: new EntityFields_1.UUIDField({
|
|
109
|
-
columnName: 'test_entity_id',
|
|
110
|
-
association: {
|
|
111
|
-
associatedEntityClass: TestEntity,
|
|
112
|
-
edgeDeletionBehavior: EntityFieldDefinition_1.EntityEdgeDeletionBehavior.CASCADE_DELETE,
|
|
113
|
-
edgeDeletionAuthorizationInferenceBehavior: EntityFieldDefinition_1.EntityEdgeDeletionAuthorizationInferenceBehavior.ONE_IMPLIES_ALL,
|
|
114
|
-
},
|
|
115
|
-
}),
|
|
116
|
-
},
|
|
117
|
-
databaseAdapterFlavor: 'postgres',
|
|
118
|
-
cacheAdapterFlavor: 'redis',
|
|
119
|
-
}),
|
|
120
|
-
privacyPolicyClass: AlwaysAllowEntityPrivacyPolicy,
|
|
121
|
-
};
|
|
122
|
-
}
|
|
123
|
-
}
|
|
124
|
-
class TestLeafLookupByFieldEntity extends Entity_1.Entity {
|
|
125
|
-
static defineCompanionDefinition() {
|
|
126
|
-
return {
|
|
127
|
-
entityClass: TestLeafEntity,
|
|
128
|
-
entityConfiguration: new EntityConfiguration_1.EntityConfiguration({
|
|
129
|
-
idField: 'id',
|
|
130
|
-
tableName: 'blah_4',
|
|
131
|
-
schema: {
|
|
132
|
-
id: new EntityFields_1.UUIDField({
|
|
133
|
-
columnName: 'custom_id',
|
|
134
|
-
cache: false,
|
|
135
|
-
}),
|
|
136
|
-
test_entity_id: new EntityFields_1.UUIDField({
|
|
137
|
-
columnName: 'test_entity_id',
|
|
138
|
-
association: {
|
|
139
|
-
associatedEntityClass: TestEntity,
|
|
140
|
-
edgeDeletionBehavior: EntityFieldDefinition_1.EntityEdgeDeletionBehavior.CASCADE_DELETE,
|
|
141
|
-
associatedEntityLookupByField: 'id',
|
|
142
|
-
edgeDeletionAuthorizationInferenceBehavior: EntityFieldDefinition_1.EntityEdgeDeletionAuthorizationInferenceBehavior.ONE_IMPLIES_ALL,
|
|
143
|
-
},
|
|
144
|
-
}),
|
|
145
|
-
},
|
|
146
|
-
databaseAdapterFlavor: 'postgres',
|
|
147
|
-
cacheAdapterFlavor: 'redis',
|
|
148
|
-
}),
|
|
149
|
-
privacyPolicyClass: AlwaysAllowEntityPrivacyPolicy,
|
|
150
|
-
};
|
|
151
|
-
}
|
|
152
|
-
}
|
|
153
|
-
class TestLeafNoInferenceEntity extends Entity_1.Entity {
|
|
154
|
-
static defineCompanionDefinition() {
|
|
155
|
-
return {
|
|
156
|
-
entityClass: TestLeafNoInferenceEntity,
|
|
157
|
-
entityConfiguration: new EntityConfiguration_1.EntityConfiguration({
|
|
158
|
-
idField: 'id',
|
|
159
|
-
tableName: 'blah_3',
|
|
160
|
-
schema: {
|
|
161
|
-
id: new EntityFields_1.UUIDField({
|
|
162
|
-
columnName: 'custom_id',
|
|
163
|
-
cache: false,
|
|
164
|
-
}),
|
|
165
|
-
test_entity_id: new EntityFields_1.UUIDField({
|
|
166
|
-
columnName: 'test_entity_id',
|
|
167
|
-
association: {
|
|
168
|
-
associatedEntityClass: TestEntity,
|
|
169
|
-
edgeDeletionBehavior: EntityFieldDefinition_1.EntityEdgeDeletionBehavior.CASCADE_DELETE,
|
|
170
|
-
},
|
|
171
|
-
}),
|
|
172
|
-
},
|
|
173
|
-
databaseAdapterFlavor: 'postgres',
|
|
174
|
-
cacheAdapterFlavor: 'redis',
|
|
175
|
-
}),
|
|
176
|
-
privacyPolicyClass: AlwaysAllowEntityPrivacyPolicy,
|
|
177
|
-
};
|
|
178
|
-
}
|
|
179
|
-
}
|
|
180
|
-
//# sourceMappingURL=canViewerDeleteAsync-edgeDeletionPermissionInferenceBehavior-test.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"canViewerDeleteAsync-edgeDeletionPermissionInferenceBehavior-test.js","sourceRoot":"","sources":["../../../../src/utils/__tests__/canViewerDeleteAsync-edgeDeletionPermissionInferenceBehavior-test.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export {};
|
|
@@ -1,27 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
const globals_1 = require("@jest/globals");
|
|
4
|
-
const TestEntityWithMutationTriggers_1 = require("../__testfixtures__/TestEntityWithMutationTriggers");
|
|
5
|
-
const mergeEntityMutationTriggerConfigurations_1 = require("../mergeEntityMutationTriggerConfigurations");
|
|
6
|
-
(0, globals_1.describe)(mergeEntityMutationTriggerConfigurations_1.mergeEntityMutationTriggerConfigurations, () => {
|
|
7
|
-
(0, globals_1.it)('successfully merges triggers', async () => {
|
|
8
|
-
const firstAfter = new TestEntityWithMutationTriggers_1.TestMutationTrigger('2');
|
|
9
|
-
const secondAfter = new TestEntityWithMutationTriggers_1.TestMutationTrigger('3');
|
|
10
|
-
const merged = (0, mergeEntityMutationTriggerConfigurations_1.mergeEntityMutationTriggerConfigurations)({
|
|
11
|
-
beforeAll: [new TestEntityWithMutationTriggers_1.TestMutationTrigger('1')],
|
|
12
|
-
afterAll: [firstAfter],
|
|
13
|
-
}, {
|
|
14
|
-
afterAll: [secondAfter],
|
|
15
|
-
});
|
|
16
|
-
(0, globals_1.expect)(merged.beforeAll?.length).toBe(1);
|
|
17
|
-
(0, globals_1.expect)(merged.afterAll).toEqual([firstAfter, secondAfter]);
|
|
18
|
-
(0, globals_1.expect)(merged.beforeCreate?.length).toBeFalsy();
|
|
19
|
-
(0, globals_1.expect)(merged.afterCreate?.length).toBeFalsy();
|
|
20
|
-
(0, globals_1.expect)(merged.beforeUpdate?.length).toBeFalsy();
|
|
21
|
-
(0, globals_1.expect)(merged.afterUpdate?.length).toBeFalsy();
|
|
22
|
-
(0, globals_1.expect)(merged.beforeDelete?.length).toBeFalsy();
|
|
23
|
-
(0, globals_1.expect)(merged.afterDelete?.length).toBeFalsy();
|
|
24
|
-
(0, globals_1.expect)(merged.afterCommit?.length).toBeFalsy();
|
|
25
|
-
});
|
|
26
|
-
});
|
|
27
|
-
//# sourceMappingURL=mergeEntityMutationTriggerConfigurations-test.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"mergeEntityMutationTriggerConfigurations-test.js","sourceRoot":"","sources":["../../../../src/utils/__tests__/mergeEntityMutationTriggerConfigurations-test.ts"],"names":[],"mappings":";;AAAA,2CAAqD;AAErD,uGAAyF;AACzF,0GAAuG;AAEvG,IAAA,kBAAQ,EAAC,mFAAwC,EAAE,GAAG,EAAE;IACtD,IAAA,YAAE,EAAC,8BAA8B,EAAE,KAAK,IAAI,EAAE;QAC5C,MAAM,UAAU,GAAG,IAAI,oDAAmB,CAAC,GAAG,CAAC,CAAC;QAChD,MAAM,WAAW,GAAG,IAAI,oDAAmB,CAAC,GAAG,CAAC,CAAC;QAEjD,MAAM,MAAM,GAAG,IAAA,mFAAwC,EACrD;YACE,SAAS,EAAE,CAAC,IAAI,oDAAmB,CAAC,GAAG,CAAC,CAAC;YACzC,QAAQ,EAAE,CAAC,UAAU,CAAC;SACvB,EACD;YACE,QAAQ,EAAE,CAAC,WAAW,CAAC;SACxB,CACF,CAAC;QAEF,IAAA,gBAAM,EAAC,MAAM,CAAC,SAAS,EAAE,MAAM,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QACzC,IAAA,gBAAM,EAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,OAAO,CAAC,CAAC,UAAU,EAAE,WAAW,CAAC,CAAC,CAAC;QAC3D,IAAA,gBAAM,EAAC,MAAM,CAAC,YAAY,EAAE,MAAM,CAAC,CAAC,SAAS,EAAE,CAAC;QAChD,IAAA,gBAAM,EAAC,MAAM,CAAC,WAAW,EAAE,MAAM,CAAC,CAAC,SAAS,EAAE,CAAC;QAC/C,IAAA,gBAAM,EAAC,MAAM,CAAC,YAAY,EAAE,MAAM,CAAC,CAAC,SAAS,EAAE,CAAC;QAChD,IAAA,gBAAM,EAAC,MAAM,CAAC,WAAW,EAAE,MAAM,CAAC,CAAC,SAAS,EAAE,CAAC;QAC/C,IAAA,gBAAM,EAAC,MAAM,CAAC,YAAY,EAAE,MAAM,CAAC,CAAC,SAAS,EAAE,CAAC;QAChD,IAAA,gBAAM,EAAC,MAAM,CAAC,WAAW,EAAE,MAAM,CAAC,CAAC,SAAS,EAAE,CAAC;QAC/C,IAAA,gBAAM,EAAC,MAAM,CAAC,WAAW,EAAE,MAAM,CAAC,CAAC,SAAS,EAAE,CAAC;IACjD,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -1,99 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
const globals_1 = require("@jest/globals");
|
|
4
|
-
const SerializableKeyMap_1 = require("../SerializableKeyMap");
|
|
5
|
-
(0, globals_1.describe)(SerializableKeyMap_1.SerializableKeyMap, () => {
|
|
6
|
-
(0, globals_1.it)('behaves as a Map/ReadonlyMap', () => {
|
|
7
|
-
const map = new TestSerializableKeyMap();
|
|
8
|
-
(0, globals_1.expect)(map.size).toBe(0);
|
|
9
|
-
(0, globals_1.expect)(map.has(new TestSerializableKey('key'))).toBe(false);
|
|
10
|
-
(0, globals_1.expect)(map.get(new TestSerializableKey('key'))).toBe(undefined);
|
|
11
|
-
map.set(new TestSerializableKey('key'), 'value');
|
|
12
|
-
(0, globals_1.expect)(map.size).toBe(1);
|
|
13
|
-
(0, globals_1.expect)(map.has(new TestSerializableKey('key'))).toBe(true);
|
|
14
|
-
(0, globals_1.expect)(map.get(new TestSerializableKey('key'))).toBe('value');
|
|
15
|
-
map.delete(new TestSerializableKey('key'));
|
|
16
|
-
(0, globals_1.expect)(map.size).toBe(0);
|
|
17
|
-
(0, globals_1.expect)(map.has(new TestSerializableKey('key'))).toBe(false);
|
|
18
|
-
(0, globals_1.expect)(map.get(new TestSerializableKey('key'))).toBe(undefined);
|
|
19
|
-
map.set(new TestSerializableKey('key'), 'value');
|
|
20
|
-
(0, globals_1.expect)(map.size).toBe(1);
|
|
21
|
-
map.clear();
|
|
22
|
-
(0, globals_1.expect)(map.size).toBe(0);
|
|
23
|
-
(0, globals_1.expect)(map.get(new TestSerializableKey('key'))).toBe(undefined);
|
|
24
|
-
map.set(new TestSerializableKey('key'), 'value');
|
|
25
|
-
map.set(new TestSerializableKey('key'), 'value');
|
|
26
|
-
(0, globals_1.expect)(map.size).toBe(1);
|
|
27
|
-
map.set(new TestSerializableKey('key2'), 'value2');
|
|
28
|
-
(0, globals_1.expect)(map.size).toBe(2);
|
|
29
|
-
// check keys ordering based on insertion order
|
|
30
|
-
const keys = Array.from(map.keys());
|
|
31
|
-
(0, globals_1.expect)(keys.length).toBe(2);
|
|
32
|
-
(0, globals_1.expect)(keys[0].value).toBe('key');
|
|
33
|
-
(0, globals_1.expect)(keys[1].value).toBe('key2');
|
|
34
|
-
// check values ordering based on insertion order
|
|
35
|
-
const values = Array.from(map.values());
|
|
36
|
-
(0, globals_1.expect)(values.length).toBe(2);
|
|
37
|
-
(0, globals_1.expect)(values[0]).toBe('value');
|
|
38
|
-
(0, globals_1.expect)(values[1]).toBe('value2');
|
|
39
|
-
// check entries ordering based on insertion order
|
|
40
|
-
const entries = Array.from(map.entries());
|
|
41
|
-
(0, globals_1.expect)(entries.length).toBe(2);
|
|
42
|
-
(0, globals_1.expect)(entries[0][0].value).toBe('key');
|
|
43
|
-
(0, globals_1.expect)(entries[0][1]).toBe('value');
|
|
44
|
-
(0, globals_1.expect)(entries[1][0].value).toBe('key2');
|
|
45
|
-
(0, globals_1.expect)(entries[1][1]).toBe('value2');
|
|
46
|
-
// check forEach ordering based on insertion order
|
|
47
|
-
const forEachEntries = [];
|
|
48
|
-
map.forEach((value, key) => {
|
|
49
|
-
forEachEntries.push([key, value]);
|
|
50
|
-
});
|
|
51
|
-
(0, globals_1.expect)(forEachEntries.length).toBe(2);
|
|
52
|
-
(0, globals_1.expect)(forEachEntries[0][0].value).toBe('key');
|
|
53
|
-
(0, globals_1.expect)(forEachEntries[0][1]).toBe('value');
|
|
54
|
-
(0, globals_1.expect)(forEachEntries[1][0].value).toBe('key2');
|
|
55
|
-
(0, globals_1.expect)(forEachEntries[1][1]).toBe('value2');
|
|
56
|
-
// check iterator ordering based on insertion order
|
|
57
|
-
const iteratorEntries = Array.from(map);
|
|
58
|
-
(0, globals_1.expect)(iteratorEntries.length).toBe(2);
|
|
59
|
-
(0, globals_1.expect)(iteratorEntries[0][0].value).toBe('key');
|
|
60
|
-
(0, globals_1.expect)(iteratorEntries[0][1]).toBe('value');
|
|
61
|
-
(0, globals_1.expect)(iteratorEntries[1][0].value).toBe('key2');
|
|
62
|
-
(0, globals_1.expect)(iteratorEntries[1][1]).toBe('value2');
|
|
63
|
-
});
|
|
64
|
-
(0, globals_1.it)('constructs with values', () => {
|
|
65
|
-
const map = new TestSerializableKeyMap([
|
|
66
|
-
[new TestSerializableKey('key'), 'value'],
|
|
67
|
-
[new TestSerializableKey('key2'), 'value2'],
|
|
68
|
-
]);
|
|
69
|
-
(0, globals_1.expect)(map.size).toBe(2);
|
|
70
|
-
(0, globals_1.expect)(map.get(new TestSerializableKey('key'))).toBe('value');
|
|
71
|
-
(0, globals_1.expect)(map.get(new TestSerializableKey('key2'))).toBe('value2');
|
|
72
|
-
const keys = Array.from(map.keys());
|
|
73
|
-
(0, globals_1.expect)(keys.length).toBe(2);
|
|
74
|
-
(0, globals_1.expect)(keys[0].value).toBe('key');
|
|
75
|
-
(0, globals_1.expect)(keys[1].value).toBe('key2');
|
|
76
|
-
});
|
|
77
|
-
(0, globals_1.it)('has correct toStringTag', () => {
|
|
78
|
-
const map = new TestSerializableKeyMap();
|
|
79
|
-
(0, globals_1.expect)(Object.prototype.toString.call(map)).toBe('[object SerializableKeyMap]');
|
|
80
|
-
});
|
|
81
|
-
});
|
|
82
|
-
class TestSerializableKey {
|
|
83
|
-
value;
|
|
84
|
-
constructor(value) {
|
|
85
|
-
this.value = value;
|
|
86
|
-
}
|
|
87
|
-
serialize() {
|
|
88
|
-
return JSON.stringify(this.value);
|
|
89
|
-
}
|
|
90
|
-
static deserialize(serialized) {
|
|
91
|
-
return new TestSerializableKey(JSON.parse(serialized));
|
|
92
|
-
}
|
|
93
|
-
}
|
|
94
|
-
class TestSerializableKeyMap extends SerializableKeyMap_1.SerializableKeyMap {
|
|
95
|
-
deserializeKey(serializedKey) {
|
|
96
|
-
return TestSerializableKey.deserialize(serializedKey);
|
|
97
|
-
}
|
|
98
|
-
}
|
|
99
|
-
//# sourceMappingURL=SerializableKeyMap-test.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"SerializableKeyMap-test.js","sourceRoot":"","sources":["../../../../../src/utils/collections/__tests__/SerializableKeyMap-test.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export {};
|
|
@@ -1,121 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
const globals_1 = require("@jest/globals");
|
|
4
|
-
const maps_1 = require("../maps");
|
|
5
|
-
(0, globals_1.describe)(maps_1.computeIfAbsent, () => {
|
|
6
|
-
(0, globals_1.it)('computes a value when absent', () => {
|
|
7
|
-
const map = new Map();
|
|
8
|
-
const blah = (0, maps_1.computeIfAbsent)(map, 'hello', () => 'world');
|
|
9
|
-
(0, globals_1.expect)(blah).toEqual(map.get('hello'));
|
|
10
|
-
});
|
|
11
|
-
(0, globals_1.it)('does not compute a value when already present', () => {
|
|
12
|
-
const map = new Map([['hello', 'world']]);
|
|
13
|
-
let didCompute = false;
|
|
14
|
-
const blah = (0, maps_1.computeIfAbsent)(map, 'hello', () => {
|
|
15
|
-
didCompute = true;
|
|
16
|
-
return 'world2';
|
|
17
|
-
});
|
|
18
|
-
(0, globals_1.expect)(blah).toEqual(map.get('hello'));
|
|
19
|
-
(0, globals_1.expect)(didCompute).toBe(false);
|
|
20
|
-
});
|
|
21
|
-
});
|
|
22
|
-
(0, globals_1.describe)(maps_1.mapMap, () => {
|
|
23
|
-
(0, globals_1.it)('maps a map', () => {
|
|
24
|
-
const map = new Map([['hello', 'world']]);
|
|
25
|
-
const map2 = (0, maps_1.mapMap)(map, () => 2);
|
|
26
|
-
(0, globals_1.expect)(map2.get('hello')).toEqual(2);
|
|
27
|
-
});
|
|
28
|
-
});
|
|
29
|
-
(0, globals_1.describe)(maps_1.mapMapAsync, () => {
|
|
30
|
-
(0, globals_1.it)('maps a map with async mapper', async () => {
|
|
31
|
-
const map = new Map([['hello', 'world']]);
|
|
32
|
-
const map2 = await (0, maps_1.mapMapAsync)(map, async () => await Promise.resolve(2));
|
|
33
|
-
(0, globals_1.expect)(map2.get('hello')).toEqual(2);
|
|
34
|
-
});
|
|
35
|
-
});
|
|
36
|
-
(0, globals_1.describe)(maps_1.mapKeys, () => {
|
|
37
|
-
(0, globals_1.it)('maps keys', async () => {
|
|
38
|
-
const map = new Map([
|
|
39
|
-
['hello', 'world'],
|
|
40
|
-
['amphibian', 'creature'],
|
|
41
|
-
]);
|
|
42
|
-
const map2 = (0, maps_1.mapKeys)(map, (k) => k.length);
|
|
43
|
-
(0, globals_1.expect)(map2.size).toEqual(2);
|
|
44
|
-
(0, globals_1.expect)(map2.get(5)).toEqual('world');
|
|
45
|
-
(0, globals_1.expect)(map2.get(9)).toEqual('creature');
|
|
46
|
-
});
|
|
47
|
-
});
|
|
48
|
-
(0, globals_1.describe)(maps_1.zipToMap, () => {
|
|
49
|
-
(0, globals_1.it)('zips keys to values', () => {
|
|
50
|
-
const keys = [1, 2, 3];
|
|
51
|
-
const values = ['a', 'b', 'c'];
|
|
52
|
-
const map = (0, maps_1.zipToMap)(keys, values);
|
|
53
|
-
(0, globals_1.expect)(map.get(2)).toEqual('b');
|
|
54
|
-
});
|
|
55
|
-
(0, globals_1.it)('throws when input lengths mismatch', () => {
|
|
56
|
-
const keys = [1, 2];
|
|
57
|
-
const values = [1];
|
|
58
|
-
(0, globals_1.expect)(() => (0, maps_1.zipToMap)(keys, values)).toThrow('zipToMap input length mismatch: keys[2], values[1]');
|
|
59
|
-
});
|
|
60
|
-
});
|
|
61
|
-
(0, globals_1.describe)(maps_1.invertMap, () => {
|
|
62
|
-
(0, globals_1.it)('inverts a map', () => {
|
|
63
|
-
const map = new Map([
|
|
64
|
-
[1, 'world'],
|
|
65
|
-
[2, 'what'],
|
|
66
|
-
]);
|
|
67
|
-
const inverted = (0, maps_1.invertMap)(map);
|
|
68
|
-
(0, globals_1.expect)(inverted.get('world')).toEqual(1);
|
|
69
|
-
});
|
|
70
|
-
(0, globals_1.it)('keeps last inverted key instance', () => {
|
|
71
|
-
const map = new Map([
|
|
72
|
-
[1, 'world'],
|
|
73
|
-
[2, 'world'],
|
|
74
|
-
]);
|
|
75
|
-
const inverted = (0, maps_1.invertMap)(map);
|
|
76
|
-
(0, globals_1.expect)(inverted.get('world')).toEqual(2);
|
|
77
|
-
});
|
|
78
|
-
});
|
|
79
|
-
(0, globals_1.describe)(maps_1.reduceMap, () => {
|
|
80
|
-
(0, globals_1.it)('reduces a map', () => {
|
|
81
|
-
const map = new Map([
|
|
82
|
-
['a', 'a'],
|
|
83
|
-
['b', 'b'],
|
|
84
|
-
]);
|
|
85
|
-
const reduction = (0, maps_1.reduceMap)(map, (acc, v, k) => acc.concat(v).concat(k), 'initial-');
|
|
86
|
-
(0, globals_1.expect)(reduction).toEqual('initial-aabb');
|
|
87
|
-
});
|
|
88
|
-
});
|
|
89
|
-
(0, globals_1.describe)(maps_1.reduceMapAsync, () => {
|
|
90
|
-
(0, globals_1.it)('reduces a map (async)', async () => {
|
|
91
|
-
const map = new Map([
|
|
92
|
-
['a', 'a'],
|
|
93
|
-
['b', 'b'],
|
|
94
|
-
]);
|
|
95
|
-
const reduction = await (0, maps_1.reduceMapAsync)(map, async (acc, v, k) => acc.concat(v).concat(k), 'initial-');
|
|
96
|
-
(0, globals_1.expect)(reduction).toEqual('initial-aabb');
|
|
97
|
-
});
|
|
98
|
-
});
|
|
99
|
-
(0, globals_1.describe)(maps_1.filterMap, () => {
|
|
100
|
-
(0, globals_1.it)('filters a map', () => {
|
|
101
|
-
const map = new Map([
|
|
102
|
-
['a', false],
|
|
103
|
-
['b', true],
|
|
104
|
-
]);
|
|
105
|
-
const filteredMap = (0, maps_1.filterMap)(map, (v) => v);
|
|
106
|
-
(0, globals_1.expect)(filteredMap.get('a')).toBeUndefined();
|
|
107
|
-
(0, globals_1.expect)(filteredMap.get('b')).toBe(true);
|
|
108
|
-
});
|
|
109
|
-
(0, globals_1.it)('can use predicates', () => {
|
|
110
|
-
function truthy(value) {
|
|
111
|
-
return !!value;
|
|
112
|
-
}
|
|
113
|
-
const map = new Map([
|
|
114
|
-
['a', 'yes'],
|
|
115
|
-
['b', null],
|
|
116
|
-
]);
|
|
117
|
-
const filteredMap = (0, maps_1.filterMap)(map, truthy);
|
|
118
|
-
(0, globals_1.expect)(filteredMap.size).toBe(1);
|
|
119
|
-
});
|
|
120
|
-
});
|
|
121
|
-
//# sourceMappingURL=maps-test.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"maps-test.js","sourceRoot":"","sources":["../../../../../src/utils/collections/__tests__/maps-test.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export {};
|
|
@@ -1,19 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
const globals_1 = require("@jest/globals");
|
|
4
|
-
const sets_1 = require("../sets");
|
|
5
|
-
(0, globals_1.describe)(sets_1.areSetsEqual, () => {
|
|
6
|
-
globals_1.it.each([
|
|
7
|
-
[new Set([1, 2]), new Set([1, 2])],
|
|
8
|
-
[new Set([1, 2]), new Set([2, 1])],
|
|
9
|
-
])('equal cases: %p', (a, b) => {
|
|
10
|
-
(0, globals_1.expect)((0, sets_1.areSetsEqual)(a, b)).toBe(true);
|
|
11
|
-
});
|
|
12
|
-
globals_1.it.each([
|
|
13
|
-
[new Set([1, 2, 3]), new Set([1, 2])],
|
|
14
|
-
[new Set([1, 2]), new Set([1, 2, 3])],
|
|
15
|
-
])('non-equal cases: %p', (a, b) => {
|
|
16
|
-
(0, globals_1.expect)((0, sets_1.areSetsEqual)(a, b)).toBe(false);
|
|
17
|
-
});
|
|
18
|
-
});
|
|
19
|
-
//# sourceMappingURL=sets-test.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"sets-test.js","sourceRoot":"","sources":["../../../../../src/utils/collections/__tests__/sets-test.ts"],"names":[],"mappings":";;AAAA,2CAAqD;AAErD,kCAAuC;AAEvC,IAAA,kBAAQ,EAAC,mBAAY,EAAE,GAAG,EAAE;IAC1B,YAAE,CAAC,IAAI,CAAC;QACN,CAAC,IAAI,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,IAAI,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAClC,CAAC,IAAI,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,IAAI,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;KACnC,CAAC,CAAC,iBAAiB,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE;QAC7B,IAAA,gBAAM,EAAC,IAAA,mBAAY,EAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACxC,CAAC,CAAC,CAAC;IAEH,YAAE,CAAC,IAAI,CAAC;QACN,CAAC,IAAI,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,IAAI,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACrC,CAAC,IAAI,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,IAAI,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;KACtC,CAAC,CAAC,qBAAqB,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE;QACjC,IAAA,gBAAM,EAAC,IAAA,mBAAY,EAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACzC,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|