actions-setup/Earthfile
2024-12-09 07:12:50 +00:00

149 lines
5.0 KiB
Plaintext

VERSION 0.8
PROJECT earthly-technologies/core
ARG EARTHLY_LIB_VERSION=3.0.1
IMPORT github.com/earthly/lib/utils/git:$EARTHLY_LIB_VERSION AS git
npm-base:
FROM node:21.7-alpine3.19
COPY ./package.json ./
COPY ./package-lock.json ./
RUN npm install
# Output these back in case npm install changes them.
SAVE ARTIFACT package.json AS LOCAL ./package.json
SAVE ARTIFACT package-lock.json AS LOCAL ./package-lock.json
code:
FROM +npm-base
WORKDIR /code
COPY package.json package-lock.json .
RUN npm ci
COPY --dir src .
lint:
FROM +code
COPY .eslintrc.cjs .
RUN npm run-script lint
compile:
FROM +code
WORKDIR /code
RUN npm ci
COPY tsconfig.json .
RUN npm run-script package
SAVE ARTIFACT dist AS LOCAL dist
SAVE ARTIFACT node_modules AS LOCAL node_modules
test-compile-was-run:
FROM alpine:3.21
COPY dist /from-git
COPY +compile/dist /from-compile
RUN diff -r /from-git /from-compile >/dev/null || (echo "dist and +compile/dist are different, did you forget to run earthly +compile?" && exit 1)
test:
FROM +code
COPY tsconfig.json .
COPY vite.config.ts vitest.config.ts .
RUN npm test
test-run:
FROM +npm-base
COPY --dir +compile/dist .
ENV RUNNER_TOOL_CACHE=/tmp/cache-dir
RUN node dist/setup/index.js | tee output
RUN ! grep 'Found tool in cache' output
RUN cat output | grep '^::add-path::' | sed 's/::add-path:://g' > earthly-path
RUN test "$(cat earthly-path)" = "/root/.earthly/bin"
# [a-zA-Z0-9]* attempt to match a commit hash
RUN export PATH="$(cat earthly-path):$PATH" && earthly --version | tee version.output
RUN grep '^earthly version v.*linux/amd64; Alpine Linux' version.output
# validate cache was used
RUN node dist/setup/index.js | tee output2
RUN grep 'Found tool in cache' output2
lint-newline:
FROM alpine:3.21
WORKDIR /everything
COPY . .
# test that line endings are unix-style
RUN set -e; \
code=0; \
for f in $(find . -type f \( -iname '*.ts' -o -iname 'Earthfile' \) | grep -v node_modules); do \
if ! dos2unix < "$f" | cmp - "$f"; then \
echo "$f contains windows-style newlines and must be converted to unix-style (use dos2unix to fix)"; \
code=1; \
fi; \
done; \
exit $code
# test file ends with a single newline
RUN set -e; \
code=0; \
for f in $(find . -type f \( -iname '*.ts' -o -iname 'Earthfile' \) | grep -v node_modules); do \
if [ "$(tail -c 1 $f)" != "$(printf '\n')" ]; then \
echo "$f does not end with a newline"; \
code=1; \
fi; \
done; \
exit $code
# check for files with trailing newlines
RUN set -e; \
code=0; \
for f in $(find . -type f \( -iname '*.ts' -o -iname 'Earthfile' \) | grep -v node_modules); do \
if [ "$(tail -c 2 $f)" == "$(printf '\n\n')" ]; then \
echo "$f has trailing newlines"; \
code=1; \
fi; \
done; \
exit $code
update-dist-for-renovate:
FROM alpine/git
RUN git config --global user.name "renovate[bot]" && \
git config --global user.email "renovate[bot]@users.noreply.github.com" && \
git config --global url."git@github.com:".insteadOf "https://github.com/"
ARG git_repo="earthly/actions-setup"
ARG git_url="git@github.com:$git_repo"
ARG SECRET_PATH=littleredcorvette-id_rsa
DO --pass-args git+DEEP_CLONE --GIT_URL=$git_url --SECRET_PATH=$SECRET_PATH
ARG EARTHLY_GIT_BRANCH
LET branch=$EARTHLY_GIT_BRANCH
RUN --mount=type=secret,id=$SECRET_PATH,mode=0400,target=/root/.ssh/id_rsa \
git checkout $branch
COPY --dir +compile/dist .
RUN git add dist && git commit -m "update dist for Renovate" || echo nothing to commit
RUN --push --mount=type=secret,id=$SECRET_PATH,mode=0400,target=/root/.ssh/id_rsa \
git push origin $branch
merge-release-to-major-branch:
FROM alpine/git
RUN git config --global user.name "littleredcorvette" && \
git config --global user.email "littleredcorvette@users.noreply.github.com" && \
git config --global url."git@github.com:".insteadOf "https://github.com/"
ARG git_repo="earthly/actions-setup"
ARG git_url="git@github.com:$git_repo"
ARG SECRET_PATH=littleredcorvette-id_rsa
DO --pass-args git+DEEP_CLONE --GIT_URL=$git_url --SECRET_PATH=$SECRET_PATH
ARG --required RELEASE_TAG
LET tag=${RELEASE_TAG#refs/tags/}
LET major=$tag
SET major=$(echo ${major%.*})
SET major=$(echo ${major%.*})
RUN --mount=type=secret,id=$SECRET_PATH,mode=0400,target=/root/.ssh/id_rsa \
git checkout $major && git merge --ff-only $tag
RUN --push --mount=type=secret,id=$SECRET_PATH,mode=0400,target=/root/.ssh/id_rsa \
git push origin $major
all:
BUILD +lint
BUILD +lint-newline
BUILD +compile
BUILD +test
BUILD +test-run
BUILD +test-compile-was-run