platform_build_soong/cmd/javac_wrapper/javac_wrapper_test.go
Colin Cross 405af07859 Revert "Make lots of tests run in parallel"
This reverts commit 323dc60712.

Reason for revert: Possible cause of test instability
Bug: 170513220
Test: soong tests

Change-Id: Iee168e9fbb4210569e6cffcc23e60d111403abb8
2020-10-09 18:34:24 -07:00

143 lines
4 KiB
Go

// Copyright 2017 Google Inc. All rights reserved.
//
// 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 main
import (
"bytes"
"io/ioutil"
"strconv"
"testing"
)
var testCases = []struct {
in, out string
}{
{
in: "File.java:40: error: cannot find symbol\n",
out: "\x1b[1mFile.java:40: \x1b[31merror:\x1b[0m\x1b[1m cannot find symbol\x1b[0m\n",
},
{
in: "import static com.blah.SYMBOL;\n",
out: "import static com.blah.SYMBOL;\n",
},
{
in: " ^ \n",
out: "\x1b[1m \x1b[32m^\x1b[0m\x1b[1m \x1b[0m\n",
},
{
in: "File.java:398: warning: [RectIntersectReturnValueIgnored] Return value of com.blah.function() must be checked\n",
out: "\x1b[1mFile.java:398: \x1b[35mwarning:\x1b[0m\x1b[1m [RectIntersectReturnValueIgnored] Return value of com.blah.function() must be checked\x1b[0m\n",
},
{
in: "warning: [options] blah\n",
out: "\x1b[1m\x1b[35mwarning:\x1b[0m\x1b[1m [options] blah\x1b[0m\n",
},
{
in: " (see http://go/errorprone/bugpattern/RectIntersectReturnValueIgnored.md)\n",
out: " (see http://go/errorprone/bugpattern/RectIntersectReturnValueIgnored.md)\n",
},
{
in: `
Note: Some input files use or override a deprecated API.
Note: Recompile with -Xlint:deprecation for details.
Note: Some input files use unchecked or unsafe operations.
Note: Recompile with -Xlint:unchecked for details.
Note: dir/file.java uses or overrides a deprecated API.
Note: dir/file.java uses unchecked or unsafe operations.
warning: [options] bootstrap class path not set in conjunction with -source 1.7
`,
out: "\n",
},
{
in: "\n",
out: "\n",
},
{
in: `
javadoc: warning - The old Doclet and Taglet APIs in the packages
com.sun.javadoc, com.sun.tools.doclets and their implementations
are planned to be removed in a future JDK release. These
components have been superseded by the new APIs in jdk.javadoc.doclet.
Users are strongly recommended to migrate to the new APIs.
javadoc: option --boot-class-path not allowed with target 1.9
`,
out: "\n",
},
{
in: `
warning: [options] bootstrap class path not set in conjunction with -source 1.9\n
1 warning
`,
out: "\n",
},
{
in: `
warning: foo
warning: [options] bootstrap class path not set in conjunction with -source 1.9\n
2 warnings
`,
out: "\n\x1b[1m\x1b[35mwarning:\x1b[0m\x1b[1m foo\x1b[0m\n1 warning\n",
},
}
func TestJavacColorize(t *testing.T) {
for i, test := range testCases {
t.Run(strconv.Itoa(i), func(t *testing.T) {
buf := new(bytes.Buffer)
proc := processor{}
err := proc.process(bytes.NewReader([]byte(test.in)), buf)
if err != nil {
t.Errorf("error: %q", err)
}
got := string(buf.Bytes())
if got != test.out {
t.Errorf("expected %q got %q", test.out, got)
}
})
}
}
func TestSubprocess(t *testing.T) {
t.Run("failure", func(t *testing.T) {
exitCode, err := Main(ioutil.Discard, "test", []string{"sh", "-c", "exit 9"})
if err != nil {
t.Fatal("unexpected error", err)
}
if exitCode != 9 {
t.Fatal("expected exit code 9, got", exitCode)
}
})
t.Run("signal", func(t *testing.T) {
exitCode, err := Main(ioutil.Discard, "test", []string{"sh", "-c", "kill -9 $$"})
if err != nil {
t.Fatal("unexpected error", err)
}
if exitCode != 137 {
t.Fatal("expected exit code 137, got", exitCode)
}
})
t.Run("success", func(t *testing.T) {
exitCode, err := Main(ioutil.Discard, "test", []string{"echo"})
if err != nil {
t.Fatal("unexpected error", err)
}
if exitCode != 0 {
t.Fatal("expected exit code 0, got", exitCode)
}
})
}