xref: /aosp_15_r20/build/soong/java/droiddoc_test.go (revision 333d2b3687b3a337dbcca9d65000bca186795e39)
1*333d2b36SAndroid Build Coastguard Worker// Copyright 2021 Google Inc. All rights reserved.
2*333d2b36SAndroid Build Coastguard Worker//
3*333d2b36SAndroid Build Coastguard Worker// Licensed under the Apache License, Version 2.0 (the "License");
4*333d2b36SAndroid Build Coastguard Worker// you may not use this file except in compliance with the License.
5*333d2b36SAndroid Build Coastguard Worker// You may obtain a copy of the License at
6*333d2b36SAndroid Build Coastguard Worker//
7*333d2b36SAndroid Build Coastguard Worker//     http://www.apache.org/licenses/LICENSE-2.0
8*333d2b36SAndroid Build Coastguard Worker//
9*333d2b36SAndroid Build Coastguard Worker// Unless required by applicable law or agreed to in writing, software
10*333d2b36SAndroid Build Coastguard Worker// distributed under the License is distributed on an "AS IS" BASIS,
11*333d2b36SAndroid Build Coastguard Worker// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12*333d2b36SAndroid Build Coastguard Worker// See the License for the specific language governing permissions and
13*333d2b36SAndroid Build Coastguard Worker// limitations under the License.
14*333d2b36SAndroid Build Coastguard Worker
15*333d2b36SAndroid Build Coastguard Workerpackage java
16*333d2b36SAndroid Build Coastguard Worker
17*333d2b36SAndroid Build Coastguard Workerimport (
18*333d2b36SAndroid Build Coastguard Worker	"reflect"
19*333d2b36SAndroid Build Coastguard Worker	"strings"
20*333d2b36SAndroid Build Coastguard Worker	"testing"
21*333d2b36SAndroid Build Coastguard Worker
22*333d2b36SAndroid Build Coastguard Worker	"android/soong/android"
23*333d2b36SAndroid Build Coastguard Worker)
24*333d2b36SAndroid Build Coastguard Worker
25*333d2b36SAndroid Build Coastguard Workerfunc TestDroiddoc(t *testing.T) {
26*333d2b36SAndroid Build Coastguard Worker	ctx, _ := testJavaWithFS(t, `
27*333d2b36SAndroid Build Coastguard Worker		droiddoc_exported_dir {
28*333d2b36SAndroid Build Coastguard Worker		    name: "droiddoc-templates-sdk",
29*333d2b36SAndroid Build Coastguard Worker		    path: ".",
30*333d2b36SAndroid Build Coastguard Worker		}
31*333d2b36SAndroid Build Coastguard Worker		filegroup {
32*333d2b36SAndroid Build Coastguard Worker		    name: "bar-doc-aidl-srcs",
33*333d2b36SAndroid Build Coastguard Worker		    srcs: ["bar-doc/IBar.aidl"],
34*333d2b36SAndroid Build Coastguard Worker		    path: "bar-doc",
35*333d2b36SAndroid Build Coastguard Worker		}
36*333d2b36SAndroid Build Coastguard Worker		droidstubs {
37*333d2b36SAndroid Build Coastguard Worker		    name: "bar-stubs",
38*333d2b36SAndroid Build Coastguard Worker		    srcs: [
39*333d2b36SAndroid Build Coastguard Worker		        "bar-doc/a.java",
40*333d2b36SAndroid Build Coastguard Worker		    ],
41*333d2b36SAndroid Build Coastguard Worker		    exclude_srcs: [
42*333d2b36SAndroid Build Coastguard Worker		        "bar-doc/b.java"
43*333d2b36SAndroid Build Coastguard Worker		    ],
44*333d2b36SAndroid Build Coastguard Worker		    api_levels_annotations_dirs: [
45*333d2b36SAndroid Build Coastguard Worker		      "droiddoc-templates-sdk",
46*333d2b36SAndroid Build Coastguard Worker		    ],
47*333d2b36SAndroid Build Coastguard Worker		    api_levels_annotations_enabled: true,
48*333d2b36SAndroid Build Coastguard Worker		}
49*333d2b36SAndroid Build Coastguard Worker		droiddoc {
50*333d2b36SAndroid Build Coastguard Worker		    name: "bar-doc",
51*333d2b36SAndroid Build Coastguard Worker		    srcs: [
52*333d2b36SAndroid Build Coastguard Worker		        ":bar-stubs",
53*333d2b36SAndroid Build Coastguard Worker		        "bar-doc/IFoo.aidl",
54*333d2b36SAndroid Build Coastguard Worker		        ":bar-doc-aidl-srcs",
55*333d2b36SAndroid Build Coastguard Worker		    ],
56*333d2b36SAndroid Build Coastguard Worker		    custom_template: "droiddoc-templates-sdk",
57*333d2b36SAndroid Build Coastguard Worker		    hdf: [
58*333d2b36SAndroid Build Coastguard Worker		        "android.whichdoc offline",
59*333d2b36SAndroid Build Coastguard Worker		    ],
60*333d2b36SAndroid Build Coastguard Worker		    knowntags: [
61*333d2b36SAndroid Build Coastguard Worker		        "bar-doc/known_oj_tags.txt",
62*333d2b36SAndroid Build Coastguard Worker		    ],
63*333d2b36SAndroid Build Coastguard Worker		    proofread_file: "libcore-proofread.txt",
64*333d2b36SAndroid Build Coastguard Worker		    todo_file: "libcore-docs-todo.html",
65*333d2b36SAndroid Build Coastguard Worker		    flags: ["-offlinemode -title \"libcore\""],
66*333d2b36SAndroid Build Coastguard Worker		}
67*333d2b36SAndroid Build Coastguard Worker		`,
68*333d2b36SAndroid Build Coastguard Worker		map[string][]byte{
69*333d2b36SAndroid Build Coastguard Worker			"bar-doc/a.java": nil,
70*333d2b36SAndroid Build Coastguard Worker			"bar-doc/b.java": nil,
71*333d2b36SAndroid Build Coastguard Worker		})
72*333d2b36SAndroid Build Coastguard Worker	barStubsOutputs := ctx.ModuleForTests("bar-stubs", "android_common").OutputFiles(ctx, t, "")
73*333d2b36SAndroid Build Coastguard Worker	if len(barStubsOutputs) != 1 {
74*333d2b36SAndroid Build Coastguard Worker		t.Errorf("Expected one output from \"bar-stubs\" got %s", barStubsOutputs)
75*333d2b36SAndroid Build Coastguard Worker	}
76*333d2b36SAndroid Build Coastguard Worker
77*333d2b36SAndroid Build Coastguard Worker	barStubsOutput := barStubsOutputs[0]
78*333d2b36SAndroid Build Coastguard Worker	barDoc := ctx.ModuleForTests("bar-doc", "android_common")
79*333d2b36SAndroid Build Coastguard Worker	javaDoc := barDoc.Rule("javadoc")
80*333d2b36SAndroid Build Coastguard Worker	if g, w := android.PathsRelativeToTop(javaDoc.Implicits), android.PathRelativeToTop(barStubsOutput); !inList(w, g) {
81*333d2b36SAndroid Build Coastguard Worker		t.Errorf("implicits of bar-doc must contain %q, but was %q.", w, g)
82*333d2b36SAndroid Build Coastguard Worker	}
83*333d2b36SAndroid Build Coastguard Worker
84*333d2b36SAndroid Build Coastguard Worker	expected := "-sourcepath out/soong/.intermediates/bar-doc/android_common/srcjars "
85*333d2b36SAndroid Build Coastguard Worker	if !strings.Contains(javaDoc.RuleParams.Command, expected) {
86*333d2b36SAndroid Build Coastguard Worker		t.Errorf("bar-doc command does not contain flag %q, but should\n%q", expected, javaDoc.RuleParams.Command)
87*333d2b36SAndroid Build Coastguard Worker	}
88*333d2b36SAndroid Build Coastguard Worker
89*333d2b36SAndroid Build Coastguard Worker	aidl := barDoc.Rule("aidl")
90*333d2b36SAndroid Build Coastguard Worker	if g, w := android.PathsRelativeToTop(javaDoc.Implicits), android.PathRelativeToTop(aidl.Output); !inList(w, g) {
91*333d2b36SAndroid Build Coastguard Worker		t.Errorf("implicits of bar-doc must contain %q, but was %q.", w, g)
92*333d2b36SAndroid Build Coastguard Worker	}
93*333d2b36SAndroid Build Coastguard Worker
94*333d2b36SAndroid Build Coastguard Worker	if g, w := aidl.Implicits.Strings(), []string{"bar-doc/IBar.aidl", "bar-doc/IFoo.aidl"}; !reflect.DeepEqual(w, g) {
95*333d2b36SAndroid Build Coastguard Worker		t.Errorf("aidl inputs must be %q, but was %q", w, g)
96*333d2b36SAndroid Build Coastguard Worker	}
97*333d2b36SAndroid Build Coastguard Worker}
98*333d2b36SAndroid Build Coastguard Worker
99*333d2b36SAndroid Build Coastguard Workerfunc TestDroiddocArgsAndFlagsCausesError(t *testing.T) {
100*333d2b36SAndroid Build Coastguard Worker	testJavaError(t, "flags is set. Cannot set args", `
101*333d2b36SAndroid Build Coastguard Worker		droiddoc_exported_dir {
102*333d2b36SAndroid Build Coastguard Worker		    name: "droiddoc-templates-sdk",
103*333d2b36SAndroid Build Coastguard Worker		    path: ".",
104*333d2b36SAndroid Build Coastguard Worker		}
105*333d2b36SAndroid Build Coastguard Worker		filegroup {
106*333d2b36SAndroid Build Coastguard Worker		    name: "bar-doc-aidl-srcs",
107*333d2b36SAndroid Build Coastguard Worker		    srcs: ["bar-doc/IBar.aidl"],
108*333d2b36SAndroid Build Coastguard Worker		    path: "bar-doc",
109*333d2b36SAndroid Build Coastguard Worker		}
110*333d2b36SAndroid Build Coastguard Worker		droidstubs {
111*333d2b36SAndroid Build Coastguard Worker		    name: "bar-stubs",
112*333d2b36SAndroid Build Coastguard Worker		    srcs: [
113*333d2b36SAndroid Build Coastguard Worker		        "bar-doc/a.java",
114*333d2b36SAndroid Build Coastguard Worker		    ],
115*333d2b36SAndroid Build Coastguard Worker		    exclude_srcs: [
116*333d2b36SAndroid Build Coastguard Worker		        "bar-doc/b.java"
117*333d2b36SAndroid Build Coastguard Worker		    ],
118*333d2b36SAndroid Build Coastguard Worker		    api_levels_annotations_dirs: [
119*333d2b36SAndroid Build Coastguard Worker		      "droiddoc-templates-sdk",
120*333d2b36SAndroid Build Coastguard Worker		    ],
121*333d2b36SAndroid Build Coastguard Worker		    api_levels_annotations_enabled: true,
122*333d2b36SAndroid Build Coastguard Worker		}
123*333d2b36SAndroid Build Coastguard Worker		droiddoc {
124*333d2b36SAndroid Build Coastguard Worker		    name: "bar-doc",
125*333d2b36SAndroid Build Coastguard Worker		    srcs: [
126*333d2b36SAndroid Build Coastguard Worker		        ":bar-stubs",
127*333d2b36SAndroid Build Coastguard Worker		        "bar-doc/IFoo.aidl",
128*333d2b36SAndroid Build Coastguard Worker		        ":bar-doc-aidl-srcs",
129*333d2b36SAndroid Build Coastguard Worker		    ],
130*333d2b36SAndroid Build Coastguard Worker		    custom_template: "droiddoc-templates-sdk",
131*333d2b36SAndroid Build Coastguard Worker		    hdf: [
132*333d2b36SAndroid Build Coastguard Worker		        "android.whichdoc offline",
133*333d2b36SAndroid Build Coastguard Worker		    ],
134*333d2b36SAndroid Build Coastguard Worker		    knowntags: [
135*333d2b36SAndroid Build Coastguard Worker		        "bar-doc/known_oj_tags.txt",
136*333d2b36SAndroid Build Coastguard Worker		    ],
137*333d2b36SAndroid Build Coastguard Worker		    proofread_file: "libcore-proofread.txt",
138*333d2b36SAndroid Build Coastguard Worker		    todo_file: "libcore-docs-todo.html",
139*333d2b36SAndroid Build Coastguard Worker		    flags: ["-offlinemode -title \"libcore\""],
140*333d2b36SAndroid Build Coastguard Worker		    args: "-offlinemode -title \"libcore\"",
141*333d2b36SAndroid Build Coastguard Worker		}
142*333d2b36SAndroid Build Coastguard Worker		`)
143*333d2b36SAndroid Build Coastguard Worker}
144