각도기-첫 번째 테스트 작성

이 장에서는 각도기에서 첫 번째 테스트를 작성하는 방법을 이해하겠습니다.

각도기에 필요한 파일

각도기는 실행하려면 다음 두 파일이 필요합니다-

사양 또는 테스트 파일

Protractor를 실행하는 데 중요한 파일 중 하나입니다. 이 파일에서 실제 테스트 코드를 작성합니다. 테스트 코드는 테스트 프레임 워크의 구문을 사용하여 작성됩니다.

예를 들어, 우리가 Jasmine 다음 구문을 사용하여 테스트 코드를 작성합니다. Jasmine. 이 파일에는 테스트의 모든 기능 흐름과 어설 션이 포함됩니다.

간단히 말해서이 파일에는 응용 프로그램과 상호 작용하는 논리 및 로케이터가 포함되어 있다고 말할 수 있습니다.

다음은 URL로 이동하여 페이지 제목을 확인하는 테스트 케이스가있는 간단한 스크립트 인 TestSpecification.js입니다.

//TestSpecification.js
describe('Protractor Demo', function() {
   it('to check the page title', function() {
      browser.ignoreSynchronization = true;
      browser.get('https://www.tutorialspoint.com/tutorialslibrary.htm');
      browser.driver.getTitle().then(function(pageTitle) {
         expect(pageTitle).toEqual('Free Online Tutorials and Courses');
      });
   });
});

코드 설명

위 사양 파일의 코드는 다음과 같이 설명 할 수 있습니다.

브라우저

모든 브라우저 수준 명령을 처리하기 위해 Protractor에서 만든 전역 변수입니다. 기본적으로 WebDriver 인스턴스를 둘러싼 래퍼입니다. browser.get ()은 Protractor에게 특정 페이지를로드하도록 지시하는 간단한 Selenium 메소드입니다.

  • describeit− 둘 다 Jasmine 테스트 프레임 워크의 구문입니다. 그만큼’Describe’ 테스트 케이스의 종단 간 흐름을 포함하는 데 사용되는 반면 ‘it’몇 가지 테스트 시나리오가 포함되어 있습니다. 우리는 여러‘it’ 테스트 케이스 프로그램의 블록.

  • Expect − 웹 페이지 제목을 미리 정의 된 데이터와 비교하는 주장입니다.

  • ignoreSynchronization− 앵글이 아닌 웹 사이트를 테스트 할 때 사용하는 브라우저의 태그입니다. 각도기는 각도 웹 사이트에서만 작동 할 것으로 예상하지만 각도가 아닌 웹 사이트로 작업하려면이 태그를 다음으로 설정해야합니다.“true”.

구성 파일

이름에서 알 수 있듯이이 파일은 모든 각도기 구성 옵션에 대한 설명을 제공합니다. 기본적으로 각도기에게 다음을 알려줍니다.

  • 테스트 또는 사양 파일을 찾을 수있는 위치
  • 선택할 브라우저
  • 사용할 테스트 프레임 워크
  • Selenium 서버와 대화 할 곳

다음은 간단한 스크립트 config.js입니다.

