Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[TEP-0050] Convert Step OnError from string to "OnErrorType" type #5322

Merged

Conversation

QuanZhang-William
Copy link
Member

@QuanZhang-William QuanZhang-William commented Aug 15, 2022

Changes

Prior to this commit, the step.OnError field is defined as string and the 2 supported string values "continue" and "stopAndFail" are directly used across the codebase. This is error-prone and it introduces maintenance difficulty. This commit updates the OnError field to be typed string OnErrorType, with constants defined for the 2 supported values, and updates all the related references

Submitter Checklist

As the author of this PR, please check off the items in this checklist:

  • Has Docs included if any changes are user facing
  • Has Tests included if any functionality added or changed
  • Follows the commit message standard
  • Meets the Tekton contributor standards (including
    functionality, content, code)
  • Has a kind label. You can add one by adding a comment on this PR that contains /kind <type>. Valid types are bug, cleanup, design, documentation, feature, flake, misc, question, tep
  • Release notes block below has been updated with any user facing changes (API changes, bug fixes, changes requiring upgrade notices or deprecation warnings)
  • Release notes contains the string "action required" if the change requires additional action from users switching to the new release

Release Notes

Convert step.OnError from string to type: OnErrorType

@tekton-robot
Copy link
Collaborator

Skipping CI for Draft Pull Request.
If you want CI signal for your change, please convert it to an actual PR.
You can still manually trigger a test run with /test all

@tekton-robot tekton-robot added release-note-none Denotes a PR that doesnt merit a release note. do-not-merge/work-in-progress Indicates that a PR should not merge because it is a work in progress. size/M Denotes a PR that changes 30-99 lines, ignoring generated files. labels Aug 15, 2022
@QuanZhang-William QuanZhang-William force-pushed the convert-step-onError-to-enum branch from d76c726 to 15b4e2a Compare August 15, 2022 14:50
@QuanZhang-William
Copy link
Member Author

/kind cleanup

@tekton-robot tekton-robot added the kind/cleanup Categorizes issue or PR as related to cleaning up code, process, or technical debt. label Aug 15, 2022
@QuanZhang-William
Copy link
Member Author

/test all

@QuanZhang-William QuanZhang-William force-pushed the convert-step-onError-to-enum branch from 15b4e2a to b2c75e2 Compare August 15, 2022 15:24
@QuanZhang-William
Copy link
Member Author

/test all

@QuanZhang-William QuanZhang-William force-pushed the convert-step-onError-to-enum branch from b2c75e2 to 52b0712 Compare August 15, 2022 20:18
@QuanZhang-William
Copy link
Member Author

/retest

@QuanZhang-William QuanZhang-William force-pushed the convert-step-onError-to-enum branch from 52b0712 to 24e9d96 Compare August 15, 2022 21:05
@tekton-robot tekton-robot added size/XXL Denotes a PR that changes 1000+ lines, ignoring generated files. and removed size/M Denotes a PR that changes 30-99 lines, ignoring generated files. labels Aug 15, 2022
@QuanZhang-William
Copy link
Member Author

/retest

@QuanZhang-William QuanZhang-William force-pushed the convert-step-onError-to-enum branch 2 times, most recently from 78afa44 to cba79bf Compare August 15, 2022 21:43
@QuanZhang-William
Copy link
Member Author

/retest

@QuanZhang-William
Copy link
Member Author

/retest pull-tekton-pipeline-unit-tests

@tekton-robot
Copy link
Collaborator

@QuanZhang-William: The /retest command does not accept any targets.
The following commands are available to trigger required jobs:

  • /test pull-tekton-pipeline-alpha-integration-tests
  • /test pull-tekton-pipeline-build-tests
  • /test pull-tekton-pipeline-integration-tests
  • /test tekton-pipeline-unit-tests

The following commands are available to trigger optional jobs:

  • /test pull-tekton-pipeline-go-coverage

Use /test all to run all jobs.

In response to this:

/retest pull-tekton-pipeline-unit-tests

Instructions for interacting with me using PR comments are available here. If you have questions or suggestions related to my behavior, please file an issue against the kubernetes/test-infra repository.

@QuanZhang-William QuanZhang-William changed the title Convert Step String from string to "OnErrorType" type Convert Step OnError from string to "OnErrorType" type Aug 15, 2022
@QuanZhang-William
Copy link
Member Author

/retest

1 similar comment
@QuanZhang-William
Copy link
Member Author

/retest

@QuanZhang-William QuanZhang-William force-pushed the convert-step-onError-to-enum branch 2 times, most recently from 41fd8eb to ca8e5b7 Compare August 16, 2022 12:57
Copy link
Member

@wlynch wlynch left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Mostly LGTM! Just one change I think we should make.

