test — 파이썬 용 회귀 테스트 패키지

참고

test 패키지는 파이썬 내부 용으로만 사용됩니다. 파이썬의 핵심 개발자를 위해 설명됩니다. 여기에 언급된 코드는 파이썬 릴리스 사이에 예고 없이 변경되거나 제거될 수 있어서, 파이썬의 표준 라이브러리 외부에서 이 패키지를 사용하는 것은 권장되지 않습니다.


test 패키지에는 test.supporttest.regrtest뿐만 아니라 파이썬에 대한 모든 회귀 테스트가 포함되어 있습니다. test.support는 테스트를 향상하는 데 사용되며 test.regrtest는 테스트 스위트를 구동합니다.

이름이 test_로 시작하는 test 패키지의 각 모듈은 특정 모듈이나 기능에 대한 테스트 스위트입니다. 모든 새로운 테스트는 unittestdoctest 모듈을 사용하여 작성해야 합니다. 일부 오래된 테스트는 sys.stdout으로 인쇄된 출력을 비교하는 “전통적인” 테스트 스타일을 사용하여 작성되었습니다; 이 테스트 스타일은 폐지된 것으로 간주합니다.

더 보기

모듈 unittest

PyUnit 회귀 테스트 작성.

모듈 doctest

독스트링에 포함된 테스트.

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 명령은 audiolargefile 리소스를 제외한 모든 리소스로 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. 실행 중인 테스트에 대한 자세한 정보가 필요할 때 확인해야 합니다. verbosetest.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.socketconnect(), 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_TIMEOUTSHORT_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.NEVER_EQ

어떤 것과도 같지 않은 객체 (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을 삭제합니다.

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를 발생시킵니다. msgResourceDenied가 발생한다면 이에 대한 인자입니다. __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)

testset_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)를 반환합니다.

verbosityNone이면, doctest.testmod()는 상세도를 verbose로 설정하여 실행됩니다. 그렇지 않으면 상세도를 None으로 설정하여 실행됩니다. optionflagsoptionflagsdoctest.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가 제공되거나, 선택적 키워드 인자 quietFalse이면, 경고가 예상대로인지 확인합니다: 지정된 각 필터는 둘러싸인 코드에서 발생한 경고 중 적어도 하나와 일치해야 합니다. 그렇지 않으면 테스트가 실패합니다. 지정된 필터와 일치하지 않는 경고가 발생하면 테스트가 실패합니다. 첫 번째 검사를 비활성화하려면, quietTrue로 설정합니다.

인자가 지정되지 않으면, 기본값은 다음과 같습니다:

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에서 변경: 새로운 선택적 인자 filtersquiet.

test.support.check_no_resource_warning(testcase)

ResourceWarning이 발생하지 않았는지 확인하는 컨텍스트 관리자. 컨텍스트 관리자가 끝나기 전에 ResourceWarning을 방출할 수 있는 객체를 제거해야 합니다.

test.support.set_memlimit(limit)

대용량 메모리 테스트를 위해 max_memusereal_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.flagssys.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에 임시 디렉터리를 만들고 그 디렉터리를 산출하는 컨텍스트 관리자.

pathNone이면, 임시 디렉터리는 tempfile.mkdtemp()를 사용하여 만들어집니다. quietFalse이면, 컨텍스트 관리자는 에러 시 예외를 발생시킵니다. 그렇지 않으면, path가 지정되고 만들 수 없으면, 경고만 발행됩니다.

test.support.change_cwd(path, quiet=False)

현재 작업 디렉터리를 path로 일시적으로 변경하고 그 디렉터리를 산출하는 컨텍스트 관리자.

quietFalse이면, 컨텍스트 관리자는 에러 시 예외를 발생시킵니다. 그렇지 않으면, 경고만 발행하고 현재 작업 디렉터리를 같게 유지합니다.

test.support.temp_cwd(name='tempcwd', quiet=False)

임시로 새 디렉터리를 만들고 현재 작업 디렉터리(CWD)를 변경하는 컨텍스트 관리자.

컨텍스트 관리자는 현재 작업 디렉터리를 임시로 변경하기 전에 이름이 name인 임시 디렉터리를 현재 디렉터리에 만듭니다. nameNone이면, 임시 디렉터리는 tempfile.mkdtemp()를 사용하여 만들어집니다.

quietFalse이고 만들 수 없거나 CWD를 변경할 수 없으면, 에러가 발생합니다. 그렇지 않으면, 경고만 발생하고 원래 CWD가 사용됩니다.

test.support.temp_umask(umask)

프로세스 umask를 임시로 설정하는 컨텍스트 관리자.

test.support.disable_faulthandler()

sys.stderrsys.__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로 설정되고, 블록 끝에서 이전 값이 복원됩니다. objattr이 없으면, 만들어지고 블록의 끝에서 삭제됩니다.

이전 값(또는 존재하지 않으면 None)이 “as” 절의 대상(있다면)에 대입됩니다.

test.support.swap_item(obj, attr, new_val)

항목을 새 객체로 스와프하는 컨텍스트 관리자.

용법:

with swap_item(obj, "item", 5):
    ...

이렇게 하면 with 블록의 기간 중 obj["item"]이 5로 설정되고, 블록 끝에서 이전 값이 복원됩니다. objitem이 없으면, 만들어지고 블록의 끝에서 삭제됩니다.

