Espresso 테스트 프레임 워크-AdapterView

AdapterViewAdapter를 사용하여 기본 데이터 소스에서 가져온 제품 목록 및 사용자 연락처와 같은 유사한 정보 모음을 렌더링하도록 특별히 설계된 특수한 종류의보기 입니다. 데이터 소스는 복잡한 데이터베이스 항목에 대한 간단한 목록 일 수 있습니다. AdapterView 에서 파생 된보기 중 일부 는 ListView , GridViewSpinner 입니다.

AdapterView 는 기본 데이터 소스에서 사용 가능한 데이터의 양에 따라 동적으로 사용자 인터페이스를 렌더링합니다. 또한 AdapterView 는 화면의 사용 가능한 가시 영역에서 렌더링 할 수있는 최소한의 필수 데이터 만 렌더링합니다. AdapterView 는 메모리를 절약하고 기본 데이터가 큰 경우에도 사용자 인터페이스를 매끄럽게 보이게하기 위해이 작업을 수행합니다.

분석시 AdapterView 아키텍처 의 특성으로 인해 테스트 할 특정 뷰가 처음에 전혀 렌더링되지 않을 수 있기 때문에 onView 옵션과 해당 뷰 매 처가 관련이 없습니다. 운 좋게도 espresso 는 hamcrest matchers (기본 데이터의 데이터 유형과 관련이있는)를 받아 기본 데이터와 일치시키고 일치 된 데이터의 뷰에 해당하는 DataInteraction 유형의 개체를 반환하는 onData ( ) 메서드를 제공합니다 . 샘플 코드는 다음과 같습니다.

onData(allOf(is(instanceOf(String.class)), startsWith("Apple"))).perform(click())

여기서 onData () 는 기본 데이터 (배열 목록)에서 사용할 수있는 경우 "Apple"항목과 일치 하고 일치하는 뷰 ( "Apple"항목에 해당하는 TextView )와 상호 작용하기 위해 DataInteraction 개체를 반환합니다 .

행동 양식

DataInteraction 은 뷰와 상호 작용할 수있는 아래 메서드를 제공합니다.

행하다()

이것은 뷰 액션을 받아들이고 전달 된 뷰 액션을 실행합니다.

onData(allOf(is(instanceOf(String.class)), startsWith("Apple"))).perform(click())

검사()

이것은 뷰 어설 션을 받아들이고 전달 된 뷰 어설 션을 확인합니다.

onData(allOf(is(instanceOf(String.class)), startsWith("Apple")))
   .check(matches(withText("Apple")))

inAdapterView ()

이것은 뷰 매처를 허용합니다. 전달 된 뷰 매처를 기반으로 특정 AdapterView 를 선택 하고 일치하는 AdapterView 와 상호 작용하기 위해 DataInteraction 객체를 반환합니다.

onData(allOf())
   .inAdapterView(withId(R.id.adapter_view))
   .atPosition(5)
   .perform(click())

atPosition ()

이것은 정수 유형의 인수를 허용하고 기본 데이터에서 항목의 위치를 ​​참조합니다. 전달 된 데이터의 위치 값에 해당하는 뷰를 선택하고 일치하는 뷰와 상호 작용할 DataInteraction 객체를 반환합니다 . 기본 데이터의 올바른 순서를 알고 있다면 유용 할 것입니다.

onData(allOf())
   .inAdapterView(withId(R.id.adapter_view))
   .atPosition(5)
   .perform(click())

onChildView ()

이것은 뷰 매처를 받아들이고 특정 자식 뷰 내의 뷰와 일치합니다. 예를 들어, AdapterView 기반 제품 목록에서 구매 버튼 과 같은 특정 항목과 상호 작용할 수 있습니다 .

onData(allOf(is(instanceOf(String.class)), startsWith("Apple")))
   .onChildView(withId(R.id.buy_button))
   .perform(click())

샘플 애플리케이션 작성

아래 단계에 따라 AdapterView를 기반으로 간단한 애플리케이션을 작성 하고 onData () 메서드를 사용하여 테스트 케이스를 작성합니다 .

  • Android 스튜디오를 시작하십시오.

  • 앞에서 설명한대로 새 프로젝트를 만들고 이름을 MyFruitApp으로 지정 합니다.

  • RefactorMigrate to AndroidX 옵션 메뉴 를 사용하여 애플리케이션을 AndroidX 프레임 워크로 마이그레이션 합니다.

  • 기본 활동에서 기본 디자인을 제거하고 ListView를 추가하십시오 . activity_main.xml 의 내용은 다음과 같습니다.

