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

Visual Studio 빌드 오류 - result: unexpected exception occured (-1002 - 0xfffffc16)

Fake가 포함된 단위 테스트 프로젝트 빌드 시 다음과 같은 오류가 발생합니다.

1>------ Build started: Project: TestLibUnitTest, Configuration: Debug Any CPU ------
1>Build started 2019-07-08 오전 11:52:39.
1>BuildFakesAssemblies:
1>  Collecting outdated Fakes assemblies
1>  fakes tools timestamp: 2019-03-26 07:31:33Z
1>  reference assembly paths:
...[생략]...
1>  framework assembly path: C:\Program Files (x86)\Microsoft Visual Studio\2019\Enterprise\Common7\IDE\PublicAssemblies
1>  output path: D:\TestPrj\FakesAssemblies
1>  intermediate path: D:\TestPrj\obj\Debug\Fakes
1>  Fakes: 4 (4 .fakes files)
1>   Fakes\TestLib.fakes
1>   Fakes\mscorlib.fakes
1>   Fakes\System.fakes
1>   Fakes\System.Web.fakes
1>  fakes tool: C:\Program Files (x86)\Microsoft Visual Studio\2019\Enterprise\MSBuild\Microsoft\VisualStudio\v16.0\Fakes\fakes.exe
1>  command line arguments:  /Properties:";PlatformTarget=x64" /msbuildpath:"C:\Program Files (x86)\Microsoft Visual Studio\2019\Enterprise\MSBuild\Current\Bin\msbuild.exe"
1>  result: unexpected exception occured (-1002 - 0xfffffc16)
1>  Fakes assemblies:
1>   D:\TestPrj\FakesAssemblies\TestLib.Fakes.dll
1>   D:\TestPrj\FakesAssemblies\TestLib.Fakes.fakesconfig
1>   D:\TestPrj\FakesAssemblies\System.4.0.0.0.Fakes.dll
1>   D:\TestPrj\FakesAssemblies\System.4.0.0.0.Fakes.fakesconfig
1>   D:\TestPrj\FakesAssemblies\System.Web.4.0.0.0.Fakes.dll
1>   D:\TestPrj\FakesAssemblies\System.Web.4.0.0.0.Fakes.fakesconfig
1>   D:\TestPrj\FakesAssemblies\System.4.0.0.0.Fakes.messages
1>   D:\TestPrj\FakesAssemblies\System.Web.4.0.0.0.Fakes.messages
1>
1>Build FAILED.
1>    0 Warning(s)
1>    0 Error(s)
1>
1>Time Elapsed 00:00:36.52
========== Build: 0 succeeded, 1 failed, 2 up-to-date, 0 skipped ==========

자세히 보면, fakes 파일이 4개인데,

1>  Fakes: 4 (4 .fakes files)
1>   Fakes\TestLib.fakes
1>   Fakes\mscorlib.fakes
1>   Fakes\System.fakes
1>   Fakes\System.Web.fakes

생성된 Fakes.dll은 3개입니다.

1>   D:\TestPrj\FakesAssemblies\TestLib.Fakes.dll
1>   D:\TestPrj\FakesAssemblies\TestLib.Fakes.fakesconfig
1>   D:\TestPrj\FakesAssemblies\System.4.0.0.0.Fakes.dll
1>   D:\TestPrj\FakesAssemblies\System.4.0.0.0.Fakes.fakesconfig
1>   D:\TestPrj\FakesAssemblies\System.Web.4.0.0.0.Fakes.dll
1>   D:\TestPrj\FakesAssemblies\System.Web.4.0.0.0.Fakes.fakesconfig
1>   D:\TestPrj\FakesAssemblies\System.4.0.0.0.Fakes.messages
1>   D:\TestPrj\FakesAssemblies\System.Web.4.0.0.0.Fakes.messages

원인은, DLL을 생성하지 못했던 mscorlib.fakes 파일에 정의한 ShimGeneration과 StubGeneration의 순서에 있었습니다. 즉, 다음과 같은 순서인 경우에 "unexpected exception occured (-1002 - 0xfffffc16)" 오류가 발생했던 것으로,

<Fakes xmlns="http://schemas.microsoft.com/fakes/2011/">
  <Assembly Name="mscorlib" Version="4.0.0.0"/>

    <ShimGeneration>
        <Clear />
        <Add FullName="System.AppDomain"/>
    </ShimGeneration>

    <StubGeneration>
        <Remove Namespace="System.Security.Cryptography.X509Certificates"/>
    </StubGeneration>

