এই নির্দেশিকা বর্ণনা করে কিভাবে Firebase Test Lab ব্যবহার করে একটি ইন্সট্রুমেন্টেশন পরীক্ষা প্রস্তুত ও চালাতে হয়। এই নির্দেশিকাটি ব্যবহার করার জন্য, আপনার একটি ইন্সট্রুমেন্টেশন টেস্টের প্রয়োজন হবে (আপনি বা আপনার দলের দ্বারা লিখিত) যা এসপ্রেসো বা UI অটোমেটর অ্যান্ড্রয়েড টেস্ট ফ্রেমওয়ার্ক ব্যবহার করে। ইন্সট্রুমেন্টেশন পরীক্ষাগুলি শারীরিক ডিভাইসে 45 মিনিট পর্যন্ত এবং ভার্চুয়াল ডিভাইসে 60 মিনিট পর্যন্ত চলতে পারে।
পরবর্তী ধাপে, আপনি আপনার অ্যাপের APK এবং আপনার পরীক্ষার APK Firebase-এ আপলোড করবেন।
(ঐচ্ছিক) আপনার অ্যাপে স্ক্রিনশট লাইব্রেরি যোগ করুন
Firebase Test Lab একটি লাইব্রেরি (testlab-instr-lib) রয়েছে যা আপনি AndroidX-এর স্ক্রিনক্যাপচারের মাধ্যমে নেওয়া যেকোনো স্ক্রিনশট প্রক্রিয়া করতে ব্যবহার করতে পারেন যখন ইন্সট্রুমেন্টেশন পরীক্ষা চালানো হয়, যেমন Espresso টেস্ট ফ্রেমওয়ার্ক ব্যবহার করে লিখিত পরীক্ষা। এই বিভাগটি বর্ণনা করে কিভাবে AndroidX লাইব্রেরি দিয়ে ScreenCapture
অবজেক্ট তৈরি করা যায় এবং testlab-instr-lib ব্যবহার করে কিভাবে সেগুলি প্রক্রিয়া করা যায়।
আপনার ইন্সট্রুমেন্টেশন পরীক্ষা চালানোর পরে, আপনি Firebase কনসোলে ক্যাপচার করা স্ক্রিনশট দেখতে পারেন।
একটি নমুনা অ্যাপ্লিকেশন চেষ্টা করুন
এই কার্যকারিতা চেষ্টা করার জন্য নোটপ্যাড নমুনা অ্যাপ্লিকেশন ডাউনলোড করুন। স্ক্রিনশট নেওয়ার ক্ষমতা ইতিমধ্যেই নোটপ্যাড প্রকল্পে অন্তর্ভুক্ত করা হয়েছে।
ধাপ 1. আপনার প্রকল্পে স্ক্রিনশট লাইব্রেরি যোগ করুন
আপনার পরীক্ষা প্রকল্পের রুট-লেভেল সেটিংস গ্রেডল ফাইলে (
settings.gradle.kts
বাsettings.gradle
), প্রতিটিrepositories
বিভাগে Google এর Maven সংগ্রহস্থল যোগ করুন:pluginManagement { repositories { // Add the following line: google() // Google's Maven repository mavenCentral() gradlePluginPortal() } } dependencyResolutionManagement { repositoriesMode.set(RepositoriesMode.FAIL_ON_PROJECT_REPOS) repositories { // Add the following line: google() // Google's Maven repository mavenCentral() } } // ...
আপনার মডিউলে (অ্যাপ-লেভেল) গ্রেডল ফাইলে (সাধারণত
<project>/<app-module>/build.gradle.kts
বা<project>/<app-module>/build.gradle
), Test Lab জন্য নির্ভরতা যোগ করুন স্ক্রিনশট লাইব্রেরি।dependencies { // ... // Add Test Lab's instrumentation test screenshot library: androidTestImplementation("com.google.firebase:testlab-instr-lib:0.2") // ...
আপনার পরীক্ষার
AndroidManifest.xml
ফাইলে,<instrumentation>
ইনস্ট্রুমেন্টেশন> উপাদানের মধ্যে একটি মেটা-ডেটা ট্যাগেFirebaseScreenCaptureProcessor
নিবন্ধন করুন। আপনি পরিবর্তে AndroidJUnitRunner-এ একটি যুক্তি হিসাবে প্রসেসরকে নির্দিষ্ট করতে পারেন (কীভাবে নির্দেশাবলীর জন্য AndroidJUnitRunner রেফারেন্স ডকুমেন্টেশন দেখুন)।<instrumentation // Check that you have the following line (if not, add it): android:name="androidx.test.runner.AndroidJUnitRunner" // Specifies AndroidJUnitRunner as the test runner android:targetPackage="com.your.package.name"> // Add the following: <meta-data android:name="screenCaptureProcessors" android:value="com.google.firebase.testlab.screenshot.FirebaseScreenCaptureProcessor" /> </instrumentation> ...
আপনার অ্যাপের
AndroidManifest.xml
ফাইলে,<manifest>
উপাদানের মধ্যে নিম্নলিখিত লাইনগুলি যোগ করুন:<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/>
আপনার
AndroidManifest.xml
ফাইলে,<manifest>
ট্যাগের মধ্যে নিম্নলিখিত লাইনগুলি যোগ করে আপনার অ্যাপের জন্য সিস্টেম অনুমতিগুলি নির্দিষ্ট করুন৷ আপনি যদি Android 10 (API লেভেল 29) বা উচ্চতর তে পরীক্ষা করছেন, তাহলেWRITE_EXTERNAL_STORAGE
অনুমতি বাদ দিন (ডিভাইসটিতে স্ক্রিনশট পড়তে এবং লেখার জন্য আপনার অ্যাপের এই অনুমতির প্রয়োজন নেই)।<manifest ... > <!-- WRITE_EXTERNAL_STORAGE is not needed on Android 10 (API level 29) or higher. --> <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/> <uses-permission android:name="android.permission.INTERNET"/> ... </manifest>
ধাপ 2. আপনার পরীক্ষার সময় স্ক্রিনশট নিন
আপনার পরীক্ষার যেকোনো সময়ে যেখানে আপনি একটি স্ক্রিনশট নিতে চান, AndroidX লাইব্রেরি থেকে Screenshot.capture()
পদ্ধতিতে কল করুন। এটি একটি ScreenCapture
অবজেক্ট তৈরি করে। আপনি যখন ScreenCapture
অবজেক্টে process()
কল করেন, তখন এটি আপনার AndroidManifest.xml
এ নিবন্ধিত ScreenCaptureProcessor ব্যবহার করে প্রক্রিয়া করা হয়। মনে রাখবেন যে কোন প্রসেসর নিবন্ধিত না থাকলে BasicScreenCaptureProcessor
ব্যবহার করা হয়। যেহেতু আপনি FirebaseScreenCaptureProcessor
নিবন্ধন করেছেন, তাই আপনার স্ক্রিনশটগুলি FirebaseScreenCaptureProcessor
এর মাধ্যমে প্রসেস করা হবে এবং আপনি যখন Firebase Test Lab সাথে আপনার পরীক্ষা চালাবেন তখন আপনার ফলাফলের সাথে আপনার জন্য উপলব্ধ হবে৷
একটি ScreenCapture
তৈরি করার জন্য উদাহরণ ব্যবহার ক্ষেত্রে:
একটি API বিল্ড.VERSION_CODES.JELLY_BEAN_MR2 এবং তার উপরে একটি সম্পূর্ণ স্ক্রিন ক্যাপচার নিন:
Screenshot.capture()
যেকোনো API স্তরে কার্যকলাপের একটি
ScreenCapture
নিন। মনে রাখবেন যেগুলি Build.VERSION_CODES.JELLY_BEAN_MR2-এর নীচের ডিভাইসগুলির জন্য এটিই একমাত্র বিকল্প৷@Rule public ActivityTestRule<MainActivity> activityRule = new ActivityTestRule<>(MainActivity.class); ... Screenshot.capture(activityRule.getActivity()); ...
একটি ScreenCapture প্রক্রিয়াকরণের জন্য উদাহরণ ব্যবহার ক্ষেত্রে
FirebaseScreenCaptureProcessor
এর মাধ্যমে একটিScreenCapture
প্রক্রিয়া করুন:Screenshot.capture().process();
একটি নির্দিষ্ট
ScreenCaptureProcessor
এর মাধ্যমে একটিScreenCapture
প্রক্রিয়া করুন (এটি আপনাকে প্রসেসর নিবন্ধন করা এড়িয়ে যেতে দেয়):Set<ScreenCaptureProcessor> processors = new HashSet<>(); processors.add(new FirebaseScreenCaptureProcessor()); Screenshot.capture().process(processors);
ScreenCapture
এর নাম এবং বিন্যাস সেট করুন এবং নিবন্ধিত প্রসেসর ব্যবহার করে এটি প্রক্রিয়া করুন:Screenshot.capture().setName("myscreenshot").setFormat(CompressFormat.JPEG).process();
ধাপ 3. আপনার পরীক্ষা তৈরি করুন এবং চালান
আপনার অ্যাপ তৈরি করুন এবং APK পরীক্ষা করুন (নির্দেশের জন্য আপনার অ্যাপ পরীক্ষা করুন দেখুন)।
Firebase কনসোলের Test Lab ড্যাশবোর্ডে APK ফাইলগুলি আপলোড করুন।
অবশেষে, আপনার পরীক্ষা চালান।
ধাপ 4. আপনার পরীক্ষার স্ক্রিনশট দেখুন
আপনার পরীক্ষা শেষ হওয়ার পরে, আপনি Firebase কনসোলে নেওয়া যেকোনো স্ক্রিনশট দেখতে পারেন।
টেস্ট ট্যাবে, আপনার সম্পূর্ণ পরীক্ষা নির্বাচন করুন, তারপর ফলাফল ট্যাবে ক্লিক করুন।
আবার আপনার পরীক্ষা নির্বাচন করুন, তারপর প্রদর্শিত স্ক্রিনশট ট্যাবে ক্লিক করুন।
(ঐচ্ছিক) অতিরিক্ত পরীক্ষা বৈশিষ্ট্য সক্ষম করুন
Test Lab সাথে চালানোর আগে আপনি আপনার পরীক্ষায় নিম্নলিখিত বৈশিষ্ট্যগুলি সক্ষম করতে পারেন:
অর্কেস্ট্রেটর সক্ষম করুন
অ্যান্ড্রয়েড টেস্ট অর্কেস্ট্রেটর হল একটি টুল যা আপনার অ্যাপের প্রতিটি ইন্সট্রুমেন্টেশন পরীক্ষা স্বাধীনভাবে চালায়। Test Lab সর্বদা অর্কেস্ট্রেটরের সর্বশেষ সংস্করণ ব্যবহার করে।
Test Lab জন্য অর্কেস্ট্রেটর সক্ষম করতে, ইন্সট্রুমেন্টেশন টেস্ট সেটআপে, অতিরিক্ত বিকল্প > অর্কেস্ট্রেটরের সাথে চালান ক্লিক করুন।
আপনি যখন অর্কেস্ট্রেটর ব্যবহার করেন, তখন আপনি নিম্নলিখিতগুলি থেকে উপকৃত হন:
- কোন ভাগ করা রাষ্ট্র. প্রতিটি পরীক্ষা তার নিজস্ব ইন্সট্রুমেন্টেশন দৃষ্টান্তে চলে, তাই একটি ভাগ করা অবস্থা পরীক্ষা জুড়ে জমা হয় না।
- বিচ্ছিন্ন ক্র্যাশ। যদি একটি পরীক্ষা ক্র্যাশ হয়ে যায়, শুধুমাত্র সেই ইন্সট্রুমেন্টেশনটি বন্ধ করা হয় এবং আপনার স্যুটে অন্যান্য পরীক্ষাগুলি এখনও চলতে পারে।
মনে রাখবেন যে আপনি যখন অর্কেস্ট্রেটর ব্যবহার করেন, তখন প্রতিটি পরীক্ষা তার নিজস্ব ইন্সট্রুমেন্টেশন ইন্সট্যান্স চালায়, যার মানে হল প্রতিটি পরীক্ষার পরে অ্যাপ প্রক্রিয়াটি পুনরায় আরম্ভ করা হয়। ফলস্বরূপ রানের সময় বৃদ্ধি আপনার কোটা ব্যবহার বা বিল করা সময়কে প্রভাবিত করতে পারে এবং আপনার ডিভাইসের সময়সীমা অতিক্রম করতে পারে। আপনি যদি আপনার অ্যাপের শুরুর সময় কমিয়ে দেন, তাহলে এই ওভারহেডটি ছোট হয়ে যাবে।
অর্কেস্ট্রেটরের জন্য অতিরিক্ত বিকল্পগুলি সেট করতে, এগুলিকে environmentVariables
ক্ষেত্রের মাধ্যমে নির্দিষ্ট করুন৷ উদাহরণস্বরূপ, clearPackageData
ব্যবহার করতে, gcloud-এ এই বিকল্পটি ব্যবহার করুন:
--environment-variables clearPackageData=true
শর্ডিং সক্ষম করুন
টেস্ট শার্ডিং পরীক্ষার একটি সেটকে সাব-গ্রুপে (শার্ডস) ভাগ করে যা বিচ্ছিন্নভাবে আলাদাভাবে চলে। Test Lab স্বয়ংক্রিয়ভাবে একাধিক ডিভাইস ব্যবহার করে সমান্তরালভাবে প্রতিটি শার্ড চালায় এবং কম সময়ের মধ্যে পরীক্ষার সম্পূর্ণ সেট সম্পূর্ণ করে।
উদাহরণস্বরূপ, আপনি যদি N শার্ড তৈরি করেন, আপনার নির্বাচন করা প্রতিটি ডিভাইসের জন্য, Test Lab এন অভিন্ন ডিভাইসগুলিকে স্পিন করে এবং প্রতিটি ডিভাইসে পরীক্ষার একটি উপসেট চালায়। এর অর্থ হল শার্ড টেস্ট কেস প্রতি ডিভাইসে একাধিক পরীক্ষা কার্যকর করতে পারে। নন-শার্ডেড টেস্ট কেস, তবে ডিভাইস প্রতি একটি টেস্ট এক্সিকিকিউশনের ফলে। Test Lab ধারণাগুলি শিখতে, মূল ধারণাগুলি দেখুন।
Firebase কনসোলে টেস্ট শার্ডিং সক্ষম করতে, এই পদক্ষেপগুলি অনুসরণ করুন:
ইনস্ট্রুমেন্টেশন টেস্ট সেটআপে, অতিরিক্ত বিকল্পগুলিতে ক্লিক করুন।
Sharding বিভাগে, আপনি চালাতে চান শার্ডের সংখ্যা লিখুন।
টেস্ট শার্ডের জন্য বিলিং
Test Lab AndroidJUnitRunner-এর অন্তর্নির্মিত শার্ডিং মেকানিজম ব্যবহার করে আপনার শার্ডগুলি প্রয়োগ করে৷ খালি শার্ডগুলি ঘোরানোর জন্য চার্জ করা এড়াতে (অনির্ধারিত পরীক্ষার কেস ছাড়া শার্ডগুলি), আপনার তৈরি শার্ডগুলির সংখ্যা মোট পরীক্ষার ক্ষেত্রের সংখ্যার চেয়ে কম হওয়া উচিত। প্রতিটি টেস্ট কেস চালানোর জন্য কতক্ষণ লাগে তার উপর নির্ভর করে, সাধারণত প্রতি শার্ডে 2-10 টি টেস্ট কেস বরাদ্দ করা ভাল ধারণা।
বিলিং সম্পর্কে আরও তথ্যের জন্য, ব্যবহার, কোটা এবং বিলিং পড়ুন।