> 웹 프론트엔드 > JS 튜토리얼 > Playwright와 TypeScript, JavaScript를 사용한 자동화

Playwright와 TypeScript, JavaScript를 사용한 자동화

Mary-Kate Olsen
풀어 주다: 2024-10-24 04:50:01
원래의
1107명이 탐색했습니다.

TypeScript를 사용하는 극작가 | 자바스크립트 설치

Playwright는 Puppeteer 팀과 협력하여 Microsoft에서 제공하는 최신 웹 기반 API 자동화 도구입니다. Puppeteer는 DevTools 프로토콜 또는 WebDriver BiDi를 통해 Chrome 또는 Firefox를 제어할 수 있는 고급 API를 제공하는 JavaScript 라이브러리입니다. Puppeteer는 기본적으로 헤드리스(표시되는 UI 없음)에서 실행됩니다.

Playwright는 단일 API를 통해 웹 애플리케이션 자동화를 위한 최신 웹 기반 브라우저를 지원하며 API 자동화도 지원합니다.

극작가의 건축

Automation using Playwright and TypeScript and JavaScript

Playwright는 연결이 설정되면 웹 소켓 프로토콜에서 작동하며 테스트를 트리거하고 웹 소켓 프로토콜을 사용하여 JSON 형식의 요청을 서버에 보냅니다. 즉, Playwright가 연결을 설정하면 요청을 보내기 위해 연결을 다시 설정할 필요가 없습니다. 테스트 실행이 완료될 때까지 서버에 보관됩니다. 극작가는 playwright.quit() 메소드로 연결을 끊어야 합니다.

HTTP 프로토콜 연결 웹소켓 프로토콜 연결의 차이점을 알아봅시다

Automation using Playwright and TypeScript and JavaScript

WebSocket과 HTTP 프로토콜의 차이점
극작가의 특징 :
모든 브라우저 • 모든 플랫폼 • 하나의 API
크로스 브라우저. Playwright는 Chromium, WebKit, Firefox를 포함한 모든 최신 렌더링 엔진을 지원합니다.

크로스 플랫폼. Windows, Linux 및 macOS, 로컬 또는 CI(헤드리스 또는 헤드 없음)에서 테스트하세요.

언어 간. TypeScript, JavaScript, Python, .NET, Java에서 Playwright API를 사용하세요.

모바일 웹을 테스트해보세요. Android 및 모바일 Safari용 Google Chrome의 기본 모바일 에뮬레이션입니다. 동일한 렌더링 엔진이 데스크탑과 클라우드에서 작동합니다.

  1. 탄력성 • 불안정한 테스트 없음

자동 대기. 극작가는 작업을 수행하기 전에 요소가 실행 가능해질 때까지 기다립니다. 또한 다양한 자기 성찰 이벤트가 있습니다. 이 두 가지를 결합하면 불안정한 테스트의 주요 원인인 인위적인 시간 초과가 필요하지 않습니다.

웹 우선 어설션. 극작가 어설션은 동적 웹을 위해 특별히 생성되었습니다. 필요한 조건이 충족될 때까지 자동으로 검사가 재시도됩니다.

추적. 테스트 재시도 전략을 구성하고, 실행 추적, 비디오, 스크린샷을 캡처하여 플레이크를 제거합니다.

  1. 절충 없음 • 제한 없음

브라우저는 서로 다른 프로세스에서 서로 다른 출처에 속하는 웹 콘텐츠를 실행합니다. Playwright는 최신 브라우저 아키텍처에 맞춰 프로세스 외부에서 테스트를 실행합니다. 이를 통해 Playwright는 일반적인 진행 중인 테스트 실행기의 제한 사항에서 벗어날 수 있습니다.

다양한 것. 여러 탭, 여러 원본 및 여러 사용자를 포괄하는 테스트 시나리오입니다. 다양한 사용자를 위한 다양한 상황의 시나리오를 생성하고 이를 서버에 대해 한 번의 테스트로 실행해 보세요.

신뢰할 수 있는 이벤트. 요소를 가리키고, 동적 컨트롤과 상호 작용하고, 신뢰할 수 있는 이벤트를 생성합니다. Playwright는 실제 사용자와 구별할 수 없는 실제 브라우저 입력 파이프라인을 사용합니다.

프레임을 테스트하고 Shadow DOM을 뚫습니다. 극작가 선택기는 Shadow DOM을 관통하여 프레임을 원활하게 입력할 수 있도록 합니다.

  1. 완전 격리 • 빠른 실행

