Espresso 테스트 프레임 워크-작업보기

앞에서 배운 것처럼보기 작업은 Android 애플리케이션에서 사용자가 수행 할 수있는 모든 가능한 작업을 자동화합니다. Espresso onView 및 "onData" 는보기 작업을 수락하고 테스트 환경에서 해당 사용자 작업을 호출 / 자동화하는 수행 메서드를 제공 합니다. 예를 들어, "click ()"은 onView ( R.id.myButton ) .perform (click ()) 메서드에 전달 될 때 버튼의 클릭 이벤트 (id : "myButton" ) 를 발생시키는 뷰 액션 입니다. ) 테스트 환경에서.

이 장에서는 에스프레소 테스트 프레임 워크에서 제공하는보기 작업에 대해 알아 보겠습니다.

typeText ()

typeText ()문자열 유형의 하나의 인수 (텍스트)를 허용 하고보기 조치를 리턴합니다. 반환 된보기 작업은 제공된 텍스트를보기에 입력합니다. 텍스트를 배치하기 전에보기를 한 번 탭합니다. 내용이 이미 텍스트를 포함하고있는 경우 임의의 위치에 배치 될 수 있습니다.

onView(withId(R.id.text_view)).perform(typeText("Hello World!"))

typeTextIntoFocusedView ()

typeTextIntoFocusedView () 는 뷰의 커서 위치 바로 옆에 텍스트를 배치한다는 점을 제외하면 typeText () 와 유사합니다 .

onView(withId(R.id.text_view)).perform(typeTextIntoFocusedView("Hello World!"))

replaceText ()

replaceText () 는 뷰의 내용을 대체한다는 점을 제외하면 typeText () 와 유사합니다 .

onView(withId(R.id.text_view)).perform(typeTextIntoFocusedView("Hello World!"))

명확한 문구()

clearText () 에는 인수가 없으며 뷰의 텍스트를 지우는 뷰 액션을 반환합니다.

onView(withId(R.id.text_view)).perform(clearText())

pressKey ()

pressKey () 는 키 코드 (예 : KeyEvent.KEYCODE_ENTER )를 받아들이고 키 코드에 해당하는 키를 누르는보기 작업을 반환합니다.

onView(withId(R.id.text_view)).perform(typeText(
   "Hello World!", pressKey(KeyEvent.KEYCODE_ENTER))

pressMenuKey ()

pressMenuKey () 에는 인수가 없으며 하드웨어 메뉴 키를 누르는보기 작업을 반환합니다.

onView(withId(R.id.text_view)).perform(typeText(
   "Hello World!", pressKey(KeyEvent.KEYCODE_ENTER), pressMenuKey())

closeSoftKeyboard ()

closeSoftKeyboard () 에는 인수가 없으며 키보드가 열려있는 경우 닫는보기 작업을 반환합니다.

onView(withId(R.id.text_view)).perform(typeText(
   "Hello World!", closeSoftKeyboard())

딸깍 하는 소리()

click () 에는 인수가 없으며보기의 클릭 작업을 호출하는보기 작업을 반환합니다.

onView(withId(R.id.button)).perform(click())

더블 클릭()

doubleClick () 에는 인수가 없으며 뷰의 두 번 클릭 동작을 호출하는 뷰 동작을 반환합니다.

onView(withId(R.id.button)).perform(doubleClick())

longClick ()

longClick () 에는 인수가 없으며 뷰의 긴 클릭 동작을 호출하는 뷰 동작을 반환합니다.

onView(withId(R.id.button)).perform(longClick())

pressBack ()

pressBack ()에는 인수가 없으며 뒤로 버튼을 클릭하는보기 작업을 반환합니다.

onView(withId(R.id.button)).perform(pressBack())

pressBackUnconditionally ()

pressBackUnconditionally () 에는 인수가 없으며보기 작업을 반환합니다.이 작업은 뒤로 버튼을 클릭하고 뒤로 버튼 작업이 애플리케이션 자체를 종료하는 경우 예외를 throw하지 않습니다.

onView(withId(R.id.button)).perform(pressBack())

openLink ()

openLink () 에는 두 개의 인수가 있습니다. 첫 번째 인수 (링크 텍스트)는 Matcher 유형 이며 HTML 앵커 태그의 텍스트를 참조합니다. 두 번째 인수 (url)는 Matcher 유형 이며 HTML 앵커 태그의 URL을 참조합니다. TextView 에만 적용 됩니다. 텍스트보기의 콘텐츠에서 사용할 수있는 모든 HTML 앵커 태그를 수집하고 첫 번째 인수 (링크 텍스트) 및 두 번째 인수 (url)와 일치하는 앵커 태그를 찾은 다음 마지막으로 해당 URL을 여는보기 작업을 반환합니다. 내용이있는 텍스트보기를 고려해 보겠습니다.

<a href="http://www.google.com/">copyright</a>

그런 다음 아래 테스트 사례를 사용하여 링크를 열고 테스트 할 수 있습니다.

onView(withId(R.id.text_view)).perform(openLink(is("copyright"),
   is(Uri.parse("http://www.google.com/"))))

여기에서 openLink는 텍스트보기의 내용을 가져오고, 저작권이 텍스트로, www.google.com 이 URL 로있는 링크를 찾아 브라우저에서 URL을 엽니 다.

openLinkWithText ()

openLinkWithText () 에는 ** String * 또는 Matcher 유형일 수있는 하나의 인수가 있습니다. 이것은 단순히 openLink * 메서드 의 지름길 입니다.

onView(withId(R.id.text_view)).perform(openLinkWithText("copyright"))

openLinkWithUri ()

openLinkWithUri () 에는 String 또는 Matcher 유형일 수있는 하나의 인수가 있습니다 . 그것은이다 단순히 짧은 받는 컷 오픈 링크의 * 방법.

onView(withId(R.id.text_view)).perform(openLinkWithUri("http://www.google.com/"))

pressImeActionButton ()

pressImeActionButton () 에는 인수가 없으며 android : imeOptions 구성에 설정된 작업을 실행하는보기 작업을 반환 합니다. 예를 들어 android : imeOptions가 actionNext 와 같으면 커서가 화면에서 가능한 다음 EditText 보기 로 이동합니다 .

onView(withId(R.id.text_view)).perform(pressImeActionButton())

scrollTo ()

scrollTo () 에는 인수가 없으며 화면에서 일치하는 scrollView를 스크롤하는 뷰 액션을 반환합니다.

onView(withId(R.id.scrollView)).perform(scrollTo())

아래로 쓸어 내려라()

swipeDown () 에는 인수가 없으며 화면에서 아래로 스 와이프 작업을 실행하는보기 작업을 반환합니다.

onView(withId(R.id.root)).perform(swipeDown())

swipeUp ()

swipeUp () 에는 인수가 없으며 화면에서 위로 스 와이프 작업을 실행하는보기 작업을 반환합니다.

onView(withId(R.id.root)).perform(swipeUp())

swipeRight ()

swipeRight () 에는 인수가 없으며 화면에서 오른쪽으로 스 와이프 작업을 실행하는보기 작업을 반환합니다.

onView(withId(R.id.root)).perform(swipeRight())

왼쪽으로 밀으시오()

swipeLeft () 에는 인수가 없으며 화면에서 왼쪽으로 스 와이프 작업을 실행하는보기 작업을 반환합니다.

onView(withId(R.id.root)).perform(swipeLeft())