"일꾼이 일을 잘하려면 먼저 도구를 갈고 닦아야 한다." - 공자, 『논어』.
첫 장 > 프로그램 작성 > Cypress의 모킹(Mocking) 및 스터빙(Stubbing) 마스터하기: 종합 가이드

Cypress의 모킹(Mocking) 및 스터빙(Stubbing) 마스터하기: 종합 가이드

2024-07-31에 게시됨
검색:652

Mastering Mocking and Stubbing in Cypress: A Comprehensive Guide

소개

종단 간 테스트의 경우 외부 종속성을 제어하면 테스트의 안정성과 속도를 크게 향상시킬 수 있습니다. 최신 웹 테스트 프레임워크인 Cypress는 HTTP 요청을 조롱하고 스터빙하는 강력한 기능을 제공하므로 실제 백엔드 서비스에 의존하지 않고도 다양한 시나리오를 시뮬레이션할 수 있습니다. 이 게시물에서는 테스트를 더욱 강력하고 효율적으로 만들기 위해 API 호출 모킹 및 스터빙에 Cypress의 cy.intercept()를 활용하는 방법을 살펴보겠습니다.

왜 조롱하고 스터빙하는가?

Cypress의 HTTP 요청 모의 및 스텁은 다음과 같은 여러 이점을 제공합니다.

  1. 격리: 백엔드와 독립적으로 프런트엔드를 테스트하여 테스트가 백엔드 변경이나 중단으로 인해 영향을 받지 않도록 합니다.
  2. 속도: 실제 네트워크 호출을 방지하여 테스트 실행 시간을 줄입니다.
  3. 신뢰성: 다양한 응답과 극단적인 사례를 시뮬레이션하여 예측 가능하고 일관된 테스트 조건을 만듭니다.
  4. 유연성: 백엔드 변경 없이 오류, 느린 응답, 다양한 데이터 페이로드 등 다양한 시나리오를 테스트하세요.

Cypress 설정

아직 Cypress를 설치하지 않았다면 다음 명령을 사용하여 설정할 수 있습니다.

npm install cypress --save-dev
npx cypress open

진행하기 전에 기본 Cypress 프로젝트 구조가 준비되어 있는지 확인하세요.

cy.intercept() 사용하기

Cypress의 cy.intercept() 명령을 사용하면 네트워크 요청과 응답을 가로채고 수정할 수 있습니다. 더 이상 사용되지 않는 cy.route() 명령을 대체하고 더 많은 유연성과 성능을 제공합니다.

기본 예
API 응답을 모의하는 기본 예제부터 시작해 보겠습니다.

// cypress/integration/mock_basic.spec.js
describe('Mocking API Responses', () => {
  it('should display mocked data', () => {
    cy.intercept('GET', '/api/todos', {
      statusCode: 200,
      body: [
        { id: 1, title: 'Mocked Todo 1', completed: false },
        { id: 2, title: 'Mocked Todo 2', completed: true }
      ]
    }).as('getTodos');

    cy.visit('/todos');
    cy.wait('@getTodos');

    cy.get('.todo').should('have.length', 2);
    cy.get('.todo').first().should('contain.text', 'Mocked Todo 1');
  });
});

이 예에서는 /api/todos에 대한 GET 요청을 가로채고 모의 응답을 제공합니다. as('getTodos')는 가로채는 요청에 별칭을 할당하여 테스트에서 더 쉽게 참조할 수 있도록 합니다.

고급 모의 시나리오

오류 시뮬레이션
다양한 HTTP 오류 상태를 시뮬레이션하여 애플리케이션이 이를 처리하는 방법을 테스트할 수 있습니다.

// cypress/integration/mock_errors.spec.js
describe('Simulating API Errors', () => {
  it('should display error message on 500 response', () => {
    cy.intercept('GET', '/api/todos', {
      statusCode: 500,
      body: { error: 'Internal Server Error' }
    }).as('getTodosError');

    cy.visit('/todos');
    cy.wait('@getTodosError');

    cy.get('.error-message').should('contain.text', 'Failed to load todos');
  });
});

