โหลดโปรโตคอลที่มีการกำหนดค่าส่วนกลาง

หากต้องการทำความเข้าใจส่วนนี้ โปรดศึกษา Tradefed @Option ก่อน

โดยปกติแล้ว ตัวเลือกใน Tradefed จะอนุญาตให้คลาสการทดสอบรับข้อมูลเพิ่มเติม จากการกำหนดค่า XML หรือบรรทัดคำสั่ง ฟีเจอร์นี้ช่วยให้คุณ ดำเนินการอีกขั้นและแก้ไขข้อมูลเพิ่มเติมบางอย่างได้หาก จำเป็น

ตัวอย่างตัวเลือกไฟล์

ตัวอย่างไฟล์ @option:

@Option(name = 'config-file')
private File mConfigFile;

คุณตั้งค่าข้างต้นได้ผ่านการกำหนดค่า XML ดังนี้

<option name="config-file" value="/tmp/file" />

หรือผ่านคำสั่ง

--config-file /tmp/file

คำอธิบาย

ฟีเจอร์นี้ช่วยให้คุณแก้ไข @Options ประเภทไฟล์ที่อยู่ระยะไกลให้เป็นไฟล์ในเครื่องเพื่อให้พร้อมใช้งานได้อย่างราบรื่นจากมุมมองของผู้ใช้

หากต้องการให้การดำเนินการนี้ได้ผล คุณต้องระบุไฟล์ด้วยเส้นทางสไตล์ระยะไกล เช่น

--config-file gs://bucket/tmp/file

เส้นทางนี้ชี้ไปยังไฟล์ภายในที่เก็บข้อมูล Google Cloud Storage (GCS) ที่จัดเก็บไฟล์ เมื่อเห็นเส้นทางระยะไกล Tradefed จะพยายามดาวน์โหลดไฟล์ ในเครื่องและกำหนดให้กับ @Option ซึ่งจะส่งผลให้ตัวแปร mConfigFile ชี้ไปยังไฟล์เวอร์ชันในเครื่องที่ใช้ในการทดสอบได้

หากดาวน์โหลดไฟล์ระยะไกลไม่ได้ไม่ว่าด้วยเหตุผลใดก็ตาม Tradefed จะแสดง ConfigurationException ซึ่งจะป้องกันไม่ให้การทดสอบทำงาน เราถือว่าการไม่มีไฟล์เหล่านั้นเป็นความล้มเหลวที่สำคัญ เนื่องจากอาร์ติแฟกต์การทดสอบบางอย่างจะหายไปด้วย

ใช้พารามิเตอร์การค้นหา

คุณเพิ่มพารามิเตอร์การค้นหาลงใน URL ได้โดยใช้ ? เช่น gs://bucket/path?unzip=true คีย์/ค่า unzip=true จะพร้อมใช้งานใน การใช้งานอินเทอร์เฟซ IRemoteFileResolver

มีลักษณะการทำงานในตัว 2 แบบให้เลือกใช้ ดังนี้

  • unzip: หากตั้งค่าเป็น true และไฟล์ที่ดาวน์โหลดเป็นไฟล์ zip ระบบจะ คลายซิปไฟล์โดยอัตโนมัติไปยังตำแหน่งชั่วคราว ตัวอย่าง: ?unzip=true
  • ไม่บังคับ: ค่าเริ่มต้นคือ false หากตั้งค่าเป็น true และการแก้ไขไม่สำเร็จ ระบบจะไม่แสดงข้อยกเว้นและจะไม่แทนที่ไฟล์ ตัวอย่าง ?optional=true

นอกจากนี้ คุณยังส่งอาร์กิวเมนต์การค้นหาแบบส่วนกลางผ่าน --dynamic-download-args key=value ซึ่งจะส่งคีย์/ค่าไปยังการดาวน์โหลดแบบไดนามิกทั้งหมดที่พยายามใน การเรียกใช้ได้ด้วย

โปรโตคอลที่รองรับ

โปรโตคอลที่รองรับอย่างเป็นทางการและรูปแบบที่เกี่ยวข้องมีดังนี้

  • Google Cloud Storage, โปรโตคอล: gs, รูปแบบ: gs://<bucket name>/path
  • ไฟล์ในเครื่อง โปรโตคอล: file รูปแบบ: file:/local/path
  • ลิงก์ http, โปรโตคอล: http, รูปแบบ: http://url
  • ลิงก์ https, โปรโตคอล: https, รูปแบบ: https://url

ข้อจำกัด

ปัจจุบันความละเอียดแบบไดนามิกของ @Option รองรับเฉพาะโปรโตคอลและตำแหน่งที่จำกัดเพื่อดาวน์โหลด ขณะนี้ความละเอียดของ @Option ใช้ได้เฉพาะกับการกำหนดค่า Tradefed XML หลักเท่านั้น

หากเรียกใช้เป็นชุด โมดูลปัจจุบัน (AndroidTest.xml) จะไม่แก้ไขไฟล์โดยค่าเริ่มต้น ซึ่งมีไว้เพื่อป้องกันไม่ให้โมดูลสร้างการอ้างอิงที่ไม่รู้จัก คุณหลีกเลี่ยงการดำเนินการนี้ได้โดยใช้ --enable-module-dynamic-download ที่ระดับชุดทดสอบ แต่ชุดทดสอบหลักๆ เช่น ชุดเครื่องมือทดสอบความเข้ากันได้ (CTS) และชุดทดสอบของผู้ให้บริการ (VTS) จะไม่เปิดใช้

ใช้โปรโตคอลใหม่

โปรโตคอลที่รองรับมีการติดตั้งใช้งานใน Tradefed ของอินเทอร์เฟซ IRemoteFileResolver ซึ่งกำหนดแท็กแบบย่อของโปรโตคอลที่จะจับคู่ในเส้นทางไฟล์ผ่าน getSupportedProtocol เช่น gs ใช้สำหรับ โปรโตคอล Google Cloud Storage อินเทอร์เฟซที่แนะนำให้ใช้คือ #resolveRemoteFiles(RemoteFileResolverArgs) ซึ่งจะเป็นอินเทอร์เฟซที่ ได้รับการดูแลในระยะยาว

คุณสามารถเพิ่มโปรโตคอลที่ใช้ลงในไฟล์ the harness META-INF services เพื่อเปิดใช้การรองรับอย่างเป็นทางการ