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

OpenCover 소스 코드 분석을 Visual Studio 2013에서 하는 방법

OpenCover가 꽤나 잘 만들어진 .NET Profiler의 한 사례라서 자꾸만 보게 되는군요. ^^

혹시 분석하고 싶은 분들이 계시다면, 기왕이면 Visual Studio내에서 Breakpoint를 걸어가며 테스트하는 것이 훨씬 도움이 되기 때문에 기록을 남겨봅니다.

우선, github에 공개된 프로젝트를 로드하기 위해서는 다음의 준비물들이 필요합니다.

  1. Visual Studio VS2013 (Community Edition) or later with C# and C++
  2. WiX 3.9 or later (http://wix.codeplex.com/releases/view/136891)
  3. Specflow (http://visualstudiogallery.msdn.microsoft.com/9915524d-7fb0-43c3-bb3c-a8a14fbd40ee)

이 중에서 3번 Sepcflow는 2013용으로 따로 링크가 있으므로 이것을 다운로드 받아야 합니다.

SpecFlow for Visual Studio 2013 
; https://visualstudiogallery.msdn.microsoft.com/90ac3587-7466-4155-b591-2cd4cc4401bc

부가적으로, OpenCover.Console.exe가 2차 프로세스를 실행하는 방식이므로 디버깅을 위해서는 다음의 도구도 다운로드 받아야 합니다.

Microsoft Child Process Debugging Power Tool
; https://visualstudiogallery.msdn.microsoft.com/a1141bff-463f-465f-9b6d-d29b7b503d7a

이걸로 설치 준비는 되었고.

이제, Visual Studio 2013에서 Tools / Options 메뉴에서 "Source Control"의 "Current source control plug-in"을 "Microsoft Git Provider"로 변경시켜줍니다. 그런 후, "Team Explorer" 창에서 "Clone" 링크를 이용해 다음의 GIT 리포지터리를 내려받습니다. (또는, 그냥 자신의 것으로 Fork하는 것도 좋겠고!)

https://github.com/OpenCover/opencover.git

모두 내려받은 후에는 루트 폴더에 있는 Build.bat 파일을 명령행에서 한번 실행해 줍니다. 그럼, 각종 환경 구성과 함께 빌드를 합니다. 이후, Visual Studio 2013에서 /Main/OpenCover.sln 파일을 불러오면 됩니다.

마지막으로 디버깅 환경을 구성해 주는데요. 예제 프로그램을 위해 제 경우에는 \samples\ConsoleApplication1\bin\Debug\ConsoleApplication1.exe로 두었고,
OpenCover.Profiler 프로젝트 속성 창에서 다음과 같이 디버깅 설정을 해줬습니다.

Command:            $(OutDir)..\OpenCover.Console.exe
Command Arguments:  -target:$(SolutionDir)..\samples\ConsoleApplication1\bin\Debug\ConsoleApplication1.exe -register:user -filter:+[*]*
Working Directory:  $(OutDir)..

그다음 F5 키를 누르면 이제부터 BP(Breakpoint) 디버깅을 이용한 프로그램 분석이 가능합니다. 이렇게!

open_cover_build_1.png

조금 헤매다 보면... OpenCover의 흐름이 보일 것입니다. ^^




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

[연관 글]






[최초 등록일: ]
[최종 수정일: 6/28/2021]

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

비밀번호

댓글 작성자
 



2015-03-10 02시25분
조금 어렵지만 좋은정보 감사합니다!
김선우

... 106  107  108  109  110  111  112  113  114  [115]  116  117  118  119  120  ...
NoWriterDateCnt.TitleFile(s)
11082정성태10/26/201631398.NET Framework: 614. C# - DateTime.Ticks의 정밀도 [4]파일 다운로드1
11081정성태10/26/201621537오류 유형: 364. You need to fix your Microsoft Account for apps on your other devices to be able to launch apps and continue experiences on this device.
11080정성태10/24/201624929Windows: 130. Windows Server 2016 Nano 서버 설치 방법
11079정성태10/21/201622109Windows: 129. Windows Server 2016 설치 CD에 있는 Convert-WindowsImage.ps1 사용 방법 정리
11078정성태10/21/201623288Windows: 128. Windows Server 2016 Nano 서버 VHD 이미지 만드는 방법 - TP5 기준
11077정성태10/21/201621675오류 유형: 363. Active Directory 서버의 NETLOGON 서비스가 멈췄을 때 발생하는 문제
11076정성태10/21/201621308오류 유형: 362. 윈도우 백업 시 오류 - 0x80780040
11075정성태10/20/201621691Windows: 127. Convert-WindowsImage.ps1 사용 방법 정리
11074정성태10/20/201630608Windows: 126. Windows Server 2016 평가판을 정식 버전으로 라이선스 변경하는 방법
11073정성태10/20/201626659.NET Framework: 613. 윈도우 데스크톱 응용 프로그램(예: Console)에서 알림 메시지(Toast notifications) 띄우기 [1]파일 다운로드1
11072정성태10/20/201623218VC++: 102. 새로 추가한 ATL COM 객체가 regsvr32.exe로 등록이 안 되는 문제
11071정성태10/20/201626908.NET Framework: 612. UWP(유니버설 윈도우 플랫폼) 앱에서 콜백 함수 내에서의 UI 요소 접근 방법 [1]
11070정성태10/20/201620505Windows: 125. 윈도우 서버 2016 마이그레이션
11069정성태10/19/201628590.NET Framework: 611. C++ 개발자들을 위한 C# Thread 동작 방식 [2]
11068정성태10/19/201631762Windows: 124. 윈도우 운영체제의 시간 함수 (5) - TSC(Time Stamp Counter)와 QueryPerformanceCounter [12]파일 다운로드1
11067정성태10/18/201627627Windows: 123. 윈도우 운영체제의 시간 함수 (4) - RTC, TSC, PM Clock, HPET Timer [2]
11066정성태10/17/201625918Windows: 122. 윈도우 운영체제의 시간 함수 (3) - QueryInterruptTimePrecise, QueryInterruptTime 함수파일 다운로드1
11065정성태10/15/201631038Windows: 121. 윈도우 운영체제의 시간 함수 (2) - Sleep 함수의 동작 방식 [1]
11064정성태10/14/201623027.NET Framework: 610. C# - WaitOnAddress Win32 API 사용파일 다운로드1
11063정성태10/14/201639128Windows: 120. 윈도우 운영체제의 시간 함수 (1) - GetTickCount와 timeGetTime의 차이점 [5]파일 다운로드1
11062정성태10/12/201619062오류 유형: 361. WCF .svc 호출 시 Could not find a base address that matches scheme net.tcp 예외
11061정성태10/12/201631866오류 유형: 360. IIS - 500.19 오류 (0x80070021)
11060정성태10/12/201624034오류 유형: 359. WCF - .svc 요청시 404 Not Found
11059정성태10/11/201628772.NET Framework: 609. WPF - 다중 스레드 환경에서 데이터 바인딩의 INotifyPropertyChanged.PropertyChanged에 대한 배려 [1]파일 다운로드1
11058정성태10/8/201623897개발 환경 구성: 303. Windows 10 Bash Shell - 한글 환경을 영문으로 바꾸고 싶다면?
11057정성태10/8/201618434오류 유형: 358. Windows 10 bash shell - sudo: unable to resolve host ...
... 106  107  108  109  110  111  112  113  114  [115]  116  117  118  119  120  ...