diff options
author | Anthony Martin <ality@pbrane.org> | 2012-02-24 14:48:36 -0500 |
---|---|---|
committer | Anthony Martin <ality@pbrane.org> | 2012-02-24 14:48:36 -0500 |
commit | dabaf74c78c5b4ec8b438d7f5cbf79441b4712fe (patch) | |
tree | f7eab82b377be19e56d11696af6d4aaf66badb68 /test/import5.go | |
parent | 1a34d5e4a9418a9e31384c40466e52bca57ee7cb (diff) | |
download | go-dabaf74c78c5b4ec8b438d7f5cbf79441b4712fe.tar.gz |
gc: reject import paths containing special characters
Also allow multiple invalid import statements in a
single file.
Fixes issue 3021. The changes to go/parser and the
language specifcation have already been committed.
R=rsc, gri
CC=golang-dev
http://codereview.appspot.com/5672084
Committer: Russ Cox <rsc@golang.org>
Diffstat (limited to 'test/import5.go')
-rw-r--r-- | test/import5.go | 44 |
1 files changed, 41 insertions, 3 deletions
diff --git a/test/import5.go b/test/import5.go index 54d22fd9e..02d443b2e 100644 --- a/test/import5.go +++ b/test/import5.go @@ -4,10 +4,48 @@ // Use of this source code is governed by a BSD-style // license that can be found in the LICENSE file. -// Verify that imports with backslashes are rejected by the compiler. +// Verify that invalid imports are rejected by the compiler. // Does not compile. -// TODO: make more thorough. package main -import `net\http` // ERROR "backslash" +// Correct import paths. +import _ "fmt" +import _ `time` +import _ "m\x61th" +import _ "go/parser" + +// Correct import paths, but the packages don't exist. +// Don't test. +//import "a.b" +//import "greek/αβ" + +// Import paths must be strings. +import 42 // ERROR "import statement" +import 'a' // ERROR "import statement" +import 3.14 // ERROR "import statement" +import 0.25i // ERROR "import statement" + +// Each of these pairs tests both `` vs "" strings +// and also use of invalid characters spelled out as +// escape sequences and written directly. +// For example `"\x00"` tests import "\x00" +// while "`\x00`" tests import `<actual-NUL-byte>`. +import "" // ERROR "import path" +import `` // ERROR "import path" +import "\x00" // ERROR "import path" +import `\x00` // ERROR "import path" +import "\x7f" // ERROR "import path" +import `\x7f` // ERROR "import path" +import "a!" // ERROR "import path" +import `a!` // ERROR "import path" +import "a b" // ERROR "import path" +import `a b` // ERROR "import path" +import "a\\b" // ERROR "import path" +import `a\\b` // ERROR "import path" +import "\"`a`\"" // ERROR "import path" +import `\"a\"` // ERROR "import path" +import "\x80\x80" // ERROR "import path" +import `\x80\x80` // ERROR "import path" +import "\xFFFD" // ERROR "import path" +import `\xFFFD` // ERROR "import path" |