มีข้อมูลเกี่ยวกับไฟล์แหล่งที่มาและไฟล์ข้อมูลเมตาของการใช้เครื่องมือสำหรับเป้าหมายกฎที่ตรงกันโดย --instrumentation_filter
เพื่อวัตถุประสงค์ในการรวบรวมข้อมูลการครอบคลุมของโค้ด เมื่อเปิดใช้การรวบรวมข้อมูลการครอบคลุม ระบบจะส่งไฟล์ Manifest ที่มีเส้นทางรวมใน instrumented_files
และ metadata_files
ไปยังการดำเนินการทดสอบเป็นอินพุต พร้อมกับเส้นทางของไฟล์ Manifest ที่ระบุไว้ในตัวแปรสภาพแวดล้อม COVERAGE_MANIFEST
ไฟล์ข้อมูลเมตา (ไม่ใช่ไฟล์ต้นฉบับ) จะส่งผ่านไปยังการดำเนินการทดสอบเป็นอินพุตด้วยเช่นกัน เมื่อฟังก์ชันการใช้งานของแง่มุมแสดงผล InstrumentedFilesInfo
ระบบจะไม่สนใจ InstrumentedFilesInfo
จากเป้าหมายกฎพื้นฐาน
สมาชิก
instrumented_files
depset InstrumentedFilesInfo.instrumented_files
depset
ของออบเจ็กต์ File
ที่แสดงไฟล์ต้นฉบับที่มีเครื่องมือวัดสำหรับเป้าหมายนี้และรายการที่เกี่ยวข้อง
metadata_files
depset InstrumentedFilesInfo.metadata_files
depset
ออบเจ็กต์ File
ที่แสดงไฟล์ข้อมูลเมตาการครอบคลุมสําหรับเป้าหมายนี้และรายการที่เกี่ยวข้อง ไฟล์เหล่านี้มีข้อมูลเพิ่มเติมที่จําเป็นในการสร้างเอาต์พุตการครอบคลุมรูปแบบ LCOV หลังจากเรียกใช้โค้ด เช่น ไฟล์ .gcno
ที่สร้างขึ้นเมื่อเรียกใช้ gcc
ด้วย -ftest-coverage
to_json
string InstrumentedFilesInfo.to_json()
---incompatible_struct_has_no_methods
ใช้ Flag นี้เพื่อยืนยันว่าโค้ดของคุณเข้ากันได้กับการนําออกที่กําลังจะเกิดขึ้น สร้างสตริง JSON จากพารามิเตอร์ Struct วิธีนี้ใช้งานได้เฉพาะเมื่อองค์ประกอบ Struct ทั้งหมด (เกิดซ้ำ) เป็นสตริง, ints, บูลีน, Struct อื่นๆ, รายการประเภทเหล่านี้ หรือพจนานุกรมที่มีคีย์สตริงและค่าในประเภทเหล่านี้ ระบบจะใช้อักขระหลีกกับเครื่องหมายคำพูดและบรรทัดใหม่ในสตริง ตัวอย่าง:
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()
---incompatible_struct_has_no_methods
ใช้ธงนี้เพื่อยืนยันว่าโค้ดของคุณเข้ากันได้กับการนำออกในเร็วๆ นี้ สร้าง SMS จากพารามิเตอร์ Struct วิธีการนี้จะใช้งานได้ก็ต่อเมื่อองค์ประกอบ Struct ทั้งหมด (แบบเรียกซ้ำ) เป็นสตริง, int, บูลีน, Struct หรือ Dict หรือลิสต์ประเภทอื่นๆ เหล่านี้ ระบบจะหลีกหนีเครื่องหมายคำพูดและบรรทัดใหม่ในสตริง ระบบจะวนคีย์ Struct ตามลําดับที่จัดเรียง ตัวอย่าง:
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) แทน