You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
64 lines
2.5 KiB
64 lines
2.5 KiB
6 years ago
|
package com.keylesspalace.tusky
|
||
|
|
||
|
import androidx.room.testing.MigrationTestHelper
|
||
|
import androidx.sqlite.db.framework.FrameworkSQLiteOpenHelperFactory
|
||
|
import androidx.test.ext.junit.runners.AndroidJUnit4
|
||
|
import androidx.test.platform.app.InstrumentationRegistry
|
||
|
import com.keylesspalace.tusky.db.AppDatabase
|
||
|
import org.junit.Assert.assertEquals
|
||
|
import org.junit.Rule
|
||
|
import org.junit.Test
|
||
|
import org.junit.runner.RunWith
|
||
|
|
||
|
const val TEST_DB = "mirgation_test"
|
||
|
|
||
|
@RunWith(AndroidJUnit4::class)
|
||
|
class MigrationsTest {
|
||
|
|
||
|
@JvmField
|
||
|
@Rule
|
||
|
var helper: MigrationTestHelper = MigrationTestHelper(
|
||
|
InstrumentationRegistry.getInstrumentation(),
|
||
|
AppDatabase::class.java.canonicalName,
|
||
|
FrameworkSQLiteOpenHelperFactory()
|
||
|
)
|
||
|
|
||
|
@Test
|
||
|
fun migrateTo11() {
|
||
|
val db = helper.createDatabase(TEST_DB, 10)
|
||
|
|
||
|
val id = 1
|
||
|
val domain = "domain.site"
|
||
|
val token = "token"
|
||
|
val active = true
|
||
|
val accountId = "accountId"
|
||
|
val username = "username"
|
||
|
val values = arrayOf(id, domain, token, active, accountId, username, "Display Name",
|
||
|
"https://picture.url", true, true, true, true, true, true, true,
|
||
|
true, "1000", "[]", "[{\"shortcode\": \"emoji\", \"url\": \"yes\"}]", 0, false,
|
||
|
false, true)
|
||
|
|
||
|
db.execSQL("INSERT OR REPLACE INTO `AccountEntity`(`id`,`domain`,`accessToken`,`isActive`," +
|
||
|
"`accountId`,`username`,`displayName`,`profilePictureUrl`,`notificationsEnabled`," +
|
||
|
"`notificationsMentioned`,`notificationsFollowed`,`notificationsReblogged`," +
|
||
|
"`notificationsFavorited`,`notificationSound`,`notificationVibration`," +
|
||
|
"`notificationLight`,`lastNotificationId`,`activeNotifications`,`emojis`," +
|
||
|
"`defaultPostPrivacy`,`defaultMediaSensitivity`,`alwaysShowSensitiveMedia`," +
|
||
|
"`mediaPreviewEnabled`) " +
|
||
|
"VALUES (nullif(?, 0),?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?)",
|
||
|
values)
|
||
|
|
||
|
db.close()
|
||
|
|
||
|
val newDb = helper.runMigrationsAndValidate(TEST_DB, 11, true, AppDatabase.MIGRATION_10_11)
|
||
|
|
||
|
val cursor = newDb.query("SELECT * FROM AccountEntity")
|
||
|
cursor.moveToFirst()
|
||
|
assertEquals(id, cursor.getInt(0))
|
||
|
assertEquals(domain, cursor.getString(1))
|
||
|
assertEquals(token, cursor.getString(2))
|
||
|
assertEquals(active, cursor.getInt(3) != 0)
|
||
|
assertEquals(accountId, cursor.getString(4))
|
||
|
assertEquals(username, cursor.getString(5))
|
||
|
}
|
||
|
}
|