এই পৃষ্ঠাটি Microbenchmark লাইব্রেরি ব্যবহার করার সময় একটি নন-Gradle বিল্ড সিস্টেম কনফিগার করার বর্ণনা দেয়।
যদিও Microbenchmark লাইব্রেরি Android Gradle প্লাগইনের সাথে সরাসরি সংহত করার জন্য একটি Gradle প্লাগইন পাঠায়, আপনি এটিকে অন্যান্য বিল্ড সিস্টেমে ব্যবহার করতে পারেন, যেমন Bazel বা Buck ।
ইন্সট্রুমেন্টেশন
টেস্ট ম্যানিফেস্টের ইন্সট্রুমেন্টেশন ব্লকে উল্লেখ করে AndroidBenchmarkRunner
বা একটি সাবক্লাসকে আপনার ইন্সট্রুমেন্টেশন রানার হিসেবে ব্যবহার করুন:
...
সঠিক পরিমাপ পেতে, বেঞ্চমার্কগুলি ডিবাগযোগ্য হতে হবে না। আপনি যদি ডিবাগযোগ্য পতাকা সঠিকভাবে সেট না করেন, তাহলে লাইব্রেরি ভুল ফলাফলের প্রতিবেদন করার পরিবর্তে একটি ত্রুটি ছুড়ে দেয়। অ্যান্ড্রয়েড স্টুডিও প্রোফাইলারগুলির সাথে ব্যবহারের জন্য স্থানীয় রানের সময় আপনাকে এই সেটিংটি টগল করতে হতে পারে, যার জন্য debuggable=true
প্রয়োজন।
আপনি দুটি উপায়ে চালানোর জন্য মাইক্রোবেঞ্চমার্ক তৈরি করতে পারেন: একটি স্ব-ইনস্ট্রুমেন্টিং APK-এর মধ্যে, অথবা একটি পরীক্ষা APK অন্য APK যন্ত্রের মাধ্যমে।
স্ব-ইনস্ট্রুমেন্টিং APK
com.android.library
থেকে একটি androidTest
ডিরেক্টরির জন্য Gradle-এর আউটপুট হিসাবে একটি স্ব-ইন্সট্রুমেন্টিং APK সহ — আপনাকে অবশ্যই একক APK এর Android ম্যানিফেস্টে ডিবাগযোগ্য অক্ষম করতে হবে:
অ্যাপ APK টেস্ট APK দ্বারা যন্ত্রযুক্ত
com.android.app
প্যাকেজ থেকে androidTest
ডিরেক্টরির জন্য Gradle-এর আউটপুট হিসাবে যদি আপনার বিল্ড দুটি APK—একটি অ্যাপ APK এবং টেস্ট APK আউটপুট করে—আপনাকে অবশ্যই অ্যাপ APK debuggable=false
এ সেট করতে হবে। পরীক্ষা APK এর ডিবাগযোগ্য পতাকা Android OS দ্বারা উপেক্ষা করা হয়।
অ্যান্ড্রয়েড স্টুডিও এবং গ্রেডল একটি অ্যাপ মডিউল APK মাইক্রোবেঞ্চমার্কিং সমর্থন করে না। এটি একটি অতিরিক্ত টেস্টিং ডিরেক্টরিকে সমর্থন করার জটিলতার কারণে যা APK-এর একটি নন-ডিবাগেবল, অপ্টিমাইজ করা বা মিনিফাইড ভেরিয়েন্টের উপর নির্ভর করে, কিন্তু বেঞ্চমার্ক থেকে অ্যাপ কোডে কলগুলিকে মিনিফেকশন ছাড়াই।
সংকলন
আমরা নিম্নলিখিত কমান্ড ব্যবহার করে পরীক্ষা চালানোর আগে আপনার মাইক্রোবেঞ্চমার্ক APK কম্পাইল করার পরামর্শ দিই:
adb shell cmd package compile -f -m speed com.example.benchmark
মিনিফিকেশন এবং অপ্টিমাইজেশান
মুক্তির কাছাকাছি পারফরম্যান্স পেতে আমরা আপনার বেঞ্চমার্কের জন্য মিনিফেকশন এবং অপ্টিমাইজেশন ব্যবহার করার পরামর্শ দিই। উদাহরণ কোডের জন্য, বেঞ্চমার্ক নমুনা প্রকল্প দেখুন।
কোড কভারেজ
আমরা কভারেজ অক্ষম করে বেঞ্চমার্ক চালানোর পরামর্শ দিই এবং কোনো লাইব্রেরি ছাড়াই বা JaCoCo-এর মতো টুলের সাহায্যে DEX ম্যাঙ্গলিং ছাড়াই।
এই কারণে, আমরা আপনাকে অন্যান্য ইন্সট্রুমেন্টেশন পরীক্ষা থেকে একটি উৎস সেট হিসাবে বেঞ্চমার্কগুলিকে বিচ্ছিন্ন করার এবং রিলিজ নির্ভরতাগুলির সাথে আলাদাভাবে তৈরি করার পরামর্শ দিই। এটি কভারেজ সহ এবং ছাড়াই একাধিকবার পরীক্ষা তৈরি করা এড়িয়ে যায়।
আপনার বেঞ্চমার্কের উপর নির্ভর করে এমন লাইব্রেরিগুলির ডিবাগ ভেরিয়েন্টগুলি, বিশেষত স্থানীয়ভাবে নির্মিত, কভারেজ সক্ষম করে নির্মিত হতে পারে।
আপনার পরীক্ষা চালান
আপনি কমান্ড লাইন থেকে আপনার পরীক্ষা চালাতে পারেন এবং নিম্নলিখিত উদাহরণে দেখানো ক্লাসগুলির সাথে চালানোর জন্য নির্দিষ্ট করতে পারেন:
adb shell am instrument -w com.example.benchmark/androidx.benchmark.junit4.AndroidBenchmarkRunner
Gradle ছাড়া রানটাইমে মাইক্রোবেঞ্চমার্ক লাইব্রেরি কনফিগার করতে, মাইক্রোবেঞ্চমার্ক ইনস্ট্রুমেন্টেশন আর্গুমেন্ট দেখুন।
{% শব্দার্থে %}আপনার জন্য প্রস্তাবিত
- দ্রষ্টব্য: জাভাস্ক্রিপ্ট বন্ধ থাকলে লিঙ্ক টেক্সট প্রদর্শিত হয়
- একটি মাইক্রোবেঞ্চমার্ক লিখ
- বেসলাইন প্রোফাইল তৈরি করুন {:#creating-profile-rules}