jMeter-정규식
정규식은 패턴을 기반으로 텍스트를 검색하고 조작하는 데 사용됩니다. JMeter는 패턴 일치 소프트웨어 Apache Jakarta ORO 를 포함하여 JMeter 테스트 계획 전체에서 사용되는 정규식 또는 패턴의 형태를 해석합니다 .
정규식을 사용하면 테스트 계획을 만들거나 향상시킬 때 확실히 많은 시간을 절약하고 더 큰 유연성을 얻을 수 있습니다. 정규식은 결과를 예측하는 것이 불가능하거나 매우 어려울 때 페이지에서 정보를 가져 오는 간단한 방법을 제공합니다.
표현식 사용의 표준 사용 예는 서버 응답에서 세션 ID를 가져 오는 것입니다. 서버가 고유 한 세션 키를 반환하면로드 스크립트의 표현식을 사용하여 쉽게 가져올 수 있습니다.
테스트 계획에서 정규식을 사용하려면 JMeter의 정규식 추출기를 사용해야합니다. 테스트 계획의 모든 구성 요소에 정규식을 배치 할 수 있습니다.
차이점을 강조 할 가치가 있습니다. contains 과 matches, Response Assertion 테스트 요소에 사용됨 −
contains정규 표현식이 대상의 일부 이상과 일치했음을 의미하므로 'alphabet'은 'contains' 'ph.b'를 의미합니다. 정규 표현식이 하위 문자열 'phabe'와 일치하기 때문입니다.
matches정규식이 전체 대상과 일치했음을 의미합니다. 따라서 '알파벳'은 'al. * t'와 "일치"됩니다.
웹 페이지의 다음 부분과 일치한다고 가정 해보십시오.
name = "file" value = "readme.txt"
그리고 readme.txt를 추출하고 싶습니다. 적합한 정규식은 다음과 같습니다.
name = "file" value = "(.+?)">
위의 특수 문자는-
( 과 ) − 반환 될 일치 문자열의 일부를 묶습니다.
. − 모든 문자와 일치
+ − 1 회 이상
? − 첫 번째 경기가 성공하면 중지
JMeter 테스트 계획 생성
테스트 계획을 작성하여 정규식 추출기 (포스트 프로세서 요소)에서 정규식의 사용을 이해하겠습니다. 이 요소는 원하는 요소가 준수하는 텍스트 패턴을 식별하기 위해 정규식을 사용하여 현재 페이지에서 텍스트를 추출합니다.
먼저 사람들과 이메일 ID 목록이있는 HTML 페이지를 작성합니다. Tomcat 서버에 배포합니다. html (index.html)의 내용은 다음과 같습니다.
<html>
<head>
</head>
<body>
<table style = "border: 1px solid #000000;">
<th style = "border: 1px solid #000000;">ID</th>
<th style = "border: 1px solid #000000;">name</th>
<th style = "border: 1px solid #000000;">Email</th>
<tr>
<td id = "ID" style = "border: 1px solid #000000;">3</td>
<td id = "Name" style = "border: 1px solid #000000;">Manisha</td>
<td id = "Email" style = "border: 1px solid #000000;">[email protected]</td>
</tr>
<tr>
<td id = "ID" style = "border: 1px solid #000000;">4</td>
<td id = "Name" style = "border: 1px solid #000000;">joe</td>
<td id = "Email" style = "border: 1px solid #000000;">[email protected]</td>
</tr>
</table>
</body>
</html>
tomcat 서버에 배포 할 때이 페이지는 다음 스크린 샷과 같이 보입니다.
테스트 계획에서 위의 사람 목록 페이지에 표시된 사람 테이블의 첫 번째 행에서 사람을 선택합니다. 이 사람의 ID를 캡처하려면 먼저 두 번째 행에서 사람을 찾을 패턴을 결정합니다.
다음 스냅 샷에서 볼 수 있듯이 두 번째 사람의 ID는 <td id = "ID"> 및 </ td>로 둘러싸여 있으며이 패턴을 갖는 데이터의 두 번째 행입니다. 이를 사용하여 정보를 추출하려는 정확한 패턴과 일치시킬 수 있습니다. 이 페이지에서 개인 ID와 개인 이름의 두 가지 정보를 추출하고자하므로 필드는 다음과 같이 정의됩니다.
JMeter 시작, 스레드 그룹 추가 Test Plan → Add→ Threads(Users)→ Thread Group.
다음으로 샘플러 HTTP 요청을 추가하고 테스트 계획을 선택하고 마우스 오른쪽 버튼을 클릭합니다. Add → Sampler → HTTP Request 다음과 같이 세부 정보를 입력하십시오-
Name − 관리
Server Name or IP − 로컬 호스트
Port Number − 8080
Protocol −이 항목을 비워두면 HTTP를 프로토콜로 사용합니다.
Path − jmeter / index.html
다음으로 정규식 추출기를 추가하십시오. HTTP 요청 샘플러 (관리)를 선택하고 마우스 오른쪽 단추를 클릭하십시오.Add → Post Processor → Regular Expression Extractor.
다음 표는 위 스크린 샷에서 사용 된 필드에 대한 설명을 제공합니다.
Sr. 아니요 | 필드 및 설명 |
---|---|
1 | Reference Name 추출 된 테스트가 저장 될 변수의 이름 (refname). |
2 | Regular Expression 추출 할 텍스트가 일치하는 패턴입니다. 추출 할 텍스트 그룹은 '('및 ')'문자로 묶여 있습니다. '. +?'를 사용합니다. <td ..> .. </ td> 태그로 묶인 텍스트의 단일 인스턴스를 나타냅니다. 이 예에서 표현식은 − <td id = "ID"> (+?) </ td> \ s * <td id = "Name"> (+?) </ td> \ s * |
삼 | Template 추출 된 각 텍스트 그룹은 '('및 ')'로 묶인 각 패턴 그룹의 순서에 따라 변수 Person의 구성원으로 배치됩니다. 각 그룹은 refname_g #으로 저장됩니다. 여기서 refname은 참조 이름으로 입력 한 문자열이고 #은 그룹 번호입니다. $ 1 $는 그룹 1을, $ 2 $는 그룹 2를 나타냅니다. $ 0 $는 전체 표현식이 일치하는 모든 것을 나타냅니다. 이 예에서 추출한 ID는 Person_g1에 유지되고 Name 값은 Person_g2에 저장됩니다. |
4 | Match No. 두 번째 자원자와 일치하는이 패턴의 두 번째 발생 만 추출 할 계획이므로 값 2를 사용합니다. 값 0은 무작위로 일치하는 반면 음수 값은 ForEach 컨트롤러에서 사용해야합니다. |
5 | Default 항목을 찾을 수없는 경우 이것이 기본값입니다. 이것은 선택적 필드입니다. 비워 둘 수 있습니다. |
이 테스트 계획의 결과를 캡처하려면 리스너를 추가하십시오. 스레드 그룹을 마우스 오른쪽 단추로 클릭하고 추가 → 리스너 → 결과 트리보기 옵션을 선택하여 리스너를 추가하십시오.
테스트 계획을 reg_express_test.jmx 로 저장하고 테스트를 실행합니다. 출력은 다음 스크린 샷과 같이 성공할 것입니다.