ci: Refactor timelord action to use git-warp-time fallback

Updates the timelord action to fall back to git-warp-time when the cache
is completely empty, enabling timestamp restoration even on fresh builds.
Simplifies the interface by making inputs optional with sensible defaults
and adds Docker integration via buildkit-cache-dance.
This commit is contained in:
Tom Foster 2025-09-08 04:32:23 +01:00
commit 45adfabbcd
3 changed files with 57 additions and 33 deletions

View file

@ -1,46 +1,64 @@
name: timelord name: timelord
description: | description: |
Use timelord to set file timestamps Use timelord to set file timestamps with git-warp-time fallback for cache misses
inputs: inputs:
key: key:
description: | description: |
The key to use for caching the timelord data. The key to use for caching the timelord data.
This should be unique to the repository and the runner. required: false
required: true default: ''
default: timelord-v0
path: path:
description: | description: |
The path to the directory to be timestamped. The path to the directory to be timestamped.
This should be the root of the repository. required: false
required: true default: ''
default: .
outputs:
database-path:
description: Path to timelord database
value: '${{ env.TIMELORD_CACHE_PATH }}'
runs: runs:
using: composite using: composite
steps: steps:
- name: Cache timelord-cli installation - name: Set defaults
id: cache-timelord-bin
uses: actions/cache@v3
with:
path: ~/.cargo/bin/timelord
key: timelord-cli-v3.0.1
- name: Install timelord-cli
uses: https://github.com/cargo-bins/cargo-binstall@main
if: steps.cache-timelord-bin.outputs.cache-hit != 'true'
- run: cargo binstall timelord-cli@3.0.1
shell: bash shell: bash
if: steps.cache-timelord-bin.outputs.cache-hit != 'true' run: |
echo "TIMELORD_KEY=${{ inputs.key || format('timelord-v1-{0}-{1}', github.repository, hashFiles('**/*.rs', '**/Cargo.toml', '**/Cargo.lock')) }}" >> $GITHUB_ENV
echo "TIMELORD_PATH=${{ inputs.path || '.' }}" >> $GITHUB_ENV
echo "TIMELORD_CACHE_PATH=$HOME/.cache/timelord" >> $GITHUB_ENV
- name: Load timelord files - name: Install timelord-cli and git-warp-time
uses: actions/cache/restore@v3 uses: taiki-e/install-action@v2
with: with:
path: /timelord/ tool: git-warp-time,timelord-cli@3.0.1
key: ${{ inputs.key }}
- name: Run timelord to set timestamps - name: Restore timelord cache with fallbacks
id: timelord-restore
uses: actions/cache/restore@v4
with:
path: ${{ env.TIMELORD_CACHE_PATH }}
key: ${{ env.TIMELORD_KEY }}
restore-keys: |
timelord-v1-${{ github.repository }}-
- name: Initialize timestamps on complete cache miss
if: steps.timelord-restore.outputs.cache-hit != 'true'
shell: bash shell: bash
run: timelord sync --source-dir ${{ inputs.path }} --cache-dir /timelord/ run: |
- name: Save timelord echo "Complete timelord cache miss - running git-warp-time"
uses: actions/cache/save@v3 git fetch --unshallow
git-warp-time --quiet ${{ env.TIMELORD_PATH }}
echo "Git timestamps restored"
- name: Run timelord sync
shell: bash
run: |
mkdir -p ${{ env.TIMELORD_CACHE_PATH }}
timelord sync --source-dir ${{ env.TIMELORD_PATH }} --cache-dir ${{ env.TIMELORD_CACHE_PATH }}
- name: Save updated timelord cache immediately
uses: actions/cache/save@v4
with: with:
path: /timelord/ path: ${{ env.TIMELORD_CACHE_PATH }}
key: ${{ inputs.key }} key: ${{ env.TIMELORD_KEY }}

View file

@ -150,10 +150,7 @@ jobs:
echo "Commit timestamp: $timestamp" echo "Commit timestamp: $timestamp"
- uses: ./.forgejo/actions/timelord - uses: ./.forgejo/actions/timelord
if: ${{ env.BUILDKIT_ENDPOINT == '' }} id: timelord
with:
key: timelord-v0
path: .
- name: Cache Rust registry - name: Cache Rust registry
if: ${{ env.BUILDKIT_ENDPOINT == '' }} if: ${{ env.BUILDKIT_ENDPOINT == '' }}
@ -202,7 +199,8 @@ jobs:
"id": "cargo-target-${{ matrix.target_cpu }}-${{ matrix.slug }}-${{ matrix.profile }}" "id": "cargo-target-${{ matrix.target_cpu }}-${{ matrix.slug }}-${{ matrix.profile }}"
}, },
"var-cache-apt-${{ matrix.slug }}": "/var/cache/apt", "var-cache-apt-${{ matrix.slug }}": "/var/cache/apt",
"var-lib-apt-${{ matrix.slug }}": "/var/lib/apt" "var-lib-apt-${{ matrix.slug }}": "/var/lib/apt",
"${{ steps.timelord.outputs.database-path }}": "/root/.cache/timelord"
} }
skip-extraction: ${{ steps.cache.outputs.cache-hit }} skip-extraction: ${{ steps.cache.outputs.cache-hit }}

View file

@ -133,6 +133,14 @@ FROM toolchain AS builder
# Get source # Get source
COPY . . COPY . .
# Restore timestamps from timelord cache if available
RUN if [ -f /root/.cache/timelord/timelord.db ]; then \
echo "Restoring timestamps from timelord cache"; \
timelord sync --source-dir /app --cache-dir /root/.cache/timelord; \
else \
echo "No timelord cache found, timestamps will be build time"; \
fi
ARG TARGETPLATFORM ARG TARGETPLATFORM
# Verify environment configuration # Verify environment configuration