12 Commits
v2.1.0 ... v3

Author SHA1 Message Date
Daniel Carbone
b7ef57d46e Adding 1.8.0 stuff (#20) 2025-06-18 18:11:24 -05:00
Nikolay Ermolovich
2eac2baa38 case sensitive is off (#19) 2025-06-18 09:21:03 -05:00
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
9 changed files with 139 additions and 61 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

@@ -7,7 +7,7 @@ on:
type: string
required: false
description: 'Version of jq to install'
default: '1.7'
default: '1.7.1'
force:
type: boolean
required: false
@@ -19,7 +19,7 @@ jobs:
runs-on: ubuntu-latest
steps:
- name: 'Setup jq'
uses: dcarbone/install-jq-action@v2
uses: dcarbone/install-jq-action@v3
with:
version: '${{ inputs.version }}'
force: '${{ inputs.force }}'

View File

@@ -7,7 +7,7 @@ on:
type: string
required: false
description: 'Version of jq to install'
default: '1.7'
default: '1.7.1'
force:
type: boolean
required: false
@@ -19,7 +19,7 @@ jobs:
runs-on: macos-latest
steps:
- name: 'Setup jq'
uses: dcarbone/install-jq-action@v2
uses: dcarbone/install-jq-action@v3
with:
version: '${{ inputs.version }}'
force: '${{ inputs.force }}'

View File

@@ -7,7 +7,7 @@ on:
type: string
required: false
description: 'Version of jq to install'
default: '1.7'
default: '1.7.1'
force:
type: boolean
required: false
@@ -19,7 +19,7 @@ jobs:
runs-on: windows-latest
steps:
- name: 'Setup jq'
uses: dcarbone/install-jq-action@v2
uses: dcarbone/install-jq-action@v3
with:
version: '${{ inputs.version }}'
force: '${{ inputs.force }}'

View File

@@ -23,20 +23,102 @@ jobs:
strategy:
matrix:
image:
- "ubuntu-latest"
- "ubuntu-22.04"
- "ubuntu-20.04"
- "ubuntu-24.04"
- "macos-latest"
- "macos-13"
- "macos-11"
- "macos-12"
- "windows-2022"
- "macos-14"
- "macos-15"
- "windows-latest"
- "windows-2019"
- "windows-2022"
force:
- 'true'
- 'false'
version:
- '1.5'
- '1.6'
- '1.7'
- '1.7.1'
- '1.8.0'
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 }})"
runs-on: ${{ matrix.image }}
steps:
@@ -74,15 +156,13 @@ jobs:
if: runner.os == 'Linux' || runner.os == 'macOS'
# language=sh
run: |
_installed='${{ steps.install-jq.outputs.installed }}'
_err=
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 }}"'
_err=1
exit 1
fi
else
if [[ '${{ steps.install-jq.outputs.found }}' == 'true' ]]; then
@@ -91,7 +171,7 @@ jobs:
echo 'Unexpected value for "installed":'
echo 'Expected: "false"'
echo 'Actual: "${{ steps.install-jq.outputs.installed }}"'
_err=1
exit 1
fi
else
# if not found, must be installed
@@ -99,12 +179,10 @@ jobs:
echo 'Unexpected value for "installed":'
echo 'Expected: "true"'
echo 'Actual: "${{ steps.install-jq.outputs.installed }}"'
_err=1
exit 1
fi
fi
fi
if [ -n "${_err}" ]; then exit 1; fi;
- name: Check jq - Windows-ish
if: runner.os == 'Windows' && matrix.force == 'true'
@@ -129,7 +207,6 @@ jobs:
$ErrorActionPreference = 'Stop'
Set-StrictMode -Version Latest
$_installed='${{ steps.install-jq.outputs.installed }}'
$_err = 0
if ("${{ matrix.force }}" -eq "true")
{
# enabling "force" must result in an install
@@ -138,7 +215,7 @@ jobs:
Write-Host "Unexpected value for installed"
Write-Host "Expected: true"
Write-Host "Actual: ${{ steps.install-jq.outputs.installed }}"
$_err=1
exit 1
}
}
else
@@ -151,7 +228,7 @@ jobs:
Write-Host "Unexpected value for installed"
Write-Host "Expected: false"
Write-Host "Actual: ${{ steps.install-jq.outputs.installed }}"
$_err=1
exit 1
}
}
else
@@ -161,20 +238,16 @@ jobs:
Write-Host "Unexpected value for installed"
Write-Host "Expected: true"
Write-Host "Actual: ${{ steps.install-jq.outputs.installed }}"
$_err=1
exit 1
}
}
}
if ("${_err}" -ne 0)
{
exit 1
}
test-container:
strategy:
matrix:
image:
- "ubuntu-24.04"
- "ubuntu-22.04"
- "ubuntu-20.04"
force:
- 'true'
- 'false'
@@ -182,10 +255,12 @@ jobs:
- '1.5'
- '1.6'
- '1.7'
- '1.7.1'
- '1.8.0'
name: "Test Action (Container) - (img: ${{ matrix.image }}; version: ${{ matrix.version }}; force: ${{ matrix.force }})"
runs-on: ${{ matrix.image }}
container:
image: node:18.12.1
image: node:20
steps:
- uses: actions/checkout@v4
@@ -199,35 +274,31 @@ jobs:
- name: Check jq
# language=sh
run: |
_err=
_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}\""
_err=1
exit 1
fi
if [[ "${_vers}" != 'jq-${{ matrix.version }}' ]]; then
echo "jq --version returned unexpected value"
echo ' Expected: "jq-${{ matrix.version }}"'
echo " Actual: \"${_vers}\""
_err=1
exit 1
fi
if [ -n "${_err}" ]; then exit 1; fi;
- name: Check Outputs
# language=sh
run: |
_installed='${{ steps.install-jq.outputs.installed }}'
_err=
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 }}"'
_err=1
exit 1
fi
else
if [[ '${{ steps.install-jq.outputs.found }}' == 'true' ]]; then
@@ -236,7 +307,7 @@ jobs:
echo 'Unexpected value for "installed":'
echo 'Expected: "false"'
echo 'Actual: "${{ steps.install-jq.outputs.installed }}"'
_err=1
exit 1
fi
else
# if not found, must be installed
@@ -244,8 +315,7 @@ jobs:
echo 'Unexpected value for "installed":'
echo 'Expected: "true"'
echo 'Actual: "${{ steps.install-jq.outputs.installed }}"'
_err=1
exit 1
fi
fi
fi
if [ -n "${_err}" ]; then exit 1; fi;

