InstrumentedFilesInfo

7.3 · 7.2 · 7.1 · 7.0 · 6.5

코드 커버리지 데이터 수집을 위해 --instrumentation_filter와 일치하는 규칙 타겟의 소스 파일 및 계측 메타데이터 파일에 관한 정보를 포함합니다. 적용 범위 데이터 수집이 사용 설정된 경우 instrumented_filesmetadata_files의 결합된 경로가 포함된 매니페스트가 테스트 작업에 입력으로 전달되며, 매니페스트의 경로는 환경 변수 COVERAGE_MANIFEST에 표시됩니다. 메타데이터 파일(소스 파일은 아님)도 테스트 작업에 입력으로 전달됩니다. InstrumentedFilesInfoAspect의 구현 함수에서 반환되면 기본 규칙 대상의 InstrumentedFilesInfo는 무시됩니다.

회원

instrumented_files

depset InstrumentedFilesInfo.instrumented_files

이 타겟 및 종속 항목의 계측된 소스 파일을 나타내는 File 객체의 depset입니다.

metadata_files

depset InstrumentedFilesInfo.metadata_files

이 타겟과 해당 종속 항목의 적용 범위 메타데이터 파일을 나타내는 File 객체의 depset입니다. 이러한 파일에는 코드가 실행된 후 LCOV 형식의 노출 영역 출력을 생성하는 데 필요한 추가 정보가 포함됩니다(예: gcc-ftest-coverage와 함께 실행될 때 생성된 .gcno 파일).

to_json

string InstrumentedFilesInfo.to_json()

지원 중단되었습니다. 이 API는 지원 중단되었으며 곧 삭제됩니다. 이 방법을 사용하지 마세요. ---incompatible_struct_has_no_methods사용 중지됩니다. 이 플래그를 사용하여 코드가 곧 삭제되는 것과 호환되는지 확인합니다.
구조체 매개변수에서 JSON 문자열을 만듭니다. 이 메서드는 모든 구조체 요소가 문자열, 정수, 불리언, 기타 구조체, 이러한 유형의 목록 또는 이러한 유형의 문자열 키와 값을 포함하는 사전인 경우에만 작동합니다 (재귀적으로). 문자열의 따옴표와 새 줄은 이스케이프 처리됩니다. 예를 들면 다음과 같습니다.
struct(key=123).to_json()
# {"key":123}

struct(key=True).to_json()
# {"key":true}

struct(key=[1, 2, 3]).to_json()
# {"key":[1,2,3]}

struct(key='text').to_json()
# {"key":"text"}

struct(key=struct(inner_key='text')).to_json()
# {"key":{"inner_key":"text"}}

struct(key=[struct(inner_key=1), struct(inner_key=2)]).to_json()
# {"key":[{"inner_key":1},{"inner_key":2}]}

struct(key=struct(inner_key=struct(inner_inner_key='text'))).to_json()
# {"key":{"inner_key":{"inner_inner_key":"text"}}}
.

지원 중단됨: 대신 json.encode(x) 또는 json.encode_indent(x)를 사용하세요. 이 함수는 구조체 이외의 값에 작동하며 구조체 필드 네임스페이스를 오염시키지 않습니다.

to_proto

string InstrumentedFilesInfo.to_proto()

지원 중단되었습니다. 이 API는 지원 중단되었으며 곧 삭제됩니다. 이 방법을 사용하지 마세요. ---incompatible_struct_has_no_methods를 사용하면 사용 중지됩니다. 이 플래그를 사용하여 코드가 곧 삭제되는 것과 호환되는지 확인합니다.
구조체 매개변수에서 텍스트 메시지를 만듭니다. 이 메서드는 모든 구조체 요소가 (재귀적으로) 문자열, 정수, 불리언, 다른 구조체 또는 이러한 유형의 사전 또는 목록인 경우에만 작동합니다. 문자열의 따옴표와 새 줄은 이스케이프 처리됩니다. 구조체 키는 정렬된 순서로 반복됩니다. 예를 들면 다음과 같습니다.
struct(key=123).to_proto()
# key: 123

struct(key=True).to_proto()
# key: true

struct(key=[1, 2, 3]).to_proto()
# key: 1
# key: 2
# key: 3

struct(key='text').to_proto()
# key: "text"

struct(key=struct(inner_key='text')).to_proto()
# key {
#   inner_key: "text"
# }

struct(key=[struct(inner_key=1), struct(inner_key=2)]).to_proto()
# key {
#   inner_key: 1
# }
# key {
#   inner_key: 2
# }

struct(key=struct(inner_key=struct(inner_inner_key='text'))).to_proto()
# key {
#    inner_key {
#     inner_inner_key: "text"
#   }
# }

struct(foo={4: 3, 2: 1}).to_proto()
# foo: {
#   key: 4
#   value: 3
# }
# foo: {
#   key: 2
#   value: 1
# }

지원 중단됨: 대신 proto.encode_text(x)를 사용하세요.