使用 Room 持久性库创建数据库时,验证应用数据库和用户数据的稳定性非常重要。本页面讨论如何测试数据库以及执行调试步骤以帮助测试通过。
测试您的数据库
测试数据库有两种方法
- 在 Android 设备上。
- 在您的主机开发机器上(不推荐)。
有关数据库迁移特定测试的信息,请参阅测试迁移。
在 Android 设备上测试
测试数据库实现时推荐的方法是编写在 Android 设备上运行的 JUnit 测试。由于这些测试不需要创建 activity,因此它们的执行速度应比 UI 测试快。
设置测试时,您应该创建一个数据库的内存版本,以使您的测试更具隔离性,如以下示例所示
Kotlin
@RunWith(AndroidJUnit4::class) class SimpleEntityReadWriteTest { private lateinit var userDao: UserDao private lateinit var db: TestDatabase @Before fun createDb() { val context = ApplicationProvider.getApplicationContext<Context>() db = Room.inMemoryDatabaseBuilder( context, TestDatabase::class.java).build() userDao = db.getUserDao() } @After @Throws(IOException::class) fun closeDb() { db.close() } @Test @Throws(Exception::class) fun writeUserAndReadInList() { val user: User = TestUtil.createUser(3).apply { setName("george") } userDao.insert(user) val byName = userDao.findUsersByName("george") assertThat(byName.get(0), equalTo(user)) } }
Java
@RunWith(AndroidJUnit4.class) public class SimpleEntityReadWriteTest { private UserDao userDao; private TestDatabase db; @Before public void createDb() { Context context = ApplicationProvider.getApplicationContext(); db = Room.inMemoryDatabaseBuilder(context, TestDatabase.class).build(); userDao = db.getUserDao(); } @After public void closeDb() throws IOException { db.close(); } @Test public void writeUserAndReadInList() throws Exception { User user = TestUtil.createUser(3); user.setName("george"); userDao.insert(user); List<User> byName = userDao.findUsersByName("george"); assertThat(byName.get(0), equalTo(user)); } }
在您的主机机器上测试
Room 使用 SQLite 支持库,该库提供的接口与 Android 框架类中的接口相匹配。此支持允许您传入支持库的自定义实现来测试您的数据库查询。
测试您的迁移
Room 支持增量式数据库迁移,以便在应用更新更改数据库架构时保留现有应用数据。但是,定义不正确的迁移可能会导致您的应用崩溃。请务必测试您的 Room 数据库迁移。
调试您的数据库
您可以使用多种工具和流程来调试数据库。
使用 Database Inspector
在 Android Studio 4.1 及更高版本中,Database Inspector 允许您在应用运行时检查、查询和修改应用的数据库。Database Inspector 与 Android 捆绑的 SQLite 版本兼容,并包含用于 Room 的特殊功能
- 使用边栏操作可快速从您的 DAO 类运行查询。
- 当您的运行中的应用更改数据时,立即在 Database Inspector 中查看实时更新。
要详细了解 Database Inspector,请参阅使用 Database Inspector 调试您的数据库。
从命令行转储数据
Android SDK 包含一个用于检查应用数据库的 sqlite3
数据库工具。它包含 .dump
等命令用于打印表的内容,以及 .schema
用于打印现有表的 SQL CREATE
语句。
您还可以从命令行执行 SQLite 命令,如下面的代码段所示
adb -s emulator-5554 shell sqlite3 /data/data/your-app-package/databases/rssitems.db
有关详细信息,请参阅 SQLite 网站上提供的 sqlite3
命令行文档。
更多资源
要详细了解如何测试和调试您的 Room 数据库,请参阅以下更多资源
博文
视频
- Database Inspector(Android 11 周系列)