17 Commits

Author SHA1 Message Date
Daniel Carbone
f0e10f46ff 1.7.1 for windows and some small cleanup (#17)
* 171 for windows and some small cleanup

* startWith -> startsWith
2025-03-31 06:35:49 -05:00
Daniel Carbone
8f16b8ad5b remove ubuntu 20.04 from tests. 2025-03-29 22:45:14 -05:00
Daniel Carbone
26514abd65 always forget the dang readme. 2025-03-29 22:38:50 -05:00
Daniel Carbone
4e6d52de30 bumping default to jq 1.7.1 (#16)
* bumping default to jq 1.7.1
2025-03-29 22:36:49 -05:00
Daniel Carbone
8fd607321d Update README.md
fixing name in badge
2025-03-05 05:17:29 -06:00
Daniel Carbone
e397bd8743 Use sh in action (#15)
Use sh in each action stanza
2024-11-15 05:46:41 -06:00
Daniel Carbone
36b228ee68 Add dependabot for github-actions 2024-11-14 19:47:37 -06:00
Daniel Carbone
d5935278d5 updating examples 2024-11-14 19:41:13 -06:00
Daniel Carbone
ca8101273e trying out posix sh (#14)
* trying out posix sh
2024-11-14 19:38:37 -06:00
Daniel Carbone
de7c0d1fb1 updating matrix versions (#12)
* updating matrix versions
2024-11-14 19:19:41 -06:00
Daniel Carbone
8867ddb478 remove windows gubbins from container tests 2023-11-07 14:50:52 -06:00
Michael Busby
945d84920f Support running action inside containers (#10)
* Add container tests

* Update github actions path to fix container compat
2023-11-07 14:47:46 -06:00
akhil
1090b8bd11 use curl instead of wget to fix failure on macOS runners (#8) 2023-09-29 12:04:15 -05:00
Daniel Carbone
ff922c75b7 Update example-windows.yaml 2023-09-27 19:11:45 -05:00
Daniel Carbone
7f4d6f4833 Update example-macos.yaml 2023-09-27 19:11:32 -05:00
Daniel Carbone
bfb9fa8e7d Update example-linux.yaml 2023-09-27 19:11:18 -05:00
Daniel Carbone
c1548c666d using macos as dl link os prefix in lieu of osx (#7)
* using macos as dl link os prefix in lieu of osx

* probably won't work
2023-09-27 18:12:19 -05:00
9 changed files with 198 additions and 43 deletions

6
.github/dependabot.yml vendored Normal file
View File

@@ -0,0 +1,6 @@
version: 2
updates:
- package-ecosystem: "github-actions"
directory: "/"
schedule:
interval: "weekly"

View File

@@ -19,7 +19,7 @@ jobs:
runs-on: ubuntu-latest runs-on: ubuntu-latest
steps: steps:
- name: 'Setup jq' - name: 'Setup jq'
uses: dcarbone/install-jq-action@v2.0.0 uses: dcarbone/install-jq-action@v3
with: with:
version: '${{ inputs.version }}' version: '${{ inputs.version }}'
force: '${{ inputs.force }}' force: '${{ inputs.force }}'

View File

@@ -19,7 +19,7 @@ jobs:
runs-on: macos-latest runs-on: macos-latest
steps: steps:
- name: 'Setup jq' - name: 'Setup jq'
uses: dcarbone/install-jq-action@v2.0.0 uses: dcarbone/install-jq-action@v3
with: with:
version: '${{ inputs.version }}' version: '${{ inputs.version }}'
force: '${{ inputs.force }}' force: '${{ inputs.force }}'

View File

@@ -19,7 +19,7 @@ jobs:
runs-on: windows-latest runs-on: windows-latest
steps: steps:
- name: 'Setup jq' - name: 'Setup jq'
uses: dcarbone/install-jq-action@v2.0.0 uses: dcarbone/install-jq-action@v3
with: with:
version: '${{ inputs.version }}' version: '${{ inputs.version }}'
force: '${{ inputs.force }}' force: '${{ inputs.force }}'

View File

@@ -23,20 +23,101 @@ jobs:
strategy: strategy:
matrix: matrix:
image: image:
- "ubuntu-latest"
- "ubuntu-22.04" - "ubuntu-22.04"
- "ubuntu-20.04" - "ubuntu-24.04"
- "macos-latest"
- "macos-13" - "macos-13"
- "macos-11" - "macos-14"
- "macos-12" - "macos-15"
- "windows-2022" - "windows-latest"
- "windows-2019" - "windows-2019"
- "windows-2022"
force: force:
- 'true' - 'true'
- 'false' - 'false'
version: version:
- '1.5'
- '1.6'
- '1.7' - '1.7'
- '1.7.1'
include:
- image: "ubuntu-latest"
version: '1.6'
force: true
- image: "ubuntu-latest"
version: '1.6'
force: false
- image: "ubuntu-latest"
version: '1.5'
force: true
- image: "ubuntu-latest"
version: '1.5'
force: false
- image: "ubuntu-22.04"
version: '1.6'
force: true
- image: "ubuntu-22.04"
version: '1.6'
force: false
- image: "ubuntu-22.04"
version: '1.5'
force: true
- image: "ubuntu-22.04"
version: '1.5'
force: false
- image: "ubuntu-24.04"
version: '1.6'
force: true
- image: "ubuntu-24.04"
version: '1.6'
force: false
- image: "ubuntu-24.04"
version: '1.5'
force: true
- image: "ubuntu-24.04"
version: '1.5'
force: false
- image: "windows-latest"
version: '1.6'
force: true
- image: "windows-latest"
version: '1.6'
force: false
- image: "windows-latest"
version: '1.5'
force: true
- image: "windows-latest"
version: '1.5'
force: false
- image: "windows-2019"
version: '1.6'
force: true
- image: "windows-2019"
version: '1.6'
force: false
- image: "windows-2019"
version: '1.5'
force: true
- image: "windows-2019"
version: '1.5'
force: false
- image: "windows-2022"
version: '1.6'
force: true
- image: "windows-2022"
version: '1.6'
force: false
- image: "windows-2022"
version: '1.5'
force: true
- image: "windows-2022"
version: '1.5'
force: false
name: "Test Action - (img: ${{ matrix.image }}; version: ${{ matrix.version }}; force: ${{ matrix.force }})" name: "Test Action - (img: ${{ matrix.image }}; version: ${{ matrix.version }}; force: ${{ matrix.force }})"
runs-on: ${{ matrix.image }} runs-on: ${{ matrix.image }}
steps: steps:
@@ -44,7 +125,7 @@ jobs:
- name: Setup jq - name: Setup jq
id: install-jq id: install-jq
uses: dcarbone/install-jq-action@main uses: ./
with: with:
version: '${{ matrix.version }}' version: '${{ matrix.version }}'
force: '${{ matrix.force }}' force: '${{ matrix.force }}'
@@ -74,15 +155,13 @@ jobs:
if: runner.os == 'Linux' || runner.os == 'macOS' if: runner.os == 'Linux' || runner.os == 'macOS'
# language=sh # language=sh
run: | run: |
_installed='${{ steps.install-jq.outputs.installed }}'
_err=
if [[ '${{ matrix.force }}' == 'true' ]]; then if [[ '${{ matrix.force }}' == 'true' ]]; then
# enabling "force" must result in an install # enabling "force" must result in an install
if [[ '${{ steps.install-jq.outputs.installed }}' != 'true' ]]; then if [[ '${{ steps.install-jq.outputs.installed }}' != 'true' ]]; then
echo 'Unexpected value for "installed":' echo 'Unexpected value for "installed":'
echo 'Expected: "true"' echo 'Expected: "true"'
echo 'Actual: "${{ steps.install-jq.outputs.installed }}"' echo 'Actual: "${{ steps.install-jq.outputs.installed }}"'
_err=1 exit 1
fi fi
else else
if [[ '${{ steps.install-jq.outputs.found }}' == 'true' ]]; then if [[ '${{ steps.install-jq.outputs.found }}' == 'true' ]]; then
@@ -91,7 +170,7 @@ jobs:
echo 'Unexpected value for "installed":' echo 'Unexpected value for "installed":'
echo 'Expected: "false"' echo 'Expected: "false"'
echo 'Actual: "${{ steps.install-jq.outputs.installed }}"' echo 'Actual: "${{ steps.install-jq.outputs.installed }}"'
_err=1 exit 1
fi fi
else else
# if not found, must be installed # if not found, must be installed
@@ -99,12 +178,10 @@ jobs:
echo 'Unexpected value for "installed":' echo 'Unexpected value for "installed":'
echo 'Expected: "true"' echo 'Expected: "true"'
echo 'Actual: "${{ steps.install-jq.outputs.installed }}"' echo 'Actual: "${{ steps.install-jq.outputs.installed }}"'
_err=1 exit 1
fi fi
fi fi
fi fi
if [ -n "${_err}" ]; then exit 1; fi;
- name: Check jq - Windows-ish - name: Check jq - Windows-ish
if: runner.os == 'Windows' && matrix.force == 'true' if: runner.os == 'Windows' && matrix.force == 'true'
@@ -129,7 +206,6 @@ jobs:
$ErrorActionPreference = 'Stop' $ErrorActionPreference = 'Stop'
Set-StrictMode -Version Latest Set-StrictMode -Version Latest
$_installed='${{ steps.install-jq.outputs.installed }}' $_installed='${{ steps.install-jq.outputs.installed }}'
$_err = 0
if ("${{ matrix.force }}" -eq "true") if ("${{ matrix.force }}" -eq "true")
{ {
# enabling "force" must result in an install # enabling "force" must result in an install
@@ -138,7 +214,7 @@ jobs:
Write-Host "Unexpected value for installed" Write-Host "Unexpected value for installed"
Write-Host "Expected: true" Write-Host "Expected: true"
Write-Host "Actual: ${{ steps.install-jq.outputs.installed }}" Write-Host "Actual: ${{ steps.install-jq.outputs.installed }}"
$_err=1 exit 1
} }
} }
else else
@@ -151,7 +227,7 @@ jobs:
Write-Host "Unexpected value for installed" Write-Host "Unexpected value for installed"
Write-Host "Expected: false" Write-Host "Expected: false"
Write-Host "Actual: ${{ steps.install-jq.outputs.installed }}" Write-Host "Actual: ${{ steps.install-jq.outputs.installed }}"
$_err=1 exit 1
} }
} }
else else
@@ -161,11 +237,83 @@ jobs:
Write-Host "Unexpected value for installed" Write-Host "Unexpected value for installed"
Write-Host "Expected: true" Write-Host "Expected: true"
Write-Host "Actual: ${{ steps.install-jq.outputs.installed }}" Write-Host "Actual: ${{ steps.install-jq.outputs.installed }}"
$_err=1
}
}
}
if ("${_err}" -ne 0)
{
exit 1 exit 1
} }
}
}
test-container:
strategy:
matrix:
image:
- "ubuntu-24.04"
- "ubuntu-22.04"
force:
- 'true'
- 'false'
version:
- '1.5'
- '1.6'
- '1.7'
- '1.7.1'
name: "Test Action (Container) - (img: ${{ matrix.image }}; version: ${{ matrix.version }}; force: ${{ matrix.force }})"
runs-on: ${{ matrix.image }}
container:
image: node:20
steps:
- uses: actions/checkout@v4
- name: Setup jq
id: install-jq
uses: ./
with:
version: '${{ matrix.version }}'
force: '${{ matrix.force }}'
- name: Check jq
# language=sh
run: |
_which="$(which jq)"
_vers="$(jq --version)"
if [[ "${_which}" != "$RUNNER_TOOL_CACHE/jq/jq" ]]; then
echo "jq found at unexpected path."
echo " Expected: \"$RUNNER_TOOL_CACHE/jq/jq\""
echo " Actual: \"${_which}\""
exit 1
fi
if [[ "${_vers}" != 'jq-${{ matrix.version }}' ]]; then
echo "jq --version returned unexpected value"
echo ' Expected: "jq-${{ matrix.version }}"'
echo " Actual: \"${_vers}\""
exit 1
fi
- name: Check Outputs
# language=sh
run: |
if [[ '${{ matrix.force }}' == 'true' ]]; then
# enabling "force" must result in an install
if [[ '${{ steps.install-jq.outputs.installed }}' != 'true' ]]; then
echo 'Unexpected value for "installed":'
echo 'Expected: "true"'
echo 'Actual: "${{ steps.install-jq.outputs.installed }}"'
exit 1
fi
else
if [[ '${{ steps.install-jq.outputs.found }}' == 'true' ]]; then
# if found, must not be installed without force
if [[ '${{ steps.install-jq.outputs.installed }}' != 'false' ]]; then
echo 'Unexpected value for "installed":'
echo 'Expected: "false"'
echo 'Actual: "${{ steps.install-jq.outputs.installed }}"'
exit 1
fi
else
# if not found, must be installed
if [[ '${{ steps.install-jq.outputs.installed }}' != 'true' ]]; then
echo 'Unexpected value for "installed":'
echo 'Expected: "true"'
echo 'Actual: "${{ steps.install-jq.outputs.installed }}"'
exit 1
fi
fi
fi

