ci: add Gitea Actions workflow for make check #21
59
Dockerfile
59
Dockerfile
@@ -1,57 +1,44 @@
|
|||||||
# Build stage
|
# Lint stage — fast feedback on formatting and lint issues
|
||||||
FROM golang:1.24-alpine AS builder
|
# golangci/golangci-lint:v2.1.6
|
||||||
|
FROM golangci/golangci-lint:v2.1.6 AS lint
|
||||||
|
|
||||||
# Install build dependencies
|
WORKDIR /src
|
||||||
RUN apk add --no-cache \
|
|
||||||
gcc \
|
|
||||||
musl-dev \
|
|
||||||
make \
|
|
||||||
git \
|
|
||||||
gnupg
|
|
||||||
|
|
||||||
# Set working directory
|
|
||||||
WORKDIR /build
|
|
||||||
|
|
||||||
# Copy go mod files
|
|
||||||
COPY go.mod go.sum ./
|
COPY go.mod go.sum ./
|
||||||
|
|
||||||
# Download dependencies
|
|
||||||
RUN go mod download
|
RUN go mod download
|
||||||
|
|
||||||
# Copy source code
|
|
||||||
COPY . .
|
COPY . .
|
||||||
|
|
||||||
# Install golangci-lint for checks (binary install to avoid Go version constraints)
|
RUN make fmt-check
|
||||||
RUN wget -O- -nv https://raw.githubusercontent.com/golangci/golangci-lint/HEAD/install.sh | sh -s -- -b $(go env GOPATH)/bin v2.1.6
|
RUN make lint
|
||||||
|
|
||||||
# Run all checks (lint, vet, test, build)
|
# Build stage — tests and compilation
|
||||||
RUN make check
|
FROM golang:1.24-alpine AS builder
|
||||||
|
|
||||||
# Build the final binary with version info
|
# Force BuildKit to run the lint stage
|
||||||
RUN CGO_ENABLED=1 go build -v -o secret cmd/secret/main.go
|
COPY --from=lint /src/go.sum /dev/null
|
||||||
|
|
||||||
|
RUN apk add --no-cache gcc musl-dev make git gnupg
|
||||||
|
|
||||||
|
WORKDIR /build
|
||||||
|
COPY go.mod go.sum ./
|
||||||
|
RUN go mod download
|
||||||
|
|
||||||
|
COPY . .
|
||||||
|
|
||||||
|
RUN make test
|
||||||
|
RUN CGO_ENABLED=1 go build -v -ldflags "-X 'git.eeqj.de/sneak/secret/internal/cli.Version=0.1.0' -X 'git.eeqj.de/sneak/secret/internal/cli.GitCommit=$(git rev-parse HEAD)'" -o secret cmd/secret/main.go
|
||||||
|
|
||||||
# Runtime stage
|
# Runtime stage
|
||||||
FROM alpine:latest
|
FROM alpine:latest
|
||||||
|
|
||||||
# Install runtime dependencies
|
RUN apk add --no-cache ca-certificates gnupg
|
||||||
RUN apk add --no-cache \
|
|
||||||
ca-certificates \
|
|
||||||
gnupg
|
|
||||||
|
|
||||||
# Create non-root user
|
|
||||||
RUN adduser -D -s /bin/sh secret
|
RUN adduser -D -s /bin/sh secret
|
||||||
|
|
||||||
# Copy binary from builder
|
|
||||||
COPY --from=builder /build/secret /usr/local/bin/secret
|
COPY --from=builder /build/secret /usr/local/bin/secret
|
||||||
|
|
||||||
# Ensure binary is executable
|
|
||||||
RUN chmod +x /usr/local/bin/secret
|
RUN chmod +x /usr/local/bin/secret
|
||||||
|
|
||||||
# Switch to non-root user
|
|
||||||
USER secret
|
USER secret
|
||||||
|
|
||||||
# Set working directory
|
|
||||||
WORKDIR /home/secret
|
WORKDIR /home/secret
|
||||||
|
|
||||||
# Set entrypoint
|
ENTRYPOINT ["secret"]
|
||||||
ENTRYPOINT ["secret"]
|
|
||||||
|
|||||||
7
Makefile
7
Makefile
@@ -17,7 +17,7 @@ build: ./secret
|
|||||||
vet:
|
vet:
|
||||||
go vet ./...
|
go vet ./...
|
||||||
|
|
||||||
test: lint vet
|
test: vet
|
||||||
go test ./... || go test -v ./...
|
go test ./... || go test -v ./...
|
||||||
|
|
||||||
fmt:
|
fmt:
|
||||||
@@ -26,7 +26,7 @@ fmt:
|
|||||||
lint:
|
lint:
|
||||||
golangci-lint run --timeout 5m
|
golangci-lint run --timeout 5m
|
||||||
|
|
||||||
check: build test
|
check: build lint test
|
||||||
|
|
||||||
# Build Docker container
|
# Build Docker container
|
||||||
docker:
|
docker:
|
||||||
@@ -42,3 +42,6 @@ clean:
|
|||||||
|
|
||||||
install: ./secret
|
install: ./secret
|
||||||
cp ./secret $(HOME)/bin/secret
|
cp ./secret $(HOME)/bin/secret
|
||||||
|
|
||||||
|
fmt-check:
|
||||||
|
@test -z "$$(gofmt -l .)" || (echo "Files need formatting:" && gofmt -l . && exit 1)
|
||||||
|
|||||||
@@ -2285,6 +2285,7 @@ func verifyFileExists(t *testing.T, path string) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// verifyFileNotExists checks if a file does not exist at the given path
|
// verifyFileNotExists checks if a file does not exist at the given path
|
||||||
|
//
|
||||||
//nolint:unused // kept for future use
|
//nolint:unused // kept for future use
|
||||||
func verifyFileNotExists(t *testing.T, path string) {
|
func verifyFileNotExists(t *testing.T, path string) {
|
||||||
t.Helper()
|
t.Helper()
|
||||||
|
|||||||
@@ -154,4 +154,3 @@ func TestValidateGPGKeyID(t *testing.T) {
|
|||||||
})
|
})
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user