인터넷 회사가 계속 성장함에 따라 소프트웨어 개발은 점점 더 복잡해지고 테스트는 점점 더 중요해집니다. 프로그램의 정확성과 안정성을 보장하기 위해서는 다양한 형태의 테스트를 수행해야 합니다. 그 중 자동화된 테스트는 테스트 작업의 효율성을 높이고, 오류율을 줄이고, 테스트 케이스를 반복적으로 실행하여 문제를 조기에 발견할 수 있는 매우 중요한 방법입니다. , 테스트 도구 선택, 테스트 케이스 작성, 테스트 환경 설정 등의 문제.
go-zero는 Go 언어의 기본 표준 라이브러리를 기반으로 개발되었으며 동시에 고성능 분산 API 서비스의 빠른 구축을 지원하는 오픈 소스 Go 언어 프레임워크입니다. 매우 풍부한 테스트 지원 기능은 API 서비스의 자동화된 비파괴 테스트를 실현하는 데 도움이 되며 자동화된 테스트 프로세스에서 많은 어려움을 극복할 수 있습니다.
이 글에서는 go-zero의 테스트 지원 기능부터 시작하여 go-zero를 사용하여 API 서비스의 자동화된 비파괴 테스트를 구현하는 방법을 자세히 소개합니다.
1. go-zero의 테스트 지원 기능
go-zero는 단위 테스트, HTTP 테스트, 통합 테스트, 성능 테스트, 서버 측 테스트 등 다양한 테스트 지원 기능을 제공합니다. 그 중 통합 테스트는 go-zero의 테스트 지원 기능 중 매우 중요한 부분입니다.
go-zero의 통합 테스트는 플러그형 방식을 채택하고 다양한 테스트 도구를 지원하여 특정 요구 사항에 따라 테스트할 수 있습니다. 현재 지원되는 테스트 도구로는 webtest, postman, Resty 등이 있습니다.
2. API 서비스의 자동화된 비파괴 테스트를 위해 go-zero를 사용하세요
다음으로 예시를 사용하여 go-zero의 통합 테스트를 사용하여 API 서비스의 자동화된 비파괴 테스트를 수행하는 방법을 보여드리겠습니다.
통합 테스트를 진행하기 전에 먼저 테스트 환경을 구성해야 합니다. 이 예에서는 docker-compose를 사용하여 환경을 구축합니다. 구성 파일은 다음과 같습니다.
version: '3' services: api: image: your-api-image:latest ports: - "8888:8888" environment: - MYSQL_DSN=root:@tcp(mysql:3306)/test - REDIS_DSN=redis:6379 - REDIS_KEY_PREFIX=test - SERVICE_PORT=8888 depends_on: - mysql - redis mysql: image: mysql:5.7 restart: always environment: MYSQL_ROOT_PASSWORD: '' volumes: - ./docker/mysql:/docker-entrypoint-initdb.d - ./docker/mysql/data:/var/lib/mysql redis: image: redis:3.2 restart: always volumes: - ./docker/redis:/data command: redis-server --appendonly yes
위 구성 파일에는 API 서비스, MySQL 데이터베이스, Redis 캐시라는 세 가지 서비스가 정의되어 있습니다. API 서비스는 포트 8888을 노출해야 하며 MySQL 데이터베이스 및 Redis 캐시를 사용합니다.
테스트 환경을 구성한 후에는 테스트 케이스를 작성해야 합니다. 이 예에서는 테스트를 위해 webtest를 사용합니다. Webtest는 HTTP 프로토콜과 WebSocket 프로토콜을 지원하는 웹 애플리케이션용 테스트 프레임워크입니다. 이는 HTTP 요청 및 응답을 시뮬레이션하고 요청 및 응답 내용이 기대치를 충족하는지 확인할 수 있는 풍부한 API를 제공합니다.
다음은 webtest를 사용하여 테스트 사례를 작성하는 예입니다.
import ( "testing" "github.com/stretchr/testify/assert" "github.com/franktrue/grpc-demo/api" "github.com/franktrue/grpc-demo/internal/config" "github.com/franktrue/grpc-demo/internal/server" "github.com/franktrue/grpc-demo/internal/svc" ) func TestCreateUser(t *testing.T) { cfg := config.TestConfig() s := server.NewServer(cfg) defer s.Stop() testCases := []struct { name string req *api.CreateUserRequest expectErr bool }{ { name: "test createUser success", req: &api.CreateUserRequest{ Name: "testUser", Age: 20, }, expectErr: false, }, { name: "test createUser failed", req: &api.CreateUserRequest{ Name: "", Age: 20, }, expectErr: true, }, } for _, tc := range testCases { resp, err := s.CreateUser(nil, tc.req) if tc.expectErr { assert.NotNil(t, err, tc.name) } else { assert.Nil(t, err, tc.name) assert.NotNil(t, resp, tc.name) } } }
위 코드에서는 어설션을 위해 testify 프레임워크를 사용합니다. 테스트 사례의 for 루프에서 두 가지 테스트 사례를 각각 테스트합니다. 예상되는 결과는 첫 번째 사용 사례에서는 사용자를 성공적으로 생성할 수 있지만 두 번째 사용 사례에서는 잘못된 매개 변수로 인해 실패한다는 것입니다. 테스트 케이스가 기대와 일치하면 어설션이 통과되고, 테스트 케이스가 기대와 일치하지 않으면 어설션이 실패합니다.
테스트 케이스를 작성한 후 go test 명령을 사용하여 테스트 케이스를 실행할 수 있습니다.
go test -v ./tests/users_test.go
테스트 케이스를 실행한 후 터미널에서 실행 결과를 볼 수 있습니다. 테스트 케이스가 성공적으로 실행되면 OK 결과가 출력되고, 테스트 케이스가 실패하면 자세한 오류 정보가 출력됩니다.
이를 통해 우리는 API 서비스의 자동화된 비파괴 테스트를 완료했으며, 그 과정에서 go-zero의 강력한 테스트 지원 기능과 웹 테스트 테스트 프레임워크의 사용 편의성 및 유연성을 최대한 활용했습니다. API 서비스의 정확성은 확실한 보장을 제공합니다.
위 내용은 Go-Zero 통합 테스트: API 서비스의 자동화된 비파괴 테스트 실현의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!