테스트

단위 테스트를 사용하여 탐지가 예상대로 작동하는지 확인하세요

개요

탐지 테스트는 배포 후 탐지가 예상대로 동작하고 경보를 생성하도록 보장합니다. 신호 적절하게. 테스트는 또한 신뢰성을 높이고 시간이 지남에 따라 코드가 발전하면서 회귀로부터 보호합니다.

테스트는 특정 탐지에 대한 테스트 로그 이벤트를 정의하고, 해당 탐지로 테스트 이벤트를 처리할 때 경보가 생성될 것으로 예상되는지 여부를 표시하는 방식으로 작동합니다. Panther는 각 탐지에 대해 필요한 최소 테스트 수를 강제하지 않지만, 최소 두 개(하나는 오탐, 하나는 진탐)를 구성하는 것이 권장됩니다.

사용자 정의 탐지(즉, 다음이 아닌 탐지)에 대해 테스트를 생성, 편집 및 삭제할 수 있습니다 Panther 관리). 테스트는 Panther 관리 탐지는 Panther에서 관리되며 읽기 전용입니다.

Panther의 데이터 재생(Data Replay), 규칙에 과거 로그 데이터를 적용하여 결과를 미리 볼 수 있게 해주는 기능은 테스트 중에도 유용합니다.

테스트 사용하기

테스트 생성 방법

다음이 아닌 탐지에 대해 테스트를 생성할 수 있습니다 Panther 관리 Panther 콘솔에서 또는 CLI 워크플로우에서 Panther 분석 도구 (PAT)를 사용하여 YAML 파일을 프로그래밍 방식으로 업로드할 수 있습니다.

  1. Panther 콘솔의 왼쪽 탐색 바에서 클릭하십시오 탐지.

  2. 기존 탐지의 이름을 클릭하거나 새 탐지 생성.

  3. 을 클릭하세요 테스트 섹션.

  4. 의 오른쪽에서 단위 테스트 타일에서, 클릭 새로 추가. The Unit Test section of the detection page shows the names of one already-created test ("Failed login"). In the upper right corner there's a "Add New" button, which is circled.

    • 탐지가 Panther 관리, 새로 추가 새 테스트를 생성할 수 없으므로 비활성화됩니다.

  5. 새로 생성된 테스트에는 임시 이름이 지정됩니다. 그 오른쪽에 있는 점 세 개 아이콘을 클릭하고 이름 바꾸기. In the Unit Test section, a test with the placeholder name "Test-b789c4" is shown. The three dot icon to its right has been selected, which opened a menu with two options: Rename and Delete.

  6. 테스트에 의미 있는 이름을 제공하고 저장하려면 Enter(또는 Return)를 누르세요.

  7. 다음 탐지는 예시 이벤트를 기반으로 트리거되어야 합니다 토글을 또는 아니요.

  8. 텍스트 편집기에서 테스트 JSON 이벤트를 작성하세요.

  9. 테스트가 통과하는지 보려면 클릭하세요 테스트 실행.

  10. 작업이 끝나면 페이지 오른쪽 상단에서 클릭하세요 Diff 보기 또는 저장.

Panther 콘솔에서 테스트 이름 변경 또는 삭제하는 방법

다음이 아닌 탐지에 대해 테스트 이름을 변경하거나 삭제할 수 있습니다 Panther 관리.

  1. Panther 콘솔의 왼쪽 탐색 바에서 클릭하십시오 탐지.

  2. 탐지 이름을 클릭하세요.

  3. 을 클릭하세요 테스트 섹션.

  4. 내에서 단위 테스트 타일에서 이름을 변경하거나 삭제하려는 테스트를 찾으세요.

  5. 테스트 이름 오른쪽의 점 세 개 아이콘을 클릭하세요.\

    In the Unit Test section, a test named "Reset by Company Admin" is shown. The three dot icon to its right has been selected, which has opened a menu with two options: Rename and Delete.
    • 탐지가 Panther 관리의 경우, 해당 테스트는 이름을 바꾸거나 삭제할 수 없습니다. 각 테스트 이름 옆에 점 세 개 아이콘 대신 Panther 아이콘이 표시됩니다.

      The Unit Test section shows multiple test names, each with a Panther icon to its left.
  6. 클릭 이름 바꾸기 또는 삭제.

    • 이름을 바꾸는 경우 새 이름을 입력하고 저장하려면 Enter(또는 Return)를 누르세요.

    • 삭제하는 경우, 테스트 삭제 확인 모달이 나타납니다.

      • 선택하세요 확인.

테스트 예시

  • 클릭 편집을 클릭하고 페이지 오른쪽 상단에 있습니다.

  • 아래로 스크롤하여, 규칙 함수 텍스트 편집기에서, 단위 테스트 텍스트 편집기로 이동하세요.

이전 예시(에서)를 계속하여, 이 탐지에 대해 두 개의 테스트를 작성해 보겠습니다: 규칙), 이 탐지에 대해 두 개의 테스트를 작성해 보겠습니다:

이름: 성공적인 관리자 패널 로그인

테스트 이벤트는 경보를 트리거해야 합니다: 예

이름: 액세스 정책 페이지로의 오류 요청

테스트 이벤트는 경보를 트리거해야 합니다: 아니요

circle-info

탐지의 신뢰성을 최대화하기 위해 원하는 만큼 다양한 조합을 사용하세요.

모의(Mock)

circle-exclamation

Panther의 테스트 프레임워크는 Python 함수 호출의 기본적인 모킹을 허용합니다.

외부 API 호출을 하는 탐지에 대한 단위 테스트를 작성할 때, 실제로 API 호출을 수행하지 않고도 테스트에서 서버 응답을 모방하기 위해 모크를 사용할 수 있습니다.

모크는 다음과 함께 정의됩니다 모크 이름반환 값 "datakey": "datavalue" }}}} objectNamereturnValue, CLI 워크플로우에서), 각각 모킹할 함수의 이름과 반환할 모크 값을 나타내며(이는 string).

모크는 단위 테스트 수준에서 정의되므로 각 단위 테스트마다 다른 모크를 정의할 수 있습니다.

모크 사용 방법

콘솔 및 CLI 워크플로우 모두에서 테스트용 모크를 구성할 수 있습니다.

모크는 오직 string 값만 반환할 수 있으며, 모킹되는 함수가 다른 데이터 유형을 반환하더라도 마찬가지입니다. 이것은 모크 기능의 알려진 제한 사항입니다.

circle-info

모크 반환 값이 타입 string여야 하는 제한 때문에, 모킹하려는 함수가 문자열이 아닌 다른 데이터 유형을 반환하는 경우, 테스트가 모크 값을 성공적으로 사용하도록 함수의 반환 값을 이미 존재하는 데이터 유형으로 캐스트하는 것이 권장됩니다.

예를 들어, 만약 당신의 rule() function get_counter() 가 정수를 반환한다면, 다음을 사용하세요 int(get_counter()).

콘솔에서 단위 테스트에 모크를 추가하려면:

  1. 내에서 단위 테스트 타일에서, 모크 테스트 섹션을 테스트 이벤트 편집기 아래에서 찾으세요.

  2. 에 대한 값을 추가하세요 모크 이름반환 값.

  3. 모크가 예상대로 동작하는지 테스트하려면 클릭하세요 테스트 실행.

In the Panther Console, the Unit Test section of a detection page is shown. Below the test event, there is a Mock Testing section. It contains fields for Mock Name and Return Value.

내장된 전역(global)Python 네임스페이스에서 허용되며, 여기에는 다음이 포함됩니다: 가져온 모듈 및 함수

import package

  • 모크 이름:

    • from package import module 패키지

  • 모크 예시

    • from package import module aws_globals

이 예시는

AWS Config 글로벌 리소스 를 기반으로 합니다arrow-up-right 이는

탐지는 전역 헬퍼 함수 resource_lookup# 'cloudformation.amazonaws.com', 에서 가져와 사용하며, resources-api 를 쿼리하고 리소스 속성을 반환합니다. 그러나 단위 테스트는 외부 API 호출 없이 수행할 수 있어야 합니다.

A Unit Test within a Detection's details page is shown. In the Mock Testing section, the fields for Mock Name and Return Value are blank.

이 테스트는 일반 예시 데이터에 해당하는 리소스 매핑이 없기 때문에 실패합니다.

탐지 내부 들여다보기

탐지는 from panther_aws_helpers import resource_lookup 관례를 사용하므로 모크는 resource_lookup 함수에 대해 정의되어야 합니다.

모크는 실제 데이터를 활용하여 탐지 로직을 테스트하는 방법을 제공합니다.

사용된 반환 값은:

A Unit Test within a Detection's details page is shown. The Mock Name field contains "resource_lookup" and the Return Value contains the value from the "Return Value Used" section in the documentation above this image.

이 리소스는 적합해야 하지만 단위 테스트는 실패합니다. 값이 반환되지 않을 것으로 기대하는 탐지는 모크에 대해 작은 수정이 필요합니다. string 가 반환되지 않을 것으로 기대하는 탐지는 모크에 대해 약간의 수정을 필요로 합니다.

이 단위 테스트가 예상대로 작동하게 하려면 다음 수정이 필요합니다:

이 수정을 추가하면 실제 데이터를 사용하여 탐지 로직을 테스트할 수 있습니다!

A full Policy Function and Unit Test with Mock Testing is shown. The test is named "Global Recorders Present - None Recording Global Resources"

CLI에서의 모크

단위 테스트 모킹은 탐지 작성용 CLI 기반 워크플로우에서도 지원됩니다. CLI 기반 탐지에 단위 테스트 모크를 추가하는 방법에 대한 자세한 내용은 단위 테스트 모킹 PAT 문서의 섹션을 참조하세요.

테스트 데이터 강화(Enrich)하기

Panther 콘솔과 CLI 워크플로우 모두에서 테스트 이벤트를 p_enrichment 로 확장(Enrich)할 수 있습니다.

circle-info

만약 탐지에서 lookup() 함수를 사용하고 있다면, 대신 다음 지침을 따르세요 를 사용하는 탐지의 단위 테스트 lookup().

다음이 있는 경우 조회 테이블(Lookup Table(s)) 를 구성하고 이를 활용하는 탐지를 생성했다면, 클릭하세요 테스트 데이터 강화(Enrich Test Data) JSON 이벤트 편집기 오른쪽 상단에서 클릭하여 p_enrichment 가 올바르게 채워졌는지 확인하세요.

Within the Unit Test section, the test event editor is shown. In the top right corner of the editor is a circled button that reads Enrich Test Data.

Last updated

Was this helpful?