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

docs: Add CI/CD example for building Argo Workflows using Argo Workflows - Fixes #8591 #13895

Open
wants to merge 12 commits into
base: main
Choose a base branch
from

Conversation

wesleyscholl
Copy link

@wesleyscholl wesleyscholl commented Nov 12, 2024

A detailed example for implementing CI/CD pipelines to build Argo Workflows using Argo Workflows

Fixes #8591

Motivation

This issue was more than 2 years old and I wanted to contribute to the project. I work with Argo Workflows everyday and I'm CAPA certified (Certified Argo Project Associate). To prepare for my next DevOps role, I wanted to learn more about CI/CD pipelines and lifecycle.

Slide Deck from the Community Meeting Demo

Screenshot 2024-12-20 at 5 06 21 PM

Argo Workflows CI_CD Demo.pdf

Modifications

WorkflowTemplate example includes:

CI

Description Resource Status
Argo Workflows API endpoint, submits WorkflowTemplate WorkflowEventBinding ☑️
Build the CLI WorkflowTemplate ☑️
Build images using Buildkit - Push images to Docker Hub WorkflowTemplate ☑️
Run unit tests and collect test report WorkflowTemplate ☑️
Run coverage and collect report WorkflowTemplate ☑️
Deploy to a cluster WorkflowTemplate ☑️
Run basic E2E tests and collect report WorkflowTemplate ☑️

Pipeline

Description Resource Status
Combine CI and CD jobs with an approval step WorkflowTemplate ☑️

CD

Description Resource Status
Tag and push tag WorkflowTemplate ☑️
Update deployment manifests using kustomize edit set image WorkflowTemplate ☑️
Commit deployment manifests WorkflowTemplate ☑️
Start Argo CD sync step WorkflowTemplate ☑️

Documentation & Configuration

Description Resource Status
CI, CD, & Pipeline Documentation Comments ☑️
Service Account for WorkflowEventBinding ServiceAccount ☑️
$ARGO_TOKEN - Bearer Authorization for WorkflowEventBinding Secret ☑️
Role to submit workflow templates for WorkflowEventBinding Role ☑️
RoleBinding the Role to the ServiceAccount for WorkflowEventBinding RoleBinding ☑️
Docker configuration - Hub credentials Secret ☑️
GitHub PAT - GitHub credentials Secret ☑️
ArgoCD server and credentials Secret ☑️
ArgoCD network policy NetworkPolicy ☑️

Verification

Thoroughly tested the workflow:

  • E2E Workflow
Screenshot 2024-12-17 at 4 33 40 PM
  • Workflow steps

  • clone-repo

Screenshot 2024-11-07 at 9 29 08 AM
  • build-cli
Screenshot 2024-11-07 at 9 50 37 AM
  • create-exec-image
Screenshot 2024-11-07 at 10 13 17 AM
  • create-cli-image
Screenshot 2024-11-07 at 10 55 04 AM
  • run-tests
Screenshot 2024-11-07 at 12 02 53 PM
  • run-coverage
Screenshot 2024-11-07 at 12 09 01 PM
  • prepare-deploy-to-cluster-e2e-test
Screenshot 2024-11-12 at 11 35 58 AM
  • approval
Screenshot 2024-11-08 at 1 00 57 PM
  • docker-tag-push
Screenshot 2024-11-08 at 1 04 11 PM
  • update-manifests
Screenshot 2024-11-08 at 1 04 46 PM
  • commit-manifests
Screenshot 2024-11-08 at 1 05 08 PM
  • start-argocd-sync
Screenshot 2024-11-08 at 1 07 01 PM

@wesleyscholl wesleyscholl marked this pull request as draft November 17, 2024 12:21
@wesleyscholl wesleyscholl marked this pull request as ready for review November 17, 2024 12:22
@wesleyscholl
Copy link
Author

For review: @alexec @terrytangyuan @sarabala1979 @caelan-io

Thanks

Copy link
Member

@terrytangyuan terrytangyuan left a comment

Choose a reason for hiding this comment

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

This is great but my main concern is how difficult it is to maintain this in this repo

@mubarak-j
Copy link

I'm not sure how this adds any complexity or burden when there are more than 50 examples in this repo. The lack of documentation/example for CI/CD use case, makes this a much-needed addition, as described in the linked issue.

@Joibel
Copy link
Member

Joibel commented Nov 21, 2024

I would like this to make it clear that it isn't a useful CI/CD for workflows, as it doesn't build everything and doesn't run all of the e2e tests. It doesn't build the controller.

It also feels like we should demonstrate a proper DAG, rather than running the whole thing in series. Build and test the components in parallel.

I'm also not sure that workflows is a good thing to demonstrate this on, as it's pretty peculiar and demonstrates bad practice - e.g. the argo-cli you build in the earlier test isn't the one under test in e2e.

@tico24 did a talk at argocon about doing the whole thing, including fixing some of this https://www.youtube.com/watch?v=q2jAPJHfubA

On the other hand, it would be good to have something in here. Perhaps explain the scope of what is going on and the caveats better in the example. This isn't like most of the other examples in there - the readme section of it is longer than most of the other actual examples in total, so I'm not sure all comparisons apply.

