Skip to content

Build git-annex on Windows #1725

Build git-annex on Windows

Build git-annex on Windows #1725

name: Build git-annex on Windows
on:
# Trigger the workflow on pull requests
pull_request:
paths:
- '.github/workflows/build-windows.yaml'
- 'patches/*.patch'
schedule:
- cron: '30 03 * * *'
workflow_dispatch:
inputs:
commitish:
description: The upstream commitish to build
pr:
description: The number of the PR to build
defaults:
run:
shell: bash
env:
LANG: C.utf-8
jobs:
build-package:
runs-on: windows-2019
outputs:
build-version: ${{ steps.build-version.outputs.version }}
steps:
- name: Checkout this repository
uses: actions/checkout@v4
with:
fetch-depth: 0
- name: Create pending PR status
if: github.event.inputs.pr != ''
run: |
.github/workflows/tools/set-pr-status \
"${{ github.event.inputs.pr }}" \
Windows \
build-package \
pending
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
- name: Setup Haskell
uses: haskell/actions/setup@v2
with:
enable-stack: true
stack-no-global: true
- name: Handle long filenames
run: git config --system core.longpaths true
- name: Determine git-annex ref to build
run: |
. .github/workflows/tools/set-build-commit
echo "BUILD_COMMIT=$BUILD_COMMIT" >> "$GITHUB_ENV"
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
INPUT_PR: ${{ github.event.inputs.pr }}
INPUT_COMMITISH: ${{ github.event.inputs.commitish }}
- name: Check out source files
run: |
# The goal here is for $BUILD_COMMIT to be the HEAD (necessary for
# git-annex's version detection to use the correct git commit) with
# the .github/, clients/, and patches/ trees from master — or
# whatever ref is being used as the workflow source — also available.
git reset --soft "$BUILD_COMMIT"
# Avoid checking out unnecessary files with paths that are invalid on
# Windows.
git ls-tree --name-only HEAD | grep -v '^doc$' | xargs git checkout HEAD
git checkout HEAD doc/license ':(glob)doc/*.mdwn' ':(glob)doc/logo*'
git checkout "$GITHUB_SHA" -- .github clients patches
- name: Get build version
id: build-version
run: |
version="$(git describe "$BUILD_COMMIT" | sed -e 's/-/+git/')"
arch=x64
echo "Building $version"
echo "version=${version}_$arch" >> "$GITHUB_OUTPUT"
- name: Apply local patches
run: |
.github/workflows/tools/apply-patches patches ${{ github.event_name }}
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
- name: Download and "install" libmagic for windows
run: |
gh release download -R datalad/file-windows -p file-windows-dist.zip
unzip file-windows-dist.zip
cp libmagic-1.dll libmagic.dll
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
- name: Enable building with magic
run: |
perl -pli -e 's/magicmime: false/magicmime: true/' stack.yaml
- name: Set UPGRADE_LOCATION
run: |
# This tells git-annex where to upgrade itself from.
echo "UPGRADE_LOCATION=http://downloads.kitenet.net/git-annex/windows/current/git-annex-installer.exe" >> "$GITHUB_ENV"
- name: Run stack --version
run: stack --version
- name: stack setup
run: stack setup
# At this point, stack.yaml.lock exists, so we can activate the cache
- name: Enable Stack cache
uses: actions/cache@v4
with:
path: 'C:\sr\snapshots'
key: cache-stack-windows-${{ hashFiles('stack.yaml.lock') }}-${{ hashFiles('git-annex.cabal') }}
restore-keys: |
cache-stack-windows-
- name: Build dependencies
run: stack build --only-dependencies --extra-include-dirs=$PWD --extra-lib-dirs=$PWD
- name: Update version info for git rev being built.
run: |
mkdir -p dist
stack ghc --no-haddock Build/BuildVersion.hs
./Build/BuildVersion > dist/build-version
- name: Build git-annex
run: stack install --no-haddock --local-bin-path .
- name: Build the installer
run: |
stack ghc --no-haddock --package nsis Build/NullSoftInstaller.hs
TMP="$PWD" ./Build/NullSoftInstaller
- name: Add version to installer name
run: |
mv git-annex-installer.exe \
git-annex-installer_"${{ steps.build-version.outputs.version }}".exe
- name: Upload packages
uses: actions/upload-artifact@v4
with:
name: git-annex-windows-installer_${{ steps.build-version.outputs.version }}
path: |
git-annex[-_]*.*
dist/build-version
- name: Create new release
if: github.event.inputs.commitish != ''
run: |
printf '[DEBUG] INPUT_COMMITISH=%b\n' "$INPUT_COMMITISH"
if git rev-parse refs/tags/"$INPUT_COMMITISH" &> /dev/null
then
echo "[INFO] Building a tag; uploading assets to release ..."
echo '[DEBUG] BEGIN gh release list'
gh release list | tee releases.txt | cat -v
echo '[DEBUG] END gh release list'
if grep -q "^$INPUT_COMMITISH\b" releases.txt
then
echo "[INFO] Release already exists; uploading assets"
gh release upload "$INPUT_COMMITISH" git-annex[-_]*.*
else
echo "[INFO] Creating release"
gh release create \
--notes "This is an unofficial release build provided by the DataLad team." \
"$INPUT_COMMITISH" git-annex[-_]*.*
fi
else
echo "[INFO] Not building a tag; no release to make"
fi
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
INPUT_COMMITISH: ${{ github.event.inputs.commitish }}
- name: Set final PR status
if: always() && github.event.inputs.pr != ''
run: |
.github/workflows/tools/set-pr-status \
"${{ github.event.inputs.pr }}" \
Windows \
build-package \
"${{ job.status }}"
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
- name: Send e-mail on failed run
if: failure() && contains(fromJSON('["schedule", "workflow_dispatch"]'), github.event_name)
uses: dawidd6/action-send-mail@v4
with:
server_address: ${{ secrets.NOTIFY_SMTP_HOST }}
server_port: ${{ secrets.NOTIFY_SMTP_PORT }}
username: ${{ secrets.NOTIFY_SMTP_USERNAME }}
password: ${{ secrets.NOTIFY_SMTP_PASSWORD }}
from: GitHub Actions Notifications
to: ${{ secrets.NOTIFY_RECIPIENT }}
subject: '[${{ github.repository }}] Build on Windows failed!'
body: |
A build (via ${{ github.event_name }}) of git-annex for Windows failed!
See <https://github.com/${{ github.repository }}/actions/runs/${{ github.run_id }}> for more information.
test-annex:
runs-on: ${{ matrix.os }}
needs: build-package
strategy:
matrix:
flavor: ["normal", "custom-config1"]
os: [windows-2019]
fail-fast: false
steps:
- name: Checkout this repository
uses: actions/checkout@v4
- name: Create pending PR status
if: github.event.inputs.pr != ''
run: |
.github/workflows/tools/set-pr-status \
"${{ github.event.inputs.pr }}" \
Windows \
"test-annex (${{ matrix.flavor }}, ${{ matrix.os }})" \
pending
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
- name: Download git-annex package
uses: actions/download-artifact@v4
with:
name: git-annex-windows-installer_${{ needs.build-package.outputs.build-version }}
- name: Install git-annex package
shell: powershell
run: |
./git-annex-installer_*.exe /S
- name: Check that magic files are installed
run: |
GIT_ANNEX_PATH="$(type -p git-annex)"
echo "git-annex is at $GIT_ANNEX_PATH"
GIT_ANNEX_DIR="$(dirname "$GIT_ANNEX_PATH")"
ls "$GIT_ANNEX_DIR"/*magic* "$GIT_ANNEX_DIR"/*gnurx*
ls "$GIT_ANNEX_DIR"/../share/misc/*magic*
- name: Check git-annex version for some expected build flags
run: |
# apparently order is not alphabetic, so cannot be relied upon for a single grep
flags=$(git annex version | grep 'build flags:')
for f in Assistant MagicMime Servant S3; do
echo -n "Checking for $f: "
echo "$flags" | grep --color "$f" || { echo "FAIL"; exit 1; }
done
- name: Print git-annex version
run: git annex version
- name: Run tests
run: |
# Do it after we possibly setup HOME
git config --global user.email "[email protected]"
git config --global user.name "GitHub Almighty"
test_opts=( )
case "${{ matrix.flavor }}" in
# For git-annex it causes only few temporary directories to be on the crippled FS,
# while the main ones produced by git annex test reside in CWD, for which we use
# $HOME
custom-config1)
test_opts=( --test-git-config annex.stalldetection=1KB/120s )
;;
*)
;;
esac
cd $HOME
export | grep -e crippledfs || :
timeout 3600 git annex test "${test_opts[@]:-}"
- name: Set final PR status
if: always() && github.event.inputs.pr != ''
run: |
.github/workflows/tools/set-pr-status \
"${{ github.event.inputs.pr }}" \
Windows \
"test-annex (${{ matrix.flavor }}, ${{ matrix.os }})" \
"${{ job.status }}"
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
- name: Send e-mail on failed run
if: failure() && contains(fromJSON('["schedule", "workflow_dispatch"]'), github.event_name)
uses: dawidd6/action-send-mail@v4
with:
server_address: ${{ secrets.NOTIFY_SMTP_HOST }}
server_port: ${{ secrets.NOTIFY_SMTP_PORT }}
username: ${{ secrets.NOTIFY_SMTP_USERNAME }}
password: ${{ secrets.NOTIFY_SMTP_PASSWORD }}
from: GitHub Actions Notifications
to: ${{ secrets.NOTIFY_RECIPIENT }}
subject: '[${{ github.repository }}] Tests of Windows build failed!'
body: |
The tests for a build (via ${{ github.event_name }}) of git-annex for Windows (flavor: ${{ matrix.flavor }}, OS: ${{ matrix.os }}) failed!
See <https://github.com/${{ github.repository }}/actions/runs/${{ github.run_id }}> for more information.
test-datalad:
runs-on: windows-2019
needs: build-package
strategy:
matrix:
version: [master, maint, release]
fail-fast: false
steps:
- name: Checkout this repository
uses: actions/checkout@v4
- name: Create pending PR status
if: github.event.inputs.pr != ''
run: |
.github/workflows/tools/set-pr-status \
"${{ github.event.inputs.pr }}" \
Windows \
"test-datalad (${{ matrix.version }})" \
pending
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
- name: Download git-annex package
uses: actions/download-artifact@v4
with:
name: git-annex-windows-installer_${{ needs.build-package.outputs.build-version }}
- name: Install git-annex package
shell: powershell
run: |
./git-annex-installer_*.exe /S
- name: Define test host alias
shell: cmd
run: |
echo. >> %SYSTEMROOT%\System32\drivers\etc\hosts
echo.127.0.0.1 datalad-test >> %SYSTEMROOT%\System32\drivers\etc\hosts
echo.127.0.0.1 datalad-test2 >> %SYSTEMROOT%\System32\drivers\etc\hosts
- name: OpenSSH server setup
shell: powershell
run: |
mkdir downloads
Invoke-WebRequest -Uri https://github.com/PowerShell/Win32-OpenSSH/releases/download/v7.6.1.0p1-Beta/OpenSSH-Win32.zip -OutFile downloads\openssh.zip
7z x -o"downloads" downloads\openssh.zip
- name: Install
shell: cmd
run: powershell.exe -ExecutionPolicy Bypass -File downloads\OpenSSH-Win32\install-sshd.ps1
- name: Configure service
shell: cmd
run: powershell.exe New-NetFirewallRule -Name sshd -DisplayName 'OpenSSH Server (sshd)' -Enabled True -Direction Inbound -Protocol TCP -Action Allow -LocalPort 22
- name: Keys in default place
run: ssh-keygen -f ~/.ssh/id_rsa -N ""
- name: Authorize access with these keys
shell: cmd
run: |
copy %USERPROFILE%\.ssh\id_rsa.pub %USERPROFILE%\.ssh\authorized_keys
- name: Configure SSH
run: |
(
echo Host localhost
echo StrictHostKeyChecking no
echo Host datalad-test
echo StrictHostKeyChecking no
echo Host datalad-test2
echo StrictHostKeyChecking no
) > "$USERPROFILE"/.ssh/config
- name: Fire up service
run: net start sshd
- name: Test login
run: |
ssh -v localhost exit
ssh datalad-test exit
ssh datalad-test2 exit
- name: Enable SSH tests
run: echo DATALAD_TESTS_SSH=1 >> "$GITHUB_ENV"
- name: Set up environment
run: |
git config --global user.email "[email protected]"
git config --global user.name "GitHub Almighty"
- name: Set up Python 3.9
uses: actions/setup-python@v5
with:
python-version: 3.9
- name: Install ${{ matrix.version }} Datalad
run: |
if [ "${{ matrix.version }}" = "release" ]; then
commitish="$(gh api --jq .tag_name repos/datalad/datalad/releases/latest)"
else
commitish="${{ matrix.version }}"
fi
python -m pip install --upgrade pip
pip install git+https://github.com/datalad/datalad@${commitish}
env:
# Authorize so that we don't run up against low API rate limits
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
- name: Install nose et al (just in case!)
run: pip install nose pytest vcrpy mock
- name: WTF!?
run: datalad wtf
# needed for ssh certs under ubuntu and tox.ini everywhere
- name: Checkout datalad
uses: actions/checkout@v4
with:
repository: datalad/datalad
path: datalad
fetch-depth: 1
- name: Run datalad tests
run: |
mkdir -p __testhome__
cd __testhome__
python -m pytest -c ../datalad/tox.ini -s -v --pyargs datalad
- name: Set final PR status
if: always() && github.event.inputs.pr != ''
run: |
.github/workflows/tools/set-pr-status \
"${{ github.event.inputs.pr }}" \
Windows \
"test-datalad (${{ matrix.version }})" \
"${{ job.status }}"
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
# vim:set et sts=2: