rspec/validate_asciidoc.sh

69 lines
1.7 KiB
Bash
Raw Normal View History

#!/bin/bash
set -uo pipefail
./generate_html.sh
exit_code=0
#validate sections in asciidoc
cd rspec-tools
pipenv install -e .
if pipenv run rspec-tools check-sections --d ../out; then
2021-05-05 09:40:19 +02:00
echo "Sections are fine"
else
echo "ERROR: incorrect section names"
exit_code=1
fi
cd ..
2020-06-23 11:33:04 +02:00
for dir in rules/*
do
dir=${dir%*/}
2020-06-26 15:25:20 +02:00
echo ${dir##*/}
subdircount=$(find $dir -maxdepth 1 -type d | wc -l)
# check if there are language specializations
if [[ "$subdircount" -eq 1 ]]
then
# no specializations, that's fine if the rule is deprecated
if grep -q '"status": "deprecated"\|"status": "closed"' "$dir/metadata.json"; then
echo "INFO: deprecated generic rule $dir with no language specializations"
2020-06-23 11:33:04 +02:00
else
echo "ERROR: non-deprecated generic rule $dir with no language specializations"
exit_code=1
2020-06-23 11:33:04 +02:00
fi
else
#validate asciidoc
supportedLanguages=$(sed 's/ or//' supported_languages.adoc | tr -d '`,')
for language in $dir/*/
do
language=${language%*/}
echo ${language##*/}
if [[ ! "${supportedLanguages[@]}" =~ "${language##*/}" ]]; then
echo "ERROR: ${language##*/} is not a supported language"
exit_code=1
fi
RULE="$language/rule.adoc"
if test -f $RULE; then
echo "$RULE exists."
TMP_ADOC="$language/tmp.adoc"
echo "== Description" > $TMP_ADOC
cat $RULE >> $TMP_ADOC
if asciidoctor --failure-level=WARNING -o /dev/null $TMP_ADOC; then
echo "$RULE syntax is fine"
else
echo "ERROR: $RULE has incorrect asciidoc"
exit_code=1
fi
rm $TMP_ADOC
else
echo "ERROR: no asciidoc file $RULE"
exit_code=1
fi
done
fi
2020-06-23 11:33:04 +02:00
done
exit $exit_code