IBuildInfo

public interface IBuildInfo

com.android.tradefed.build.IBuildInfo


包含有关被测 build 的信息。

摘要

常量

String REMOTE_FILE_PREFIX

名称中使用的前缀,表示文件已设置为延迟下载。

String REMOTE_FILE_VERSION

远程文件未进行版本控制。

String UNKNOWN_BUILD_ID

当 build ID 未知时,默认值。

公共方法

default void addAppPackageFile(File appPackageFile, String version)

添加本地 apk 文件及其关联的版本。

abstract void addBuildAttribute(String attributeName, String attributeValue)

添加 build 属性。

default void addBuildAttributes( buildAttributes)

添加 build 属性

default void allowStagingRemoteFile(boolean stageRemoteFile)

设置权限以允许暂存远程文件。

abstract void cleanUp()

清理所有临时 build 文件

abstract void cleanUp( doNotDelete)

某个 cleanUp() 版本,其中部分文件未被删除。

abstract IBuildInfo clone()

克隆 IBuildInfo 对象。

default getAppPackageFiles()

获取一组本地应用 APK 文件及其版本的副本。

abstract getBuildAttributes()

获取一组用于描述 build 的其他属性的名称值对。

abstract String getBuildBranch()

用于返回被测 build 的来源代码库分支的可选方法。

abstract String getBuildFlavor()

用于返回被测 build 类型的可选方法。

abstract String getBuildId()

返回被测 build 的唯一标识符。

abstract String getBuildTargetName()

返回要测试的 build 的完整名称。

abstract String getDeviceSerial()
abstract File getFile(String name)

用于检索指定名称的文件的辅助方法。

default File getFile(BuildInfoKey.BuildInfoFileKey key)

用于检索给定 BuildInfoFileKey 的文件的辅助方法。

abstract getFiles()

返回此 BuildInfo 中存储的所有 VersionedFile

abstract getProperties()

返回当前在 IBuildInfo 上设置的属性的副本。

default getRemoteFiles()

获取延迟下载的 build 工件的路径。

abstract String getTestTag()

返回正在运行的测试的唯一名称。

default String getVersion(BuildInfoKey.BuildInfoFileKey key)

用于检索给定 BuildInfoFileKey 的文件版本的辅助方法。

abstract String getVersion(String name)

用于检索指定名称的文件版本的辅助方法。

default VersionedFile getVersionedFile(BuildInfoKey.BuildInfoFileKey key)

用于使用给定 BuildInfoFileKey 检索 VersionedFile 的辅助方法。

default VersionedFile getVersionedFile(String name)

用于检索具有指定名称的 VersionedFile 的辅助方法。

default getVersionedFileKeys()

返回可通过 getFile(BuildInfoFileKey) 查询 VersionedFile 的一组键。

default getVersionedFiles(BuildInfoKey.BuildInfoFileKey key)

用于检索与给定 BuildInfoFileKey 关联的 VersionedFile 列表的辅助方法。

default void removeBuildAttribute(String attributeName)

从跟踪中移除指定的 attributeName。

abstract void setBuildBranch(String branch)

设置 build 分支

abstract void setBuildFlavor(String buildFlavor)

设置 build 变种。

abstract void setBuildId(String buildId)

设置被测 build 的唯一标识符。

abstract void setDeviceSerial(String serial)

设置与此 build 关联的 ITestDevice 序列号。

abstract void setFile(String name, File file, String version)

在此 build 信息中存储一个指定名称的文件。

default void setFile(BuildInfoKey.BuildInfoFileKey key, File file, String version)

在此 build 信息中根据 BuildInfoFileKey 存储文件。

abstract void setProperties(BuildInfoProperties... properties)

IBuildInfo 实例设置 BuildInfoProperties

abstract void setTestTag(String testTag)

为正在运行的测试设置唯一名称。

default File stageRemoteFile(String fileName, File workingDir)

在 build 信息的根目录中暂存属于远程文件的文件。

default BuildInformation.BuildInfo toProto()

