Espresso 테스트 프레임 워크-아키텍처

이 장에서는 에스프레소 테스트 프레임 워크의 용어, 간단한 에스프레소 테스트 케이스를 작성하는 방법 및 에스프레소 테스트 프레임 워크의 전체 워크 플로 또는 아키텍처에 대해 알아 보겠습니다.

개요

Espresso는 사용자 인터페이스와 Android 애플리케이션의 사용자 상호 작용을 테스트하기위한 많은 클래스를 제공합니다. 아래에 지정된대로 다섯 가지 범주로 그룹화 할 수 있습니다.

JUnit 러너

Android 테스트 프레임 워크는 JUnit3 및 JUnit4 스타일 테스트 케이스로 작성된 에스프레소 테스트 케이스를 실행하기위한 실행기 AndroidJUnitRunner를 제공합니다. 이는 안드로이드 애플리케이션에 국한되며 실제 기기 또는 에뮬레이터에서 에스프레소 테스트 케이스 및 테스트중인 애플리케이션로드를 투명하게 처리하고 테스트 케이스를 실행하며 테스트 케이스의 결과를보고합니다. 테스트 케이스에서 AndroidJUnitRunner를 사용하려면 @RunWith 주석을 사용하여 테스트 클래스에 주석을 추가 한 다음 아래 지정된대로 AndroidJUnitRunner 인수를 전달해야합니다.

@RunWith(AndroidJUnit4.class)
   public class ExampleInstrumentedTest {
}

JUnit 규칙

