Breaking changes typically (sometimes we don't realise they are breaking) have "!" in the commit message, as per the conventional commits.
bd49c630328d30206a5c5b78cbc9a00700a28e7d fix(artifact)!: default https to any URL missing a scheme. Fixes #6973
HTTPArtifact without a scheme will now defaults to https instead of http
user need to explicitly include a http prefix if they want to retrieve HTTPArtifact through http
e5b131a33 feat: Add template node to pod name. Fixes #1319 (#6712)
This add the template name to the pod name, to make it easier to understand which pod ran which step. This behaviour can be reverted by setting POD_NAMES=v1
on the workflow controller.
be63efe89 feat(executor)!: Change argoexec
base image to alpine. Closes #5720 (#6006)
Changing from Debian to Alpine reduces the size of the argoexec
image, resulting is faster starting workflow pods, and it also reduce the risk of security issues. There is not such thing as a free lunch. There maybe other behaviour changes we don't know of yet.
48d7ad3 chore: Remove onExit naming transition scaffolding code (#6297)
When upgrading from <v2.12
to >v3.2
workflows that are running at the time of the upgrade and have onExit
steps may experience the onExit
step running twice. This is only applicable for workflows that began running before a workflow-controller
upgrade and are still running after the upgrade is complete. This is only applicable for upgrading from v2.12
or earlier directly to v3.2
or later. Even under these conditions, duplicate work may not be experienced.
3fff791e4 build!: Automatically add manifests to v*
tags (#5880)
The manifests in the repository on the tag will no longer contain the image tag, instead they will contain :latest
.
- You must not get your manifests from the Git repository, you must get them from the release notes.
- You must not use the
stable
tag. This is defunct, and will be removed in v3.1.
ab361667a feat(controller) Emissary executor. (#4925)
The Emissary executor is not a breaking change per-se, but it is brand new so we would not recommend you use it by default yet. Instead, we recommend you test it out on some workflows using config map configuration.
# Specifies the executor to use.
#
# You can use this to:
# * Tailor your executor based on your preference for security or performance.
# * Test out an executor without committing yourself to use it for every workflow.
#
# To find out which executor was actually use, see the `wait` container logs.
#
# The list is in order of precedence; the first matching executor is used.
# This has precedence over `containerRuntimeExecutor`.
containerRuntimeExecutors: |
- name: emissary
selector:
matchLabels:
workflows.argoproj.io/container-runtime-executor: emissary
be63efe89 feat(controller): Expression template tags. Resolves #4548 & #1293 (#5115)
This PR introduced a new expression syntax know as "expression tag template". A user has reported that this does not
always play nicely with the when
condition syntax (Goevaluate).
This can be resolved using a single quote in your when expression:
when: "'{{inputs.parameters.should-print}}' != '2021-01-01'"
defbd600e fix: Default ARGO_SECURE=true. Fixes #5607 (#5626)
The server now starts with TLS enabled by default if a key is available. The original behaviour can be configured with --secure=false
.
If you have an ingress, you may need to add the appropriate annotations:(varies by ingress):
alb.ingress.kubernetes.io/backend-protocol: HTTPS
nginx.ingress.kubernetes.io/backend-protocol: HTTPS
01d310235 chore(server)!: Required authentication by default. Resolves #5206 (#5211)
To login to the user interface, you must provide a login token. The original behaviour can be configured with --auth-mode=server
.
f31e0c6f9 chore!: Remove deprecated fields (#5035)
Some fields that were deprecated in early 2020 have been removed.
Field | Action |
---|---|
template.template and template.templateRef | The workflow spec must be changed to use steps or DAG, otherwise the workflow will error. |
spec.ttlSecondsAfterFinished | change to spec.ttlStrategy.secondsAfterCompletion , otherwise the workflow will not be garbage collected as expected. |
To find impacted workflows:
kubectl get wf --all-namespaces -o yaml | grep templateRef
kubectl get wf --all-namespaces -o yaml | grep ttlSecondsAfterFinished
c8215f972 feat(controller)!: Key-only artifacts. Fixes #3184 (#4618)
This change is not breaking per-se, but many users do not appear to aware of artifact repository ref, so check your usage of that feature if you have problems.