@mubarak-j
Copy link

I agree it would be good to have something in here considering that the last Argo workflows survery had CI/CD was the top use case and yet this repo lack an example for that. Like other examples (which are not meant to be full-fledged solutions), this is a great starting point...

@wesleyscholl
Copy link
Author

@terrytangyuan

The example is a bit long, but it includes all the requirements from #8591. Would be it easier to maintain if it was split into separate CI and CD WorkflowTemplates? Then link them in the docs.

@Joibel

Thanks for reviewing, this is the first CI/CD pipeline I've ever built. I want to modify this example to make it fully functional. For instance, adding this line to build the controller:

make controller kit STATIC_FILES=false

The workflow can implement a DAG to run all of the e2e tests in parallel and use the argo-cli build in the e2e tests.

As for the scope and caveats, should more comments be added to the example to explain each step in the workflow?

…support - Fixes argoproj#8591

- Added test matrix to cover all E2E test cases.
- Introduced a DAG for parallel test execution to optimize runtime.
- Updated workflow steps for improved parallelism.
- Refactored code to use generic templates, reducing duplication and overall code length.
- Enhanced code readability by adding detailed comments.
- Added build step for the controller.

Signed-off-by: Wesley Scholl <[email protected]>
@wesleyscholl
Copy link
Author

@terrytangyuan @Joibel @mubarak-j @alexec

This PR has been updated:

  • Added test matrix to cover all E2E test cases.
  • Introduced a DAG for parallel test execution to optimize runtime.
  • Updated workflow steps for improved parallelism.
  • Refactored code to use generic templates, reducing duplication and overall code length.
  • Enhanced code readability by adding detailed comments.
  • Added build step for the controller.

@sarabala1979
Copy link
Member

I am kind of thinking to create argoproj-lab repo to keep e2e CI/CD configuration for end user like product which implemented on top argo workflow.
WDYT?
@terrytangyuan

@sarabala1979
Copy link
Member

@wesleyscholl Thanks for contributing this usecase. But just examble is not enough. Community is looking full fetch e2e product. You demo this in upcoming community meeting. Do you like to contribute?

@terrytangyuan
Copy link
Member

I am kind of thinking to create argoproj-lab repo to keep e2e CI/CD configuration for end user like product which implemented on top argo workflow.

Sure as long as there's a way to maintain and test it continuously going forward.

@wesleyscholl
Copy link
Author

@sarabala1979 @terrytangyuan

I can demo for the upcoming community meeting (12/18) and I'm interested in contributing to a full-fledged e2e CI/CD product. A CI/CD extension/plugin that integrates with Argo Workflows sounds very interesting. I can also help with the maintenance and tests.

@caelan-io
Copy link
Member

Hi @wesleyscholl - thanks a lot for developing this example! I agree with @mubarak-j that it's definitely needed. Looking forward to reviewing it further myself.

Happy to have you join us at our last community meeting of the year next Weds, Dec 18 @ 10a PST. 🙌 I have added you to the agenda and we will record the meeting and publish to YouTube afterwards. Please feel free to message me in CNCF Slack if you have any questions ahead of the meeting.

@caelan-io
Copy link
Member

An idea that came to mind while seeing @wesleyscholl 's presentation today at the Community Meeting: We could create a new docs page for "CI/CD use cases" and add links to various examples for users to check out and try on their own.

👍 if you'd like to see this page created and we can suggest some content to add to it from community meetings, examples like this, blog posts, and the Pipekit library of free resources.

I agree that we probably want to improve upon this example before it's blessed as the canonical CI/CD example in the docs, but I think it can serve as a good example for others to take inspiration from for their own CI/CD pipelines using Argo Workflows at their companies, hobby projects, etc. Maybe, like @sarabala1979 recommended, it's hosted in argoproj-labs and referenced in the docs as an unofficial example?

@terrytangyuan
Copy link
Member

terrytangyuan commented Dec 19, 2024

That's a great idea. There's an existing page for CI/CD here: https://argo-workflows.readthedocs.io/en/latest/use-cases/ci-cd/

@wesleyscholl
Copy link
Author

@terrytangyuan @caelan-io

Should I add a link to the CI/CD use cases docs page?

@terrytangyuan
Copy link
Member

Should I add a link to the CI/CD use cases docs page?

Yes that would be great

… configuration

- Updated test matrix to reflect latest software versions for compatibility testing.
- Added detailed comments to improve workflow maintainability.
- Set workingDir for all steps to ensure consistent file paths.
- Adjusted resource requests and limits (CPU/memory) to align with step requirements and runtime optimization.
- Refactored step/task commands to conform to WorkflowTemplate format for modularity.
- Combined unit tests and test coverage into a single step for efficiency.
- Improved readability and reduced redundancy by centralizing template logic.
- Added link in ci cd use cases docs to example workflow.

Signed-off-by: Wesley Scholl <[email protected]>
@wesleyscholl
Copy link
Author

@terrytangyuan @caelan-io

I added a link to the CI/CD use cases docs page. Let me know if you need anything else, thanks.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Add an example of CI/CD - one that builds Argo Workflows, using Argo Workflows
7 participants