맨 마지막 테스트 함수의 테스트 준비단계가 2번 실행되는 버그가 있는 것같다.
나의 test case가 성공할 때도 있고 실패할 때도 있는 이상한 상태가 되어서 내 잘못인 줄 알고 개발중인 모듈의 여기저기를 손댔다가 갑자기 느끼는 바가 있어 EUnit을 테스트하는 간단한 코드를 만들었다.
순간 당황했으나, 방금 추가한 테스트 케이스를 살펴보니 _assert macro에 들어가는 내용이 잘못되어 있었다. boolean expression이 들어가야하는 곳에 그냥 expression만 하나 들어있었고, _assert(very_complex_expression) =:= expected value의 형태로 되어 있었다(어제 급히 추가하고 안돌려보고 바로 퇴근한 것이 후회되는 순간이었다). 그래도 컴파일은 멀쩡히 평소처럼 잘 되고 runtime에 가서야 에러가 나는 것은 좀 불편해보인다.
간략히 축약해서 예를 들자면 다음과 같다.
%% causes runtime error (see above msg).
?_assert(1+1) =:= 2
%% runs well w/o runtime error (good)
?_assert(1+1 =:= 2)
실제 내 코드에서는 1+1부분이 많이 복잡해서 화면을 넘어가고 있었고, _assert macro가 여러 개의 리스트로 묶여져 있어서 찾는데 좀 고생했다. Orz.
unit test - makefile에서... make file에 다음과 같은 부분을 추가한 후에, make test 하면 간편하게 명령행에서 unit test를 수행할 수있다. (makefile 뼈대는 Programming Erlang을 기초로 했다.)
...... MODS = doc str_util db i18n tiny_scan ......
test: compile test_subdirs rm -rf Mnesia.nonode@nohost # removes previous mneisa db (optional). @for m in ${MODS};\ do \ echo "testing $$m";\ ${ERL} -noshell -pz "subdir1" -pz "subdir2" -s $$m test -s init stop;\ done
test_subdirs: cd subdir1; make test cd subdir2; make test
unit test, coverage test - 개발중 REPL(distel 또는 erl prompt) 에서... REPL을 사용해서 (멋지게) 코딩-테스트를 반복중이라면, 다음과 같은 모듈을 하나 디렉토리에 넣어서 test:unit() 또는 test:cover() 를 실행시켜서 unit test 및 coverage test를 시시때때로 수행해 볼 수 있다.
%%%------------------------------------------------------------------- %%% File : test.erl %%% Author : manywaypark <manywaypark@gmail.com> %%% Description : some test codes. %%% %%% Created : 11 Aug 2008 by manywaypark <manywaypark@gmail.com> %%%------------------------------------------------------------------- -module(test).