Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 
(연관된 글이 1개 있습니다.)

Fakes를 포함한 단위 테스트 프로젝트를 빌드 시 CS0619 관련 오류 발생

Fakes를 사용한 단위 테스트 프로젝트가,

Visual Studio의 단위 테스트 작성 시 Fakes를 이용한 메서드 재정의 방법
; https://www.sysnet.pe.kr/2/0/10858

어느 순간부터 다음과 같은 빌드 오류가 발생합니다. (빌드가 안되었으므로 당연히 해당 프로젝트에 대한 테스트 목록은 "Test Explorer"에서 제거됩니다.)

Error CS0619 'SocketClientAccessPolicyProtocol' is obsolete: 'This API supports the .NET Framework infrastructure and is not intended to be used directly from your code.'

오류를 보면 SocketClientAccessPolicyProtocol을 obsolete되었다고 하는데 실제로 다음의 문서에서 그 기록을 확인할 수 있습니다.

.NET Framework에서 사용되지 않는 멤버
; https://docs.microsoft.com/en-us/dotnet/framework/whats-new/obsolete-members

그러고 보니, 원래 이 단위 테스트 프로젝트는 빌드가 잘 되던 것인데 지난번 문제로,

Error CS0234 The type or namespace name 'ITuple' does not exist in the namespace
; https://www.sysnet.pe.kr/2/0/11438

.NET 4.0 단위 테스트 프로젝트를 .NET 4.7.1로 올렸더니 발생한 것입니다.




그런데 재미있는 것은, "Rebuild"했을 때만 이런 오류가 발생하고 그다음 이어서 그냥 "Build"하면 정상적으로 빌드가 됩니다. 게다가 분명히 다음과 같이 Fakes에서 제거하도록 설정했는데도,

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

    <ShimGeneration>
        <Add FullName="System.Net.Sockets.Socket"/>
        <Remove FullName="System.Net.Sockets.SocketClientAccessPolicyProtocol"/>
    </ShimGeneration>

</Fakes>

이에 상관없이 오류가 발생합니다. 이를 해결하려면, 오류가 발생하는 Fakes 프로젝트의 소스 코드를 잘 봐야 합니다.

Error CS0619 'SocketClientAccessPolicyProtocol' is obsolete: 'This API supports the .NET Framework infrastructure and is not intended to be used directly from your code.' [D:\UnitTest\MyUnitTest\obj\Debug\Fakes\s\f.csproj] MyUnitTest D:\UnitTest\MyUnitTest\f.cs 17591 Active


따라서 다음의 소스 코드를 보면,

D:\UnitTest\MyUnitTest\obj\Debug\Fakes\s\f.cs

검색으로 SocketClientAccessPolicyProtocol이 사용된 타입을 알아낼 수 있습니다.

public static mqttf::Microsoft.QualityTools.Testing.Fakes.FakesDelegates.Func<global::System.Net.Sockets.SocketAsyncEventArgs, global::System.Net.Sockets.SocketClientAccessPolicyProtocol> SocketClientAccessPolicyProtocolGet
{
    [mqttf::Microsoft.QualityTools.Testing.Fakes.Shims.ShimMethod("get_SocketClientAccessPolicyProtocol", 20)]
    set
    {
        mqttf::Microsoft.QualityTools.Testing.Fakes.Shims.ShimRuntime.SetShimPublicInstance
            ((global::System.Delegate)value, typeof(global::System.Net.Sockets.SocketAsyncEventArgs), (object)null, 
                "get_SocketClientAccessPolicyProtocol", 
                typeof(global::System.Net.Sockets.SocketClientAccessPolicyProtocol), new global::System.Type[]{});
    }
}

위의 코드를 포함하는 클래스는 "System.Net.Sockets.SocketAsyncEventArgs"이고 따라서 다음과 같이 .Fakes 설정 파일에 추가하면 됩니다.

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

    <ShimGeneration>
        <Add FullName="System.Net.Sockets.Socket"/>
        <Remove FullName="System.Net.Sockets.SocketClientAccessPolicyProtocol"/>
        <Remove FullName="System.Net.Sockets.SocketAsyncEventArgs"/>
    </ShimGeneration>

</Fakes>




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

[연관 글]






[최초 등록일: ]
[최종 수정일: 1/20/2018]

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

비밀번호

댓글 작성자
 