将 BuildInfo 实例序列化为 protobuf。

常量

REMOTE_FILE_PREFIX

public static final String REMOTE_FILE_PREFIX

名称中使用的前缀,表示文件已设置为延迟下载。

常量值: "remote_file:"

REMOTE_FILE_VERSION

public static final String REMOTE_FILE_VERSION

远程文件未进行版本控制。

常量值: ""

UNKNOWN_BUILD_ID

public static final String UNKNOWN_BUILD_ID

当 build ID 未知时,默认值。

常量值: “-1”

公共方法

addAppPackageFile

public void addAppPackageFile (File appPackageFile, 
                String version)

添加本地 apk 文件及其关联的版本。请注意,getAppPackageFiles() 将按此方法添加 apk 的顺序返回 apk。

参数
appPackageFile File

version String

addBuildAttribute

public abstract void addBuildAttribute (String attributeName, 
                String attributeValue)

添加 build 属性。这不允许替换现有的 attributeName。

参数
attributeName String:具有唯一性的属性名称

attributeValue String:属性值

addBuildAttributes

public void addBuildAttributes ( buildAttributes)

添加 build 属性

参数
buildAttributes :要添加的属性的映射

allowStagingRemoteFile

public void allowStagingRemoteFile (boolean stageRemoteFile)

设置权限以允许暂存远程文件。

参数
stageRemoteFile boolean

cleanUp

public abstract void cleanUp ()

清理所有临时 build 文件

cleanUp

public abstract void cleanUp ( doNotDelete)

某些文件不会被删除的 cleanUp() 版本。

参数
doNotDelete

clone

public abstract IBuildInfo clone ()

克隆 IBuildInfo 对象。

返回
IBuildInfo

getAppPackageFiles

public  getAppPackageFiles ()

获取一组本地应用 APK 文件及其版本的副本。返回的顺序与 apk 添加到 IAppBuildInfo 的顺序一致。

返回

getBuildAttributes

public abstract  getBuildAttributes ()

获取一组用于描述 build 的其他属性的名称值对。

返回
build 属性的 ERROR(/Map)。不得为 null,但可以为空。

getBuildBranch

public abstract String getBuildBranch ()

用于返回被测 build 的来源代码控制分支的可选方法。

返回
String build 分支或 null(如果未设置/不适用)

getBuildFlavor

public abstract String getBuildFlavor ()

用于返回被测 build 类型的可选方法。

Android 平台 build 的常见实现是返回 (build product)-(build os)-(build variant)。ie generic-linux-userdebug

返回
String build 变种或 null(如果未设置/不适用)

getBuildId

public abstract String getBuildId ()

返回被测 build 的唯一标识符。不得为 null。默认为 UNKNOWN_BUILD_ID

返回
String

getBuildTargetName

public abstract String getBuildTargetName ()

返回要测试的 build 的完整名称。

常见的实现是通过构建变种和分支名称的组合来构建 build 目标名称。[即 (branch name)-(build flavor)]

返回
String

getDeviceSerial

public abstract String getDeviceSerial ()

返回
String 此 build 的执行序列 ITestDevice。如果没有设备与此 build 相关联,则返回 null

getFile

public abstract File getFile (String name)

用于检索指定名称的文件的辅助方法。

返回
File 图片文件或 null(如果找不到)

getFile

public File getFile (BuildInfoKey.BuildInfoFileKey key)

用于检索给定 BuildInfoFileKey 的文件的辅助方法。

参数
key BuildInfoKey.BuildInfoFileKey:请求的 BuildInfoFileKey

返回
File 图片文件或 null(如果找不到)

getFiles

public abstract  getFiles ()

返回此 BuildInfo 中存储的所有 VersionedFile

返回

getProperties

public abstract  getProperties ()

返回当前在 IBuildInfo 上设置的属性的副本。

返回

getRemoteFiles

public  getRemoteFiles ()

获取延迟下载的 build 工件的路径。

返回

getTestTag

public abstract String getTestTag ()

