Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 

단위 테스트 - Could not load file or assembly 'Microsoft.VisualStudio.QualityTools.VideoRecorderEngine' or one of its dependencies.

이상하군요. 특정 PC에서만 단위 테스트를 "디버그"로 실행하면 다음과 같은 오류가 발생합니다.

HResult=0x80131018
Message=Could not load file or assembly 'Microsoft.VisualStudio.QualityTools.VideoRecorderEngine' or one of its dependencies. The module was expected to contain an assembly manifest.
Source=mscorlib
StackTrace:
at System.Reflection.RuntimeAssembly._nLoad(AssemblyName fileName, String codeBase, Evidence assemblySecurity, RuntimeAssembly locationHint, StackCrawlMark& stackMark, IntPtr pPrivHostBinder, Boolean throwOnFileNotFound, Boolean forIntrospection, Boolean suppressSecurityChecks)
at System.Reflection.RuntimeAssembly.InternalLoadAssemblyName(AssemblyName assemblyRef, Evidence assemblySecurity, RuntimeAssembly reqAssembly, StackCrawlMark& stackMark, IntPtr pPrivHostBinder, Boolean throwOnFileNotFound, Boolean forIntrospection, Boolean suppressSecurityChecks) in f:\dd\ndp\clr\src\BCL\system\reflection\assembly.cs:line 1828

System.BadImageFormatException: 'Could not load file or assembly 'Microsoft.VisualStudio.QualityTools.VideoRecorderEngine' or one of its dependencies. The module was expected to contain an assembly manifest.'

재미있는 것은 실제로 "Microsoft.VisualStudio.QualityTools.VideoRecorderEngine.dll"은 다음의 경로에 존재하는데,

C:\Program Files (x86)\Microsoft Visual Studio\2017\Enterprise\Common7\IDE\Extensions\TestPlatform\Extensions
C:\Program Files (x86)\Microsoft Visual Studio\2017\Enterprise\Common7\IDE\Extensions\TestPlatform\Extensions\V1
C:\Program Files (x86)\Microsoft Visual Studio\2017\Enterprise\Common7\IDE\PrivateAssemblies\DataCollectors

.NET Reflector로 검사해 보면 오류 메시지에서 의미하는 데로 "assembly manifest"가 없는 그냥 Native DLL입니다. 테스트는 x86으로 하든 x64로 하든 System.BadImageFormatException 예외가 발생하는데 왜 그 컴퓨터에서만 발생하는지에 대해서는 원인을 모르겠습니다. ^^; "Output" 윈도우의 출력 내용을 보면 다음의 DLL 로드 후 곧바로 발생합니다.

'testhost.exe' (CLR v4.0.30319: testhost.exe): Loaded 'C:\PROGRAM FILES (X86)\MICROSOFT VISUAL STUDIO\2017\ENTERPRISE\COMMON7\IDE\EXTENSIONS\TESTPLATFORM\Extensions\Microsoft.TestPlatform.TestHostRuntimeProvider.dll'. Cannot find or open the PDB file.

테스트 삼아 "C:\Program Files (x86)\Microsoft Visual Studio\2017\Enterprise\Common7\IDE\Extensions\TestPlatform\Extensions" 폴더에 있는 "Microsoft.VisualStudio.QualityTools.VideoRecorderEngine.dll" 파일의 이름을 바꾸면 System.BadImageFormatException 예외 대신 그 위치에서 System.IO.FileNotFoundException와 System.ArgumentException 예외가 발생합니다. 그러다 다음의 DLL 로드 이후에,

'testhost.exe' (CLR v4.0.30319: testhost.exe): Loaded 'C:\PROGRAM FILES (X86)\MICROSOFT VISUAL STUDIO\2017\ENTERPRISE\COMMON7\IDE\EXTENSIONS\TESTPLATFORM\Extensions\Microsoft.VisualStudio.UwpTestHostRuntimeProvider.dll'. Cannot find or open the PDB file.

다시 System.BadImageFormatException 예외가 이번에는 VSTestVideoRecorder.exe에 대해 발생합니다.

System.BadImageFormatException
  HResult=0x8007000B
  Message=Could not load file or assembly 'VSTestVideoRecorder' or one of its dependencies. An attempt was made to load a program with an incorrect format.
  Source=mscorlib
  StackTrace:
   at System.Reflection.RuntimeAssembly._nLoad(AssemblyName fileName, String codeBase, Evidence assemblySecurity, RuntimeAssembly locationHint, StackCrawlMark& stackMark, IntPtr pPrivHostBinder, Boolean throwOnFileNotFound, Boolean forIntrospection, Boolean suppressSecurityChecks)
   at System.Reflection.RuntimeAssembly.InternalLoadAssemblyName(AssemblyName assemblyRef, Evidence assemblySecurity, RuntimeAssembly reqAssembly, StackCrawlMark& stackMark, IntPtr pPrivHostBinder, Boolean throwOnFileNotFound, Boolean forIntrospection, Boolean suppressSecurityChecks) in f:\dd\ndp\clr\src\BCL\system\reflection\assembly.cs:line 1828

역시 이번에도 "C:\Program Files (x86)\Microsoft Visual Studio\2017\Enterprise\Common7\IDE\Extensions\TestPlatform\Extensions" 폴더의 VSTestVideoRecorder.exe 파일명의 이름을 바꾸면 System.BadImageFormatException 예외 대신 System.IO.FileNotFoundException 예외로 바뀝니다.




