기본 콘텐츠로 건너뛰기

라벨이 TDD인 게시물 표시

[javascript] 자스민(Jasmine)을 이용하여 TDD 작성후 웹 페이지에 적용해보자.

 다음 코드는  멍개의 코드 저장소 에 있습니다. 코드를 확인하고 싶으면 여기를 click 하세요 시작하기 전에... 책을 시작하기 전에 책에서 사용하는 자스민을 어떤식으로 이용하여 테스트 코드를 작성할 수 있는지 봐보자. 자스민 사용방법 테스트 러너파일 작성 테스트 러너란 자스민 코드와 소스파일, 스펙을 참조하는 html 파일 app_spec.html 테스트 코드를 작성하기 전에 첫째로 js 파일을 UI에서 완전히 분리하여 작성하는 것이 중요하다. 모듈패턴 테스트 코드가 가능한 코드를 작성하기 위해서는  모듈패턴 을 사용하도록 합니다. 모듈패턴이란? 함수로 데이터를 감추고, 모듈 API를 담고있는 객체를 반환하는 형태다. 모듈패턴은 자바스크립트에서 가장 많이 사용하는 패턴입니다. 두 가지 형태로 모듈패턴을 사용할 수 있습니다. 첫 번째는 호출하는 방식으로 사용합니다. 두 번째는 즉시 실행 함수 기반으로 사용할 수 있습니다. 여기서 즉시 실행 함수를  IIFE(Immediately Invoked Function Expression) 라고 합니다. 모듈 패턴 코드를 어떤식으로 작성할 수 있는지 간단하게 확인해보겠습니다. // 공간생성 let App = App || {}; // 생성된 공간에 함수를 추가한다. 인자로 함수를 넘긴다.( == 의존성 있는 함수를 주입) App.Person = function(God){ let name = God.makeName(); // API 노출 return { getName: function(){return name;}, setName: function(newName){name = newName;} } }; App 변수를 생성합니다. 생선된 변수에 Person() 함수를 만듭니다. person() 함수는 첫 번째 인자로 함수를 전달받습니다. retur...

[node.js] TDD 및 BDD 추가 설명

TDD와 BDD를 좀더 추가적인 설명을 하려고 한다. superagent는 http요청을 수행하기 위한 스트림라인용 라이브러리이다. request : 세번째로 많이 사용되는 모듈 core http 모듈 : 투박하며, 매우 낮은 레벨을 가짐 supertest : superagent 시반의 어서션 라이브러리 superagent을 install을 해주자 npm install sueragent 1 var  superagent  =  require( 'superagent' ); cs 설치된 모듈을 추가를 해준다 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 var  expect  =  require( 'expect.js' ); var  testmodules  =  require( './index' ).TestModules; var  assert  =  require( 'chai' ).assert; var  superagent  =  require( 'superagent' ); describe.only( 'frame1' , function (){     it( 'should respond to Get' ,  function (){         superagent             .get( "ec2-54-92-43-111.ap-northeast-1.compute....