Skip to content

Commit

Permalink
redux GitHub actions and add Docker builds
Browse files Browse the repository at this point in the history
  • Loading branch information
jessepeterson committed Sep 17, 2023
1 parent 6ea0a2c commit 173bc38
Show file tree
Hide file tree
Showing 6 changed files with 186 additions and 87 deletions.
79 changes: 0 additions & 79 deletions .github/workflows/go.yml

This file was deleted.

123 changes: 123 additions & 0 deletions .github/workflows/on-push-pr.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,123 @@
on:
push:
branches: [main]
tags: ["v*.*.*"]
pull_request:
types: [opened, reopened, synchronize]
jobs:
format-build-test:
strategy:
matrix:
go-version: ['1.19.x']
platform: [ubuntu-latest, macos-latest, windows-latest]
runs-on: ${{ matrix.platform }}
steps:
- uses: actions/checkout@755da8c3cf115ac066823e79a1e1788f8940201b # v3.2.0

- uses: actions/setup-go@6edd4406fa81c3da01a34fa6f6343087c207a568 # v3.5.0
with:
go-version: ${{ matrix.go-version }}

- if: matrix.platform == 'ubuntu-latest'
run: if [ "$(gofmt -s -l . | wc -l)" -gt 0 ]; then exit 1; fi

- run: go build -v ./...

- run: make test
docker-build-push:
if: github.event_name != 'pull_request'
needs: mysql-test
runs-on: ubuntu-latest
permissions:
contents: read
packages: write
steps:
- uses: actions/checkout@755da8c3cf115ac066823e79a1e1788f8940201b # v3.2.0

- uses: docker/login-action@465a07811f14bebb1938fbed4728c6a1ff8901fc # v2.2.0
with:
registry: ghcr.io
username: ${{ github.actor }}
password: ${{ secrets.GITHUB_TOKEN }}

- uses: docker/setup-buildx-action@4c0219f9ac95b02789c1075625400b2acbff50b1 # v2.9.1

- uses: docker/metadata-action@818d4b7b91585d195f67373fd9cb0332e31a7175 # v4.6.0
id: meta
with:
images: |
ghcr.io/${{ github.repository }}
tags: |
type=ref,event=branch
type=semver,pattern={{version}}
type=semver,pattern={{major}}.{{minor}}
type=semver,pattern={{major}}
type=sha
- uses: docker/build-push-action@2eb1c1961a95fc15694676618e422e8ba1d63825 # v4.1.1
with:
context: .
push: true
file: Dockerfile.buildx
platforms: linux/amd64,linux/arm64,linux/arm
tags: ${{ steps.meta.outputs.tags }}
labels: ${{ steps.meta.outputs.labels }}
release-zips:
if: github.event_name != 'pull_request'
needs: mysql-test
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@755da8c3cf115ac066823e79a1e1788f8940201b # v3.2.0

- uses: actions/setup-go@6edd4406fa81c3da01a34fa6f6343087c207a568 # v3.5.0
with:
go-version: '1.19'

- run: CGO_ENABLED=0 make release

- uses: actions/upload-artifact@v3
with:
name: release-zips
path: "*.zip"
mysql-test:
runs-on: 'ubuntu-latest'
needs: format-build-test
services:
mysql:
image: mysql:8.0
env:
MYSQL_RANDOM_ROOT_PASSWORD: yes
MYSQL_DATABASE: nanodep
MYSQL_USER: nanodep
MYSQL_PASSWORD: nanodep
ports:
- 3800:3306
options: --health-cmd="mysqladmin ping" --health-interval=5s --health-timeout=2s --health-retries=3
defaults:
run:
shell: bash
env:
MYSQL_PWD: nanodep
PORT: 3800
steps:
- uses: actions/checkout@755da8c3cf115ac066823e79a1e1788f8940201b # v3.2.0

- uses: actions/setup-go@6edd4406fa81c3da01a34fa6f6343087c207a568 # v3.5.0
with:
go-version: '1.19.x'

