是否可以使用SQLite.Net-PCL创建内存数据库?

时间:2016-05-24 08:54:37

标签: c# sqlite unit-testing mvvmcross sqlite-net

目前我正在使用SQLite.Net-PCL 3.1.1开发Xamarin MvvmCross应用程序的单元测试。单元测试项目是一个普通的.NET项目。

所以现在我在嘲笑MvxSqliteConnectionFactoryBase

public class MockMvxSqliteConnectionFactoryBase :  MvxSqliteConnectionFactoryBase
{
    #region implemented abstract members of MvxSqliteConnectionFactoryBase

    public override string GetPlattformDatabasePath(string databaseName)
    {
        return "Data Source=:memory:";
    }

    public override ISQLitePlatform GetCurrentPlatform()
    {
        return new SQLite.Net.Platform.Generic.SQLitePlatformGeneric(); 
    }
    public override ISQLitePlatform GetCurrentPlatform(string key)
    {
        return new  SQLite.Net.Platform.Generic.SQLitePlatformGeneric();
    }

    #endregion
}

但是数据库不是在内存中创建的,而是在项目的bin文件夹中创建的。

我尝试像example这样初始化SQLiteConnection,但是没有一个构造函数只接受一个字符串。

1 个答案:

答案 0 :(得分:2)

遵循@CL的提示。给了我改变方法GetPlattformDatabasePath:

public override string GetPlattformDatabasePath(string databaseName)
    {
        return ":memory:";
    }

现在我没有在bin文件夹中看到要创建的内容,并且在每次单元测试运行后都不需要删除数据,因此数据库必须在内存中。