Some checks failed
Mark stable commit / test-unit (push) Has been cancelled
Mark stable commit / test-integration (push) Has been cancelled
Mark stable commit / test-env-virtual (push) Has been cancelled
Mark stable commit / test-env-nix (push) Has been cancelled
Mark stable commit / test-e2e (push) Has been cancelled
Mark stable commit / test-virgin-user (push) Has been cancelled
Mark stable commit / test-virgin-root (push) Has been cancelled
Mark stable commit / mark-stable (push) Has been cancelled
Why: The Dockerfile previously validated `nix --version` during image build, which is environment-sensitive and behaves differently in GitHub Actions vs local/act builds due to PATH and non-login shell differences. The actual contract is runtime availability of Nix, not build-step PATH resolution. This is now reliably enforced by the dedicated `test-env-nix` container test, which validates nix presence and flake execution in the real execution environment. This removes flaky CI behavior while keeping stronger, more accurate coverage of the intended guarantee. https://chatgpt.com/share/693bfbc7-63d8-800f-9ceb-728c7a58e963
62 lines
2.3 KiB
Docker
62 lines
2.3 KiB
Docker
# ------------------------------------------------------------
|
|
# Base image selector — overridden by Makefile
|
|
# ------------------------------------------------------------
|
|
ARG BASE_IMAGE
|
|
FROM ${BASE_IMAGE}
|
|
|
|
RUN echo "BASE_IMAGE=${BASE_IMAGE}" && \
|
|
cat /etc/os-release || true
|
|
|
|
# ------------------------------------------------------------
|
|
# Nix environment defaults
|
|
#
|
|
# Nix itself is installed by your system packages (via init-nix.sh).
|
|
# Here we only define default configuration options.
|
|
# ------------------------------------------------------------
|
|
ENV NIX_CONFIG="experimental-features = nix-command flakes"
|
|
|
|
# ------------------------------------------------------------
|
|
# Unprivileged user for Arch package build (makepkg)
|
|
# ------------------------------------------------------------
|
|
RUN useradd -m aur_builder || true
|
|
|
|
# ------------------------------------------------------------
|
|
# Copy scripts and install distro dependencies
|
|
# ------------------------------------------------------------
|
|
WORKDIR /build
|
|
|
|
# Copy only scripts first so dependency installation can run early
|
|
COPY scripts/ scripts/
|
|
RUN find scripts -type f -name '*.sh' -exec chmod +x {} \;
|
|
|
|
# Install distro-specific build dependencies (and AUR builder on Arch)
|
|
RUN scripts/installation/run-dependencies.sh
|
|
|
|
# ------------------------------------------------------------
|
|
# Select distro-specific Docker entrypoint
|
|
# ------------------------------------------------------------
|
|
# Docker entrypoint (distro-agnostic, nutzt run-package.sh)
|
|
# ------------------------------------------------------------
|
|
COPY scripts/docker/entry.sh /usr/local/bin/docker-entry.sh
|
|
RUN chmod +x /usr/local/bin/docker-entry.sh
|
|
|
|
# ------------------------------------------------------------
|
|
# Build and install distro-native package-manager package
|
|
# via Makefile `install` target (calls scripts/installation/run-package.sh)
|
|
# ------------------------------------------------------------
|
|
COPY . .
|
|
RUN find scripts -type f -name '*.sh' -exec chmod +x {} \;
|
|
|
|
RUN set -e; \
|
|
echo "Building and installing package-manager via make install..."; \
|
|
make install; \
|
|
rm -rf /build
|
|
|
|
# ------------------------------------------------------------
|
|
# Runtime working directory and dev entrypoint
|
|
# ------------------------------------------------------------
|
|
WORKDIR /src
|
|
|
|
ENTRYPOINT ["/usr/local/bin/docker-entry.sh"]
|
|
CMD ["pkgmgr", "--help"]
|