【测试平台系列】第一章 手撸压力机(七)- 使用gin

简介: 今天,我们使用gin框架将压力机做成一个web服务后端。我们引入gin框架:

今天,我们使用gin框架将压力机做成一个web服务后端。
我们引入gin框架:
go get github.com/gin-gonic/gin
在项目根目录新建一个routers目录,并在routers目录下新建:cors.go router.go router_group.go三个文件。
router.go文件主要是我们编辑路由时使用,目的是统一对web服务的接口进行管理。
router.go

package routers

import "github.com/gin-gonic/gin"

/*
  路由配置
*/
func initRouters(groups *gin.RouterGroup) {
        {
                groups.POST("/run/testObject/") //运行测试对象接口, url: http://*****/engine/run/testObject/
        }

}

cors.go主要是进行跨域配置,如:前端调用我们的后端服务
cors.go


package routers

import (
        "github.com/gin-gonic/gin"
        "net/http"
)

/*
  跨域配置
  需要在路由使用前进行使用
*/
func cors() gin.HandlerFunc {
        return func(ctx *gin.Context) {
                method := ctx.Request.Method
                ctx.Header("Access-Control-Allow-Origin", "*")
                ctx.Header("Access-Control-Allow-Headers", "Content-Type,AccessToken,X-CSRF-Token, Authorization, Token, x-token")
                ctx.Header("Access-Control-Allow-Methods", "POST, GET, OPTIONS, DELETE, PATCH, PUT")
                ctx.Header("Access-Control-Expose-Headers", "Content-Length, Access-Control-Allow-Origin, Access-Control-Allow-Headers, Content-Type")
                ctx.Header("Access-Control-Allow-Credentials", "true")

                if method == "OPTIONS" {
                        ctx.AbortWithStatus(http.StatusNoContent)
                }
                ctx.Next()
        }
}

router_group.go主要是实现一个路由组,我们可以定义一个路由的统一前缀,对接口进行分类管理。
router_group.go

package routers

import "github.com/gin-gonic/gin"

/*
 路由组
*/

func NewRouterGroup() (handler *gin.Engine) {
        handler = gin.Default()
        handler.Use(cors()) // 使用跨域配置,在路由使用前进行使用跨域配置
        group := handler.Group("engine")
        initRouters(group)
        return
}

目前总体项目结构如下:
image.png

这样我们就把我们web服务的路由表配置好了,下面我们使用go自带的http,开启并进行服务监听。
在main.go文件中新建runService()函数,并在main方法中调用。
package main


import (
        "context"
        "fmt"
        "kitchen-engine/global/config"
        "kitchen-engine/global/log"
        "kitchen-engine/routers"
        "net/http"
        "os"
        "os/signal"
        "syscall"
        "time"
)

// 初始化函数,在main函数之前运行
func init() {
        // 初始化配置信息
        config.InitConfig()
        // 初始化日志配置
        log.InitLogger(config.YC)

}

/*
 启动服务并监听
*/
func runService() {

        handler := routers.NewRouterGroup()
        engineServer := &http.Server{
        // 我们的服务地址是本机的ip:8000端口,这个可以根据自己的需求修改
                Addr:    "0.0.0.0:8000",
                Handler: handler,
                // 控制服务器解析请求报头的键和值(包括请求行)时将读取的最大字节数。它不限制请求体的大小。如果为零,则使用DefaultMaxHeaderBytes。
                MaxHeaderBytes: 1 << 20,
        }

        go func() {
                // 启动http服务
                if err := engineServer.ListenAndServe(); err != nil {
                        log.Logger.Error(fmt.Sprintln("engineServer出错: ", err.Error()))
                        return
                }
                log.Logger.Debug("engine服务启动成功")
        }()

        /// 接收终止信号
        quit := make(chan os.Signal)
        signal.Notify(quit, syscall.SIGINT, syscall.SIGTERM)
        <-quit

        ctx, cancel := context.WithTimeout(context.Background(), 5*time.Second)
        defer cancel()

        if err := engineServer.Shutdown(ctx); err != nil {
                log.Logger.Info("注销成功")
        }

}

func main() {
        log.Logger.Debug("yc:   ", config.YC)
        runService()

        //// 一个类型中的字段,可以重置,也可以使用默认值,在go中,所有的类型的初始值,都是字段类型的0值,比如string的初始值是""空字符串,int类型的初始值是0等等
        //httpClientSettings := model.HttpClientSettings{
        //        Name:                     "测试厨房",
        //        NoDefaultUserAgentHeader: true,
        //        MaxConnDuration:          1000,
        //        AdvancedOptions: model.AdvancedOptions{
        //                Tls: model.Tls{
        //                        IsVerify:   true,
        //                        VerifyType: 1,
        //                },
        //        },
        //}
        //
        //headers := []model.Header{
        //        model.Header{
        //                Field: "name",
        //                Value: "你好",
        //        },
        //}
        //
        //httpRequest := model.HttpRequest{
        //        Url:                "https://www.baidu.com",
        //        Method:             "GET",
        //        HttpClientSettings: httpClientSettings,
        //        Headers:            headers,
        //}
        //
        //client.RequestHttp(httpRequest)
        log.Logger.Info("欢迎使用zap日志")
}

