mirror of
https://github.com/mandiant/capa.git
synced 2025-12-08 05:40:36 -08:00
Run `isort` and `black` in the hooks. Run them with the `--check` option to not modify files which could be committed by accident. Note that the changes in `.gitignore` are not needed as `.log` is already excluded in the Django's section. We add those file to this section in case `.log` is removed in the future.
86 lines
2.4 KiB
Bash
Executable File
86 lines
2.4 KiB
Bash
Executable File
#!/usr/bin/env bash
|
|
# Copyright (C) 2020 FireEye, Inc. All Rights Reserved.
|
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
# you may not use this file except in compliance with the License.
|
|
# You may obtain a copy of the License at: [package root]/LICENSE.txt
|
|
# Unless required by applicable law or agreed to in writing, software distributed under the License
|
|
# is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
# See the License for the specific language governing permissions and limitations under the License.
|
|
#
|
|
# doesn't matter if this gets repeated later on in a hooks file
|
|
|
|
# Use a console with emojis support for a better experience
|
|
|
|
# Stash uncommited changes
|
|
MSG="pre-push-$(date +%s)";
|
|
git stash push -kqum "$MSG";
|
|
STASH_LIST=$(git stash list);
|
|
if [[ "$STASH_LIST" == *"$MSG"* ]]; then
|
|
echo "Uncommited changes stashed with message '$MSG', if you abort before they are restored run \`git stash pop\`";
|
|
fi
|
|
|
|
restore_stashed() {
|
|
if [[ "$STASH_LIST" == *"$MSG"* ]]; then
|
|
git stash pop -q --index;
|
|
echo "Stashed changes '$MSG' restored";
|
|
fi
|
|
}
|
|
|
|
python_3() {
|
|
case "$(uname -s)" in
|
|
CYGWIN*|MINGW32*|MSYS*|MINGW*)
|
|
py -3 -m $1 > $2 2>&1;;
|
|
*)
|
|
python3 -m $1 > $2 2>&1;;
|
|
esac
|
|
}
|
|
|
|
# Run isort and print state
|
|
python_3 'isort --profile black --length-sort --line-width 120 -c .' 'isort-output.log';
|
|
if [ $? == 0 ]; then
|
|
echo 'isort succeeded!! 💖';
|
|
else
|
|
echo 'isort failed 😭';
|
|
echo 'Check isort-output.log for details';
|
|
restore_stashed;
|
|
exit 1;
|
|
fi
|
|
|
|
# Run black and print state
|
|
python_3 'black -l 120 --check .' 'black-output.log';
|
|
if [ $? == 0 ]; then
|
|
echo 'black succeeded!! 💝';
|
|
else
|
|
echo 'black failed 😭';
|
|
echo 'Check black-output.log for details';
|
|
restore_stashed;
|
|
exit 2;
|
|
fi
|
|
|
|
# Run rule linter and print state
|
|
python ./scripts/lint.py ./rules/ > rule-linter-output.log 2>&1;
|
|
if [ $? == 0 ]; then
|
|
echo 'Rule linter succeeded!! 💘';
|
|
else
|
|
echo 'Rule linter failed 😭';
|
|
echo 'Check rule-linter-output.log for details';
|
|
restore_stashed;
|
|
exit 3;
|
|
fi
|
|
|
|
# Run tests
|
|
echo 'Running tests, please wait ⌛';
|
|
pytest tests/ --maxfail=1;
|
|
if [ $? == 0 ]; then
|
|
echo 'Tests succeed!! 🎉';
|
|
else
|
|
echo 'Tests failed 😓 PUSH ABORTED';
|
|
echo 'Run `pytest -v --cov=capa test/` if you need more details';
|
|
restore_stashed;
|
|
exit 4;
|
|
fi
|
|
|
|
echo 'PUSH SUCCEEDED 🎉🎉';
|
|
|
|
restore_stashed;
|