Skip to content

Commit

Permalink
Merge pull request #1 from perlrdf/ci
Browse files Browse the repository at this point in the history
Add GHA CI
  • Loading branch information
zmughal authored Dec 13, 2023
2 parents bf88d18 + 5397258 commit d48adf8
Show file tree
Hide file tree
Showing 3 changed files with 182 additions and 1 deletion.
159 changes: 159 additions & 0 deletions .github/workflows/ci.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,159 @@
name: Run Tests

on:
workflow_dispatch:
push:
branches:
- '*'
tags-ignore:
- '*'
pull_request:
create:

env:
PKG_NAME: Tarql
PKG_UBUNTU: ~
PKG_HOMEBREW: ~
PKG_MSYS2_MINGW64: ~
PKG_MSYS2_MINGW64_DEPS: >-
base-devel
unzip
mingw-w64-x86_64-toolchain
mingw-w64-x86_64-perl
jobs:
notify:
runs-on: ubuntu-latest
continue-on-error: true
if: ${{ always() }}
steps:
- uses: perlrdf/devops/github-actions/irc-notifications@main
with:
target-notifications: true
dist:
if: ${{ github.event_name == 'push' || github.event_name == 'pull_request' }}
name: Make distribution
runs-on: ubuntu-latest
outputs:
min-perl-version: ${{ steps.build-dist.outputs.min-perl-version }}
steps:
- name: Checkout code
uses: actions/checkout@v3
- id: build-dist
uses: perlrdf/devops/github-actions/build-dist@main
with:
dist-perl-deps-develop: strict # Add modules
test:
needs: [ 'dist', 'notify' ]
runs-on: ${{ matrix.os }}
defaults:
run:
# bash on macos and linux
# powershell on windows + strawberry perl
# msys2 {0} on windows + msys2
shell: >-
${{ fromJSON( '["", "bash {0}"]' )[ startsWith(matrix.os, 'ubuntu-' ) || startsWith(matrix.os, 'macos-') ]
}}${{ fromJSON( '["", "powershell {0}"]' )[ startsWith(matrix.os, 'windows-') && matrix.dist == 'strawberry' ]
}}${{ fromJSON( '["", "msys2 {0}"]' )[ startsWith(matrix.os, 'windows-') && matrix.dist == 'msys2' ] }}
strategy:
fail-fast: false
matrix:
os: [ubuntu-latest]
perl-version: ['5.8', '5.20', '5.30', '5.34']
alien-install-type: [ 'share' ]
include:
# Windows strawberry | share
- { perl-version: '5.34' , os: windows-latest , dist: strawberry , alien-install-type: 'share' }
# Windows msys2 | system, share
#- { perl-version: '5.34' , os: windows-latest , dist: msys2 , alien-install-type: 'system' }
#- { perl-version: '5.34' , os: windows-latest , dist: msys2 , alien-install-type: 'share' }
# macOS | system, share
#- { perl-version: '5.34' , os: macos-11 , alien-install-type: 'system' }
- { perl-version: '5.34' , os: macos-11 , alien-install-type: 'share' }
name: Perl ${{ matrix.perl-version }} on ${{ matrix.os }} with install-type ${{ matrix.alien-install-type }}, dist ${{ matrix.dist }}

steps:
- name: Get dist artifact
uses: actions/download-artifact@v3
with:
name: dist

# Setup system package
- name: Setup system ${{ env.PKG_NAME }} (apt)
if: runner.os == 'Linux' && matrix.alien-install-type == 'system'
run: |
sudo apt-get -y update && sudo apt-get install -y ${{ env.PKG_UBUNTU }}
- name: Setup system ${{ env.PKG_NAME }} (homebrew)
if: runner.os == 'macOS' && matrix.alien-install-type == 'system'
run: |
brew install ${{ env.PKG_HOMEBREW }}
- name: Set up MSYS2
uses: msys2/setup-msys2@v2
if: runner.os == 'Windows' && matrix.dist == 'msys2'
with:
update: true
install: ${{ env.PKG_MSYS2_MINGW64_DEPS }}
- name: Set up ${{ env.PKG_NAME }} (MSYS2/MinGW pacman)
if: runner.os == 'Windows' && matrix.dist == 'msys2' && matrix.alien-install-type == 'system'
shell: msys2 {0}
run: |
pacman -S --needed --noconfirm ${{ env.PKG_MSYS2_MINGW64 }}
# Setup Java
- uses: actions/setup-java@v4
with:
distribution: 'temurin'
java-version: '17'

# Setup Perl
- name: Set up perl
uses: shogo82148/actions-setup-perl@v1
if: runner.os != 'Windows'
with:
perl-version: ${{ matrix.perl-version }}
- name: Set up perl (Strawberry)
uses: shogo82148/actions-setup-perl@v1
if: runner.os == 'Windows' && matrix.dist == 'strawberry'
with:
distribution: 'strawberry'

- run: perl -V
- name: Install cpanm
if: runner.os == 'Windows' && matrix.dist == 'msys2'
run:
yes | cpan -T App::cpanminus || true

- name: Install Perl deps
run: |
cpanm --notest --installdeps .
- name: Install share install deps before setting ALIEN_INSTALL_TYPE
if: matrix.alien-install-type == 'share'
run: |
cpanm --notest Net::SSLeay IO::Socket::SSL
- name: Set ALIEN_INSTALL_TYPE
shell: bash
run: |
echo "ALIEN_INSTALL_TYPE=${{ matrix.alien-install-type }}" >> $GITHUB_ENV
- name: Set ALIEN_BUILD_PKG_CONFIG
if: runner.os == 'Windows' && matrix.dist == 'msys2'
run: |
echo "ALIEN_BUILD_PKG_CONFIG=PkgConfig::CommandLine" >> $GITHUB_ENV
- name: Run tests
env:
ALIEN_BUILD_GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
run: |
cpanm --verbose --test-only .
build-status:
runs-on: ubuntu-latest
continue-on-error: true
if: ${{ always() }}
needs: test
steps:
- uses: perlrdf/devops/github-actions/irc-notifications@main
with:
target-build-status: true
needs: ${{ toJSON(needs) }}
21 changes: 21 additions & 0 deletions .github/workflows/issue-notify.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,21 @@
name: issue-notify

on:
issues:
types: [opened,assigned,closed,reopened]
issue_comment:
types: [created]
pull_request:
types: [closed,assigned,converted_to_draft,ready_for_review,review_requested]
pull_request_review:
types: [submitted]

jobs:
notify:
runs-on: ubuntu-latest
continue-on-error: true
if: ${{ always() }}
steps:
- uses: perlrdf/devops/github-actions/irc-notifications@main
with:
target-notifications: true
3 changes: 2 additions & 1 deletion t/alien_tarql.t
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,8 @@ use Alien::Tarql;
alien_diag 'Alien::Tarql';
alien_ok 'Alien::Tarql';

run_ok([ 'tarql', '--version' ])
my $tarql = $^O ne 'MSWin32' ? 'tarql' : 'tarql.bat';
run_ok([ $tarql, '--version' ])
->success
->out_like(qr/tarql:\s+VERSION:\s+([0-9\.]+)/);

Expand Down

0 comments on commit d48adf8

Please sign in to comment.