저도 왜 저 오류가 발생하는지는 잘 모르겠습니다. 다른 PC에서 하면 관련 예외가 없는 걸로 봐서 뭔가 전역 설정이 있는 것 같은데 딱히 ^^; 찾을 수가 없습니다. 다행인 점은, 해당 예외들이 "first-chance exception"일 뿐 디버그 테스트에 직접적인 영향은 없다는 것입니다. 따라서 이를 해결하기 위해서는 2가지 방법 중 하나를 선택해야 합니다.

즉, "Ctrl + Alt + E"키를 눌러 나오는 "Exception Settings"에서 다음과 같은 예외를 해제하든지,

System.BadImageFormatException
System.ArgumentException

아니면 "Microsoft.VisualStudio.QualityTools.VideoRecorderEngine.dll", "VSTestVideoRecorder.exe" 파일명을 바꾸고 다음과 같이 예외를 해제하든지 택해야 합니다.

System.IO.FileNotFoundException
System.ArgumentException

참고로, 차후에는 아마 해결될 것입니다.

BadImageFormatException - Microst.VisualStudio.QualityTools.VideoRecorderEngine
; https://developercommunity.visualstudio.com/t/BadImageFormatException---MicrostVisual/168116




[이 글에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]







[최초 등록일: ]
[최종 수정일: 7/24/2022]

Creative Commons License
이 저작물은 크리에이티브 커먼즈 코리아 저작자표시-비영리-변경금지 2.0 대한민국 라이센스에 따라 이용하실 수 있습니다.
by SeongTae Jeong, mailto:techsharer at outlook.com

비밀번호

댓글 작성자
 



2018-03-06 04시55분
15.6.0부터 해결되었습니다.
정성태

... 121  122  123  124  125  126  127  128  [129]  130  131  132  133  134  135  ...
NoWriterDateCnt.TitleFile(s)
1865정성태2/20/201521124.NET Framework: 499. 특정 닷넷 프레임워크 버전 이후부터 제공되는 타입을 사용해야 한다면?
1864정성태2/18/201526082.NET Framework: 498. C#으로 간단하게 만들어 본 ASCII Art 프로그램 [2]파일 다운로드1
1862정성태2/18/201530135.NET Framework: 497. .NET Garbage Collection에 대한 정리 [6]
1861정성태2/18/201525301.NET Framework: 496. 마우스 커서가 놓인 지점의 문자열 얻는 방법 [1]파일 다운로드1
1860정성태2/18/201525249.NET Framework: 495. CorElementType의 요소 값 설명파일 다운로드1
1859정성태2/17/201525711Windows: 106. 컴퓨터를 재부팅하면 절전(Power Saver) 전원 모드로 돌아가는 경우
1858정성태2/16/201535600Windows: 105. 자동으로 로그아웃/잠김 화면 상태로 전환된다면? [2]
1857정성태2/16/201523711.NET Framework: 494. 값(struct) 형식의 제네릭(Generic) 타입이 박싱되는 경우의 메타데이터 토큰 값파일 다운로드1
1856정성태2/15/201522527.NET Framework: 493. TypeRef 메타테이블에 등록되는 타입의 조건파일 다운로드1
1855정성태2/10/201521966개발 환경 구성: 256. WebDAV Redirector - Sysinternals 폴더 연결 시 "The network path was not found" 오류 해결 방법
1854정성태2/10/201522868Windows: 104. 폴더는 삭제할 수 없지만, 그 하위 폴더/파일은 생성/삭제/변경하는 보안 설정
1853정성태2/6/201553382웹: 29. 여신금융협회 웹 사이트의 "Netscape 6.0은 지원하지 않습니다." 오류 메시지 [5]
1852정성태2/5/201523884.NET Framework: 492. .NET CLR Memory 성능 카운터의 의미파일 다운로드1
1851정성태2/5/201524594VC++: 88. 하룻밤의 꿈 - 인텔 하스웰의 TSX Instruction 지원 [2]
1850정성태2/4/201545487Windows: 103. 작업 관리자에서의 "Commit size"가 가리키는 메모리의 의미 [4]
1849정성태2/4/201525045기타: 51. DropBox의 CPU 100% 현상 [1]파일 다운로드1
1848정성태2/4/201520668.NET Framework: 491. 닷넷 Generic 타입의 메타 데이터 토큰 값 알아내는 방법 [2]
1847정성태2/3/201524003기타: 50. C# - 윈도우에서 dropbox 동기화 폴더 경로 및 종료하는 방법
1846정성태2/2/201533185Windows: 102. 제어판의 프로그램 추가/삭제 항목을 수동으로 실행하고 싶다면? [1]
1845정성태1/26/201534302Windows: 101. 제어판의 "Windows 자격 증명 관리(Manage your credentials)"를 금지시키는 방법
1844정성태1/26/201531912오류 유형: 269. USB 메모리의 용량이 비정상적으로 보여진다면? [7]
1843정성태1/24/201523071VC++: 87. 무시할 수 없는 Visual C++ 런타임 함수 성능
1842정성태1/23/201546120개발 환경 구성: 255. 노트북 키보드에 없는 BREAK 키를 다른 키로 대체하는 방법
1841정성태1/21/201520526오류 유형: 268. Win32 핸들 관련 CLR4 보안 오류 사례
1840정성태1/8/201528897오류 유형: 267. Visual Studio - CodeLens 사용 시 CPU 100% 현상
1839정성태1/5/201521536디버깅 기술: 69. windbg 분석 사례 - cpu 100% 현상 (2)
... 121  122  123  124  125  126  127  128  [129]  130  131  132  133  134  135  ...