শেয়ারিং কনফিগার করুন

এই পৃষ্ঠাটি বর্ণনা করে যে শার্ডিংয়ের মাধ্যমে একটি স্যুট মডিউল ( AndroidTest.xml ) এর জন্য কী টিউন করা সম্ভব এবং ল্যাবে ক্রমাগত সম্পাদনের সময় সর্বোত্তম গতির পারফরম্যান্স পাওয়া যায়৷ আমরা প্রতিটি ব্যবহারের জন্য যুক্তিসঙ্গত সহ সাধারণ পদ্ধতিতে বিকল্পগুলি বর্ণনা করার চেষ্টা করব।

ল্যাবে একটানা স্যুট চালানোর সময়, সামগ্রিক সমাপ্তির সময় কমানোর জন্য স্যুটটিকে সাধারণত বিভিন্ন ডিভাইস জুড়ে শার্ড করা হয়। জোতা সাধারণত সামগ্রিক সমাপ্তির সময় (যখন শেষ শার্ড শেষ হয়) কমানোর জন্য প্রতিটি শার্ডের কার্যকর করার সময়কে ভারসাম্য বজায় রাখার চেষ্টা করে; কিন্তু কিছু পরীক্ষার প্রকৃতির কারণে, আমাদের সবসময় পর্যাপ্ত আত্মদর্শন থাকে না এবং মডিউল মালিককে কিছু আচরণের সুর করার প্রয়োজন হয়।

Shardable না shardable?

একটি মডিউল ( AndroidTest.xml ) কে <option name="not-shardable" value="true" /> দিয়ে ট্যাগ করা সম্ভব যাতে জোতাকে সূচিত করা যায় যে এটি শার্ড করা উচিত নয়।

একটি সাধারণ মডিউলে, জোতাকে আপনার মডিউলটি (ডিফল্ট আচরণ) শার্ড করতে দেওয়া সঠিক কাজ। কিন্তু কিছু ক্ষেত্রে, আপনি সেই আচরণটিকে ওভাররাইড করতে চাইতে পারেন:

  • যখন আপনার মডিউলের সেটআপ ব্যয়বহুল হয়:

একটি মডিউল শেয়ার করার ফলে প্রস্তুতিতে পরিণত হয় (এপিকে ইনস্টল করুন, পুশ ফাইল, ইত্যাদি) সম্ভবত জড়িত প্রতি ডিভাইসে একবার চালানো হবে। যদি আপনার মডিউল সেটআপ দীর্ঘ এবং ব্যয়বহুল হয় এবং পরীক্ষার রানটাইমের তুলনায় প্রতিলিপি করা মূল্যবান না হয়, তাহলে আপনার মডিউলটিকে অ-শর্ডিবল হিসাবে ট্যাগ করা উচিত।

  • যখন আপনার মডিউলে পরীক্ষার সংখ্যা কম হয়:

একটি মডিউল ভাগ করার ফলে সমস্ত পরীক্ষার ক্ষেত্রে সম্ভবত বিভিন্ন ডিভাইসে স্বাধীনভাবে চালানো হয়। এটি প্রথম পয়েন্টের সাথে সম্পর্কিত; যদি আপনার পরীক্ষার সংখ্যা কম হয়, তবে আপনি একটি একক পরীক্ষা দিয়ে শেষ করতে পারেন বা কিছু শার্ডে কোনো পরীক্ষা নাও হতে পারে, যা প্রস্তুতির যে কোনো পদক্ষেপকে বেশ ব্যয়বহুল করে তুলবে। একটি একক পরীক্ষার ক্ষেত্রে একটি APK ইনস্টল করা সাধারণত এটির মূল্য নয়, উদাহরণস্বরূপ।

ইন্সট্রুমেন্টেশন পরীক্ষা: শার্ডের সর্বোচ্চ সংখ্যা?

AndroidJUnitTest- এর মাধ্যমে চলমান একটি ইন্সট্রুমেন্টেশন টেস্টের মাধ্যমে বোঝা যায় না যে কতগুলি পরীক্ষা ইনস্ট্রুমেন্টেশনের অংশ, যতক্ষণ না আমরা প্রকৃতপক্ষে APK ইনস্টল ও রান করি। এই ক্রিয়াকলাপগুলি ব্যয়বহুল এবং স্যুটের সমস্ত মডিউল অংশের জন্য শার্ডিংয়ের সময়ে কার্যকর করা যায় না।

জোতা ইন্সট্রুমেন্টেশন পরীক্ষা ওভার-শার্ড এবং কিছু খালি shards সঙ্গে শেষ হতে পারে; একটি ইন্সট্রুমেন্টেশন পরীক্ষা ছয়টি শার্ডে পাঁচটি পরীক্ষা সহ একটি পরীক্ষা সহ পাঁচটি শার্ড এবং কোন পরীক্ষা ছাড়াই একটি শার্ডের ফলাফল হয়। এই শার্ডগুলির প্রতিটির জন্য একটি ব্যয়বহুল APK ইনস্টলেশনের প্রয়োজন হবে।

তাই যখন ইন্সট্রুমেন্টেশন টেস্ট APK-এ পরীক্ষার সংখ্যা কম থাকে, তখন মডিউলটিকে <option name="not-shardable" value="true" /> দিয়ে ট্যাগ করা হলে তা হারনেসকে জানতে পারবে যে মডিউলটি শার্ড করা মূল্যহীন।

AndroidJUnitTest রানারের একটি বিশেষ বিকল্প রয়েছে যা এটিতে শার্ডের সর্বোচ্চ সংখ্যা নির্দিষ্ট করতে দেয়: <option name="ajur-max-shard" value="5" />

এটি আপনাকে আমন্ত্রণ স্তরে অনুরোধ করা শার্ডের সংখ্যা নির্বিশেষে ইন্সট্রুমেন্টেশনটি কতবার শার্ড করা যেতে পারে তা নির্দিষ্ট করতে দেয়। ডিফল্টরূপে, ইনস্ট্রুমেন্টেশনটি আমন্ত্রণের জন্য অনুরোধ করা শার্ডের সংখ্যায় ভাগ করা হবে।

উদাহরণ স্বরূপ, যদি আপনার ইন্সট্রুমেন্টেশন টেস্ট APK-এ শুধুমাত্র দুটি টেস্ট কেস থাকে কিন্তু আপনি এখনও এটিকে শার্ড করতে চান, তাহলে 2 এর ajur-max-shard মান থাকলে নিশ্চিত হবে যে আপনি খালি শার্ড তৈরি করছেন না।