SQLiteDatabse unitTest

时间:2016-05-28 19:30:57

标签: android sqlite testing junit4

我遇到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总是为空。

1 个答案:

答案 0 :(得分:0)

我找到了这个问题的原因。 我试图从'test'文件夹运行这个测试,但是他们需要一个Context for a work,所以他们必须位于'androidTest'文件夹中。 PS:对于简单的测试用例,可以通过RoboGuice或类似的库在