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

fix: production ready docker build with ci workflow #13541

Draft
wants to merge 37 commits into
base: main
Choose a base branch
from

Conversation

ChichiCaleb
Copy link

What does this PR do?

builds a production ready docker image

  • builds a leaner and more secure docker image (< 1/3) the size of the current calcom image

  • abilty to change host and any chosen inlined build time variable with runtime variable

  • db migration at runtime

  • implemented postgres healthcheck and service_healthy option in compose removing the need for wait-for-it script

  • ability to run unit test in docker

builds a full featured ci with ability to:

  • build a test image and push to GHCR which will subequently be pulled by integration-test
    and trivy scan jobs for their respective actions

  • builds and runs unit test specified in the repo by targeting unit-test layer of multistage docker build
    however uses the cache from test image to save time

  • pulls test image from GHCR and runs integration test in docker compose

  • pulls test image from GHCR and run a trivy vulnerability scan for high and crtical CVEs (non-blocking)
    and uploads the sarif result to github security tab

  • generates changelog.MD file and create releases using conventional commits.

    • creates a prelease when a pull request is made to main branch following a succesful unit and integration test.

    • creates a release when a merge is made to the main branch and adds either the prelease or released version to github output to be used by final image published to docker hub

  • builds the final image and adds latest tag and image:V*.*.* semantic versioning tag to merge request
    and image:v*.*.*-alpha.* tag to pull requests made to main branch before pushing to dockerhub

  • adds the Docker image tag(s)/labels pushed to docker hub,to the pull request comment section for reference purpose

Fixes #12032

Requirement/Documentation

  • In repo settings under actions enable:

    • Read and write permissions
  • create a github Personal access Token and add as repo secret with the name RELEASE_MAIN for automated
    changelog generation and release enabling the following:

    • Repo
    • workflow
    • write package
    • admin:org
  • In repo settings under rules enable:

    • repository admin bypass list

Type of change

  • Chore (refactoring code, technical debt, workflow improvements)

How should this be tested?

  git clone https://github.com/calcom/cal.com.git
  • Duplicate .env.example to .env in infra/docker/web

  • A workflow flow run, pull request or merge request triggers the ci workflow

  • start the services in docker compose and test locally with:

    docker compose -f infra/docker/web/docker-compose.yaml up

Mandatory Tasks

  • Make sure you have self-reviewed the code. A decent size PR without self-review might be rejected.

@CLAassistant
Copy link

CLAassistant commented Feb 5, 2024

CLA assistant check
Thank you for your submission! We really appreciate it. Like many open source projects, we ask that you all sign our Contributor License Agreement before we can accept your contribution.
1 out of 2 committers have signed the CLA.

✅ keithwillcode
❌ chichi


chichi seems not to be a GitHub user. You need a GitHub account to be able to sign the CLA. If you have already a GitHub account, please add the email address used for this commit to your account.
You have signed the CLA already but the status is still pending? Let us recheck it.

Copy link
Contributor

github-actions bot commented Feb 5, 2024

Thank you for following the naming conventions! 🙏 Feel free to join our discord and post your PR link.

@github-actions github-actions bot added ci area: CI, DX, pipeline, github actions community Created by Linear-GitHub Sync docker foundation Medium priority Created by Linear-GitHub Sync osshack Submission for 2023 OSShack platform Anything related to our platform plan labels Feb 5, 2024
Copy link
Contributor

github-actions bot commented Feb 5, 2024

📦 Next.js Bundle Analysis for @calcom/web

This analysis was generated by the Next.js Bundle Analysis action. 🤖

This PR introduced no changes to the JavaScript bundle! 🙌

@Udit-takkar Udit-takkar requested a review from a team February 5, 2024 17:19
@Udit-takkar Udit-takkar added this to the v3.9 milestone Feb 5, 2024
@keithwillcode
Copy link
Contributor

Wow, thanks so much for this contribution, @ChichiCaleb. We’ve slotted it to be reviewed during the 3.9 milestone which starts the 15th. 🙏🏼

@ChichiCaleb
Copy link
Author

thanks for the great work this community has been doing

Copy link

vercel bot commented Feb 8, 2024

Someone is attempting to deploy a commit to the cal Team on Vercel.

A member of the Team first needs to authorize it.

@ChichiCaleb ChichiCaleb changed the title fix: production ready docker build with ci workflow fix: production ready docker build with ci workflow with opionated choosing of nextbuild output Feb 8, 2024
@ChichiCaleb ChichiCaleb changed the title fix: production ready docker build with ci workflow with opionated choosing of nextbuild output fix: production ready docker build with ci workflow and opionated choosing of nextbuild output Feb 8, 2024
@ChichiCaleb ChichiCaleb changed the title fix: production ready docker build with ci workflow and opionated choosing of nextbuild output fix: production ready docker build with ci workflow Feb 8, 2024
@zomars
Copy link
Member

zomars commented Feb 8, 2024

If we merge this PR means that the calcom/docker repo would be deprecated?

@keithwillcode keithwillcode removed the platform Anything related to our platform plan label Feb 13, 2024
@keithwillcode keithwillcode added this to the v4.7 milestone Nov 3, 2024
@dosubot dosubot bot modified the milestones: v4.7, v4.8 Nov 6, 2024
@keithwillcode keithwillcode removed the platform Anything related to our platform plan label Nov 11, 2024
@keithwillcode keithwillcode modified the milestones: v4.8, v4.9 Dec 15, 2024
@dosubot dosubot bot removed this from the v4.9 milestone Dec 15, 2024
@dosubot dosubot bot modified the milestones: v5.0, v4.10 Jan 16, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
ci area: CI, DX, pipeline, github actions community Created by Linear-GitHub Sync docker foundation high-risk Requires approval by Foundation team osshack Submission for 2023 OSShack
Projects
None yet
Development

Successfully merging this pull request may close these issues.

[CAL-2635] make cal.com dockerable – refactor constant.ts
10 participants