VERSION 0.6 ARG BASE_IMAGE=quay.io/kairos/core-opensuse:latest ARG OSBUILDER_IMAGE=quay.io/kairos/osbuilder-tools ARG GO_VERSION=1.18 ARG LUET_VERSION=0.33.0 build-challenger: FROM golang:alpine COPY . /work WORKDIR /work RUN CGO_ENABLED=0 go build -o kcrypt-discovery-challenger ./cmd/discovery SAVE ARTIFACT /work/kcrypt-discovery-challenger AS LOCAL kcrypt-discovery-challenger image: FROM $BASE_IMAGE ARG IMAGE COPY +build-challenger/kcrypt-discovery-challenger /system/discovery/kcrypt-discovery-challenger SAVE IMAGE $IMAGE iso: ARG OSBUILDER_IMAGE ARG ISO_NAME=challenger FROM $OSBUILDER_IMAGE RUN zypper in -y jq docker WORKDIR /build WITH DOCKER --allow-privileged --load $IMAGE=(+image --IMAGE=test) RUN /entrypoint.sh --name $ISO_NAME --debug build-iso --date=false --local test --output /build/ END # See: https://github.com/rancher/elemental-cli/issues/228 RUN sha256sum $ISO_NAME.iso > $ISO_NAME.iso.sha256 SAVE ARTIFACT /build/$ISO_NAME.iso kairos.iso AS LOCAL build/$ISO_NAME.iso SAVE ARTIFACT /build/$ISO_NAME.iso.sha256 kairos.iso.sha256 AS LOCAL build/$ISO_NAME.iso.sha256 test: ARG GO_VERSION FROM golang:$GO_VERSION ENV CGO_ENABLED=0 WORKDIR /work # Cache layer for modules COPY go.mod go.sum ./ RUN go mod download && go mod verify RUN go get github.com/onsi/gomega/... RUN go get github.com/onsi/ginkgo/v2/ginkgo/internal@v2.1.4 RUN go get github.com/onsi/ginkgo/v2/ginkgo/generators@v2.1.4 RUN go get github.com/onsi/ginkgo/v2/ginkgo/labels@v2.1.4 RUN go install -mod=mod github.com/onsi/ginkgo/v2/ginkgo COPY . /work RUN PATH=$PATH:$GOPATH/bin ginkgo run --covermode=atomic --coverprofile=coverage.out -p -r pkg/challenger cmd/discovery/client SAVE ARTIFACT coverage.out AS LOCAL coverage.out # Generic targets # usage e.g. ./earthly.sh +datasource-iso --CLOUD_CONFIG=tests/assets/qrcode.yaml datasource-iso: ARG OSBUILDER_IMAGE ARG CLOUD_CONFIG FROM $OSBUILDER_IMAGE RUN zypper in -y mkisofs WORKDIR /build RUN touch meta-data COPY ${CLOUD_CONFIG} user-data RUN cat user-data RUN mkisofs -output ci.iso -volid cidata -joliet -rock user-data meta-data SAVE ARTIFACT /build/ci.iso iso.iso AS LOCAL build/datasource.iso luet: FROM quay.io/luet/base:$LUET_VERSION SAVE ARTIFACT /usr/bin/luet /luet e2e-tests-image: FROM opensuse/tumbleweed RUN zypper in -y go git qemu-x86 qemu-arm qemu-tools swtpm docker jq docker-compose make glibc libopenssl-devel curl ENV GOPATH="/go" COPY . /test WORKDIR /test RUN go install -mod=mod github.com/onsi/ginkgo/v2/ginkgo RUN go get github.com/onsi/gomega/... RUN go get github.com/onsi/ginkgo/v2/ginkgo/internal@v2.7.1 RUN go get github.com/onsi/ginkgo/v2/ginkgo/generators@v2.7.1 RUN go get github.com/onsi/ginkgo/v2/ginkgo/labels@v2.7.1 IF [ -e /test/build/kairos.iso ] ENV ISO=/test/build/kairos.iso ELSE COPY +iso/kairos.iso kairos.iso ENV ISO=/test/kairos.iso END COPY +luet/luet /usr/bin/luet RUN mkdir -p /etc/luet/repos.conf.d/ RUN luet repo add -y kairos --url quay.io/kairos/packages --type docker RUN LUET_NOLOCK=true luet install -y container/kubectl utils/k3d e2e-tests: FROM +e2e-tests-image WITH DOCKER --allow-privileged RUN ./scripts/e2e-tests.sh END