This commit is contained in:
24
.gitea/workflows/ci.yaml
Normal file
24
.gitea/workflows/ci.yaml
Normal file
@@ -0,0 +1,24 @@
|
|||||||
|
name: CI
|
||||||
|
|
||||||
|
on:
|
||||||
|
push:
|
||||||
|
branches:
|
||||||
|
- main
|
||||||
|
- dev
|
||||||
|
pull_request:
|
||||||
|
workflow_dispatch:
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
ubuntu:
|
||||||
|
name: Linux Tests
|
||||||
|
runs-on: ubuntu-22.04
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v4
|
||||||
|
- name: Setup just
|
||||||
|
uses: https://git.housh.dev/actions/setup-just.git@v1
|
||||||
|
- name: Setup QEMU
|
||||||
|
uses: docker/setup-qemu-action@v3
|
||||||
|
- name: Setup buildx
|
||||||
|
uses: docker/setup-buildx-action@v3
|
||||||
|
- name: Run tests
|
||||||
|
run: just docker_tag=test test-docker
|
||||||
@@ -120,11 +120,10 @@ let package = Package(
|
|||||||
.target(name: "HTMLSnapshotTesting"),
|
.target(name: "HTMLSnapshotTesting"),
|
||||||
.target(name: "PdfClient"),
|
.target(name: "PdfClient"),
|
||||||
.product(name: "SnapshotTesting", package: "swift-snapshot-testing"),
|
.product(name: "SnapshotTesting", package: "swift-snapshot-testing"),
|
||||||
|
],
|
||||||
|
resources: [
|
||||||
|
.copy("__Snapshots__")
|
||||||
]
|
]
|
||||||
// ,
|
|
||||||
// resources: [
|
|
||||||
// .copy("__Snapshots__")
|
|
||||||
// ]
|
|
||||||
),
|
),
|
||||||
.target(
|
.target(
|
||||||
name: "ProjectClient",
|
name: "ProjectClient",
|
||||||
|
|||||||
36
docker/Dockerfile.test
Normal file
36
docker/Dockerfile.test
Normal file
@@ -0,0 +1,36 @@
|
|||||||
|
FROM docker.io/swift:6.2-noble
|
||||||
|
|
||||||
|
# Make sure all system packages are up to date, and install only essential packages.
|
||||||
|
RUN export DEBIAN_FRONTEND=noninteractive DEBCONF_NONINTERACTIVE_SEEN=true \
|
||||||
|
&& apt-get -q update \
|
||||||
|
&& apt-get -q dist-upgrade -y \
|
||||||
|
&& apt-get -q install -y \
|
||||||
|
libjemalloc2 \
|
||||||
|
ca-certificates \
|
||||||
|
tzdata \
|
||||||
|
# If your app or its dependencies import FoundationNetworking, also install `libcurl4`.
|
||||||
|
libcurl4 \
|
||||||
|
# If your app or its dependencies import FoundationXML, also install `libxml2`.
|
||||||
|
# libxml2 \
|
||||||
|
sqlite3 \
|
||||||
|
&& rm -r /var/lib/apt/lists/*
|
||||||
|
|
||||||
|
# Set up a build area
|
||||||
|
WORKDIR /app
|
||||||
|
|
||||||
|
# First just resolve dependencies.
|
||||||
|
# This creates a cached layer that can be reused
|
||||||
|
# as long as your Package.swift/Package.resolved
|
||||||
|
# files do not change.
|
||||||
|
COPY ./Package.* ./
|
||||||
|
RUN swift package resolve \
|
||||||
|
$([ -f ./Package.resolved ] && echo "--force-resolved-versions" || true)
|
||||||
|
|
||||||
|
# Copy entire repo into container
|
||||||
|
COPY . .
|
||||||
|
|
||||||
|
ENV SWIFT_BACKTRACE=enable=no
|
||||||
|
ENV LOG_LEVEL=debug
|
||||||
|
|
||||||
|
CMD ["swift", "test"]
|
||||||
|
|
||||||
7
justfile
7
justfile
@@ -14,7 +14,10 @@ run:
|
|||||||
@swift run App serve --log debug
|
@swift run App serve --log debug
|
||||||
|
|
||||||
build-docker file="docker/Dockerfile":
|
build-docker file="docker/Dockerfile":
|
||||||
@podman build -f {{file}} -t {{docker_image}}:{{docker_tag}} .
|
@docker build -f {{file}} -t {{docker_image}}:{{docker_tag}} .
|
||||||
|
|
||||||
run-docker:
|
run-docker:
|
||||||
@podman run -it --rm -v $PWD:/app -p 8080:8080 {{docker_image}}:{{docker_tag}}
|
@docker run -it --rm -v $PWD:/app -p 8080:8080 {{docker_image}}:{{docker_tag}}
|
||||||
|
|
||||||
|
test-docker: (build-docker "docker/Dockerfile.test")
|
||||||
|
@docker run --rm {{docker_image}}:{{docker_tag}} swift test
|
||||||
|
|||||||
Reference in New Issue
Block a user