Commit e1b90378 authored by Jay Conrod's avatar Jay Conrod

cmd/go: deflake TestScript/gcflags_patterns

The check below can fail incorrectly if the buildid ends with '-p'.

    ! stderr 'compile.* -e .*-p [^z]'

This fix changes regular expressions to '-e.* -p' or '-N.* -p' instead
of '-e .*-p'. '-l' is no longer used because the compiler accepts
multiple flags starting with '-l' ('-e' and '-N' do not have this
problem), so there could be false matches.

Change-Id: I827c411de28624019a287f853acc9666e87cbfb9
Reviewed-on: https://go-review.googlesource.com/c/156327Reviewed-by: default avatarBrad Fitzpatrick <bradfitz@golang.org>
parent 73fb3c38
...@@ -2,28 +2,28 @@ ...@@ -2,28 +2,28 @@
# -gcflags=-e applies to named packages, not dependencies # -gcflags=-e applies to named packages, not dependencies
go build -n -v -gcflags=-e z1 z2 go build -n -v -gcflags=-e z1 z2
stderr 'compile.* -e .*-p z1' stderr 'compile.* -e.* -p z1'
stderr 'compile.* -e .*-p z2' stderr 'compile.* -e.* -p z2'
stderr 'compile.* -p y' stderr 'compile.* -p y'
! stderr 'compile.* -e .*-p [^z]' ! stderr 'compile.* -e.* -p [^z]'
# -gcflags can specify package=flags, and can be repeated; last match wins # -gcflags can specify package=flags, and can be repeated; last match wins
go build -n -v -gcflags=-e -gcflags=z1=-N z1 z2 go build -n -v -gcflags=-e -gcflags=z1=-N z1 z2
stderr 'compile.* -N .*-p z1' stderr 'compile.* -N.* -p z1'
! stderr 'compile.* -e .*-p z1' ! stderr 'compile.* -e.* -p z1'
! stderr 'compile.* -N .*-p z2' ! stderr 'compile.* -N.* -p z2'
stderr 'compile.* -e .*-p z2' stderr 'compile.* -e.* -p z2'
stderr 'compile.* -p y' stderr 'compile.* -p y'
! stderr 'compile.* -e .*-p [^z]' ! stderr 'compile.* -e.* -p [^z]'
! stderr 'compile.* -N .*-p [^z]' ! stderr 'compile.* -N.* -p [^z]'
# -gcflags can have arbitrary spaces around the flags # -gcflags can have arbitrary spaces around the flags
go build -n -v -gcflags=' z1 = -e ' z1 go build -n -v -gcflags=' z1 = -e ' z1
stderr 'compile.* -e .*-p z1' stderr 'compile.* -e.* -p z1'
# -gcflags='all=-N -l' should apply to all packages, even with go test # -gcflags='all=-e' should apply to all packages, even with go test
go test -c -n -gcflags='all=-N -l' z1 go test -c -n -gcflags='all=-e' z1
stderr 'compile.* -N -l .*-p z3 ' stderr 'compile.* -e.* -p z3 '
# -ldflags for implicit test package applies to test binary # -ldflags for implicit test package applies to test binary
go test -c -n -gcflags=-N -ldflags=-X=x.y=z z1 go test -c -n -gcflags=-N -ldflags=-X=x.y=z z1
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment