각도기-소개
이 장에서는 Protractor에 대한 소개를 제공합니다. 여기서이 테스트 프레임 워크의 기원과이 도구의 작동 및 제한 사항을 선택해야하는 이유에 대해 알아 봅니다.
각도기는 무엇입니까?
Protractor는 Angular 및 AngularJS 애플리케이션을위한 오픈 소스 엔드-투-엔드 테스트 프레임 워크입니다. WebDriver 위에 Google에 의해 구축되었습니다. 또한“Angular Scenario Runner”라고하는 기존 AngularJS E2E 테스트 프레임 워크를 대체합니다.
또한 NodeJS, Selenium, Jasmine, WebDriver, Cucumber, Mocha 등과 같은 강력한 기술을 결합하는 솔루션 통합 자로 작동합니다. AngularJS 애플리케이션 테스트와 함께 일반 웹 애플리케이션에 대한 자동 회귀 테스트도 작성합니다. 실제 브라우저를 사용하여 테스트를 실행하기 때문에 실제 사용자처럼 애플리케이션을 테스트 할 수 있습니다.
다음 다이어그램은 각도기의 간략한 개요를 제공합니다-
위의 다이어그램에서 우리는-
Protractor − 앞서 언급했듯이, 특히 각도 앱을 위해 설계된 WebDriver JS에 대한 래퍼입니다.
Jasmine− 기본적으로 JavaScript 코드를 테스트하기위한 동작 중심 개발 프레임 워크입니다. Jasmine으로 쉽게 테스트를 작성할 수 있습니다.
WebDriver JS − 셀레늄 2.0 / WebDriver를위한 Node JS 바인딩 구현입니다.
Selenium − 단순히 브라우저를 자동화합니다.
유래
앞서 말했듯이 Protractor는 "Angular Scenario Runner"라고하는 기존 AngularJS E2E 테스트 프레임 워크를 대체합니다. 기본적으로 Protractor의 기원은 Scenario Runner의 끝에서 시작됩니다. 여기서 발생하는 질문은 왜 우리가 Protractor를 만들어야 하는가입니다. 이를 이해하려면 먼저 이전 모델 인 Scenario Runner에 대해 확인해야합니다.
각도기의 시작
Protractor 개발의 주요 기여자 인 Julie Ralph는 Google 내의 다른 프로젝트에서 Angular Scenario Runner에 대해 다음과 같은 경험을했습니다. 이것은 특히 간격을 메우기 위해 Protractor를 구축하는 동기가되었습니다.
“Scenario Runner를 사용해 보았지만 실제로 테스트에 필요한 작업을 수행 할 수 없다는 것을 알게되었습니다. 로그인과 같은 것들을 테스트해야했습니다. 귀하의 로그인 페이지는 Angular 페이지가 아니며 Scenario Runner는이를 처리 할 수 없습니다. 팝업 및 여러 창, 브라우저 기록 탐색 등을 처리 할 수 없습니다. "
Protractor의 가장 큰 장점은 Selenium 프로젝트의 성숙도이며 Angular 프로젝트에 쉽게 사용할 수 있도록 방법을 정리했습니다. Protractor의 디자인은 응용 프로그램의 웹 UI, 백엔드 서비스, 지속성 계층 등과 같은 모든 계층을 테스트하는 방식으로 구축됩니다.
왜 각도기?
거의 모든 애플리케이션이 개발을 위해 JavaScript를 사용하고 있다는 것을 알고 있습니다. 자바 스크립트의 크기가 커지면 테스터의 작업이 어려워지고 애플리케이션 자체의 수가 증가하여 애플리케이션이 복잡해집니다. 대부분의 경우 AngularJS 애플리케이션에서 웹 요소를 캡처하고 JUnit 또는 Selenium WebDriver를 사용하여 확장 된 HTML 구문을 사용하여 웹 애플리케이션 구성 요소를 표현하는 것이 매우 어려워집니다.
여기서 질문은 Selenium Web Driver가 AngularJS 웹 요소를 찾을 수없는 이유입니다. 그 이유는 AngularJS 응용 프로그램에 Selenium 로케이터에 포함되지 않은 ng-repeater, ng-controller 및 ng-model 등과 같은 확장 된 HTML 속성이 있기 때문입니다.
여기에서 Protractor의 중요성은 Selenium 위에있는 Protractor가 AngularJS 웹 애플리케이션에서 확장 된 HTML 요소를 처리하고 제어 할 수 있기 때문에 존재합니다. 그렇기 때문에 대부분의 프레임 워크는 AngularJS 애플리케이션에 대한 단위 테스트를 수행하는 데 초점을 맞추고 있으며, Protractor는 애플리케이션의 실제 기능을 테스트하는 데 사용되었습니다.
각도기의 작동
테스트 프레임 워크 인 Protractor는 Selenium과 함께 작동하여 브라우저 또는 모바일 장치에서 실행되는 AngularJS 애플리케이션과 사용자의 상호 작용을 시뮬레이션하기위한 자동화 된 테스트 인프라를 제공합니다.
각도기의 작동은 다음 단계의 도움으로 이해할 수 있습니다-
Step 1− 첫 번째 단계에서는 테스트를 작성해야합니다. Jasmine 또는 Mocha 또는 Cucumber의 도움으로 할 수 있습니다.
Step 2− 이제 Protractor를 사용하여 수행 할 수있는 테스트를 실행해야합니다. 테스트 러너라고도합니다.
Step 3 −이 단계에서 Selenium 서버는 브라우저 관리를 도와줍니다.
Step 4 − 마지막으로 브라우저 API는 Selenium WebDriver의 도움으로 호출됩니다.
장점
이 오픈 소스 엔드 투 엔드 테스트 프레임 워크는 다음과 같은 이점을 제공합니다.
오픈 소스 도구 인 Protractor는 설치 및 설정이 매우 쉽습니다.
Jasmine 프레임 워크와 잘 작동하여 테스트를 만듭니다.
TDD (테스트 주도 개발)를 지원합니다.
테스트에 명시 적으로 대기 및 절전을 추가 할 필요가 없음을 의미하는 자동 대기를 포함합니다.
Selenium WebDriver의 모든 장점을 제공합니다.
여러 브라우저를 통한 병렬 테스트를 지원합니다.
자동 동기화의 이점을 제공합니다.
테스트 속도가 뛰어납니다.
한계
이 오픈 소스 엔드-투-엔드 테스트 프레임 워크에는 다음과 같은 제한 사항이 있습니다.
WebDriver JS의 래퍼이기 때문에 브라우저 자동화에서 카테고리를 발견하지 않습니다.
JavaScript에서만 사용할 수 있으므로 JavaScript에 대한 지식은 사용자에게 필수적입니다.
UI 기반 테스트 도구이기 때문에 프런트 엔드 테스트 만 제공합니다.