From ebdbc023b24f8e93f2b71b33d70e8dcd1fe028c9 Mon Sep 17 00:00:00 2001 From: Ryan Brue Date: Thu, 15 Feb 2024 23:22:07 -0600 Subject: [PATCH] Test making compile cosmic image --- .github/workflows/compile_cosmic.yml | 161 +++++++++++++++++++++++ containers/cosmic-compiled/Containerfile | 31 +++++ containers/cosmic-compiled/desc.yml | 5 + 3 files changed, 197 insertions(+) create mode 100644 .github/workflows/compile_cosmic.yml create mode 100644 containers/cosmic-compiled/Containerfile create mode 100644 containers/cosmic-compiled/desc.yml diff --git a/.github/workflows/compile_cosmic.yml b/.github/workflows/compile_cosmic.yml new file mode 100644 index 0000000..9efc84c --- /dev/null +++ b/.github/workflows/compile_cosmic.yml @@ -0,0 +1,161 @@ +name: compile_cosmic +on: + workflow_dispatch: + +env: + IMAGE_REGISTRY: ghcr.io/${{ github.repository_owner }} + +# Only deploys the branch named "live". Ignores all other branches, to allow +# having "development" branches without interfering with GHCR image uploads. +jobs: + push-ghcr: + name: Build and push image + runs-on: ubuntu-22.04 + permissions: + contents: read + packages: write + id-token: write + strategy: + fail-fast: false + matrix: + arch: [amd64] #add ,arm64 to add back arm build + + steps: + - name: Maximize build space + uses: easimon/maximize-build-space@v10 + with: + root-reserve-mb: 37500 + remove-dotnet: 'true' + remove-android: 'true' + remove-haskell: 'true' + remove-codeql: 'true' + remove-docker-images: 'true' + + # Checkout push-to-registry action GitHub repository + - name: Checkout Push to Registry action + uses: actions/checkout@v4 + + - name: Add yq (for reading desc.yml) + uses: mikefarah/yq@v4.35.1 + + - name: Gather image data from description + run: | + echo "IMAGE_NAME=$(yq '.name' ./containers/cosmic-compiled/desc.yml)" >> $GITHUB_ENV + echo "IMAGE_DESCRIPTION=$(yq '.description' ./containers/cosmic-compiled/desc.yml)" >> $GITHUB_ENV + echo "IMAGE_MAJOR_VERSION=$(yq '.image-version' ./containers/cosmic-compiled/desc.yml)" >> $GITHUB_ENV + + - name: Get current version + id: labels + run: | + ver=$(skopeo inspect docker://quay.io/fedora/fedora-silverblue:${{ env.IMAGE_MAJOR_VERSION }} | jq -r '.Labels["org.opencontainers.image.version"]') + echo "VERSION=$ver" >> $GITHUB_OUTPUT + + - name: Generate tags + id: generate-tags + shell: bash + run: | + # Generate a timestamp for creating an image version history + TIMESTAMP="$(date +%Y%m%d)" + MAJOR_VERSION="$(echo ${{ steps.labels.outputs.VERSION }} | cut -d . -f 1)" + COMMIT_TAGS=() + BUILD_TAGS=() + # Have tags for tracking builds during pull request + SHA_SHORT="${GITHUB_SHA::7}" + + # Using clever bash string templating, https://stackoverflow.com/q/40771781 + # don't make malformed tags if $MAJOR_VERSION is empty (base-image didn't include proper labels) -- + COMMIT_TAGS+=("pr-${{ github.event.number }}${MAJOR_VERSION:+-$MAJOR_VERSION}-${{ matrix.arch }}") + COMMIT_TAGS+=("${SHA_SHORT}${MAJOR_VERSION:+-$MAJOR_VERSION}-${{ matrix.arch }}") + + BUILD_TAGS=("${MAJOR_VERSION}-${{ matrix.arch }}" "${MAJOR_VERSION:+$MAJOR_VERSION-}${TIMESTAMP}-${{ matrix.arch }}") + # -- + + BUILD_TAGS+=("${TIMESTAMP}-${{ matrix.arch }}") + BUILD_TAGS+=("latest-${{ matrix.arch }}") + + if [[ "${{ github.event_name }}" == "pull_request" ]]; then + echo "Generated the following commit tags: " + for TAG in "${COMMIT_TAGS[@]}"; do + echo "${TAG}" + done + alias_tags=("${COMMIT_TAGS[@]}") + else + alias_tags=("${BUILD_TAGS[@]}") + fi + echo "Generated the following build tags: " + for TAG in "${BUILD_TAGS[@]}"; do + echo "${TAG}" + done + echo "alias_tags=${alias_tags[*]}" >> $GITHUB_OUTPUT + + # Build metadata + - name: Image Metadata + uses: docker/metadata-action@v5 + id: meta + with: + images: | + ${{ env.IMAGE_NAME }} + labels: | + org.opencontainers.image.title=${{ env.IMAGE_NAME }} + org.opencontainers.image.version=${{ steps.labels.outputs.VERSION }} + org.opencontainers.image.description=${{ env.IMAGE_DESCRIPTION }} + io.artifacthub.package.readme-url=https://raw.githubusercontent.com/ryanabx/cosmic-compiled/main/README.md + io.artifacthub.package.logo-url=https://avatars.githubusercontent.com/u/56272643?s=200&v=4 + + # Workaround bug where capital letters in your GitHub username make it impossible to push to GHCR. + # https://github.com/macbre/push-to-ghcr/issues/12 + - name: Lowercase Registry + id: registry_case + uses: ASzc/change-string-case-action@v6 + with: + string: ${{ env.IMAGE_REGISTRY }} + + - name: Lowercase Image + id: image_case + uses: ASzc/change-string-case-action@v6 + with: + string: ${{ env.IMAGE_NAME }} + + - name: Install qemu dependency + run: | + sudo apt-get update + sudo apt-get install -y qemu-user-static + + # Build image using Buildah action + - name: Build Image + id: build_image + uses: redhat-actions/buildah-build@v2 + with: + containerfiles: | + ./containers/fedora-cosmic-atomic/Containerfile + image: ${{ env.IMAGE_NAME }} + tags: | + ${{ steps.generate-tags.outputs.alias_tags }} + archs: ${{ matrix.arch }} + build-args: | + IMAGE_MAJOR_VERSION=${{ env.IMAGE_MAJOR_VERSION }} + IMAGE_REGISTRY=${{ steps.registry_case.outputs.lowercase }} + labels: ${{ steps.meta.outputs.labels }} + oci: false + + - name: 'Login to GitHub Container Registry' + uses: docker/login-action@v3 + with: + registry: ghcr.io + username: ${{github.actor}} + password: ${{secrets.GITHUB_TOKEN}} + + # Push the image to GHCR (Image Registry) + - name: Push To GHCR + uses: redhat-actions/push-to-registry@v2 + id: push + with: + image: ${{ steps.build_image.outputs.image }} + tags: ${{ steps.build_image.outputs.tags }} + registry: ${{ steps.registry_case.outputs.lowercase }} + extra-args: | + --disable-content-trust + + - name: Echo outputs + run: | + echo "${{ toJSON(steps.push.outputs) }}" \ No newline at end of file diff --git a/containers/cosmic-compiled/Containerfile b/containers/cosmic-compiled/Containerfile new file mode 100644 index 0000000..96f44d9 --- /dev/null +++ b/containers/cosmic-compiled/Containerfile @@ -0,0 +1,31 @@ +ARG IMAGE_MAJOR_VERSION=39 + +FROM registry.fedoraproject.org/fedora:${IMAGE_MAJOR_VERSION} + +RUN dnf update -y +RUN dnf install -y git \ + make \ + which \ + just \ + rustc \ + libglvnd-devel \ + libseat-devel \ + libxkbcommon-devel \ + lld \ + libinput-devel \ + glib2-devel \ + gtk3-devel \ + dbus-devel \ + wayland-devel \ + clang-devel \ + cargo \ + mesa-libgbm-devel \ + pipewire-devel \ + pam-devel \ + flatpak-devel \ + rust-rav1e+nasm-rs-devel +RUN git clone --recurse-submodules https://github.com/pop-os/cosmic-epoch +# This is where the magic happens +RUN cd cosmic-epoch && git submodule update --remote && just sysext && rm -rf cosmic-sysext/usr/lib/extension-release.d + +RUN rpm-ostree cleanup -m && ostree container commit diff --git a/containers/cosmic-compiled/desc.yml b/containers/cosmic-compiled/desc.yml new file mode 100644 index 0000000..ddaf680 --- /dev/null +++ b/containers/cosmic-compiled/desc.yml @@ -0,0 +1,5 @@ +title: COSMIC Compiled +name: cosmic-compiled +description: Image with artifacts compiled from latest COSMIC commits. +image-registry: ghcr.io +image-version: 39 \ No newline at end of file