5

いくつかの SQL コマンドを Oracle データベースに対して直接実行する単体テストを実行しようとしていますが、単体テストの開始時に次の例外が発生します。

Testmethod1 が例外をスローしました:
System.IO.FileNotFoundException: ファイルまたはアセンブリ 'Oracle.DataAccess, Version=4.112.3.0, Culture=neutral, PublicKeyToken=89b483f429c47342' またはその依存関係の 1 つを読み込めませんでした。システムは、指定されたファイルを見つけることができません。

私はOracle.DataAccessプロジェクト参照 (NuGet を介して追加) を持っており、Oracle Data Provider をインストールしています。

Oracle.DataAccessこのマシンで問題なく実行される他のプロジェクトもあります。Microsoft.Net Unit Test Framework (MSTest) だけがアセンブリを読み込めないようです。

これは、Fusion Log Viewer から取得したログです。

*** Assembly Binder Log Entry  (23/08/2013 @ 04:50:07 p.m.) ***

The operation failed.
Bind result: hr = 0x80070002. The system cannot find the file specified.

Assembly manager loaded from:  C:\Windows\Microsoft.NET\Framework\v4.0.30319\clr.dll
Running under executable  C:\Program Files (x86)\Microsoft Visual Studio 11.0\Common7\IDE\QTAgent32_40.exe
--- A detailed error log follows. 

=== Pre-bind state information ===
LOG: User = ...
LOG: DisplayName = Oracle.DataAccess, Version=4.112.3.0, Culture=neutral, PublicKeyToken=89b483f429c47342
 (Fully-specified)
LOG: Appbase = file:///...C:/<solution_folder>.../TestResults/.../Out
LOG: Initial PrivatePath = NULL
LOG: Dynamic Base = NULL
LOG: Cache Base = NULL
LOG: AppName = QTAgent32_40.exe
Calling assembly : ...<project_name>..., Version=1.0.0.0, Culture=neutral, PublicKeyToken=null.
===
LOG: This bind starts in default load context.
LOG: Using application configuration file: C:\...<solution_folder>...\TestResults\...\Out\...<project_name>....DLL.config
LOG: Using host configuration file: 
LOG: Using machine configuration file from C:\Windows\Microsoft.NET\Framework\v4.0.30319\config\machine.config.
LOG: Post-policy reference: Oracle.DataAccess, Version=4.112.3.0, Culture=neutral, PublicKeyToken=89b483f429c47342
LOG: GAC Lookup was unsuccessful.
LOG: Attempting download of new URL file:///C:/...<solution_folder>.../TestResults/.../Out/Oracle.DataAccess.DLL.
LOG: Attempting download of new URL file:///C:/...<solution_folder>.../TestResults/.../Out/Oracle.DataAccess/Oracle.DataAccess.DLL.
LOG: Attempting download of new URL file:///C:/...<solution_folder>.../TestResults/.../Out/Oracle.DataAccess.EXE.
LOG: Attempting download of new URL file:///C:/...<solution_folder>.../TestResults/.../Out/Oracle.DataAccess/Oracle.DataAccess.EXE.
LOG: All probing URLs attempted and failed.

アセンブリがGACで見つからなかったと述べていますが、私はそれを見つけました:C:\Windows\Microsoft.NET\assembly\GAC_64\Oracle.DataAccess\v4.0_4.112.3.0__89b483f429c47342\Oracle.DataAccess.dll\

QTAgent32_40.exeまた、Visual Studio menu で選択したにもかかわらず、上記のログが表示されることも注目に値しますTEST -> Test Settings -> Default Processor Architecture -> X64。そうする前に、私はBadImageFormatException代わりに取得していました。

その他の注意事項:

  • インストールした Oracle Data Provider は 64 ビット バージョンです。
  • リファレンスはすでにCopy Local=True
4

1 に答える 1

6

問題が見つかりました。

私が .testsettingsを選択したかどうかに関係なく、テストを 32 ビット モードで強制的に実行する .testsettings ファイルがありましたTEST -> Test Settings -> Default Processor Architecture -> X64

奇妙なことに、X86 を選択すると、実行時に適切な結果が得られBadImageFormatExceptionますが、アーキテクチャが .testsettings ファイルで強制されている場合FileNotFoundExceptionは、少し誤解を招く可能性があります。

于 2013-08-28T16:00:17.200 に答える