TestExtension

Added in 4.2.0

interface TestExtension : CommonExtension


Extension for the Android Test Gradle Plugin.

This is the android block when the com.android.test plugin is applied.

Only the Android Gradle Plugin should create instances of interfaces in com.android.build.api.dsl.

Summary

Public functions

Unit

Specifies options related to the processing of Android Resources.

Unit

A list of build features that can be enabled or disabled on the Android Project.

Unit

Encapsulates all build type configurations for this project.

Unit

Shortcut extension method to allow easy access to the predefined debug TestBuildType

Unit

Specifies defaults for variant properties that the Android plugin applies to all build variants.

Unit

Specifies options for the Android Debug Bridge (ADB), such as APK installation options.

Unit
Unit

Encapsulates all product flavors configurations for this project.

Unit

Shortcut extension method to allow easy access to the predefined release TestBuildType

Public properties

TestAndroidResources

Specifies options related to the processing of Android Resources.

TestBuildFeatures

A list of build features that can be enabled or disabled on the Android Project.

NamedDomainObjectContainer<TestBuildType>

Encapsulates all build type configurations for this project.

TestDefaultConfig

Specifies defaults for variant properties that the Android plugin applies to all build variants.

TestInstallation

Specifies options for the Android Debug Bridge (ADB), such as APK installation options.

PrivacySandbox

Options related to the consumption of privacy sandbox libraries

NamedDomainObjectContainer<TestProductFlavor>

Encapsulates all product flavors configurations for this project.

String?

The Gradle path of the project that this test project tests.

Inherited functions

From com.android.build.api.dsl.CommonExtension
Unit
aaptOptions(action: AaptOptions.() -> Unit)

This function is deprecated. Replaced by

Unit
adbOptions(action: AdbOptions.() -> Unit)

This function is deprecated. Replaced by installation

Unit
buildToolsVersion(buildToolsVersion: String)

This function is deprecated. Replaced by buildToolsVersion property

Unit

Specifies Java compiler options, such as the language level of the Java source code and generated bytecode.

Unit

Configures all aspects regarding compile Sdk version, see CompileSdkSpec for more details.

Unit
compileSdkAddon(vendor: String, name: String, version: Int)

Specify an SDK add-on to compile your project against.

Unit

This function is deprecated. Will be removed in AGP 10.0, replaced by the compileSdk block

Unit

This function is deprecated. Will be removed in AGP 10.0, replaced by the compileSdk block

Unit
Unit
dataBinding(action: DataBinding.() -> Unit)

Specifies options for the Data Binding Library.

Unit

Specifies options for external native build using CMake or ndk-build.

File
Unit

This function is deprecated. Renamed to testCoverage

Unit
lint(action: Lint.() -> Unit)

Specifies options for the lint tool.

Unit

This function is deprecated. Renamed to lint

Unit
packaging(action: Packaging.() -> Unit)

Specifies options and rules that determine which files the Android plugin packages into your APK.

Unit

This function is deprecated. Renamed to packaging

Unit

Encapsulates signing configurations that you can apply to BuildType and ProductFlavor configurations.

Unit

Encapsulates source set configurations for all variants.

Unit
splits(action: Splits.() -> Unit)

Specifies configurations for building multiple APKs or APK splits.

Unit

Configure the gathering of code-coverage from tests.

Unit
testOptions(action: TestOptions.() -> Unit)

Specifies options for how the Android plugin should run local and instrumented tests.

Unit

Includes the specified library to the classpath.

Unit
useLibrary(name: String, required: Boolean)

Includes the specified library to the classpath.

Unit
viewBinding(action: ViewBinding.() -> Unit)

Specifies options for the View Binding Library.

Inherited properties

From com.android.build.api.dsl.CommonExtension
AaptOptions

This property is deprecated. Replaced by

AdbOptions

This property is deprecated. Replaced by installation

String

Specifies the version of the SDK Build Tools to use when building your project.

CompileOptions

Specifies Java compiler options, such as the language level of the Java source code and generated bytecode.

Int?

Specifies the API level to compile your project against.

Int?

Specifies the SDK Extension level to compile your project against.

Int?

Specify a minor API version for the compile SDK.

String?

Specify a preview API to compile your project against.

ComposeOptions
DataBinding

Specifies options for the Data Binding Library.

MutableMap<StringAny>

Additional per module experimental properties.

ExternalNativeBuild

Specifies options for external native build using CMake or ndk-build.

MutableList<String>

Specifies the names of product flavor dimensions for this project.

JacocoOptions

This property is deprecated. Renamed to testCoverage

Lint

Specifies options for the lint tool.

LintOptions

This property is deprecated. Renamed to lint

String?

The namespace of the generated R and BuildConfig classes.

String?

Requires the specified path to NDK be used.

String

Requires the specified NDK version to be used.

Packaging

Specifies options and rules that determine which files the Android plugin packages into your APK.

Packaging

This property is deprecated. Renamed to packaging

String?

Specifies this project's resource prefix to Android Studio for editor features, such as Lint checks.

SdkComponents
NamedDomainObjectContainer<ApkSigningConfig>

Encapsulates signing configurations that you can apply to [ ] and [ ] configurations.

NamedDomainObjectContainer<AndroidSourceSet>

Encapsulates source set configurations for all variants.

Splits

Specifies configurations for building multiple APKs or APK splits.

