diff options
author | 2019-01-21 21:37:16 -0800 | |
---|---|---|
committer | 2019-01-23 20:17:51 +0000 | |
commit | be9cdb8d647b6f47fc427eca5e38092614171a4d (patch) | |
tree | f61e5566bc1327dd89c51b81c3b985f06dceb968 /java/plugin_test.go | |
parent | c4efd9cb55239a9cb71286781ef47371d4f391a9 (diff) |
Replace annotation_processors with plugins
Follow bazel's modules for annotation processors by introducing
a java_plugin module type that can contain extra metadata about
the annotation processor, the processor class and a flag to
specify if the annotation processor is compatible with the
turbine optimization. Deprecate the annotation_processors
property, which took a list of java_library_host modules, in
favor of the plugins property, which takes a list of java_plugin
modules. The annotation_processors property will be removed
once all uses have been replaced with plugins.
Bug: 77284273
Test: plugin_test.go
Test: m caliper
Change-Id: I37c1e80eba71ae2d6a06199fb102194a51994989
Diffstat (limited to 'java/plugin_test.go')
-rw-r--r-- | java/plugin_test.go | 124 |
1 files changed, 124 insertions, 0 deletions
diff --git a/java/plugin_test.go b/java/plugin_test.go new file mode 100644 index 000000000..7aa0164f1 --- /dev/null +++ b/java/plugin_test.go @@ -0,0 +1,124 @@ +// Copyright 2019 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 java + +import ( + "android/soong/android" + "testing" +) + +func TestNoPlugin(t *testing.T) { + ctx := testJava(t, ` + java_library { + name: "foo", + srcs: ["a.java"], + } + `) + + javac := ctx.ModuleForTests("foo", "android_common").Rule("javac") + turbine := ctx.ModuleForTests("foo", "android_common").MaybeRule("turbine") + + if turbine.Rule == nil { + t.Errorf("expected turbine to be enabled") + } + + if javac.Args["processsorpath"] != "" { + t.Errorf("want empty processorpath, got %q", javac.Args["processorpath"]) + } + + // TODO(b/77284273): test for -processor:none if no plugins are enabled + if javac.Args["processor"] != "" { + t.Errorf("want no -processor argument, got %q", javac.Args["processor"]) + } +} + +func TestPlugin(t *testing.T) { + ctx := testJava(t, ` + java_library { + name: "foo", + srcs: ["a.java"], + plugins: ["bar"], + } + + java_plugin { + name: "bar", + processor_class: "com.bar", + srcs: ["b.java"], + } + `) + + buildOS := android.BuildOs.String() + + javac := ctx.ModuleForTests("foo", "android_common").Rule("javac") + turbine := ctx.ModuleForTests("foo", "android_common").MaybeRule("turbine") + + if turbine.Rule == nil { + t.Errorf("expected turbine to be enabled") + } + + bar := ctx.ModuleForTests("bar", buildOS+"_common").Rule("javac").Output.String() + + if !inList(bar, javac.Implicits.Strings()) { + t.Errorf("foo implicits %v does not contain %q", javac.Implicits.Strings(), bar) + } + + if javac.Args["processorpath"] != "-processorpath "+bar { + t.Errorf("foo processorpath %q != '-processorpath %s'", javac.Args["processorpath"], bar) + } + + if javac.Args["processor"] != "-processor com.bar" { + t.Errorf("foo processor %q != '-processor com.bar'", javac.Args["processor"]) + } +} + +func TestPluginGeneratesApi(t *testing.T) { + ctx := testJava(t, ` + java_library { + name: "foo", + srcs: ["a.java"], + plugins: ["bar"], + } + + java_plugin { + name: "bar", + processor_class: "com.bar", + generates_api: true, + srcs: ["b.java"], + } + `) + + buildOS := android.BuildOs.String() + + javac := ctx.ModuleForTests("foo", "android_common").Rule("javac") + turbine := ctx.ModuleForTests("foo", "android_common").MaybeRule("turbine") + + if turbine.Rule != nil { + t.Errorf("expected turbine to be disabled") + } + + bar := ctx.ModuleForTests("bar", buildOS+"_common").Rule("javac").Output.String() + + if !inList(bar, javac.Implicits.Strings()) { + t.Errorf("foo implicits %v does not contain %q", javac.Implicits.Strings(), bar) + } + + if javac.Args["processorpath"] != "-processorpath "+bar { + t.Errorf("foo processorpath %q != '-processorpath %s'", javac.Args["processorpath"], bar) + } + + if javac.Args["processor"] != "-processor com.bar" { + t.Errorf("foo processor %q != '-processor com.bar'", javac.Args["processor"]) + } +} |