응답 지연
애플리케이션이 느린 네트워크 응답을 어떻게 처리하는지 테스트하려면 지연을 도입할 수 있습니다.

// cypress/integration/mock_delays.spec.js
describe('Simulating Slow Responses', () => {
  it('should display loading indicator during slow response', () => {
    cy.intercept('GET', '/api/todos', (req) => {
      req.reply((res) => {
        res.delay(2000); // 2-second delay
        res.send({ body: [] });
      });
    }).as('getTodosSlow');

    cy.visit('/todos');
    cy.get('.loading').should('be.visible');
    cy.wait('@getTodosSlow');
    cy.get('.loading').should('not.exist');
  });
});

특정 시나리오 조롱

조건부 조롱
요청 본문이나 헤더를 기반으로 조건부로 응답을 모의할 수 있습니다.

// cypress/integration/mock_conditional.spec.js
describe('Conditional Mocking', () => {
  it('should mock response based on request body', () => {
    cy.intercept('POST', '/api/todos', (req) => {
      if (req.body.title === 'Special Todo') {
        req.reply({
          statusCode: 201,
          body: { id: 999, title: 'Special Todo', completed: false }
        });
      }
    }).as('createTodo');

    cy.visit('/todos');
    cy.get('input[name="title"]').type('Special Todo');
    cy.get('button[type="submit"]').click();

    cy.wait('@createTodo');
    cy.get('.todo').should('contain.text', 'Special Todo');
  });
});

모킹 및 스터빙 모범 사례

  1. 별칭 사용: 항상 .as()를 사용하여 가로채는 요청에 별칭을 할당합니다. 이렇게 하면 테스트를 더 읽기 쉽고 디버깅하기가 더 쉬워집니다.
  2. Fixture와 결합: 더 나은 유지 관리 및 가독성을 위해 큰 모의 데이터를 Fixture 파일에 저장합니다. Fixture를 로드하려면 cy.fixture()를 사용하세요.
  3. 과도한 조롱을 피하세요: 테스트에 필요한 것만 조롱하세요. 과도한 모의는 실제 시나리오를 반영하지 않는 테스트로 이어질 수 있습니다.
  4. 실제 API 호출 테스트: 실제 백엔드에 대해 주기적으로 테스트하여 애플리케이션이 실제 데이터와 올바르게 작동하는지 확인하세요.

결론

Cypress의 모의 및 스터빙은 테스트를 더 빠르고 안정적이며 유지 관리하기 쉽게 만들 수 있는 강력한 기술입니다. HTTP 요청을 가로채고 사용자 지정 응답을 제공함으로써 외부 서비스에 의존하지 않고도 광범위한 테스트 시나리오를 만들 수 있습니다. Cypress 테스트에서 모킹 및 스터빙을 마스터하려면 이 가이드에 제공된 모범 사례와 예제를 따르세요.

즐거운 테스트를 진행하세요!

