ci: rework build
Some checks failed
Build containers / Build and push image (asahi-cosmic, 43) (push) Failing after 1m49s
Some checks failed
Build containers / Build and push image (asahi-cosmic, 43) (push) Failing after 1m49s
This commit is contained in:
@@ -10,33 +10,23 @@ on:
|
|||||||
jobs:
|
jobs:
|
||||||
build_push:
|
build_push:
|
||||||
name: Build and push image
|
name: Build and push image
|
||||||
runs-on: job-v2
|
runs-on: wesley-arm
|
||||||
|
|
||||||
strategy:
|
strategy:
|
||||||
fail-fast: false
|
fail-fast: false
|
||||||
matrix:
|
matrix:
|
||||||
image: [asahi-cosmic]
|
image: [asahi-cosmic]
|
||||||
version: [43] #Build current stable,next stable/rawhide (if not branched)
|
version: [43] #Build current stable,next stable/rawhide (if not branched)
|
||||||
|
|
||||||
container:
|
container:
|
||||||
image: "quay.io/fedora-ostree-desktops/buildroot:43"
|
image: "quay.io/fedora-ostree-desktops/buildroot:43"
|
||||||
options: "--security-opt apparmor=unconfined --privileged --user 0:0 --device=/dev/kvm --device=/dev/fuse --volume /:/run/host:rw --arch arm64"
|
options: "--security-opt=label=disable --privileged --user 0:0 --device=/dev/kvm --device=/dev/fuse --volume /:/run/host:rw"
|
||||||
|
|
||||||
steps:
|
steps:
|
||||||
- name: Install dependencies
|
|
||||||
run: |
|
|
||||||
dnf install -y nodejs
|
|
||||||
dnf upgrade -y --enablerepo=updates-testing --refresh rpm-ostree
|
|
||||||
|
|
||||||
- name: Checkout
|
- name: Checkout
|
||||||
uses: actions/checkout@v4
|
uses: actions/checkout@v4
|
||||||
|
|
||||||
- name: Build Bootable Container image
|
- name: Build
|
||||||
run: |
|
run: |
|
||||||
./builder.sh "${{ matrix.image }}" "${{ matrix.version }}"
|
sudo podman build --tag misthios/asahi-cosmic:43 --file ./Containerfile --build-arg VERSION=43 --build-arg IMAGE=asahi-cosmic
|
||||||
|
|
||||||
- name: Prepare Docker config directory
|
|
||||||
run: mkdir -p /root/.docker
|
|
||||||
|
|
||||||
- name: Login to Container Registry
|
- name: Login to Container Registry
|
||||||
uses: redhat-actions/podman-login@v1
|
uses: redhat-actions/podman-login@v1
|
||||||
@@ -45,39 +35,4 @@ jobs:
|
|||||||
registry: git.plabble.org
|
registry: git.plabble.org
|
||||||
username: ${{ secrets.REGISTRY_USERNAME }}
|
username: ${{ secrets.REGISTRY_USERNAME }}
|
||||||
password: ${{ secrets.REGISTRY_TOKEN }}
|
password: ${{ secrets.REGISTRY_TOKEN }}
|
||||||
auth_file_path: /tmp/auth.json
|
|
||||||
|
|
||||||
- name: Push container image to container registry
|
|
||||||
id: push
|
|
||||||
run: |
|
|
||||||
# Determine buildid (same logic as upstream)
|
|
||||||
if [[ -f ".buildid" ]]; then
|
|
||||||
buildid="$(< .buildid)"
|
|
||||||
else
|
|
||||||
buildid="$(date '+%Y%m%d.0')"
|
|
||||||
echo "${buildid}" > .buildid
|
|
||||||
fi
|
|
||||||
|
|
||||||
version="${{ matrix.version }}"
|
|
||||||
image="${{ matrix.image }}"
|
|
||||||
|
|
||||||
# Path to the OCI archive produced by builder.sh
|
|
||||||
archive="images/${image}/manifest.ociarchive"
|
|
||||||
|
|
||||||
echo "Pushing ${archive} as ${image}:${version}.${buildid}"
|
|
||||||
|
|
||||||
# Push version.buildid
|
|
||||||
skopeo copy \
|
|
||||||
--authfile /tmp/auth.json \
|
|
||||||
--retry-times 3 \
|
|
||||||
--dest-compress-format zstd \
|
|
||||||
oci-archive:${archive} \
|
|
||||||
docker://git.plabble.org/misthios/${image}:${version}.${buildid}
|
|
||||||
|
|
||||||
# Push version
|
|
||||||
skopeo copy \
|
|
||||||
--authfile /tmp/auth.json \
|
|
||||||
--retry-times 3 \
|
|
||||||
--dest-compress-format zstd \
|
|
||||||
docker://git.plabble.org/misthios/${image}:${version}.${buildid} \
|
|
||||||
docker://git.plabble.org/misthios/${image}:${version}
|
|
||||||
|
|||||||
27
Containerfile
Normal file
27
Containerfile
Normal file
@@ -0,0 +1,27 @@
|
|||||||
|
ARG IMAGE=asahi-cosmic
|
||||||
|
ARG VERSION=43
|
||||||
|
|
||||||
|
FROM quay.io/fedora/fedora:${VERSION} as builder
|
||||||
|
|
||||||
|
ARG IMAGE
|
||||||
|
ARG VERSION
|
||||||
|
|
||||||
|
#Install deps and the latest rpm-ostree
|
||||||
|
RUN dnf -y install rpm-ostree selinux-policy-targeted python3 && dnf upgrade -y --enablerepo=updates-testing --refresh rpm-ostree
|
||||||
|
|
||||||
|
#Copy all files into the container and set permissions
|
||||||
|
COPY . /src
|
||||||
|
RUN chmod -R a=rX,u+w /src
|
||||||
|
WORKDIR /src
|
||||||
|
|
||||||
|
#Build the wanted image and version
|
||||||
|
RUN sudo ./builder.sh ${IMAGE} ${VERSION}
|
||||||
|
|
||||||
|
# Create the container and set the labels
|
||||||
|
FROM scratch
|
||||||
|
COPY --from=builder /src/images/${IMAGE}/manifest.ociarchive /
|
||||||
|
LABEL containers.bootc 1
|
||||||
|
ENV container=oci
|
||||||
|
# Make systemd the default
|
||||||
|
STOPSIGNAL SIGRTMIN+3
|
||||||
|
CMD ["/sbin/init"]
|
||||||
32
builder.sh
32
builder.sh
@@ -43,34 +43,34 @@ echo "${buildid}" > .buildid
|
|||||||
|
|
||||||
echo "Composing ${VERSION}.${buildid} ..."
|
echo "Composing ${VERSION}.${buildid} ..."
|
||||||
|
|
||||||
# repos import
|
# --- REPOS IMPORT ---
|
||||||
cp images/shared/*.repo "${IMAGE_DIR}"
|
cp images/shared/*.repo "${IMAGE_DIR}/"
|
||||||
cp "${IMAGE_DIR}"/{$IMAGE}/repos/*.repo "${IMAGE_DIR}"
|
cp "${IMAGE_DIR}"/repos/*.repo "${IMAGE_DIR}/"
|
||||||
|
|
||||||
# Ensure manifest has correct ref and releasever
|
# --- MANIFEST FIXUPS ---
|
||||||
sed -i '/^ref:/d' "$MANIFEST"
|
# Remove existing ref: and releasever:
|
||||||
sed -i '/^releasever:/d' "$MANIFEST"
|
sed -i '/^ref:/d' "$MANIFEST"
|
||||||
sed -i "1i releasever: ${VERSION}" "$MANIFEST"
|
sed -i '/^releasever:/d' "$MANIFEST"
|
||||||
|
|
||||||
|
# Insert new values at top
|
||||||
|
sed -i "1i releasever: ${VERSION}" "$MANIFEST"
|
||||||
sed -i "1i ref: ${REF}" "$MANIFEST"
|
sed -i "1i ref: ${REF}" "$MANIFEST"
|
||||||
|
|
||||||
#Run a optional per image script to do image specific things
|
# --- OPTIONAL POSTPROCESS ---
|
||||||
POSTPROCESS="${IMAGE_DIR}/${IMAGE}"/postprocess.sh"
|
POSTPROCESS="$IMAGE_DIR/test.sh"
|
||||||
if [[ -x "${POSTPROCESS}" ]]; then
|
if [[ -x "$POSTPROCESS" ]]; then
|
||||||
echo "Running postprocess script: ${POSTPROCESS}"
|
echo "Running postprocess script: $POSTPROCESS"
|
||||||
"${POSTPROCESS}"
|
"$POSTPROCESS"
|
||||||
else
|
else
|
||||||
echo "No postprocess.sh found in ${IMAGE_DIR}, skipping."
|
echo "No postprocess.sh found in ${IMAGE_DIR}, skipping."
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
|
||||||
# --- COMPOSE IMAGE ---
|
# --- COMPOSE IMAGE ---
|
||||||
ARGS=(
|
ARGS=(
|
||||||
"--cachedir=cache"
|
"--cachedir=cache"
|
||||||
"--initialize"
|
|
||||||
"--max-layers=96"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
rpm-ostree compose image \
|
rpm-ostree compose rootfs \
|
||||||
"${ARGS[@]}" \
|
"${ARGS[@]}" \
|
||||||
"$MANIFEST" \
|
"$MANIFEST" \
|
||||||
"$OUTPUT"
|
"$OUTPUT"
|
||||||
|
|||||||
@@ -1,4 +1,13 @@
|
|||||||
#Cosmic related packages
|
|
||||||
|
# System packages (boot)
|
||||||
|
packages-aarch64:
|
||||||
|
- grub2-efi
|
||||||
|
- efibootmgr
|
||||||
|
- shim
|
||||||
|
|
||||||
|
#System packages (common)
|
||||||
|
|
||||||
|
# Core packages (common.yaml upstream)
|
||||||
packages:
|
packages:
|
||||||
- cosmic-edit
|
- cosmic-edit
|
||||||
- cosmic-files
|
- cosmic-files
|
||||||
@@ -16,17 +25,6 @@ packages:
|
|||||||
- plymouth-system-theme
|
- plymouth-system-theme
|
||||||
- system-config-printer
|
- system-config-printer
|
||||||
- xdg-desktop-portal-gtk
|
- xdg-desktop-portal-gtk
|
||||||
|
|
||||||
# System packages (boot)
|
|
||||||
packages-aarch64:
|
|
||||||
- grub2-efi
|
|
||||||
- efibootmgr
|
|
||||||
- shim
|
|
||||||
|
|
||||||
#System packages (common)
|
|
||||||
|
|
||||||
# Core packages (common.yaml upstream)
|
|
||||||
packages:
|
|
||||||
# Ensure that we have a kernel. Kernel packages are not in any comps group
|
# Ensure that we have a kernel. Kernel packages are not in any comps group
|
||||||
# - kernel
|
# - kernel
|
||||||
# - kernel-modules
|
# - kernel-modules
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
copr:copr.fedorainfracloud.org:group_asahi:fedora-remix-branding]
|
[copr:copr.fedorainfracloud.org:group_asahi:fedora-remix-branding]
|
||||||
name=Copr repo for fedora-remix-branding owned by @asahi
|
name=Copr repo for fedora-remix-branding owned by @asahi
|
||||||
baseurl=https://download.copr.fedorainfracloud.org/results/@asahi/fedora-remix-branding/fedora-$releasever-$basearch/
|
baseurl=https://download.copr.fedorainfracloud.org/results/@asahi/fedora-remix-branding/fedora-$releasever-$basearch/
|
||||||
type=rpm-md
|
type=rpm-md
|
||||||
|
|||||||
0
images/asahi-cosmic/postprocess.sh → images/asahi-cosmic/test.sh
Normal file → Executable file
0
images/asahi-cosmic/postprocess.sh → images/asahi-cosmic/test.sh
Normal file → Executable file
Reference in New Issue
Block a user