Refactor proctor binaries to implement testRunner interface.

Shared code among proctor-*.go files has been refactored
into common/common.go. The common package is imported in
each proctor binary and a struct is created to implement
the testRunner interface defined in common.go. This allows
for the proctor binaries to be updated without having to
copy/paste the same code across all files. There are no
usage or functionality changes.

PiperOrigin-RevId: 260967080
This commit is contained in:
Brett Landau 2019-07-31 11:34:34 -07:00 committed by gVisor bot
parent 12c4eb294a
commit edcc60b931
12 changed files with 171 additions and 237 deletions

View File

@ -0,0 +1,10 @@
load("@io_bazel_rules_go//go:def.bzl", "go_library")
package(licenses = ["notice"])
go_library(
name = "common",
srcs = ["common.go"],
importpath = "gvisor.dev/gvisor/test/runtimes/common",
visibility = ["//:sandbox"],
)

View File

@ -0,0 +1,85 @@
// Copyright 2019 The gVisor Authors.
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
// Package common executes functions for proctor binaries.
package common
import (
"flag"
"fmt"
"os"
)
var (
list = flag.Bool("list", false, "list all available tests")
test = flag.String("test", "", "run a single test from the list of available tests")
version = flag.Bool("v", false, "print out the version of node that is installed")
)
// TestRunner is an interface to be implemented in each proctor binary.
type TestRunner interface {
// ListTests returns a string slice of tests available to run.
ListTests() ([]string, error)
// RunTest runs a single test.
RunTest(test string) error
}
// LaunchFunc parses flags passed by a proctor binary and calls the requested behavior.
func LaunchFunc(tr TestRunner) error {
flag.Parse()
if *list && *test != "" {
flag.PrintDefaults()
return fmt.Errorf("cannot specify 'list' and 'test' flags simultaneously")
}
if *list {
tests, err := tr.ListTests()
if err != nil {
return fmt.Errorf("failed to list tests: %v", err)
}
for _, test := range tests {
fmt.Println(test)
}
return nil
}
if *version {
fmt.Println(os.Getenv("LANG_NAME"), "version:", os.Getenv("LANG_VER"), "is installed.")
return nil
}
if *test != "" {
if err := tr.RunTest(*test); err != nil {
return fmt.Errorf("test %q failed to run: %v", *test, err)
}
return nil
}
if err := runAllTests(tr); err != nil {
return fmt.Errorf("error running all tests: %v", err)
}
return nil
}
func runAllTests(tr TestRunner) error {
tests, err := tr.ListTests()
if err != nil {
return fmt.Errorf("failed to list tests: %v", err)
}
for _, test := range tests {
if err := tr.RunTest(test); err != nil {
return fmt.Errorf("test %q failed to run: %v", test, err)
}
}
return nil
}

View File

@ -5,4 +5,5 @@ package(licenses = ["notice"])
go_binary(
name = "proctor-go",
srcs = ["proctor-go.go"],
deps = ["//test/runtimes/common"],
)

View File

