i.landsat.import: Adding tarfile member sanitization to extractall() (CVE-2007-4559 Patch) #3654
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: Build and test | |
on: | |
push: | |
pull_request: | |
schedule: | |
# 01:00 Pacific Time (in UTC), every day (late night PT) | |
- cron: '0 8 * * *' | |
jobs: | |
build: | |
name: ${{ matrix.grass-version }} (Python ${{ matrix.python-version }}) | |
runs-on: ubuntu-20.04 | |
strategy: | |
matrix: | |
# Test with relevant active branches or tags and supported Python | |
# versions, but also limit the number of jobs by, e.g., testing only | |
# every second version or testing older GRASS versions with older Python | |
# only. | |
include: | |
- grass-version: main | |
python-version: "3.8" | |
- grass-version: releasebranch_8_2 | |
python-version: "3.8" | |
fail-fast: false | |
steps: | |
- name: Checkout core | |
uses: actions/checkout@v2 | |
with: | |
repository: OSGeo/grass | |
ref: ${{ matrix.grass-version }} | |
path: grass | |
- name: Checkout addons | |
uses: actions/checkout@v2 | |
with: | |
path: grass-addons | |
- name: Get dependencies | |
run: | | |
sudo apt-get update -y | |
sudo apt-get install -y wget git gawk findutils | |
xargs -a <(awk '! /^ *(#|$)/' "grass-addons/.github/workflows/apt.txt") -r -- \ | |
sudo apt-get install -y --no-install-recommends --no-install-suggests | |
- name: Set up Python ${{ matrix.python-version }} as default Python | |
uses: actions/setup-python@v2 | |
with: | |
python-version: ${{ matrix.python-version }} | |
- name: Get Python dependencies | |
run: | | |
python -m pip install --upgrade pip | |
pip install -r grass-addons/.github/workflows/requirements.txt | |
- name: Create installation directory | |
run: | | |
mkdir $HOME/install | |
- name: Set number of cores for compilation | |
run: | | |
echo "MAKEFLAGS=-j$(nproc)" >> $GITHUB_ENV | |
- name: Set LD_LIBRARY_PATH for GRASS GIS compilation | |
run: | | |
echo "LD_LIBRARY_PATH=$HOME/install/lib" >> $GITHUB_ENV | |
- name: Build GRASS GIS core | |
run: | | |
cd grass | |
../grass-addons/.github/workflows/build_grass.sh $HOME/install | |
- name: Add the bin directory to PATH | |
run: | | |
echo "$HOME/install/bin" >> $GITHUB_PATH | |
- name: Make simple grass command available (not needed in G8) | |
run: | | |
if [ ! -e $HOME/install/bin/grass ] ; then ln -s $HOME/install/bin/grass* $HOME/install/bin/grass ; fi | |
- name: Build addons | |
run: | | |
cd grass-addons/src | |
GRASS_INSTALL=$($HOME/install/bin/grass --config | sed -n '4{p;q}') | |
make MODULE_TOPDIR=$GRASS_INSTALL | |
- name: Get extra Python dependencies | |
run: | | |
export GDAL_VERSION=$(gdal-config --version) | |
pip install -r grass-addons/.github/workflows/extra_requirements.txt | |
- name: Set up R | |
uses: r-lib/actions/setup-r@v1 | |
with: | |
r-version: "4.2.1" | |
- name: Get R dependencies | |
run: | | |
grass-addons/.github/workflows/install_r_packages.R | |
- name: Run tests | |
run: | | |
cd grass-addons/src | |
../.github/workflows/test.sh | |
- name: Make HTML test report available | |
uses: actions/upload-artifact@v2 | |
with: | |
name: testreport-grass-${{ matrix.grass-version }}-python-${{ matrix.python-version }} | |
path: grass-addons/src/testreport | |
retention-days: 3 |