pkg/entrypoint/entrypointer.go Outdated Show resolved Hide resolved
Prior to this commit, the step onError field is defined as normal string and the 2 supported string values "continue" and "stopAndFail" are directly used across the codebase. This is error-prone and it introduces maintenance difficulty. This commit updates the onError field to be typed string "OnErrorType", with constants defined for the 2 supported values, and updates all the related references
@QuanZhang-William QuanZhang-William force-pushed the convert-step-onError-to-enum branch from 92386df to 7ba5090 Compare August 17, 2022 14:43
@tekton-robot tekton-robot added size/L Denotes a PR that changes 100-499 lines, ignoring generated files. and removed size/XL Denotes a PR that changes 500-999 lines, ignoring generated files. labels Aug 17, 2022
Copy link
Member

@wlynch wlynch left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

/lgtm

@tekton-robot tekton-robot added the lgtm Indicates that a PR is ready to be merged. label Aug 17, 2022
Copy link
Member

@Yongxuanzhang Yongxuanzhang left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Great work!
Maybe adding a release note?

@QuanZhang-William
Copy link
Member Author

Great work! Maybe adding a release note?

My understanding of a Release Note is to notify users about a behaviour change. There is actually no change from the user's perspective and there is nothing to "notify" (since we already have the OnError input validation before this PR). This is more like a "clean up " work. I don't think a Release Note is necessary in this case?

@wlynch
Copy link
Member

wlynch commented Aug 17, 2022

My understanding of a Release Note is to notify users about a behaviour change. There is actually no change from the user's perspective and there is nothing to "notify" (since we already have the OnError input validation before this PR). This is more like a "clean up " work. I don't think a Release Note is necessary in this case?

Good catch @Yongxuanzhang! - This should be called out as a breaking change to the API - this will cause build failures for clients if they were previously using the string based type, i.e.

s := "asdf"
v1beta1.Step{
	OnError: s,
}

// stopAndFail indicates exit the taskRun if the container exits with non-zero exit code
// continue indicates continue executing the rest of the steps irrespective of the container exit code
OnError string `json:"onError,omitempty"`
OnError OnErrorType `json:"onError,omitempty"`
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

we added support for variables in addition to the two constants - #5307

steps[].onError: $(params.CONTINUE)
steps[].onError: continue
steps[].onError: stopAndFail

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Hi @pritidesai, thanks for letting me know. Was wondering if there is any concern when using variables with "OnErrorType". We will eventually parse the variable to a real value here.

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

How?

I haven't reviewed the code changes in this PR. I am not sure how can it be restricted to the type of enum (continue and stopAndFail) when it can have a parameter of type string.

Copy link
Member Author

@QuanZhang-William QuanZhang-William Aug 17, 2022

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This is also what I found interesting that enum is not that restricted in Go, even with a Typed string OnErrorType you can still do something like

// the value is properly set to step.OnError even if it is not defined in enum
step.OnError = "this is undefined value in enum OnErrorType"

So there is essentially no difference between a regular string or a typed string OnErrorTypewhen calling ApplyReplacement function other than some type casting.

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

thank you @QuanZhang-William for all the efforts but declaring onError to as enum but allowing it to specify variables sounds very confusing. If we are declaring a field as enum, it will be simpler and easier to follow if it's restricted to the specified enum values.

I suggest keeping the type to string, thanks!

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@pritidesai I am not sure I follow here ? The type is still string, as OnErrorType is still just an alias to a string. There is no concept of enum in Go anyway 🙃. Also, this is the exact same thing with a lot of other types we are using (in status, …), it is mainly useful for developer and consumer of the go library to use a predefined set of values, it doesn't do much more than this.

@QuanZhang-William
Copy link
Member Author

My understanding of a Release Note is to notify users about a behaviour change. There is actually no change from the user's perspective and there is nothing to "notify" (since we already have the OnError input validation before this PR). This is more like a "clean up " work. I don't think a Release Note is necessary in this case?

Good catch @Yongxuanzhang! - This should be called out as a breaking change to the API - this will cause build failures for clients if they were previously using the string based type, i.e.

s := "asdf"
v1beta1.Step{
	OnError: s,
}

Ohh, got what you mean. I didn't think about that Tekton can be used in this way programmatically. Will update the Release Note in this case

@tekton-robot tekton-robot added release-note Denotes a PR that will be considered when it comes time to generate release notes. and removed release-note-none Denotes a PR that doesnt merit a release note. labels Aug 17, 2022
@vdemeester
Copy link
Member

Ohh, got what you mean. I didn't think about that Tekton can be used in this way programmatically. Will update the Release Note in this case

Mainly the cli or go client might be affected 🙃

// stopAndFail indicates exit the taskRun if the container exits with non-zero exit code
// continue indicates continue executing the rest of the steps irrespective of the container exit code
OnError string `json:"onError,omitempty"`
OnError OnErrorType `json:"onError,omitempty"`
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@pritidesai I am not sure I follow here ? The type is still string, as OnErrorType is still just an alias to a string. There is no concept of enum in Go anyway 🙃. Also, this is the exact same thing with a lot of other types we are using (in status, …), it is mainly useful for developer and consumer of the go library to use a predefined set of values, it doesn't do much more than this.

@tekton-robot
Copy link
Collaborator

[APPROVALNOTIFIER] This PR is APPROVED

This pull-request has been approved by: vdemeester, wlynch

