Chrome for Testing: 브라우저 자동화를 위한 안정적인 다운로드

오늘은 웹 앱 테스트 및 자동화 사용 사례를 특별히 타겟팅하는 새로운 Chrome 버전인 Chrome for Testing을 발표하게 되어 기쁩니다. 이 도움말에서는 Chrome 팀이 이 기능이 필요하다고 생각한 이유를 설명하고, 테스트용 Chrome이 개발자에게 도움이 될 수 있는 구체적인 예를 살펴봅니다.

배경

브라우저 테스트는 수동으로든 자동으로든 고품질 웹 환경을 만드는 데 있어 중요한 구성요소입니다. 동시에 적절한 브라우저 테스트 환경을 설정하는 것은 매우 어려워 지속적으로 웹 개발자의 주요 문제로 보고됩니다. 오늘은 이러한 불편함을 다소 완화할 수 있는 변경사항을 발표합니다.

자동 업데이트: 사용자에게는 좋지만 개발자에게는 고통

Chrome의 가장 주목할 만한 기능 중 하나는 자동 업데이트 기능입니다. 사용자는 최신 보안 브라우저 버전을 항상 실행하고 있다는 사실을 알게 되어 기뻐합니다. 여기에는 최신 웹 플랫폼 기능, 브라우저 기능, 버그 수정이 포함됩니다.

하지만 엔드 투 엔드 테스트 모음을 실행하는 개발자는 완전히 다른 관점을 가질 수 있습니다.

  • 반복되는 테스트 실행에서 일관되고 재현 가능한 결과를 원하지만 브라우저 실행 파일이나 바이너리가 두 실행 사이에 자체 업데이트를 결정하면 이러한 결과가 발생하지 않을 수 있습니다.
  • 특정 브라우저 버전을 고정하고 해당 버전 번호를 소스 코드 저장소에 체크인하여 이전 커밋과 브랜치를 체크아웃하고 해당 시점의 브라우저 바이너리에 대해 테스트를 다시 실행할 수 있습니다.

자동 업데이트 브라우저 바이너리로는 이 중 어떤 것도 불가능합니다. 따라서 자동 테스트에는 일반 Chrome 설치를 사용하지 않는 것이 좋습니다. 이는 일반 브라우저 사용자에게 적합한 것과 자동 테스트를 실행하는 개발자에게 적합한 것 간의 근본적인 불일치입니다.

버전이 지정된 브라우저 바이너리

자동 업데이트 외에도 특정 버전의 Chrome 바이너리를 찾기 어려웠을 수도 있습니다. 사용자는 버전 번호에 신경 쓰지 않아도 되며 가능한 한 빨리 최신 버전으로 업데이트되어야 하므로 Google에서는 의도적으로 버전이 지정된 Chrome 다운로드를 제공하지 않습니다. 이는 사용자에게는 좋지만 이전 Chrome 버전에서 버그 신고를 재현해야 하는 개발자에게는 고통스럽습니다.

이 문제의 더 구체적인 예는 브라우저 자동화에 ChromeDriver를 사용하려는 경우입니다. Chrome 바이너리를 다운로드해야 할 뿐만 아니라 두 바이너리가 호환되도록 해당 버전의 ChromeDriver 바이너리도 필요합니다.

이러한 문제를 해결할 좋은 방법이 없기 때문에 많은 개발자가 이 접근 방식에 몇 가지 결함이 있음에도 불구하고 Chrome이 아닌 Chromium 바이너리를 다운로드하는 것으로 알고 있습니다. 첫째, 이러한 Chromium 바이너리는 모든 플랫폼에서 안정적으로 사용할 수 없습니다. 둘째, Chrome 출시 프로세스와 별도로 빌드되고 게시되므로 버전을 실제 사용자 대상 Chrome 출시에 다시 매핑할 수 없습니다. 셋째, Chromium은 Chrome과 다릅니다.

솔루션: Chrome for Testing

이러한 문제를 해결하기 위해 설계된 Chrome for Testing은 테스트 사용 사례를 타겟팅하는 전용 Chrome 버전으로, 자동 업데이트가 없으며 Chrome 출시 프로세스에 통합되어 모든 Chrome 출시에서 사용할 수 있습니다. 테스트 사용 사례에 부정적인 영향을 미치지 않으면서 일반 Chrome에 최대한 가까운 버전이 지정된 바이너리

테스트용 Chrome을 만들기 위해 Chromium 및 Chrome 코드베이스를 변경하고 모든 채널 (안정화 버전, 베타, 개발자, Canary)에서 Chrome 출시 프로세스와 동시에 이러한 바이너리를 공개적으로 제공되는 버킷에 빌드하고 업로드하는 인프라를 설정했습니다.

Chrome for Testing을 둘러싼 인프라를 통해 Chrome 자체를 넘어 흥미로운 기회를 활용할 수 있습니다. 예를 들어 이전에 언급한 일치하는 Chrome 및 ChromeDriver 바이너리를 찾는 데 따르는 어려움은 ChromeDriver 출시 프로세스를 Chrome for Testing 인프라에 통합하여 완전히 해결할 수 있습니다. 이 사용자 대상 문제점을 해결하는 것 외에도 ChromeDriver 출시가 Chrome과 일치하게 되고 수동 ChromeDriver 출시 프로세스가 삭제됩니다.

테스트용 Chrome 바이너리는 어떻게 받을 수 있나요?

플랫폼용 Chrome for Testing 바이너리를 다운로드하는 가장 쉬운 방법은 npm을 통해 제공되는 Google의 @puppeteer/browsers 명령줄 유틸리티를 사용하는 것입니다. 예를 들면 다음과 같습니다.

# Download the latest available Chrome for Testing binary corresponding to the Stable channel.
npx @puppeteer/browsers install chrome@stable

# Download a specific Chrome for Testing version.
npx @puppeteer/browsers install chrome@116.0.5793.0

# Download the latest available ChromeDriver version corresponding to the Canary channel.
npx @puppeteer/browsers install chromedriver@canary

# Download a specific ChromeDriver version.
npx @puppeteer/browsers install chromedriver@116.0.5793.0

이러한 바이너리를 다운로드하기 위한 자동 스크립트를 직접 빌드하려는 경우에도 지원해 드립니다. Chrome 출시 채널 (안정화 버전, 베타, 개발자, Canary)별로 사용 가능한 최신 버전이 포함된 JSON API 엔드포인트가 제공됩니다. 최신 상태를 빠르게 확인하려면 테스트용 Chrome 사용 가능 여부 대시보드를 참고하세요.