hack: add docs generation/validation
Signed-off-by: Tonis Tiigi <tonistiigi@gmail.com>pull/506/head
							parent
							
								
									c46407b2d3
								
							
						
					
					
						commit
						363c0fdf4b
					
				| @ -0,0 +1,29 @@ | ||||
| # syntax = docker/dockerfile:1.2 | ||||
| 
 | ||||
| FROM golang:1.16-alpine AS docsgen | ||||
| WORKDIR /src | ||||
| RUN --mount=target=. \ | ||||
|   --mount=target=/root/.cache,type=cache \ | ||||
|   go build -mod=vendor -o /out/docsgen ./docs/docsgen | ||||
| 
 | ||||
| FROM alpine AS gen | ||||
| RUN apk add --no-cache rsync git | ||||
| WORKDIR /src | ||||
| COPY --from=docsgen /out/docsgen /usr/bin | ||||
| RUN --mount=target=/context \ | ||||
|   --mount=target=.,type=tmpfs,readwrite  \ | ||||
|   rsync -a /context/. . && \ | ||||
|   docsgen && \ | ||||
|   mkdir /out && cp -r docs/reference /out | ||||
| 
 | ||||
| FROM scratch AS update | ||||
| COPY --from=gen /out /out | ||||
| 
 | ||||
| FROM gen AS validate | ||||
| RUN --mount=target=/context \ | ||||
|   --mount=target=.,type=tmpfs,readwrite  \ | ||||
|   rsync -a /context/. . && \ | ||||
|   git add -A && \ | ||||
|   rm -rf docs/reference/* && \ | ||||
|   cp -rf /out/* ./docs/ && \ | ||||
|   ./hack/validate-docs check | ||||
| @ -0,0 +1,16 @@ | ||||
| #!/usr/bin/env bash | ||||
| 
 | ||||
| . $(dirname $0)/util | ||||
| set -eu | ||||
| 
 | ||||
| output=$(mktemp -d -t buildx-output.XXXXXXXXXX) | ||||
| 
 | ||||
| buildxCmd build \ | ||||
|   --target "update" \ | ||||
|   --output "type=local,dest=$output" \ | ||||
|   --file "./hack/dockerfiles/docs.Dockerfile" \ | ||||
|   . | ||||
| 
 | ||||
| rm -rf ./docs/reference/* | ||||
| cp -R "$output"/out/* ./docs/ | ||||
| rm -rf $output | ||||
| @ -0,0 +1,29 @@ | ||||
| #!/usr/bin/env sh | ||||
| set -eu | ||||
| 
 | ||||
| case ${1:-} in | ||||
|   '') | ||||
|     . $(dirname $0)/util | ||||
|     buildxCmd build \ | ||||
|       --target validate \ | ||||
|       --file ./hack/dockerfiles/docs.Dockerfile \ | ||||
|       . | ||||
|     ;; | ||||
|   check) | ||||
|     status="$(git status --porcelain -- docs/reference 2>/dev/null)" | ||||
|     diffs=$(echo "$status" | grep -v '^[RAD] ' || true) | ||||
|     if [ "$diffs" ]; then | ||||
|       { | ||||
|         set +x | ||||
|         echo 'The result of ./hack/update-docs differs' | ||||
|         echo | ||||
|         echo "$diffs" | ||||
|         echo | ||||
|         echo 'Please vendor your package with ./hack/update-docs' | ||||
|         echo | ||||
|       } >&2 | ||||
|       exit 1 | ||||
|     fi | ||||
|     echo 'Congratulations! All docs changes are done the right way.' | ||||
|     ;; | ||||
| esac | ||||
					Loading…
					
					
				
		Reference in New Issue
	
	 Tonis Tiigi
						Tonis Tiigi