সহজ বিল্ড কনফিগারেশন

প্রতিটি নতুন টেস্ট মডিউলের অবশ্যই একটি কনফিগারেশন ফাইল থাকতে হবে যাতে মডিউল মেটাডেটা, কম্পাইল-টাইম নির্ভরতা এবং প্যাকেজিং নির্দেশাবলী সহ বিল্ড সিস্টেমকে নির্দেশিত করা যায়। Android এখন সহজ পরীক্ষা কনফিগারেশনের জন্য Soong বিল্ড সিস্টেম ব্যবহার করে।

Soong ব্লুপ্রিন্ট বা .bp ফাইলগুলি ব্যবহার করে, যেগুলি তৈরি করতে মডিউলগুলির JSON-এর মতো সহজ ঘোষণামূলক বিবরণ৷ এই বিন্যাসটি পূর্ববর্তী রিলিজে ব্যবহৃত মেক-ভিত্তিক সিস্টেমকে প্রতিস্থাপন করে। সম্পূর্ণ বিশদ বিবরণের জন্য কন্টিনিউয়াস ইন্টিগ্রেশন ড্যাশবোর্ডে সুং রেফারেন্স ফাইলগুলি দেখুন।

কাস্টম টেস্টিং সামঞ্জস্য করতে বা Android সামঞ্জস্য পরীক্ষা স্যুট (CTS) ব্যবহার করতে, পরিবর্তে জটিল পরীক্ষা কনফিগারেশন অনুসরণ করুন।

উদাহরণ

নীচের এন্ট্রিগুলি এই উদাহরণ ব্লুপ্রিন্ট কনফিগারেশন ফাইল থেকে এসেছে: /platform_testing/tests/example/instrumentation/Android.bp

সুবিধার জন্য এখানে একটি স্ন্যাপশট অন্তর্ভুক্ত করা হয়েছে:

android_test {
    name: "HelloWorldTests",
    srcs: ["src/**/*.java"],
    sdk_version: "current",
    static_libs: ["androidx.test.runner"],
    certificate: "platform",
    test_suites: ["device-tests"],
}

লক্ষ্য করুন শুরুতে android_test ঘোষণাটি নির্দেশ করে যে এটি একটি পরীক্ষা। android_app সহ এটি বিপরীতভাবে নির্দেশ করবে এটি একটি বিল্ড প্যাকেজ।

সেটিংস

নিম্নলিখিত সেটিংস গারনার ব্যাখ্যা:

    name: "HelloWorldTests",

android_test মডিউল টাইপ নির্দিষ্ট করা হলে name সেটিং প্রয়োজন হয় (ব্লকের শুরুতে)। এটি আপনার মডিউলের একটি নাম দেয়, এবং ফলস্বরূপ APK-এর নাম একই এবং একটি .apk প্রত্যয় সহ হবে, যেমন এই ক্ষেত্রে, ফলাফলের পরীক্ষার apk-এর নাম দেওয়া হয়েছে HelloWorldTests.apk । উপরন্তু, এটি আপনার মডিউলের জন্য একটি মেক টার্গেট নামও সংজ্ঞায়িত করে, যাতে আপনি আপনার পরীক্ষার মডিউল এবং এর সমস্ত নির্ভরতা তৈরি করতে make [options] <HelloWorldTests> ব্যবহার করতে পারেন।

    static_libs: ["androidx.test.runner"],

static_libs সেটিং বিল্ড সিস্টেমকে নির্দেশ দেয় যে নামকৃত মডিউলের বিষয়বস্তু বর্তমান মডিউলের apk-এ অন্তর্ভুক্ত করতে। এর মানে হল যে প্রতিটি নামযুক্ত মডিউল একটি .jar ফাইল তৈরি করবে বলে আশা করা হচ্ছে, এবং এর বিষয়বস্তু কম্পাইলের সময় ক্লাসপাথ রেফারেন্সগুলি সমাধান করার জন্য ব্যবহার করা হবে, সেইসাথে ফলাফল apk-এ অন্তর্ভুক্ত করা হবে।

androidx.test.runner মডিউলটি AndroidX টেস্ট রানার লাইব্রেরির জন্য প্রি-বিল্ট, যার মধ্যে রয়েছে টেস্ট রানার AndroidJUnitRunnerAndroidJUnitRunner JUnit4 টেস্টিং ফ্রেমওয়ার্ককে সমর্থন করে এবং Android 10-এ InstrumentationTestRunner প্রতিস্থাপিত করেছে । Android-এ টেস্ট অ্যাপে Android অ্যাপ পরীক্ষা করার বিষয়ে আরও পড়ুন।

