最新的SQLite版本错误

时间:2012-08-19 22:03:51

标签: c# visual-studio sqlite nhibernate

刚刚通过Nuget将我的SQLite dll更新为v1.0.81.0,我收到的错误如下所示。首次成功执行一次或多次(不确定)后会发生这种情况。环境是x64计算机上的vs2010,但其构建设置为x86。

我使用SQLite对我的NHibernate映射进行单元测试。在过去经常发现SQLite有点“胡思乱想”,我不愿意弄乱工作单元测试夹具(见下文)

任何人都知道这里出了什么问题?

干杯,
Berryl

错误消息

Unable to copy file "...\x86\SQLite.Interop.dll" to "bin\Debug\x86\SQLite.Interop.dll". The process cannot access the file 'bin\Debug\x86\SQLite.Interop.dll' because it is being used by another process. Parties.Data.Impl.NHib.Tests

单元测试夹具(足以显示文件访问权限)

public abstract class SQLiteTestFixture
{

    protected override void BeforeAllTests()
    {
        _configureDbFile();
        base.BeforeAllTests();
    }

    protected override void AfterAllTests()
    {
        base.AfterAllTests();

        _deleteAllDbFiles();
    }

    #region Db File Maintenance

    /// <summary>
    /// Using a file is likely slower than just memory but not noticeably so far,
    /// AND seems to be a bit more stable
    /// </summary>
    private const string DB_FILE_SUFFIX = ".Test.db";

    /// <summary>
    /// Just make some random file name with a known suffix, so we can clean up when done.
    /// </summary>
    private void _configureDbFile()
    {
        _dbFile = Path.GetFullPath(Guid.NewGuid().ToString("N") + DB_FILE_SUFFIX);

        // highly unlikely but just in case the same file is already out there
        _deleteDbFile();
    }

    private void _deleteDbFile()
    {
        if (File.Exists(_dbFile)) File.Delete(_dbFile);
    }

    private static void _deleteAllDbFiles()
    {
        var files = Directory.GetFiles(Directory.GetCurrentDirectory(), "*" + DB_FILE_SUFFIX);
        foreach (var file in files)
        {
            File.Delete(file);
        }
    }

    private string _dbFile;

    #endregion

}

}

3 个答案:

答案 0 :(得分:2)

我在使用VS2010和TestDriven.Net的SQLite 1.0.88.0时遇到了这个问题。我尝试了几个问题的答案,但唯一对我有用的是:

  1. 工具 - &gt;选项 - &gt; TestDriven.Net - &gt;将军
  2. 运行测试下,取消选中“在测试运行之间缓存测试过程”
  3. 重新启动Visual Studio
  4. 您现在应该能够运行测试,调试测试,重建等,而无需重新启动进程或Visual Studio。

答案 1 :(得分:1)

KB文章描述了一个可能的原因

以下大部分内容暂时解决了问题

答案 2 :(得分:0)

将SQLite dll“复制到输出目录”更改为“如果更新则复制”。 (您可能需要在更改属性后重新启动VS)