Automated Test Framework 디자인 고려사항

  • 릴리스 버전: Xanadu
  • 업데이트 날짜 2024년 08월 01일
  • 읽기5분
  • 다음 디자인 고려 사항에 따라 안정적이고 확장 가능하며 효율적인 테스트를 만듭니다.

    일반 테스트

    시스템의 동작을 잠재적으로 변경할 수 있는 애플리케이션 파일[sys_metadata]을 확장하는 시스템 테이블 또는 테이블을 수정 ServiceNow 하지 마십시오. 테스트 사이에 예기치 않은 결과가 발생하지 않도록 기존 기록을 사용하거나 수정하지 마십시오. 다음은 예기치 않은 결과를 초래할 수 있는 시스템 데이터 변경의 몇 가지 일반적인 예입니다.
    • 기존 계정으로 가장
    • 기존 기록을 삭제합니다.
    • 비즈니스 규칙 또는 시스템 속성을 비활성화하는 테스트 실행
    • 기존 기록으로 확인

    병렬 테스트

    여러 테스트와 테스트 도구 모음을 동시에 실행하여 테스트 설계 시간을 단축합니다. 리소스 충돌 및 데이터 종속성을 방지하여 병렬로 실행되도록 테스트를 디자인합니다.

    병렬 테스트 간의 리소스 충돌 방지

    자체 데이터를 생성하는 테스트를 실행하여 자원 충돌을 방지합니다. 기존 데이터로 실행되는 테스트는 동일한 데이터가 필요한 다른 테스트가 병렬로 실행되지 않도록 합니다.
    주:
    두 개 이상의 리소스 충돌 테스트가 있는 경우 병렬로 실행되지 않도록 하는 상호 제외 규칙을 만들려면을 참조하세요 테스트를 상호 배타적으로 표시 .

    매개변수화된 테스트

    각 실행에 대해 서로 다른 테스트 데이터를 사용하여 테스트를 여러 번 실행합니다. 각 테스트 실행에 대한 테스트 데이터를 저장할 매개 변수를 만듭니다. 자세한 내용은 을 참조하십시오 매개변수화된 테스트 구성요소 .
    • 각 테스트 실행에 대한 테스트 데이터를 저장할 매개 변수를 만듭니다.
    • 매개변수화된 테스트가 보고서, 테스트 도구 모음 및 데이터 롤백과 같은 표준 ATF(Automated Test Framework) 기능을 지원하는지 확인합니다. 매개변수화된 테스트를 복사하면 모든 매개변수, 테스트 실행 데이터 세트 및 테스트 단계가 복사됩니다.
      주:
      사용자 지정 UI 테스트 단계를 포함하여 매개변수화된 테스트가 생성되면 시스템은 첫 번째 데이터 세트만 사용하여 구성요소를 검색합니다.

    사용자 지정 UI 테스트

    HTML 및 JavaScript 페이지 구성요소를 검색하고 지원하는 테스트 작업을 식별하여 UI 페이지 및 UI 매크로와 같은 사용자 지정 사용자 인터페이스를 테스트합니다.

    페이지 검사기를 사용하여 테스트 가능한 페이지 구성요소 식별
    페이지 검사기는 사용자 지정 UI 테스트에 사용할 수 있는 페이지 구성 요소를 결정합니다. 페이지 검사기에서 사용할 수 없는 페이지 구성 요소는 사용자 지정 UI 테스트에 사용할 수 없습니다.
    테스트할 사용자 지정 UI로 이동합니다
    기존 테스트 단계를 사용하여 대상 사용자 지정 UI로 이동합니다. 예를 들어, 지식베이스 문서를 테스트하려면 기존 테스트 단계를 사용하여 모듈로 이동하거나 기존 기록을 엽니다. 대부분의 사용자 지정 UI 테스트를 하려면 테스트의 일부로 기존 테스트 단계 범주를 사용해야 합니다.
    구성요소 영역을 사용하여 페이지 구성요소 식별
    구성 요소 영역에서는 또는 <section> 요소와 같은 <div> 구성 요소를 포함하는 HTML 레이아웃 요소에 대해 설명합니다. 이 영역은 테스트 디자이너가 페이지 레이아웃에서 위치를 제공하여 구성 요소를 구별하는 데 도움이 됩니다.
    UI가 아닌 Now Platform 사용자 지정 UI 테스트
    기능의 Automated Test FrameworkNow Platform 사용자 지정 UI 테스트를 방지합니다. 예를 들어 대시보드나 그래픽 디자이너는 테스트할 수 없습니다. 대신 이러한 사용자 인터페이스를 직접 제어할 수 있으므로 사용자 지정 UI 페이지와 요소의 유효성을 검사하는 테스트를 빌드합니다.
    HTML 속성을 사용하여 페이지 구성요소 테스트 속성을 재정의합니다.
    에 특정한 Automated Test FrameworkHTML 속성을 사용하여 특정 페이지 구성 요소의 테스트 속성을 변경합니다. 구성요소 테스트 작업 재정의 문서를 참조하십시오.
    테스트를 다른 인스턴스로 이동할 때 페이지 구성 요소를 다시 검색합니다.
    사용자 지정 UI 테스트 단계는 UI 구성요소를 메타데이터로 저장하지 않습니다. 테스터는 인스턴스 간에 테스트를 이동할 때 페이지 구성 요소를 수동으로 다시 검색해야 합니다.

    프로덕션 시스템에서 테스트 클론

    테스트를 프로덕션 시스템으로 이동하여 테스트를 위해 가장 업데이트된 인스턴스를 복제합니다. 프로덕션 시스템에서 하위 프로덕션 인스턴스로 테스트를 직접 복사하거나 복제하여 테스트 시간을 단축합니다.

    주:
    실수로 운영 시스템에서 이러한 테스트를 실행하는 경우를 방지하기 위해 자동화된 테스트 실행에 사용되는 시스템 속성은 기본적으로 비활성화되어 있습니다. 데이터 손상 또는 중단을 방지하려면 개발, 테스트, 기타 비프로덕션 인스턴스에서만 테스트를 실행하십시오.

    모든 테스트에 대한 경고 메시지

    경고 메시지 디자인 고려 사항
    기존 사용자를 가장하면 이 테스트에 예기치 않은 동작이 발생할 수 있습니다. 대신 "사용자 생성" 단계를 추가하여 잠재적인 문제를 방지합니다. 테스트 설계 고려 사항에 대한 설명서를 참조하십시오. 적절한 역할과 그룹을 확보하고 기존 기록을 사용하지 않도록 새 사용자를 생성합니다. 자세한 내용은 일반 테스트 문서를 참조하십시오.
    응용 프로그램 파일 [sys_metadata]을 확장하는 테이블을 사용하면 병렬로 실행되는 다른 테스트에 예기치 않은 동작이 발생할 수 있습니다. 테스트 설계 고려 사항에 대한 설명서를 참조하십시오. 응용 프로그램 파일을 확장하는 테이블로 테스트를 실행하면 다른 테스트에 영향을 줄 수 있으므로 실행하지 마십시오. 자세한 내용은 병렬 테스트 문서를 참조하십시오.
    시스템 테이블을 사용하면 병렬로 실행되는 다른 테스트에 예기치 않은 동작이 발생할 수 있습니다. 테스트 설계 고려 사항에 대한 설명서를 참조하십시오. 시스템 테이블은 병렬로 실행되는 다른 테스트에 영향을 줄 수 있으므로 사용하지 마십시오. 자세한 내용은 병렬 테스트 문서를 참조하십시오.
    기존 기록을 사용하면 이 테스트에 예기치 않은 동작이 발생할 수 있습니다. 테스트 설계 고려 사항에 대한 설명서를 참조하십시오. 기존 기록에는 테스트에서 예상한 상태와 값이 없을 수 있으므로 기존 기록을 사용하지 마십시오. 테스트 중에 생성된 기록을 사용하여 적절한 상태와 값을 확인합니다. 자세한 내용은 일반 테스트 문서를 참조하십시오.
    기존 기록을 수정하면 병렬로 실행되는 다른 테스트에 예기치 않은 동작이 발생할 수 있습니다. 테스트 설계 고려 사항에 대한 설명서를 참조하십시오. 기존 레코드를 사용하면 다른 테스트에 영향을 줄 수 있으므로 사용하지 마십시오. 테스트 중에 생성된 기록을 사용합니다. 자세한 내용은 일반 테스트 문서를 참조하십시오.
    어설션 유형 '--없음--'을 사용하면 서버 UI 작업에 예기치 않은 동작이 발생할 수 있습니다. 어설션 유형을 설정하고 시간 제한을 사용하여 잠재적인 문제를 방지합니다. 테스트 설계 고려 사항에 대한 설명서를 참조하십시오. 서버 UI 작업으로 인해 현재 양식이 제출되고 페이지가 다시 로드됩니다. 서버 UI 동작에 예기치 않은 동작이 발생하지 않도록 하려면 없음 이외의 어설션 유형을 선택합니다. 다음 단계로 넘어가기 전에 테스트에서 양식이 제출되거나 제출되지 않을 때까지 대기하도록 시간 제한을 설정합니다. 서버 UI 동작을 테스트할 때 None 어설션 유형은 서버에 제출된 양식으로 자동으로 구성됩니다.

    도메인 분리 테스트

    도메인 분리를 테스트할 때는 도메인을 먼저 설정해야 합니다. 이는 설정되는 도메인에 종속된 경우 각 ATF 테스트 단계의 첫 번째 가장 단계의 일부여야 합니다. 도메인 분리 권장 사례에 대한 자세한 내용은 서비스 제공자를 위한 도메인 분리 권장 사례를 참조하세요.