Raj*_*ran 6 automation android gridview android-espresso
我将 Espresso 用于一些自动化测试用例。场景是:
我有一个包含两个片段的活动,比如 FrgA 和 FrgB。
FrgA 由一个包含一些项目的列表组成,用户点击它们时会将用户带到 FrgB。
显示 FrgB 后,我会检查 FrgB 上是否存在 gridview。我为此使用的代码是:
@Test
public void testProductsDisplayed(){
onData(anything()).atPosition(1).perform(click());
onView(withId(R.id.gridview)).check(matches(isDisplayed()));
}
Run Code Online (Sandbox Code Playgroud)
我一直面临的问题是,来自 FrgA 的列表项被成功点击,它还会将我带到具有 GridView 的 FrgB。但是我的测试不会继续到测试用例的第 2 行,而是卡在第一行(click())。一段时间后它会超时。奇怪的是,如果我删除 gridview 并放置一些 TextView 并搜索它的存在,则测试通过而没有任何错误。
我唯一能想到的是在 FrgB 中加载 gridview 内容时的一些时间问题。FrgB的代码如下:
public class FrgB extends BaseFragment implements OnItemClickListener {
private View mView;
private List<Product> mProducts;
private ImagesAdapter mAdapter;
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
}
@Override
public void onActivityCreated(Bundle savedInstanceState) {
super.onActivityCreated(savedInstanceState);
Log.d("Kart", "In onActivityCreated");
GridView gvProducts = findTypedViewById(mView, R.id.gvProducts);
mAdapter = new ImagesAdapter(getActivity(), R.layout.image_grid_item, new ArrayList<Product>());
if(getArguments() != null && getArguments().containsKey(Constants.CATEGORY_ID)){
String catId = getArguments().getString(Constants.CATEGORY_ID);
Log.d("Kart", "In onActivityCreated - activity is: "+getActivity());
if(getActivity() == null){
Log.e("Kart", "Activity does not exist");
}else{
mProducts = ((ScrLanding)getActivity()).getProductsForCategory(catId);
mAdapter.addAll(mProducts);
}
gvProducts.setAdapter(mAdapter);
gvProducts.setOnItemClickListener(this);
} else{
returnToLastScreen();
}
}
/**
* Method to remove current fragment from fragment manager
*/
private void returnToLastScreen() {
UiHelper.showToast(getString(R.string.msg_no_products), Toast.LENGTH_SHORT);
removeFragment(this);
}
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container,
Bundle savedInstanceState) {
super.onCreateView(inflater, container, savedInstanceState);
mView = inflater.inflate(R.layout.frg_product_listing, container, false);
return mView;
}
@Override
public void onItemClick(AdapterView<?> parent, View view, int position,
long id) {
switch (parent.getId()) {
case R.id.gvProducts:
FrgProductDetails fragment = new FrgProductDetails();
Bundle bundle = new Bundle();
bundle.putSerializable(Constants.PRODUCT_INFO, mProducts.get(position));
((ScrLanding)getActivity()).setSelectedProductBitmap(mAdapter.getThumbsMap().get(position));
fragment.setArguments(bundle);
addFragment(fragment, R.id.fragment_container);
break;
default:
break;
}
}
Run Code Online (Sandbox Code Playgroud)
}
我哪里错了?
小智 4
我在使用 ListView 时遇到了同样的问题。
有趣的是,我注意到如果我手动尝试滚动屏幕,测试将会继续。添加这一行解决了问题并恢复了测试。
onView(withId(R.id.myListView)).perform(swipeUp());
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
2227 次 |
| 最近记录: |