mirror of
https://github.com/crazy-max/diun.git
synced 2025-12-21 13:23:09 +01:00
Add e2e tests (#471)
Co-authored-by: CrazyMax <crazy-max@users.noreply.github.com>
This commit is contained in:
@@ -1,8 +1,10 @@
|
|||||||
|
/.dev
|
||||||
/.idea
|
/.idea
|
||||||
/*.iml
|
/*.iml
|
||||||
|
|
||||||
.dev
|
/.github
|
||||||
/bin
|
/bin
|
||||||
/dist
|
/dist
|
||||||
/site
|
/site
|
||||||
/coverage.txt
|
/coverage.txt
|
||||||
|
/test
|
||||||
|
|||||||
17
.github/workflows/build.yml
vendored
17
.github/workflows/build.yml
vendored
@@ -39,6 +39,10 @@ jobs:
|
|||||||
uses: docker/bake-action@v1
|
uses: docker/bake-action@v1
|
||||||
with:
|
with:
|
||||||
targets: validate
|
targets: validate
|
||||||
|
pull: true
|
||||||
|
set: |
|
||||||
|
*.cache-from=type=gha,scope=diun-validate
|
||||||
|
*.cache-to=type=gha,scope=diun-validate,mode=max
|
||||||
|
|
||||||
test:
|
test:
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
@@ -56,6 +60,10 @@ jobs:
|
|||||||
uses: docker/bake-action@v1
|
uses: docker/bake-action@v1
|
||||||
with:
|
with:
|
||||||
targets: test
|
targets: test
|
||||||
|
pull: true
|
||||||
|
set: |
|
||||||
|
*.cache-from=type=gha,scope=diun-test
|
||||||
|
*.cache-to=type=gha,scope=diun-test,mode=max
|
||||||
-
|
-
|
||||||
name: Upload coverage
|
name: Upload coverage
|
||||||
uses: codecov/codecov-action@v2
|
uses: codecov/codecov-action@v2
|
||||||
@@ -117,6 +125,10 @@ jobs:
|
|||||||
uses: docker/bake-action@v1
|
uses: docker/bake-action@v1
|
||||||
with:
|
with:
|
||||||
targets: artifact-all
|
targets: artifact-all
|
||||||
|
pull: true
|
||||||
|
set: |
|
||||||
|
*.cache-from=type=gha,scope=diun-artifact
|
||||||
|
*.cache-to=type=gha,scope=diun-artifact,mode=max
|
||||||
-
|
-
|
||||||
name: Move artifacts
|
name: Move artifacts
|
||||||
run: |
|
run: |
|
||||||
@@ -136,7 +148,12 @@ jobs:
|
|||||||
./docker-bake.hcl
|
./docker-bake.hcl
|
||||||
${{ steps.meta.outputs.bake-file }}
|
${{ steps.meta.outputs.bake-file }}
|
||||||
targets: image-all
|
targets: image-all
|
||||||
|
pull: true
|
||||||
push: ${{ github.event_name != 'pull_request' }}
|
push: ${{ github.event_name != 'pull_request' }}
|
||||||
|
set: |
|
||||||
|
*.cache-from=type=gha,scope=diun-artifact
|
||||||
|
*.cache-from=type=gha,scope=diun-image
|
||||||
|
*.cache-to=type=gha,scope=diun-image,mode=max
|
||||||
-
|
-
|
||||||
name: GitHub Release
|
name: GitHub Release
|
||||||
uses: softprops/action-gh-release@v1
|
uses: softprops/action-gh-release@v1
|
||||||
|
|||||||
1
.github/workflows/docs.yml
vendored
1
.github/workflows/docs.yml
vendored
@@ -36,6 +36,7 @@ jobs:
|
|||||||
uses: docker/bake-action@v1
|
uses: docker/bake-action@v1
|
||||||
with:
|
with:
|
||||||
targets: docs
|
targets: docs
|
||||||
|
pull: true
|
||||||
-
|
-
|
||||||
name: Check GitHub Pages status
|
name: Check GitHub Pages status
|
||||||
uses: crazy-max/ghaction-github-status@v2
|
uses: crazy-max/ghaction-github-status@v2
|
||||||
|
|||||||
107
.github/workflows/e2e.yml
vendored
Normal file
107
.github/workflows/e2e.yml
vendored
Normal file
@@ -0,0 +1,107 @@
|
|||||||
|
name: e2e
|
||||||
|
|
||||||
|
on:
|
||||||
|
push:
|
||||||
|
branches:
|
||||||
|
- 'master'
|
||||||
|
- 'v*'
|
||||||
|
paths-ignore:
|
||||||
|
- '**.md'
|
||||||
|
pull_request:
|
||||||
|
branches:
|
||||||
|
- 'master'
|
||||||
|
- 'v*'
|
||||||
|
paths-ignore:
|
||||||
|
- '**.md'
|
||||||
|
|
||||||
|
env:
|
||||||
|
BUILD_TAG: 'crazymax/diun:local'
|
||||||
|
CONTAINER_NAME: 'diun'
|
||||||
|
RUNNING_TIMEOUT: '240'
|
||||||
|
RUNNING_LOG_CHECK: 'Next run in'
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
e2e:
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
services:
|
||||||
|
redis:
|
||||||
|
image: redis:6.2.3-alpine
|
||||||
|
cloudflared:
|
||||||
|
image: crazymax/cloudflared:latest
|
||||||
|
options: >-
|
||||||
|
--label "diun.enable=true"
|
||||||
|
--label "diun.watch_repo=true"
|
||||||
|
strategy:
|
||||||
|
fail-fast: false
|
||||||
|
matrix:
|
||||||
|
include:
|
||||||
|
- folder: docker1
|
||||||
|
loglevel: debug
|
||||||
|
- folder: docker2
|
||||||
|
loglevel: info
|
||||||
|
- folder: docker3
|
||||||
|
loglevel: info
|
||||||
|
- folder: dockerfile1
|
||||||
|
loglevel: debug
|
||||||
|
steps:
|
||||||
|
-
|
||||||
|
name: Checkout
|
||||||
|
uses: actions/checkout@v2
|
||||||
|
with:
|
||||||
|
fetch-depth: 0
|
||||||
|
-
|
||||||
|
name: Set up Docker Buildx
|
||||||
|
uses: docker/setup-buildx-action@v1
|
||||||
|
-
|
||||||
|
name: Build
|
||||||
|
uses: docker/bake-action@v1
|
||||||
|
with:
|
||||||
|
targets: image-local
|
||||||
|
pull: true
|
||||||
|
set: |
|
||||||
|
*.cache-from=type=gha,scope=diun-image
|
||||||
|
*.cache-from=type=gha,scope=diun-e2e-${{ matrix.folder }}
|
||||||
|
*.cache-to=type=gha,scope=diun-e2e-${{ matrix.folder }},mode=max
|
||||||
|
-
|
||||||
|
name: Start container
|
||||||
|
run: |
|
||||||
|
volFlags="-v $(pwd)/test/${{ matrix.folder }}/diun.yml:/diun.yml:ro"
|
||||||
|
volFlags="-v /var/run/docker.sock:/var/run/docker.sock ${volFlags}"
|
||||||
|
if [ -d "$(pwd)/test/${{ matrix.folder }}/mount" ]; then
|
||||||
|
volFlags="-v $(pwd)/test/${{ matrix.folder }}/mount:/mount ${volFlags}"
|
||||||
|
fi
|
||||||
|
docker run -d --name ${{ env.CONTAINER_NAME }} ${volFlags} \
|
||||||
|
-e "TZ=Europe/Paris" \
|
||||||
|
-e "LOG_LEVEL=${{ matrix.loglevel }}" \
|
||||||
|
${{ env.BUILD_TAG }}
|
||||||
|
-
|
||||||
|
name: Test run
|
||||||
|
run: |
|
||||||
|
TIMEOUT=$((SECONDS + ${{ env.RUNNING_TIMEOUT }}))
|
||||||
|
while read LOGLINE; do
|
||||||
|
echo ${LOGLINE}
|
||||||
|
if [[ ${LOGLINE} == *"${{ env.RUNNING_LOG_CHECK }}"* ]]; then
|
||||||
|
echo "🎉 Container up!"
|
||||||
|
break
|
||||||
|
fi
|
||||||
|
if [[ $SECONDS -gt ${TIMEOUT} ]]; then
|
||||||
|
>&2 echo "❌ Failed to run ${{ env.CONTAINER_NAME }} container"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
done < <(docker logs -f ${{ env.CONTAINER_NAME }} 2>&1)
|
||||||
|
|
||||||
|
CONTAINER_STATUS=$(docker container inspect --format "{{.State.Status}}" ${{ env.CONTAINER_NAME }})
|
||||||
|
if [[ ${CONTAINER_STATUS} != "running" ]]; then
|
||||||
|
>&2 echo "❌ Container ${{ env.CONTAINER_NAME }} returned status '$CONTAINER_STATUS'"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
-
|
||||||
|
name: List images in db
|
||||||
|
run: |
|
||||||
|
docker exec -t ${{ env.CONTAINER_NAME }} diun image list
|
||||||
|
-
|
||||||
|
name: Container logs
|
||||||
|
if: always()
|
||||||
|
run: |
|
||||||
|
docker logs ${{ env.CONTAINER_NAME }}
|
||||||
|
docker rm -f ${{ env.CONTAINER_NAME }} > /dev/null 2>&1 || true
|
||||||
@@ -33,8 +33,8 @@ COPY --from=generate /out /
|
|||||||
FROM generate AS validate
|
FROM generate AS validate
|
||||||
RUN --mount=type=bind,target=.,rw \
|
RUN --mount=type=bind,target=.,rw \
|
||||||
git add -A && cp -rf /out/* .; \
|
git add -A && cp -rf /out/* .; \
|
||||||
if [ -n "$(git status --porcelain)" ]; then \
|
if [ -n "$(git status --porcelain -- pb)" ]; then \
|
||||||
echo >&2 'ERROR: Generate result differs. Please update with "docker buildx bake gen-update"'; \
|
echo >&2 'ERROR: Generate result differs. Please update with "docker buildx bake gen-update"'; \
|
||||||
git status --porcelain; \
|
git status --porcelain -- pb; \
|
||||||
exit 1; \
|
exit 1; \
|
||||||
fi
|
fi
|
||||||
|
|||||||
6
test/docker1/diun.yml
Normal file
6
test/docker1/diun.yml
Normal file
@@ -0,0 +1,6 @@
|
|||||||
|
watch:
|
||||||
|
workers: 20
|
||||||
|
schedule: "0 */6 * * *"
|
||||||
|
|
||||||
|
providers:
|
||||||
|
docker: {}
|
||||||
7
test/docker2/diun.yml
Normal file
7
test/docker2/diun.yml
Normal file
@@ -0,0 +1,7 @@
|
|||||||
|
watch:
|
||||||
|
workers: 20
|
||||||
|
schedule: "0 */6 * * *"
|
||||||
|
|
||||||
|
providers:
|
||||||
|
docker:
|
||||||
|
watchByDefault: true
|
||||||
8
test/docker3/diun.yml
Normal file
8
test/docker3/diun.yml
Normal file
@@ -0,0 +1,8 @@
|
|||||||
|
watch:
|
||||||
|
workers: 20
|
||||||
|
schedule: "0 */6 * * *"
|
||||||
|
|
||||||
|
providers:
|
||||||
|
docker:
|
||||||
|
watchByDefault: true
|
||||||
|
watchStopped: true
|
||||||
15
test/dockerfile1/diun.yml
Normal file
15
test/dockerfile1/diun.yml
Normal file
@@ -0,0 +1,15 @@
|
|||||||
|
watch:
|
||||||
|
workers: 20
|
||||||
|
schedule: "0 */6 * * *"
|
||||||
|
firstCheckNotif: true
|
||||||
|
|
||||||
|
notif:
|
||||||
|
script:
|
||||||
|
cmd: "sh"
|
||||||
|
args:
|
||||||
|
- "/mount/notif.sh"
|
||||||
|
|
||||||
|
providers:
|
||||||
|
dockerfile:
|
||||||
|
patterns:
|
||||||
|
- /mount/Dockerfile*
|
||||||
16
test/dockerfile1/mount/Dockerfile
Normal file
16
test/dockerfile1/mount/Dockerfile
Normal file
@@ -0,0 +1,16 @@
|
|||||||
|
# syntax=docker/dockerfile:1.2
|
||||||
|
|
||||||
|
# diun.platform=linux/amd64
|
||||||
|
FROM alpine:latest
|
||||||
|
|
||||||
|
# diun.watch_repo=true
|
||||||
|
# diun.max_tags=10
|
||||||
|
# diun.platform=linux/amd64
|
||||||
|
COPY --from=crazymax/yasu / /
|
||||||
|
|
||||||
|
# diun.watch_repo=true
|
||||||
|
# diun.include_tags=^\d+\.\d+\.\d+$
|
||||||
|
# diun.platform=linux/amd64
|
||||||
|
RUN --mount=type=bind,target=.,rw \
|
||||||
|
--mount=type=bind,from=docker/buildx-bin:0.6.0,source=/buildx,target=/usr/bin/buildx \
|
||||||
|
yasu --version
|
||||||
49
test/dockerfile1/mount/Dockerfile1
Normal file
49
test/dockerfile1/mount/Dockerfile1
Normal file
@@ -0,0 +1,49 @@
|
|||||||
|
# syntax=docker/dockerfile:1.2
|
||||||
|
ARG GO_VERSION=1.16
|
||||||
|
|
||||||
|
# diun.watch_repo=true
|
||||||
|
# diun.max_tags=100
|
||||||
|
FROM --platform=$BUILDPLATFORM crazymax/goreleaser-xx:latest AS goreleaser-xx
|
||||||
|
# diun:"watch_repo=true,max_tags=100"
|
||||||
|
FROM --platform=$BUILDPLATFORM golang:${GO_VERSION}-alpine AS base
|
||||||
|
COPY --from=goreleaser-xx / /
|
||||||
|
COPY --from=crazymax/goreleaser-xx:0.162.0 / /
|
||||||
|
RUN apk add --no-cache ca-certificates gcc file git linux-headers musl-dev tar
|
||||||
|
WORKDIR /src
|
||||||
|
|
||||||
|
FROM base AS build
|
||||||
|
ARG TARGETPLATFORM
|
||||||
|
ARG GIT_REF
|
||||||
|
RUN --mount=type=bind,target=/src,rw \
|
||||||
|
--mount=type=cache,target=/root/.cache/go-build \
|
||||||
|
--mount=target=/go/pkg/mod,type=cache \
|
||||||
|
goreleaser-xx --debug \
|
||||||
|
--name "diun" \
|
||||||
|
--dist "/out" \
|
||||||
|
--hooks="go mod tidy" \
|
||||||
|
--hooks="go mod download" \
|
||||||
|
--main="./cmd/main.go" \
|
||||||
|
--ldflags="-s -w -X 'main.version={{.Version}}'" \
|
||||||
|
--files="CHANGELOG.md" \
|
||||||
|
--files="LICENSE" \
|
||||||
|
--files="README.md"
|
||||||
|
|
||||||
|
FROM scratch AS artifacts
|
||||||
|
COPY --from=build /out/*.tar.gz /
|
||||||
|
COPY --from=build /out/*.zip /
|
||||||
|
|
||||||
|
FROM alpine
|
||||||
|
LABEL maintainer="CrazyMax"
|
||||||
|
|
||||||
|
RUN apk --update --no-cache add \
|
||||||
|
ca-certificates \
|
||||||
|
libressl \
|
||||||
|
&& rm -rf /tmp/* /var/cache/apk/*
|
||||||
|
|
||||||
|
COPY --from=build /usr/local/bin/diun /usr/local/bin/diun
|
||||||
|
RUN diun --version
|
||||||
|
|
||||||
|
ENV DIUN_DB_PATH="/data/diun.db"
|
||||||
|
|
||||||
|
VOLUME [ "/data" ]
|
||||||
|
ENTRYPOINT [ "diun" ]
|
||||||
25
test/dockerfile1/mount/Dockerfile2
Normal file
25
test/dockerfile1/mount/Dockerfile2
Normal file
@@ -0,0 +1,25 @@
|
|||||||
|
# syntax=docker/dockerfile:1.2
|
||||||
|
ARG NODE_VERSION
|
||||||
|
|
||||||
|
# foo
|
||||||
|
# diun:"watch_repo=true,max_tags=100"
|
||||||
|
FROM node:${NODE_VERSION}-alpine AS base
|
||||||
|
RUN apk add --no-cache git
|
||||||
|
WORKDIR /src
|
||||||
|
|
||||||
|
FROM base AS deps
|
||||||
|
RUN --mount=type=bind,target=.,rw \
|
||||||
|
--mount=type=cache,target=/src/node_modules \
|
||||||
|
yarn install
|
||||||
|
|
||||||
|
FROM deps AS test
|
||||||
|
ENV RUNNER_TEMP=/tmp/github_runner
|
||||||
|
ENV RUNNER_TOOL_CACHE=/tmp/github_tool_cache
|
||||||
|
RUN --mount=type=bind,target=.,rw \
|
||||||
|
--mount=type=cache,target=/src/node_modules \
|
||||||
|
--mount=type=bind,from=crazymax/docker,source=/usr/libexec/docker/cli-plugins/docker-buildx,target=/usr/libexec/docker/cli-plugins/docker-buildx \
|
||||||
|
--mount=type=bind,from=crazymax/docker,source=/usr/local/bin/docker,target=/usr/bin/docker \
|
||||||
|
yarn run test --coverageDirectory=/tmp/coverage
|
||||||
|
|
||||||
|
FROM scratch AS test-coverage
|
||||||
|
COPY --from=test /tmp/coverage /
|
||||||
1
test/dockerfile1/mount/notif.sh
Normal file
1
test/dockerfile1/mount/notif.sh
Normal file
@@ -0,0 +1 @@
|
|||||||
|
env|sort
|
||||||
Reference in New Issue
Block a user