//
|
// Copyright (C) 2016 The Android Open Source Project
|
//
|
// 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.
|
//
|
|
// Build jacoco-agent from sources for the platform
|
//
|
// Note: this is only intended to be used for the platform development. This is *not* intended
|
// to be used in the SDK where apps can use the official jacoco release.
|
java_library {
|
name: "jacocoagent",
|
installable: true,
|
|
srcs: [
|
"org.jacoco.core/src/**/*.java",
|
"org.jacoco.agent/src/**/*.java",
|
"org.jacoco.agent.rt/src/**/*.java",
|
],
|
|
// Some Jacoco source files depend on classes that do not exist in Android.
|
// While these classes are not executed at runtime (because we use offline
|
// instrumentation), they will cause issues when compiling them with ART
|
// during dex pre-opting. Therefore, it would prevent from applying code
|
// coverage on classes in the bootclasspath (frameworks, services, ...) or
|
// system apps.
|
// Note: we still may need to update the source code to cut dependencies in
|
// mandatory jacoco classes.
|
exclude_srcs: [
|
"org.jacoco.core/src/org/jacoco/core/runtime/ModifiedSystemClassRuntime.java",
|
"org.jacoco.agent.rt/src/org/jacoco/agent/rt/internal/PreMain.java",
|
"org.jacoco.agent.rt/src/org/jacoco/agent/rt/internal/CoverageTransformer.java",
|
"org.jacoco.agent.rt/src/org/jacoco/agent/rt/internal/JmxRegistration.java",
|
],
|
|
// In order to include Jacoco in core libraries, we cannot depend on
|
// anything in the bootclasspath (or we would create dependency cycle).
|
// Therefore we compile against the SDK android.jar which gives the same
|
// APIs Jacoco depends on.
|
sdk_version: "9",
|
|
// TODO(b/69671801): there's no bytecode on the device, so these shouldn't
|
// be necessary.
|
static_libs: [
|
"asm-6.0",
|
"asm-commons-6.0",
|
"asm-tree-6.0",
|
],
|
}
|
|
// Generates stubs containing the classes that will be referenced by instrumented bytecode.
|
droidstubs {
|
name: "jacoco-stubs-gen",
|
srcs: ["org.jacoco.agent.rt/src/org/jacoco/agent/rt/internal/Offline.java"],
|
}
|
|
// A stubs target containing the parts of JaCoCo that we need to add to the hidden API whitelist.
|
java_library {
|
name: "jacoco-stubs",
|
compile_dex: true,
|
srcs: [":jacoco-stubs-gen"],
|
}
|
|
// Build jacoco-cli from sources for the platform
|
|
// TODO(jeffrygaston) it'd be nice to keep the build process and/or list of source files in sync with
|
// what is defined in the pom.xml files, although it's probably much more trouble than it's worth
|
java_library_host {
|
name: "jacoco-cli",
|
|
manifest: "org.jacoco.cli/src/MANIFEST.MF",
|
|
srcs: [
|
"org.jacoco.core/src/**/*.java",
|
"org.jacoco.report/src/**/*.java",
|
"org.jacoco.cli/src/**/*.java",
|
],
|
|
java_resource_dirs: [
|
"org.jacoco.core/src",
|
"org.jacoco.report/src",
|
],
|
|
static_libs: [
|
"asm-6.0",
|
"asm-commons-6.0",
|
"asm-tree-6.0",
|
"args4j-2.0.28",
|
],
|
|
dist: {
|
targets: [
|
"dist_files",
|
"apps_only",
|
],
|
},
|
}
|