View File

@@ -1,10 +1,12 @@
# install-jq-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:
- [1.8.0](https://github.com/jqlang/jq/releases/tag/jq-1.8.0)
- [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.6](https://github.com/jqlang/jq/releases/tag/jq-1.6)
- [1.5](https://github.com/jqlang/jq/releases/tag/jq-1.5)
@@ -29,7 +31,7 @@ This action is tested against the following versions of JQ:
version:
required: false
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).

View File

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

View File

@@ -1,4 +1,4 @@
#!/usr/bin/env bash
#!/bin/sh
set -e
@@ -19,10 +19,10 @@ _dl_path=
_dl_url=
case $RUNNER_OS in
Linux)
[Ll]inux)
_os='linux'
;;
macOS)
mac[Oo][Ss])
_os='macos'
;;

View File

@@ -1,4 +1,4 @@
#!/usr/bin/env bash
#!/bin/sh
set -e
@@ -17,10 +17,10 @@ _dl_path=
_dl_url=
case $RUNNER_OS in
Linux)
[Ll]inux)
_os='linux'
;;
macOS)
mac[Oo][Ss])
_os='osx'
;;
@@ -54,7 +54,7 @@ esac
# determine binary name
if [[ "${_os}" == "linux" ]]; then
if [ "${_os}" = "linux" ]; then
case "${_arch}" in
'386')
_bin_name="jq-linux32"