আপনি যদি একটি নতুন ইন্সট্রুমেন্টেশন মডিউল তৈরি করেন, তাহলে আপনার টেস্ট রানার হিসেবে সবসময় androidx.test.runner লাইব্রেরি দিয়ে শুরু করা উচিত। প্ল্যাটফর্ম সোর্স ট্রিতে অন্যান্য দরকারী টেস্টিং ফ্রেমওয়ার্ক যেমন ub-uiautomator , mockito-target , easymock এবং আরও অনেক কিছু অন্তর্ভুক্ত রয়েছে।

    certificate: "platform",

certificate সেটিং বিল্ড সিস্টেমকে মূল প্ল্যাটফর্মের মতো একই শংসাপত্রের সাথে apk-এ স্বাক্ষর করার নির্দেশ দেয়৷ আপনার পরীক্ষা যদি একটি স্বাক্ষর সুরক্ষিত অনুমতি বা API ব্যবহার করে তাহলে এটি প্রয়োজন। মনে রাখবেন যে এটি প্ল্যাটফর্ম ক্রমাগত পরীক্ষার জন্য উপযুক্ত, কিন্তু CTS পরীক্ষা মডিউলগুলিতে ব্যবহার করা উচিত নয় । মনে রাখবেন যে এই উদাহরণটি শুধুমাত্র চিত্রের উদ্দেশ্যে এই শংসাপত্র সেটিং ব্যবহার করে: উদাহরণের পরীক্ষার কোডটি আসলে বিশেষ প্ল্যাটফর্ম শংসাপত্রের সাথে পরীক্ষার apk স্বাক্ষর করার প্রয়োজন নেই৷

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

অন্যান্য ক্ষেত্রে, আপনার এই সেটিংটি থাকা দরকার নেই: বিল্ড সিস্টেমটি কেবল বিল্ড বৈকল্পিকের উপর ভিত্তি করে একটি ডিফল্ট অন্তর্নির্মিত শংসাপত্র দিয়ে স্বাক্ষর করবে এবং এটিকে সাধারণত dev-keys বলা হয়।

    test_suites: ["device-tests"],

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

${ANDROID_PRODUCT_OUT}/testcases/HelloWorldTests/HelloWorldTests.apk

ঐচ্ছিক সেটিংস

নিম্নলিখিত ঐচ্ছিক সেটিংস গারনার ব্যাখ্যা:

    test_config: "path/to/hello_world_test.xml"

test_config সেটিং বিল্ড সিস্টেমকে নির্দেশ দেয় আপনার টেস্ট টার্গেটের জন্য একটি নির্দিষ্ট কনফিগারেশন প্রয়োজন। ডিফল্টরূপে, Android.bp এর পাশে একটি AndroidTest.xml কনফিগারেশনের সাথে যুক্ত।

    auto_gen_config: true

auto_gen_config সেটিং স্বয়ংক্রিয়ভাবে পরীক্ষা কনফিগার তৈরি করবে কি না তা নির্দেশ করে। Android.bp এর পাশে AndroidTest.xml না থাকলে, এই অ্যাট্রিবিউটটিকে স্পষ্টভাবে সত্যে সেট করার প্রয়োজন নেই।

    require_root: true

require_root সেটিং বিল্ড সিস্টেমকে স্বয়ংক্রিয় উৎপন্ন পরীক্ষা কনফিগারে RootTargetPreparer যোগ করার নির্দেশ দেয়। এটি রুট অনুমতির সাথে পরীক্ষা চালানোর নিশ্চয়তা দেয়।

    test_min_api_level: 29

test_min_api_level সেটিং স্বয়ংক্রিয়ভাবে তৈরি পরীক্ষা কনফিগারে MinApiLevelModuleController যোগ করার জন্য বিল্ড সিস্টেমকে নির্দেশ দেয়। যখন ট্রেড ফেডারেশন পরীক্ষা কনফিগার চালায়, তখন ro.product.first_api_level < test_min_api_level এর ডিভাইসের বৈশিষ্ট্য থাকলে পরীক্ষাটি এড়িয়ে যাবে।