Skip to content

Commit af8bf18

Browse files
author
Your Name
committed
dind
1 parent 1e534da commit af8bf18

File tree

2 files changed

+174
-26
lines changed

2 files changed

+174
-26
lines changed

.github/workflows/test-update.yml

Lines changed: 156 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,156 @@
1+
name: Build & Update with Arduino CLI
2+
3+
on:
4+
push:
5+
branches:
6+
- main
7+
- test_package_update
8+
workflow_dispatch:
9+
10+
permissions:
11+
contents: read
12+
13+
jobs:
14+
build-and-update:
15+
runs-on: ubuntu-22.04
16+
# services:
17+
# docker:
18+
# image: docker:dind
19+
# options: --privileged --shm-size=2g
20+
# volumes:
21+
# - /var/run/docker.sock:/var/run/docker.sock:ro
22+
# container:
23+
# image: ubuntu:latest
24+
25+
env:
26+
ARCH: amd64
27+
APPCLI_REPO: arduino/arduino-app-cli
28+
ROUTER_REPO: arduino/arduino-router
29+
STABLE_DIR: build/stable
30+
# ---- Configure what to fetch ----
31+
# Use a specific tag (with leading v) or leave empty to use the latest stable release.
32+
APPCLI_TAG: v0.6.6 # or "" to auto-use latest
33+
APPCLI_REGEX: "arm64\\.deb$" # choose the matching asset (regex)
34+
35+
ROUTER_TAG: v0.5.3 # or "" to auto-use latest
36+
ROUTER_REGEX: "amd64\\.deb$" # e.g. change to "arm64\\.deb$" if you need arm64
37+
38+
steps:
39+
- name: Checkout
40+
uses: actions/checkout@v4
41+
42+
- name: Set up Go
43+
uses: actions/setup-go@v5
44+
with:
45+
go-version-file: go.mod
46+
47+
# - name: Set up Docker
48+
# uses: docker/setup-docker-action@v2
49+
50+
# - name: Set up Docker Buildx
51+
# uses: docker/setup-buildx-action@v3
52+
53+
- name: Install Task (go-task)
54+
run: |
55+
go tool task --version
56+
57+
- name: Prepare folder
58+
run: |
59+
mkdir -p "${STABLE_DIR}"
60+
61+
- name: Checkout
62+
uses: actions/checkout@v4
63+
64+
65+
- name: Configure Git for private repo cloning
66+
env:
67+
GITHUB_USERNAME: ${{ secrets.GITHUB_USERNAME }}
68+
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
69+
run: |
70+
git config --global url."https://${GITHUB_USERNAME}:${GITHUB_TOKEN}@github.com".insteadOf "https://github.com"
71+
72+
- name: Install jq & curl
73+
run: |
74+
sudo apt-get update
75+
sudo apt-get install -y jq curl
76+
77+
- name: Fetch .debs dynamically into build/stable
78+
env:
79+
GH_TOKEN: ${{ secrets.GITHUB_TOKEN }} # for private access; use a PAT with repo scope if needed
80+
run: |
81+
set -euo pipefail
82+
mkdir -p build/stable
83+
84+
fetch_deb () {
85+
local repo="$1" tag="${2:-}" regex="$3"
86+
87+
echo "==> Resolving release for ${repo} (tag='${tag:-<latest>}')"
88+
if [ -n "${tag}" ]; then
89+
url="https://api.github.com/repos/${repo}/releases/tags/${tag}"
90+
else
91+
url="https://api.github.com/repos/${repo}/releases/latest"
92+
fi
93+
94+
# Get release JSON
95+
rel="$(curl -sfL -H "Authorization: token ${GH_TOKEN}" -H "Accept: application/vnd.github+json" "${url}")"
96+
97+
# Extract asset that matches regex
98+
name="$(echo "$rel" | jq -r --arg re "${regex}" '.assets[] | select(.name | test($re)) | .name' | head -n1)"
99+
dl="$(echo "$rel" | jq -r --arg re "${regex}" '.assets[] | select(.name | test($re)) | .browser_download_url' | head -n1)"
100+
101+
if [ -z "${name}" ] || [ "${name}" = "null" ] || [ -z "${dl}" ] || [ "${dl}" = "null" ]; then
102+
echo "!! No asset found in ${repo} matching regex: ${regex}"
103+
echo " Available assets were:"
104+
echo "$rel" | jq -r '.assets[].name'
105+
exit 1
106+
fi
107+
108+
echo "Found asset: ${name}"
109+
echo "Downloading: ${dl}"
110+
curl -sfL -H "Authorization: token ${GH_TOKEN}" -o "build/stable/${name}" "${dl}"
111+
ls -lh "build/stable/${name}"
112+
}
113+
114+
# Arduino App CLI
115+
fetch_deb "${APPCLI_REPO}" "${APPCLI_TAG}" "${APPCLI_REGEX}"
116+
117+
# Arduino Router
118+
fetch_deb "${ROUTER_REPO}" "${ROUTER_TAG}" "${ROUTER_REGEX}"
119+
- name: List assets for Arduino App CLI v0.6.6
120+
env:
121+
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
122+
run: |
123+
curl -H "Authorization: token ${GITHUB_TOKEN}" \
124+
-H "Accept: application/vnd.github+json" \
125+
"https://api.github.com/repos/arduino/arduino-app-cli/releases/tags/v0.6.6" \
126+
| jq -r '.assets[] | "\(.name) -> \(.browser_download_url)"'
127+
128+
- name: Download Arduino App CLI .deb
129+
run: |
130+
mkdir -p build/stable
131+
wget -O build/stable/arduino-app-cli_0.6.6_amd64.deb \
132+
https://github.com/arduino/arduino-app-cli/releases/download/0.6.6/arduino-app-cli_0.6.6_amd64.deb
133+
134+
- name: Download Arduino Router .deb
135+
run: |
136+
mkdir -p build/stable
137+
wget -O build/stable/arduino-router_0.5.3_amd64.deb \
138+
https://github.com/arduino/arduino-router/releases/download/v0.5.3/arduino-router_0.5.3_amd64.deb
139+
140+
- name: Build Docker image (no cache)
141+
run: |
142+
docker build --no-cache -t mock-apt-repo -f test.Dockerfile .
143+
144+
- name: Run mock-apt-repo container
145+
run: |
146+
docker run --rm -d \
147+
--privileged \
148+
--cgroupns=host \
149+
-v /sys/fs/cgroup:/sys/fs/cgroup:rw \
150+
-v /var/run/docker.sock:/var/run/docker.sock \
151+
-e DOCKER_HOST=unix:///var/run/docker.sock \
152+
--name apt-test-update \
153+
mock-apt-repo
154+
155+
- name: Verify container is running
156+
run: docker ps

