首页 后端开发 Golang GitHub Actions 上的 Go 应用程序与 PostgreSQL 的无缝集成测试

GitHub Actions 上的 Go 应用程序与 PostgreSQL 的无缝集成测试

Nov 28, 2024 pm 09:55 PM

Seamless Integration Testing for Your Go Application on GitHub Actions with PostgreSQL

介绍

集成测试对于确保您的 Go 应用程序与数据库等外部依赖项完美配合至关重要。在本博客中,我们将探讨如何使用 GitHub Actions 设置和运行 Go 应用程序的集成测试。我们将在 CI 管道中配置 PostgreSQL 数据库,简化测试流程,并确保您的代码库在每次推送时都是可靠且可投入生产的。让我们开始吧!.

我们在上一篇文章中创建了单元测试和集成!。在本文中,我们希望对 github 存储库的所有提交运行这些测试。

Github 操作

它们是一个持续集成和持续交付 (CI/CD) 平台,可让您自动化构建、测试和部署管道。
Github Actions 允许您在存储库中发生其他事件时运行工作流程

Github 工作流程

工作流程是一个可配置的自动化流程,将运行一个或多个作业。工作流由签入存储库的 YAML 文件定义,并在存储库中的事件触发时运行。工作流程在 .github/workfows 中定义。

  • 事件 是存储库中触发工作流运行的特定活动。在我们的例子中,这将推动我们的分支。
  • 作业 是在同一运行器上执行的工作流程中的一组步骤。
  • Runners 是一个在触发工作流时运行工作流的服务器。每个运行程序一次只能运行一项作业。

工作流程 YAML

  • 第一步是创建 .github/workflows 文件夹,我们的 yaml 文件将位于其中。
  • 下一步是创建 yaml 文件,在本例中我们将其命名为 ci-test.yml。
name: ci-test

on:
  push:
    branches: [main]
  pull_request:
    branches: [main]

env:
  POSTGRES_USER: postgres
  POSTGRES_PASSWORD: Password123
  POSTGRES_DB: crud_db

jobs:
  build:
    name: tests
    runs-on: ubuntu-latest
    services:
      postgres:
        image: postgres
        env:
          POSTGRES_USER: ${{ env.POSTGRES_USER }}
          POSTGRES_PASSWORD: ${{ env.POSTGRES_PASSWORD }}
          POSTGRES_DB: ${{ env.POSTGRES_DB }}
        ports:
          - 5432:5432
        options: >-
          --health-cmd pg_isready
          --health-interval 10s
          --health-timeout 5s
          --health-retries 5

    steps:
      - uses: actions/checkout@v4

      - name: Set up Go
        uses: actions/setup-go@v4
        with:
          go-version: "1.22"

      - name: Install dbmate for golang migrations
        run: |
          sudo curl -fsSL -o /usr/local/bin/dbmate https://github.com/amacneil/dbmate/releases/latest/download/dbmate-linux-amd64
          sudo chmod +x /usr/local/bin/dbmate
          which dbmate

      - name: Construct DB URL
        id: construct_url
        run: echo "DB_URL=postgres://${{ env.POSTGRES_USER }}:${{ env.POSTGRES_PASSWORD }}@localhost:5432/${{ env.POSTGRES_DB }}?sslmode=disable" >> $GITHUB_ENV

      - run: env

      - name: Make Migrations
        run: make migrations URL=${{ env.DB_URL }}

      - name: Seed test DB
        run: go run db/seed.go

      - name: Test
        run: make test

登录后复制
登录后复制

yaml 描述

  • 第一部分是命名操作,在本例中为 ci-test

工作流程触发器

  • 第二部分描述触发器。触发操作的事件。在此文件中,我们有两个事件将触发此作业的运行,针对主分支的推送拉取请求。这确保了用于生产的每个代码更改在合并之前都经过测试,从而保持了项目的完整性。

环境变量

Github 工作流程支持全局和特定于作业的环境变量。这些变量描述了我们稍后将在 yaml 文件中使用的 postgres 凭据。

工作

