>백엔드 개발 >Golang >명세서가 커버되지 않은 경우 테스트 커버리지로 이동

명세서가 커버되지 않은 경우 테스트 커버리지로 이동

WBOY
WBOY앞으로
2024-02-11 10:36:081061검색

명세서가 커버되지 않은 경우 테스트 커버리지로 이동

php 편집기 Baicao는 오늘 커버리지 테스트 방법을 소개합니다. 소프트웨어 개발 과정에서 테스트 커버리지는 테스트 케이스별 코드 커버리지 정도를 평가하는 데 도움이 되는 중요한 지표입니다. 그리고 다루지 않은 내용이 있는 경우에는 어떤 방법을 통해 이 문제를 해결할 수 있습니다. 이 글에서는 커버리지를 테스트하는 방법과 발견되지 않은 진술을 처리하는 방법을 살펴보겠습니다.

질문 내용

setupConfig()라는 go 함수가 있고 이를 테스트할 Test_setupconfig가 있는데 잘 테스트됩니다. 그러나 적용 범위를 테스트하고 HTML 보고서를 살펴보니 Viper 패키지에서 반환된 일부 오류에 대한 처리가 포함되지 않은 것으로 나타났습니다. 왜 이것이 다루어지지 않습니까? 이 문제를 어떻게 처리해야 합니까?

해결 방법

적용 범위 보고서는 테스트 중에 실행된 코드의 양을 알려줍니다. 여러분이 보고 있는 것은 이러한 if 块中的 return 문이 테스트되지 않았다는 것입니다. 즉, 실패하고 오류를 반환하도록 설계된 단위 테스트가 없다는 의미입니다. 올바른 입력이 주어졌을 때 코드가 작동하는지 테스트하는 동안 잘못된 입력이 주어졌을 때 테스트가 정확하고 안전하게 실패하는지 확인하는 것도 중요합니다.

그러나 이러한 오류는 자체 패키지에 있지 않고 viper 包。此时,重要的是要问自己一个问题“我真正测试的是什么?”。如果您使用 viper 包,那么假设该包经过了彻底的测试,并且通过为 viper 错误创建您自己的测试,您只是在这些测试上加倍,而没有真正的改进。出于这个原因,有时我们选择省略测试这些分支,因为实际上,如果 viper 包错误 - 并假设您的所有输入都是静态的并且像所示的那样进行硬编码 - 那么这不是您的代码的问题,而是 viper 라이브러리 문제로 인해 발생하기 때문에 이는 이상한 상황입니다.

만약 정말로 100% 적용 범위를 얻고 모든 결정 트리를 테스트하고 싶다면, 유일한 방법은 추상화 뒤에 viper 패키지를 두는 것입니다. 아마도 이는 함수에 전달된 인터페이스이므로 프로덕션에서 실행 중이든 테스트 중이든 여러 구현이 가능합니다.

단, 이와 같은 함수의 모든 값을 하드코딩하는 것은 권장되지 않습니다. 이상적으로는 구성 구조의 값이 로컬 구성 파일, 환경 변수, 명령줄 플래그 또는 이들의 조합에서 나오길 원합니다. 이렇게 하면 이 설정 함수가 구성을 검색하기 위한 인터페이스를 허용하게 되어 함수를 쉽게 테스트할 수 있게 됩니다. 왜냐하면 테스트에서 인터페이스 구현을 모의하기만 하면 되기 때문입니다. 그러면 다음과 같이 보일 것입니다:

config.go

으아아아

config_test.go

으아아아

이 작업을 수행하고 setupConfig() 함수에 대한 승인 인터페이스를 제공하면 프로덕션에서 실행할 때 함수 구현을 제공할 수 있을 뿐만 아니라 테스트를 실행할 때 하드코딩된 테스트 데이터를 사용하여 시뮬레이션할 수도 있습니다. 데이터베이스와 같은 다른 서비스와 상호 작용할 때도 자주 사용됩니다. 테스트를 실행할 때 데이터베이스를 시작하고 연결하는 대신 데이터베이스와 상호 작용하고 테스트에서 시뮬레이션하는 방법을 알려주는 인터페이스를 코드에서 허용하도록 할 수 있습니다. 이를 통해 코드의 일부를 분리하고 원하는 것만 테스트할 수 있습니다.

위 내용은 명세서가 커버되지 않은 경우 테스트 커버리지로 이동의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
이 기사는 stackoverflow.com에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제