2019-07-31 16:54:26 +02:00
|
|
|
#!/usr/bin/env bash
|
2019-06-30 13:05:04 +02:00
|
|
|
|
|
|
|
OUTPUT_REGULAR=reports/lint-regular-report.txt
|
|
|
|
OUTPUT_LEGACY=reports/lint-legacy-report.txt
|
|
|
|
OUTPUT_FINAL=reports/lint-common-report.txt
|
|
|
|
|
|
|
|
OUTPUT_MR=reports/lint-mr-report.txt
|
|
|
|
|
|
|
|
LINE_CHANGES=changed-lines.txt
|
|
|
|
|
|
|
|
is_empty() {
|
|
|
|
(! grep -q . $1)
|
|
|
|
}
|
|
|
|
|
|
|
|
run_eslint() {
|
|
|
|
ARGS_LEGACY='--config lint/eslintrc-legacy.json'
|
|
|
|
|
|
|
|
local extra_args=ARGS_$1
|
2019-08-14 13:14:23 +02:00
|
|
|
local output_var=OUTPUT_$1
|
|
|
|
local output=${!output_var}
|
|
|
|
|
|
|
|
# ensure output exists even if eslint doesn't report any errors
|
|
|
|
mkdir -p $(dirname $output)
|
|
|
|
touch $output
|
|
|
|
|
|
|
|
eslint -f unix ${!extra_args} -o $output js
|
2019-06-30 13:05:04 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
list_commit_range_additions() {
|
|
|
|
# Turn raw context-less git-diff into a list of
|
|
|
|
# filename:lineno pairs of new (+) lines
|
|
|
|
git diff -U0 "$@" -- js |
|
|
|
|
awk '
|
|
|
|
BEGIN { file=""; }
|
|
|
|
/^+++ b/ { file=substr($0,7); }
|
|
|
|
/^@@ / {
|
|
|
|
len = split($3,a,",")
|
|
|
|
start=a[1]
|
|
|
|
count=(len > 1) ? a[2] : 1
|
|
|
|
|
|
|
|
for (line=start; line<start+count; line++)
|
|
|
|
printf "%s/%s:%d:\n",ENVIRON["PWD"],file,line;
|
|
|
|
}'
|
|
|
|
}
|
|
|
|
|
|
|
|
copy_matched_lines() {
|
|
|
|
local source=$1
|
|
|
|
local matches=$2
|
|
|
|
local target=$3
|
|
|
|
|
|
|
|
echo -n > $target
|
|
|
|
for l in $(<$matches); do
|
|
|
|
grep $l $source >> $target
|
|
|
|
done
|
|
|
|
}
|
|
|
|
|
|
|
|
create_common() {
|
|
|
|
# comm requires sorted input;
|
|
|
|
# we also strip the error message to make the following a "common" error:
|
|
|
|
# regular:
|
|
|
|
# file.js:42:23 Indentation of 55, expected 42
|
|
|
|
# legacy:
|
|
|
|
# file.js:42:23 Indentation of 55, extected 24
|
|
|
|
prepare() {
|
|
|
|
sed 's: .*::' $1 | sort
|
|
|
|
}
|
|
|
|
|
|
|
|
comm -12 <(prepare $OUTPUT_REGULAR) <(prepare $OUTPUT_LEGACY) >$OUTPUT_FINAL.tmp
|
|
|
|
|
|
|
|
# Now add back the stripped error messages
|
|
|
|
copy_matched_lines $OUTPUT_REGULAR $OUTPUT_FINAL.tmp $OUTPUT_FINAL
|
|
|
|
rm $OUTPUT_FINAL.tmp
|
|
|
|
}
|
|
|
|
|
2019-09-12 14:50:22 +02:00
|
|
|
# Disable MR handling for now. We aren't ready to enforce
|
|
|
|
# non-legacy style just yet ...
|
|
|
|
unset CI_MERGE_REQUEST_TARGET_BRANCH_NAME
|
|
|
|
|
2019-09-14 17:09:04 +02:00
|
|
|
REMOTE=${1:-$CI_MERGE_REQUEST_PROJECT_URL.git}
|
|
|
|
BRANCH_NAME=${2:-$CI_MERGE_REQUEST_TARGET_BRANCH_NAME}
|
|
|
|
|
|
|
|
if [ "$BRANCH_NAME" ]; then
|
|
|
|
git fetch $REMOTE $BRANCH_NAME
|
2019-07-25 22:26:19 +02:00
|
|
|
branch_point=$(git merge-base HEAD FETCH_HEAD)
|
2019-09-14 17:09:04 +02:00
|
|
|
commit_range=$branch_point...HEAD
|
2019-07-25 22:26:19 +02:00
|
|
|
|
2019-06-30 13:05:04 +02:00
|
|
|
list_commit_range_additions $commit_range > $LINE_CHANGES
|
|
|
|
|
|
|
|
# Don't bother with running lint when no JS changed
|
|
|
|
if is_empty $LINE_CHANGES; then
|
|
|
|
exit 0
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
|
|
|
echo Generating lint report using regular configuration
|
|
|
|
run_eslint REGULAR
|
|
|
|
echo Generating lint report using legacy configuration
|
|
|
|
run_eslint LEGACY
|
|
|
|
echo Done.
|
|
|
|
create_common
|
|
|
|
|
2019-09-12 13:41:17 +02:00
|
|
|
if ! is_empty $OUTPUT_FINAL; then
|
|
|
|
cat $OUTPUT_FINAL
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
|
2019-06-30 13:05:04 +02:00
|
|
|
# Just show the report and succeed when not testing a MR
|
2019-09-14 17:09:04 +02:00
|
|
|
if [ -z "$BRANCH_NAME" ]; then
|
2019-06-30 13:05:04 +02:00
|
|
|
exit 0
|
|
|
|
fi
|
|
|
|
|
2019-09-12 13:51:26 +02:00
|
|
|
copy_matched_lines $OUTPUT_REGULAR $LINE_CHANGES $OUTPUT_MR
|
2019-06-30 13:05:04 +02:00
|
|
|
cat $OUTPUT_MR
|
|
|
|
is_empty $OUTPUT_MR
|