@ -21,7 +21,6 @@
package main
import (
"flag"
"fmt"
"log"
"os"
@ -29,14 +28,13 @@ import (
"path/filepath"
"regexp"
"strings"
"gvisor.dev/gvisor/test/runtimes/common"
)
var (
list = flag.Bool("list", false, "list all available tests")
test = flag.String("test", "", "run a single test from the list of available tests")
version = flag.Bool("v", false, "print out the version of node that is installed")
dir = os.Getenv("LANG_DIR")
goBin = filepath.Join(dir, "bin/go")
testDir = filepath.Join(dir, "test")
testRegEx = regexp.MustCompile(`^.+\.go$`)
@ -45,35 +43,16 @@ var (
exclDirs = regexp.MustCompile(`^.+\/(bench|stress)\/.+$|^.+\.dir.+$`)
)
func main() {
flag.Parse()
if *list && *test != "" {
flag.PrintDefaults()
os.Exit(1)
}
if *list {
tests, err := listTests()
if err != nil {
log.Fatalf("Failed to list tests: %v", err)
}
for _, test := range tests {
fmt.Println(test)
}
return
}
if *version {
fmt.Println("Go version: ", os.Getenv("LANG_VER"), " is installed.")
return
}
if *test != "" {
runTest(*test)
return
}
runAllTests()
type goRunner struct {
}
func listTests() ([]string, error) {
func main() {
if err := common.LaunchFunc(goRunner{}); err != nil {
log.Fatalf("Failed to start: %v", err)
}
}
func (g goRunner) ListTests() ([]string, error) {
// Go tool dist test tests.
args := []string{"tool", "dist", "test", "-list"}
cmd := exec.Command(filepath.Join(dir, "bin/go"), args...)
@ -112,50 +91,29 @@ func listTests() ([]string, error) {
return testSlice, nil
}
func runTest(test string) {
toolArgs := []string{
"tool",
"dist",
"test",
}
diskArgs := []string{
"run",
"run.go",
"-v",
}
func (g goRunner) RunTest(test string) error {
// Check if test exists on disk by searching for file of the same name.
// This will determine whether or not it is a Go test on disk.
if _, err := os.Stat(test); err == nil {
relPath, err := filepath.Rel(testDir, test)
if err != nil {
log.Fatalf("Failed to get rel path: %v", err)
return fmt.Errorf("failed to get rel path: %v", err)
}
diskArgs = append(diskArgs, "--", relPath)
cmd := exec.Command(filepath.Join(dir, "bin/go"), diskArgs...)
cmd := exec.Command(goBin, "run", "run.go", "-v", "--", relPath)
cmd.Dir = testDir
cmd.Stdout, cmd.Stderr = os.Stdout, os.Stderr
if err := cmd.Run(); err != nil {
log.Fatalf("Failed to run: %v", err)
return fmt.Errorf("failed to run test: %v", err)
}
} else if os.IsNotExist(err) {
// File was not found, try running as Go tool test.
toolArgs = append(toolArgs, "-run", test)
cmd := exec.Command(filepath.Join(dir, "bin/go"), toolArgs...)
cmd := exec.Command(goBin, "tool", "dist", "test", "-run", test)
cmd.Stdout, cmd.Stderr = os.Stdout, os.Stderr
if err := cmd.Run(); err != nil {
log.Fatalf("Failed to run: %v", err)
return fmt.Errorf("failed to run test: %v", err)
}
} else {
log.Fatalf("Error searching for test: %v", err)
}
}
func runAllTests() {
tests, err := listTests()
if err != nil {
log.Fatalf("Failed to list tests: %v", err)
}
for _, test := range tests {
runTest(test)
return fmt.Errorf("error searching for test: %v", err)
}
return nil
}

View File

@ -5,4 +5,5 @@ package(licenses = ["notice"])
go_binary(
name = "proctor-java",
srcs = ["proctor-java.go"],
deps = ["//test/runtimes/common"],
)

View File

@ -16,7 +16,6 @@
package main
import (
"flag"
"fmt"
"log"
"os"
@ -24,47 +23,26 @@ import (
"path/filepath"
"regexp"
"strings"
"gvisor.dev/gvisor/test/runtimes/common"
)
var (
list = flag.Bool("list", false, "list all available tests")
test = flag.String("test", "", "run a single test from the list of available tests")
version = flag.Bool("v", false, "print out the version of node that is installed")
dir = os.Getenv("LANG_DIR")
jtreg = filepath.Join(dir, "jtreg/bin/jtreg")
exclDirs = regexp.MustCompile(`(^(sun\/security)|(java\/util\/stream)|(java\/time)| )`)
)
func main() {
flag.Parse()
if *list && *test != "" {
flag.PrintDefaults()
os.Exit(1)
}
if *list {
tests, err := listTests()
if err != nil {
log.Fatalf("Failed to list tests: %v", err)
}
for _, test := range tests {
fmt.Println(test)
}
return
}
if *version {
fmt.Println("Java version: ", os.Getenv("LANG_VER"), " is installed.")
return
}
if *test != "" {
runTest(*test)
return
}
runAllTests()
type javaRunner struct {
}
func listTests() ([]string, error) {
func main() {
if err := common.LaunchFunc(javaRunner{}); err != nil {
log.Fatalf("Failed to start: %v", err)
}
}
func (j javaRunner) ListTests() ([]string, error) {
args := []string{
"-dir:test/jdk",
"-ignore:quiet",
@ -90,21 +68,12 @@ func listTests() ([]string, error) {
return testSlice, nil
}
func runTest(test string) {
func (j javaRunner) RunTest(test string) error {
args := []string{"-dir:test/jdk/", test}
cmd := exec.Command(jtreg, args...)
cmd.Stdout, cmd.Stderr = os.Stdout, os.Stderr
if err := cmd.Run(); err != nil {
log.Fatalf("Failed to run: %v", err)
}
}
func runAllTests() {
tests, err := listTests()
if err != nil {
log.Fatalf("Failed to list tests: %v", err)
}
for _, test := range tests {
runTest(test)
return fmt.Errorf("failed to run: %v", err)
}
return nil
}

View File

@ -5,4 +5,5 @@ package(licenses = ["notice"])
go_binary(
name = "proctor-nodejs",
srcs = ["proctor-nodejs.go"],
deps = ["//test/runtimes/common"],
)

View File

@ -16,53 +16,31 @@
package main
import (
"flag"
"fmt"
"log"
"os"
"os/exec"
"path/filepath"
"regexp"
"gvisor.dev/gvisor/test/runtimes/common"
)
var (
list = flag.Bool("list", false, "list all available tests")
test = flag.String("test", "", "run a single test from the list of available tests")
version = flag.Bool("v", false, "print out the version of node that is installed")
dir = os.Getenv("LANG_DIR")
testRegEx = regexp.MustCompile(`^test-.+\.js$`)
)
func main() {
flag.Parse()
if *list && *test != "" {
flag.PrintDefaults()
os.Exit(1)
}
if *list {
tests, err := listTests()
if err != nil {
log.Fatalf("Failed to list tests: %v", err)
}
for _, test := range tests {
fmt.Println(test)
}
return
}
if *version {
fmt.Println("Node.js version: ", os.Getenv("LANG_VER"), " is installed.")
return
}
if *test != "" {
runTest(*test)
return
}
runAllTests()
type nodejsRunner struct {
}
func listTests() ([]string, error) {
func main() {
if err := common.LaunchFunc(nodejsRunner{}); err != nil {
log.Fatalf("Failed to start: %v", err)
}
}
func (n nodejsRunner) ListTests() ([]string, error) {
var testSlice []string
root := filepath.Join(dir, "test")
@ -88,21 +66,12 @@ func listTests() ([]string, error) {
return testSlice, nil
}
func runTest(test string) {
func (n nodejsRunner) RunTest(test string) error {
args := []string{filepath.Join(dir, "tools", "test.py"), test}
cmd := exec.Command("/usr/bin/python", args...)
cmd.Stdout, cmd.Stderr = os.Stdout, os.Stderr
if err := cmd.Run(); err != nil {
log.Fatalf("Failed to run: %v", err)
}
}
func runAllTests() {
tests, err := listTests()
if err != nil {
log.Fatalf("Failed to list tests: %v", err)
}
for _, test := range tests {
runTest(test)
return fmt.Errorf("failed to run: %v", err)
}
return nil
}

View File

@ -5,4 +5,5 @@ package(licenses = ["notice"])
go_binary(
name = "proctor-php",
srcs = ["proctor-php.go"],
deps = ["//test/runtimes/common"],
)

View File

@ -16,53 +16,31 @@
package main
import (
"flag"
"fmt"
"log"
"os"
"os/exec"
"path/filepath"
"regexp"
"gvisor.dev/gvisor/test/runtimes/common"
)
var (
list = flag.Bool("list", false, "list all available tests")
test = flag.String("test", "", "run a single test from the list of available tests")
version = flag.Bool("v", false, "print out the version of node that is installed")
dir = os.Getenv("LANG_DIR")
testRegEx = regexp.MustCompile(`^.+\.phpt$`)
)
func main() {
flag.Parse()
if *list && *test != "" {
flag.PrintDefaults()
os.Exit(1)
}
if *list {
tests, err := listTests()
if err != nil {
log.Fatalf("Failed to list tests: %v", err)
}
for _, test := range tests {
fmt.Println(test)
}
return
}
if *version {
fmt.Println("PHP version: ", os.Getenv("LANG_VER"), " is installed.")
return
}
if *test != "" {
runTest(*test)
return
}
runAllTests()
type phpRunner struct {
}
func listTests() ([]string, error) {
func main() {
if err := common.LaunchFunc(phpRunner{}); err != nil {
log.Fatalf("Failed to start: %v", err)
}
}
func (p phpRunner) ListTests() ([]string, error) {
var testSlice []string
err := filepath.Walk(dir, func(path string, info os.FileInfo, err error) error {
@ -87,21 +65,12 @@ func listTests() ([]string, error) {
return testSlice, nil
}
func runTest(test string) {
func (p phpRunner) RunTest(test string) error {
args := []string{"test", "TESTS=" + test}
cmd := exec.Command("make", args...)
cmd.Stdout, cmd.Stderr = os.Stdout, os.Stderr
if err := cmd.Run(); err != nil {
log.Fatalf("Failed to run: %v", err)
}
}
func runAllTests() {
tests, err := listTests()
if err != nil {
log.Fatalf("Failed to list tests: %v", err)
}
for _, test := range tests {
runTest(test)
return fmt.Errorf("failed to run: %v", err)
}
return nil
}

View File

@ -5,4 +5,5 @@ package(licenses = ["notice"])
go_binary(
name = "proctor-python",
srcs = ["proctor-python.go"],
deps = ["//test/runtimes/common"],
)

View File

@ -16,53 +16,31 @@
package main
import (
"flag"
"fmt"
"log"
"os"
"os/exec"
"path/filepath"
"regexp"
"gvisor.dev/gvisor/test/runtimes/common"
)
var (
list = flag.Bool("list", false, "list all available tests")
test = flag.String("test", "", "run a single test from the list of available tests")
version = flag.Bool("v", false, "print out the version of node that is installed")
dir = os.Getenv("LANG_DIR")
testRegEx = regexp.MustCompile(`^test_.+\.py$`)
)
func main() {
flag.Parse()
if *list && *test != "" {
flag.PrintDefaults()
os.Exit(1)
}
if *list {
tests, err := listTests()
if err != nil {
log.Fatalf("Failed to list tests: %v", err)
}
for _, test := range tests {
fmt.Println(test)
}
return
}
if *version {
fmt.Println("Python version: ", os.Getenv("LANG_VER"), " is installed.")
return
}
if *test != "" {
runTest(*test)
return
}
runAllTests()
type pythonRunner struct {
}
func listTests() ([]string, error) {
func main() {
if err := common.LaunchFunc(pythonRunner{}); err != nil {
log.Fatalf("Failed to start: %v", err)
}
}
func (p pythonRunner) ListTests() ([]string, error) {
var testSlice []string
root := filepath.Join(dir, "Lib/test")
@ -88,21 +66,12 @@ func listTests() ([]string, error) {
return testSlice, nil
}
func runTest(test string) {
func (p pythonRunner) RunTest(test string) error {
args := []string{"-m", "test", test}
cmd := exec.Command(filepath.Join(dir, "python"), args...)
cmd.Stdout, cmd.Stderr = os.Stdout, os.Stderr
if err := cmd.Run(); err != nil {
log.Fatalf("Failed to run: %v", err)
}
}
func runAllTests() {
tests, err := listTests()
if err != nil {
log.Fatalf("Failed to list tests: %v", err)
}
for _, test := range tests {
runTest(test)
return fmt.Errorf("failed to run: %v", err)
}
return nil
}