- name: verify mysql
run: |
while ! mysqladmin ping --host=localhost --port=$PORT --protocol=TCP --silent; do
sleep 1
done
- name: mysql schema
run: |
mysql --version
mysql --user=nanodep --host=localhost --port=$PORT --protocol=TCP nanodep < ./storage/mysql/schema.sql
- name: setup test dsn
run: echo "NANODEP_MYSQL_STORAGE_TEST_DSN=nanodep:nanodep@tcp(localhost:$PORT)/nanodep" >> $GITHUB_ENV

- run: go test -v ./storage/mysql
20 changes: 20 additions & 0 deletions .github/workflows/on-release.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,20 @@
on:
release:
types: [published]
jobs:
release-zips:
runs-on: ubuntu-latest
permissions:
contents: write
steps:
- uses: actions/checkout@755da8c3cf115ac066823e79a1e1788f8940201b # v3.2.0

- uses: actions/setup-go@6edd4406fa81c3da01a34fa6f6343087c207a568 # v3.5.0
with:
go-version: '1.19'

- run: CGO_ENABLED=0 make release

- run: gh release upload ${{ github.event.release.tag_name }} *.zip
env:
GH_TOKEN: ${{ github.token }}
12 changes: 8 additions & 4 deletions Dockerfile
Original file line number Diff line number Diff line change
@@ -1,10 +1,14 @@
FROM gcr.io/distroless/static

COPY depserver-linux-amd64 /depserver
COPY depsyncer-linux-amd64 /depsyncer
ARG TARGETOS TARGETARCH

COPY depserver-$TARGETOS-$TARGETARCH /app/depserver
COPY depsyncer-$TARGETOS-$TARGETARCH /app/depsyncer

EXPOSE 9001

VOLUME ["/db"]
VOLUME ["/app/db"]

WORKDIR /app

ENTRYPOINT ["/depserver"]
ENTRYPOINT ["/app/depserver"]
28 changes: 28 additions & 0 deletions Dockerfile.buildx
Original file line number Diff line number Diff line change
@@ -0,0 +1,28 @@
FROM --platform=$BUILDPLATFORM golang:1.19 AS builder

WORKDIR /go/app

COPY . .

ARG TARGETOS TARGETARCH

RUN --mount=type=cache,target=/root/.cache/go-build \
--mount=type=cache,target=/go/pkg \
CGO_ENABLED=0 make \
depserver-$TARGETOS-$TARGETARCH \
depsyncer-$TARGETOS-$TARGETARCH

FROM gcr.io/distroless/static

ARG TARGETOS TARGETARCH

COPY --from=builder /go/app/depserver-$TARGETOS-$TARGETARCH /app/depserver
COPY --from=builder /go/app/depsyncer-$TARGETOS-$TARGETARCH /app/depsyncer

EXPOSE 9001

VOLUME ["/app/db"]

WORKDIR /app

ENTRYPOINT ["/app/depserver"]
11 changes: 7 additions & 4 deletions Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -6,18 +6,24 @@ DEPTOKENS=\
deptokens-darwin-arm64 \
deptokens-darwin-amd64 \
deptokens-linux-amd64 \
deptokens-linux-arm64 \
deptokens-linux-arm \
deptokens-windows-amd64.exe

DEPSERVER=\
depserver-darwin-arm64 \
depserver-darwin-amd64 \
depserver-linux-amd64 \
depserver-linux-arm64 \
depserver-linux-arm \
depserver-windows-amd64.exe

DEPSYNCER=\
depsyncer-darwin-arm64 \
depsyncer-darwin-amd64 \
depsyncer-linux-amd64 \
depsyncer-linux-arm64 \
depsyncer-linux-arm \
depsyncer-windows-amd64.exe

SUPPLEMENTAL=\
Expand Down Expand Up @@ -54,10 +60,7 @@ nanodep-%-$(VERSION).zip: depserver-%.exe depsyncer-%.exe deptokens-%.exe $(SUPP
clean:
rm -f deptokens-* depserver-* depsyncer-* nanodep-*.zip

release: \
nanodep-darwin-amd64-$(VERSION).zip \
nanodep-darwin-arm64-$(VERSION).zip \
nanodep-linux-amd64-$(VERSION).zip
release: $(foreach bin,$(DEPSERVER),$(subst .exe,,$(subst depserver,nanodep,$(bin)))-$(VERSION).zip)

test:
go test -v -cover -race ./...
Expand Down

0 comments on commit 173bc38

Please sign in to comment.