Skip to content

Commit

Permalink
Update components to support displaying new Cancelled status
Browse files Browse the repository at this point in the history
TEP-0058 Graceful Termination deprecated the existing `PipelineRunCancelled`
status. Instead, runs have the status reason `Cancelled`.

The feature is still in alpha, so to test it out you can edit the `feature-flags`
ConfigMap to set `enable-api-fields: alpha`, then use one of the following values
when cancelling the PipelineRun:
- `Cancelled` replaces the existing `PipelineRunCancelled`, interrupts any
  executing tasks and does not run finally tasks
- `StoppedRunFinally` lets any executing tasks complete normally but does not
  start any new non-finally tasks, then runs finally tasks
- `CancelledRunFinally` interrupts any executing non-finally tasks, then executes
  finally tasks

In all 3 cases above, the PipelineRun status reason is `Cancelled`

Update tests and storybook to include 'Cancelled' variants.

The Dashboard API will still use `PipelineRunCancelled` to stop a PipelineRun.
A future change once the feature has been promoted to beta will switch to the
replacement `Cancelled` value. Some UI change may also be made to support the
alternative behaviours, tracking this in #2094
  • Loading branch information
AlanGreene authored and tekton-robot committed Mar 1, 2022
1 parent 252b974 commit 8913256
Show file tree
Hide file tree
Showing 6 changed files with 47 additions and 13 deletions.
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
/*
Copyright 2019-2021 The Tekton Authors
Copyright 2019-2022 The Tekton Authors
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
Expand Down Expand Up @@ -88,7 +88,6 @@ header.tkn--step-details-header {
&[data-status='terminated'][data-reason='Error'],
&[data-status='False'],
&[data-status='cancelled'],
&[data-reason='PipelineRunCancelled'],
&[data-reason='TaskRunCancelled'],
&[data-reason='TaskRunTimeout'] {
.tkn--status-label {
Expand Down
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
/*
Copyright 2019-2021 The Tekton Authors
Copyright 2019-2022 The Tekton Authors
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
Expand Down Expand Up @@ -48,11 +48,12 @@ export default {
title: 'Components/DetailsHeader'
};

export const Running = args => (
export const Cancelled = args => (
<DetailsHeader
status="running"
reason="TaskRunCancelled"
status="terminated"
displayName="build"
taskRun={getTaskRun({ reason: 'Running', status: 'Unknown' })}
taskRun={getTaskRun({ reason: 'TaskRunCancelled', status: 'False' })}
{...args}
/>
);
Expand Down Expand Up @@ -96,3 +97,12 @@ export const Pending = args => (
{...args}
/>
);

export const Running = args => (
<DetailsHeader
status="running"
displayName="build"
taskRun={getTaskRun({ reason: 'Running', status: 'Unknown' })}
{...args}
/>
);
4 changes: 3 additions & 1 deletion packages/components/src/components/StatusIcon/StatusIcon.js
Original file line number Diff line number Diff line change
Expand Up @@ -82,7 +82,9 @@ export default function StatusIcon({
statusClass = hasWarning ? 'warning' : 'success';
} else if (
status === 'False' &&
(reason === 'PipelineRunCancelled' || reason === 'TaskRunCancelled')
(reason === 'PipelineRunCancelled' ||
reason === 'Cancelled' ||
reason === 'TaskRunCancelled')
) {
statusClass = 'cancelled';
} else if (
Expand Down
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
/*
Copyright 2020-2021 The Tekton Authors
Copyright 2020-2022 The Tekton Authors
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
Expand Down Expand Up @@ -34,12 +34,30 @@ export default {
title: 'Components/StatusIcon'
};

export const Queued = args => <StatusIcon {...args} />;
export const CancelledGraceful = args => (
<StatusIcon reason="Cancelled" status="False" {...args} />
);
CancelledGraceful.storyName =
'Cancelled - PipelineRun TEP-0058 graceful termination';

export const CancelledPipelineRun = args => (
<StatusIcon reason="PipelineRunCancelled" status="False" {...args} />
);
CancelledPipelineRun.storyName = 'Cancelled - PipelineRun legacy';

export const CancelledTaskRun = args => (
<StatusIcon reason="TaskRunCancelled" status="False" {...args} />
);
CancelledTaskRun.storyName = 'Cancelled - TaskRun';

export const Failed = args => <StatusIcon status="False" {...args} />;

export const Pending = args => (
<StatusIcon reason="Pending" status="Unknown" {...args} />
);

export const Queued = args => <StatusIcon {...args} />;

export const Running = args => (
<StatusIcon reason="Running" status="Unknown" {...args} />
);
Expand All @@ -50,5 +68,3 @@ export const SucceededWithWarning = args => (
<StatusIcon hasWarning status="True" {...args} />
);
SucceededWithWarning.storyName = 'Succeeded with warning';

export const Failed = args => <StatusIcon status="False" {...args} />;
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
/*
Copyright 2021 The Tekton Authors
Copyright 2021-2022 The Tekton Authors
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
Expand Down Expand Up @@ -28,6 +28,10 @@ describe('StatusIcon', () => {
render(<StatusIcon reason="PipelineRunCancelled" status="False" />);
});

it('renders Cancelled state', () => {
render(<StatusIcon reason="Cancelled" status="False" />);
});

it('renders TaskRunCancelled state', () => {
render(<StatusIcon reason="TaskRunCancelled" status="False" />);
});
Expand Down
5 changes: 4 additions & 1 deletion packages/utils/src/utils/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -316,13 +316,16 @@ export function runMatchesStatusFilter({ run, statusFilter }) {
return (
(status === 'False' &&
reason !== 'PipelineRunCancelled' &&
reason !== 'Cancelled' &&
reason !== 'TaskRunCancelled') ||
(status === 'Unknown' && reason === 'PipelineRunCouldntCancel')
);
case 'cancelled':
return (
status === 'False' &&
(reason === 'PipelineRunCancelled' || reason === 'TaskRunCancelled')
(reason === 'PipelineRunCancelled' ||
reason === 'Cancelled' ||
reason === 'TaskRunCancelled')
);
case 'completed':
return status === 'True';
Expand Down

0 comments on commit 8913256

Please sign in to comment.