</Fakes>

이렇게 순서를 바꾸고 나서는 정상적으로 빌드가 되었습니다.

<Fakes xmlns="http://schemas.microsoft.com/fakes/2011/">
  <Assembly Name="mscorlib" Version="4.0.0.0"/>

    <StubGeneration>
        <Remove Namespace="System.Security.Cryptography.X509Certificates"/>
    </StubGeneration>

    <ShimGeneration>
        <Clear />
        <Add FullName="System.AppDomain"/>
    </ShimGeneration>

</Fakes>

사실, Visual Studio 편집기 화면에서 StubGeneration을 뒤에 둔 경우 빨간색 밑줄이 그어져 오류임을 알리고 있었는데 그걸 무시하고 빌드하는 바람에 발생한 오류였습니다.




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







[최초 등록일: ]
[최종 수정일: 7/8/2019]

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

비밀번호

댓글 작성자
 




... 166  167  168  169  170  171  172  [173]  174  175  176  177  178  179  180  ...
NoWriterDateCnt.TitleFile(s)
714정성태5/7/200925714Windows: 45. Windows 7 RC와 함께 공개된 Windows Virtual PC 베타
713정성태4/30/200957455오류 유형: 79. DLL 'xxxxx.dll'을(를) 로드할 수 없습니다. [1]
712정성태4/28/200930080오류 유형: 78. Windows Vista/2008에서의 MSXML4.cab 파일 배포 문제
711정성태4/27/200929855개발 환경 구성: 43. Hyper-V VHD 파일 크기 확장하는 방법
710정성태4/26/200930292.NET Framework: 133. CallbackOnCollectedDelegate was detected [4]파일 다운로드1
709정성태4/24/200926521개발 환경 구성: 42. Windows Vista SP1에서 사용 가능한 Hyper-V 관리 도구
708정성태4/23/200931427.NET Framework: 132. ClickOnce 배포를 명령행 수작업 구성파일 다운로드1
707정성태4/22/200930938개발 환경 구성: 41. Hyper-V에 Linux 설치 - SUSE Linux Enterprise Server 11
706정성태4/21/200926851.NET Framework: 131. ClickOnce - 그룹화시켜 다운로드파일 다운로드1
705정성태4/20/200922406개발 환경 구성: 40. TFS2008 SP1의 DBTier에 SQL Server 2008 SP1 설치 [1]
704정성태4/19/200922292개발 환경 구성: 39. Together 2007 SP1 설치
702정성태4/18/200933776.NET Framework: 130. Infragistics - Tabbed MDI WPF 응용 프로그램파일 다운로드1
701정성태4/17/200928524Windows: 44. bootsect 오류 - Access is denied.
700정성태4/17/200931579.NET Framework: 129. Infragistics WPF 컨트롤 사용 [1]
699정성태4/16/200929979.NET Framework: 128. 이벤트 멤버의 명시적 구현파일 다운로드1
696정성태4/12/200929272오류 유형: 77. RDP 연결이 되지 않는 경우. [1]
693정성태4/9/200923964오류 유형: 76. "Client found response content type of '', but expected 'text/xml'. The request failed with an empty response.No Reports".
692정성태4/8/200936863.NET Framework: 127. ClickOnce로 ActiveX를 같이 배포하는 방법 [2]파일 다운로드1
690정성태4/5/200924561오류 유형: 75. Event Viewer - The data is invalid (13)
688정성태4/5/200930567VS.NET IDE: 60. Output 경로에 매크로 상수 사용하는 방법 [1]
687정성태4/5/200924670.NET Framework: 126. Composite Application Guidance for WPF and Silverlight
689정성태4/5/200924697    답변글 .NET Framework: 126.1. CAG - 빌드 환경 구성파일 다운로드1
691정성태4/6/200924412    답변글 .NET Framework: 126.2. CAG - Shell 띄우기파일 다운로드1
695정성태4/10/200926192    답변글 .NET Framework: 126.3. CAG - 간단한 유형의 모듈 제작파일 다운로드1
703정성태4/18/200925114        답변글 .NET Framework: 126.6. CAG - Tabbed MDI Shell 적용파일 다운로드1
697정성태4/13/200929409    답변글 .NET Framework: 126.4. CAG - Unity 컨테이너 사용 [1]파일 다운로드1
... 166  167  168  169  170  171  172  [173]  174  175  176  177  178  179  180  ...