The full list of commands accepted by this bot can be found here.

The pull request process is described here

Needs approval from an approver in each of these files:

Approvers can indicate their approval by writing /approve in a comment
Approvers can cancel approval by writing /approve cancel in a comment

@tekton-robot tekton-robot added the approved Indicates a PR has been approved by an approver from all required OWNERS files. label Aug 18, 2022
@QuanZhang-William
Copy link
Member Author

/retest

@tekton-robot tekton-robot merged commit 119f7bd into tektoncd:main Aug 18, 2022
@pritidesai
Copy link
Member

@pritidesai I am not sure I follow here ? The type is still string, as OnErrorType is still just an alias to a string. There is no concept of enum in Go anyway 🙃. Also, this is the exact same thing with a lot of other types we are using (in status, …), it is mainly useful for developer and consumer of the go library to use a predefined set of values, it doesn't do much more than this.

I was a little surprised to discover this was merged while going over the release notes for 0.39 🤔

step.onError was recently changed to support params in addition to constants. step.onError is something user specified through params unlike other types in status which are mostly set by the controller or specified as static values by the users (unless that's not true) in their YAML specifications.

OnErrorType represents a false impression that it only accepts static values (continue and stopAndFail). Why unnecessary creating such type and then converting it back to string in many places?

@vdemeester
Copy link
Member

OnErrorType represents a false impression that it only accepts static values (continue and stopAndFail). Why unnecessary creating such type and then converting it back to string in many places?

From a API consumer point of view, nothing changes, it's still "just a string" nothing else. 99% of users of Tekton won't read code, just docs, and OnErrorType doesn't bubble up anywhere in the API or the doc. This is a pure "implementation detail" change that can help developer code overall when working on the controller's code.

@pritidesai
Copy link
Member

thank you @vdemeester for being patient here, appreciate it 🙏

I don't know how are these interpreted - https://tekton.dev/docs/pipelines/pipeline-api/#tekton.dev/v1.Step This API doc has listed onError as OnErrorType.

The source for this doc is here - https://github.com/tektoncd/pipeline/blob/main/docs/pipeline-api.md#tekton.dev/v1.Step

@QuanZhang-William
Copy link
Member Author

thank you @vdemeester for being patient here, appreciate it 🙏

I don't know how are these interpreted - https://tekton.dev/docs/pipelines/pipeline-api/#tekton.dev/v1.Step This API doc has listed onError as OnErrorType.

The source for this doc is here - https://github.com/tektoncd/pipeline/blob/main/docs/pipeline-api.md#tekton.dev/v1.Step

Thanks for your feedback @pritidesai! The OnErrorType is documented as (string Alias) here: https://tekton.dev/docs/pipelines/pipeline-api/#tekton.dev/v1.OnErrorType. I think the question is essentially how does a user interpret a string alias in GO. My understanding is that a string alias is not a enum and there is no real enum in GO: golang/go#19814.

The string value "continue" and "stopAndFail" are being directly used across the codebase and it is in general not a good practice. We can also benefit a better compile time check from such typed string, for example, pipelineTask.OnError = step.OnError (after TEP-0050) cannot happen as they are different things semantically.

I think we can keep the OnErrorType for a better practice. And I can update the API doc explicitly saying something like: The value can be set dynamically from task parameter for example, onError: $(params. CONTINUE) to resolve user's confusion if any. What do you think?

/cc @jerop, @dibyom

@dibyom
Copy link
Member

dibyom commented Aug 22, 2022

I think we can keep the OnErrorType for a better practice. And I can update the API doc explicitly saying something like: The value can be set dynamically from task parameter for example, onError: $(params. CONTINUE) to resolve user's confusion if any. What do you think?

https://tekton.dev/docs/pipelines/variables/#fields-that-accept-variable-substitutions already lists onError - I think that's sufficient? (There are other non "string" string types that also accept variable substitutions e.g. imagePullPolicy)

@QuanZhang-William
Copy link
Member Author

I think we can keep the OnErrorType for a better practice. And I can update the API doc explicitly saying something like: The value can be set dynamically from task parameter for example, onError: $(params. CONTINUE) to resolve user's confusion if any. What do you think?

https://tekton.dev/docs/pipelines/variables/#fields-that-accept-variable-substitutions already lists onError - I think that's sufficient? (There are other non "string" string types that also accept variable substitutions e.g. imagePullPolicy)

Yeah, I agree it should be sufficient in this case :)

@QuanZhang-William QuanZhang-William changed the title Convert Step OnError from string to "OnErrorType" type [TEP-0050] Convert Step OnError from string to "OnErrorType" type Nov 27, 2023
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
approved Indicates a PR has been approved by an approver from all required OWNERS files. kind/cleanup Categorizes issue or PR as related to cleaning up code, process, or technical debt. lgtm Indicates that a PR is ready to be merged. release-note Denotes a PR that will be considered when it comes time to generate release notes. size/L Denotes a PR that changes 100-499 lines, ignoring generated files.
Projects
None yet
Development

Successfully merging this pull request may close these issues.

8 participants