-
Notifications
You must be signed in to change notification settings - Fork 1.6k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #15764 from michaelnebel/csharp/csharptracerrunapp
C#: Don't inject compiler flags when dotnet is used to execute an application.
- Loading branch information
Showing
4 changed files
with
39 additions
and
24 deletions.
There are no files selected for viewing
2 changes: 1 addition & 1 deletion
2
csharp/ql/integration-tests/all-platforms/dotnet_build/Program.cs
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1 +1 @@ | ||
Console.WriteLine(args[0]); | ||
Console.WriteLine($"<arguments>{string.Join(",", args)}</arguments>"); |
15 changes: 13 additions & 2 deletions
15
csharp/ql/integration-tests/all-platforms/dotnet_build/test.py
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,5 +1,16 @@ | ||
from create_database_utils import * | ||
from diagnostics_test_utils import * | ||
|
||
run_codeql_database_create(['dotnet build'], db=None, lang="csharp") | ||
check_diagnostics() | ||
def check_build_out(msg, s): | ||
if "[build-stdout] " + msg not in s: | ||
raise Exception("The C# tracer did not interpret the dotnet path-to-application command correctly.") | ||
|
||
run_codeql_database_create(['dotnet build'], test_db="test1-db", lang="csharp") | ||
check_diagnostics(test_db="test1-db") | ||
|
||
# This test checks that we don't inject any flags when running the application using `dotnet` | ||
my_dir = "my_program" | ||
my_abs_path = os.path.abspath(f"{my_dir}/dotnet_build.dll") | ||
s = run_codeql_database_create_stdout(['dotnet clean', 'rm -rf test1-db', 'dotnet build -o my_program', f'dotnet {my_abs_path} build is not a subcommand'], "test2-db", "csharp") | ||
check_build_out("<arguments>build,is,not,a,subcommand</arguments>", s) | ||
check_diagnostics(test_db="test2-db") |
30 changes: 11 additions & 19 deletions
30
csharp/ql/integration-tests/all-platforms/dotnet_run/test.py
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,65 +1,57 @@ | ||
from create_database_utils import * | ||
from diagnostics_test_utils import * | ||
|
||
def run_codeql_database_create_stdout(args, dbname): | ||
stdout = open(dbname + "file.txt", 'w+') | ||
run_codeql_database_create(args, test_db=dbname, db=None, stdout=stdout, lang="csharp") | ||
stdout.seek(0) | ||
s = stdout.read() | ||
stdout.close() | ||
return s | ||
|
||
def check_build_out(msg, s): | ||
if "[build-stdout] " + msg not in s: | ||
raise Exception("The C# extractor did not interpret the 'dotnet run' command correctly") | ||
raise Exception("The C# tracer did not interpret the 'dotnet run' command correctly") | ||
|
||
# no arguments | ||
s = run_codeql_database_create_stdout(['dotnet run'], "test-db") | ||
s = run_codeql_database_create_stdout(['dotnet run'], "test-db", "csharp") | ||
check_build_out("Default reply", s) | ||
check_diagnostics() | ||
|
||
# no arguments, but `--` | ||
s = run_codeql_database_create_stdout(['dotnet clean', 'rm -rf test-db', 'dotnet run --'], "test2-db") | ||
s = run_codeql_database_create_stdout(['dotnet clean', 'rm -rf test-db', 'dotnet run --'], "test2-db", "csharp") | ||
check_build_out("Default reply", s) | ||
check_diagnostics(test_db="test2-db") | ||
|
||
# one argument, no `--` | ||
s = run_codeql_database_create_stdout(['dotnet clean', 'rm -rf test2-db', 'dotnet run hello'], "test3-db") | ||
s = run_codeql_database_create_stdout(['dotnet clean', 'rm -rf test2-db', 'dotnet run hello'], "test3-db", "csharp") | ||
check_build_out("Default reply", s) | ||
check_diagnostics(test_db="test3-db") | ||
|
||
# one argument, but `--` | ||
s = run_codeql_database_create_stdout(['dotnet clean', 'rm -rf test3-db', 'dotnet run -- hello'], "test4-db") | ||
s = run_codeql_database_create_stdout(['dotnet clean', 'rm -rf test3-db', 'dotnet run -- hello'], "test4-db", "csharp") | ||
check_build_out("Default reply", s) | ||
check_diagnostics(test_db="test4-db") | ||
|
||
# two arguments, no `--` | ||
s = run_codeql_database_create_stdout(['dotnet clean', 'rm -rf test4-db', 'dotnet run hello world'], "test5-db") | ||
s = run_codeql_database_create_stdout(['dotnet clean', 'rm -rf test4-db', 'dotnet run hello world'], "test5-db", "csharp") | ||
check_build_out("hello, world", s) | ||
check_diagnostics(test_db="test5-db") | ||
|
||
# two arguments, and `--` | ||
s = run_codeql_database_create_stdout(['dotnet clean', 'rm -rf test5-db', 'dotnet run -- hello world'], "test6-db") | ||
s = run_codeql_database_create_stdout(['dotnet clean', 'rm -rf test5-db', 'dotnet run -- hello world'], "test6-db", "csharp") | ||
check_build_out("hello, world", s) | ||
check_diagnostics(test_db="test6-db") | ||
|
||
# shared compilation enabled; tracer should override by changing the command | ||
# to `dotnet run -p:UseSharedCompilation=true -p:UseSharedCompilation=false -- hello world` | ||
s = run_codeql_database_create_stdout(['dotnet clean', 'rm -rf test6-db', 'dotnet run -p:UseSharedCompilation=true -- hello world'], "test7-db") | ||
s = run_codeql_database_create_stdout(['dotnet clean', 'rm -rf test6-db', 'dotnet run -p:UseSharedCompilation=true -- hello world'], "test7-db", "csharp") | ||
check_build_out("hello, world", s) | ||
check_diagnostics(test_db="test7-db") | ||
|
||
# option passed into `dotnet run` | ||
s = run_codeql_database_create_stdout(['dotnet clean', 'rm -rf test7-db', 'dotnet build', 'dotnet run --no-build hello world'], "test8-db") | ||
s = run_codeql_database_create_stdout(['dotnet clean', 'rm -rf test7-db', 'dotnet build', 'dotnet run --no-build hello world'], "test8-db", "csharp") | ||
check_build_out("hello, world", s) | ||
check_diagnostics(test_db="test8-db") | ||
|
||
# two arguments, no '--' (first argument quoted) | ||
s = run_codeql_database_create_stdout(['dotnet clean', 'rm -rf test8-db', 'dotnet run "hello world part1" part2'], "test9-db") | ||
s = run_codeql_database_create_stdout(['dotnet clean', 'rm -rf test8-db', 'dotnet run "hello world part1" part2'], "test9-db", "csharp") | ||
check_build_out("hello world part1, part2", s) | ||
check_diagnostics(test_db="test9-db") | ||
|
||
# two arguments, no '--' (second argument quoted) and using dotnet to execute dotnet | ||
s = run_codeql_database_create_stdout(['dotnet clean', 'rm -rf test9-db', 'dotnet dotnet run part1 "hello world part2"'], "test10-db") | ||
s = run_codeql_database_create_stdout(['dotnet clean', 'rm -rf test9-db', 'dotnet dotnet run part1 "hello world part2"'], "test10-db", "csharp") | ||
check_build_out("part1, hello world part2", s) | ||
check_diagnostics(test_db="test10-db") |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters