diff options
author | Tobias Bosch <tbosch@google.com> | 2019-06-10 15:50:33 -0700 |
---|---|---|
committer | Tobias Bosch <tbosch@google.com> | 2019-06-20 15:41:37 +0000 |
commit | ef8f969c8ea2498c2a8aa701cb2e83833339f9a8 (patch) | |
tree | a3c988999263f4e43ec561908b452093ad169b53 /compiler_wrapper/sysroot_flag_test.go | |
parent | 87d457dfc5ae0a7631917523eb3c62751453e4bb (diff) | |
download | toolchain-utils-ef8f969c8ea2498c2a8aa701cb2e83833339f9a8.tar.gz |
Initial version of a go version of the compiler wrapper.
Still calls the old wrapper if one of the following flags is given:
- Xclang-path
- clang-syntax
- env WITH_TIDY
- env FORCE_DISABLE_WERROR
- env GETRUSAGE
- env BISECT_STAGE
BUG=chromium:773875
TEST=Unit tests that also verify the produced command against the
TEST=existing compiler wrapper.
Change-Id: I1e0a720ce9f485d8015deefb2682f2cb760d82e4
Reviewed-on: https://chromium-review.googlesource.com/c/chromiumos/third_party/toolchain-utils/+/1652057
Reviewed-by: Manoj Gupta <manojgupta@chromium.org>
Reviewed-by: Tobias Bosch <tbosch@google.com>
Reviewed-by: George Burgess <gbiv@chromium.org>
Tested-by: Tobias Bosch <tbosch@google.com>
Legacy-Commit-Queue: Commit Bot <commit-bot@chromium.org>
Diffstat (limited to 'compiler_wrapper/sysroot_flag_test.go')
-rw-r--r-- | compiler_wrapper/sysroot_flag_test.go | 62 |
1 files changed, 62 insertions, 0 deletions
diff --git a/compiler_wrapper/sysroot_flag_test.go b/compiler_wrapper/sysroot_flag_test.go new file mode 100644 index 00000000..dd726291 --- /dev/null +++ b/compiler_wrapper/sysroot_flag_test.go @@ -0,0 +1,62 @@ +package main + +import ( + "path" + "testing" +) + +func TestOmitSysrootGivenUserDefinedSysroot(t *testing.T) { + withTestContext(t, func(ctx *testContext) { + runWithCompiler := func(compiler string) { + cmd := ctx.must(calcCompilerCommandAndCompareToOld(ctx, ctx.cfg, + ctx.newCommand(compiler, "--sysroot=/somepath", mainCc))) + if err := verifyArgOrder(cmd, "--sysroot=/somepath", mainCc); err != nil { + t.Error(err) + } + if err := verifyArgCount(cmd, 1, "--sysroot.*"); err != nil { + t.Error(err) + } + } + + runWithCompiler(gccX86_64) + runWithCompiler(clangX86_64) + }) +} + +func TestSetSysrootFlagFromEnv(t *testing.T) { + withTestContext(t, func(ctx *testContext) { + ctx.env = []string{"SYSROOT=/envpath"} + cmd := ctx.must(calcCompilerCommandAndCompareToOld(ctx, ctx.cfg, + ctx.newCommand(gccX86_64, mainCc))) + if err := verifyArgOrder(cmd, "--sysroot=/envpath", mainCc); err != nil { + t.Error(err) + } + }) +} + +func TestSetSysrootRelativeToWrapperPath(t *testing.T) { + withTestContext(t, func(ctx *testContext) { + ctx.cfg.rootRelPath = "somepath" + wrapperCmd := ctx.newCommand(gccX86_64, mainCc) + cmd := ctx.must(calcCompilerCommandAndCompareToOld(ctx, ctx.cfg, wrapperCmd)) + if err := verifyArgOrder(cmd, + "--sysroot="+ctx.tempDir+"/somepath/usr/x86_64-cros-linux-gnu", mainCc); err != nil { + t.Error(err) + } + }) +} + +func TestSetSysrootRelativeToSymlinkedWrapperPath(t *testing.T) { + withTestContext(t, func(ctx *testContext) { + ctx.cfg.rootRelPath = "somepath" + linkedWrapperPath := path.Join(ctx.tempDir, "a/linked/path/x86_64-cros-linux-gnu-gcc") + ctx.symlink(path.Join(ctx.tempDir, gccX86_64), linkedWrapperPath) + + cmd := ctx.must(calcCompilerCommandAndCompareToOld(ctx, ctx.cfg, + ctx.newCommand(linkedWrapperPath, mainCc))) + if err := verifyArgOrder(cmd, + "--sysroot="+ctx.tempDir+"/somepath/usr/x86_64-cros-linux-gnu", mainCc); err != nil { + t.Error(err) + } + }) +} |