返回正在运行的测试的唯一名称。

返回
String

getVersion

public String getVersion (BuildInfoKey.BuildInfoFileKey key)

用于检索给定 BuildInfoFileKey 的文件版本的辅助方法。

参数
key BuildInfoKey.BuildInfoFileKey:请求的 BuildInfoFileKey

返回
String 映像版本,如果未找到则为 null

getVersion

public abstract String getVersion (String name)

用于检索指定名称的文件版本的辅助方法。

返回
String 映像版本,如果未找到则为 null

getVersionedFile

public VersionedFile getVersionedFile (BuildInfoKey.BuildInfoFileKey key)

用于使用给定 BuildInfoFileKey 检索 VersionedFile 的辅助方法。

参数
key BuildInfoKey.BuildInfoFileKey:请求的 BuildInfoFileKey

返回
VersionedFile 版本化文件或 null(如果未找到)

getVersionedFile

public VersionedFile getVersionedFile (String name)

用于检索具有指定名称的 VersionedFile 的辅助方法。

返回
VersionedFile 版本化文件或 null(如果未找到)

getVersionedFileKeys

public  getVersionedFileKeys ()

返回可通过 getFile(BuildInfoFileKey) 查询 VersionedFile 的一组键。

返回

getVersionedFiles

public  getVersionedFiles (BuildInfoKey.BuildInfoFileKey key)

用于检索与给定 BuildInfoFileKey 关联的 VersionedFile 列表的辅助方法。键是否允许存储列表。

参数
key BuildInfoKey.BuildInfoFileKey:请求的 BuildInfoFileKey

返回
版本化文件或 null(如果未找到)

removeBuildAttribute

public void removeBuildAttribute (String attributeName)

从跟踪中移除指定的 attributeName。

参数
attributeName String:要停止跟踪的属性

setBuildBranch

public abstract void setBuildBranch (String branch)

设置 build 分支

参数
branch String:分支名称

setBuildFlavor

public abstract void setBuildFlavor (String buildFlavor)

设置 build 变种。

setBuildId

public abstract void setBuildId (String buildId)

设置要测试的 build 的唯一标识符。不得为 null。

参数
buildId String

setDeviceSerial

public abstract void setDeviceSerial (String serial)

设置与此 build 关联的 ITestDevice 序列号。

参数
serial String:用于执行此 build 的 ITestDevice 的序列号。

setFile

public abstract void setFile (String name, 
                File file, 
                String version)

在此 build 信息中存储一个指定名称的文件。

参数
name String:文件的唯一名称

file File:本地 ERROR(/File)

version String:文件版本

setFile

public void setFile (BuildInfoKey.BuildInfoFileKey key, 
                File file, 
                String version)

在此 build 信息中根据 BuildInfoFileKey 存储文件。

参数
key BuildInfoKey.BuildInfoFileKey:基于 BuildInfoFileKey 的文件的唯一名称。

file File:本地 ERROR(/File)

version String:文件版本

setProperties

public abstract void setProperties (BuildInfoProperties... properties)

IBuildInfo 实例设置 BuildInfoProperties。替换之前设置的所有现有属性。

参数
properties BuildInfoProperties:要添加的媒体资源列表。

setTestTag

public abstract void setTestTag (String testTag)

为正在运行的测试设置唯一名称。

参数
testTag String

stageRemoteFile

public File stageRemoteFile (String fileName, 
                File workingDir)

在 build 信息的根目录中暂存属于远程文件的文件。

TODO(b/138416078):当测试所需的模块可以正确构建并输出到测试模块的目录本身时,移除此接口及其调用方。

参数
fileName String:要位于远程文件中的文件的名称。

workingDir File:要将文件暂存到其中的目录的 ERROR(/File) 对象。

返回
File 在本地 workingDir 中暂存的文件的 ERROR(/File) 对象。

toProto

public BuildInformation.BuildInfo toProto ()

将 BuildInfo 实例序列化为 protobuf。

返回
BuildInformation.BuildInfo