오늘 Google에서는 웹 앱 테스트 및 자동화 사용 사례를 대상으로 하는 새로운 Chrome 버전인 Chrome for Testing을 발표하게 되어 기쁩니다. 이 도움말에서는 Chrome팀에서 이 작업이 필요하다고 생각하는 이유를 설명하고 Chrome for Testing이 개발자에게 도움이 될 수 있는 구체적인 예를 살펴봅니다.
배경
브라우저 테스트는 고품질 웹 환경을 만드는 데 있어 필수적인 구성 요소입니다. 수동이든 자동으로 수행되든 관계없습니다. 동시에 적절한 브라우저 테스트 환경을 설정하는 것은 매우 어려우므로 주요 웹 개발자의 고충으로 일관되게 보고됩니다. 오늘은 이러한 고충을 덜어줄 수 있는 변경 사항을 발표합니다.
자동 업데이트: 사용자에게는 유용하지만 개발자에게는 골치 아픈 문제
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 for Testing을 만들기 위해 Chromium 및 Chrome 코드베이스에 변경사항을 적용했으며, 모든 채널 (안정화, 베타, 개발자, Canary)의 Chrome 출시 프로세스에 따라 이러한 바이너리를 빌드하고 공개적으로 사용 가능한 버킷에 업로드할 수 있도록 인프라를 설정했습니다.
Chrome for Testing의 인프라는 Chrome 그 이상의 흥미로운 기회를 열어줍니다. 예를 들어 이전에 언급한 Chrome 및 ChromeDriver 바이너리를 찾는 데 따르는 어려움을 ChromeDriver 출시 프로세스를 Chrome for Testing 인프라에 통합하면 완전히 없앨 수 있습니다. 이를 통해 사용자가 겪는 이러한 문제를 해결할 뿐만 아니라 ChromeDriver 출시 버전을 Chrome의 버전과 일치시키고 수동으로 ChromeDriver 출시 프로세스를 없앱니다.
Chrome for Testing 바이너리는 어떻게 구할 수 있나요?
플랫폼에 맞는 Chrome for Testing 바이너리를 다운로드하는 가장 쉬운 방법은 npm
를 통해 제공되는 @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 [email protected]
# 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 [email protected]
이러한 바이너리를 다운로드하기 위해 자체 자동 스크립트를 빌드하고 싶은 경우, 저희가 도와드리겠습니다. Google에서는 Chrome 출시 채널 (공개, 베타, 개발자, Canary)별로 사용 가능한 최신 버전이 포함된 JSON API 엔드포인트를 제공합니다. 최신 상태에 관한 간략한 개요는 Chrome for Testing 사용 가능 여부 대시보드를 참고하세요.