Skip to content
Snippets Groups Projects
Commit fa19a803 authored by Jean-Michel Picod's avatar Jean-Michel Picod
Browse files

Try with a custom action

parent db3b23cf
No related branches found
No related tags found
No related merge requests found
......@@ -23,11 +23,14 @@ jobs:
run: |
python -m pip install --upgrade pip setuptools wheel
pip install tockloader pylint
- name: Register matcher
run: echo ::add-matcher::./.github/python_matcher.json
- name: Test code with pylint
run: |
echo ::add-matcher::./.github/python_matcher.json
find . -type f -name '*.py' -exec echo PYLINT:\{\} \; -exec pylint --rcfile=.pylintrc --score=n \{\} \;
# find . ! -path "./third_party/*" -type f -name '*.py' -exec echo PYLINT:\{\} \; -exec pylint --rcfile=.pylintrc --score=n \{\} \;
uses: ./github_actions/pylint
with:
config-file: .pylintrc
files: '**/*.py'
exclude-path: third_party
yapf:
runs-on: ubuntu-18.04
......
FROM python:3.7-alpine
RUN apk add --no-cache bash build-base gcc
RUN pip install --upgrade pip
RUN pip install pylint
RUN python --version ; pip --version ; pylint --version
COPY entrypoint.sh /entrypoint.sh
RUN chmod +x /entrypoint.sh
ENTRYPOINT ["/entrypoint.sh"]
---
name: 'Pylint'
description: 'Runs pylint across multiple files/modules'
author: 'Jean-Michel Picod <jmichel@google.com>'
inputs:
config-file:
description: pylintrc configuration file
required: false
files:
description: files, directories, or globs
required: true
ignore-files:
description: files to ignore/exclude
required: false
exclude-path:
description: paths to ignore/exclude
required: false
runs:
using: docker
image: Dockerfile
#!/bin/bash
env
PYLINT_CMD=pylint --score=n${INPUT_CONFIG_FILE:+ --rcfile=${INPUT_CONFIG_FILE}}
EXCLUDE_PATH=${INPUT_EXCLUDE_PATH:-}
EXCLUDE_FILES=${INPUT_EXCLUDE_PATH:-}
SUCCESS=0
for file in ${FILES}
do
fname=$(basename $file)
directory=$(dirname $file)
if [[ "$directory" =~ "^${EXCLUDE_PATH}" ]]
then
echo "Ignoring file '$file' (reason: matching exclude-path parameter)"
continue
fi
if [[ "$fname" =~ "${EXCLUDE_FILES}" ]]
then
echo "Ignoring file '$file' (reason: matching exclude-files parameter)"
continue
fi
# Just to trigger the custom matcher
echo PYLINT:$file
if ! $PYLINT_CMD $file
then
SUCCESS=1
fi
done
exit $SUCCESS
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Please register or to comment