mirror of
				https://github.com/dani-garcia/vaultwarden.git
				synced 2025-10-26 07:50:02 +02:00 
			
		
		
		
	Optimize release workflow.
- Split Debian and Alpine into different build matrix This starts building both Debian and Alpine based images at the same time - Make use of Docker BuildKit, which improves speed also. - Use BuildKit caching for Rust Cargo across docker images. This prevents downloading the same crates multiple times. - Use Github Actions Services to start a docker registry, starting it via the build script sometimes caused issues. - Updated the Build workflow to use Ubuntu 20.04 which is more close to the Bullseye Debian release regarding package versions.
This commit is contained in:
		
							
								
								
									
										45
									
								
								.github/workflows/build.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										45
									
								
								.github/workflows/build.yml
									
									
									
									
										vendored
									
									
								
							| @@ -31,30 +31,22 @@ jobs: | ||||
|       matrix: | ||||
|         channel: | ||||
|           - nightly | ||||
|           # - stable | ||||
|         target-triple: | ||||
|           - x86_64-unknown-linux-gnu | ||||
|           # - x86_64-unknown-linux-musl | ||||
|         include: | ||||
|           - target-triple: x86_64-unknown-linux-gnu | ||||
|             host-triple: x86_64-unknown-linux-gnu | ||||
|             features: [sqlite,mysql,postgresql] # Remember to update the `cargo test` to match the amount of features | ||||
|             channel: nightly | ||||
|             os: ubuntu-18.04 | ||||
|             os: ubuntu-20.04 | ||||
|             ext: "" | ||||
|           # - target-triple: x86_64-unknown-linux-gnu | ||||
|           #   host-triple: x86_64-unknown-linux-gnu | ||||
|           #   features: "sqlite,mysql,postgresql" | ||||
|           #   channel: stable | ||||
|           #   os: ubuntu-18.04 | ||||
|           #   ext: "" | ||||
|  | ||||
|     name: Building ${{ matrix.channel }}-${{ matrix.target-triple }} | ||||
|     runs-on: ${{ matrix.os }} | ||||
|     steps: | ||||
|       # Checkout the repo | ||||
|       - name: Checkout | ||||
|         uses: actions/checkout@v2 | ||||
|         uses: actions/checkout@5a4ac9002d0be2fb38bd78e4b4dbde5606d7042f # v2.3.4 | ||||
|       # End Checkout the repo | ||||
|  | ||||
|  | ||||
| @@ -73,13 +65,13 @@ jobs: | ||||
|  | ||||
|  | ||||
|       # Enable Rust Caching | ||||
|       - uses: Swatinem/rust-cache@v1 | ||||
|       - uses: Swatinem/rust-cache@842ef286fff290e445b90b4002cc9807c3669641 # v1.3.0 | ||||
|       # End Enable Rust Caching | ||||
|  | ||||
|  | ||||
|       # Uses the rust-toolchain file to determine version | ||||
|       - name: 'Install ${{ matrix.channel }}-${{ matrix.host-triple }} for target: ${{ matrix.target-triple }}' | ||||
|         uses: actions-rs/toolchain@v1 | ||||
|         uses: actions-rs/toolchain@b2417cde72dcf67f306c0ae8e0828a81bf0b189f # v1.0.6 | ||||
|         with: | ||||
|           profile: minimal | ||||
|           target: ${{ matrix.target-triple }} | ||||
| @@ -90,28 +82,28 @@ jobs: | ||||
|       # Run cargo tests (In release mode to speed up future builds) | ||||
|       # First test all features together, afterwards test them separately. | ||||
|       - name: "`cargo test --release --features ${{ join(matrix.features, ',') }} --target ${{ matrix.target-triple }}`" | ||||
|         uses: actions-rs/cargo@v1 | ||||
|         uses: actions-rs/cargo@ae10961054e4aa8b4aa7dffede299aaf087aa33b # v1.0.1 | ||||
|         with: | ||||
|           command: test | ||||
|           args: --release --features ${{ join(matrix.features, ',') }} --target ${{ matrix.target-triple }} | ||||
|       # Test single features | ||||
|       # 0: sqlite | ||||
|       - name: "`cargo test --release --features ${{ matrix.features[0] }} --target ${{ matrix.target-triple }}`" | ||||
|         uses: actions-rs/cargo@v1 | ||||
|         uses: actions-rs/cargo@ae10961054e4aa8b4aa7dffede299aaf087aa33b # v1.0.1 | ||||
|         with: | ||||
|           command: test | ||||
|           args: --release --features ${{ matrix.features[0] }} --target ${{ matrix.target-triple }} | ||||
|         if: ${{ matrix.features[0] != '' }} | ||||
|       # 1: mysql | ||||
|       - name: "`cargo test --release --features ${{ matrix.features[1] }} --target ${{ matrix.target-triple }}`" | ||||
|         uses: actions-rs/cargo@v1 | ||||
|         uses: actions-rs/cargo@ae10961054e4aa8b4aa7dffede299aaf087aa33b # v1.0.1 | ||||
|         with: | ||||
|           command: test | ||||
|           args: --release --features ${{ matrix.features[1] }} --target ${{ matrix.target-triple }} | ||||
|         if: ${{ matrix.features[1] != '' }} | ||||
|       # 2: postgresql | ||||
|       - name: "`cargo test --release --features ${{ matrix.features[2] }} --target ${{ matrix.target-triple }}`" | ||||
|         uses: actions-rs/cargo@v1 | ||||
|         uses: actions-rs/cargo@ae10961054e4aa8b4aa7dffede299aaf087aa33b # v1.0.1 | ||||
|         with: | ||||
|           command: test | ||||
|           args: --release --features ${{ matrix.features[2] }} --target ${{ matrix.target-triple }} | ||||
| @@ -121,7 +113,7 @@ jobs: | ||||
|  | ||||
|       # Run cargo clippy, and fail on warnings (In release mode to speed up future builds) | ||||
|       - name: "`cargo clippy --release --features ${{ join(matrix.features, ',') }} --target ${{ matrix.target-triple }}`" | ||||
|         uses: actions-rs/cargo@v1 | ||||
|         uses: actions-rs/cargo@ae10961054e4aa8b4aa7dffede299aaf087aa33b # v1.0.1 | ||||
|         with: | ||||
|           command: clippy | ||||
|           args: --release --features ${{ join(matrix.features, ',') }} --target ${{ matrix.target-triple }} -- -D warnings | ||||
| @@ -130,7 +122,7 @@ jobs: | ||||
|  | ||||
|       # Run cargo fmt | ||||
|       - name: '`cargo fmt`' | ||||
|         uses: actions-rs/cargo@v1 | ||||
|         uses: actions-rs/cargo@ae10961054e4aa8b4aa7dffede299aaf087aa33b # v1.0.1 | ||||
|         with: | ||||
|           command: fmt | ||||
|           args: --all -- --check | ||||
| @@ -139,7 +131,7 @@ jobs: | ||||
|  | ||||
|       # Build the binary | ||||
|       - name: "`cargo build --release --features ${{ join(matrix.features, ',') }} --target ${{ matrix.target-triple }}`" | ||||
|         uses: actions-rs/cargo@v1 | ||||
|         uses: actions-rs/cargo@ae10961054e4aa8b4aa7dffede299aaf087aa33b # v1.0.1 | ||||
|         with: | ||||
|           command: build | ||||
|           args: --release --features ${{ join(matrix.features, ',') }} --target ${{ matrix.target-triple }} | ||||
| @@ -148,21 +140,8 @@ jobs: | ||||
|  | ||||
|       # Upload artifact to Github Actions | ||||
|       - name: Upload artifact | ||||
|         uses: actions/upload-artifact@v2 | ||||
|         uses: actions/upload-artifact@27121b0bdffd731efa15d66772be8dc71245d074 # v2.2.4 | ||||
|         with: | ||||
|           name: vaultwarden-${{ matrix.target-triple }}${{ matrix.ext }} | ||||
|           path: target/${{ matrix.target-triple }}/release/vaultwarden${{ matrix.ext }} | ||||
|       # End Upload artifact to Github Actions | ||||
|  | ||||
|  | ||||
|       ## This is not used at the moment | ||||
|       ## We could start using this when we can build static binaries | ||||
|       # Upload to github actions release | ||||
|       # - name: Release | ||||
|       #   uses: Shopify/upload-to-release@1 | ||||
|       #   if: startsWith(github.ref, 'refs/tags/') | ||||
|       #   with: | ||||
|       #     name: vaultwarden-${{ matrix.target-triple }}${{ matrix.ext }} | ||||
|       #     path: target/${{ matrix.target-triple }}/release/vaultwarden${{ matrix.ext }} | ||||
|       #     repo-token: ${{ secrets.GITHUB_TOKEN }} | ||||
|       # End Upload to github actions release | ||||
|   | ||||
							
								
								
									
										2
									
								
								.github/workflows/hadolint.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								.github/workflows/hadolint.yml
									
									
									
									
										vendored
									
									
								
							| @@ -16,7 +16,7 @@ jobs: | ||||