이전 값(또는 존재하지 않으면 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에 대해, osys.getsizeof에 GC 헤더 크기를 더한 값이 size와 같다고 어서션 합니다.

OS가 심볼릭 링크를 지원하면 True를, 그렇지 않으면 False를 반환합니다.

test.support.can_xattr()

OS가 xattr을 지원하면 True를, 그렇지 않으면 False를 반환합니다.

심볼릭 링크 지원이 필요한 테스트를 실행하기 위한 데코레이터.

@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_zlib

zlib가 없으면 테스트를 건너뛰는 데코레이터.

@test.support.requires_gzip

gzip이 없으면 테스트를 건너뛰는 데코레이터.

@test.support.requires_bz2

bz2가 없으면 테스트를 건너뛰는 데코레이터.

@test.support.requires_lzma

lzma가 없으면 테스트를 건너뛰는 데코레이터.

@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)

guardscheck_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_runTrue이면, 테스트 메서드에 전달된 값이 요청된 값보다 작을 수 있습니다. dry_runFalse이면, -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의 문자열 표현과 일치해야 하는 정규식입니다. linenoNone이 아니면, 예외 줄과 비교합니다. offsetNone이 아니면, 예외의 오프셋과 비교합니다.

test.support.check_syntax_warning(testcase, statement, errtext='', *, lineno=1, offset=None)

statement 컴파일을 시도하여 statement에서 구문 경고를 테스트합니다. SyntaxWarning이 한 번만 방출되고, 에러로 바꿀 때 SyntaxError로 변환되는지도 테스트합니다. testcase는 테스트를 위한 unittest 인스턴스입니다. errtext는 방출된 SyntaxWarning과 발생한 SyntaxError의 문자열 표현과 일치해야 하는 정규식입니다. linenoNone이 아니면 경고와 예외 줄과 비교합니다. offsetNone이 아니면, 예외 오프셋과 비교합니다.

버전 3.8에 추가.

test.support.open_urlresource(url, *args, **kw)

url을 엽니다. 열기에 실패하면, TestFailed를 발생시킵니다.

test.support.import_module(name, deprecated=False, *, required_on())

이 함수는 명명된 모듈을 임포트하고 반환합니다. 일반 임포트와 달리, 이 함수는 모듈을 임포트할 수 없으면 unittest.SkipTest를 발생시킵니다.

deprecatedTrue이면 이 임포트 중에 모듈과 패키지 폐지 메시지가 억제됩니다. 모듈이 한 플랫폼에서는 필수지만, 다른 곳에서는 선택적이면, required_onsys.platform과 비교할 플랫폼 접두사의 이터러블로 설정합니다.

버전 3.1에 추가.

test.support.import_fresh_module(name, fresh=(), blocked=(), deprecated=False)

이 함수는 임포트 전에 sys.modules에서 명명된 모듈을 제거하여 명명된 파이썬 모듈의 새 복사본을 임포트하고 반환합니다. reload()와 달리, 원래 모듈은 이 연산의 영향을 받지 않습니다.

fresh는 임포트를 수행하기 전에 sys.modules 캐시에서 함께 제거되는 추가 모듈 이름의 이터러블입니다.

blocked는 임포트 하는 동안 모듈 캐시에서 None으로 대체되는 모듈 이름의 이터러블로, 임포트 하려고 시도하면 ImportError가 발생하도록 합니다.

명명된 모듈과 freshblocked 매개 변수에 명명된 모든 모듈은 임포트를 시작하기 전에 보관되고 새 임포트가 완료되면 sys.modules에 다시 삽입됩니다.

deprecatedTrue이면 이 임포트 중에 모듈과 패키지 폐지 메시지가 억제됩니다.

이 함수는 명명된 모듈을 임포트 할 수 없으면 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)

내부 캐시를 보존하기 위해 oldmodulesencodings를 제외한 모듈들을 제거합니다.

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_testspatternload_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_namenew_value로 대체합니다. 또한 test_instance에 대한 정리 절차를 추가하여 object_to_patchattr_name을 복원합니다. attr_nameobject_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)

일시적으로 환경 변수 envvarvalue 값으로 설정합니다.

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() 설명서를 참조하십시오.

class test.support.BasicTestRunner
run(test)

test를 실행하고 결과를 반환합니다.

class test.support.FakePath(path)

단순 경로류 객체. 단지 path 인자를 반환하는 __fspath__() 메서드를 구현합니다. path가 예외이면, __fspath__()에서 발생시킵니다.

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.familyAF_INET이고 sock.typeSOCK_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 설정은 이러한 상황에서 대부분의 테스트 스위트를 실행하는 한 가지 방법입니다. PYTHONPATHPYTHONUSERSITE는 인터프리터가 시작될 수 있는지에 영향을 줄 수 있는 다른 공통 환경 변수입니다.

test.support.script_helper.run_python_until_end(*args, **env_vars)

서브 프로세스에서 인터프리터를 실행하기 위해 env_vars 기반 환경을 설정합니다. 값에는 __isolated, __cleanenv, __cwdTERM이 포함될 수 있습니다.

버전 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)

주어진 인자로 파이썬 서브 프로세스를 실행합니다.

kwsubprocess.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_dirscript_basename 경로에 source를 포함하는 스크립트를 만듭니다. omit_suffixFalse이면, 이름에 .py를 추가합니다. 전체 스크립트 경로를 반환합니다.

test.support.script_helper.make_zip_script(zip_dir, zip_basename, script_name, name_in_zip=None)

script_name의 파일을 포함하는 확장자가 zip인 zip 파일을 zip_dirzip_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_dirzip_basename 경로로 만듭니다. compiledTrue이면, 두 소스 파일이 모두 컴파일되어 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를 던집니다.