Fra*_*ank 7 android mockito roboguice robolectric
在过去的几天里,我开始玩roboguice,robolectric和mockito.我有一个小型的Android应用程序,其中包含一个包含AutoCompleteTextView的登录屏幕,可以更快地输入用户名.AutoCompleteTextView的用户名存储在sqlite数据库中.
public class MainActivity extends RoboActivity implements View.OnClickListener {
@InjectView(R.id.startScreen_Login_Button) private Button loginButton;
@InjectView(R.id.startScreen_Cancel_Button) private Button cancelButton;
@InjectView(R.id.startScreen_forgotPwd_TextView) private TextView forgotPWTextView;
@InjectView(R.id.startScreen_Username_AutoCompleteTextView) private AutoCompleteTextView loginUsernameAutoCompleteTextView;
@InjectView(R.id.startScreen_Password_EditText) private EditText loginPasswordEditText;
@Inject private SharedPreferences sharedPreferences;
@Inject SQLiteDBAdapter dbAdapter;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
loginButton.setOnClickListener(this);
cancelButton.setOnClickListener(this);
forgotPWTextView.setOnClickListener(this);
// Creating List for startScreen_Username_AutoCompleteTextView
List<User> userList = dbAdapter.getUserList();
ListIterator<User> it = userList.listIterator();
List<String> userStringList = new ArrayList<String>();
User user;
while (it.hasNext()) {
user = it.next();
userStringList.add(user.getName());
}
loginUsernameAutoCompleteTextView.setAdapter(new ArrayAdapter<String>(this, R.layout.select_page_row, userStringList));
}
...
}
Run Code Online (Sandbox Code Playgroud)
我想使用robolectric测试MainActivity,试图用mockito模拟数据库.这是我的测试类:
@RunWith(CustomRobolectricTestRunner.class)
public class MainActivityTest {
@Mock
SQLiteDBAdapter dbAdapter;
@Before
public void setUp() throws Exception {
MockitoAnnotations.initMocks(this);
}
@Test
public void shouldHaveApplicationName() throws Exception {
String appName = new MainActivity().getResources().getString(R.string.app_name);
assertThat(appName, equalTo("OperationReport"));
}
@Test
public void testButtonsVisible()
{
MainActivity mainActivity = new MainActivity();
mainActivity.onCreate(null);
}
}
Run Code Online (Sandbox Code Playgroud)
调用mainActivity.onCreate(null); 正在启动错误级联,结束于行Cursor cursor = db.rawQuery(SQL_QUERY,null); 我的SQLiteDBAdapter中的getUserList方法:
public List<User> getUserList() {
SQLiteDatabase db = getReadableDatabase();
List<User> userList = new ArrayList<User>();
String SQL_QUERY = "SELECT * FROM User;";
Cursor cursor = db.rawQuery(SQL_QUERY, null);
cursor.moveToFirst();
while (!cursor.isAfterLast()) {
User user = new User();
user.setUserUUID(cursor.getString(0));
user.setName(cursor.getString(1));
user.setPassword(cursor.getString(2));
user.setDateOfBirth(cursor.getString(3));
user.setStaffNumber(cursor.getString(4));
user.setActive(cursor.getInt(5));
user.setUserClass(cursor.getInt(6));
userList.add(user);
cursor.moveToNext();
}
cursor.close();
db.close();
return userList;
}
Run Code Online (Sandbox Code Playgroud)
我读过,Mock返回void-methods的空存根,并在任何其他方法上返回null.当我在模拟SQLiteDBAdapter类时,我期望在我的模拟SQLiteDBAdapter上调用getUserList返回null.我不太清楚他为什么要访问原始方法.我猜它仍然使用原始的SQLiteDBAdapter而不是Mock.我该怎么做才能解决这个问题,它是如何工作的?我没有想法,所以任何帮助都表示赞赏.
模拟数据库来测试 DAO 对我来说根本没有意义。你在测试什么?数据库。为什么要消除它?
一旦您通过了所有 DAO 测试,并且是时候测试使用数据库来完成工作单元的服务了,那么模拟数据库就有意义了。您已经测试了 DAO 和数据库,并且您的服务单元测试不必是集成测试。在这种情况下,无论如何都要嘲笑。
我不太了解你在嘲笑什么,但当我嘲笑它时,它是针对我制作的界面的。该模拟为我的客户端/测试正在使用的接口类型引用提供了一个替代实现。
如果您尝试模拟一个具体的类,我建议将该适配器包装在基于接口的实现中。这将是一个更好的抽象,并且您将可以更轻松地模拟您的界面。
| 归档时间: |
|
| 查看次数: |
3961 次 |
| 最近记录: |