我遇到SQLDatabase测试问题。
这里是我的代码的一些部分,我跳过代码的不重要部分,如TetsObject声明(包含2个字段:String id和String Title)以及数据库表及其字段的定义。
的build.gradle:
android {
...
testOptions { unitTests.returnDefaultValues = true }
}
dependencies { testCompile 'junit:junit:4.12' }
DatabaseHelper:
public class DatabaseHelper extends SQLiteOpenHelper {
private static final int DATABASE_VERSION = 1;
private static final String DATABASE_NAME = "database.db";
private static final String TABLE_TABLE_CREATE = "...";
public DatabaseHelper(Context context) {
super(context, DATABASE_NAME, null, DATABASE_VERSION);
}
@Override
public void onCreate(SQLiteDatabase db) {
db.execSQL(TABLE_TABLE_CREATE);
}
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) { ... } }
TableOperations:
public class TableOperations {
private SQLiteDatabase mDatabase;
public TableOperations(SQLiteDatabase database) {
mDatabase = database;
}
public List<TestObject> getEnteries() { ... }
public TestObject getEntery(String id) { ... }
public void addEntery(TestObject object) { ... }
public void updateEntery(String id, TestObject object) { ... } }
测试:
public class ExampleUnitTest extends AndroidTestCase {
private SQLiteOpenHelper mDatabaseHelper;
@Override
protected void setUp() throws Exception {
super.setUp();
Context context =new RenamingDelegatingContext(getContext(), "test_");
mDatabaseHelper = new DatabaseHelper(context);
}
@Override
protected void tearDown() throws Exception {
super.tearDown();
mDatabaseHelper.close();
}
@Test
public void testDatabaseNotNull() throws Exception {
assertNotNull("Database is null", mDatabaseHelper.getWritableDatabase());
}
@Test
public void testDatabaseReading() throws Exception{
// insert some data to database
TableOperations operations = new TableOperations(mDatabaseHelper.getWritableDatabase());
// assertEquals test database reading here
} }
我想测试数据库操作但不能,因为第一次测试总是失败,mDatabase总是为空。
答案 0 :(得分:0)
我找到了这个问题的原因。
我试图从'test'文件夹运行这个测试,但是他们需要一个Context for a work,所以他们必须位于'androidTest'文件夹中。
PS:对于简单的测试用例,可以通过RoboGuice或类似的库在