<?xml version = "1.0" encoding = "utf-8"?>
<RelativeLayout xmlns:android = "http://schemas.android.com/apk/res/android"
   xmlns:app = "http://schemas.android.com/apk/res-auto"
   xmlns:tools = "http://schemas.android.com/tools"
   android:layout_width = "match_parent"
   android:layout_height = "match_parent"
   tools:context = ".MainActivity">
   <ListView
      android:id = "@+id/listView"
      android:layout_width = "wrap_content"
      android:layout_height = "wrap_content" />
</RelativeLayout>
  • 새 레이아웃 리소스 인 item.xml 을 추가 하여 목록보기의 항목 템플릿을 지정합니다. item.xml 의 내용은 다음과 같습니다.

<?xml version = "1.0" encoding = "utf-8"?>
<TextView xmlns:android = "http://schemas.android.com/apk/res/android"
   android:id = "@+id/name"
   android:layout_width = "fill_parent"
   android:layout_height = "fill_parent"
   android:padding = "8dp"
/>
  • 이제 과일 배열을 기본 데이터로 사용하는 어댑터를 만들고 목록보기로 설정합니다. 이 요구 사항은에서 수행 할 에서 onCreate ()MainActivity 아래에 지정된대로

@Override
protected void onCreate(Bundle savedInstanceState) {
   super.onCreate(savedInstanceState);
   setContentView(R.layout.activity_main);
   
   // Find fruit list view
   final ListView listView = (ListView) findViewById(R.id.listView);
   
   // Initialize fruit data
   String[] fruits = new String[]{
      "Apple", 
      "Banana", 
      "Cherry", 
      "Dates", 
      "Elderberry", 
      "Fig", 
      "Grapes", 
      "Grapefruit", 
      "Guava",
      "Jack fruit", 
      "Lemon",
      "Mango", 
      "Orange", 
      "Papaya", 
      "Pears", 
      "Peaches", 
      "Pineapple",
      "Plums", 
      "Raspberry",
      "Strawberry", 
      "Watermelon"
   };
   
   // Create array list of fruits
   final ArrayList<String> fruitList = new ArrayList<String>();
   for (int i = 0; i < fruits.length; ++i) {
      fruitList.add(fruits[i]);
   }
   
   // Create Array adapter
   final ArrayAdapter adapter = new ArrayAdapter(this, R.layout.item, fruitList);
   
   // Set adapter in list view
   listView.setAdapter(adapter);
}
  • 이제 코드를 컴파일하고 애플리케이션을 실행합니다. My Fruit 앱 의 스크린 샷은 다음과 같습니다.

  • 이제 ExampleInstrumentedTest.java 파일을 열고 아래와 같이 ActivityTestRule 을 추가 합니다.

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

또한, 확인 시험 구성에서 수행 할 응용 프로그램 / build.gradle -

dependencies {
   testImplementation 'junit:junit:4.12'
   androidTestImplementation 'androidx.test:runner:1.1.1'
   androidTestImplementation 'androidx.test:rules:1.1.1'
   androidTestImplementation 'androidx.test.espresso:espresso-core:3.1.1'
}
  • 아래와 같이 목록보기를 테스트하기 위해 새로운 테스트 케이스를 추가합니다.

@Test
public void listView_isCorrect() {
   // check list view is visible
   onView(withId(R.id.listView)).check(matches(isDisplayed()));
   onData(allOf(is(instanceOf(String.class)), startsWith("Apple"))).perform(click());
   onData(allOf(is(instanceOf(String.class)), startsWith("Apple")))
      .check(matches(withText("Apple")));
   // click a child item
   onData(allOf())
      .inAdapterView(withId(R.id.listView))
      .atPosition(10)
      .perform(click());
}
  • 마지막으로 Android Studio의 컨텍스트 메뉴를 사용하여 테스트 케이스를 실행하고 모든 테스트 케이스가 성공했는지 확인합니다.