Add a CI job to build the staging image of the homepage.
	
		
			
	
		
	
	
		
	
		
			All checks were successful
		
		
	
	
		
			
				
	
				build-homepage-staging Build build-homepage-staging has succeeded
				
			
		
		
	
	
				
					
				
			
		
			All checks were successful
		
		
	
	build-homepage-staging Build build-homepage-staging has succeeded
				
			The staging image will be whatever commit was most recently pushed, deployed instantly to a protected subdomain.
This commit is contained in:
		
							parent
							
								
									070eaef72d
								
							
						
					
					
						commit
						3ebe169ee9
					
				
							
								
								
									
										173
									
								
								.lighthouse/pipeline-build-homepage-staging.yaml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										173
									
								
								.lighthouse/pipeline-build-homepage-staging.yaml
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,173 @@ | ||||
| apiVersion: tekton.dev/v1beta1 | ||||
| kind: PipelineRun | ||||
| metadata: | ||||
|   name: build-homepage-staging | ||||
| spec: | ||||
|   pipelineSpec: | ||||
|     params: | ||||
|       - name: image-name | ||||
|         description: The name for the built image | ||||
|         type: string | ||||
|       - name: path-to-image-context | ||||
|         description: The path to the build context | ||||
|         type: string | ||||
|       - name: path-to-dockerfile | ||||
|         description: The path to the Dockerfile | ||||
|         type: string | ||||
|     tasks: | ||||
|       - name: get-time | ||||
|         taskSpec: | ||||
|           metadata: {} | ||||
|           stepTemplate: | ||||
|             image: alpine:3.18 | ||||
|             name: "" | ||||
|             resources: | ||||
|               requests: | ||||
|                 cpu: 10m | ||||
|                 memory: 600Mi | ||||
|             workingDir: /workspace/source | ||||
|           results: | ||||
|             - name: unix-time | ||||
|               description: The current date in unix timestamp format | ||||
|           steps: | ||||
|             - image: alpine:3.18 | ||||
|               name: get-time-step | ||||
|               script: | | ||||
|                 #!/usr/bin/env sh | ||||
|                 echo -n "$(date +%s)" | tee $(results.unix-time.path) | ||||
|       - name: report-pending | ||||
|         taskRef: | ||||
|           name: gitea-set-status | ||||
|         runAfter: | ||||
|           - fetch-repository | ||||
|         params: | ||||
|           - name: CONTEXT | ||||
|             value: "$(params.JOB_NAME)" | ||||
|           - name: REPO_FULL_NAME | ||||
|             value: "$(params.REPO_OWNER)/$(params.REPO_NAME)" | ||||
|           - name: GITEA_HOST_URL | ||||
|             value: code.fizz.buzz | ||||
|           - name: SHA | ||||
|             value: "$(tasks.fetch-repository.results.commit)" | ||||
|           - name: DESCRIPTION | ||||
|             value: "Build $(params.JOB_NAME) has started" | ||||
|           - name: STATE | ||||
|             value: pending | ||||
|           - name: TARGET_URL | ||||
|             value: "https://tekton.fizz.buzz/#/namespaces/$(context.pipelineRun.namespace)/pipelineruns/$(context.pipelineRun.name)" | ||||
|       - name: fetch-repository | ||||
|         taskRef: | ||||
|           name: git-clone | ||||
|         workspaces: | ||||
|           - name: output | ||||
|             workspace: git-source | ||||
|         params: | ||||
|           - name: url | ||||
|             value: $(params.REPO_URL) | ||||
|           - name: revision | ||||
|             value: $(params.PULL_BASE_SHA) | ||||
|           - name: deleteExisting | ||||
|             value: "true" | ||||
|       - name: build-image | ||||
|         taskRef: | ||||
|           name: kaniko | ||||
|         params: | ||||
|           - name: IMAGE | ||||
|             value: "$(params.image-name):$(tasks.get-time.results.unix-time)" | ||||
|           - name: CONTEXT | ||||
|             value: $(params.path-to-image-context) | ||||
|           - name: DOCKERFILE | ||||
|             value: $(params.path-to-dockerfile) | ||||
|           - name: BUILDER_IMAGE | ||||
|             value: "gcr.io/kaniko-project/executor:v1.12.1" | ||||
|           - name: EXTRA_ARGS | ||||
|             value: | ||||
|               - "--destination=$(params.image-name)" # Also write the :latest image | ||||
|               - --cache=true | ||||
|               - --cache-copy-layers | ||||
|               - --cache-repo=harbor.fizz.buzz/kanikocache/cache | ||||
|               - --use-new-run # Should result in a speed-up | ||||
|               - --reproducible # To remove timestamps so layer caching works. | ||||
|               - --snapshot-mode=redo | ||||
|               - --skip-unused-stages=true | ||||
|               - --registry-mirror=dockerhub.dockerhub.svc.cluster.local | ||||
|         workspaces: | ||||
|           - name: source | ||||
|             workspace: git-source | ||||
|           - name: dockerconfig | ||||
|             workspace: docker-credentials | ||||
|         runAfter: | ||||
|           - get-time | ||||
|           - report-pending | ||||
|           - fetch-repository | ||||
|     finally: | ||||
|       - name: report-success | ||||
|         when: | ||||
|           - input: "$(tasks.status)" | ||||
|             operator: in | ||||
|             values: ["Succeeded", "Completed"] | ||||
|         taskRef: | ||||
|           name: gitea-set-status | ||||
|         params: | ||||
|           - name: CONTEXT | ||||
|             value: "$(params.JOB_NAME)" | ||||
|           - name: REPO_FULL_NAME | ||||
|             value: "$(params.REPO_OWNER)/$(params.REPO_NAME)" | ||||
|           - name: GITEA_HOST_URL | ||||
|             value: code.fizz.buzz | ||||
|           - name: SHA | ||||
|             value: "$(tasks.fetch-repository.results.commit)" | ||||
|           - name: DESCRIPTION | ||||
|             value: "Build $(params.JOB_NAME) has succeeded" | ||||
|           - name: STATE | ||||
|             value: success | ||||
|           - name: TARGET_URL | ||||
|             value: "https://tekton.fizz.buzz/#/namespaces/$(context.pipelineRun.namespace)/pipelineruns/$(context.pipelineRun.name)" | ||||
|       - name: report-failure | ||||
|         when: | ||||
|           - input: "$(tasks.status)" | ||||
|             operator: in | ||||
|             values: ["Failed"] | ||||
|         taskRef: | ||||
|           name: gitea-set-status | ||||
|         params: | ||||
|           - name: CONTEXT | ||||
|             value: "$(params.JOB_NAME)" | ||||
|           - name: REPO_FULL_NAME | ||||
|             value: "$(params.REPO_OWNER)/$(params.REPO_NAME)" | ||||
|           - name: GITEA_HOST_URL | ||||
|             value: code.fizz.buzz | ||||
|           - name: SHA | ||||
|             value: "$(tasks.fetch-repository.results.commit)" | ||||
|           - name: DESCRIPTION | ||||
|             value: "Build $(params.JOB_NAME) has failed" | ||||
|           - name: STATE | ||||
|             value: failure | ||||
|           - name: TARGET_URL | ||||
|             value: "https://tekton.fizz.buzz/#/namespaces/$(context.pipelineRun.namespace)/pipelineruns/$(context.pipelineRun.name)" | ||||
|     workspaces: | ||||
|       - name: git-source | ||||
|       - name: docker-credentials | ||||
|   workspaces: | ||||
|     - name: git-source | ||||
|       volumeClaimTemplate: | ||||
|         spec: | ||||
|           storageClassName: "nfs-client" | ||||
|           accessModes: | ||||
|             - ReadWriteOnce | ||||
|           resources: | ||||
|             requests: | ||||
|               storage: 10Gi | ||||
|       subPath: rust-source | ||||
|     - name: docker-credentials | ||||
|       secret: | ||||
|         secretName: harbor-plain | ||||
|   serviceAccountName: build-bot | ||||
|   timeout: 240h0m0s | ||||
|   params: | ||||
|     - name: image-name | ||||
|       value: "harbor.fizz.buzz/private/homepage-staging" | ||||
|     - name: path-to-image-context | ||||
|       value: . | ||||
|     - name: path-to-dockerfile | ||||
|       value: docker/server/Dockerfile | ||||
| @ -28,6 +28,13 @@ spec: | ||||
|                     storage: 10Gi | ||||
|             subPath: homepage-source | ||||
|         params: [] | ||||
|     - name: build-homepage-staging | ||||
|       source: "pipeline-build-homepage-staging.yaml" | ||||
|       # Override https-based url from lighthouse events. | ||||
|       clone_uri: "git@code.fizz.buzz:talexander/homepage.git" | ||||
|       skip_branches: | ||||
|         # We already run on every commit, so running when the semver tags get pushed is causing needless double-processing. | ||||
|         - "^v[0-9]+\\.[0-9]+\\.[0-9]+$" | ||||
|     - name: build-homepage | ||||
|       agent: tekton-pipeline | ||||
|       branches: | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 Tom Alexander
						Tom Alexander