>백엔드 개발 >Golang >Go-Zero 통합 테스트: API 서비스의 자동화된 비파괴 테스트 실현

Go-Zero 통합 테스트: API 서비스의 자동화된 비파괴 테스트 실현

王林
王林원래의
2023-06-22 14:06:291043검색

인터넷 회사가 계속 성장함에 따라 소프트웨어 개발은 ​​점점 더 복잡해지고 테스트는 점점 더 중요해집니다. 프로그램의 정확성과 안정성을 보장하기 위해서는 다양한 형태의 테스트를 수행해야 합니다. 그 중 자동화된 테스트는 테스트 작업의 효율성을 높이고, 오류율을 줄이고, 테스트 케이스를 반복적으로 실행하여 문제를 조기에 발견할 수 있는 매우 중요한 방법입니다. , 테스트 도구 선택, 테스트 케이스 작성, 테스트 환경 설정 등의 문제.

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 서비스의 자동화된 비파괴 테스트를 수행하는 방법을 보여드리겠습니다.

  1. 테스트 환경 구성

통합 테스트를 진행하기 전에 먼저 테스트 환경을 구성해야 합니다. 이 예에서는 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 캐시를 사용합니다.

  1. 테스트 케이스 작성

테스트 환경을 구성한 후에는 테스트 케이스를 작성해야 합니다. 이 예에서는 테스트를 위해 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 루프에서 두 가지 테스트 사례를 각각 테스트합니다. 예상되는 결과는 첫 번째 사용 사례에서는 사용자를 성공적으로 생성할 수 있지만 두 번째 사용 사례에서는 잘못된 매개 변수로 인해 실패한다는 것입니다. 테스트 케이스가 기대와 일치하면 어설션이 통과되고, 테스트 케이스가 기대와 일치하지 않으면 어설션이 실패합니다.

  1. 테스트 케이스 실행

테스트 케이스를 작성한 후 go test 명령을 사용하여 테스트 케이스를 실행할 수 있습니다.

go test -v ./tests/users_test.go

테스트 케이스를 실행한 후 터미널에서 실행 결과를 볼 수 있습니다. 테스트 케이스가 성공적으로 실행되면 OK 결과가 출력되고, 테스트 케이스가 실패하면 자세한 오류 정보가 출력됩니다.

이를 통해 우리는 API 서비스의 자동화된 비파괴 테스트를 완료했으며, 그 과정에서 go-zero의 강력한 테스트 지원 기능과 웹 테스트 테스트 프레임워크의 사용 편의성 및 유연성을 최대한 활용했습니다. API 서비스의 정확성은 확실한 보장을 제공합니다.

위 내용은 Go-Zero 통합 테스트: API 서비스의 자동화된 비파괴 테스트 실현의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.