Microsoft MVP성태의 닷넷 이야기
VS.NET IDE: 40. FxCop - IDE 에서 제공해 주는 SuppressMessage 코드 [링크 복사], [링크+제목 복사],
조회: 20316
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 

.NET 에서의 Code Analysis 툴인 FxCop.
잘들 사용하고 계신가요? ^^

솔직히, 저도 .NET 1.1 시절에는 그다지 잘 사용하지 않았습니다.
.NET 2.0이 되면서, VS.NET IDE에 통합이 되어 있어서 이젠 좀 관심을 갖게 되었는데요.
그래서, 신규 프로젝트는 모두 FxCop을 Enable 시켜놓고 진행하고 있습니다. (Debug 모드에서는 Disable 시켜 놓고, Release 모드에서 Enable 시켜 놓는 것이 좋습니다.)

그런데, FxCop 규칙을 적용하다 보면 부득이하게 해당 규칙에 위반할 수밖에 없는 상황이 나오는데요.
그런 경우, 해결할 수 있는 방법이 크게 2가지가 있습니다.

1. 프로젝트 규모로 해당 규칙을 Disable.
다음과 같이 "프로젝트 속성" 창에서, "Code Analysis" 부분을 통해서 특정 규칙에 대한 Enable/Disbale 설정이 가능합니다.

Code Analysis

2. 코드 단위로 해당 규칙을 Disable.
규칙을 위반하는 .NET 코드에 대해서 SuppressMessage 특성을 설정해서 예외적으로 벗어납니다.
예를 들어서,

[System.Diagnostics.CodeAnalysis.SuppressMessage("Microsoft.Naming", "CA1705:LongAcronymsShouldBePascalCased")]
public partial class DDDPanel : UserControl
{

개인적으로는, 위의 그림에서 보는 것처럼, "CA2210" 규칙을 제외하고는 가능한 FxCop 규정에 맞춰주고 부득이한 경우, 위와 같이 특성을 제공해서 컴파일을 하고 있습니다. 즉, 프로젝트 규모로 규칙을 disable 시키는 설정은 거의 하지 않는 다는 것이지요.



그나저나, 코드로 하는 것을 보니 상당히 귀찮습니다. 첫째로 너무 길죠. ^^;
게다가 중간에 "CA1705" 다음에 나오는 규칙의 타입명에 해당하는 "LongAcronymsShouldBePascalCased"까지 주어야 합니다. 더욱 문제는 바로 그 타입명 "LongAcronymsShouldBePascalCased"이 컴파일 경고 메시지에는 전혀 안 나온다는 것입니다.

일례로, 위의 구문에서 SuppressMessage를 제거하면.
Output 출력에는 다음과 같이 경고가 나오고,

D:\Program Files\Microsoft Visual Studio 8\Team Tools\Static Analysis Tools\FxCop\FxCopCmd.exe  
/o:"..\..\Output\Release\Test.dll.CodeAnalysisLog.xml" 
;
/r:D:\Program Files\Microsoft Visual Studio 8\Team Tools\Static Analysis Tools\FxCop\\rules /rid:-Microsoft.Design#CA2210
MSBUILD : warning : CA1705 : Microsoft.Naming : Correct the capitalization of type name 'DDDPanel'.

Eror List에는 다음과 같이 경고가 나옵니다.

Warning	1 CA1705 : Microsoft.Naming : Correct the capitalization of type name 'DDDPanel'.	D:\workshop\Test\DDDPanel.cs	15	

그래서, ^^; 제가 선택했던 방법은, "Error List"에서 해당 항목을 선택한 다음 "F1" 도움말을 호출하는 것이었습니다. 그러면, 온라인 도움말에서 타입명이 나오기 때문인데요.

오호...~~~ ^^;
오늘 새로운 것을 배웠습니다. Code Snippet과 비슷한 개념인데요. 자동으로 SuppressMessage 특성을 생성하도록 하는 방법이 MSDN Wiki 사이트에 댓글로 달려져 있었습니다.

방법은 매우 간단합니다. "Error List"에서 해당 항목을 오른쪽 마우스 버튼으로 눌러서 나오는 메뉴의 "SuppressMessage(s)"를 선택하는 것이었습니다. 다음 화면과 같이.

SuppressMessage 적용
훌륭하군요. ^^ 위의 메뉴를 선택하면, 해당 코드의 바로 윗부분에 자동으로 SuppressMessage 특성이 추가됩니다.






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

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

비밀번호

댓글 작성자
 




... 46  47  48  49  50  51  52  53  54  [55]  56  57  58  59  60  ...
NoWriterDateCnt.TitleFile(s)
12565정성태3/17/202113559오류 유형: 704. curl.exe 실행 시 dll not found 오류
12564정성태3/16/202114417VS.NET IDE: 160. 새 프로젝트 창에 C++/CLI 프로젝트 템플릿이 없는 경우
12563정성태3/16/202117309개발 환경 구성: 551. C# - JIRA REST API 사용 정리 (3) jira-oauth-cli 도구를 이용한 키 관리
12562정성태3/15/202118055개발 환경 구성: 550. C# - JIRA REST API 사용 정리 (2) JIRA OAuth 토큰으로 API 사용하는 방법파일 다운로드1
12561정성태3/12/202116816VS.NET IDE: 159. Visual Studio에서 개행(\n, \r) 등의 제어 문자를 치환하는 방법 - 정규 표현식 사용
12560정성태3/11/202117822개발 환경 구성: 549. ssh-keygen으로 생성한 PKCS#1 개인키/공개키 파일을 각각 PKCS8/PEM 형식으로 변환하는 방법
12559정성태3/11/202118118.NET Framework: 1028. 닷넷 5 환경의 Web API에 OpenAPI 적용을 위한 NSwag 또는 Swashbuckle 패키지 사용 [2]파일 다운로드1
12558정성태3/10/202117243Windows: 192. Power Automate Desktop (Preview) 소개 - Bitvise SSH Client 제어 [1]
12557정성태3/10/202115445Windows: 191. 탐색기의 보안 탭에 있는 "Object name" 경로에 LEFT-TO-RIGHT EMBEDDING 제어 문자가 포함되는 문제
12556정성태3/9/202113639오류 유형: 703. PowerShell ISE의 Debug / Toggle Breakpoint 메뉴가 비활성 상태인 경우
12555정성태3/8/202116948Windows: 190. C# - 레지스트리에 등록된 DigitalProductId로부터 라이선스 키(Product Key)를 알아내는 방법파일 다운로드2
12554정성태3/8/202116539.NET Framework: 1027. 닷넷 응용 프로그램을 위한 PDB 옵션 - full, pdbonly, portable, embedded
12553정성태3/5/202116491개발 환경 구성: 548. 기존 .NET Framework 프로젝트를 .NET Core/5+ 용으로 변환해 주는 upgrade-assistant, try-convert 도구 소개 [4]
12552정성태3/5/202115969개발 환경 구성: 547. github workflow/actions에서 Visual Studio Marketplace 패키지 등록하는 방법
12551정성태3/5/202114344오류 유형: 702. 비주얼 스튜디오 - The 'CascadePackage' package did not load correctly. (2)
12550정성태3/5/202114053오류 유형: 701. Live Share 1.0.3713.0 버전을 1.0.3884.0으로 업데이트 이후 ContactServiceModelPackage 오류 발생하는 문제
12549정성태3/4/202115427오류 유형: 700. VsixPublisher를 이용한 등록 시 다양한 오류 유형 해결책
12548정성태3/4/202116526개발 환경 구성: 546. github workflow/actions에서 nuget 패키지 등록하는 방법
12547정성태3/3/202117153오류 유형: 699. 비주얼 스튜디오 - The 'CascadePackage' package did not load correctly.
12546정성태3/3/202117036개발 환경 구성: 545. github workflow/actions에서 빌드시 snk 파일 다루는 방법 - Encrypted secrets
12545정성태3/2/202119837.NET Framework: 1026. 닷넷 5에 추가된 POH (Pinned Object Heap) [10]
12544정성태2/26/202120025.NET Framework: 1025. C# - Control의 Invalidate, Update, Refresh 차이점 [2]
12543정성태2/26/202118019VS.NET IDE: 158. C# - 디자인 타임(design-time)과 런타임(runtime)의 코드 실행 구분
12542정성태2/20/202119684개발 환경 구성: 544. github repo의 Release 활성화 및 Actions를 이용한 자동화 방법 [1]
12541정성태2/18/202117267개발 환경 구성: 543. 애저듣보잡 - Github Workflow/Actions 소개
12540정성태2/17/202118415.NET Framework: 1024. C# - Win32 API에 대한 P/Invoke를 대신하는 Microsoft.Windows.CsWin32 패키지
... 46  47  48  49  50  51  52  53  54  [55]  56  57  58  59  60  ...