”工欲善其事,必先利其器。“—孔子《论语.录灵公》
首页 > 编程 > GitHub Actions 上的 Go 应用程序与 PostgreSQL 的无缝集成测试

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

发布于2024-11-26
浏览:552

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.

工作流程触发器

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

环境变量

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

工作

jobs:
  build:
    name: tests
    runs-on: ubuntu-latest

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

服务

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

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

工作流程步骤

  • 第一步是检查存储库代码
- uses: actions/checkout@v4

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

  • 第二步是在运行器中设置 golang。
- name: Set up Go
  uses: actions/setup-go@v4
  with:
    go-version: "1.22"
  • 第三步是在我们的运行器上安装 dbmate。 Dbmate 是一个管理应用程序迁移的迁移工具。
- 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

  • 第四是构造db url
- 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 }}
  • 倒数第二个操作是用测试数据为数据库播种。
- name: Seed test DB
  run: go run db/seed.go

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

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

- name: Test
  run: make test

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

采用 Github Action 的一些优点。

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

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

结论

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

版本声明 本文转载于:https://dev.to/sha254/seamless-integration-testing-for-your-go-application-on-github-actions-with-postgresql-5dne?1如有侵犯,请联系[email protected]删除
最新教程 更多>
  • 大批
    大批
    [2 数组是对象,因此它们在JS中也具有方法。 切片(开始):在新数组中提取部分数组,而无需突变原始数组。 令ARR = ['a','b','c','d','e']; // USECASE:提取直到索引作...
    编程 发布于2025-04-17
  • 如何使用不同数量列的联合数据库表?
    如何使用不同数量列的联合数据库表?
    合并列数不同的表 当尝试合并列数不同的数据库表时,可能会遇到挑战。一种直接的方法是在列数较少的表中,为缺失的列追加空值。 例如,考虑两个表,表 A 和表 B,其中表 A 的列数多于表 B。为了合并这些表,同时处理表 B 中缺失的列,请按照以下步骤操作: 确定表 B 中缺失的列,并将它们添加到表的末...
    编程 发布于2025-04-17
  • JavaScript计算两个日期之间天数的方法
    JavaScript计算两个日期之间天数的方法
    How to Calculate the Difference Between Dates in JavascriptAs you attempt to determine the difference between two dates in Javascript, consider this s...
    编程 发布于2025-04-17
  • 为什么我在Silverlight Linq查询中获得“无法找到查询模式的实现”错误?
    为什么我在Silverlight Linq查询中获得“无法找到查询模式的实现”错误?
    查询模式实现缺失:解决“无法找到”错误在Silverlight应用程序中,尝试使用LINQ建立LINQ连接以错误而实现的数据库”,无法找到查询模式的实现。”当省略LINQ名称空间或查询类型缺少IEnumerable 实现时,通常会发生此错误。 解决问题来验证该类型的质量是至关重要的。在此特定实例中...
    编程 发布于2025-04-17
  • 在GO中构造SQL查询时,如何安全地加入文本和值?
    在GO中构造SQL查询时,如何安全地加入文本和值?
    在go中构造文本sql查询时,在go sql queries 中,在使用conting and contement和contement consem per时,尤其是在使用integer per当per当per时,per per per当per. [&​​&&&&&&&&&&&&&&&默元组方法在...
    编程 发布于2025-04-17
  • 如何将PANDAS DataFrame列转换为DateTime格式并按日期过滤?
    如何将PANDAS DataFrame列转换为DateTime格式并按日期过滤?
    Transform Pandas DataFrame Column to DateTime FormatScenario:Data within a Pandas DataFrame often exists in various formats, including strings.使用时间数据时...
    编程 发布于2025-04-17
  • 在Java中使用for-to-loop和迭代器进行收集遍历之间是否存在性能差异?
    在Java中使用for-to-loop和迭代器进行收集遍历之间是否存在性能差异?
    For Each Loop vs. Iterator: Efficiency in Collection TraversalIntroductionWhen traversing a collection in Java, the choice arises between using a for-...
    编程 发布于2025-04-17
  • 如何从PHP中的Unicode字符串中有效地产生对URL友好的sl。
    如何从PHP中的Unicode字符串中有效地产生对URL友好的sl。
    为有效的slug生成首先,该函数用指定的分隔符替换所有非字母或数字字符。此步骤可确保slug遵守URL惯例。随后,它采用ICONV函数将文本简化为us-ascii兼容格式,从而允许更广泛的字符集合兼容性。接下来,该函数使用正则表达式删除了不需要的字符,例如特殊字符和空格。此步骤可确保slug仅包含...
    编程 发布于2025-04-17
  • 如何使用Python有效地以相反顺序读取大型文件?
    如何使用Python有效地以相反顺序读取大型文件?
    在python 反向行读取器生成器 == ord('\ n'): 缓冲区=缓冲区[:-1] 剩余_size- = buf_size lines = buffer.split('\ n'....
    编程 发布于2025-04-17
  • 使用jQuery如何有效修改":after"伪元素的CSS属性?
    使用jQuery如何有效修改":after"伪元素的CSS属性?
    在jquery中了解伪元素的限制:访问“ selector 尝试修改“:”选择器的CSS属性时,您可能会遇到困难。 This is because pseudo-elements are not part of the DOM (Document Object Model) and are th...
    编程 发布于2025-04-17
  • 如何配置Pytesseract以使用数字输出的单位数字识别?
    如何配置Pytesseract以使用数字输出的单位数字识别?
    Pytesseract OCR具有单位数字识别和仅数字约束 在pytesseract的上下文中,在配置tesseract以识别单位数字和限制单个数字和限制输出对数字可能会提出质疑。 To address this issue, we delve into the specifics of Te...
    编程 发布于2025-04-17
  • PHP阵列键值异常:了解07和08的好奇情况
    PHP阵列键值异常:了解07和08的好奇情况
    PHP数组键值问题,使用07&08 在给定数月的数组中,键值07和08呈现令人困惑的行为时,就会出现一个不寻常的问题。运行print_r($月)返回意外结果:键“ 07”丢失,而键“ 08”分配给了9月的值。此问题源于PHP对领先零的解释。当一个数字带有0(例如07或08)的前缀时,PHP将其...
    编程 发布于2025-04-17
  • Java字符串非空且非null的有效检查方法
    Java字符串非空且非null的有效检查方法
    检查字符串是否不是null而不是空的 if(str!= null && str.isementy())二手: if(str!= null && str.length()== 0) option 3:trim()。isement(Isement() trim whitespace whitesp...
    编程 发布于2025-04-17
  • JavaScript中如何动态访问全局变量?
    JavaScript中如何动态访问全局变量?
    在JavaScript 一种方法是使用窗口对象存储和检索变量。通过引用全局范围,可以使用其名称动态访问变量。 //一个脚本 var somevarname_10 = 20; //另一个脚本 window.all_vars = {}; window.all_vars ['somevarnam...
    编程 发布于2025-04-17
  • 如何将MySQL数据库添加到Visual Studio 2012中的数据源对话框中?
    如何将MySQL数据库添加到Visual Studio 2012中的数据源对话框中?
    在Visual Studio 2012 尽管已安装了MySQL Connector v.6.5.4,但无法将MySQL数据库添加到实体框架的“ DataSource对话框”中。为了解决这一问题,至关重要的是要了解MySQL连接器v.6.5.5及以后的6.6.x版本将提供MySQL的官方Visual...
    编程 发布于2025-04-17

免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。

Copyright© 2022 湘ICP备2022001581号-3