trace
— 파이썬 문장 실행 추적¶
소스 코드: Lib/trace.py
trace
모듈을 사용하면 프로그램 실행을 추적하고, 주석 처리된 문장 커버리지 리스트를 생성하고, 호출자/피호출자 관계를 인쇄하고, 프로그램 실행 중 호출되는 함수를 나열할 수 있습니다. 다른 프로그램이나 명령 줄에서 사용할 수 있습니다.
더 보기
- Coverage.py
브랜치 커버리지와 같은 고급 기능과 함께 HTML 출력을 제공하는 널리 사용되는 제삼자 커버리지 도구.
명령 줄 사용법¶
trace
모듈은 명령 줄에서 호출할 수 있습니다. 다음과 같이 간단할 수도 있습니다
python -m trace --count -C . somefile.py ...
이것은 somefile.py
를 실행하고 실행 중에 임포트 한 모든 파이썬 모듈들의 주석이 달린 리스트를 현재 디렉터리에 생성합니다.
-
--help
¶
사용법을 표시하고 종료합니다.
-
--version
¶
모듈의 버전을 표시하고 종료합니다.
주요 옵션¶
trace
를 호출할 때 다음 옵션 중 적어도 하나를 지정해야 합니다. --listfuncs
옵션은 --trace
나 --count
옵션과 함께 사용할 수 없습니다. --listfuncs
이 제공되면, --count
나 --trace
는 허용되지 않으며, 반대의 경우도 마찬가지입니다.
-
-c
,
--count
¶
프로그램 완료 시 각 문장이 실행된 횟수를 보여주는 주석이 달린 리스팅 파일 집합을 생성합니다. 아래의
--coverdir
,--file
및--no-report
도 참조하십시오.
-
-t
,
--trace
¶
줄이 실행될 때마다 표시합니다.
-
-l
,
--listfuncs
¶
프로그램을 실행하여 실행되는 함수들을 표시합니다.
-
-T
,
--trackcalls
¶
프로그램을 실행하여 노출된 호출 관계를 표시합니다.
수정자¶
-
-C
,
--coverdir
=<dir>
¶ 보고서 파일이 저장되는 디렉터리.
package.module
에 대한 커버리지 보고서는dir/package/module.cover
파일에 기록됩니다.
-
-m
,
--missing
¶
주석이 달린 리스팅을 작성할 때,
>>>>>>
로 실행되지 않은 줄을 표시합니다.
-
-R
,
--no-report
¶
주석이 달린 리스팅을 생성하지 않습니다. 이것은
--count
를 사용하여 여러 번 실행한 다음, 마지막에 주석이 달린 리스팅의 단일 집합을 생성하려고 할 때 유용합니다.
-
-g
,
--timing
¶
프로그램이 시작된 이후의 시간을 각 줄 앞에 붙입니다. 추적하는 동안에만 사용됩니다.
필터¶
이 옵션들은 여러 번 반복 될 수 있습니다.
-
--ignore-module
=<mod>
¶ 주어진 각 모듈 이름과 (패키지라면) 그 서브 모듈을 무시합니다. 인자는 쉼표로 구분된 이름 목록일 수 있습니다.
-
--ignore-dir
=<dir>
¶ 명명된 디렉터리와 하위 디렉터리의 모든 모듈과 패키지를 무시합니다. 인자는
os.pathsep
으로 구분된 디렉터리 목록일 수 있습니다.
프로그래밍 인터페이스¶
-
class
trace.
Trace
(count=1, trace=1, countfuncs=0, countcallers=0, ignoremods=(), ignoredirs=(), infile=None, outfile=None, timing=False)¶ 단일 문장이나 표현식의 실행을 추적할 객체를 만듭니다. 모든 매개 변수는 선택 사항입니다. count는 줄 번호의 카운팅을 활성화합니다. trace는 줄 실행 추적을 활성화합니다. countfuncs는 실행 중에 호출된 함수들의 리스팅을 활성화합니다. countcallers는 호출 관계 추적을 활성화합니다. ignoremods는 무시할 모듈이나 패키지의 리스트입니다. ignoredirs는 들어있는 모듈이나 패키지를 무시해야 하는 디렉터리의 리스트입니다. infile은 저장된 카운트 정보를 읽을 파일 이름입니다. outfile는 갱신된 카운트 정보를 쓰는 파일의 이름입니다. timing는 추적이 시작될 때에 상대적인 타임스탬프 표시를 활성화합니다.
-
runctx
(cmd, globals=None, locals=None)¶ 정의된 전역과 지역 환경에서, 명령을 실행하고 현재 추적 매개 변수를 사용하여 실행에서 통계를 수집합니다. 정의되지 않으면, globals 와 locals의 기본값은 빈 딕셔너리입니다.
-
results
()¶ 주어진
Trace
인스턴스에 대한 모든 이전run
,runctx
및runfunc
호출의 누적 결과를 포함하는CoverageResults
객체를 반환합니다. 누적된 추적 결과를 재설정하지 않습니다.
-
-
class
trace.
CoverageResults
¶ Trace.results()
에 의해 만들어진 커버리지 결과를 위한 컨테이너. 사용자가 직접 만들어서는 안 됩니다.-
update
(other)¶ 다른
CoverageResults
객체의 데이터를 병합합니다.
-
write_results
(show_missing=True, summary=False, coverdir=None)¶ 커버리지 결과를 기록합니다. 실행 카운트가 없는 줄을 표시하려면 show_missing을 설정하십시오. 모듈당 커버리지 요약을 출력에 포함 시키려면 summary를 설정하십시오. coverdir은 커버리지 결과 파일이 출력될 디렉터리를 지정합니다.
None
이면, 각 소스 파일의 결과가 해당 디렉터리에 위치합니다.
-
프로그래밍 인터페이스의 사용을 보여주는 간단한 예제:
import sys
import trace
# create a Trace object, telling it what to ignore, and whether to
# do tracing or line-counting or both.
tracer = trace.Trace(
ignoredirs=[sys.prefix, sys.exec_prefix],
trace=0,
count=1)
# run the new command using the given tracer
tracer.run('main()')
# make a report, placing output in the current directory
r = tracer.results()
r.write_results(show_missing=True, coverdir=".")