Skip to content

Commit

Permalink
fix(mojaloop/3017): callbacks count comparison logic (#419)
Browse files Browse the repository at this point in the history
* fix: callbacks count comparison logic

* chore: added some delay for testing

* chore: removed the delay

* chore: some improvements in func tests

* chore: updated dependencies
  • Loading branch information
vijayg10 authored Nov 10, 2022
1 parent f4f23ee commit 56e1db0
Show file tree
Hide file tree
Showing 10 changed files with 84 additions and 57 deletions.
4 changes: 2 additions & 2 deletions modules/api-svc/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -87,7 +87,7 @@
"prom-client": "^14.1.0",
"promise-timeout": "^1.3.0",
"random-word-slugs": "^0.1.6",
"redis": "^4.4.0",
"redis": "^4.5.0",
"uuidv4": "^6.2.13",
"ws": "^8.11.0"
},
Expand All @@ -106,7 +106,7 @@
"nock": "^13.2.9",
"npm-check-updates": "^16.3.18",
"openapi-response-validator": "^12.0.2",
"openapi-typescript": "^6.0.1",
"openapi-typescript": "^6.0.2",
"redis-mock": "^0.56.3",
"replace": "^1.2.2",
"standard-version": "^9.5.0",
Expand Down
2 changes: 1 addition & 1 deletion modules/outbound-command-event-handler/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -48,7 +48,7 @@
"convict": "^6.2.3",
"express": "^4.18.2",
"openapi-backend": "^5.5.0",
"redis": "^4.4.0",
"redis": "^4.5.0",
"swagger-ui-express": "^4.6.0",
"yamljs": "^0.3.0"
},
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -49,8 +49,6 @@ export async function handleProcessBulkQuotesCallbackCmdEvt(
const processBulkQuotesCallbackMessage = message as ProcessBulkQuotesCallbackCmdEvt;
try {
logger.info(`Got ProcessBulkQuotesCallbackCmdEvt: id=${processBulkQuotesCallbackMessage.getKey()}`);
let successCountAfterIncrement;
let failedCountAfterIncrement;

// Create aggregate
const bulkTransactionAgg = await BulkTransactionAgg.CreateFromRepo(
Expand All @@ -68,7 +66,6 @@ export async function handleProcessBulkQuotesCallbackCmdEvt(
// bulkQuotesResult.currentState === 'ERROR_OCCURRED' necessitates erroring out all individual transfers in that bulk batch.
if(bulkQuotesResult?.currentState === SDKOutboundTransferState.COMPLETED) {
bulkBatch.setState(BulkBatchInternalState.AGREEMENT_COMPLETED);
successCountAfterIncrement = await bulkTransactionAgg.incrementBulkQuotesSuccessCount();

// Iterate through items in batch and update the individual states
for await (const quoteResult of bulkQuotesResult.individualQuoteResults) {
Expand Down Expand Up @@ -97,7 +94,6 @@ export async function handleProcessBulkQuotesCallbackCmdEvt(
// to AGREEMENT_FAILED.
} else {
bulkBatch.setState(BulkBatchInternalState.AGREEMENT_FAILED);
failedCountAfterIncrement = await bulkTransactionAgg.incrementBulkQuotesFailedCount();

const individualTransferIds = Object.values(bulkBatch.quoteIdReferenceIdMap);
for await (const individualTransferId of individualTransferIds) {
Expand Down Expand Up @@ -141,9 +137,16 @@ export async function handleProcessBulkQuotesCallbackCmdEvt(
// Progressing to the next step
// Check the status of the remaining items in the bulk
const bulkQuotesTotalCount = await bulkTransactionAgg.getBulkQuotesTotalCount();
// eslint-disable-next-line max-len
const bulkQuotesSuccessCount = successCountAfterIncrement || await bulkTransactionAgg.getBulkQuotesSuccessCount();
const bulkQuotesFailedCount = failedCountAfterIncrement || await bulkTransactionAgg.getBulkQuotesFailedCount();
let bulkQuotesSuccessCount;
let bulkQuotesFailedCount;
if(bulkQuotesResult?.currentState === SDKOutboundTransferState.COMPLETED) {
bulkQuotesSuccessCount = await bulkTransactionAgg.incrementBulkQuotesSuccessCount();
bulkQuotesFailedCount = await bulkTransactionAgg.getBulkQuotesFailedCount();
} else {
bulkQuotesFailedCount = await bulkTransactionAgg.incrementBulkQuotesFailedCount();
bulkQuotesSuccessCount = await bulkTransactionAgg.getBulkQuotesSuccessCount();
}

if(bulkQuotesTotalCount === (bulkQuotesSuccessCount + bulkQuotesFailedCount)) {
// Update global state "AGREEMENT_COMPLETED"
await bulkTransactionAgg.setGlobalState(BulkTransactionInternalState.AGREEMENT_COMPLETED);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -45,8 +45,7 @@ export async function handleProcessBulkTransfersCallbackCmdEvt(
const processBulkTransfersCallbackMessage = message as ProcessBulkTransfersCallbackCmdEvt;
try {
logger.info(`Got ProcessBulkTransfersCallbackCmdEvt: id=${processBulkTransfersCallbackMessage.getKey()}`);
let successCount;
let failedCount;

// Create aggregate
const bulkTransactionAgg = await BulkTransactionAgg.CreateFromRepo(
processBulkTransfersCallbackMessage.getKey(),
Expand All @@ -63,7 +62,6 @@ export async function handleProcessBulkTransfersCallbackCmdEvt(
// bulkTransfersResult.currentState === 'ERROR_OCCURRED' necessitates erroring out all individual transfers in that bulk batch.
if(bulkTransfersResult?.currentState === SDKOutboundTransferState.COMPLETED) {
bulkBatch.setState(BulkBatchInternalState.TRANSFERS_COMPLETED);
successCount = await bulkTransactionAgg.incrementBulkTransfersSuccessCount();

// Iterate through items in batch and update the individual states
// TODO: We need to handle the case where the Quote was not successful!
Expand Down Expand Up @@ -91,7 +89,6 @@ export async function handleProcessBulkTransfersCallbackCmdEvt(
// to TRANSFERS_FAILED.
} else {
bulkBatch.setState(BulkBatchInternalState.TRANSFERS_FAILED);
failedCount = await bulkTransactionAgg.incrementBulkTransfersFailedCount();

const individualTransferIds = Object.values(bulkBatch.transferIdReferenceIdMap);
for await (const individualTransferId of individualTransferIds) {
Expand Down Expand Up @@ -119,8 +116,15 @@ export async function handleProcessBulkTransfersCallbackCmdEvt(
// Progressing to the next step
// Check the status of the remaining items in the bulk
const bulkTransfersTotalCount = await bulkTransactionAgg.getBulkTransfersTotalCount();
const bulkTransfersSuccessCount = successCount || await bulkTransactionAgg.getBulkTransfersSuccessCount();
const bulkTransfersFailedCount = failedCount || await bulkTransactionAgg.getBulkTransfersFailedCount();
let bulkTransfersSuccessCount;
let bulkTransfersFailedCount;
if(bulkTransfersResult?.currentState === SDKOutboundTransferState.COMPLETED) {
bulkTransfersSuccessCount = await bulkTransactionAgg.incrementBulkTransfersSuccessCount();
bulkTransfersFailedCount = await bulkTransactionAgg.getBulkTransfersFailedCount();
} else {
bulkTransfersFailedCount = await bulkTransactionAgg.incrementBulkTransfersFailedCount();
bulkTransfersSuccessCount = await bulkTransactionAgg.getBulkTransfersSuccessCount();
}

if(bulkTransfersTotalCount === (bulkTransfersSuccessCount + bulkTransfersFailedCount)) {
// Update global state "TRANSFERS_COMPLETED"
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -47,8 +47,6 @@ export async function handleProcessPartyInfoCallbackCmdEvt(
): Promise<void> {
const processPartyInfoCallback = message as ProcessPartyInfoCallbackCmdEvt;
try {
let successCountAfterIncrement;
let failedCountAfterIncrement;
logger.info(`Got ProcessPartyInfoCallbackCmdEvt: id=${processPartyInfoCallback.getKey()}`);

// Create aggregate
Expand All @@ -63,12 +61,9 @@ export async function handleProcessPartyInfoCallbackCmdEvt(
);
if(processPartyInfoCallback.partyResult?.currentState === SDKOutboundTransferState.COMPLETED) {
individualTransfer.setTransferState(IndividualTransferInternalState.DISCOVERY_SUCCESS);
successCountAfterIncrement = await bulkTransactionAgg.incrementPartyLookupSuccessCount();
individualTransfer.setPartyResponse(processPartyInfoCallback.partyResult);
} else {
individualTransfer.setTransferState(IndividualTransferInternalState.DISCOVERY_FAILED);
failedCountAfterIncrement = await bulkTransactionAgg.incrementPartyLookupFailedCount();
await bulkTransactionAgg.incrementFailedCount();
individualTransfer.setLastError(processPartyInfoCallback.partyErrorResult);
}
await bulkTransactionAgg.setIndividualTransferById(individualTransfer.id, individualTransfer);
Expand Down Expand Up @@ -99,8 +94,17 @@ export async function handleProcessPartyInfoCallbackCmdEvt(
// Progressing to the next step
// Check the status of the remaining party lookups
const partyLookupTotalCount = await bulkTransactionAgg.getPartyLookupTotalCount();
const partyLookupSuccessCount = successCountAfterIncrement || await bulkTransactionAgg.getPartyLookupSuccessCount();
const partyLookupFailedCount = failedCountAfterIncrement || await bulkTransactionAgg.getPartyLookupFailedCount();
let partyLookupSuccessCount;
let partyLookupFailedCount;
if(processPartyInfoCallback.partyResult?.currentState === SDKOutboundTransferState.COMPLETED) {
partyLookupSuccessCount = await bulkTransactionAgg.incrementPartyLookupSuccessCount();
partyLookupFailedCount = await bulkTransactionAgg.getPartyLookupFailedCount();
} else {
partyLookupFailedCount = await bulkTransactionAgg.incrementPartyLookupFailedCount();
await bulkTransactionAgg.incrementFailedCount();
partyLookupSuccessCount = await bulkTransactionAgg.getPartyLookupSuccessCount();
}

if(partyLookupTotalCount === (partyLookupSuccessCount + partyLookupFailedCount)) {
// Update global state "DISCOVERY_COMPLETED"
await bulkTransactionAgg.setGlobalState(BulkTransactionInternalState.DISCOVERY_COMPLETED);
Expand Down
2 changes: 1 addition & 1 deletion modules/outbound-domain-event-handler/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -46,7 +46,7 @@
"convict": "^6.2.3",
"express": "^4.18.2",
"openapi-backend": "^5.5.0",
"redis": "^4.4.0",
"redis": "^4.5.0",
"swagger-ui-express": "^4.6.0",
"yamljs": "^0.3.0"
},
Expand Down
2 changes: 1 addition & 1 deletion modules/private-shared-lib/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -33,7 +33,7 @@
"@mojaloop/platform-shared-lib-messaging-types-lib": "^0.2.18",
"@mojaloop/platform-shared-lib-nodejs-kafka-client-lib": "^0.2.15",
"ajv": "^8.11.0",
"redis": "^4.4.0",
"redis": "^4.5.0",
"uuid": "^9.0.0"
},
"devDependencies": {
Expand Down
2 changes: 1 addition & 1 deletion test/func/config/ttk-ttksim1/spec_files/user_config.json
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
{
"VERSION": 1,
"CALLBACK_ENDPOINT": "http://ttksim1-sdk-api-svc:4001",
"MONITORING_LOG_INCLUDE_PAYLOAD": false,
"MONITORING_LOG_INCLUDE_PAYLOAD": true,
"CALLBACK_RESOURCE_ENDPOINTS": {
"enabled": false,
"endpoints": []
Expand Down
32 changes: 24 additions & 8 deletions test/func/docker-compose.yml
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,8 @@ services:
networks:
- mojaloop-net
image: "redis:5.0.4-alpine"
cap_add:
- NET_ADMIN
ports:
- "6379:6379"
healthcheck:
Expand Down Expand Up @@ -275,12 +277,26 @@ services:
depends_on:
- kafka

# redisinsight:
# image: redislabs/redisinsight
# ports:
# - "9001:8001"
# networks:
# - mojaloop-net
# volumes: []
# restart: on-failure
redisinsight:
image: redislabs/redisinsight
ports:
- "9001:8001"
networks:
- mojaloop-net
volumes: []
restart: on-failure
healthcheck:
test: ["CMD" ,"sh", "-c", "curl http://localhost:8001/api/instance/"]
timeout: 20s
retries: 30
start_period: 5s
interval: 5s

init-redisinsight:
networks:
- mojaloop-net
image: curlimages/curl:7.86.0
depends_on:
redisinsight:
condition: service_healthy
command: "--location --request POST 'http://redisinsight:8001/api/instance/' --header 'Content-Type: application/json' --data-raw '{\"name\": \"Redis DB\",\"connectionType\": \"STANDALONE\",\"host\": \"redis\",\"port\": 6379}'"
46 changes: 23 additions & 23 deletions yarn.lock
Original file line number Diff line number Diff line change
Expand Up @@ -2250,11 +2250,11 @@ __metadata:
oauth2-server: ^4.0.0-dev.2
openapi-jsonschema-parameters: ^12.0.2
openapi-response-validator: ^12.0.2
openapi-typescript: ^6.0.1
openapi-typescript: ^6.0.2
prom-client: ^14.1.0
promise-timeout: ^1.3.0
random-word-slugs: ^0.1.6
redis: ^4.4.0
redis: ^4.5.0
redis-mock: ^0.56.3
replace: ^1.2.2
standard-version: ^9.5.0
Expand Down Expand Up @@ -2293,7 +2293,7 @@ __metadata:
nodemon: ^2.0.20
npm-check-updates: ^16.3.18
openapi-backend: ^5.5.0
redis: ^4.4.0
redis: ^4.5.0
replace: ^1.2.2
standard-version: ^9.5.0
swagger-ui-express: ^4.6.0
Expand Down Expand Up @@ -2330,7 +2330,7 @@ __metadata:
nodemon: ^2.0.20
npm-check-updates: ^16.3.18
openapi-backend: ^5.5.0
redis: ^4.4.0
redis: ^4.5.0
replace: ^1.2.2
standard-version: ^9.5.0
swagger-ui-express: ^4.6.0
Expand All @@ -2355,7 +2355,7 @@ __metadata:
eslint: ^8.27.0
jest: ^29.3.1
npm-check-updates: ^16.3.18
redis: ^4.4.0
redis: ^4.5.0
replace: ^1.2.2
standard-version: ^9.5.0
ts-jest: ^29.0.3
Expand Down Expand Up @@ -2651,14 +2651,14 @@ __metadata:
languageName: node
linkType: hard

"@redis/client@npm:1.3.1":
version: 1.3.1
resolution: "@redis/client@npm:1.3.1"
"@redis/client@npm:1.4.0":
version: 1.4.0
resolution: "@redis/client@npm:1.4.0"
dependencies:
cluster-key-slot: 1.1.1
generic-pool: 3.9.0
yallist: 4.0.0
checksum: fb82a1a80da941d7de9bcf8a3fa04b58a3c4682473f1331578cd04e6325bf0ea0e17c98bc3bed620c6408f320796265f2b453542e2b53dcc811c0ae8592c2e57
checksum: 1fb229ccfb960620273750551c63cd5b3ce521b03ed5ef52cd196063873f589045cc87578694ee5ffde05c62347a58e70b0aee0725c3d567a1f234861d3afad6
languageName: node
linkType: hard

Expand Down Expand Up @@ -2689,12 +2689,12 @@ __metadata:
languageName: node
linkType: hard

"@redis/time-series@npm:1.0.3":
version: 1.0.3
resolution: "@redis/time-series@npm:1.0.3"
"@redis/time-series@npm:1.0.4":
version: 1.0.4
resolution: "@redis/time-series@npm:1.0.4"
peerDependencies:
"@redis/client": ^1.0.0
checksum: 4d11518185dd15f31c5b4a433902e53a3ebc24614a0221080ab12abf4f6fc60b3db00a71a83de7b4b10f11077de611dc1c273274573646d63481d40ca246f82d
checksum: a5fca079deb04a2f204a7f9a375a6ff698a119d5dd53f7581fa8fd9e3bacacf1ecb0253b97fada484a012fea7a98014bc0f4f79707d4e92ff61c00318f2bfe04
languageName: node
linkType: hard

Expand Down Expand Up @@ -10899,9 +10899,9 @@ __metadata:
languageName: node
linkType: hard

"openapi-typescript@npm:^6.0.1":
version: 6.0.1
resolution: "openapi-typescript@npm:6.0.1"
"openapi-typescript@npm:^6.0.2":
version: 6.0.2
resolution: "openapi-typescript@npm:6.0.2"
dependencies:
ansi-colors: ^4.1.3
fast-glob: ^3.2.12
Expand All @@ -10911,7 +10911,7 @@ __metadata:
yargs-parser: ^21.1.1
bin:
openapi-typescript: bin/cli.js
checksum: d61f1f7d0f11b48fcdf7d47cbd4d05d233ec59f0c36cb2a454406a29891b7e657ec936816e13c0eb622bf142995a885232336530733f889c0890b03439b76c49
checksum: 17900e6590d47efb2d49df149c90d9bea082340805b33d2b939a46c2d5675e21dbd9ede2ca2439365ba98e41e014ac29f9c0b4a81842d43daa081e1992c4f5e2
languageName: node
linkType: hard

Expand Down Expand Up @@ -11958,17 +11958,17 @@ __metadata:
languageName: node
linkType: hard

"redis@npm:^4.4.0":
version: 4.4.0
resolution: "redis@npm:4.4.0"
"redis@npm:^4.5.0":
version: 4.5.0
resolution: "redis@npm:4.5.0"
dependencies:
"@redis/bloom": 1.1.0
"@redis/client": 1.3.1
"@redis/client": 1.4.0
"@redis/graph": 1.1.0
"@redis/json": 1.0.4
"@redis/search": 1.1.0
"@redis/time-series": 1.0.3
checksum: 54a66d7acf5bd2acd36d5653c02fa2b1a43ffb25c9e3915a14a02ed722b7bd835bc6c9b0e21ec87c1ec6cc6fa536a9ee0371eb8360bb5b0f6cf455453bfaffc0
"@redis/time-series": 1.0.4
checksum: 3c2a2fdf497acbd8847715d32d41466498908e96c53145b6a7c74187018c1cbf59f3fadae4e8d8166feef5c72fe8f1ac5d7b03eef665914c658bfc182e1216f3
languageName: node
linkType: hard

Expand Down

0 comments on commit 56e1db0

Please sign in to comment.