>我创建了一个Android应用程序,该应用程序具有登录编辑文本和密码编辑文本,条件是如果登录编辑文本和密码编辑文本中的两个内容都匹配,则其为真,否则为假。如何使用浓缩咖啡单元测试进行测试
我使用了下面的代码.
@Test
public void validLogin() {
onView(withId(R.id.edtUserId))
.perform(typeText(mStringToBetyped), closeSoftKeyboard());
onView(withId(R.id.edtPass))
.perform(typeText(mValidPass), closeSoftKeyboard());
onView(withId(R.id.loginBtn)).perform(click());
// onView(allOf(withId(R.id.edtUserId))).check(matches(withText(String.valueOf(allOf(withId(R.id.edtPass))))));
onView(withId(R.id.edtUserId)).check(matches(isEditTextValueEqualTo(R.id.edtPass, mStringToBetyped)));
/* onView(allOf(withId(R.id.edtUserId)))
.check(matches(withText(String.valueOf(withId(R.id.edtPass)))));*/
try {
Thread.sleep(10000);
} catch (InterruptedException e) {
e.printStackTrace();
}
}
Matcher<View> isEditTextValueEqualTo(final int viewId, final String content) {
return new TypeSafeMatcher<View>() {
@Override
public void describeTo(Description description) {
description.appendText("Match Edit Text Value with View ID Value : : " + content);
}
@Override
public boolean matchesSafely(View view) {
if (view != null) {
String editTextValue = ((EditText) view.findViewById(viewId)).getText().toString();
if (editTextValue.equalsIgnoreCase(content)) {
return true;
}
}
return false;
}
};
}
但它给了我匹配器的错误,如下所示
java.lang.NullPointerException: Attempt to invoke virtual method 'android.text.Editable android.widget.EditText.getText()' on a null object reference
at com.test.espressodemo.MainActivityTest$1.matchesSafely(MainActivityTest.java:90)
at com.test.espressodemo.MainActivityTest$1.matchesSafely(MainActivityTest.java:80)
at org.hamcrest.TypeSafeMatcher.matches(TypeSafeMatcher.java:65)
at android.support.test.espresso.matcher.ViewMatchers.assertThat(ViewMatchers.java:526)
at android.support.test.espresso.assertion.ViewAssertions$MatchesViewAssertion.check(ViewAssertions.java:103)
at android.support.test.espresso.ViewInteraction$SingleExecutionViewAssertion.check(ViewInteraction.java:415)
at android.support.test.espresso.ViewInteraction$2.call(ViewInteraction.java:279)
at android.support.test.espresso.ViewInteraction$2.call(ViewInteraction.java:265)
at java.util.concurrent.FutureTask.run(FutureTask.java:237)
at android.os.Handler.handleCallback(Handler.java:751)
at android.os.Handler.dispatchMessage(Handler.java:95)
at android.os.Looper.loop(Looper.java:154)
at android.app.ActivityThread.main(ActivityThread.java:6119)
at java.lang.reflect.Method.invoke(Native Method)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:886)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:776)
下面是不使用自定义匹配器的解决方案:
onView(withId(R.id.parentViewId)).check(matches(allOf(
hasDescendant(allOf(withId(R.id.edtUserId), withText(mStringToBetyped))),
hasDescendant(allOf(withId(R.id.edtPass), withText(mStringToBetyped)))
)));
但是,由于您只是在 2 个视图中比较文本,因此您可以像 Bach Vu 提到的那样使用 Assert 类:
Assert.equals(edittext1.getText().toString(), edittext2.getText().toString())
isEditTextValueEqualTo
内部的view
实际上是R.id.edtUserId
的,所以view.findViewById(R.id.edtPass)
会返回 null。那里尝试更改为此
onView(withId(R.id.your_parent_view_that_has_edtPass)).check(matches(isEditTextValueEqualTo(R.id.edtPass, mStringToBetyped)));
如果你真的想使用自定义Matcher
,那么这个怎么样
Matcher<View> isEditTextValueEqualTo(final int viewId1, final int viewId2, final String content) {
return new TypeSafeMatcher<View>() {
@Override
public void describeTo(Description description) {
description.appendText("Match Edit Text Value with View ID Value : : " + content);
}
@Override
public boolean matchesSafely(View view) {
if (view != null) {
String editTextValue1 = ((EditText) view.findViewById(viewId1)).getText().toString();
String editTextValue2 = ((EditText) view.findViewById(viewId2)).getText().toString();
if (editTextValue1.equalsIgnoreCase(editTextValue2)) {
return true;
}
}
return false;
}
};
}
在您的测试中:
onView(withId(R.id.your_parent_view_that_has_edtPass)).check(matches(isEditTextValueEqualTo(R.id.edtPass, R.id.edtUserId)));