name: ci-test

on:
  push:
    branches: [main]
  pull_request:
    branches: [main]

env:
  POSTGRES_USER: postgres
  POSTGRES_PASSWORD: Password123
  POSTGRES_DB: crud_db

jobs:
  build:
    name: tests
    runs-on: ubuntu-latest
    services:
      postgres:
        image: postgres
        env:
          POSTGRES_USER: ${{ env.POSTGRES_USER }}
          POSTGRES_PASSWORD: ${{ env.POSTGRES_PASSWORD }}
          POSTGRES_DB: ${{ env.POSTGRES_DB }}
        ports:
          - 5432:5432
        options: >-
          --health-cmd pg_isready
          --health-interval 10s
          --health-timeout 5s
          --health-retries 5

    steps:
      - uses: actions/checkout@v4

      - name: Set up Go
        uses: actions/setup-go@v4
        with:
          go-version: "1.22"

      - name: Install dbmate for golang migrations
        run: |
          sudo curl -fsSL -o /usr/local/bin/dbmate https://github.com/amacneil/dbmate/releases/latest/download/dbmate-linux-amd64
          sudo chmod +x /usr/local/bin/dbmate
          which dbmate

      - name: Construct DB URL
        id: construct_url
        run: echo "DB_URL=postgres://${{ env.POSTGRES_USER }}:${{ env.POSTGRES_PASSWORD }}@localhost:5432/${{ env.POSTGRES_DB }}?sslmode=disable" >> $GITHUB_ENV

      - run: env

      - name: Make Migrations
        run: make migrations URL=${{ env.DB_URL }}

      - name: Seed test DB
        run: go run db/seed.go

      - name: Test
        run: make test

登录后复制
登录后复制

在这里,我们为将执行核心任务的作业分配了一个名称,这些任务正在构建和测试我们的代码。
Runner - 描述工作流程将在 Ubuntu 虚拟机上运行的位置。

服务

Github Actions 工作流程允许您定义服务。在这种情况下,我们需要一个 postgres 数据库来运行我们的测试。

  • PostgreSQL 容器是使用官方 PostgreSQL Docker 镜像创建的。
  • 容器配置了我们之前声明的环境变量

工作流程步骤

  • 第一步是检查存储库代码
jobs:
  build:
    name: tests
    runs-on: ubuntu-latest
登录后复制

此行获取存储库的最新版本,提供对所有源文件的访问。

  • 第二步是在运行器中设置 golang。
- uses: actions/checkout@v4
登录后复制
  • 第三步是在我们的运行器上安装 dbmate。 Dbmate 是一个管理应用程序迁移的迁移工具。
- name: Set up Go
  uses: actions/setup-go@v4
  with:
    go-version: "1.22"
登录后复制
  • 第四步是构造db url
- name: Install dbmate for golang migrations
  run: |
    sudo curl -fsSL -o /usr/local/bin/dbmate https://github.com/amacneil/dbmate/releases/latest/download/dbmate-linux-amd64
    sudo chmod +x /usr/local/bin/dbmate
    which dbmate

登录后复制
  • 第五是运行数据库迁移来设置我们的关系,该关系将与日期一起播种
- name: Construct DB URL
  id: construct_url
  run: echo "DB_URL=postgres://${{ env.POSTGRES_USER }}:${{ env.POSTGRES_PASSWORD }}@localhost:5432/${{ env.POSTGRES_DB }}?sslmode=disable" >> $GITHUB_ENV

登录后复制
  • 倒数第二个操作是使用测试数据为数据库播种。
- name: Make Migrations
  run: make migrations URL=${{ env.DB_URL }}
登录后复制

seed.go 文件用测试数据为数据集播种。设置真实的测试环境。要进一步检查此文件,请访问此处

最后阶段是使用 make 文件执行我们的 go 测试

- name: Seed test DB
  run: go run db/seed.go
登录后复制

现在,每次我们发出拉取请求或将代码推送到主分支时,此工作流程都会运行

采用 Github Action 的一些优点。

