test
— 파이썬 용 회귀 테스트 패키지¶
참고
test
패키지는 파이썬 내부 용으로만 사용됩니다. 파이썬의 핵심 개발자를 위해 설명됩니다. 여기에 언급된 코드는 파이썬 릴리스 사이에 예고 없이 변경되거나 제거될 수 있어서, 파이썬의 표준 라이브러리 외부에서 이 패키지를 사용하는 것은 권장되지 않습니다.
test
패키지에는 test.support
와 test.regrtest
뿐만 아니라 파이썬에 대한 모든 회귀 테스트가 포함되어 있습니다. test.support
는 테스트를 향상하는 데 사용되며 test.regrtest
는 테스트 스위트를 구동합니다.
이름이 test_
로 시작하는 test
패키지의 각 모듈은 특정 모듈이나 기능에 대한 테스트 스위트입니다. 모든 새로운 테스트는 unittest
나 doctest
모듈을 사용하여 작성해야 합니다. 일부 오래된 테스트는 sys.stdout
으로 인쇄된 출력을 비교하는 “전통적인” 테스트 스타일을 사용하여 작성되었습니다; 이 테스트 스타일은 폐지된 것으로 간주합니다.
test
패키지를 위한 단위 테스트 작성하기¶
unittest
모듈을 사용하는 테스트는 몇 가지 지침을 따르는 것이 좋습니다. 하나는 테스트 모듈의 이름을 test_
로 시작하고 테스트 중인 모듈의 이름으로 끝나도록 짓는 것입니다. 테스트 모듈의 테스트 메서드는 test_
로 시작하고 메서드가 테스트하는 내용에 대한 설명으로 끝나야 합니다. 이는 테스트 드라이버가 메서드를 테스트 메서드로 인식하기 위해 필요합니다. 또한, 메서드에 대한 독스트링이 포함되어서는 안 됩니다. 주석(가령 # Tests function returns only True or False
)을 사용하여 테스트 메서드에 대한 설명을 제공해야 합니다. 이는 독스트링이 존재하면 이것이 인쇄되어 실행되는 테스트가 인쇄되지 않기 때문입니다.
기본 상용구가 자주 사용됩니다:
import unittest
from test import support
class MyTestCase1(unittest.TestCase):
# Only use setUp() and tearDown() if necessary
def setUp(self):
... code to execute in preparation for tests ...
def tearDown(self):
... code to execute to clean up after tests ...
def test_feature_one(self):
# Test feature one.
... testing code ...
def test_feature_two(self):
# Test feature two.
... testing code ...
... more test methods ...
class MyTestCase2(unittest.TestCase):
... same structure as MyTestCase1 ...
... more test classes ...
if __name__ == '__main__':
unittest.main()
이 코드 패턴을 사용하면 test.regrtest
에서 자체적으로 unittest
CLI를 지원하는 스크립트로나 python -m unittest
CLI를 통해 테스트 스위트를 실행할 수 있습니다.
회귀 테스트의 목표는 코드를 깨려고 시도하는 것입니다. 이는 따라야 할 몇 가지 지침으로 이어집니다:
테스트 스위트는 모든 클래스, 함수 및 상수를 괴롭혀야 합니다. 여기에는 외부 세계에 제공되는 외부 API뿐만 아니라 “내부(private)” 코드도 포함됩니다.
화이트 박스 테스트 (테스트 작성 시 테스트 중인 코드 검사)가 선호됩니다. 블랙박스 테스트(게시된 사용자 인터페이스 만 테스트)는 모든 경계와 에지 케이스가 테스트 되었는지 확인하기에 충분하지 않습니다.
유효하지 않은 값을 포함하여 가능한 모든 값이 테스트 되었는지 확인하십시오. 이렇게 하면 모든 유효한 값이 받아들여질 뿐만 아니라 부적절한 값이 올바르게 처리되었는지 확인하게 됩니다.
가능한 한 많은 코드 경로를 소진하십시오. 분기가 발생하는 위치를 테스트하고 입력을 조정하여 코드에서 여러 경로가 사용되는지 확인합니다.
테스트 된 코드에 대해 발견된 버그에 대한 명시적 테스트를 추가합니다. 이렇게 하면 나중에 코드가 변경되어도 에러가 다시 발생하는지 확인합니다.
테스트 후에 정리해야 합니다 (가령 모든 임시 파일 닫고 제거하기).
테스트가 운영 체제의 특정 조건에 의존하면 테스트를 시도하기 전에 조건이 이미 존재하는지 확인하십시오.
가능한 한 적은 수의 모듈을 임포트 하고 가능한 한 빨리 수행하십시오. 이렇게 하면 테스트의 외부 종속성이 최소화되고 모듈 임포트의 부작용에 따른 비정상적인 동작이 최소화됩니다.
코드 재사용을 극대화하십시오. 때에 따라, 테스트는 사용되는 입력 유형에 따라 조금씩 달라집니다. 입력을 지정하는 클래스로 기본 테스트 클래스를 서브 클래싱하여 코드 중복을 최소화합니다:
class TestFuncAcceptsSequencesMixin: func = mySuperWhammyFunction def test_func(self): self.func(self.arg) class AcceptLists(TestFuncAcceptsSequencesMixin, unittest.TestCase): arg = [1, 2, 3] class AcceptStrings(TestFuncAcceptsSequencesMixin, unittest.TestCase): arg = 'abc' class AcceptTuples(TestFuncAcceptsSequencesMixin, unittest.TestCase): arg = (1, 2, 3)
이 패턴을 사용할 때,
unittest.TestCase
를 상속한 모든 클래스가 테스트로 실행된다는 점을 기억하십시오. 위 예제의Mixin
클래스는 데이터가 없어서 자체적으로 실행할 수 없기 때문에,unittest.TestCase
를 상속하지 않습니다.
더 보기
- 테스트 주도 개발(Test Driven Development)
코드 전에 테스트를 작성하는 것에 관한 Kent Beck의 책.
명령 줄 인터페이스를 사용하여 테스트 실행하기¶
-m
옵션 덕분에 test
패키지를 스크립트로 실행하여 파이썬의 회귀 테스트 스위트를 구동 할 수 있습니다: python -m test. 내부적으로는 test.regrtest
를 사용합니다; 이전 파이썬 버전에서 사용된 호출 python -m test.regrtest는 여전히 작동합니다. 스크립트를 단독으로 실행하면 test
패키지의 모든 회귀 테스트 실행이 자동으로 시작됩니다. 패키지에서 이름이 test_
로 시작하는 모든 모듈을 찾아서, 임포트 하고, test_main()
함수가 있으면 실행하고, test_main
이 없으면 unittest.TestLoader.loadTestsFromModule 을 통해 테스트를 로드하여 이를 수행합니다. 실행할 테스트 이름도 스크립트에 전달할 수 있습니다. 단일 회귀 테스트를 지정하면 (python -m test test_spam) 출력이 최소화되고 테스트의 통과나 실패 여부만 인쇄됩니다.
test
를 직접 실행하면 테스트에 사용할 수 있는 리소스를 설정할 수 있습니다. -u
명령 줄 옵션을 사용하여 이 작업을 수행합니다. -u
옵션의 값으로 all
을 지정하면 가능한 모든 자원을 사용할 수 있습니다: python -m test -uall. 하나를 제외한 모든 리소스가 필요한 경우 (더 흔한 경우입니다), 원하지 않는 리소스의 쉼표로 구분된 목록이 all
뒤에 나열될 수 있습니다. python -m test -uall,-audio,-largefile 명령은 audio
와 largefile
리소스를 제외한 모든 리소스로 test
를 실행합니다. 모든 리소스와 추가 명령 줄 옵션 목록을 보려면, python -m test -h를 실행하십시오.
회귀 테스트를 실행하는 다른 방법은 테스트가 실행되는 플랫폼에 따라 다릅니다. 유닉스에서는, 파이썬이 빌드된 최상위 디렉터리에서 make test를 실행할 수 있습니다. 윈도우에서는, PCbuild
디렉터리에서 rt.bat을 실행하면 모든 회귀 테스트가 실행됩니다.
test.support
— 파이썬 테스트 스위트용 유틸리티¶
test.support
모듈은 파이썬의 회귀 테스트 스위트를 지원합니다.
참고
test.support
는 공용 모듈이 아닙니다. 파이썬 개발자가 테스트를 작성하는 데 도움이 되도록 여기에 설명하고 있습니다. 이 모듈의 API는 릴리스 간에 하위 호환성에 대한 고려 없이 변경될 수 있습니다.
이 모듈은 다음 예외를 정의합니다:
-
exception
test.support.
TestFailed
¶ 테스트가 실패할 때 발생하는 예외. 이것은 폐지되었고
unittest
기반 테스트와unittest.TestCase
의 어서션 메서드로 대체합니다.
-
exception
test.support.
ResourceDenied
¶ unittest.SkipTest
의 서브 클래스. 리소스(가령 네트워크 연결)를 사용할 수 없을 때 발생합니다.requires()
함수에 의해 발생합니다.
test.support
모듈은 다음 상수를 정의합니다:
-
test.support.
verbose
¶ 상세 출력이 활성화될 때
True
. 실행 중인 테스트에 대한 자세한 정보가 필요할 때 확인해야 합니다. verbose는test.regrtest
에 의해 설정됩니다.
-
test.support.
is_jython
¶ 실행 중인 인터프리터가 Jython이면
True
.
-
test.support.
is_android
¶ 시스템이 안드로이드이면
True
.
-
test.support.
unix_shell
¶ 윈도우가 아니면 셸 경로; 그렇지 않으면
None
.
-
test.support.
FS_NONASCII
¶ os.fsencode()
로 인코딩 할 수 있는 비 ASCII 문자.
-
test.support.
TESTFN
¶ 임시 파일의 이름으로 사용하기에 안전한 이름으로 설정합니다. 만들어진 모든 임시 파일은 닫히고 언 링크(제거) 되어야 합니다.
-
test.support.
TESTFN_UNICODE
¶ 임시 파일을 위한 비 ASCII 이름으로 설정합니다.
-
test.support.
TESTFN_ENCODING
¶ sys.getfilesystemencoding()
로 설정합니다.
-
test.support.
TESTFN_UNENCODABLE
¶ 엄격(strict) 모드에서 파일 시스템 인코딩으로 인코딩할 수 없는 파일명(str 형)으로 설정합니다. 이러한 파일명을 생성할 수 없으면
None
일 수 있습니다.
-
test.support.
TESTFN_UNDECODABLE
¶ 엄격(strict) 모드에서 파일 시스템 인코딩으로 디코딩할 수 없는 파일명(bytes 형)으로 설정합니다. 이러한 파일명을 생성할 수 없으면
None
일 수 있습니다.
-
test.support.
TESTFN_NONASCII
¶ FS_NONASCII
문자를 포함하는 파일명으로 설정합니다.
-
test.support.
LOOPBACK_TIMEOUT
¶ 127.0.0.1
과 같은 네트워크 로컬 루프 백 인터페이스에서 리스닝하는 네트워크 서버를 사용하는 테스트의 초 단위 제한 시간.제한 시간은 테스트 실패를 방지 할 수 있을 만큼 깁니다: 클라이언트와 서버가 다른 스레드나 다른 프로세스에서 실행될 수 있다는 점을 고려합니다.
제한 시간은
socket.socket
의connect()
,recv()
및send()
메서드를 위해 충분히 길어야 합니다.기본값은 5초입니다.
INTERNET_TIMEOUT
도 참조하십시오.
-
test.support.
INTERNET_TIMEOUT
¶ 인터넷으로 가는 네트워크 요청에 대한 초 단위 제한 시간.
어떤 이유로 든 인터넷 요청이 블록 되면 테스트가 너무 오래 기다리지 않을 만큼 제한 시간이 적당히 짧습니다.
일반적으로,
INTERNET_TIMEOUT
을 사용하는 시간 초과는 테스트를 실패로 표시해서는 안 되며, 대신 테스트를 건너뜁니다:transient_internet()
을 참조하십시오.기본값은 1분입니다.
LOOPBACK_TIMEOUT
도 참조하십시오.
-
test.support.
SHORT_TIMEOUT
¶ 테스트가 “너무 오래” 걸리면 테스트를 실패로 표시하는 초 단위 제한 시간.
제한 시간 값은 regrtest
--timeout
명령 줄 옵션에 따라 다릅니다.SHORT_TIMEOUT
을 사용하는 테스트가 느린 빌드 봇에서 무작위로 실패하기 시작하면, 대신LONG_TIMEOUT
을 사용합니다.기본값은 30초입니다.
-
test.support.
LONG_TIMEOUT
¶ 테스트 멈춤을 감지하기 위한 초 단위 제한 시간.
가장 느린 파이썬 빌드 봇에서 테스트 실패의 위험을 줄이기에 충분히 깁니다. 테스트가 “너무 오래” 걸리면 테스트를 실패로 표시하는 데 사용해서는 안 됩니다. 제한 시간 값은 regrtest
--timeout
명령 줄 옵션에 따라 다릅니다.기본값은 5분입니다.
LOOPBACK_TIMEOUT
,INTERNET_TIMEOUT
및SHORT_TIMEOUT
도 참조하십시오.
-
test.support.
SAVEDCWD
¶ os.getcwd()
로 설정합니다.
-
test.support.
PGO
¶ PGO에 유용하지 않은 테스트를 건너뛸 수 있을 때 설정합니다.
-
test.support.
PIPE_MAX_SIZE
¶ 쓰기 블로킹을 일으키기 위해, 하부 OS 파이프 버퍼 크기보다 클 가능성이 높은 상수.
-
test.support.
SOCK_MAX_SIZE
¶ 쓰기 블로킹을 일으키기 위해, 하부 OS 소켓 버퍼 크기보다 클 가능성이 높은 상수.
-
test.support.
TEST_SUPPORT_DIR
¶ test.support
를 포함하는 최상위 디렉터리로 설정합니다.
-
test.support.
TEST_HOME_DIR
¶ 테스트 패키지의 최상위 디렉터리로 설정합니다.
-
test.support.
TEST_DATA_DIR
¶ 테스트 패키지 내의
data
디렉터리로 설정합니다.
-
test.support.
MAX_Py_ssize_t
¶ 대용량 메모리 테스트를 위해
sys.maxsize
로 설정합니다.
-
test.support.
max_memuse
¶ 대용량 메모리 테스트를 위한 메모리 제한으로
set_memlimit()
에 의해 설정됩니다.MAX_Py_ssize_t
에 의해 제한됩니다.
-
test.support.
real_max_memuse
¶ 대용량 메모리 테스트를 위한 메모리 제한으로
set_memlimit()
에 의해 설정됩니다.MAX_Py_ssize_t
에 의해 제한되지 않습니다.
-
test.support.
MISSING_C_DOCSTRINGS
¶ 윈도우가 아닌 CPython에서 실행 중이고, 구성이
WITH_DOC_STRINGS
로 설정되지 않았으면True
를 반환합니다.
-
test.support.
HAVE_DOCSTRINGS
¶ 독스트링이 있는지 확인합니다.
-
test.support.
TEST_HTTP_URL
¶ 네트워크 테스트를 위한 전용 HTTP 서버의 URL을 정의합니다.
-
test.support.
ALWAYS_EQ
¶ 모든 것과 같은 객체. 혼합형 비교를 테스트하는 데 사용됩니다.
-
test.support.
LARGEST
¶ 모든 것보다 큰 객체 (자신은 제외하고). 혼합형 비교를 테스트하는 데 사용됩니다.
-
test.support.
SMALLEST
¶ 모든 것보다 작은 객체 (자신은 제외하고). 혼합형 비교를 테스트하는 데 사용됩니다.
test.support
모듈은 다음 함수를 정의합니다:
-
test.support.
forget
(module_name)¶ sys.modules
에서 module_name이라는 모듈을 제거하고 모듈의 바이트 컴파일된 파일을 삭제합니다.
-
test.support.
unload
(name)¶ sys.modules
에서 name을 삭제합니다.
-
test.support.
unlink
(filename)¶ Call
os.unlink()
on filename. On Windows platforms, this is wrapped with a wait loop that checks for the existence of the file.
-
test.support.
rmdir
(filename)¶ filename에 대해
os.rmdir()
을 호출합니다. 윈도우 플랫폼에서는, 파일의 존재를 확인하는 대기 루프로 래핑 됩니다.
-
test.support.
rmtree
(path)¶ path에 대해
shutil.rmtree()
를 호출하거나os.lstat()
과os.rmdir()
을 호출하여 경로와 해당 내용을 제거합니다. 윈도우 플랫폼에서, 이것은 파일의 존재를 확인하는 대기 루프로 래핑 됩니다.
-
test.support.
make_legacy_pyc
(source)¶ PEP 3147/PEP 488 pyc 파일을 레거시 pyc 위치로 옮기고 레거시 pyc 파일에 대한 파일 시스템 경로를 반환합니다. source 값은 소스 파일에 대한 파일 시스템 경로입니다. 반드시 존재할 필요는 없지만, PEP 3147/488 pyc 파일이 있어야 합니다.
-
test.support.
is_resource_enabled
(resource)¶ resource가 활성화되고 사용할 수 있으면
True
를 반환합니다. 사용 가능한 리소스 목록은test.regrtest
가 테스트를 실행할 때만 설정됩니다.
-
test.support.
python_is_optimized
()¶ 파이썬이
-O0
이나-Og
로 빌드되지 않았으면True
를 반환합니다.
-
test.support.
with_pymalloc
()¶ _testcapi.WITH_PYMALLOC
을 반환합니다.
-
test.support.
requires
(resource, msg=None)¶ resource를 사용할 수 없으면
ResourceDenied
를 발생시킵니다. msg는ResourceDenied
가 발생한다면 이에 대한 인자입니다.__name__
이'__main__'
인 함수에 의해 호출되면 항상True
를 반환합니다.test.regrtest
에서 테스트를 실행할 때 사용됩니다.
-
test.support.
system_must_validate_cert
(f)¶ TLS 인증서 유효성 검사 실패 시
unittest.SkipTest
를 발생시킵니다.
-
test.support.
sortdict
(dict)¶ 정렬된 키로 dict의 repr을 반환합니다.
-
test.support.
findfile
(filename, subdir=None)¶ filename이라는 파일의 경로를 반환합니다. 일치하는 것이 없으면 filename이 반환됩니다. 이것은 파일의 경로일 수 있어서 실패와 같지 않습니다.
subdir 설정은 경로 디렉터리를 직접 찾는 대신 파일을 찾는 데 사용할 상대 경로를 나타냅니다.
-
test.support.
create_empty_file
(filename)¶ filename으로 빈 파일을 만듭니다. 이미 있으면, 자릅니다.
-
test.support.
fd_count
()¶ 열린 파일 기술자의 수를 셉니다.
-
test.support.
match_test
(test)¶ test를
set_match_tests()
에 설정된 패턴과 일치시킵니다.
-
test.support.
set_match_tests
(patterns)¶ 정규식 patterns로 일치 테스트를 정의합니다.
-
test.support.
run_unittest
(*classes)¶ 함수에 전달된
unittest.TestCase
서브 클래스를 실행합니다. 이 함수는 접두사test_
로 시작하는 메서드에 대해 클래스를 검색하고 테스트를 개별적으로 실행합니다.문자열을 매개 변수로 전달하는 것도 유효합니다;
sys.modules
의 키여야 합니다. 각 관련 모듈은unittest.TestLoader.loadTestsFromModule()
에 의해 스캔 됩니다. 일반적으로 다음test_main()
함수에서 볼 수 있습니다:def test_main(): support.run_unittest(__name__)
이것은 명명된 모듈에 정의된 모든 테스트가 실행됩니다.
-
test.support.
run_doctest
(module, verbosity=None, optionflags=0)¶ 주어진 module에서
doctest.testmod()
를 실행합니다.(failure_count, test_count)
를 반환합니다.verbosity가
None
이면,doctest.testmod()
는 상세도를verbose
로 설정하여 실행됩니다. 그렇지 않으면 상세도를None
으로 설정하여 실행됩니다. optionflags는optionflags
로doctest.testmod()
에 전달됩니다.
-
test.support.
setswitchinterval
(interval)¶ sys.setswitchinterval()
을 주어진 interval로 설정합니다. 시스템이 멈추는 것을 방지하기 위해 안드로이드 시스템을 위한 최소 간격을 정의합니다.
-
test.support.
check_impl_detail
(**guards)¶ 이 검사를 사용하여 CPython의 구현 별 테스트를 보호하거나 인자로 보호되는 구현에서만 실행합니다:
check_impl_detail() # Only on CPython (default). check_impl_detail(jython=True) # Only on Jython. check_impl_detail(cpython=False) # Everywhere except CPython.
-
test.support.
check_warnings
(*filters, quiet=True)¶ 경고가 올바르게 발생했는지 테스트하기 쉽게 하는
warnings.catch_warnings()
용 편의 래퍼.warnings.simplefilter()
를always
로 설정하고 기록된 결과를 자동으로 검증하는 옵션을 사용하여warnings.catch_warnings(record=True)
를 호출하는 것과 거의 동등합니다.check_warnings
는 위치 인자로("message regexp", WarningCategory)
형식의 2-튜플을 받습니다. 하나 이상의 filters가 제공되거나, 선택적 키워드 인자 quiet가False
이면, 경고가 예상대로인지 확인합니다: 지정된 각 필터는 둘러싸인 코드에서 발생한 경고 중 적어도 하나와 일치해야 합니다. 그렇지 않으면 테스트가 실패합니다. 지정된 필터와 일치하지 않는 경고가 발생하면 테스트가 실패합니다. 첫 번째 검사를 비활성화하려면, quiet를True
로 설정합니다.인자가 지정되지 않으면, 기본값은 다음과 같습니다:
check_warnings(("", Warning), quiet=True)
이 경우 모든 경고가 포착되고 에러가 발생하지 않습니다.
컨텍스트 관리자에 진입하면,
WarningRecorder
인스턴스가 반환됩니다.catch_warnings()
의 하부 경고 리스트는 레코더 객체의warnings
어트리뷰트를 통해 사용할 수 있습니다. 편의상, 가장 최근의 경고를 나타내는 객체의 어트리뷰트는 레코더 객체를 통해 직접 액세스 할 수도 있습니다 (아래 예를 참조하십시오). 경고가 발생하지 않으면, 객체에서 예상되는 경고를 나타내는 어트리뷰트는None
을 반환합니다.레코더 객체에는 경고 리스트를 지우는
reset()
메서드도 있습니다.컨텍스트 관리자는 다음과 같이 사용되도록 설계되었습니다:
with check_warnings(("assertion is always true", SyntaxWarning), ("", UserWarning)): exec('assert(False, "Hey!")') warnings.warn(UserWarning("Hide me!"))
이 경우 경고가 발생하지 않았거나, 다른 경고가 발생하면,
check_warnings()
는 에러를 발생시킵니다.테스트에서 경고가 발생했는지를 확인하는 것만이 아니라, 경고를 더 깊이 조사해야 할 때, 다음과 같은 코드를 사용할 수 있습니다:
with check_warnings(quiet=True) as w: warnings.warn("foo") assert str(w.args[0]) == "foo" warnings.warn("bar") assert str(w.args[0]) == "bar" assert str(w.warnings[0].args[0]) == "foo" assert str(w.warnings[1].args[0]) == "bar" w.reset() assert len(w.warnings) == 0
여기에서 모든 경고가 포착되고, 테스트 코드는 포착된 경고를 직접 테스트합니다.
버전 3.2에서 변경: 새로운 선택적 인자 filters와 quiet.
-
test.support.
check_no_resource_warning
(testcase)¶ ResourceWarning
이 발생하지 않았는지 확인하는 컨텍스트 관리자. 컨텍스트 관리자가 끝나기 전에ResourceWarning
을 방출할 수 있는 객체를 제거해야 합니다.
-
test.support.
set_memlimit
(limit)¶ 대용량 메모리 테스트를 위해
max_memuse
와real_max_memuse
값을 설정합니다.
-
test.support.
record_original_stdout
(stdout)¶ stdout의 값을 저장합니다. regrtest가 시작될 때 stdout을 잡기 위한 것입니다.
-
test.support.
get_original_stdout
()¶ record_original_stdout()
에 의해 설정된 원래 stdout이나 설정되지 않았으면sys.stdout
을 반환합니다.
-
test.support.
args_from_interpreter_flags
()¶ sys.flags
와sys.warnoptions
의 현재 설정을 재현하는 명령 줄 인자 리스트를 반환합니다.
-
test.support.
optim_args_from_interpreter_flags
()¶ sys.flags
의 현재 최적화 설정을 재현하는 명령 줄 인자 리스트를 반환합니다.
-
test.support.
captured_stdin
()¶ -
test.support.
captured_stdout
()¶ -
test.support.
captured_stderr
()¶ 명명된 스트림을
io.StringIO
객체로 일시적으로 대체하는 컨텍스트 관리자.출력 스트림 사용 예:
with captured_stdout() as stdout, captured_stderr() as stderr: print("hello") print("error", file=sys.stderr) assert stdout.getvalue() == "hello\n" assert stderr.getvalue() == "error\n"
입력 스트림 사용 예:
with captured_stdin() as stdin: stdin.write('hello\n') stdin.seek(0) # call test code that consumes from sys.stdin captured = input() self.assertEqual(captured, "hello")
-
test.support.
temp_dir
(path=None, quiet=False)¶ path에 임시 디렉터리를 만들고 그 디렉터리를 산출하는 컨텍스트 관리자.
path가
None
이면, 임시 디렉터리는tempfile.mkdtemp()
를 사용하여 만들어집니다. quiet가False
이면, 컨텍스트 관리자는 에러 시 예외를 발생시킵니다. 그렇지 않으면, path가 지정되고 만들 수 없으면, 경고만 발행됩니다.
-
test.support.
change_cwd
(path, quiet=False)¶ 현재 작업 디렉터리를 path로 일시적으로 변경하고 그 디렉터리를 산출하는 컨텍스트 관리자.
quiet가
False
이면, 컨텍스트 관리자는 에러 시 예외를 발생시킵니다. 그렇지 않으면, 경고만 발행하고 현재 작업 디렉터리를 같게 유지합니다.
-
test.support.
temp_cwd
(name='tempcwd', quiet=False)¶ 임시로 새 디렉터리를 만들고 현재 작업 디렉터리(CWD)를 변경하는 컨텍스트 관리자.
컨텍스트 관리자는 현재 작업 디렉터리를 임시로 변경하기 전에 이름이 name인 임시 디렉터리를 현재 디렉터리에 만듭니다. name이
None
이면, 임시 디렉터리는tempfile.mkdtemp()
를 사용하여 만들어집니다.quiet가
False
이고 만들 수 없거나 CWD를 변경할 수 없으면, 에러가 발생합니다. 그렇지 않으면, 경고만 발생하고 원래 CWD가 사용됩니다.
-
test.support.
temp_umask
(umask)¶ 프로세스 umask를 임시로 설정하는 컨텍스트 관리자.
-
test.support.
disable_faulthandler
()¶ sys.stderr
를sys.__stderr__
로 대체하는 컨텍스트 관리자.
-
test.support.
gc_collect
()¶ 가능한 한 많은 객체를 수거하도록 강제합니다. 이는 가비지 수거기가 적시에 할당 해제를 보장하지 않기 때문에 필요합니다. 이는
__del__
메서드가 예상보다 늦게 호출될 수 있고 약한 참조(weakrefs)가 예상보다 오래 살아있을 수 있음을 의미합니다.
-
test.support.
disable_gc
()¶ 진입할 때 가비지 수거기를 비활성화하고 탈출할 때 다시 활성화하는 컨텍스트 관리자.
-
test.support.
swap_attr
(obj, attr, new_val)¶ 어트리뷰트를 새 객체로 스와프하는 컨텍스트 관리자.
용법:
with swap_attr(obj, "attr", 5): ...
이렇게 하면
with
블록의 기간 중obj.attr
이 5로 설정되고, 블록 끝에서 이전 값이 복원됩니다.obj
에attr
이 없으면, 만들어지고 블록의 끝에서 삭제됩니다.이전 값(또는 존재하지 않으면
None
)이 “as” 절의 대상(있다면)에 대입됩니다.
-
test.support.
swap_item
(obj, attr, new_val)¶ 항목을 새 객체로 스와프하는 컨텍스트 관리자.
용법:
with swap_item(obj, "item", 5): ...
이렇게 하면
with
블록의 기간 중obj["item"]
이 5로 설정되고, 블록 끝에서 이전 값이 복원됩니다.obj
에item
이 없으면, 만들어지고 블록의 끝에서 삭제됩니다.이전 값(또는 존재하지 않으면
None
)이 “as” 절의 대상(있다면)에 대입됩니다.
-
test.support.
print_warning
(msg)¶ sys.__stderr__
에 경고를 인쇄합니다. 메시지를 다음처럼 포맷합니다:f"Warning -- {msg}"
. msg가 여러 줄로 구성되면, 각 줄에"Warning -- "
접두사를 추가합니다.버전 3.9에 추가.
-
test.support.
wait_process
(pid, *, exitcode, timeout=None)¶ 프로세스 pid가 완료될 때까지 기다렸다가 프로세스 종료 코드가 exitcode인지 확인합니다.
프로세스 종료 코드가 exitcode와 같지 않으면
AssertionError
를 발생시킵니다.프로세스가 timeout(기본적으로
SHORT_TIMEOUT
) 초보다 오래 실행되면, 프로세스를 죽이고AssertionError
를 발생시킵니다. 제한 시간 기능은 윈도우에서 사용할 수 없습니다.버전 3.9에 추가.
-
test.support.
wait_threads_exit
(timeout=60.0)¶ with
문에서 만들어진 모든 스레드가 종료할 때까지 대기하는 컨텍스트 관리자.
-
test.support.
start_threads
(threads, unlock=None)¶ threads를 시작하는 컨텍스트 관리자. 탈출 시 스레드 join을 시도합니다.
-
test.support.
calcobjsize
(fmt)¶ nP{fmt}0n
이나gettotalrefcount
가 있으면,2PnP{fmt}0P
에 대해struct.calcsize()
를 반환합니다.
-
test.support.
calcvobjsize
(fmt)¶ nPn{fmt}0n
이나gettotalrefcount
가 있으면,2PnPn{fmt}0P
에 대해struct.calcsize()
를 반환합니다.
-
test.support.
checksizeof
(test, o, size)¶ 테스트 케이스 test에 대해, o의
sys.getsizeof
에 GC 헤더 크기를 더한 값이 size와 같다고 어서션 합니다.
-
test.support.
can_symlink
()¶ OS가 심볼릭 링크를 지원하면
True
를, 그렇지 않으면False
를 반환합니다.
-
test.support.
can_xattr
()¶ OS가 xattr을 지원하면
True
를, 그렇지 않으면False
를 반환합니다.
-
@
test.support.
skip_unless_symlink
¶ 심볼릭 링크 지원이 필요한 테스트를 실행하기 위한 데코레이터.
-
@
test.support.
skip_unless_xattr
¶ xattr 지원이 필요한 테스트를 실행하기 위한 데코레이터.
-
@
test.support.
anticipate_failure
(condition)¶ unittest.expectedFailure()
로 테스트를 조건부로 표시하는 데코레이터. 이 데코레이터를 사용하려면 관련 추적기(tracker) 이슈를 식별하는 관련 주석이 있어야 합니다.
-
@
test.support.
run_with_locale
(catstr, *locales)¶ 다른 로케일에서 함수를 실행하기 위한 데코레이터로, 완료된 후 올바르게 재설정합니다. catstr은 문자열로 된 로케일 범주입니다 (예를 들어
"LC_ALL"
). 전달된 locales는 순차적으로 시도되며, 첫 번째 유효한 로케일이 사용됩니다.
-
@
test.support.
run_with_tz
(tz)¶ 특정 시간대에서 함수를 실행하기 위한 데코레이터로, 완료된 후 올바르게 재설정합니다.
-
@
test.support.
requires_freebsd_version
(*min_version)¶ FreeBSD에서 테스트를 실행할 때 최소 버전을 위한 데코레이터. FreeBSD 버전이 최소 버전보다 낮으면,
unittest.SkipTest
를 발생시킵니다.
-
@
test.support.
requires_linux_version
(*min_version)¶ 리눅스에서 테스트를 실행할 때 최소 버전을 위한 데코레이터. 리눅스 버전이 최소 버전보다 낮으면,
unittest.SkipTest
를 발생시킵니다.
-
@
test.support.
requires_mac_version
(*min_version)¶ Decorator for the minimum version when running test on macOS. If the macOS version is less than the minimum, raise
unittest.SkipTest
.
-
@
test.support.
requires_IEEE_754
¶ 비 IEEE 754 플랫폼에서 테스트를 건너뛰는 데코레이터.
-
@
test.support.
requires_resource
(resource)¶ resource를 사용할 수 없으면 테스트를 건너뛰는 데코레이터.
-
@
test.support.
requires_docstrings
¶ HAVE_DOCSTRINGS
일 때만 테스트를 실행하는 데코레이터.
-
@
test.support.
cpython_only
(test)¶ CPython에만 적용되는 테스트용 데코레이터.
-
@
test.support.
impl_detail
(msg=None, **guards)¶ guards에
check_impl_detail()
을 호출하는 데코레이터.False
가 반환되면, 테스트를 건너뛰는 이유로 msg를 사용합니다.
-
@
test.support.
no_tracing
(func)¶ 테스트 기간 중 일시적으로 추적을 해제하는 데코레이터.
-
@
test.support.
refcount_test
(test)¶ 참조 횟수를 수반하는 테스트를 위한 데코레이터. 데코레이터는 CPython에 의해 실행되지 않으면 테스트를 실행하지 않습니다. 추적 함수로 인한 예기치 않은 참조 횟수를 방지하기 위해 테스트 기간 중 모든 추적 함수가 설정 해제됩니다.
-
@
test.support.
reap_threads
(func)¶ 테스트가 실패하더라도 스레드를 정리하는 데코레이터.
-
@
test.support.
bigmemtest
(size, memuse, dry_run=True)¶ bigmem 테스트를 위한 데코레이터.
size는 테스트를 위해 요청된 크기입니다 (임의의 테스트가 해석하는 단위.) memuse는 테스트 단위당 바이트 수, 또는 이의 적절한 추정치입니다. 예를 들어, 각각 4GiB인 두 개의 바이트 버퍼가 필요한 테스트는
@bigmemtest(size=_4G, memuse=2)
로 데코레이트 될 수 있습니다.size 인자는 일반적으로 데코레이트 된 테스트 메서드에 추가 인자로 전달됩니다. dry_run이
True
이면, 테스트 메서드에 전달된 값이 요청된 값보다 작을 수 있습니다. dry_run이False
이면,-M
가 지정되지 않은 경우 테스트가 더미 실행을 지원하지 않음을 의미합니다.
-
@
test.support.
bigaddrspacetest
(f)¶ 주소 공간을 채우는 테스트용 데코레이터. f는 래핑 할 함수입니다.
-
test.support.
make_bad_fd
()¶ 임시 파일을 여닫아서 잘못된 파일 기술자를 만든 다음, 그 기술자를 반환합니다.
-
test.support.
check_syntax_error
(testcase, statement, errtext='', *, lineno=None, offset=None)¶ statement 컴파일을 시도하여 statement의 구문 에러를 테스트합니다. testcase는 테스트를 위한
unittest
인스턴스입니다. errtext는 발생한SyntaxError
의 문자열 표현과 일치해야 하는 정규식입니다. lineno가None
이 아니면, 예외 줄과 비교합니다. offset이None
이 아니면, 예외의 오프셋과 비교합니다.
-
test.support.
check_syntax_warning
(testcase, statement, errtext='', *, lineno=1, offset=None)¶ statement 컴파일을 시도하여 statement에서 구문 경고를 테스트합니다.
SyntaxWarning
이 한 번만 방출되고, 에러로 바꿀 때SyntaxError
로 변환되는지도 테스트합니다. testcase는 테스트를 위한unittest
인스턴스입니다. errtext는 방출된SyntaxWarning
과 발생한SyntaxError
의 문자열 표현과 일치해야 하는 정규식입니다. lineno가None
이 아니면 경고와 예외 줄과 비교합니다. offset이None
이 아니면, 예외 오프셋과 비교합니다.버전 3.8에 추가.
-
test.support.
open_urlresource
(url, *args, **kw)¶ url을 엽니다. 열기에 실패하면,
TestFailed
를 발생시킵니다.
-
test.support.
import_module
(name, deprecated=False, *, required_on())¶ 이 함수는 명명된 모듈을 임포트하고 반환합니다. 일반 임포트와 달리, 이 함수는 모듈을 임포트할 수 없으면
unittest.SkipTest
를 발생시킵니다.deprecated가
True
이면 이 임포트 중에 모듈과 패키지 폐지 메시지가 억제됩니다. 모듈이 한 플랫폼에서는 필수지만, 다른 곳에서는 선택적이면, required_on을sys.platform
과 비교할 플랫폼 접두사의 이터러블로 설정합니다.버전 3.1에 추가.
-
test.support.
import_fresh_module
(name, fresh=(), blocked=(), deprecated=False)¶ 이 함수는 임포트 전에
sys.modules
에서 명명된 모듈을 제거하여 명명된 파이썬 모듈의 새 복사본을 임포트하고 반환합니다.reload()
와 달리, 원래 모듈은 이 연산의 영향을 받지 않습니다.fresh는 임포트를 수행하기 전에
sys.modules
캐시에서 함께 제거되는 추가 모듈 이름의 이터러블입니다.blocked는 임포트 하는 동안 모듈 캐시에서
None
으로 대체되는 모듈 이름의 이터러블로, 임포트 하려고 시도하면ImportError
가 발생하도록 합니다.명명된 모듈과 fresh와 blocked 매개 변수에 명명된 모든 모듈은 임포트를 시작하기 전에 보관되고 새 임포트가 완료되면
sys.modules
에 다시 삽입됩니다.deprecated가
True
이면 이 임포트 중에 모듈과 패키지 폐지 메시지가 억제됩니다.이 함수는 명명된 모듈을 임포트 할 수 없으면
ImportError
를 발생시킵니다.사용 예:
# Get copies of the warnings module for testing without affecting the # version being used by the rest of the test suite. One copy uses the # C implementation, the other is forced to use the pure Python fallback # implementation py_warnings = import_fresh_module('warnings', blocked=['_warnings']) c_warnings = import_fresh_module('warnings', fresh=['_warnings'])
버전 3.1에 추가.
-
test.support.
modules_setup
()¶ sys.modules
의 복사본을 반환합니다.
-
test.support.
modules_cleanup
(oldmodules)¶ 내부 캐시를 보존하기 위해 oldmodules와
encodings
를 제외한 모듈들을 제거합니다.
-
test.support.
threading_setup
()¶ 현재 스레드 수와 매달린(dangling) 스레드의 복사본을 반환합니다.
-
test.support.
threading_cleanup
(*original_values)¶ original_values에 지정되지 않은 스레드를 정리합니다. 테스트가 백그라운드에서 실행 중인 스레드를 남겨두면 경고를 내도록 설계되었습니다.
-
test.support.
join_thread
(thread, timeout=30.0)¶ timeout 내에 thread에 조인(join)합니다. 스레드가 timeout 초 후에도 여전히 살아 있으면
AssertionError
를 발생시킵니다.
-
test.support.
reap_children
()¶ 서브 프로세스가 시작될 때마다
test_main
끝에 이것을 사용하십시오. 이렇게 하면 여분의 자식(좀비)이 남아서 리소스를 탐하지 않도록 하고 참조 누수를 찾을 때 문제가 발생하지 않도록 할 수 있습니다.
-
test.support.
get_attribute
(obj, name)¶ 어트리뷰트를 가져옵니다,
AttributeError
가 발생하면unittest.SkipTest
를 발생시킵니다.
-
test.support.
catch_threading_exception
()¶ threading.excepthook()
을 사용하여threading.Thread
예외를 포착하는 컨텍스트 관리자.Attributes set when an exception is caught:
exc_type
exc_value
exc_traceback
thread
threading.excepthook()
설명서를 참조하십시오.이러한 어트리뷰트들은 컨텍스트 관리자 탈출 시에 삭제됩니다.
용법:
with support.catch_threading_exception() as cm: # code spawning a thread which raises an exception ... # check the thread exception, use cm attributes: # exc_type, exc_value, exc_traceback, thread ... # exc_type, exc_value, exc_traceback, thread attributes of cm no longer # exists at this point # (to avoid reference cycles)
버전 3.8에 추가.
-
test.support.
catch_unraisable_exception
()¶ sys.unraisablehook()
를 사용하여 발생시킬 수 없는(unraisable) 예외를 포착하는 컨텍스트 관리자.예외 값(
cm.unraisable.exc_value
)을 저장하면 참조 순환을 만듭니다. 컨텍스트 관리자가 탈출할 때 참조 순환이 명시적으로 끊어집니다.객체(
cm.unraisable.object
)를 저장하면 파이널라이즈 중인 객체로 설정되어 있으면 되살릴 수 있습니다. 컨텍스트 관리자를 탈출하면 저장된 객체가 지워집니다.용법:
with support.catch_unraisable_exception() as cm: # code creating an "unraisable exception" ... # check the unraisable exception: use cm.unraisable ... # cm.unraisable attribute no longer exists at this point # (to break a reference cycle)
버전 3.8에 추가.
-
test.support.
load_package_tests
(pkg_dir, loader, standard_tests, pattern)¶ 테스트 패키지에서 사용하기 위한
unittest
load_tests
프로토콜의 일반 구현. pkg_dir는 패키지의 루트 디렉터리입니다; loader, standard_tests 및 pattern은load_tests
가 기대하는 인자입니다. 간단한 경우, 테스트 패키지의__init__.py
는 다음과 같을 수 있습니다:import os from test.support import load_package_tests def load_tests(*args): return load_package_tests(os.path.dirname(__file__), *args)
-
test.support.
fs_is_case_insensitive
(directory)¶ directory의 파일 시스템이 대소 문자를 구분하지 않으면
True
를 반환합니다.
-
test.support.
detect_api_mismatch
(ref_api, other_api, *, ignore=())¶ ignore에 지정된 이 검사에서 무시할 정의된 항목 리스트를 제외하고, other_api에서 찾을 수 없는 ref_api의 어트리뷰트, 함수 또는 메서드 집합을 반환합니다.
기본적으로 이것은 ‘_’로 시작하는 내부(private) 어트리뷰트를 건너뛰지만, 모든 매직 메서드, 즉 ‘__’로 시작하고 끝나는 것들을 포함합니다.
버전 3.5에 추가.
-
test.support.
patch
(test_instance, object_to_patch, attr_name, new_value)¶ object_to_patch.attr_name을 new_value로 대체합니다. 또한 test_instance에 대한 정리 절차를 추가하여 object_to_patch의 attr_name을 복원합니다. attr_name은 object_to_patch의 유효한 어트리뷰트여야 합니다.
-
test.support.
run_in_subinterp
(code)¶ 서브 인터프리터에서 code를 실행합니다.
tracemalloc
이 활성화되면unittest.SkipTest
를 발생시킵니다.
-
test.support.
check_free_after_iterating
(test, iter, cls, args=())¶ 이터레이션 후 iter가 할당 해제되었음을 어서션 합니다.
-
test.support.
missing_compiler_executable
(cmd_names=[])¶ cmd_names에 이름이 나열된 컴파일러 실행 파일이나 cmd_names가 비어있을 때 모든 컴파일러 실행 파일이 있는지 확인하고 누락된 첫 번째 실행 파일을 반환하거나 누락된 것이 없으면
None
을 반환합니다.
-
test.support.
check__all__
(test_case, module, name_of_module=None, extra=(), blacklist=())¶ module의
__all__
변수에 모든 공용 이름이 포함되어 있는지 어서션 합니다.모듈의 공용 이름(그것의 API)은 공용 이름 규칙과 일치하고 module에 정의되었는지에 따라 자동으로 감지됩니다.
name_of_module 인자는 공용 API로 감지하기 위해 API를 정의 할 수 있는 모듈을 (문자열이나 튜플로) 지정할 수 있습니다. 이에 대한 한 가지 사례는 module이 다른 모듈에서 공용 API의 일부를 임포트 할 때입니다, C 백 엔드도 가능합니다 (
csv
와 그것의_csv
처럼).extra 인자는 적절한
__module__
어트리뷰트가 없는 객체처럼, “공용”으로 자동 감지되지 않는 이름 집합일 수 있습니다. 제공되면, 자동 감지된 항목에 추가됩니다.blacklist 인자는 이름이 공용처럼 보이더라도 공용 API의 일부로 취급해서는 안 되는 이름 집합일 수 있습니다.
사용 예:
import bar import foo import unittest from test import support class MiscTestCase(unittest.TestCase): def test__all__(self): support.check__all__(self, foo) class OtherTestCase(unittest.TestCase): def test__all__(self): extra = {'BAR_CONST', 'FOO_CONST'} blacklist = {'baz'} # Undocumented name. # bar imports part of its API from _bar. support.check__all__(self, bar, ('bar', '_bar'), extra=extra, blacklist=blacklist)
버전 3.6에 추가.
-
test.support.
adjust_int_max_str_digits
(max_digits)¶ This function returns a context manager that will change the global
sys.set_int_max_str_digits()
setting for the duration of the context to allow execution of test code that needs a different limit on the number of digits when converting between an integer and string.버전 3.9.14에 추가.
test.support
모듈은 다음 클래스를 정의합니다:
-
class
test.support.
TransientResource
(exc, **kwargs)¶ 인스턴스는 지정된 예외 형이 발생하면
ResourceDenied
를 발생시키는 컨텍스트 관리자입니다. 모든 키워드 인자는with
문 내에서 발생한 예외와 비교할 어트리뷰트/값 쌍으로 처리됩니다. 모든 쌍이 예외의 어트리뷰트와 올바르게 일치할 때만ResourceDenied
가 발생합니다.
-
class
test.support.
EnvironmentVarGuard
¶ 환경 변수를 임시로 설정하거나 설정 해제하는 데 사용되는 클래스. 인스턴스는 컨텍스트 관리자로 사용할 수 있으며 하부
os.environ
을 조회/수정하기 위한 완전한 딕셔너리 인터페이스를 가질 수 있습니다. 컨텍스트 관리자를 탈출하면 이 인스턴스를 통해 수행된 환경 변수에 대한 모든 변경 사항이 되돌려집니다.버전 3.1에서 변경: 딕셔너리 인터페이스가 추가되었습니다.
-
EnvironmentVarGuard.
set
(envvar, value)¶ 일시적으로 환경 변수
envvar
를value
값으로 설정합니다.
-
EnvironmentVarGuard.
unset
(envvar)¶ 일시적으로 환경 변수
envvar
를 설정 해제합니다.
-
class
test.support.
SuppressCrashReport
¶ 서브 프로세스를 충돌시킬 것으로 예상되는 테스트에서 충돌 대화 상자 팝업을 방지하는 데 사용되는 컨텍스트 관리자.
윈도우에서는, SetErrorMode를 사용하여 윈도우 에러 보고 대화 상자를 비활성화합니다.
유닉스에서는,
resource.setrlimit()
를 사용하여resource.RLIMIT_CORE
의 소프트 제한을 0으로 설정하여 코어 덤프 파일 생성을 방지하는 데 사용됩니다.두 플랫폼 모두에서, 이전 값은
__exit__()
에 의해 복원됩니다.
-
class
test.support.
CleanImport
(*module_names)¶ 새 모듈 참조를 반환하도록 임포트를 강제하는 컨텍스트 관리자. 이는 임포트 시 DeprecationWarning의 방출과 같은 모듈 수준 동작을 테스트하는 데 유용합니다. 사용 예:
with CleanImport('foo'): importlib.import_module('foo') # New reference.
-
class
test.support.
DirsOnSysPath
(*paths)¶ sys.path에 디렉터리를 임시로 추가하는 컨텍스트 관리자.
이렇게 하면
sys.path
의 복사본이 만들어지고, 위치 인자로 지정된 모든 디렉터리를 추가한 다음, 컨텍스트가 끝나면sys.path
를 복사된 설정으로 되돌립니다.객체 교체를 포함하여, 컨텍스트 관리자 본문의 모든
sys.path
수정 사항은 블록 끝에서 되돌려짐에 유의하십시오.
-
class
test.support.
SaveSignals
¶ 파이썬 시그널 처리기가 등록한 시그널 처리기를 저장하고 복원하는 클래스.
-
class
test.support.
Matcher
¶ -
matches
(self, d, **kwargs)¶ 단일 딕셔너리를 제공된 인자와 일치시키려고 합니다.
-
match_value
(self, k, dv, v)¶ 단일 저장된 값(dv)을 제공된 값(v)과 일치시키려고 합니다.
-
-
class
test.support.
WarningsRecorder
¶ 단위 테스트에 대한 경고를 기록하는 데 사용되는 클래스. 자세한 내용은 위의
check_warnings()
설명서를 참조하십시오.
test.support.socket_helper
— 소켓 테스트용 유틸리티¶
test.support.socket_helper
모듈은 소켓 테스트를 지원합니다.
버전 3.9에 추가.
-
test.support.socket_helper.
IPV6_ENABLED
¶ 이 호스트에서 IPv6가 활성화되어 있으면
True
로 설정하고, 그렇지 않으면False
로 설정합니다.
-
test.support.socket_helper.
find_unused_port
(family=socket.AF_INET, socktype=socket.SOCK_STREAM)¶ 바인딩에 적합해야 하는 미사용 포트를 반환합니다. 이는
sock
매개 변수와 같은 패밀리와 유형으로 (기본값은AF_INET
,SOCK_STREAM
) 임시 소켓을 만들고, 포트를 0으로 설정하여 지정된 호스트 주소(기본값은0.0.0.0
)에 바인딩하여, OS에서 사용되지 않은 임시 포트를 도출하여 수행됩니다. 그런 다음 임시 소켓이 닫히고 삭제되고, 임시 포트가 반환됩니다.이 메서드나
bind_port()
는 테스트 기간 중 서버 소켓을 특정 포트에 바인딩해야 하는 모든 테스트에 사용해야 합니다. 어떤 것을 사용할 것인지는 호출하는 코드가 파이썬 소켓을 만드는지, 또는 사용되지 않은 포트가 생성자에서 제공되어야 하는지 또는 외부 프로그램에 전달되어야 하는지 (즉 openssl의 s_server 모드에 대한-accept
인자)에 따라 다릅니다. 가능하면 항상find_unused_port()
보다bind_port()
를 선호하십시오. 하드 코딩된 포트를 사용하면 여러 테스트 인스턴스를 동시에 실행할 수 없게 되어 빌드 봇에 문제가 될 수 있어서 피하는 것이 좋습니다.
-
test.support.socket_helper.
bind_port
(sock, host=HOST)¶ 소켓을 사용 가능한 포트에 바인딩하고 포트 번호를 반환합니다. 바인딩 되지 않은 포트를 사용하기 위해 임시 포트에 의존합니다. 이는 특히 빌드 봇 환경에서, 많은 테스트가 동시에 실행될 수 있어서 중요합니다. 이 메서드는
sock.family
가AF_INET
이고sock.type
이SOCK_STREAM
이고, 소켓에SO_REUSEADDR
이나SO_REUSEPORT
가 설정되면 예외가 발생합니다. 테스트는 TCP/IP 소켓에 대해 이러한 소켓 옵션을 설정해서는 안 됩니다. 이러한 옵션을 설정하는 유일한 경우는 여러 UDP 소켓을 통해 멀티캐스팅을 테스트하는 것입니다.또한,
SO_EXCLUSIVEADDRUSE
소켓 옵션을 사용할 수 있으면 (즉 윈도우에서), 소켓에 설정됩니다. 이렇게 하면 다른 사람이 테스트 기간 중 우리의 호스트/포트에 바인딩하는 것을 방지할 수 있습니다.
-
test.support.socket_helper.
bind_unix_socket
(sock, addr)¶ 유닉스 소켓을 바인드 합니다,
PermissionError
가 발생하면unittest.SkipTest
를 발생시킵니다.
-
@
test.support.socket_helper.
skip_unless_bind_unix_socket
¶ 유닉스 소켓용
bind()
기능이 필요한 테스트를 실행하기 위한 데코레이터.
-
test.support.socket_helper.
transient_internet
(resource_name, *, timeout=30.0, errnos=())¶ 인터넷 연결과 관련된 다양한 문제가 예외로 나타날 때
ResourceDenied
를 발생시키는 컨텍스트 관리자.
test.support.script_helper
— 파이썬 실행 테스트용 유틸리티¶
test.support.script_helper
모듈은 파이썬의 스크립트 실행 테스트를 지원합니다.
-
test.support.script_helper.
interpreter_requires_environment
()¶ sys.executable 인터프리터
를 실행하기 위해 환경 변수가 필요하면True
를 반환합니다.assert_python*()
함수를 사용하여 격리 모드(-I
)를 시작하거나 환경 없음 모드(-E
) 서브 인터프리터 프로세스를 시작해야 하는 테스트를 어노테이트 하는@unittest.skipIf()
와 함께 사용하도록 설계되었습니다.정상적인 빌드와 테스트는 이러한 상황을 만나지 않지만, 파이썬의 현재 홈 찾기 논리로 명확한 홈이 없는 인터프리터에서 표준 라이브러리 테스트 스위트를 실행하려고 할 때 발생할 수 있습니다.
PYTHONHOME
설정은 이러한 상황에서 대부분의 테스트 스위트를 실행하는 한 가지 방법입니다.PYTHONPATH
나PYTHONUSERSITE
는 인터프리터가 시작될 수 있는지에 영향을 줄 수 있는 다른 공통 환경 변수입니다.
-
test.support.script_helper.
run_python_until_end
(*args, **env_vars)¶ 서브 프로세스에서 인터프리터를 실행하기 위해 env_vars 기반 환경을 설정합니다. 값에는
__isolated
,__cleanenv
,__cwd
및TERM
이 포함될 수 있습니다.버전 3.9에서 변경: 이 함수는 더는 stderr에서 공백을 제거하지 않습니다.
-
test.support.script_helper.
assert_python_ok
(*args, **env_vars)¶ args와 선택적 환경 변수 env_vars를 사용하여 인터프리터를 실행하면 성공(
rc == 0
)하고(return code, stdout, stderr)
튜플을 반환함을 어서션 합니다.__cleanenv
키워드가 설정되면, env_vars가 새로운 환경으로 사용됩니다.파이썬은
__isolated
키워드가False
로 설정된 경우를 제외하고, 격리 모드(명령 줄 옵션-I
)에서 시작됩니다.버전 3.9에서 변경: 이 함수는 더는 stderr에서 공백을 제거하지 않습니다.
-
test.support.script_helper.
assert_python_failure
(*args, **env_vars)¶ args와 선택적 환경 변수 env_vars를 사용하여 인터프리터 실행하면 실패(
rc != 0
)하고(return code, stdout, stderr)
튜플을 반환함을 어서션 합니다.추가 옵션은
assert_python_ok()
를 참조하십시오.버전 3.9에서 변경: 이 함수는 더는 stderr에서 공백을 제거하지 않습니다.
-
test.support.script_helper.
spawn_python
(*args, stdout=subprocess.PIPE, stderr=subprocess.STDOUT, **kw)¶ 주어진 인자로 파이썬 서브 프로세스를 실행합니다.
kw는
subprocess.Popen()
에 전달할 추가 키워드 인자입니다.subprocess.Popen
객체를 반환합니다.
-
test.support.script_helper.
kill_python
(p)¶ 완료될 때까지 주어진
subprocess.Popen
프로세스를 실행하고 stdout을 반환합니다.
-
test.support.script_helper.
make_script
(script_dir, script_basename, source, omit_suffix=False)¶ script_dir과 script_basename 경로에 source를 포함하는 스크립트를 만듭니다. omit_suffix가
False
이면, 이름에.py
를 추가합니다. 전체 스크립트 경로를 반환합니다.
-
test.support.script_helper.
make_zip_script
(zip_dir, zip_basename, script_name, name_in_zip=None)¶ script_name의 파일을 포함하는 확장자가
zip
인 zip 파일을 zip_dir과 zip_basename에 만듭니다. name_in_zip은 아카이브 이름입니다.(full path, full path of archive name)
을 포함하는 튜플을 반환합니다.
-
test.support.script_helper.
make_pkg
(pkg_dir, init_source='')¶ init_source를 내용으로 하는
__init__
파일을 포함하는 pkg_dir이라는 디렉터리를 만듭니다.
-
test.support.script_helper.
make_zip_pkg
(zip_dir, zip_basename, pkg_name, script_basename, source, depth=1, compiled=False)¶ 빈
__init__
파일과 source를 포함하는 파일 script_basename을 포함하는 zip 패키지 디렉터리를 zip_dir과 zip_basename 경로로 만듭니다. compiled가True
이면, 두 소스 파일이 모두 컴파일되어 zip 패키지에 추가됩니다. 전체 zip 경로와 zip 파일의 아카이브 이름의 튜플을 반환합니다.
test.support.bytecode_helper
— 올바른 바이트 코드 생성 테스트를 위한 지원 도구¶
test.support.bytecode_helper
모듈은 바이트 코드 생성 테스트와 검사를 지원합니다.
버전 3.9에 추가.
모듈은 다음 클래스를 정의합니다:
-
class
test.support.bytecode_helper.
BytecodeTestCase
(unittest.TestCase)¶ 이 클래스에는 바이트 코드를 검사하기 위한 사용자 정의 어서션 메서드가 있습니다.
-
BytecodeTestCase.
get_disassembly_as_string
(co)¶ co의 역 어셈블리를 문자열로 반환합니다.
-
BytecodeTestCase.
assertInBytecode
(x, opname, argval=_UNSPECIFIED)¶ opname이 발견되면 명령어를 반환하고, 그렇지 않으면
AssertionError
를 던집니다.
-
BytecodeTestCase.
assertNotInBytecode
(x, opname, argval=_UNSPECIFIED)¶ opname이 발견되면
AssertionError
를 던집니다.