initial test
This commit is contained in:
parent
794fd1c709
commit
726879506d
2 changed files with 102 additions and 0 deletions
73
.github/workflows/matrix-build.yml
vendored
Normal file
73
.github/workflows/matrix-build.yml
vendored
Normal file
|
@ -0,0 +1,73 @@
|
||||||
|
name: docker
|
||||||
|
|
||||||
|
on:
|
||||||
|
push:
|
||||||
|
tags:
|
||||||
|
- "v*"
|
||||||
|
|
||||||
|
env:
|
||||||
|
DOCKER_REPO: username/testapp
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
build:
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
timeout-minutes: 30
|
||||||
|
|
||||||
|
strategy:
|
||||||
|
matrix:
|
||||||
|
platform:
|
||||||
|
- linux/amd64
|
||||||
|
- linux/arm64
|
||||||
|
|
||||||
|
steps:
|
||||||
|
- name: Set vars
|
||||||
|
id: vars
|
||||||
|
run: |
|
||||||
|
echo "version=${GITHUB_REF#refs/tags/v}" >> $GITHUB_OUTPUT
|
||||||
|
echo "platform=$(echo -n ${{ matrix.platform }} | sed 's/\//-/g')" >> $GITHUB_OUTPUT
|
||||||
|
|
||||||
|
- uses: actions/checkout@v3
|
||||||
|
- uses: docker/setup-qemu-action@v2
|
||||||
|
- uses: docker/setup-buildx-action@v2
|
||||||
|
|
||||||
|
- name: Login to Docker Hub
|
||||||
|
uses: docker/login-action@v2
|
||||||
|
with:
|
||||||
|
username: ${{ secrets.DOCKER_USERNAME }}
|
||||||
|
password: ${{ secrets.DOCKER_PASSWORD }}
|
||||||
|
|
||||||
|
- name: Build docker images
|
||||||
|
uses: docker/build-push-action@v3
|
||||||
|
with:
|
||||||
|
context: .
|
||||||
|
push: true
|
||||||
|
platforms: ${{ matrix.platform }}
|
||||||
|
tags: |
|
||||||
|
${{ env.DOCKER_REPO }}:${{ steps.vars.outputs.version }}-${{ steps.vars.outputs.platform }}
|
||||||
|
|
||||||
|
release:
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
timeout-minutes: 10
|
||||||
|
needs: build
|
||||||
|
|
||||||
|
steps:
|
||||||
|
- name: Set vars
|
||||||
|
id: vars
|
||||||
|
run: |
|
||||||
|
echo "version=${GITHUB_REF#refs/tags/v}" >> $GITHUB_OUTPUT
|
||||||
|
|
||||||
|
- name: Login to Docker Hub
|
||||||
|
uses: docker/login-action@v2
|
||||||
|
with:
|
||||||
|
username: ${{ secrets.DOCKER_USERNAME }}
|
||||||
|
password: ${{ secrets.DOCKER_PASSWORD }}
|
||||||
|
|
||||||
|
- name: Create Docker Hub manifest
|
||||||
|
run: |
|
||||||
|
docker manifest create $DOCKER_REPO:${{ steps.vars.outputs.version }} \
|
||||||
|
$DOCKER_REPO:${{ steps.vars.outputs.version }}-linux-amd64 \
|
||||||
|
$DOCKER_REPO:${{ steps.vars.outputs.version }}-linux-arm64
|
||||||
|
|
||||||
|
- name: Push manifests
|
||||||
|
run: |
|
||||||
|
docker manifest push $DOCKER_REPO:${{ steps.vars.outputs.version }}
|
29
Dockerfile
Normal file
29
Dockerfile
Normal file
|
@ -0,0 +1,29 @@
|
||||||
|
#
|
||||||
|
# MailHog Dockerfile
|
||||||
|
#
|
||||||
|
|
||||||
|
FROM golang:1.21-alpine as builder
|
||||||
|
|
||||||
|
# Install MailHog:
|
||||||
|
RUN apk --no-cache add --virtual build-dependencies \
|
||||||
|
git \
|
||||||
|
&& mkdir -p /root/gocode \
|
||||||
|
&& export GOPATH=/root/gocode \
|
||||||
|
&& go install github.com/mailhog/MailHog@latest
|
||||||
|
|
||||||
|
FROM alpine:3
|
||||||
|
# Add mailhog user/group with uid/gid 1000.
|
||||||
|
# This is a workaround for boot2docker issue #581, see
|
||||||
|
# https://github.com/boot2docker/boot2docker/issues/581
|
||||||
|
RUN adduser -D -u 1000 mailhog
|
||||||
|
|
||||||
|
COPY --from=builder /root/gocode/bin/MailHog /usr/local/bin/
|
||||||
|
|
||||||
|
USER mailhog
|
||||||
|
|
||||||
|
WORKDIR /home/mailhog
|
||||||
|
|
||||||
|
ENTRYPOINT ["MailHog"]
|
||||||
|
|
||||||
|
# Expose the SMTP and HTTP ports:
|
||||||
|
EXPOSE 1025 8025
|
Loading…
Reference in a new issue