解释一下为什么我们使用了gin还要在使用net/http进行服务启动,是因为我们需要接受控制台的终止信号,使用gin很难完成,所以我们使用http的Shutdown函数。
运行结果如下:

配置文件:D:\workspace\go\planet\seven-day\kitchen-engine\open.yaml初始化成功
2023-06-29T16:24:15.151+0800    DEBUG   kitchen-engine/main.go:62       yc:   {
  
  {test /data/logs/runner-go-info.log /data/logs/runner-go-err.log true}}
[GIN-debug] [WARNING] Creating an Engine instance with the Logger and Recovery middleware already attached.

[GIN-debug] [WARNING] Running in "debug" mode. Switch to "release" mode in production.
using env:   export GIN_MODE=release
using code:  gin.SetMode(gin.ReleaseMode)

[GIN-debug] POST   /engine/run/testObject/   --> kitchen-engine/routers.cors.func1 (3 handlers)

好了,本次章节结束。下章,我们将我们的testObject接口进行实现。

相关文章
|
4月前
|
关系型数据库 MySQL 测试技术
【分享】AgileTC测试用例管理平台使用分享
AgileTC 是一个脑图样式测试用例管理平台,支持用例设计、执行与团队协作,帮助测试人员高效管理测试流程。
312 116
【分享】AgileTC测试用例管理平台使用分享
|
4月前
|
人工智能 数据可视化 测试技术
AI测试平台自动遍历:低代码也能玩转全链路测试
AI测试平台的自动遍历功能,通过低代码配置实现Web和App的自动化测试。用户只需提供入口链接或安装包及简单配置,即可自动完成页面结构识别、操作验证,并生成可视化报告,大幅提升测试效率,特别适用于高频迭代项目。
|
4月前
|
人工智能 测试技术 调度
写用例写到怀疑人生?AI 智能测试平台帮你一键生成!
霍格沃兹测试开发学社推出AI智能测试用例生成功能,结合需求文档一键生成高质量测试用例,大幅提升效率,减少重复劳动。支持自定义提示词、多文档分析与批量管理,助力测试人员高效完成测试设计,释放更多时间投入核心分析工作。平台已开放内测,欢迎体验!
|
4月前
|
人工智能 测试技术 项目管理
测试不再碎片化:AI智能体平台「项目资料套件」功能上线!
在实际项目中,需求文档分散、整理费时、测试遗漏等问题常困扰测试工作。霍格沃兹推出AI智能体测试平台全新功能——项目资料套件,可将多个关联文档打包管理,并一键生成测试用例,提升测试完整性与效率。支持套件创建、文档关联、编辑删除及用例生成,适用于复杂项目、版本迭代等场景,助力实现智能化测试协作,让测试更高效、更专业。
|
5月前
|
存储 人工智能 算法
AI测试平台实战:深入解析自动化评分和多模型对比评测
在AI技术迅猛发展的今天,测试工程师面临着如何高效评估大模型性能的全新挑战。本文将深入探讨AI测试平台中自动化评分与多模型对比评测的关键技术与实践方法,为测试工程师提供可落地的解决方案。
|
7月前
|
存储 测试技术 虚拟化
VMmark 4.0.3 - 虚拟化平台基准测试
VMmark 4.0.3 - 虚拟化平台基准测试
216 0
VMmark 4.0.3 - 虚拟化平台基准测试
|
4月前
|
人工智能 自然语言处理 测试技术
AI测试平台的用例管理实践:写得清晰,管得高效,执行更智能
在测试过程中,用例分散、步骤模糊、回归测试效率低等问题常困扰团队。霍格沃兹测试开发学社推出的AI测试平台,打通“用例编写—集中管理—智能执行”全流程,提升测试效率与覆盖率。平台支持标准化用例编写、统一管理操作及智能执行,助力测试团队高效协作,释放更多精力优化测试策略。目前平台已开放内测,欢迎试用体验!
|
5月前
|
存储 人工智能 文字识别
从零开始打造AI测试平台:文档解析与知识库构建详解
AI时代构建高效测试平台面临新挑战。本文聚焦AI问答系统知识库建设,重点解析文档解析关键环节,为测试工程师提供实用技术指导和测试方法论
|
5月前
|
人工智能 安全 数据可视化
安全测试平台的选型标准与搭建思路
随着企业安全需求升级,传统漏洞扫描和渗透测试已无法满足要求。构建安全测试平台(STP)成为趋势,实现漏洞扫描、权限评估、接口测试等工作的平台化运营。本文从选型标准、平台架构、模块功能等六个方面,系统讲解如何搭建企业级安全测试平台,提升安全能力。
|
8月前
|
安全 前端开发 Linux
Immunity CANVAS Professional 7.27 (macOS, Linux, Windows) - 渗透测试和漏洞利用平台
Immunity CANVAS Professional 7.27 (macOS, Linux, Windows) - 渗透测试和漏洞利用平台
236 3
Immunity CANVAS Professional 7.27 (macOS, Linux, Windows) - 渗透测试和漏洞利用平台