All Downloads are FREE. Search and download functionalities are using the official Maven repository.

de.greenrobot.dao.test.DbTest Maven / Gradle / Ivy

/*
 * Copyright (C) 2011-2013 Markus Junginger, greenrobot (http://greenrobot.de)
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *      http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

package de.greenrobot.dao.test;

import android.app.Application;
import android.app.Instrumentation;
import android.database.sqlite.SQLiteDatabase;
import android.test.AndroidTestCase;
import de.greenrobot.dao.DaoLog;
import de.greenrobot.dao.DbUtils;
import de.greenrobot.dao.database.StandardDatabase;
import de.greenrobot.dao.database.Database;

import java.util.Random;

/**
 * Base class for database related testing, which prepares an in-memory or an file-based DB (using the test {@link
 * android.content.Context}). Also, offers some convenience methods to create new {@link Application} objects similar
 * to {@link android.test.ApplicationTestCase}.
 * 

* Unlike ApplicationTestCase, this class should behave more correctly when you call {@link #createApplication(Class)} * during {@link #setUp()}: {@link android.test.ApplicationTestCase#testApplicationTestCaseSetUpProperly()} leaves * Application objects un-terminated. * * @author Markus */ public abstract class DbTest extends AndroidTestCase { public static final String DB_NAME = "greendao-unittest-db.temp"; protected final Random random; protected final boolean inMemory; protected Database db; private Application application; public DbTest() { this(true); } public DbTest(boolean inMemory) { this.inMemory = inMemory; random = new Random(); } @Override protected void setUp() throws Exception { super.setUp(); db = createDatabase(); } /** Returns a prepared application with the onCreate method already called. */ public T createApplication(Class appClass) { assertNull("Application already created", application); T app; try { app = (T) Instrumentation.newApplication(appClass, getContext()); } catch (Exception e) { throw new RuntimeException("Could not create application " + appClass, e); } app.onCreate(); application = app; return app; } /** Terminates a previously created application. Also called by {@link #tearDown()} if needed. */ public void terminateApplication() { assertNotNull("Application not yet created", application); application.onTerminate(); application = null; } /** Gets the previously created application. */ public T getApplication() { assertNotNull("Application not yet created", application); return (T) application; } /** May be overriden by sub classes to set up a different db. */ protected Database createDatabase() { SQLiteDatabase sqLiteDatabase; if (inMemory) { sqLiteDatabase = SQLiteDatabase.create(null); } else { getContext().deleteDatabase(DB_NAME); sqLiteDatabase = getContext().openOrCreateDatabase(DB_NAME, 0, null); } return new StandardDatabase(sqLiteDatabase); } @Override /** Closes the db, and terminates an application, if one was created before. */ protected void tearDown() throws Exception { if (application != null) { terminateApplication(); } db.close(); if (!inMemory) { getContext().deleteDatabase(DB_NAME); } super.tearDown(); } protected void logTableDump(String tablename) { if (db instanceof StandardDatabase) { DbUtils.logTableDump(((StandardDatabase) db).getSQLiteDatabase(), tablename); } else { DaoLog.w("Table dump unsupported for " + db); } } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy