성태의 닷넷 이야기
홈 주인
모아 놓은 자료
프로그래밍
질문/답변
사용자 관리
사용자
메뉴
아티클
외부 아티클
유용한 코드
온라인 기능
MathJax 입력기
최근 덧글
[정성태] Java - How to use the Foreign Funct...
[정성태] 제가 큰 실수를 했군요. ^^; Delegate를 통한 Bein...
[정성태] Working with Rust Libraries from C#...
[정성태] Detecting blocking calls using asyn...
[정성태] 아쉽게도, 커뮤니티는 아니고 개인 블로그입니다. ^^
[정성태] 질문이 잘 이해가 안 됩니다. 우선, 해당 소스코드에서 ILis...
[양승조
] var대신 dinamic으로 선언해서 해결은 했습니다. 맞는 해...
[양승조
] 또 막혔습니다. ㅠㅠ var list = props[i].Ge...
[양승조
] 아. 감사합니다. 어제는 안됐던것 같은데....정신을 차려야겠네...
[정성태] "props[i].GetValue(props[i])" 코드에서 ...
글쓰기
제목
이름
암호
전자우편
HTML
홈페이지
유형
제니퍼 .NET
닷넷
COM 개체 관련
스크립트
VC++
VS.NET IDE
Windows
Team Foundation Server
디버깅 기술
오류 유형
개발 환경 구성
웹
기타
Linux
Java
DDK
Math
Phone
Graphics
사물인터넷
부모글 보이기/감추기
내용
<div style='display: inline'> <h1 style='font-family: Malgun Gothic, Consolas; font-size: 20pt; color: #006699; text-align: center; font-weight: bold'>Visual Studio 2017부터 단위 테스트에 DataRow 특성 지원</h1> <p> 아마도 대부분의 단위 테스트가 동일한 메서드에 대한 다양한 입력 값을 넣고 기댓값을 비교하는 것일 듯합니다. (특히나 경곗값 테스트도 그렇고.)<br /> <br /> 그럴 때, 일일이 "[Test]" 메서드를 작성할 수도 있고 아니면 하나의 테스트 메서드에 몽땅 밀어 넣는 경우도 있을 것입니다. 대개의 경우 권고는 전자의 경우를 따르라고 하지만 그렇게 하면 너무 과다하게 테스트 메서드가 늘어남과 동시에 테스트 자체의 코드에도 중복이 많게 됩니다. 그래서 제 경우에는 후자의 방식을 주로 선호했는데요.<br /> <br /> 예를 들어, 다음과 같이 GetFirstCharIsUpper라는 메서드를,<br /> <br /> <pre style='margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; background-color: #fbedbb; overflow: auto; font-family: Consolas, Verdana;' > using System; namespace ClassLibrary1 { public class Class1 { public string GetFirstCharIsUpper(string text) { if (char.IsLower(text[0]) == true) { return text[0] + text.Substring(1); } return text; } } } </pre> <br /> 테스트하기 위해 이런 식으로 작성하는 것입니다.<br /> <br /> <pre style='margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; background-color: #fbedbb; overflow: auto; font-family: Consolas, Verdana;' > using Microsoft.VisualStudio.TestTools.UnitTesting; namespace ClassLibrary1.Tests { [TestClass()] public class Class1Tests { Class1 _cl = new Class1(); [TestMethod()] public void GetFirstCharIsUpperTest() { Assert.IsNull(_cl.GetFirstCharIsUpper(null)); StringAssert.Equals(string.Empty, _cl.GetFirstCharIsUpper("")); StringAssert.Equals("1", _cl.GetFirstCharIsUpper("1")); StringAssert.Equals("한글", _cl.GetFirstCharIsUpper("한글")); StringAssert.Equals(" test", _cl.GetFirstCharIsUpper(" test")); StringAssert.Equals("Test", _cl.GetFirstCharIsUpper("test")); } } } </pre> <br /> 그런데, 이렇게 하면 불편한 점이 있는데 특정 입력 값에서 단위 테스트를 실패하는 경우 다음과 같은 식으로,<br /> <br /> <img onclick='toggle_img(this)' class='imgView' alt='mstest_attr_1.png' src='/SysWebRes/bbs/mstest_attr_1.png' /><br /> <br /> 딱 거기까지만 테스트가 되고 끝나 버린다는 점입니다. 위의 경우 "Assert.IsNull(_cl.GetFirstCharIsUpper(null));" 코드에서 Assert가 발생한 것인데, 사실 두 번째 Assert에서도 문제가 함께 있는데도 그 테스트까지는 진행이 안 된 것입니다. 그래서 저렇게 발생한 오류를 수정하고 다시 한번 단위 테스트를 구동하는 경우 이내 다음번 assert에서 다시 테스트가 실패할 것이고 또 그것을 수정하기를 반복해야 합니다.<br /> <br /> 바로 이러한 번잡함을 "DataRow" 특성으로 해결할 수 있는데요,<br /> <br /> <pre style='margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; background-color: #fbedbb; overflow: auto; font-family: Consolas, Verdana;' > [TestMethod] <span style='color: blue; font-weight: bold'>[DataRow(null, null)] [DataRow("", "")] [DataRow("1", "1")] [DataRow("한글", "한글")] [DataRow(" test", " test")] [DataRow("Test", "test")]</span> public void GetFirstCharIsUpperTest2(string expected, string arg) { StringAssert.Equals(expected, _cl.GetFirstCharIsUpper(arg)); } </pre> <br /> 오~~~ 깔끔하죠? ^^ 중복 코드도 많이 없어지고, 게다가 테스트 역시 하나의 항목으로 묶여 관리도 편할뿐더러 DataRow 항목에 대해 모두 실행을 하기 때문에,<br /> <br /> <img onclick='toggle_img(this)' class='imgView' alt='mstest_attr_1.png' src='/SysWebRes/bbs/mstest_attr_1.png' /><br /> <br /> 보는 바와 같이 테스트 실패한 입력 값의 유형을 모두 파악할 수 있어 한 번에 모두 수정하고 다시 단위 테스트를 돌릴 수 있습니다.<br /> </p><br /> <br /><hr /><span style='color: Maroon'>[이 글에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]</span> </div>
첨부파일
스팸 방지용 인증 번호
1786
(왼쪽의 숫자를 입력해야 합니다.)