Testy hosta JAR (Java)

Testy hosta JAR powinny zostać zaimplementowane, aby zapewnić pełne pokrycie kodu twojego oprogramowania. Postępuj zgodnie z instrukcjami tworzenia lokalnych testów jednostkowych . Napisz małe testy jednostkowe, aby zweryfikować określoną funkcję i nic więcej.

Przykład

Poniższy plik Blueprint zawiera prosty przykład testu hosta Hello World JAR do skopiowania i dostosowania do własnych potrzeb: platform_testing/tests/example/jarhosttest/Android.bp

Odpowiada to rzeczywistemu kodowi testowemu znalezionemu pod adresem: platform_testing/tests/example/jarhosttest/test/android/test/example/helloworld/HelloWorldTest.java

Migawka pliku Blueprint jest dołączona tutaj dla wygody:

java_test_host {
    name: "HelloWorldHostTest",

    test_suites: ["general-tests"],

    srcs: ["test/**/*.java"],

    static_libs: [
        "junit",
        "mockito",
    ],
}

Deklaracja java_test_host na początku wskazuje, że jest to test hosta JAR. Zobacz przykład jego użycia w: frameworks/base/tools/powermodel/Android.bp

Ustawienia

Poniżej znajdują się objaśnienia następujących ustawień:

  • Ustawienie name jest wymagane, gdy określony jest typ modułu java_test_host (na początku bloku). To ustawienie nadaje nazwę modułowi, a wynikowy plik JAR ma tę samą nazwę i przyrostek .jar . W poniższym przykładzie wynikowy testowy plik JAR nosi nazwę HelloWorldHostTest.jar . Ponadto to ustawienie określa również nazwę docelową make dla twojego modułu, dzięki czemu możesz użyć make [options] <HelloWorldHostTest> do zbudowania modułu testowego i wszystkich jego zależności.

    name: "HelloWorldHostTest",
    
  • Ustawienie test_suites sprawia, że ​​test jest łatwo wykrywalny przez wiązkę testową Federacji Handlowej. Tutaj można dodać inne zestawy testów, takie jak CTS, aby można było udostępnić test testowy hosta JAR.

    test_suites: ["general-tests"],
    
  • Ustawienie static_libs instruuje system kompilacji, aby włączył zawartość nazwanych modułów do wynikowego pliku APK bieżącego modułu. Oznacza to, że każdy nazwany moduł powinien utworzyć plik .jar . Zawartość modułu jest używana do rozpoznawania odwołań do ścieżek klas w czasie kompilacji i włączana do wynikowego pliku APK.

    static_libs: [
        "junit",
    ],