support `@arguments.rst` for args through file
This commit is contained in:
parent
a958f9ac7b
commit
6491d792f5
|
@ -5,20 +5,21 @@
|
||||||
|
|
||||||
module dscanner.main;
|
module dscanner.main;
|
||||||
|
|
||||||
import std.algorithm;
|
|
||||||
import std.array;
|
|
||||||
import std.conv;
|
|
||||||
import std.file;
|
|
||||||
import std.getopt;
|
|
||||||
import std.path;
|
|
||||||
import std.stdio;
|
|
||||||
import std.range;
|
|
||||||
import std.experimental.lexer;
|
|
||||||
import std.typecons : scoped;
|
|
||||||
import std.functional : toDelegate;
|
|
||||||
import dparse.lexer;
|
import dparse.lexer;
|
||||||
import dparse.parser;
|
import dparse.parser;
|
||||||
import dparse.rollback_allocator;
|
import dparse.rollback_allocator;
|
||||||
|
import std.algorithm;
|
||||||
|
import std.array;
|
||||||
|
import std.conv;
|
||||||
|
import std.experimental.lexer;
|
||||||
|
import std.file;
|
||||||
|
import std.functional : toDelegate;
|
||||||
|
import std.getopt;
|
||||||
|
import std.path;
|
||||||
|
import std.range;
|
||||||
|
import std.stdio;
|
||||||
|
import std.string : chomp, splitLines;
|
||||||
|
import std.typecons : scoped;
|
||||||
|
|
||||||
import dscanner.highlighter;
|
import dscanner.highlighter;
|
||||||
import dscanner.stats;
|
import dscanner.stats;
|
||||||
|
@ -75,6 +76,9 @@ else
|
||||||
bool verbose;
|
bool verbose;
|
||||||
string errorFormat;
|
string errorFormat;
|
||||||
|
|
||||||
|
if (args.length == 2 && args[1].startsWith("@"))
|
||||||
|
args = args[0] ~ readText(args[1][1 .. $]).chomp.splitLines;
|
||||||
|
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
// dfmt off
|
// dfmt off
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
; Configure which static analysis checks are enabled
|
; Configure which static analysis checks are enabled
|
||||||
[analysis.config.StaticAnalysisConfig]
|
[analysis.config.StaticAnalysisConfig]
|
||||||
; Check variable, class, struct, interface, union, and function names against the Phobos style guide
|
; Check variable, class, struct, interface, union, and function names against the Phobos style guide
|
||||||
style_check="disabled"
|
style_check="enabled"
|
||||||
; Check for array literals that cause unnecessary allocation
|
; Check for array literals that cause unnecessary allocation
|
||||||
enum_array_literal_check="enabled"
|
enum_array_literal_check="enabled"
|
||||||
; Check for poor exception handling practices
|
; Check for poor exception handling practices
|
||||||
|
|
49
tests/it.sh
49
tests/it.sh
|
@ -2,8 +2,37 @@
|
||||||
|
|
||||||
set -eu -o pipefail
|
set -eu -o pipefail
|
||||||
|
|
||||||
|
function section {
|
||||||
|
e=$'\e'
|
||||||
|
if [ ! -z "${GITHUB_ACTION:-}" ]; then
|
||||||
|
echo "::endgroup::"
|
||||||
|
fi
|
||||||
|
if [ ! -z "${GITHUB_ACTION:-}" ]; then
|
||||||
|
echo "::group::$@"
|
||||||
|
fi
|
||||||
|
echo "$e[1m$@$e[m"
|
||||||
|
}
|
||||||
|
|
||||||
|
function error {
|
||||||
|
echo $'\e[31;1mTests have failed.\e[m'
|
||||||
|
exit 1
|
||||||
|
}
|
||||||
|
|
||||||
|
function cleanup {
|
||||||
|
if [ ! -z "${GITHUB_ACTION:-}" ]; then
|
||||||
|
echo "::endgroup::"
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
DSCANNER_DIR="$(dirname -- $( cd -- "$( dirname -- "${BASH_SOURCE[0]}" )" &> /dev/null && pwd ))"
|
DSCANNER_DIR="$(dirname -- $( cd -- "$( dirname -- "${BASH_SOURCE[0]}" )" &> /dev/null && pwd ))"
|
||||||
|
|
||||||
|
if [ ! -z "${GITHUB_ACTION:-}" ]; then
|
||||||
|
echo "::group::Building d-scanner"
|
||||||
|
fi
|
||||||
|
|
||||||
|
trap cleanup EXIT
|
||||||
|
trap error ERR
|
||||||
|
|
||||||
if [ -z "${CI:-}" ]; then
|
if [ -z "${CI:-}" ]; then
|
||||||
dub build --root="$DSCANNER_DIR"
|
dub build --root="$DSCANNER_DIR"
|
||||||
fi
|
fi
|
||||||
|
@ -19,28 +48,36 @@ diff <(../bin/dscanner --resolveMessage b16 it/autofix_ide/source_autofix.d | jq
|
||||||
# CLI tests
|
# CLI tests
|
||||||
# ---------
|
# ---------
|
||||||
# check that `dscanner fix` works as expected
|
# check that `dscanner fix` works as expected
|
||||||
echo '1. test no changes if EOFing'
|
section '1. test no changes if EOFing'
|
||||||
cp -v it/autofix_cli/source.d it/autofix_cli/test.d
|
cp -v it/autofix_cli/source.d it/autofix_cli/test.d
|
||||||
printf "" | ../bin/dscanner fix it/autofix_cli/test.d
|
printf "" | ../bin/dscanner fix it/autofix_cli/test.d
|
||||||
diff it/autofix_cli/test.d it/autofix_cli/source.d
|
diff it/autofix_cli/test.d it/autofix_cli/source.d
|
||||||
echo '2. test no changes for simple enter pressing'
|
section '2. test no changes for simple enter pressing'
|
||||||
cp -v it/autofix_cli/source.d it/autofix_cli/test.d
|
cp -v it/autofix_cli/source.d it/autofix_cli/test.d
|
||||||
printf "\n" | ../bin/dscanner fix it/autofix_cli/test.d
|
printf "\n" | ../bin/dscanner fix it/autofix_cli/test.d
|
||||||
diff it/autofix_cli/test.d it/autofix_cli/source.d
|
diff it/autofix_cli/test.d it/autofix_cli/source.d
|
||||||
echo '2.1. test no changes entering 0'
|
section '2.1. test no changes entering 0'
|
||||||
cp -v it/autofix_cli/source.d it/autofix_cli/test.d
|
cp -v it/autofix_cli/source.d it/autofix_cli/test.d
|
||||||
printf "0\n" | ../bin/dscanner fix it/autofix_cli/test.d
|
printf "0\n" | ../bin/dscanner fix it/autofix_cli/test.d
|
||||||
diff it/autofix_cli/test.d it/autofix_cli/source.d
|
diff it/autofix_cli/test.d it/autofix_cli/source.d
|
||||||
echo '3. test change applies automatically with --applySingle'
|
section '3. test change applies automatically with --applySingle'
|
||||||
cp -v it/autofix_cli/source.d it/autofix_cli/test.d
|
cp -v it/autofix_cli/source.d it/autofix_cli/test.d
|
||||||
../bin/dscanner fix --applySingle it/autofix_cli/test.d | grep -F 'Writing changes to it/autofix_cli/test.d'
|
../bin/dscanner fix --applySingle it/autofix_cli/test.d | grep -F 'Writing changes to it/autofix_cli/test.d'
|
||||||
diff it/autofix_cli/test.d it/autofix_cli/fixed.d
|
diff it/autofix_cli/test.d it/autofix_cli/fixed.d
|
||||||
echo '4. test change apply when entering "1"'
|
section '4. test change apply when entering "1"'
|
||||||
cp -v it/autofix_cli/source.d it/autofix_cli/test.d
|
cp -v it/autofix_cli/source.d it/autofix_cli/test.d
|
||||||
printf "1\n" | ../bin/dscanner fix it/autofix_cli/test.d | grep -F 'Writing changes to it/autofix_cli/test.d'
|
printf "1\n" | ../bin/dscanner fix it/autofix_cli/test.d | grep -F 'Writing changes to it/autofix_cli/test.d'
|
||||||
diff it/autofix_cli/test.d it/autofix_cli/fixed.d
|
diff it/autofix_cli/test.d it/autofix_cli/fixed.d
|
||||||
echo '5. test invalid selection reasks what to apply'
|
section '5. test invalid selection reasks what to apply'
|
||||||
cp -v it/autofix_cli/source.d it/autofix_cli/test.d
|
cp -v it/autofix_cli/source.d it/autofix_cli/test.d
|
||||||
printf "2\n-1\n1000\na\n1\n" | ../bin/dscanner fix it/autofix_cli/test.d | grep -F 'Writing changes to it/autofix_cli/test.d'
|
printf "2\n-1\n1000\na\n1\n" | ../bin/dscanner fix it/autofix_cli/test.d | grep -F 'Writing changes to it/autofix_cli/test.d'
|
||||||
diff it/autofix_cli/test.d it/autofix_cli/fixed.d
|
diff it/autofix_cli/test.d it/autofix_cli/fixed.d
|
||||||
|
|
||||||
|
# check that `dscanner @myargs.rst` reads arguments from file
|
||||||
|
section "Test @myargs.rst"
|
||||||
|
echo "-f" > "myargs.rst"
|
||||||
|
echo "github" >> "myargs.rst"
|
||||||
|
echo "lint" >> "myargs.rst"
|
||||||
|
echo "it/singleissue.d" >> "myargs.rst"
|
||||||
|
diff it/singleissue_github.txt <(../bin/dscanner "@myargs.rst")
|
||||||
|
rm "myargs.rst"
|
||||||
|
|
|
@ -0,0 +1 @@
|
||||||
|
int NonMatchingName;
|
|
@ -0,0 +1 @@
|
||||||
|
::warning file=it/singleissue.d,line=1,endLine=1,col=5,endColumn=20,title=Warning (style_check)::Variable name 'NonMatchingName' does not match style guidelines.
|
Loading…
Reference in New Issue