CherryPy-테스트
테스트는 응용 프로그램이 다음을 위해 다른 관점에서 수행되는 프로세스입니다.
- 문제 목록 찾기
- 예상 결과와 실제 결과, 출력, 상태 등의 차이점을 찾습니다.
- 구현 단계를 이해합니다.
- 현실적인 목적에 유용한 응용 프로그램을 찾으십시오.
테스트의 목표는 개발자를 잘못하는 것이 아니라 도구를 제공하고 주어진 시간에 애플리케이션의 상태를 추정하기위한 품질을 개선하는 것입니다.
테스트는 미리 계획해야합니다. 이를 위해서는 테스트의 목적을 정의하고, 테스트 사례의 범위를 이해하고, 비즈니스 요구 사항 목록을 작성하고, 프로젝트의 여러 단계에 관련된 위험을 인식해야합니다.
테스트는 시스템 또는 애플리케이션에서 검증 할 다양한 측면으로 정의됩니다. 다음은 목록입니다common test approaches −
Unit testing− 이는 일반적으로 개발자가 직접 수행합니다. 이것은 코드 단위가 예상대로 작동하는지 여부를 확인하는 것을 목표로합니다.
Usability testing− 개발자는 일반적으로 시스템에 대한 지식이없는 최종 사용자를 위해 애플리케이션을 작성하고 있다는 사실을 잊을 수 있습니다. 사용성 테스트는 제품의 장단점을 확인합니다.
Functional/Acceptance testing − 사용성 테스트는 애플리케이션 또는 시스템의 사용 가능 여부를 확인하는 반면, 기능 테스트는 지정된 모든 기능이 구현되었는지 확인합니다.
Load and performance testing− 이는 시스템이 수행 할 부하 및 성능 테스트에 적응할 수 있는지 여부를 이해하기 위해 수행됩니다. 이는 하드웨어 변경, SQL 쿼리 최적화 등으로 이어질 수 있습니다.
Regression testing − 제품의 연속 릴리스가 이전 기능을 손상시키지 않는지 확인합니다.
Reliability and resilience testing − 신뢰성 테스트는 하나 또는 여러 구성 요소를 분석하여 시스템 애플리케이션을 검증하는 데 도움이됩니다.
단위 테스트
Photoblog 응용 프로그램은 지속적으로 단위 테스트를 사용하여 다음을 확인합니다.
- 새로운 기능이 올바르게 작동합니다.
- 기존 기능은 새 코드 릴리스로 인해 손상되지 않습니다.
- 결함이 수정되고 수정 된 상태로 유지됩니다.
Python은 단위 테스트에 대한 다른 접근 방식을 제공하는 표준 단위 테스트 모듈과 함께 제공됩니다.
Unittest
unittest는 Kent Beck과 Erich Gamma가 개발 한 Java 단위 테스트 패키지 인 JUnit에 뿌리를두고 있습니다. 단위 테스트는 단순히 정의 된 데이터를 반환합니다. 모의 객체를 정의 할 수 있습니다. 이러한 개체를 사용하면 전체 애플리케이션에 의존하지 않고도 디자인의 인터페이스에 대해 테스트 할 수 있습니다. 또한 다른 테스트가 포함 된 격리 모드에서 테스트를 실행하는 방법을 제공합니다.
다음과 같은 방법으로 더미 클래스를 정의 해 봅시다.
import unittest
class DummyTest(unittest.TestCase):
def test_01_forward(self):
dummy = Dummy(right_boundary=3)
self.assertEqual(dummy.forward(), 1)
self.assertEqual(dummy.forward(), 2)
self.assertEqual(dummy.forward(), 3)
self.assertRaises(ValueError, dummy.forward)
def test_02_backward(self):
dummy = Dummy(left_boundary=-3, allow_negative=True)
self.assertEqual(dummy.backward(), -1)
self.assertEqual(dummy.backward(), -2)
self.assertEqual(dummy.backward(), -3)
self.assertRaises(ValueError, dummy.backward)
def test_03_boundaries(self):
dummy = Dummy(right_boundary=3, left_boundary=-3,allow_negative=True)
self.assertEqual(dummy.backward(), -1)
self.assertEqual(dummy.backward(), -2)
self.assertEqual(dummy.forward(), -1)
self.assertEqual(dummy.backward(), -2)
self.assertEqual(dummy.backward(), -3)
코드에 대한 설명은 다음과 같습니다.
주어진 클래스에 대한 단위 테스트 기능을 제공하려면 unittest 모듈을 가져와야합니다.
unittest를 서브 클래 싱하여 클래스를 만들어야합니다.
위 코드의 모든 방법은 테스트 단어로 시작합니다. 이러한 모든 메서드는 unittest 핸들러에 의해 호출됩니다.
assert / fail 메서드는 예외를 관리하기 위해 테스트 케이스에서 호출됩니다.
이것을 테스트 케이스를 실행하는 예제로 고려하십시오-
if __name__ == '__main__':
unittest.main()
테스트 케이스를 실행 한 결과 (출력)는 다음과 같습니다.
----------------------------------------------------------------------
Ran 3 tests in 0.000s
OK
기능 테스트
애플리케이션 기능이 요구 사항에 따라 형성되기 시작하면 일련의 기능 테스트를 통해 사양과 관련된 애플리케이션의 정확성을 검증 할 수 있습니다. 그러나 Selenium과 같은 타사 제품을 사용해야하는 성능 향상을 위해 테스트를 자동화해야합니다.
CherryPy는 기능 테스트 작성을 쉽게하기 위해 내장 함수와 같은 도우미 클래스를 제공합니다.
부하 테스트
작성중인 애플리케이션과 볼륨 측면에서 기대하는 사항에 따라 특정 수준의 성능에 도달하지 못하게하는 애플리케이션의 잠재적 병목 현상을 감지하기 위해로드 및 성능 테스트를 실행해야 할 수 있습니다.
이 섹션에서는 FunkLoad 패키지에 포함되지 않은 성능 또는 부하 테스트를 수행하는 방법에 대해 자세히 설명하지 않습니다.
FunkLoad의 가장 기본적인 예는 다음과 같습니다.
from funkload.FunkLoadTestCase
import FunkLoadTestCase
class LoadHomePage(FunkLoadTestCase):
def test_homepage(self):
server_url = self.conf_get('main', 'url')
nb_time = self.conf_getInt('test_homepage', 'nb_time')
home_page = "%s/" % server_url
for i in range(nb_time):
self.logd('Try %i' % i)
self.get(home_page, description='Get gome page')
if __name__ in ('main', '__main__'):
import unittest
unittest.main()
다음은 위 코드에 대한 자세한 설명입니다.
테스트 케이스는 FunkLoadTestCase 클래스에서 상속 받아야 FunkLoad가 테스트 중에 일어나는 일을 추적하는 내부 작업을 수행 할 수 있습니다.
FunkLoad는 클래스 이름을 기반으로 파일을 검색하므로 클래스 이름이 중요합니다.
설계된 테스트 케이스는 구성 파일에 직접 액세스 할 수 있습니다. Get () 및 post () 메서드는 응답을 얻기 위해 서버에 대해 간단히 호출됩니다.