... [76]  77  78  79  80  81  82  83  84  85  86  87  88  89  90  ...
NoWriterDateCnt.TitleFile(s)
12067정성태11/27/201921143디버깅 기술: 137. 실제 사례를 통해 Debug Diagnostics 도구가 생성한 닷넷 웹 응용 프로그램의 성능 장애 보고서 설명 [1]파일 다운로드1
12066정성태11/27/201920696디버깅 기술: 136. windbg - C# PInvoke 호출 시 마샬링을 담당하는 함수 분석 - OracleCommand.ExecuteReader에서 OpsSql.Prepare2 PInvoke 호출 분석
12065정성태11/25/201918574디버깅 기술: 135. windbg - C# PInvoke 호출 시 마샬링을 담당하는 함수 분석파일 다운로드1
12064정성태11/25/201921995오류 유형: 580. HTTP Error 500.0/500.33 - ANCM In-Process Handler Load Failure
12063정성태11/21/201920917디버깅 기술: 134. windbg - RtlReportCriticalFailure로부터 parameters 정보 찾는 방법
12062정성태11/21/201920020디버깅 기술: 133. windbg - CoTaskMemFree/FreeCoTaskMem에서 발생한 덤프 분석 사례 - 두 번째 이야기
12061정성태11/20/201920224Windows: 167. CoTaskMemAlloc/CoTaskMemFree과 윈도우 Heap의 관계
12060정성태11/20/201922572디버깅 기술: 132. windbg/Visual Studio - HeapFree x64의 동작 분석
12059정성태11/20/201921780디버깅 기술: 131. windbg/Visual Studio - HeapFree x86의 동작 분석
12058정성태11/19/201922420디버깅 기술: 130. windbg - CoTaskMemFree/FreeCoTaskMem에서 발생한 덤프 분석 사례
12057정성태11/18/201917649오류 유형: 579. Visual Studio - Memory 창에서 유효한 주소 영역임에도 "Unable to evaluate the expression." 오류 출력
12056정성태11/18/201923908개발 환경 구성: 464. "Microsoft Visual Studio Installer Projects" 프로젝트로 EXE 서명 및 MSI 파일 서명 방법파일 다운로드1
12055정성태11/17/201917888개발 환경 구성: 463. Visual Studio의 Ctrl + Alt + M, 1 (Memory 1) 등의 단축키가 동작하지 않는 경우
12054정성태11/15/201919548.NET Framework: 869. C# - 일부러 GC Heap을 깨뜨려 GC 수행 시 비정상 종료시키는 예제
12053정성태11/15/201920663Windows: 166. 윈도우 10 - 명령행 창(cmd.exe) 속성에 (DotumChe, GulimChe, GungsuhChe 등의) 한글 폰트가 없는 경우
12052정성태11/15/201919507오류 유형: 578. Azure - 일정(schedule)에 등록한 runbook이 1년 후 실행이 안 되는 문제(Reason - The key used is expired.)
12051정성태11/14/201923752개발 환경 구성: 462. 시작하자마자 비정상 종료하는 프로세스의 메모리 덤프 - procdump [1]
12050정성태11/14/201921162Windows: 165. AcLayers의 API 후킹과 FaultTolerantHeap
12049정성태11/13/201921700.NET Framework: 868. (닷넷 프로세스를 대상으로) 디버거 방식이 아닌 CLR Profiler를 이용해 procdump.exe 기능 구현
12048정성태11/12/201921556Windows: 164. GUID 이름의 볼륨에 해당하는 파티션을 찾는 방법
12047정성태11/12/201923989Windows: 163. 안전하게 eject시킨 USB 장치를 물리적인 재연결 없이 다시 인식시키는 방법
12046정성태10/29/201918103오류 유형: 577. windbg - The call to LoadLibrary(...\sos.dll) failed, Win32 error 0n193
12045정성태10/27/201918520오류 유형: 576. mstest.exe 실행 시 "Visual Studio Enterprise is required to execute the test." 오류 - 두 번째 이야기
12044정성태10/27/201917665오류 유형: 575. mstest.exe - System.Resources.MissingSatelliteAssemblyException: The satellite assembly named "Microsoft.VisualStudio.ProductKeyDialog.resources.dll, ..."
12043정성태10/27/201919682오류 유형: 574. Windows 10 설치 시 오류 - 0xC1900101 - 0x4001E
12042정성태10/26/201918690오류 유형: 573. OneDrive 하위에 위치한 Documents, Desktop 폴더에 대한 권한 변경 시 "Unable to display current owner"
... [76]  77  78  79  80  81  82  83  84  85  86  87  88  89  90  ...