Kerangka Pengujian Espresso - Lihat Pernyataan

Seperti yang telah dibahas sebelumnya, pernyataan tampilan digunakan untuk menegaskan bahwa tampilan aktual (ditemukan menggunakan pencocokan tampilan) dan tampilan yang diharapkan adalah sama. Kode contoh adalah sebagai berikut,

onView(withId(R.id.my_view)) .check(matches(withText("Hello")))

Sini,

  • onView () mengembalikan objek ViewInteration yang sesuai dengan tampilan yang cocok. ViewInteraction digunakan untuk berinteraksi dengan tampilan yang cocok.

  • withId (R.id.my_view) mengembalikan matcher tampilan yang akan cocok dengan tampilan (aktual) yang memiliki atribut id sama dengan my_view .

  • withText ("Hello") juga mengembalikan pencocokan tampilan yang akan cocok dengan tampilan (diharapkan) yang memiliki atribut teks sama dengan Hello .

  • check adalah metode yang menerima argumen tipe ViewAssertion dan melakukan pernyataan menggunakan diteruskan dalam objek ViewAssertion .

  • match (withText ("Hello")) mengembalikan pernyataan tampilan, yang akan melakukanreal jobuntuk menegaskan bahwa tampilan aktual (ditemukan menggunakan withId ) dan tampilan yang diharapkan (ditemukan menggunakan withText ) adalah satu dan sama.

Mari kita pelajari beberapa metode yang disediakan oleh framework pengujian espresso untuk menegaskan objek tampilan.

tidak ada()

Mengembalikan pernyataan tampilan, yang memastikan bahwa view matcher tidak menemukan tampilan yang cocok.

onView(withText("Hello")) .check(doesNotExist());

Di sini, kasus uji memastikan bahwa tidak ada tampilan dengan teks Halo.

pertandingan ()

Menerima pencocok tampilan target dan mengembalikan pernyataan tampilan, yang memastikan bahwa pencocok tampilan (aktual) ada dan cocok dengan tampilan yang cocok dengan pencocok tampilan target.

onView(withId(R.id.textView_hello)) .check(matches(withText("Hello World!")));

Di sini, kasus uji memastikan bahwa tampilan yang memiliki id, R.id.textView_hello ada dan cocok dengan tampilan target dengan teks Hello World!

isBottomAlignedWith ()

Menerima pencocok tampilan target dan mengembalikan pernyataan tampilan, yang memastikan bahwa pencocok tampilan (aktual) ada dan rata bawah dengan pencocok tampilan target.

onView(withId(R.id.view)) .check(isBottomAlignedWith(withId(R.id.target_view)))

Di sini, kasus pengujian memastikan bahwa tampilan yang memiliki id, R.id.view ada dan sejajar paling bawah dengan tampilan yang memiliki id, R.id.target_view .

isCompletelyAbove ()

Menerima pencocok tampilan target dan mengembalikan pernyataan tampilan, yang memastikan bahwa pencocok tampilan (aktual) ada dan diposisikan sepenuhnya di atas pencocok tampilan target.

onView(withId(R.id.view)) .check(isCompletelyAbove(withId(R.id.target_view)))

Di sini, kasus pengujian memastikan bahwa tampilan yang memiliki id, R.id.view ada dan diposisikan sepenuhnya di atas tampilan yang memiliki id, R.id.target_view

isCompletelyBelow ()

Menerima pencocok tampilan target dan mengembalikan pernyataan tampilan, yang memastikan bahwa pencocok tampilan (aktual) ada dan diposisikan sepenuhnya di bawah pencocok tampilan target.

onView(withId(R.id.view)) .check(isCompletelyBelow(withId(R.id.target_view)))

Di sini, kasus pengujian memastikan bahwa tampilan yang memiliki id, R.id.view ada dan diposisikan sepenuhnya di bawah tampilan yang memiliki id, R.id.target_view .

isCompletelyLeftOf ()

Menerima pencocok tampilan target dan mengembalikan pernyataan tampilan, yang memastikan bahwa pencocok tampilan (aktual) ada dan diposisikan sepenuhnya di kiri pencocok tampilan target.

onView(withId(R.id.view)) .check(isCompletelyLeftOf(withId(R.id.target_view)))

Di sini, kasus pengujian memastikan bahwa tampilan yang memiliki id, R.id.view ada dan diposisikan sepenuhnya di kiri tampilan yang memiliki id, R.id.target_view

isCompletelyRightOf ()

Menerima pencocok tampilan target dan mengembalikan pernyataan tampilan, yang memastikan bahwa pencocok tampilan (aktual) ada dan diposisikan sepenuhnya di kanan pencocok tampilan target.

onView(withId(R.id.view)) .check(isCompletelyRightOf(withId(R.id.target_view)))