|     steps: | ||||
|       # Checkout the repo | ||||
|       - name: Checkout | ||||
|         uses: actions/checkout@v2 | ||||
|         uses: actions/checkout@5a4ac9002d0be2fb38bd78e4b4dbde5606d7042f # v2.3.4 | ||||
|       # End Checkout the repo | ||||
|  | ||||
|  | ||||
|   | ||||
							
								
								
									
										28
									
								
								.github/workflows/release.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										28
									
								
								.github/workflows/release.yml
									
									
									
									
										vendored
									
									
								
							| @@ -31,7 +31,7 @@ jobs: | ||||
|     steps: | ||||
|       - name: Skip Duplicates Actions | ||||
|         id: skip_check | ||||
|         uses: fkirc/skip-duplicate-actions@master | ||||
|         uses: fkirc/skip-duplicate-actions@f75dd6564bb646f95277dc8c3b80612e46a4a1ea # v3.4.1 | ||||
|         with: | ||||
|           cancel_others: 'true' | ||||
|         # Only run this when not creating a tag | ||||
| @@ -40,23 +40,33 @@ jobs: | ||||
|   docker-build: | ||||
|     runs-on: ubuntu-latest | ||||
|     needs: skip_check | ||||
|     if: ${{ needs.skip_check.outputs.should_skip != 'true' }} | ||||
|     # Start a local docker registry to be used to generate multi-arch images. | ||||
|     services: | ||||
|       registry: | ||||
|         image: registry:2 | ||||
|         ports: | ||||
|           - 5000:5000 | ||||
|     env: | ||||
|       # DOCKER_BUILDKIT: 1 # Disabled for now, but we should look at this because it will speedup building! | ||||
|       DOCKER_BUILDKIT: 1 # Disabled for now, but we should look at this because it will speedup building! | ||||
|       # DOCKER_REPO/secrets.DOCKERHUB_REPO needs to be 'index.docker.io/<user>/<repo>' | ||||
|       DOCKER_REPO: ${{ secrets.DOCKERHUB_REPO }} | ||||
|       SOURCE_COMMIT: ${{ github.sha }} | ||||
|       SOURCE_REPOSITORY_URL: "https://github.com/${{ github.repository }}" | ||||
|     if: ${{ needs.skip_check.outputs.should_skip != 'true' && github.repository == 'dani-garcia/vaultwarden' }} | ||||
|     strategy: | ||||
|       matrix: | ||||
|         base_image: ["debian","alpine"] | ||||
|  | ||||
|     steps: | ||||
|       # Checkout the repo | ||||
|       - name: Checkout | ||||
|         uses: actions/checkout@v2 | ||||
|         uses: actions/checkout@5a4ac9002d0be2fb38bd78e4b4dbde5606d7042f # v2.3.4 | ||||
|         with: | ||||
|           fetch-depth: 0 | ||||
|  | ||||
|       # Login to Docker Hub | ||||
|       - name: Login to Docker Hub | ||||
|         uses: docker/login-action@v1 | ||||
|         uses: docker/login-action@f054a8b539a109f9f41c372932f1ae047eff08c9 # v1.10.0 | ||||
|         with: | ||||
|           username: ${{ secrets.DOCKERHUB_USERNAME }} | ||||
|           password: ${{ secrets.DOCKERHUB_TOKEN }} | ||||
| @@ -79,16 +89,18 @@ jobs: | ||||
|       - name: Build Debian based images | ||||
|         shell: bash | ||||
|         env: | ||||
|           DOCKER_TAG: ${{steps.vars.outputs.DOCKER_TAG}} | ||||
|           DOCKER_TAG: "${{steps.vars.outputs.DOCKER_TAG}}" | ||||
|         run: | | ||||
|           ./hooks/build | ||||
|         if: ${{ matrix.base_image == 'debian' }} | ||||
|  | ||||
|       - name: Push Debian based images | ||||
|         shell: bash | ||||
|         env: | ||||
|           DOCKER_TAG: ${{steps.vars.outputs.DOCKER_TAG}} | ||||
|           DOCKER_TAG: "${{steps.vars.outputs.DOCKER_TAG}}" | ||||
|         run: | | ||||
|           ./hooks/push | ||||
|         if: ${{ matrix.base_image == 'debian' }} | ||||
|  | ||||
|       - name: Build Alpine based images | ||||
|         shell: bash | ||||
| @@ -96,6 +108,7 @@ jobs: | ||||
|           DOCKER_TAG: "${{steps.vars.outputs.DOCKER_TAG}}-alpine" | ||||
|         run: | | ||||
|           ./hooks/build | ||||
|         if: ${{ matrix.base_image == 'alpine' }} | ||||
|  | ||||
|       - name: Push Alpine based images | ||||
|         shell: bash | ||||
| @@ -103,3 +116,4 @@ jobs: | ||||
|           DOCKER_TAG: "${{steps.vars.outputs.DOCKER_TAG}}-alpine" | ||||
|         run: | | ||||
|           ./hooks/push | ||||
|         if: ${{ matrix.base_image == 'alpine' }} | ||||
|   | ||||
		Reference in New Issue
	
	Block a user