// config.js
exports.config = {
   directConnect: true,

   // Capabilities to be passed to the webdriver instance.
   capabilities: {
      'browserName': 'chrome'
   },

   // Framework to use. Jasmine is recommended.
   framework: 'jasmine',

   // Spec patterns are relative to the current working directory when
   // protractor is called.
   specs: ['TestSpecification.js'],

코드 설명

세 가지 기본 매개 변수가있는 위 구성 파일의 코드는 다음과 같이 설명 할 수 있습니다.

기능 매개 변수

이 매개 변수는 브라우저의 이름을 지정하는 데 사용됩니다. conf.js 파일의 다음 코드 블록에서 볼 수 있습니다.

exports.config = {
   directConnect: true,

   // Capabilities to be passed to the webdriver instance.
   capabilities: {
      'browserName': 'chrome'
},

위에서 볼 수 있듯이 여기에 제공된 브라우저의 이름은 Protractor의 기본 브라우저 인 'chrome'입니다. 브라우저 이름을 변경할 수도 있습니다.

프레임 워크 매개 변수

이 매개 변수는 테스트 프레임 워크의 이름을 지정하는 데 사용됩니다. config.js 파일의 다음 코드 블록에서 볼 수 있습니다.

exports.config = {
   directConnect: true,

   // Framework to use. Jasmine is recommended.
   framework: 'jasmine',

여기서는 'jasmine'테스트 프레임 워크를 사용합니다.

소스 파일 선언 매개 변수

이 매개 변수는 소스 파일 선언의 이름을 지정하는 데 사용됩니다. conf.js 파일의 다음 코드 블록에서 볼 수 있습니다.

exports.config = {
   directConnect: true,
   // Spec patterns are relative to the current working 
   directory when protractor is called.
   specs: ['TsetSpecification.js'],

위에서 볼 수 있듯이 여기에 제공된 소스 파일 선언의 이름은 다음과 같습니다. ‘TestSpecification.js’. 이 예에서는 이름이 지정된 사양 파일을 만들었 기 때문입니다.TestSpecification.js.

코드 실행

Protractor를 실행하는 데 필요한 파일과 해당 코딩에 대한 기본적인 이해를 얻었으므로 예제를 실행 해 보겠습니다. 이 예제를 실행하려면 다음 단계를 따르십시오.

  • Step 1 − 먼저 명령 프롬프트를 엽니 다.

  • Step 2 − 다음으로 config.js라는 파일을 저장 한 디렉토리로 이동해야합니다. TestSpecification.js.

  • Step 3 − 이제 Protrcator config.js 명령을 실행하여 config.js 파일을 실행합니다.

아래 스크린 샷은 위의 예제 실행 단계를 설명합니다.

스크린 샷에서 테스트가 통과되었음을 알 수 있습니다.

이제 각도가 아닌 웹 사이트를 테스트하고 ignoreSynchronization 태그를 true로 설정하지 않으면 코드를 실행 한 후 "Angular를 페이지에서 찾을 수 없습니다."라는 오류가 발생합니다.

다음 스크린 샷에서 볼 수 있습니다.

보고서 생성

지금까지 테스트 케이스를 실행하는 데 필요한 파일과 해당 코드에 대해 논의했습니다. 각도기는 또한 테스트 케이스에 대한 보고서를 생성 할 수 있습니다. 이를 위해 Jasmine을 지원합니다. JunitXMLReporter를 사용하여 테스트 실행 보고서를 자동으로 생성 할 수 있습니다.

그러나 그 전에 다음 명령을 사용하여 Jasmine reporter를 설치해야합니다.

npm install -g jasmine-reporters

보시다시피 Jasmine Reporters를 설치하는 동안 -g 옵션을 사용하는 것은 -g 옵션을 사용하여 Protractor를 전역 적으로 설치했기 때문입니다.

jasmine-reporters를 성공적으로 설치 한 후 이전에 사용한 config.js 파일에 다음 코드를 추가해야합니다.

onPrepare: function(){ //configure junit xml report

   var jasmineReporters = require('jasmine-reporters');
   jasmine.getEnv().addReporter(new jasmineReporters.JUnitXmlReporter({
      consolidateAll: true,
      filePrefix: 'guitest-xmloutput',
      savePath: 'test/reports'
   }));

이제 새로운 config.js 파일은 다음과 같습니다.

// An example configuration file.
exports.config = {
   directConnect: true,

   // Capabilities to be passed to the webdriver instance.
   capabilities: {
      'browserName': 'chrome'
   },

   // Framework to use. Jasmine is recommended.
   framework: 'jasmine',

   // Spec patterns are relative to the current working directory when
   // protractor is called.
   specs: ['TestSpecification.js'],
   //framework: "jasmine2", //must set it if you use JUnitXmlReporter

   onPrepare: function(){ //configure junit xml report

      var jasmineReporters = require('jasmine-reporters');
      jasmine.getEnv().addReporter(new jasmineReporters.JUnitXmlReporter({
         consolidateAll: true,
         filePrefix: 'guitest-xmloutput',
         savePath: 'reports'
      }));
   },
};

위의 구성 파일을 동일한 방식으로 실행 한 후 이전에 실행 한 다음 루트 디렉토리 아래에 보고서가 포함 된 XML 파일을 생성합니다. reports폴더. 테스트가 성공하면 보고서는 다음과 같습니다.

그러나 테스트에 실패하면 보고서는 다음과 같이 표시됩니다.