// // 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, apex_available: [ "//apex_available:anyapex", "//apex_available:platform", ], 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-7.0", "asm-commons-7.0", "asm-tree-7.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", "org.jacoco.core/src/org/jacoco/core/data/IExecutionData.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-7.0", "asm-commons-7.0", "asm-tree-7.0", "args4j-2.0.28", ], dist: { targets: [ "dist_files", "apps_only", ], }, }