2017-06-12 06:04:52 +00:00
|
|
|
// Copyright 2017 Manu Martinez-Almeida. All rights reserved.
|
|
|
|
// Use of this source code is governed by a MIT style
|
|
|
|
// license that can be found in the LICENSE file.
|
|
|
|
|
2015-05-29 01:28:24 +00:00
|
|
|
package gin
|
|
|
|
|
|
|
|
import (
|
|
|
|
"bufio"
|
2018-10-16 00:48:41 +00:00
|
|
|
"crypto/tls"
|
2015-05-29 01:28:24 +00:00
|
|
|
"fmt"
|
2015-05-29 11:29:33 +00:00
|
|
|
"io/ioutil"
|
2015-05-29 01:28:24 +00:00
|
|
|
"net"
|
|
|
|
"net/http"
|
2017-06-12 02:40:15 +00:00
|
|
|
"net/http/httptest"
|
2015-08-16 14:19:51 +00:00
|
|
|
"os"
|
2018-10-01 02:49:39 +00:00
|
|
|
"sync"
|
2015-05-29 01:28:24 +00:00
|
|
|
"testing"
|
|
|
|
"time"
|
|
|
|
|
|
|
|
"github.com/stretchr/testify/assert"
|
|
|
|
)
|
|
|
|
|
2015-08-16 14:19:51 +00:00
|
|
|
func testRequest(t *testing.T, url string) {
|
2018-10-16 00:48:41 +00:00
|
|
|
tr := &http.Transport{
|
|
|
|
TLSClientConfig: &tls.Config{
|
|
|
|
InsecureSkipVerify: true,
|
|
|
|
},
|
|
|
|
}
|
|
|
|
client := &http.Client{Transport: tr}
|
|
|
|
|
|
|
|
resp, err := client.Get(url)
|
2015-08-16 14:19:51 +00:00
|
|
|
assert.NoError(t, err)
|
2017-06-13 02:50:42 +00:00
|
|
|
defer resp.Body.Close()
|
2015-08-16 14:19:51 +00:00
|
|
|
|
|
|
|
body, ioerr := ioutil.ReadAll(resp.Body)
|
|
|
|
assert.NoError(t, ioerr)
|
|
|
|
assert.Equal(t, "it worked", string(body), "resp body should match")
|
|
|
|
assert.Equal(t, "200 OK", resp.Status, "should get a 200")
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestRunEmpty(t *testing.T) {
|
|
|
|
os.Setenv("PORT", "")
|
2015-05-29 11:29:33 +00:00
|
|
|
router := New()
|
|
|
|
go func() {
|
|
|
|
router.GET("/example", func(c *Context) { c.String(http.StatusOK, "it worked") })
|
2015-08-16 14:19:51 +00:00
|
|
|
assert.NoError(t, router.Run())
|
2015-05-29 11:29:33 +00:00
|
|
|
}()
|
|
|
|
// have to wait for the goroutine to start and run the server
|
|
|
|
// otherwise the main thread will complete
|
|
|
|
time.Sleep(5 * time.Millisecond)
|
|
|
|
|
2015-08-16 14:19:51 +00:00
|
|
|
assert.Error(t, router.Run(":8080"))
|
|
|
|
testRequest(t, "http://localhost:8080/example")
|
|
|
|
}
|
2015-06-03 03:25:50 +00:00
|
|
|
|
2018-10-16 00:48:41 +00:00
|
|
|
func TestRunTLS(t *testing.T) {
|
|
|
|
router := New()
|
|
|
|
go func() {
|
|
|
|
router.GET("/example", func(c *Context) { c.String(http.StatusOK, "it worked") })
|
|
|
|
|
|
|
|
assert.NoError(t, router.RunTLS(":8443", "./testdata/certificate/cert.pem", "./testdata/certificate/key.pem"))
|
|
|
|
}()
|
|
|
|
|
|
|
|
// have to wait for the goroutine to start and run the server
|
|
|
|
// otherwise the main thread will complete
|
|
|
|
time.Sleep(5 * time.Millisecond)
|
|
|
|
|
|
|
|
assert.Error(t, router.RunTLS(":8443", "./testdata/certificate/cert.pem", "./testdata/certificate/key.pem"))
|
|
|
|
testRequest(t, "https://localhost:8443/example")
|
|
|
|
}
|
|
|
|
|
2015-08-16 14:19:51 +00:00
|
|
|
func TestRunEmptyWithEnv(t *testing.T) {
|
|
|
|
os.Setenv("PORT", "3123")
|
|
|
|
router := New()
|
|
|
|
go func() {
|
|
|
|
router.GET("/example", func(c *Context) { c.String(http.StatusOK, "it worked") })
|
|
|
|
assert.NoError(t, router.Run())
|
|
|
|
}()
|
|
|
|
// have to wait for the goroutine to start and run the server
|
|
|
|
// otherwise the main thread will complete
|
|
|
|
time.Sleep(5 * time.Millisecond)
|
2015-06-03 03:25:50 +00:00
|
|
|
|
2015-08-16 14:19:51 +00:00
|
|
|
assert.Error(t, router.Run(":3123"))
|
|
|
|
testRequest(t, "http://localhost:3123/example")
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestRunTooMuchParams(t *testing.T) {
|
|
|
|
router := New()
|
|
|
|
assert.Panics(t, func() {
|
2019-01-18 01:32:53 +00:00
|
|
|
assert.NoError(t, router.Run("2", "2"))
|
2015-08-16 14:19:51 +00:00
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestRunWithPort(t *testing.T) {
|
|
|
|
router := New()
|
|
|
|
go func() {
|
|
|
|
router.GET("/example", func(c *Context) { c.String(http.StatusOK, "it worked") })
|
|
|
|
assert.NoError(t, router.Run(":5150"))
|
|
|
|
}()
|
|
|
|
// have to wait for the goroutine to start and run the server
|
|
|
|
// otherwise the main thread will complete
|
|
|
|
time.Sleep(5 * time.Millisecond)
|
|
|
|
|
|
|
|
assert.Error(t, router.Run(":5150"))
|
|
|
|
testRequest(t, "http://localhost:5150/example")
|
2015-05-29 11:29:33 +00:00
|
|
|
}
|
|
|
|
|
2015-05-29 01:28:24 +00:00
|
|
|
func TestUnixSocket(t *testing.T) {
|
|
|
|
router := New()
|
2015-06-03 03:25:50 +00:00
|
|
|
|
2015-05-29 01:28:24 +00:00
|
|
|
go func() {
|
|
|
|
router.GET("/example", func(c *Context) { c.String(http.StatusOK, "it worked") })
|
2015-08-16 14:19:51 +00:00
|
|
|
assert.NoError(t, router.RunUnix("/tmp/unix_unit_test"))
|
2015-05-29 01:28:24 +00:00
|
|
|
}()
|
|
|
|
// have to wait for the goroutine to start and run the server
|
|
|
|
// otherwise the main thread will complete
|
|
|
|
time.Sleep(5 * time.Millisecond)
|
|
|
|
|
|
|
|
c, err := net.Dial("unix", "/tmp/unix_unit_test")
|
2015-06-03 03:25:50 +00:00
|
|
|
assert.NoError(t, err)
|
|
|
|
|
2017-11-29 02:50:14 +00:00
|
|
|
fmt.Fprint(c, "GET /example HTTP/1.0\r\n\r\n")
|
2015-05-29 01:28:24 +00:00
|
|
|
scanner := bufio.NewScanner(c)
|
|
|
|
var response string
|
|
|
|
for scanner.Scan() {
|
|
|
|
response += scanner.Text()
|
|
|
|
}
|
|
|
|
assert.Contains(t, response, "HTTP/1.0 200", "should get a 200")
|
|
|
|
assert.Contains(t, response, "it worked", "resp body should match")
|
|
|
|
}
|
2015-06-03 03:25:50 +00:00
|
|
|
|
|
|
|
func TestBadUnixSocket(t *testing.T) {
|
|
|
|
router := New()
|
|
|
|
assert.Error(t, router.RunUnix("#/tmp/unix_unit_test"))
|
|
|
|
}
|
2016-02-23 17:44:52 +00:00
|
|
|
|
2018-11-06 02:28:51 +00:00
|
|
|
func TestFileDescriptor(t *testing.T) {
|
|
|
|
router := New()
|
|
|
|
|
2018-12-28 02:26:29 +00:00
|
|
|
addr, err := net.ResolveTCPAddr("tcp", "localhost:0")
|
2018-11-06 02:28:51 +00:00
|
|
|
assert.NoError(t, err)
|
|
|
|
listener, err := net.ListenTCP("tcp", addr)
|
|
|
|
assert.NoError(t, err)
|
|
|
|
socketFile, err := listener.File()
|
|
|
|
assert.NoError(t, err)
|
|
|
|
|
|
|
|
go func() {
|
|
|
|
router.GET("/example", func(c *Context) { c.String(http.StatusOK, "it worked") })
|
|
|
|
assert.NoError(t, router.RunFd(int(socketFile.Fd())))
|
|
|
|
}()
|
|
|
|
// have to wait for the goroutine to start and run the server
|
|
|
|
// otherwise the main thread will complete
|
|
|
|
time.Sleep(5 * time.Millisecond)
|
|
|
|
|
2018-12-28 02:26:29 +00:00
|
|
|
c, err := net.Dial("tcp", listener.Addr().String())
|
2018-11-06 02:28:51 +00:00
|
|
|
assert.NoError(t, err)
|
|
|
|
|
|
|
|
fmt.Fprintf(c, "GET /example HTTP/1.0\r\n\r\n")
|
|
|
|
scanner := bufio.NewScanner(c)
|
|
|
|
var response string
|
|
|
|
for scanner.Scan() {
|
|
|
|
response += scanner.Text()
|
|
|
|
}
|
|
|
|
assert.Contains(t, response, "HTTP/1.0 200", "should get a 200")
|
|
|
|
assert.Contains(t, response, "it worked", "resp body should match")
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestBadFileDescriptor(t *testing.T) {
|
|
|
|
router := New()
|
|
|
|
assert.Error(t, router.RunFd(0))
|
|
|
|
}
|
|
|
|
|
2016-02-23 17:44:52 +00:00
|
|
|
func TestWithHttptestWithAutoSelectedPort(t *testing.T) {
|
|
|
|
router := New()
|
|
|
|
router.GET("/example", func(c *Context) { c.String(http.StatusOK, "it worked") })
|
|
|
|
|
|
|
|
ts := httptest.NewServer(router)
|
|
|
|
defer ts.Close()
|
|
|
|
|
|
|
|
testRequest(t, ts.URL+"/example")
|
|
|
|
}
|
|
|
|
|
2018-10-01 02:49:39 +00:00
|
|
|
func TestConcurrentHandleContext(t *testing.T) {
|
|
|
|
router := New()
|
|
|
|
router.GET("/", func(c *Context) {
|
|
|
|
c.Request.URL.Path = "/example"
|
|
|
|
router.HandleContext(c)
|
|
|
|
})
|
|
|
|
router.GET("/example", func(c *Context) { c.String(http.StatusOK, "it worked") })
|
|
|
|
|
|
|
|
ts := httptest.NewServer(router)
|
|
|
|
defer ts.Close()
|
|
|
|
|
|
|
|
var wg sync.WaitGroup
|
|
|
|
iterations := 200
|
|
|
|
wg.Add(iterations)
|
|
|
|
for i := 0; i < iterations; i++ {
|
|
|
|
go func() {
|
|
|
|
testRequest(t, ts.URL+"/")
|
|
|
|
wg.Done()
|
|
|
|
}()
|
|
|
|
}
|
|
|
|
wg.Wait()
|
|
|
|
}
|
|
|
|
|
2017-03-16 15:38:30 +00:00
|
|
|
// func TestWithHttptestWithSpecifiedPort(t *testing.T) {
|
|
|
|
// router := New()
|
|
|
|
// router.GET("/example", func(c *Context) { c.String(http.StatusOK, "it worked") })
|
|
|
|
|
|
|
|
// l, _ := net.Listen("tcp", ":8033")
|
|
|
|
// ts := httptest.Server{
|
|
|
|
// Listener: l,
|
|
|
|
// Config: &http.Server{Handler: router},
|
|
|
|
// }
|
|
|
|
// ts.Start()
|
|
|
|
// defer ts.Close()
|
|
|
|
|
|
|
|
// testRequest(t, "http://localhost:8033/example")
|
|
|
|
// }
|