View File

@@ -1,10 +1,11 @@
# install-jq-action # install-jq-action
Multiplatform [jq](https://github.com/stedolan/jq) installer action Multiplatform [jq](https://github.com/stedolan/jq) installer action
[![Tests - Setup jq Action](https://github.com/dcarbone/install-jq-action/actions/workflows/tests.yaml/badge.svg)](https://github.com/dcarbone/install-jq-action/actions/workflows/tests.yaml) [![Tests - Install jq Action](https://github.com/dcarbone/install-jq-action/actions/workflows/tests.yaml/badge.svg)](https://github.com/dcarbone/install-jq-action/actions/workflows/tests.yaml)
This action is tested against the following versions of JQ: This action is tested against the following versions of JQ:
- [1.7.1](https://github.com/jqlang/jq/releases/tag/jq-1.7.1)
- [1.7](https://github.com/jqlang/jq/releases/tag/jq-1.7) - [1.7](https://github.com/jqlang/jq/releases/tag/jq-1.7)
- [1.6](https://github.com/jqlang/jq/releases/tag/jq-1.6) - [1.6](https://github.com/jqlang/jq/releases/tag/jq-1.6)
- [1.5](https://github.com/jqlang/jq/releases/tag/jq-1.5) - [1.5](https://github.com/jqlang/jq/releases/tag/jq-1.5)
@@ -29,7 +30,7 @@ This action is tested against the following versions of JQ:
version: version:
required: false required: false
description: "Version of jq to install" description: "Version of jq to install"
default: "1.7" default: "1.7.1"
``` ```
This must be a version with a [corresponding release](https://github.com/stedolan/jq/releases). This must be a version with a [corresponding release](https://github.com/stedolan/jq/releases).

View File

@@ -9,8 +9,8 @@ branding:
inputs: inputs:
version: version:
required: false required: false
description: "Version of jq to install" description: "Version of jq to install."
default: "1.7" default: "1.7.1"
force: force:
required: false required: false
description: "If 'true', does not check for existing jq installation before continuing." description: "If 'true', does not check for existing jq installation before continuing."
@@ -30,7 +30,7 @@ runs:
- name: 'Check for jq - Unix-ish' - name: 'Check for jq - Unix-ish'
id: jq-check-unix id: jq-check-unix
if: (runner.os == 'Linux' || runner.os == 'macOS') if: (runner.os == 'Linux' || runner.os == 'macOS')
shell: bash +e {0} shell: sh +e {0}
# language=sh # language=sh
run: | run: |
_jq_bin="$(which jq)" _jq_bin="$(which jq)"
@@ -41,20 +41,20 @@ runs:
fi fi
- name: 'Install jq - Unix-ish non-1.7' - name: 'Install jq - Unix-ish non-1.7'
if: (runner.os == 'Linux' || runner.os == 'macOS') && (inputs.version == '1.5' || inputs.version == '1.6') && (steps.jq-check-unix.outputs.found == 'false' || inputs.force == 'true') if: (runner.os == 'Linux' || runner.os == 'macOS') && (startsWith(inputs.version, '1.5') || startsWith(inputs.version, '1.6')) && (steps.jq-check-unix.outputs.found == 'false' || inputs.force == 'true')
shell: bash shell: sh
env: env:
JQ_VERSION: '${{ inputs.version }}' JQ_VERSION: '${{ inputs.version }}'
# language=sh # language=sh
run: ${{ github.action_path }}/scripts/unixish.sh run: ${GITHUB_ACTION_PATH}/scripts/unixish.sh
- name: 'Install jq - Unix-ish 1.7' - name: 'Install jq - Unix-ish 1.7'
if: (runner.os == 'Linux' || runner.os == 'macOS') && inputs.version == '1.7' && (steps.jq-check-unix.outputs.found == 'false' || inputs.force == 'true') if: (runner.os == 'Linux' || runner.os == 'macOS') && startsWith(inputs.version, '1.7') && (steps.jq-check-unix.outputs.found == 'false' || inputs.force == 'true')
shell: bash shell: sh
env: env:
JQ_VERSION: '${{ inputs.version }}' JQ_VERSION: '${{ inputs.version }}'
# language=sh # language=sh
run: ${{ github.action_path }}/scripts/unixish-17.sh run: ${GITHUB_ACTION_PATH}/scripts/unixish-17.sh
- name: 'Check for jq - Windows-ish' - name: 'Check for jq - Windows-ish'
id: jq-check-windows id: jq-check-windows
@@ -72,14 +72,14 @@ runs:
} }
- name: 'Install jq - Windows-ish non-1.7' - name: 'Install jq - Windows-ish non-1.7'
if: runner.os == 'Windows' && (inputs.version == '1.5' || inputs.version == '1.6') && (steps.jq-check-windows.outputs.found == 'false' || inputs.force == 'true') if: runner.os == 'Windows' && (startsWith(inputs.version, '1.5') || startsWith(inputs.version, '1.6')) && (steps.jq-check-windows.outputs.found == 'false' || inputs.force == 'true')
shell: powershell shell: powershell
env: env:
JQ_VERSION: '${{ inputs.version }}' JQ_VERSION: '${{ inputs.version }}'
run: ${{ github.action_path }}\scripts\windowsish.ps1 run: ${{ github.action_path }}\scripts\windowsish.ps1
- name: 'Install jq - Windows-ish 1.7' - name: 'Install jq - Windows-ish 1.7'
if: runner.os == 'Windows' && inputs.version == '1.7' && (steps.jq-check-windows.outputs.found == 'false' || inputs.force == 'true') if: runner.os == 'Windows' && startsWith(inputs.version, '1.7') && (steps.jq-check-windows.outputs.found == 'false' || inputs.force == 'true')
shell: powershell shell: powershell
env: env:
JQ_VERSION: '${{ inputs.version }}' JQ_VERSION: '${{ inputs.version }}'

View File

@@ -1,4 +1,4 @@
#!/usr/bin/env bash #!/bin/sh
set -e set -e
@@ -23,7 +23,7 @@ case $RUNNER_OS in
_os='linux' _os='linux'
;; ;;
macOS) macOS)
_os='osx' _os='macos'
;; ;;
*) *)
@@ -73,7 +73,7 @@ echo '::group::Downloading jq'
echo "Src: ${_dl_url}" echo "Src: ${_dl_url}"
echo "Dst: ${_dl_path}" echo "Dst: ${_dl_path}"
wget -O- "${_dl_url}" > "${_dl_path}" curl -L "${_dl_url}" -o "${_dl_path}"
echo '::endgroup::' echo '::endgroup::'

View File

@@ -1,4 +1,4 @@
#!/usr/bin/env bash #!/bin/sh
set -e set -e
@@ -54,7 +54,7 @@ esac
# determine binary name # determine binary name
if [[ "${_os}" == "linux" ]]; then if [ "${_os}" = "linux" ]; then
case "${_arch}" in case "${_arch}" in
'386') '386')
_bin_name="jq-linux32" _bin_name="jq-linux32"
@@ -93,7 +93,7 @@ echo '::group::Downloading jq'
echo "Src: ${_dl_url}" echo "Src: ${_dl_url}"
echo "Dst: ${_dl_path}" echo "Dst: ${_dl_path}"
wget -O- "${_dl_url}" > "${_dl_path}" curl -L "${_dl_url}" -o "${_dl_path}"
echo '::endgroup::' echo '::endgroup::'