test.Dockerfile

Lines changed: 18 additions & 26 deletions
Original file line numberDiff line numberDiff line change
@@ -1,46 +1,38 @@
11
FROM debian:trixie
22

3-
ENV container docker
4-
STOPSIGNAL SIGRTMIN+3
5-
VOLUME ["/sys/fs/cgroup"]
6-
7-
# Install systemd + dependencies
8-
RUN apt update && apt install -y systemd systemd-sysv dbus \
9-
dpkg-dev apt-utils adduser gzip \
10-
&& rm -rf /var/lib/apt/lists/*
11-
12-
# Copy your packages and setup repo (as before)
13-
ARG OLD_PACKAGE_PATH=build/old_package
14-
ARG NEW_PACKAGE_PATH=build
15-
ARG APP_PACKAGE_NAME=arduino-app-cli
16-
ARG ROUTER_PACKAGE_NAME=arduino-router
3+
RUN apt update && \
4+
apt install -y systemd systemd-sysv dbus \
5+
sudo docker.io ca-certificates curl gnupg \
6+
dpkg-dev apt-utils adduser gzip && \
7+
rm -rf /var/lib/apt/lists/*
8+
179
ARG ARCH=arm64
1810

19-
COPY ${OLD_PACKAGE_PATH}/${APP_PACKAGE_NAME}*.deb /tmp/old_app.deb
20-
COPY ${NEW_PACKAGE_PATH}/${APP_PACKAGE_NAME}*.deb /tmp/new_app.deb
21-
COPY ${NEW_PACKAGE_PATH}/${ROUTER_PACKAGE_NAME}*.deb /tmp/new_router.deb
11+
COPY build/stable/arduino-app-cli*.deb /tmp/stable.deb
12+
COPY build/arduino-app-cli*.deb /tmp/unstable.deb
13+
COPY build/stable/arduino-router*.deb /tmp/router.deb
14+
2215

23-
RUN apt update && apt install -y /tmp/old_app.deb /tmp/new_router.deb \
24-
&& rm /tmp/old_app.deb \
16+
RUN apt update && apt install -y /tmp/stable.deb /tmp/router.deb \
17+
&& rm /tmp/stable.deb /tmp/router.deb \
2518
&& mkdir -p /var/www/html/myrepo/dists/trixie/main/binary-${ARCH} \
26-
&& mv /tmp/new_app.deb /var/www/html/myrepo/dists/trixie/main/binary-${ARCH}/ \
27-
&& mv /tmp/new_router.deb /var/www/html/myrepo/dists/trixie/main/binary-${ARCH}/
19+
&& mv /tmp/unstable.deb /var/www/html/myrepo/dists/trixie/main/binary-${ARCH}/
2820

2921
WORKDIR /var/www/html/myrepo
3022
RUN dpkg-scanpackages dists/trixie/main/binary-${ARCH} /dev/null | gzip -9c > dists/trixie/main/binary-${ARCH}/Packages.gz
3123
WORKDIR /
3224

25+
26+
3327
RUN usermod -s /bin/bash arduino || true
3428
RUN mkdir -p /home/arduino && chown -R arduino:arduino /home/arduino
29+
RUN usermod -aG docker arduino
30+
3531

3632

3733
RUN echo "deb [trusted=yes arch=${ARCH}] file:/var/www/html/myrepo trixie main" \
3834
> /etc/apt/sources.list.d/my-mock-repo.list
3935

4036

41-
VOLUME [ "/sys/fs/cgroup" ]
42-
43-
44-
4537
# CMD: systemd must be PID 1
46-
CMD ["/sbin/init"]
38+
CMD ["/sbin/init"]

0 commit comments

Comments
 (0)