브라우저 컨텍스트. Playwright는 각 테스트에 대한 브라우저 컨텍스트를 만듭니다. 브라우저 컨텍스트는 새로운 브라우저 프로필과 동일합니다. 이는 오버헤드 없이 완전한 테스트 격리를 제공합니다. 새로운 브라우저 컨텍스트를 생성하는 데는 몇 밀리초밖에 걸리지 않습니다.

한 번 로그인해 보세요. 컨텍스트의 인증 상태를 저장하고 모든 테스트에서 재사용합니다. 이는 각 테스트에서 반복적인 로그인 작업을 우회하면서도 독립적인 테스트를 완전히 격리합니다.

  1. 강력한 도구

코드젠. 작업을 기록하여 테스트를 생성합니다. 원하는 언어로 저장하세요.

극작가 검사관. 페이지를 검사하고, 선택기를 생성하고, 테스트 실행을 단계별로 진행하고, 클릭 포인트를 확인하고, 실행 로그를 살펴보세요.

추적 뷰어. 테스트 실패를 조사하기 위해 모든 정보를 캡처합니다. Playwright 추적에는 테스트 실행 스크린캐스트, 라이브 DOM 스냅샷, 액션 탐색기, 테스트 소스 등이 포함되어 있습니다.

TypeScript/JavaScript와 함께 Playwright를 사용해 보겠습니다

TypeScript/JavaScript용 Playwright 설치
설치를 위한 전제조건은 다음과 같습니다: Node.js 18

Windows 10, Windows Server 2016 또는 Linux용 Windows 하위 시스템(WSL).
macOS 13 Ventura 또는 macOS 14 Sonoma.
x86–64 및 arm64 아키텍처의 Debian 11, Debian 12, Ubuntu 20.04 또는 Ubuntu 22.04, Ubuntu 24.04.
npm, Yarn 또는 pnpm을 사용하여 Playwright를 설치하여 시작하세요. 또는 VS Code 확장을 사용하여 테스트를 시작하고 실행할 수도 있습니다.

TypeScriptWithPlaywright와 같은 폴더를 만듭니다. 마찬가지로 JavaScriptwithPlaywright용 폴더를 만들고 폴더로 이동하여 창의 명령 프롬프트를 엽니다.

Automation using Playwright and TypeScript and JavaScript

극작가 설치
Enter를 클릭하면 다음 화면이 나타나고 스크립트 언어를 선택한 다음 Enter를 누르십시오

Automation using Playwright and TypeScript and JavaScript

스크립팅 언어 선택
스크립팅 언어를 선택한 후 Enter를 누르면 다음 화면이 나타나고 최종 테스트를 어디에 둘 것인지 묻습니다. 그렇게 해주세요.

극작가 설치
이제 GitHub Actions 워크플로를 요청합니다. 구성하려면 Y를 누르거나 그렇지 않으면 N을 누르십시오. 브라우저를 설치하라는 메시지가 표시됩니다. 설치하려면 Y를 선택하면 true를 의미합니다. 다음 화면이 나타납니다.

Automation using Playwright and TypeScript and JavaScript

참고: Playwright 브라우저는 아래 명령을 통해 수동으로 설치할 수 있습니다

Automation using Playwright and TypeScript and JavaScript

npx 극작가 설치

극작가 설치
이제 Enter를 누르면 다음 화면이 나타납니다.

Automation using Playwright and TypeScript and JavaScript

극작가 설치
극작가 설치

극작가 설치

극작가 설치 완료
Playwright는 기본적으로 헤드리스 모드에서 실행되는 테스트 스크립트를 실행하며 다음 명령은 특정 브라우저로 실행하고 디버그하며 codegen을 사용하여 테스트 스크립트를 생성합니다.

npx 극작가 테스트
엔드투엔드 테스트를 실행합니다.

npx 극작가 테스트 --ui
대화형 UI 모드를 시작합니다.

npx 극작가 테스트 --project=chromium
데스크톱 Chrome에서만 테스트를 실행합니다.

npx 극작가 테스트 예시
특정 파일에서 테스트를 실행합니다.

npx 극작가 테스트 --debug
디버그 모드에서 테스트를 실행합니다.

npx 극작가 코드젠
Codegen으로 테스트를 자동 생성하세요.

다음을 입력하여 시작하는 것이 좋습니다.

npx playwright test
로그인 후 복사
로그인 후 복사

이제 다음 명령을 사용하여 테스트 스크립트를 실행하고 보고서를 살펴보겠습니다. Playwright는 chromium, Firefox 및 WebKit에서 병렬로 테스트를 실행합니다.

npx 극작가 테스트

npx 극작가 쇼 보고서

