2013-08-23 72 views
5

いくつかのSQLコマンドをOracleデータベースに直接実行する単体テストを実行しようとしています。ユニットテストが開始され、次の例外:
System.IO.FileNotFoundException:ファイルまたはアセンブリをロードできませんでした「Oracle.DataAccess、バージョン= 4.112.3.0、文化=中立、なPublicKeyTokenSystem.IO.FileNotFoundException:単体テスト実行時にファイルまたはアセンブリのOracle.DataAccessなどをロードできませんでした

Testmethod1が例外をスローしました= 89b483f429c47342 'またはその依存関係の1つ。システムは、指定されたファイルを見つけることができません。

プロジェクト参照(NuGet経由で追加)にOracle.DataAccessがあり、Oracle Data Providerがインストールされています。

このマシンで問題なく動作するOracle.DataAccessを使用している他のプロジェクトがあります。 Microsoft.Net単体テストフレームワーク(MSTest)だけがアセンブリを読み込めないようです。

これは核融合ログビューアから取られたログです:

*** 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\

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

その他の注意事項:

  • 私がインストールされているOracleのデータプロバイダは、64ビットバージョンです。
  • 参照がすでにCopy Local=True
+1

フュージョンロギングを有効にして、欠落しているファイルを特定するのに役立つかどうかを確認します。http://www.hanselman.com/blog/CommentView.aspx?guid=3654c8f3-c5c3-4dee-a01f-c9a8da3ef2fa –

+0

Didn 'それについて知っている。ありがとう。私はちょうど質問にそれを追加しました – mmutilva

+0

あなたのテストは32ビットプロセスとして実行していますか? –

答えて

5

は、問題を発見しました。

を選択しているにもかかわらず、テストを32ビットモードに実行させるための.testsettingsファイルがありました。

私がX86を選択すると、実行時に適切なBadImageFormatExceptionが得られます。一方、アーキテクチャが.testsettingsファイルで強制されると、私はFileNotFoundExceptionとなります。これはやや誤解を招きます。

関連する問題