正如我们所见,github 操作允许您执行以下操作

  1. 自动化测试 - 在每次代码更改时一致地运行测试。
  2. 拥有数据库集成 - 提供真实的 postgres 环境用于测试、模拟生产条件
  3. 可重现的环境 - Github 操作使用容器化服务和预定义步骤来确保所有运行的结果一致。
  4. 快速反馈循环 - 它们使开发人员能够在出现问题时收到快速反馈,从而更快地解决问题。
  5. 简化协作 - 他们确保所有贡献者的更改在出现之前都得到验证,从而保持代码质量和项目稳定性

结论

通过利用 GitHub Actions,此工作流程简化了测试和数据库设置,确保了稳健可靠的软件开发。
访问 github 存储库以查看正在使用上述操作进行测试的代码。

以上是GitHub Actions 上的 Go 应用程序与 PostgreSQL 的无缝集成测试的详细内容。更多信息请关注PHP中文网其他相关文章!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

Golang的目的:建立高效且可扩展的系统 Golang的目的:建立高效且可扩展的系统 Apr 09, 2025 pm 05:17 PM

Go语言在构建高效且可扩展的系统中表现出色,其优势包括:1.高性能:编译成机器码,运行速度快;2.并发编程:通过goroutines和channels简化多任务处理;3.简洁性:语法简洁,降低学习和维护成本;4.跨平台:支持跨平台编译,方便部署。

Golang和C:并发与原始速度 Golang和C:并发与原始速度 Apr 21, 2025 am 12:16 AM

Golang在并发性上优于C ,而C 在原始速度上优于Golang。1)Golang通过goroutine和channel实现高效并发,适合处理大量并发任务。2)C 通过编译器优化和标准库,提供接近硬件的高性能,适合需要极致优化的应用。

表演竞赛:Golang vs.C 表演竞赛:Golang vs.C Apr 16, 2025 am 12:07 AM

Golang和C 在性能竞赛中的表现各有优势:1)Golang适合高并发和快速开发,2)C 提供更高性能和细粒度控制。选择应基于项目需求和团队技术栈。

Golang vs. Python:性能和可伸缩性 Golang vs. Python:性能和可伸缩性 Apr 19, 2025 am 12:18 AM

Golang在性能和可扩展性方面优于Python。1)Golang的编译型特性和高效并发模型使其在高并发场景下表现出色。2)Python作为解释型语言,执行速度较慢,但通过工具如Cython可优化性能。

C和Golang:表演至关重要时 C和Golang:表演至关重要时 Apr 13, 2025 am 12:11 AM

C 更适合需要直接控制硬件资源和高性能优化的场景,而Golang更适合需要快速开发和高并发处理的场景。1.C 的优势在于其接近硬件的特性和高度的优化能力,适合游戏开发等高性能需求。2.Golang的优势在于其简洁的语法和天然的并发支持,适合高并发服务开发。

Golang vs. Python:主要差异和相似之处 Golang vs. Python:主要差异和相似之处 Apr 17, 2025 am 12:15 AM

Golang和Python各有优势:Golang适合高性能和并发编程,Python适用于数据科学和Web开发。 Golang以其并发模型和高效性能着称,Python则以简洁语法和丰富库生态系统着称。

Golang的影响:速度,效率和简单性 Golang的影响:速度,效率和简单性 Apr 14, 2025 am 12:11 AM

GoimpactsdevelopmentPositationalityThroughSpeed,效率和模拟性。1)速度:gocompilesquicklyandrunseff,ifealforlargeprojects.2)效率:效率:ITScomprehenSevestAndArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdEcceSteral Depentencies,增强开发的简单性:3)SimpleflovelmentIcties:3)简单性。

Golang和C:性能的权衡 Golang和C:性能的权衡 Apr 17, 2025 am 12:18 AM

Golang和C 在性能上的差异主要体现在内存管理、编译优化和运行时效率等方面。1)Golang的垃圾回收机制方便但可能影响性能,2)C 的手动内存管理和编译器优化在递归计算中表现更为高效。

See all articles