Playwright 기본 보고서는 TypeScript/JavaScript만 지원합니다
Playwright는 기본적으로 헤드리스 모드를 사용하여 다음 브라우저에서 실행되도록 테스트 스크립트를 구성합니다. 구성은 playwright.config.js

라는 폴더에 표시됩니다.

'@playwright/test'에서 { 정의 구성, 장치 } 가져오기;

/**

  • 파일에서 환경 변수를 읽습니다.
  • https://github.com/motdotla/dotenv*/ // 'dotenv'에서 dotenv를 가져옵니다. // 'path'에서 경로를 가져옵니다. // dotenv.config({ 경로: path.resolve(__dirname, '.env') });

/**

  • https://playwright.dev/docs/test-configuration을 참조하세요.
    /
    기본 정의 내보내기({
    testDir: './tests',
    /
    파일에서 병렬로 테스트 실행 /
    완전히 병렬: true,
    /
    실수로 소스 코드에 test.only를 남겨둔 경우 CI 빌드가 실패합니다. /
    forbidOnly: !!process.env.CI,
    /
    CI에서만 재시도 /
    재시도: process.env.CI ? 2 : 0,
    /
    CI에 대한 병렬 테스트를 선택 해제합니다. /
    작업자: process.env.CI ? 1 : 정의되지 않음,
    /
    기자가 사용합니다. https://playwright.dev/docs/test-reporters /
    를 참조하세요. 기자: 'html',
    /
    아래 모든 프로젝트에 대한 공유 설정입니다. https://playwright.dev/docs/api/class-testoptions를 참조하세요. /
    사용: {
    /
    wait page.goto('/')와 같은 작업에 사용할 기본 URL입니다. */
    // 기본 URL: 'http://127.0.0.1:3000',

    /* 실패한 테스트를 재시도할 때 추적을 수집합니다. https://playwright.dev/docs/trace-viewer 참조 */
    추적: '첫 번째 재시도',
    },

/* 주요 브라우저용 프로젝트 구성 */
프로젝트: [
{
이름: '크롬',
사용: { ...devices['Desktop Chrome'] },
},

npx playwright test
로그인 후 복사
로그인 후 복사

],

/* 테스트를 시작하기 전에 로컬 개발 서버를 실행하세요 */
// 웹서버: {
// 명령: 'npm run start',
// URL: 'http://127.0.0.1:3000',
// 재사용ExistingServer: !process.env.CI,
// },
});
이제 헤드리스 모드(UI)가 아닌 테스트 스크립트를 실행하고 추가 브라우저를 추가하도록 수정해 보겠습니다. Playwright는 테스트 스크립트 실행을 기록하는 옵션과 디버깅에 유용한 추적 보기 옵션도 제공합니다. 추적 뷰어 옵션을 활성화하면 테스트 전 상태, 테스트 중 상태, 테스트 후 상태를 확인할 수 있습니다. 극작가 구성 파일을 수정했는데 아래와 같습니다.

// @ts-check
const { 정의구성, 장치 } = require('@playwright/test');

module.exports = 정의Config({
testDir: './tests',
완전히 병렬: true,
forbidOnly: !!process.env.CI,
재시도: process.env.CI ? 2 : 0,
작업자: process.env.CI ? 1 : 정의되지 않음,
기자: 'html',
사용: {
추적: 'on', // 추적 활성화
video: 'on', // 각 테스트에 대한 비디오 녹화
headless: false, // 헤드 모드에서 테스트 실행
},
프로젝트: [
{
이름: '크롬',
사용: { ...devices['Desktop Chrome'] },
},
{
이름: 'firefox',
사용: { ...devices['Desktop Firefox'] },
},
{
이름: '웹킷',
사용: { ...devices['Desktop Safari'] },
},
{
이름: 'Microsoft Edge',
사용: {
...장치['Desktop Edge'],
채널: 'msedge'
},
},
{
이름: 'Google 크롬',
사용: {
...장치['데스크톱 Chrome'],
채널: '크롬'
},
},
],
});
이제 테스트 스크립트는 기록, 추적 뷰어 옵션을 사용하여 헤드리스 모드가 아닌 구성 파일에 언급된 브라우저에서 테스트를 실행할 수 있습니다.

즐거운 학습!! 행복한 자동화 !! 즐거운 테스트

정보/질문이 있으시면 santoshvqa@gmail.com 및 LinkedIn 프로필로 언제든지 연락주세요

https://www.linkedin.com/in/santosh-kulkarni-ab571639/

위 내용은 Playwright와 TypeScript, JavaScript를 사용한 자동화의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:dev.to
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