ساختار کلی پیکربندی ماژول از یک الگوی مشابه با پیکربندی معمولی Tradefed XML پیروی می کند، اما با برخی محدودیت ها به دلیل این واقعیت که آنها به عنوان بخشی از یک مجموعه اجرا می شوند.
لیست برچسب های مجاز
پیکربندی ماژول AndroidTest.xml
یا بیشتر میتواند فقط حاوی برچسبهای XML زیر باشد: target_preparer
، multi_target_preparer
، test
و metrics_collector
.
اگرچه این لیست محدود کننده به نظر می رسد، اما به شما امکان می دهد دقیقاً نیازهای راه اندازی ماژول تست و اجرای آزمایش را تعریف کنید.
توجه: در صورت نیاز به تجدید نظر در تگ های مختلف ، پیکربندی Tradefed XML را ببینید.
اشیایی مانند build_provider
یا result_reporter
اگر بخواهند از داخل پیکربندی ماژول اجرا شوند یک ConfigurationException
ایجاد می کنند. این به معنای اجتناب از انتظار این است که این اشیا در واقع برخی از وظایف را از داخل یک ماژول انجام دهند.
نمونه پیکربندی ماژول
<configuration description="Config for CTS Gesture test cases">
<option name="test-suite-tag" value="cts" />
<target_preparer class="com.android.tradefed.targetprep.suite.SuiteApkInstaller">
<option name="cleanup-apks" value="true" />
<option name="test-file-name" value="CtsGestureTestCases.apk" />
</target_preparer>
<test class="com.android.tradefed.testtype.AndroidJUnitTest" >
<option name="package" value="android.gesture.cts" />
<option name="runtime-hint" value="10m50s" />
</test>
</configuration>
این پیکربندی آزمایشی را توصیف میکند که نیاز به نصب CtsGestureTestCases.apk
دارد و ابزار دقیقی را در برابر بسته android.gesture.cts
اجرا میکند.
تگ های گنجاندن <include>
و <template-include>
استفاده از <include>
و <template-include>
در تنظیمات ماژول ممنوع است. آنها تضمین نمی شوند که همانطور که انتظار می رود کار کنند.
مورد ویژه برای برچسب metrics_collector
metrics_collector
مجاز است اما به کلاس FilePullerLogCollector
محدود می شود تا یک فایل یا دایرکتوری معینی را مشخص کند که برای ماژول کشیده و ثبت شود. اگر گزارشها را در یک مکان خاص رها میکنید و میخواهید به طور خودکار آنها را بازیابی کنید، مفید است.
پیکربندی مثال:
<configuration description="Config for CTS UI Rendering test cases">
<target_preparer class="com.android.tradefed.targetprep.suite.SuiteApkInstaller">
<option name="cleanup-apks" value="true" />
<option name="test-file-name" value="CtsUiRenderingTestCases.apk" />
</target_preparer>
<test class="com.android.tradefed.testtype.AndroidJUnitTest" >
<option name="package" value="android.uirendering.cts" />
<option name="runtime-hint" value="11m55s" />
<option name="runner" value="android.uirendering.cts.runner.UiRenderingRunner" />
<option name="isolated-storage" value="false" />
</test>
<!-- Collect the files in the dump directory for debugging -->
<metrics_collector class="com.android.tradefed.device.metric.FilePullerLogCollector">
<option name="directory-keys" value="/sdcard/UiRenderingCaptures" />
<option name="collect-on-run-ended-only" value="true" />
</metrics_collector>
</configuration>
در مورد اطلاعات ساخت یا دانلودها چطور؟
تعریف تگ های مجاز ممکن است این تصور نادرست را ایجاد کند که یک ماژول هیچ اطلاعات ساختی را دریافت نمی کند. این درست نیست .
اطلاعات ساخت از راهاندازی در سطح مجموعه ارائه میشود و توسط همه ماژولهای مجموعه به اشتراک گذاشته میشود. این اجازه می دهد تا یک راه اندازی در سطح بالا برای مجموعه به منظور اجرای تمام ماژول های بخش مجموعه.
به عنوان مثال، به جای اینکه هر ماژول مجموعه تست سازگاری (CTS) به طور جداگانه اطلاعات دستگاه، انواع و غیره را پرس و جو کند، تنظیم سطح مجموعه CTS ( cts.xml
) یک بار این کار را انجام می دهد و هر ماژول در صورت درخواست آن اطلاعات را دریافت می کند.
برای اینکه اشیا در یک ماژول اطلاعات ساخت را دریافت کنند، باید مانند پیکربندی معمول Tradefed عمل کنند: رابط IBuildReceiver
را برای دریافت IBuildInfo
پیاده سازی کنند. برای جزئیات بیشتر به تست با دستگاه مراجعه کنید.
فیلدهای فراداده
تعداد زیادی از ماژول های تست شامل برخی از مشخصات metadata
است که هر کدام هدف منحصر به فردی دارند.
مثال:
<option name="config-descriptor:metadata" key="component" value="framework" />
<option name="config-descriptor:metadata" key="parameter" value="instant_app" />
<option name="config-descriptor:metadata" key="parameter" value="multi_abi" />
<option name="config-descriptor:metadata" key="parameter" value="secondary_user" />
جزء
component
مؤلفه عمومی Android را که ماژول قصد آزمایش آن را دارد، توصیف می کند. هیچ تاثیر مستقیمی بر اجرای آزمون ندارد. در درجه اول برای اهداف سازمانی استفاده می شود.
فهرست بهروز مؤلفههای مجاز برای CTS در CtsConfigLoadingTest موجود است. اگر مؤلفهای که وجود ندارد به یک ماژول CTS اضافه شود، این آزمون در ارسال پیشفرض با شکست مواجه میشود.
میتوانید با استفاده از module-metadata-include-filter
و module-metadata-exclude-filter
یک مجموعه اجرا را بر اساس مؤلفهها فیلتر کنید.
مثال:
--module-metadata-include-filter component framework
این مثال فقط ماژول تست مشروح شده با جزء framework
را اجرا می کند.
پارامتر
فراداده parameter
اطلاعاتی است و بر اجرای آزمون تأثیر می گذارد. مشخص میکند که ماژول تست روی کدام حالت اندروید اعمال میشود. در این حالت، حالتها به حالتهای سطح بالای اندروید، مانند instant apps
، secondary users
یا different abis
محدود میشوند.
در طول اجرای مجموعه، اگر حالت برای تست اعمال شود، چندین تغییر از ماژول تست بر اساس حالت ایجاد می شود. هر کدام از تغییرات تست های مشابهی را انجام می دهند اما در حالت های مختلف.
-
instant_app
: آزمایشهایی را ایجاد کنید که فایلهای APK را بهعنوان برنامههای فوری نصب میکنند. -
multi_abi
: برای هر ABI که توسط دستگاه پشتیبانی می شود، تنوعی از تست ها ایجاد کنید. -
secondary_user
: تنوعی از آزمایشها ایجاد کنید که فایلهای APK را نصب میکنند و آزمایشها را بهعنوان کاربر ثانویه اجرا میکنند.
جمع آوری متریک و پس پردازش برای ماژول های تست عملکرد
برای ماژول های تست عملکرد، سطح ماژول metrics_collector
و metric_post_processor
مجاز هستند زیرا برای تست های عملکرد ضروری هستند. کلکتورهای متریک سطح ماژول و پس پردازشگرها می توانند ماژول خاص باشند. توصیه نمی شود که پس پردازشگرها را هم در سطح بالا و هم در سطح ماژول مشخص کنید.
پیکربندی ماژول تست عملکرد باید شامل متادیتای test-type
با performance
مقدار باشد، مانند: xml <option name="config-descriptor:metadata" key="test-type" value="performance" />
بدون این، در صورت آزمایش پیکربندی شامل metric_collector
غیر از FilePullerLogCollector
یا هر metric_post_processor
است، آزمایش در ارسال پیشفرض با شکست مواجه میشود.
نمونه پیکربندی ماژول تست عملکرد:
<configuration description="Runs sample performance test.">
<!-- Declare as a performance test module -->
<option name="config-descriptor:metadata" key="test-type" value="performance" />
<option name="test-tag" value="hello-world-performance-test" />
<test class="com.android.tradefed.testtype.HostTest" >
<option name="class" value="android.test.example.helloworldperformance.HelloWorldPerformanceTest" />
</test>
<!-- Add module-level post processor MetricFilePostProcessor -->
<metric_post_processor class="com.android.tradefed.postprocessor.MetricFilePostProcessor">
<option name="aggregate-similar-tests" value="true" />
<option name="enable-per-test-log" value="false" />
</metric_post_processor>
</configuration>