Go语言中的单元测试及反向代理

来源:互联网 发布:python使用指南 下载 编辑:程序博客网 时间:2024/06/01 10:24

一般为了保证整个系统的稳定性,通常都需要编写大量的单元测试,诸如像java的junit,php的phpunit等都提供了类似的功能。golang中的testing包提供了这个测试的功能,结合go test工具搞起来就很方便了。

golang中的单元测试不单有功能测试,也还提供了性能测试,非常给力。

功能测试

在golang的src目录下新建目录math,测试目录结构如下:

golang单元测试目录

golang单元测试目录

fibonacci.go代码如下,主要有一个Fibonacci函数

package lib//斐波那契数列//求出第n个数的值func Fibonacci(n int64) int64 {if n < 2 {return n}return Fibonacci(n-1) + Fibonacci(n-2)

fibonacci_test.go就是测试的文件了,golang需要测试文件一律用”_test”结尾,测试的函数都用Test开头,代码如下:

package libimport ("testing")func TestFibonacci(t *testing.T) {r := Fibonacci(10)if r != 55 {t.Errorf("Fibonacci(10) failed. Got %d, expected 55.", r)}}

使用go test测试这个程序

$ go test lib ok lib 0.008s

如果提示找不到包,则将该代码路径加入环境变量GOPATH就可以了。

can't load package: package lib: cannot find package "lib" in any of:

性能测试

结合上面的方法,这里测试一下函数的性能,如果需要进行性能测试,则函数开头使用Benchmark就可以了。

//性能测试func BenchmarkFibonacci(b *testing.B) {for i := 0; i < b.N; i++ {Fibonacci(10)}}

接下来执行这个性能测试:

$ go test -bench=. lib PASS BenchmarkFibonacci 5000000 436 ns/op ok lib 2.608s

其中第二行输出表示这个函数运行了5000000次,平均运行一次的时间是436ns。

这个性能测试只测试参数为10的情况。如果有需要可以测试多个参数:

//测试参数为5的性能func BenchmarkFibonacci5(b *testing.B) {for i := 0; i < b.N; i++ {Fibonacci(5)}}//测试参数为20的性能func BenchmarkFibonacci20(b *testing.B) {for i := 0; i < b.N; i++ {Fibonacci(20)}}

运行一下:

$ go test -bench=. lib PASS BenchmarkFibonacci 5000000 357 ns/op BenchmarkFibonacci5 100000000 29.5 ns/op BenchmarkFibonacci20 50000 44688 ns/op ok lib 7.824s

如果性能测试的方法非常多,那需要的时间就会比较久。可以通过-bench=参数设置需要运行的性能测试行数:

$ go test -bench=Fibonacci20 lib PASS BenchmarkFibonacci20 50000 44367 ns/op ok lib 2.677s
 

转载请注明:快乐编程 » golang中的单元测试

 

翻阅golang包手册的时候看到net/http/httputil有一个type ReverseProxy,这个不是反向代理吗!golang自带反向代理功能?好奇就试了一下,确实非常简单,没有几行代码就实现了一个简易的反向代理服务。

关于反向代理百度百科上说的非常详细了,这里摘录一下定义:

反向代理(Reverse Proxy)方式是指以代理服务器来接受internet上的连接请求,然后将请求转发给内部网络上的服务器,并将从服务器上得到的结果返回给internet上请求连接的客户端,此时代理服务器对外就表现为一个反向代理服务器。

golang实现代码

package mainimport ("log""net/http""net/http/httputil""net/url")type handle struct {host stringport string}func (this *handle) ServeHTTP(w http.ResponseWriter, r *http.Request) {remote, err := url.Parse("http://" + this.host + ":" + this.port)if err != nil {panic(err)}proxy := httputil.NewSingleHostReverseProxy(remote)proxy.ServeHTTP(w, r)}func startServer() {//被代理的服务器host和porth := &handle{host: "127.0.0.1", port: "80"}err := http.ListenAndServe(":8888", h)if err != nil {log.Fatalln("ListenAndServe: ", err)}}func main() {startServer()}

关键的代码就是NewSingleHostReverseProxy这个方法,查看源码的话不难看出该方法返回了一个ReverseProxy对象,在ReverseProxy中的ServeHTTP方法实现了这个具体的过程,主要是对源http包头进行重新封装,而后发送到后端服务器。

 

转载请注明:快乐编程 » golang实现的反向代理

 

0 0
原创粉丝点击