ساخت Microbenchmark بدون Gradle

این صفحه پیکربندی یک سیستم ساخت غیر Gradle را هنگام استفاده از کتابخانه Microbenchmark توضیح می‌دهد.

اگرچه کتابخانه Microbenchmark یک افزونه Gradle را برای ادغام مستقیم با افزونه Android Gradle ارسال می‌کند، اما می‌توانید از آن در سایر سیستم‌های ساخت مانند Bazel یا Buck نیز استفاده کنید.

ابزار دقیق

با مشخص کردن آن در بلوک ابزاردقیق مانیفست آزمایشی، از AndroidBenchmarkRunner یا یک زیر کلاس به‌عنوان ابزار دقیق خود استفاده کنید:

<manifest
   
package="com.example.library.test" ...>

   
<instrumentation android:name="androidx.benchmark.junit4.AndroidBenchmarkRunner" />
    ...
</manifest>

برای به دست آوردن اندازه‌گیری‌های دقیق، معیارها نباید قابل اشکال‌زدایی باشند. اگر پرچم قابل اشکال زدایی را به درستی تنظیم نکنید، کتابخانه به جای گزارش نتایج نامعتبر، خطا می دهد. ممکن است لازم باشد این تنظیم را در طول اجراهای محلی برای استفاده با نمایه‌کننده‌های Android Studio تغییر دهید، که به debuggable=true نیاز دارند.

شما می‌توانید Microbenchmark‌هایی را برای اجرا به دو صورت بسازید: در یک APK خود ابزار دقیق، یا با یک APK آزمایشی که APK دیگر را ابزار می‌کند.

فایل‌های APK خود ابزار

با یک APK خودکار - به عنوان خروجی Gradle برای پوشه androidTest از com.android.library - باید اشکال زدایی را در مانیفست Android یک APK غیرفعال کنید:

<manifest
   
package="com.example.library.test" ...>

   
<instrumentation
       
android:name="androidx.benchmark.junit4.AndroidBenchmarkRunner"
       
android:targetPackage="com.example.library.test"/>

   
<application android:debuggable="false"/>
</manifest>

APK برنامه با APK آزمایشی ابزار شده است

اگر بیلد شما دو APK خروجی می‌دهد—یک APK برنامه و APK آزمایشی، به عنوان خروجی Gradle برای پوشه androidTest از بسته com.android.app باید APK برنامه را روی debuggable=false تنظیم کنید. پرچم قابل اشکال زدایی APK آزمایشی توسط سیستم عامل اندروید نادیده گرفته می شود.

<!-- Test manifest. -->
<manifest
   
package="com.example.android.app.test" ...>

   
<instrumentation
       
android:name="androidx.benchmark.junit4.AndroidBenchmarkRunner"
       
android:targetPackage="com.example.android.app"/>
   
<!-- This debuggable is ignored by the OS. -->
</manifest>

<!-- App being tested. -->
<manifest
   
package="com.example.android.app" ...>

   
<application android:debuggable="false"/>
</manifest>

Android Studio و Gradle از microbenchmarking یک ماژول برنامه APK پشتیبانی نمی کنند. این به دلیل پیچیدگی پشتیبانی از دایرکتوری آزمایشی اضافی است که به یک نوع غیراشکال‌زدایی، بهینه‌سازی یا کوچک‌سازی شده APK بستگی دارد، اما بدون کوچک‌سازی، تماس‌ها را از معیارها به کد برنامه تبدیل می‌کند.

تالیف

توصیه می‌کنیم قبل از اجرای آزمایش‌ها با استفاده از دستور زیر، APK microbenchmark خود را کامپایل کنید:

adb shell cmd package compile -f -m speed com.example.benchmark

کوچک سازی و بهینه سازی

توصیه می‌کنیم از کوچک‌سازی و بهینه‌سازی برای معیارهای خود استفاده کنید تا عملکردی نزدیک به انتشار داشته باشید. برای مثال کد، پروژه نمونه بنچمارک را ببینید.

پوشش کد

ما توصیه می‌کنیم معیارهایی را با پوشش غیرفعال و بدون هیچ گونه کتابخانه یا انحراف DEX توسط ابزارهایی مانند JaCoCo اجرا کنید.

به همین دلیل، توصیه می‌کنیم معیارها را به‌عنوان یک مجموعه منبع از سایر آزمایش‌های ابزار دقیق جدا کنید و آنها را به‌طور جداگانه با وابستگی‌های انتشار بسازید. با این کار نیازی به ساخت بیش از یک بار تست، هم با پوشش و هم بدون پوشش نیست.

انواع اشکال‌زدایی کتابخانه‌هایی که معیار شما به آن‌ها وابسته است، به ویژه آنهایی که به صورت محلی ساخته شده‌اند، ممکن است با پوشش فعال ساخته شوند.

تست های خود را اجرا کنید

همانطور که در مثال زیر نشان داده شده است، می توانید تست های خود را از خط فرمان اجرا کنید و کلاس هایی را برای اجرا مشخص کنید:

adb shell am instrument -w com.example.benchmark/androidx.benchmark.junit4.AndroidBenchmarkRunner

برای پیکربندی کتابخانه Microbenchmark در زمان اجرا بدون Gradle، به آرگومان های ابزار دقیق Microbenchmark مراجعه کنید.

{% کلمه به کلمه %} {% آخر کلمه %}