登录
首页 >  Golang >  Go教程

GOST-DOM如何避免进行HTTP调用

时间:2025-02-18 22:39:48 484浏览 收藏

珍惜时间,勤奋学习!今天给大家带来《GOST-DOM如何避免进行HTTP调用》,正文内容主要涉及到等等,如果你正在学习Golang,或者是对Golang有疑问,欢迎大家关注我!后面我会持续更新相关内容的,希望都能帮到正在学习的大家!

GOST-DOM如何避免进行HTTP调用

本文介绍了GOST-DOM的实现,这是一个用Go语言编写的无头浏览器。

Go语言编写的Web应用程序非常易于测试。Web应用程序为单个功能ServeHTTP提供HTTP请求。测试代码只需调用此函数即可测试Web应用程序的行为,但仍然可以通过HTTP请求、响应、头信息、主体和状态码来表示测试,而不是控制器方法调用。

GOST-DOM充分利用了这一点,原因如下:

  1. 性能: 测试只需调用Go代码,避免了TCP堆栈的开销。
  2. 隔离: 消除了管理TCP端口的需求,极大地简化了测试隔离。 这是最重要的部分,虽然不阻止测试进行隔离,但管理TCP端口增加了测试环境的复杂性。

HTTP客户端

我希望浏览器核心无需处理HTTP请求。幸运的是,Go的标准库可以直接使用。

传出的HTTP请求由http.Client实例处理;它通过RoundTripper接口抽象了传输层。

Go的一个重要特性是许多基本操作都是由单方法接口抽象的。RoundTripper只有一个方法:

import (
    "net/http"
    "net/http/cookiejar"
)

func NewHttpClientFromHandler(handler http.Handler) http.Client {
    cookieJar, err := cookiejar.New(nil)
    if err != nil {
        panic(err)
    }
    return http.Client{
        Transport: TestRoundTripper{Handler: handler},
        Jar:       cookieJar,
    }
}

测试身份提供商集成 (未来功能)

虽然这还不是一个功能,但它旨在扩展此功能以支持多个HTTP处理程序,模拟不同的主机名。这对于测试OAuth身份验证流程或使用外部身份提供商登录可能很有价值。您可以创建一个测试HTTP处理程序来模拟身份提供商的行为,并独立于外部提供商进行测试。

在之前的经验中,这通常是通过使用某些测试用户配置的真实身份提供商来完成的。但是这种方法有一些缺点:

  • 可能由于外部服务的暂时中断而失败。
  • 测试可能由于帐户锁定而失败。
  • 使用“真实测试用户”使测试代码依赖于外部上下文。
  • 开发人员可能没有权限管理测试用户。

通过模拟身份提供商,您可以完全控制测试环境的流程。

调用您的应用程序HTTP处理程序

调用您的模拟身份提供商Web应用程序。您可以仍然并行运行所有内容。

有兴趣的话,请查看GOST-DOM,并继续关注更多关于我在Go中构建浏览器的信息。

请传播这个信息!

我想强调的是,此工具旨在支持大多数支持TDD流程的测试。这并不意味着在发现关键集成问题后不应该添加更多测试,如果您的应用程序与外部身份提供商集成,我当然建议进行一次自动测试登录流程。但我希望这不会成为正常开发流程的一部分。

以上就是《GOST-DOM如何避免进行HTTP调用》的详细内容,更多关于的资料请关注golang学习网公众号!

相关阅读
更多>
最新阅读
更多>
课程推荐
更多>