TestCoverage

Configure the gathering of code-coverage from tests.

TestOptions

Specifies options for how the Android plugin should run local and instrumented tests.

ViewBinding

Specifies options for the View Binding Library.

Public functions

androidResources

Added in 9.0.0-alpha02
fun androidResources(action: TestAndroidResources.() -> Unit): Unit

Specifies options related to the processing of Android Resources.

For more information about the properties you can configure in this block, see TestAndroidResources.

buildFeatures

Added in 9.0.0-alpha02
fun buildFeatures(action: TestBuildFeatures.() -> Unit): Unit

A list of build features that can be enabled or disabled on the Android Project.

buildTypes

Added in 9.0.0-alpha02
fun buildTypes(action: NamedDomainObjectContainer<TestBuildType>.() -> Unit): Unit

Encapsulates all build type configurations for this project.

For more information about the properties you can configure in this block, see TestBuildType

debug

Added in 9.0.0-alpha02
fun NamedDomainObjectContainer<TestBuildType>.debug(action: TestBuildType.() -> Unit): Unit

Shortcut extension method to allow easy access to the predefined debug TestBuildType

For example:

 android {
buildTypes {
debug {
// ...
}
}
}

defaultConfig

Added in 9.0.0-alpha02
fun defaultConfig(action: TestDefaultConfig.() -> Unit): Unit

Specifies defaults for variant properties that the Android plugin applies to all build variants.

You can override any defaultConfig property when configuring product flavors

For more information about the properties you can configure in this block, see DefaultConfig.

installation

Added in 9.0.0-alpha02
fun installation(action: TestInstallation.() -> Unit): Unit

Specifies options for the Android Debug Bridge (ADB), such as APK installation options.

For more information about the properties you can configure in this block, see AdbOptions.

privacySandbox

Added in 8.5.0
fun privacySandbox(action: PrivacySandbox.() -> Unit): Unit

productFlavors

Added in 9.0.0-alpha02
fun productFlavors(action: NamedDomainObjectContainer<TestProductFlavor>.() -> Unit): Unit

Encapsulates all product flavors configurations for this project.

For more information about the properties you can configure in this block, see ProductFlavor

release

Added in 9.0.0-alpha02
fun NamedDomainObjectContainer<TestBuildType>.release(action: TestBuildType.() -> Unit): Unit

Shortcut extension method to allow easy access to the predefined release TestBuildType

For example:

 android {
buildTypes {
release {
// ...
}
}
}

Public properties

androidResources

val androidResourcesTestAndroidResources

Specifies options related to the processing of Android Resources.

For more information about the properties you can configure in this block, see TestAndroidResources.

buildFeatures

val buildFeaturesTestBuildFeatures

A list of build features that can be enabled or disabled on the Android Project.

buildTypes

val buildTypesNamedDomainObjectContainer<TestBuildType>

Encapsulates all build type configurations for this project.

Unlike using TestProductFlavor to create different versions of your project that you expect to co-exist on a single device, build types determine how Gradle builds and packages each version of your project. Developers typically use them to configure projects for various stages of a development lifecycle. For example, when creating a new project from Android Studio, the Android plugin configures a 'debug' and 'release' build type for you. You can then combine build types with product flavors to create build variants.

See also
BuildType

defaultConfig

val defaultConfigTestDefaultConfig

Specifies defaults for variant properties that the Android plugin applies to all build variants.

You can override any defaultConfig property when configuring product flavors

For more information about the properties you can configure in this block, see DefaultConfig.

installation

val installationTestInstallation

Specifies options for the Android Debug Bridge (ADB), such as APK installation options.

For more information about the properties you can configure in this block, see AdbOptions.

privacySandbox

Added in 8.5.0
val privacySandboxPrivacySandbox

Options related to the consumption of privacy sandbox libraries

productFlavors

val productFlavorsNamedDomainObjectContainer<TestProductFlavor>

Encapsulates all product flavors configurations for this project.

Product flavors represent different versions of your project that you expect to co-exist on a single device, the Google Play store, or repository. For example, you can configure 'demo' and 'full' product flavors for your app, and each of those flavors can specify different features, device requirements, resources, and application ID's--while sharing common source code and resources. So, product flavors allow you to output different versions of your project by simply changing only the components and settings that are different between them.

Configuring product flavors is similar to configuring build types: add them to the productFlavors block of your project's build.gradle file and configure the settings you want. Product flavors support the same properties as the defaultConfig block--this is because defaultConfig defines an object that the plugin uses as the base configuration for all other flavors. Each flavor you configure can then override any of the default values in defaultConfig, such as the applicationId.

When using Android plugin 3.0.0 and higher, each flavor must belong to a com.android.build.gradle.BaseExtension.html#com.android.build.gradle.BaseExtension:flavorDimensions(java.lang.String[]) value. By default, when you specify only one dimension, all flavors you configure belong to that dimension. If you specify more than one flavor dimension, you need to manually assign each flavor to a dimension. To learn more, read Use Flavor Dimensions for variant-aware dependency management.

When you configure product flavors, the Android plugin automatically combines them with your BuildType configurations to create build variants. If the plugin creates certain build variants that you don't want, you can filter variants.

See also
ProductFlavor

targetProjectPath

Added in 4.2.0
var targetProjectPathString?

The Gradle path of the project that this test project tests.