diff --git a/frontend/libs/console/legacy-ce/src/lib/features/CloudOnboarding/OneClickDeployment/components/CliLog/CliLog.tsx b/frontend/libs/console/legacy-ce/src/lib/features/CloudOnboarding/OneClickDeployment/components/CliLog/CliLog.tsx index b17d8314feb..cb98d3036f4 100644 --- a/frontend/libs/console/legacy-ce/src/lib/features/CloudOnboarding/OneClickDeployment/components/CliLog/CliLog.tsx +++ b/frontend/libs/console/legacy-ce/src/lib/features/CloudOnboarding/OneClickDeployment/components/CliLog/CliLog.tsx @@ -72,6 +72,7 @@ export const CliLog: React.VFC = props => { diff --git a/frontend/libs/console/legacy-ce/src/lib/features/CloudOnboarding/OneClickDeployment/components/CliLog/components/ErrorBox.tsx b/frontend/libs/console/legacy-ce/src/lib/features/CloudOnboarding/OneClickDeployment/components/CliLog/components/ErrorBox.tsx index c2ac11e1d8e..b8487cd976e 100644 --- a/frontend/libs/console/legacy-ce/src/lib/features/CloudOnboarding/OneClickDeployment/components/CliLog/components/ErrorBox.tsx +++ b/frontend/libs/console/legacy-ce/src/lib/features/CloudOnboarding/OneClickDeployment/components/CliLog/components/ErrorBox.tsx @@ -15,25 +15,20 @@ import { transformFallbackAppToLinkButtonProps } from '../fallbackAppUtil'; type Props = { step: UserFacingStep; error: Record; + logId: number; retryAction: VoidFunction; fallbackApps: FallbackApp[]; }; export function ErrorBox(props: Props) { - const { step, error, retryAction, fallbackApps } = props; + const { step, error, retryAction, fallbackApps, logId } = props; const [isRetrying, setIsRetrying] = React.useState(false); + + // mark retry as complete if logId is different React.useEffect(() => { - let timeout: NodeJS.Timeout; - if (isRetrying) { - timeout = setTimeout(() => { - setIsRetrying(false); - }, 5000); - } - return () => { - clearTimeout(timeout); - }; - }, [isRetrying]); + setIsRetrying(false); + }, [logId]); const onRetryClick = () => { if (!isRetrying && retryAction) { diff --git a/frontend/libs/console/legacy-ce/src/lib/features/CloudOnboarding/OneClickDeployment/types.ts b/frontend/libs/console/legacy-ce/src/lib/features/CloudOnboarding/OneClickDeployment/types.ts index 8dc2fff2bdd..8fdf1316a20 100644 --- a/frontend/libs/console/legacy-ce/src/lib/features/CloudOnboarding/OneClickDeployment/types.ts +++ b/frontend/libs/console/legacy-ce/src/lib/features/CloudOnboarding/OneClickDeployment/types.ts @@ -62,6 +62,7 @@ export type ProgressStateStatus = | { kind: 'error'; error: Record; + logId: number; } | { kind: 'awaiting'; diff --git a/frontend/libs/console/legacy-ce/src/lib/features/CloudOnboarding/OneClickDeployment/util.test.ts b/frontend/libs/console/legacy-ce/src/lib/features/CloudOnboarding/OneClickDeployment/util.test.ts index 23630ab82bd..7d8650e5b79 100644 --- a/frontend/libs/console/legacy-ce/src/lib/features/CloudOnboarding/OneClickDeployment/util.test.ts +++ b/frontend/libs/console/legacy-ce/src/lib/features/CloudOnboarding/OneClickDeployment/util.test.ts @@ -76,6 +76,7 @@ const tc: { [OneClickDeploymentState.ReadingEnvironmentVariables]: { kind: 'error', error: { message: 'unexpected' }, + logId: 2, }, [OneClickDeploymentState.AwaitingEnvironmentVariables]: { kind: 'idle' }, [OneClickDeploymentState.SufficientEnvironmentVariables]: { @@ -158,6 +159,7 @@ const tc: { [OneClickDeploymentState.ApplyingMetadataMigrationsSeeds]: { kind: 'error', error: { message: 'unable to connect' }, + logId: 2, }, [OneClickDeploymentState.Completed]: { kind: 'idle' }, }, diff --git a/frontend/libs/console/legacy-ce/src/lib/features/CloudOnboarding/OneClickDeployment/util.ts b/frontend/libs/console/legacy-ce/src/lib/features/CloudOnboarding/OneClickDeployment/util.ts index 5144e9b206f..6c5b6f2092b 100644 --- a/frontend/libs/console/legacy-ce/src/lib/features/CloudOnboarding/OneClickDeployment/util.ts +++ b/frontend/libs/console/legacy-ce/src/lib/features/CloudOnboarding/OneClickDeployment/util.ts @@ -16,12 +16,23 @@ const getStepError = ( allStateTransitionsOrdered: OneClickDeploymentStateTransition[], step: UserFacingStep ): ProgressStateStatus | null => { - const lastTransition = - allStateTransitionsOrdered[allStateTransitionsOrdered.length - 1]; - return lastTransition?.from_state === step && - lastTransition.to_state === OneClickDeploymentState.Error - ? { kind: 'error', error: lastTransition.additional_info } - : null; + let errorStatus: ProgressStateStatus | null = null; + // run through all transitions to get the latest state of a step + allStateTransitionsOrdered.forEach(transition => { + if (transition.from_state === step) { + if (transition.to_state === OneClickDeploymentState.Error) { + errorStatus = { + kind: 'error', + error: transition.additional_info, + logId: transition.id, + }; + } else { + errorStatus = null; + } + } + }); + + return errorStatus; }; /** @@ -34,6 +45,7 @@ const getStepSuccess = ( step: UserFacingStep ): ProgressStateStatus | null => { let successStatus: ProgressStateStatus | null = null; + // run through all transitions to get the latest state of a step allStateTransitionsOrdered.forEach(transition => { if (transition.from_state === step) { // it's not a success if the step goes into an error @@ -129,17 +141,19 @@ const getStepProgressState = ( return { kind: 'idle' }; } - // return error if error - const stepError = getStepError(allStateTransitionsOrdered, step); - if (stepError) return stepError; - // return success if success const stepSuccess = getStepSuccess(allStateTransitionsOrdered, step); if (stepSuccess) return stepSuccess; - return ( - getStepPendingState(allStateTransitionsOrdered, step) || { kind: 'idle' } - ); + // return pending if in progress + const stepPending = getStepPendingState(allStateTransitionsOrdered, step); + if (stepPending) return stepPending; + + // return error if error + const stepError = getStepError(allStateTransitionsOrdered, step); + if (stepError) return stepError; + + return { kind: 'idle' }; }; export const getCliProgressState = (