1
0
mirror of https://github.com/golang/go synced 2024-11-23 23:40:13 -07:00
go/test/linkx_run.go
Russ Cox 69f0d4c6be cmd/link: detect -X setting non-string variable
Fixes #9621.

Change-Id: Ib9c6001378364af899f57fd4b89fb23af2042923
Reviewed-on: https://go-review.googlesource.com/11694
Reviewed-by: Brad Fitzpatrick <bradfitz@golang.org>
Run-TryBot: Russ Cox <rsc@golang.org>
2015-06-29 20:28:36 +00:00

71 lines
1.6 KiB
Go

// +build !nacl
// run
// Copyright 2014 The Go Authors. All rights reserved.
// Use of this source code is governed by a BSD-style
// license that can be found in the LICENSE file.
// Run the linkx test.
package main
import (
"bytes"
"fmt"
"os"
"os/exec"
"strings"
)
func main() {
test(" ") // old deprecated syntax
test("=") // new syntax
}
func test(sep string) {
// Successful run
cmd := exec.Command("go", "run", "-ldflags=-X main.tbd"+sep+"hello -X main.overwrite"+sep+"trumped -X main.nosuchsymbol"+sep+"neverseen", "linkx.go")
var out, errbuf bytes.Buffer
cmd.Stdout = &out
cmd.Stderr = &errbuf
err := cmd.Run()
if err != nil {
fmt.Println(errbuf.String())
fmt.Println(out.String())
fmt.Println(err)
os.Exit(1)
}
want := "hello\ntrumped\n"
got := out.String()
if got != want {
fmt.Printf("got %q want %q\n", got, want)
os.Exit(1)
}
// Issue 8810
cmd = exec.Command("go", "run", "-ldflags=-X main.tbd", "linkx.go")
_, err = cmd.CombinedOutput()
if err == nil {
fmt.Println("-X linker flag should not accept keys without values")
os.Exit(1)
}
// Issue 9621
cmd = exec.Command("go", "run", "-ldflags=-X main.b=false -X main.x=42", "linkx.go")
outx, err := cmd.CombinedOutput()
if err == nil {
fmt.Println("-X linker flag should not overwrite non-strings")
os.Exit(1)
}
outstr := string(outx)
if !strings.Contains(outstr, "main.b") {
fmt.Printf("-X linker flag did not diagnose overwrite of main.b\n")
os.Exit(1)
}
if !strings.Contains(outstr, "main.x") {
fmt.Printf("-X linker flag did not diagnose overwrite of main.x\n")
os.Exit(1)
}
}