Skip to content

Commit

Permalink
Address review comments
Browse files Browse the repository at this point in the history
  • Loading branch information
devabhishekpal committed Jan 16, 2025
1 parent 45e9b69 commit 24a5e85
Show file tree
Hide file tree
Showing 2 changed files with 17 additions and 22 deletions.
30 changes: 14 additions & 16 deletions hadoop-ozone/dist/src/main/smoketest/recon/recon-taskstatus.robot
Original file line number Diff line number Diff line change
Expand Up @@ -24,14 +24,14 @@ Resource ../commonlib.robot
Test Timeout 5 minutes

*** Variables ***
${BASE_URL} http://recon:9888
${BASE_URL} http://recon:9888
${TASK_STATUS_ENDPOINT} ${BASE_URL}/api/v1/task/status
${TRIGGER_SYNC_ENDPOINT} ${BASE_URL}/api/v1/triggerdbsync/om
${TASK_NAME_1} ContainerHealthTask
${TASK_NAME_2} OmDeltaRequest
${BUCKET} testbucket
${VOLUME} testvolume
${KEYPATH} ${VOLUME}/${BUCKET}/testkey
${TASK_NAME_1} ContainerHealthTask
${TASK_NAME_2} OmDeltaRequest
${BUCKET} testbucket
${VOLUME} testvolume
${KEYPATH} ${VOLUME}/${BUCKET}/testkey

*** Keywords ***

Expand All @@ -41,7 +41,7 @@ Kinit as ozone admin
Sync OM Data
Log To Console Sending CURL request to ${TRIGGER_SYNC_ENDPOINT}
${result} = Execute curl --negotiate -u : -LSs ${TRIGGER_SYNC_ENDPOINT}
Should contain ${result} true # Sync should return true if successful
[return] ${result}

Fetch Task Status
Log To Console Sending CURL request to ${TASK_STATUS_ENDPOINT}
Expand All @@ -56,9 +56,10 @@ Prepopulate Data and Trigger OM DB Sync
[Documentation] Use Freon to prepopulate the OM DB with data and trigger OM DB sync.
Kinit as ozone admin
Freon DFSG n=1000 path=${KEYPATH}
Freon DFSG n=100 path=${KEYPATH} size=100

Sync OM Data
${result} = Sync OM Data
Should contain ${result} true # Sync should return true if successful

Validate Task Status After Sync
[Documentation] Validate that task status is updated after triggering the OM DB sync.
Expand Down Expand Up @@ -103,13 +104,10 @@ Validate All Tasks Updated After Sync
END

Validate Sequence number is updated after sync
Log To Console Generating Freon Data
Kinit as ozone admin
Freon DFSG n=100 path=${VOLUME}/${BUCKET}/seqValidationKey
Log To Console Triggering OM DB sync for updates
Sync OM Data

${tasks} = Fetch Task Status
Should Not Be Empty ${tasks}
${tasks} = Fetch Task Status
Should Not Be Empty ${tasks}

${om_delta_task_list} = Evaluate [task for task in ${tasks} if task["taskName"] == "OmDeltaRequest"]
${list_length} = Get Length ${om_delta_task_list}
Expand All @@ -124,4 +122,4 @@ Validate Sequence number is updated after sync
IF ${task["isCurrentTaskRunning"]} == 0
Should Be Equal As Integers ${task["lastUpdatedSeqNumber"]} ${om_delta_task_seq_num}
END
END
END
Original file line number Diff line number Diff line change
Expand Up @@ -478,10 +478,7 @@ void getAndApplyDeltaUpdatesFromOM(
inLoopStartSequenceNumber = inLoopLatestSequenceNumber;
loopCount++;
}
// We might reach loop count limit and so not all updates from RocksDB might be applied.
// Say we have: 1000 updates, each loop we get only 100 updates, loop limit is 5.
// So this will effectively only apply 500 events, even if we are having total 1000 updates/events;
// All subsequent tasks will effectively process only 500 events, till next sync takes place.

omdbUpdatesHandler.setLatestSequenceNumber(getCurrentOMDBSequenceNumber());
LOG.info("Delta updates received from OM : {} loops, {} records", loopCount,
getCurrentOMDBSequenceNumber() - fromSequenceNumber
Expand Down Expand Up @@ -544,8 +541,8 @@ boolean innerGetAndApplyDeltaUpdatesFromOM(long fromSequenceNumber,
* <li>Initially it will fetch a snapshot of OM DB.</li>
* <li>If we already have data synced it will try to fetch delta updates.</li>
* <li>If the sync is completed successfully it will trigger other OM tasks to process events</li>
* <li>If there is any exception while trying to fetch delta updates, it will fall back to snapshot update</li>
* <li>If there is any exception in snapshot sync it will do nothing.</li>
* <li>If there is any exception while trying to fetch delta updates, it will fall back to full snapshot update</li>
* <li>If there is any exception in full snapshot update it will do nothing, and return true.</li>
* <li>In case of an interrupt signal (irrespective of delta or snapshot sync),
* it will catch and mark the task as interrupted, and return false i.e. sync failed status.</li>
* </ul>
Expand Down

0 comments on commit 24a5e85

Please sign in to comment.