Android 테스트 프레임 워크는 테스트 케이스를 실행하기 전에 Android 활동을 시작하는 ActivityTestRule 규칙을 제공합니다. @ Test` 및 @Before 주석이 달린 각 메서드 전에 활동을 시작합니다. @After 주석이 달린 메소드 후에 활동을 종료합니다. 샘플 코드는 다음과 같습니다.

@Rule
public ActivityTestRule<MainActivity> mActivityTestRule = new ActivityTestRule<>(MainActivity.class);

여기서 MainActivity 는 테스트 케이스를 실행하기 전에 실행되고 특정 테스트 케이스가 실행 된 후에 삭제되는 활동입니다.

ViewMatchers

Espresso는 androidx.test.espresso.matcher.ViewMatchers 패키지 에서 많은 수의 뷰 매처 클래스를 제공 하여 Android 활동 화면의 뷰 계층 구조에서 UI 요소 / 뷰를 일치시키고 찾습니다. Espresso의 onView 메서드는 Matcher (View matchers) 유형의 단일 인수를 가져와 해당 UI보기를 찾은 다음 해당 ViewInteraction 개체를 반환 합니다. onView 메서드에 의해 반환 된 ViewInteraction 객체 는 일치 된 뷰를 클릭하는 것과 같은 작업을 호출하는 데 추가로 사용되거나 일치 된 뷰를 어설 션하는 데 사용될 수 있습니다. "Hello World!"라는 텍스트가있는보기를 찾는 샘플 코드 다음과 같다,

ViewInteraction viewInteraction = Espresso.onView(withText("Hello World!"));

여기서 withText 는 "Hello World!"라는 텍스트가있는 UI 뷰를 일치시키는 데 사용할 수있는 matcher입니다.

ViewActions

Espresso는 선택한 / 일치하는보기에서 다른 작업을 호출하기 위해 많은보기 작업 클래스 (androidx.test.espresso.action.ViewActions에서)를 제공합니다. 일단 onView 일치 반환 ViewInteraction의 객체, 모든 작업은 "수행"의 방법을 호출하여 호출 할 수 ViewInteraction의 객체와 적절한 뷰 액션으로 전달합니다. 매칭 된 뷰를 클릭하는 샘플 코드는 다음과 같습니다.

ViewInteraction viewInteraction = Espresso.onView(withText("Hello World!"));
viewInteraction.perform(click());

여기에서 일치보기의 클릭 동작이 호출됩니다.

ViewAssertions

뷰 매처 및 뷰 작업과 유사하게 Espresso는 일치 뷰가 예상 한대로임을 주장하기 위해 많은 뷰 어설 션 ( androidx.test.espresso.assertion.ViewAssertions 패키지에서)을 제공합니다. onView가 일치 반환되면 ViewInteraction의 객체를 어떤 어설가의 체크 방법을 사용하여 확인할 수 있습니다 ViewInteraction을 적절한 뷰 주장으로 전달하여. 일치하는 뷰가 다음과 같다고 주장하는 샘플 코드,

ViewInteraction viewInteraction = Espresso.onView(withText("Hello World!"));
viewInteraction.check(matches(withId(R.id.text_view)));

여기서 매치 는 뷰 매처를 받아들이고 뷰 어설 션을 반환하며, 이는 ViewInteraction의 check 메소드로 확인할 수 있습니다 .

Espresso 테스트 프레임 워크의 워크 플로

에스프레소 테스트 프레임 워크가 어떻게 작동하는지, 그리고 어떤 종류의 사용자 상호 작용을 간단하고 유연한 방식으로 수행 할 수있는 옵션을 제공하는지 이해하겠습니다. 에스프레소 테스트 케이스의 워크 플로는 다음과 같습니다.

  • 앞서 배운 것처럼 Android JUnit 실행기 인 AndroidJUnit4 는 Android 테스트 케이스를 실행합니다. 에스프레소 테스트 케이스는 @RunWith (AndroidJUnut.class) 로 표시되어야합니다 . 먼저 AndroidJUnit4 는 테스트 케이스를 실행할 환경을 준비합니다. 연결된 Android 기기 또는 에뮬레이터를 시작하고 애플리케이션을 설치하며 테스트 할 애플리케이션이 준비 상태인지 확인합니다. 테스트 케이스를 실행하고 결과를보고합니다.

  • Espresso는 활동 을 지정하기 위해 ActivityTestRule 유형의 JUnit 규칙이 하나 이상 필요 합니다. Android JUnit 실행기는 ActivityTestRule을 사용하여 시작할 활동을 시작합니다 .

  • 모든 테스트 케이스 는 원하는보기와 일치하고 찾기 위해 최소한의 단일 onView 또는 onDate ( AdapterView 와 같은 데이터 기반보기를 찾는 데 사용됨 ) 메소드 호출이 필요합니다. onView 또는 onData는 ViewInteraction 객체를 반환 합니다.

  • ViewInteraction 객체가 반환 되면 선택한 뷰의 작업을 호출하거나 어설 션을 사용하여 예상 뷰에 대한 뷰를 확인할 수 있습니다.

  • 사용 가능한보기 작업 중 하나를 전달 하여 ViewInteraction 개체 의 수행 메서드를 사용하여 작업을 호출 할 수 있습니다 .

  • 사용 가능한 뷰 어설 션 중 하나를 전달 하여 ViewInteraction 개체 의 check 메서드를 사용하여 어설 션을 호출 할 수 있습니다 .

워크 플로 의 다이어그램 표현은 다음과 같습니다.

예-어설 션보기

"Hello World!"가있는 텍스트보기를 찾는 간단한 테스트 케이스를 작성해 보겠습니다. "HelloWorldApp"애플리케이션에 텍스트를 입력 한 다음 뷰 어설 션을 사용하여 어설 션합니다. 완전한 코드는 다음과 같습니다.

package com.tutorialspoint.espressosamples.helloworldapp;

import android.content.Context;
import androidx.test.InstrumentationRegistry;
import androidx.test.rule.ActivityTestRule;
import androidx.test.runner.AndroidJUnit4;
import org.junit.Rule;
import org.junit.Test;
import org.junit.runner.RunWith;
import static androidx.test.espresso.Espresso.onView;
import static androidx.test.espresso.matcher.ViewMatchers.withText;;
import static androidx.test.espresso.assertion.ViewAssertions.matches;
import static org.junit.Assert.*;
/**
   * Instrumented test, which will execute on an Android device.
   *
   * @see <a href="http://d.android.com/tools/testing">Testing documentation</a>
*/
@RunWith(AndroidJUnit4.class)
public class ExampleInstrumentedTest {
   @Rule
   public ActivityTestRule<MainActivity> mActivityTestRule = new ActivityTestRule<>(MainActivity.class);
   @Test
   public void view_isCorrect() {
      onView(withText("Hello World!")).check(matches(isDisplayed()));
   }
   @Test
   public void useAppContext() {
      // Context of the app under test.
      Context appContext = InstrumentationRegistry.getTargetContext();
      assertEquals("com.tutorialspoint.espressosamples.helloworldapp", appContext.getPackageName());
   }
}

여기에서는 withText 뷰 매처를 사용 하여 "Hello World!"가있는 텍스트 뷰를 찾았습니다. 텍스트와 일치하는 뷰 어설 션을 통해 텍스트 뷰가 제대로 표시되는지 확인합니다. Android Studio에서 테스트 케이스가 호출되면 테스트 케이스를 실행하고 아래와 같이 성공 메시지를보고합니다.

view_isCorrect 테스트 케이스