Di sini, kasus pengujian memastikan bahwa tampilan yang memiliki id, R.id.view ada dan diposisikan sepenuhnya di kanan tampilan yang memiliki id, R.id.target_view.

isLeftAlignedWith ()

Menerima pencocok tampilan target dan mengembalikan pernyataan tampilan, yang memastikan bahwa pencocok tampilan (aktual) ada dan rata kiri dengan pencocok tampilan target.

onView(withId(R.id.view)) .check(isLeftAlignedWith(withId(R.id.target_view)))

Di sini, kasus uji memastikan bahwa tampilan yang memiliki id, R.id.view ada dan dibiarkan sejajar dengan tampilan yang memiliki id, R.id.target_view

isP partiallyAbove ()

Menerima pencocok tampilan target dan mengembalikan pernyataan tampilan, yang memastikan bahwa pencocok tampilan (aktual) ada dan diposisikan sebagian di atas pencocok tampilan target.

onView(withId(R.id.view)) .check(isPartiallyAbove(withId(R.id.target_view)))

Di sini, kasus pengujian memastikan bahwa tampilan yang memiliki id, R.id.view ada dan diposisikan sebagian di atas tampilan yang memiliki id, R.id.target_view

isP PartiallyBelow ()

Menerima pencocok tampilan target dan mengembalikan pernyataan tampilan, yang memastikan bahwa pencocok tampilan (aktual) ada dan diposisikan sebagian di bawah pencocok tampilan target.

onView(withId(R.id.view)) .check(isPartiallyBelow(withId(R.id.target_view)))

Di sini, kasus pengujian memastikan bahwa tampilan yang memiliki id, R.id.view ada dan diposisikan sebagian di bawah tampilan yang memiliki id, R.id.target_view .

isP partiallyLeftOf ()

Menerima pencocok tampilan target dan mengembalikan pernyataan tampilan, yang memastikan bahwa pencocok tampilan (aktual) ada dan diposisikan sebagian di kiri pencocok tampilan target.

onView(withId(R.id.view)) .check(isPartiallyLeftOf(withId(R.id.target_view)))

Di sini, kasus pengujian memastikan bahwa tampilan yang memiliki id, R.id.view ada dan diposisikan sebagian di kiri tampilan yang memiliki id, R.id.target_view .

isP PartiallyRightOf ()

Menerima pencocok tampilan target dan mengembalikan pernyataan tampilan, yang memastikan bahwa pencocok tampilan (aktual) ada dan diposisikan sebagian di kanan pencocok tampilan target

onView(withId(R.id.view)) .check(isPartiallyRightOf(withId(R.id.target_view)))

Di sini, kasus pengujian memastikan bahwa tampilan yang memiliki id, R.id.view ada dan diposisikan sebagian di kanan tampilan yang memiliki id, R.id.target_view .

isRightAlignedWith ()

Menerima pencocok tampilan target dan mengembalikan pernyataan tampilan, yang memastikan bahwa pencocok tampilan (aktual) ada dan sejajar kanan dengan pencocok tampilan target.

onView(withId(R.id.view)) .check(isRightAlignedWith(withId(R.id.target_view)))

Di sini, kasus pengujian memastikan bahwa tampilan yang memiliki id, R.id.view ada dan sejajar dengan tampilan yang memiliki id, R.id.target_view .

isTopAlignedWith ()

Menerima pencocok tampilan target dan mengembalikan pernyataan tampilan, yang memastikan bahwa pencocok tampilan (aktual) ada dan sejajar atas dengan pencocok tampilan target.

onView(withId(R.id.view)) .check(isTopAlignedWith(withId(R.id.target_view)))

Di sini, kasus pengujian memastikan bahwa tampilan yang memiliki id, R.id.view ada dan diratakan paling atas dengan tampilan yang memiliki id, R.id.target_view

noEllipsizedText ()

Mengembalikan pernyataan tampilan, yang memastikan bahwa hierarki tampilan tidak berisi tampilan teks elipsis atau terpotong.

onView(withId(R.id.view)) .check(noEllipsizedText());

noMultilineButtons ()

Mengembalikan pernyataan tampilan, yang memastikan bahwa hierarki tampilan tidak berisi tombol multi baris.

onView(withId(R.id.view)) .check(noMultilineButtons());

noOverlaps ()

Mengembalikan pernyataan tampilan, yang memastikan bahwa objek turunan yang dapat ditetapkan ke TextView atau ImageView tidak tumpang tindih satu sama lain. Ini memiliki opsi lain, yang menerima pencocokan tampilan target dan mengembalikan pernyataan tampilan, yang memastikan bahwa tampilan turunan yang cocok dengan tampilan target tidak tumpang tindih.