릴리스 선언문 이 기사는 https://dev.to/aswani25/mastering-mocking-and-stubbing-in-cypress-a-comprehensive-guide-3028?1에 복제되어 있습니다. 침해 사항이 있는 경우, [email protected]으로 문의하시기 바랍니다. 그것을 삭제하려면
최신 튜토리얼 더>
  • 제로에서 웹 개발자로 전환: PHP의 기초 익히기
    제로에서 웹 개발자로 전환: PHP의 기초 익히기
    PHP의 기본을 마스터하는 것은 필수입니다. PHP 설치 PHP 파일 만들기 코드 실행 변수 및 데이터 유형 이해 표현식 및 연산자 사용 기술 향상을 위한 실제 프로젝트 만들기 PHP 개발 시작하기: PHP 기본 익히기PHP는 동적 및 대화형 웹 애플리케이션을 만들...
    프로그램 작성 2024-11-05에 게시됨
  • 버퍼: Node.js
    버퍼: Node.js
    Node.js의 버퍼에 대한 간단한 가이드 Node.js의 버퍼는 원시 바이너리 데이터를 처리하는 데 사용되며, 이는 스트림, 파일 또는 네트워크 데이터로 작업할 때 유용합니다. 버퍼를 만드는 방법 문자열에서: const buf = ...
    프로그램 작성 2024-11-05에 게시됨
  • Node.js의 버전 관리 마스터하기
    Node.js의 버전 관리 마스터하기
    개발자로서 우리는 다양한 Node.js 버전을 요구하는 프로젝트를 자주 접하게 됩니다. 이 시나리오는 Node.js 프로젝트에 정기적으로 참여하지 않는 신규 개발자와 숙련된 개발자 모두에게 함정입니다. 즉, 각 프로젝트에 올바른 Node.js 버전이 사용되는지 확인하는...
    프로그램 작성 2024-11-05에 게시됨
  • 문제 해결을 위해 Go 바이너리에 Git 개정 정보를 포함하는 방법은 무엇입니까?
    문제 해결을 위해 Go 바이너리에 Git 개정 정보를 포함하는 방법은 무엇입니까?
    Go 바이너리에서 Git 개정 확인코드를 배포할 때 바이너리를 빌드된 Git 개정과 연결하는 것이 도움이 될 수 있습니다. 문제 해결 목적. 그러나 개정 번호로 소스 코드를 직접 업데이트하는 것은 소스를 변경하므로 불가능합니다.해결책: 빌드 플래그 활용이 문제에 대한 ...
    프로그램 작성 2024-11-05에 게시됨
  • 일반적인 HTML 태그: 관점
    일반적인 HTML 태그: 관점
    HTML(HyperText Markup Language)은 웹 개발의 기초를 형성하며 인터넷의 모든 웹페이지 구조 역할을 합니다. 2024년 가장 일반적인 HTML 태그와 고급 용도를 이해함으로써 개발자는 보다 효율적이고 접근 가능하며 시각적으로 매력적인 웹 페이지를 ...
    프로그램 작성 2024-11-05에 게시됨
  • CSS 미디어 쿼리
    CSS 미디어 쿼리
    웹사이트가 다양한 기기에서 원활하게 작동하도록 보장하는 것이 그 어느 때보다 중요합니다. 사용자가 데스크톱, 노트북, 태블릿, 스마트폰에서 웹사이트에 액세스함에 따라 반응형 디자인이 필수가 되었습니다. 반응형 디자인의 중심에는 개발자가 사용자 기기의 특성에 따라 다양한...
    프로그램 작성 2024-11-05에 게시됨
  • JavaScript의 호이스팅 이해: 종합 가이드
    JavaScript의 호이스팅 이해: 종합 가이드
    자바스크립트에서 호이스팅 호이스팅은 변수 및 함수 선언을 포함 범위(전역 범위 또는 함수 범위)의 맨 위로 이동(또는 "호이스팅")하는 동작입니다. 코드가 실행됩니다. 즉, 코드에서 실제로 선언되기 전에 변수와 함수를 사용할 수 있습니...
    프로그램 작성 2024-11-05에 게시됨
  • Stripe를 단일 제품 Django Python Shop에 통합
    Stripe를 단일 제품 Django Python Shop에 통합
    In the first part of this series, we created a Django online shop with htmx. In this second part, we'll handle orders using Stripe. What We'll...
    프로그램 작성 2024-11-05에 게시됨
  • Laravel에서 대기 중인 작업을 테스트하기 위한 팁
    Laravel에서 대기 중인 작업을 테스트하기 위한 팁
    Laravel 애플리케이션으로 작업할 때 명령이 비용이 많이 드는 작업을 수행해야 하는 시나리오를 접하는 것이 일반적입니다. 기본 프로세스를 차단하지 않으려면 대기열에서 처리할 수 있는 작업으로 작업을 오프로드하기로 결정할 수 있습니다. 예제를 살펴보겠습니다. app:...
    프로그램 작성 2024-11-05에 게시됨
  • 인간 수준의 자연어 이해(NLU) 시스템을 만드는 방법
    인간 수준의 자연어 이해(NLU) 시스템을 만드는 방법
    Scope: Creating an NLU system that fully understands and processes human languages in a wide range of contexts, from conversations to literature. ...
    프로그램 작성 2024-11-05에 게시됨
  • JSTL을 사용하여 HashMap 내에서 ArrayList를 반복하는 방법은 무엇입니까?
    JSTL을 사용하여 HashMap 내에서 ArrayList를 반복하는 방법은 무엇입니까?
    JSTL을 사용하여 HashMap 내에서 ArrayList 반복웹 개발에서 JSTL(JavaServer Pages Standard Tag Library)은 JSP( 자바 서버 페이지). 그러한 작업 중 하나는 데이터 구조를 반복하는 것입니다.HashMap과 그 안에 포...
    프로그램 작성 2024-11-05에 게시됨
  • Encore.ts — ElysiaJS 및 Hono보다 빠릅니다.
    Encore.ts — ElysiaJS 및 Hono보다 빠릅니다.
    몇 달 전 우리는 TypeScript용 오픈 소스 백엔드 프레임워크인 Encore.ts를 출시했습니다. 이미 많은 프레임워크가 있으므로 우리는 우리가 내린 흔하지 않은 디자인 결정과 그것이 어떻게 놀라운 성능 수치로 이어지는지 공유하고 싶었습니다. 성능 ...
    프로그램 작성 2024-11-05에 게시됨
  • 문자열 리터럴에서 +를 사용한 문자열 연결이 실패하는 이유는 무엇입니까?
    문자열 리터럴에서 +를 사용한 문자열 연결이 실패하는 이유는 무엇입니까?
    문자열 리터럴을 문자열과 연결C에서는 연산자를 사용하여 문자열과 문자열 리터럴을 연결할 수 있습니다. 그러나 이 기능에는 혼란을 초래할 수 있는 제한 사항이 있습니다.질문에서 작성자는 문자열 리터럴 "Hello", ",world" 및...
    프로그램 작성 2024-11-05에 게시됨
  • React Re-Rendering: 최적의 성능을 위한 모범 사례
    React Re-Rendering: 최적의 성능을 위한 모범 사례
    React의 효율적인 렌더링 메커니즘은 React가 인기를 얻는 주요 이유 중 하나입니다. 그러나 애플리케이션이 복잡해짐에 따라 구성 요소 다시 렌더링을 관리하는 것이 성능을 최적화하는 데 중요해졌습니다. React의 렌더링 동작을 최적화하고 불필요한 재렌더링을 방지하...
    프로그램 작성 2024-11-05에 게시됨
  • 조건부 열 생성을 달성하는 방법: Pandas DataFrame에서 If-Elif-Else 탐색?
    조건부 열 생성을 달성하는 방법: Pandas DataFrame에서 If-Elif-Else 탐색?
    조건부 열 생성: Pandas의 If-Elif-Else주어진 문제에서는 DataFrame에 새 열을 추가해야 합니다. 일련의 조건부 기준을 기반으로 합니다. 문제는 코드 효율성과 가독성을 유지하면서 이러한 조건을 구현하는 것입니다.함수 적용을 사용한 솔루션한 가지 접근...
    프로그램 작성 2024-11-05에 게시됨

부인 성명: 제공된 모든 리소스는 부분적으로 인터넷에서 가져온 것입니다. 귀하의 저작권이나 기타 권리 및 이익이 침해된 경우 자세한 이유를 설명하고 저작권 또는 권리 및 이익에 대한 증거를 제공한 후 이메일([email protected])로 보내주십시오. 최대한 빨리 처리해 드리겠습니다.

Copyright© 2022 湘ICP备2022001581号-3