mirror of
				https://github.com/gin-gonic/gin.git
				synced 2025-10-23 10:02:10 +08:00 
			
		
		
		
	
		
			
				
	
	
		
			151 lines
		
	
	
		
			5.5 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			151 lines
		
	
	
		
			5.5 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| // Copyright 2014 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.
 | |
| 
 | |
| package gin
 | |
| 
 | |
| import (
 | |
| 	"bytes"
 | |
| 	"errors"
 | |
| 	"net/http"
 | |
| 	"testing"
 | |
| 
 | |
| 	"github.com/stretchr/testify/assert"
 | |
| )
 | |
| 
 | |
| func init() {
 | |
| 	SetMode(TestMode)
 | |
| }
 | |
| 
 | |
| func TestLogger(t *testing.T) {
 | |
| 	buffer := new(bytes.Buffer)
 | |
| 	router := New()
 | |
| 	router.Use(LoggerWithWriter(buffer))
 | |
| 	router.GET("/example", func(c *Context) {})
 | |
| 	router.POST("/example", func(c *Context) {})
 | |
| 	router.PUT("/example", func(c *Context) {})
 | |
| 	router.DELETE("/example", func(c *Context) {})
 | |
| 	router.PATCH("/example", func(c *Context) {})
 | |
| 	router.HEAD("/example", func(c *Context) {})
 | |
| 	router.OPTIONS("/example", func(c *Context) {})
 | |
| 
 | |
| 	performRequest(router, "GET", "/example?a=100")
 | |
| 	assert.Contains(t, buffer.String(), "200")
 | |
| 	assert.Contains(t, buffer.String(), "GET")
 | |
| 	assert.Contains(t, buffer.String(), "/example")
 | |
| 	assert.Contains(t, buffer.String(), "a=100")
 | |
| 
 | |
| 	// I wrote these first (extending the above) but then realized they are more
 | |
| 	// like integration tests because they test the whole logging process rather
 | |
| 	// than individual functions.  Im not sure where these should go.
 | |
| 	buffer.Reset()
 | |
| 	performRequest(router, "POST", "/example")
 | |
| 	assert.Contains(t, buffer.String(), "200")
 | |
| 	assert.Contains(t, buffer.String(), "POST")
 | |
| 	assert.Contains(t, buffer.String(), "/example")
 | |
| 
 | |
| 	buffer.Reset()
 | |
| 	performRequest(router, "PUT", "/example")
 | |
| 	assert.Contains(t, buffer.String(), "200")
 | |
| 	assert.Contains(t, buffer.String(), "PUT")
 | |
| 	assert.Contains(t, buffer.String(), "/example")
 | |
| 
 | |
| 	buffer.Reset()
 | |
| 	performRequest(router, "DELETE", "/example")
 | |
| 	assert.Contains(t, buffer.String(), "200")
 | |
| 	assert.Contains(t, buffer.String(), "DELETE")
 | |
| 	assert.Contains(t, buffer.String(), "/example")
 | |
| 
 | |
| 	buffer.Reset()
 | |
| 	performRequest(router, "PATCH", "/example")
 | |
| 	assert.Contains(t, buffer.String(), "200")
 | |
| 	assert.Contains(t, buffer.String(), "PATCH")
 | |
| 	assert.Contains(t, buffer.String(), "/example")
 | |
| 
 | |
| 	buffer.Reset()
 | |
| 	performRequest(router, "HEAD", "/example")
 | |
| 	assert.Contains(t, buffer.String(), "200")
 | |
| 	assert.Contains(t, buffer.String(), "HEAD")
 | |
| 	assert.Contains(t, buffer.String(), "/example")
 | |
| 
 | |
| 	buffer.Reset()
 | |
| 	performRequest(router, "OPTIONS", "/example")
 | |
| 	assert.Contains(t, buffer.String(), "200")
 | |
| 	assert.Contains(t, buffer.String(), "OPTIONS")
 | |
| 	assert.Contains(t, buffer.String(), "/example")
 | |
| 
 | |
| 	buffer.Reset()
 | |
| 	performRequest(router, "GET", "/notfound")
 | |
| 	assert.Contains(t, buffer.String(), "404")
 | |
| 	assert.Contains(t, buffer.String(), "GET")
 | |
| 	assert.Contains(t, buffer.String(), "/notfound")
 | |
| 
 | |
| }
 | |
| 
 | |
| func TestColorForMethod(t *testing.T) {
 | |
| 	assert.Equal(t, string([]byte{27, 91, 57, 55, 59, 52, 52, 109}), colorForMethod("GET"), "get should be blue")
 | |
| 	assert.Equal(t, string([]byte{27, 91, 57, 55, 59, 52, 54, 109}), colorForMethod("POST"), "post should be cyan")
 | |
| 	assert.Equal(t, string([]byte{27, 91, 57, 55, 59, 52, 51, 109}), colorForMethod("PUT"), "put should be yellow")
 | |
| 	assert.Equal(t, string([]byte{27, 91, 57, 55, 59, 52, 49, 109}), colorForMethod("DELETE"), "delete should be red")
 | |
| 	assert.Equal(t, string([]byte{27, 91, 57, 55, 59, 52, 50, 109}), colorForMethod("PATCH"), "patch should be green")
 | |
| 	assert.Equal(t, string([]byte{27, 91, 57, 55, 59, 52, 53, 109}), colorForMethod("HEAD"), "head should be magenta")
 | |
| 	assert.Equal(t, string([]byte{27, 91, 57, 48, 59, 52, 55, 109}), colorForMethod("OPTIONS"), "options should be white")
 | |
| 	assert.Equal(t, string([]byte{27, 91, 48, 109}), colorForMethod("TRACE"), "trace is not defined and should be the reset color")
 | |
| }
 | |
| 
 | |
| func TestColorForStatus(t *testing.T) {
 | |
| 	assert.Equal(t, string([]byte{27, 91, 57, 55, 59, 52, 50, 109}), colorForStatus(http.StatusOK), "2xx should be green")
 | |
| 	assert.Equal(t, string([]byte{27, 91, 57, 48, 59, 52, 55, 109}), colorForStatus(http.StatusMovedPermanently), "3xx should be white")
 | |
| 	assert.Equal(t, string([]byte{27, 91, 57, 55, 59, 52, 51, 109}), colorForStatus(http.StatusNotFound), "4xx should be yellow")
 | |
| 	assert.Equal(t, string([]byte{27, 91, 57, 55, 59, 52, 49, 109}), colorForStatus(2), "other things should be red")
 | |
| }
 | |
| 
 | |
| func TestErrorLogger(t *testing.T) {
 | |
| 	router := New()
 | |
| 	router.Use(ErrorLogger())
 | |
| 	router.GET("/error", func(c *Context) {
 | |
| 		c.Error(errors.New("this is an error"))
 | |
| 	})
 | |
| 	router.GET("/abort", func(c *Context) {
 | |
| 		c.AbortWithError(http.StatusUnauthorized, errors.New("no authorized"))
 | |
| 	})
 | |
| 	router.GET("/print", func(c *Context) {
 | |
| 		c.Error(errors.New("this is an error"))
 | |
| 		c.String(http.StatusInternalServerError, "hola!")
 | |
| 	})
 | |
| 
 | |
| 	w := performRequest(router, "GET", "/error")
 | |
| 	assert.Equal(t, http.StatusOK, w.Code)
 | |
| 	assert.Equal(t, "{\"error\":\"this is an error\"}", w.Body.String())
 | |
| 
 | |
| 	w = performRequest(router, "GET", "/abort")
 | |
| 	assert.Equal(t, http.StatusUnauthorized, w.Code)
 | |
| 	assert.Equal(t, "{\"error\":\"no authorized\"}", w.Body.String())
 | |
| 
 | |
| 	w = performRequest(router, "GET", "/print")
 | |
| 	assert.Equal(t, http.StatusInternalServerError, w.Code)
 | |
| 	assert.Equal(t, "hola!{\"error\":\"this is an error\"}", w.Body.String())
 | |
| }
 | |
| 
 | |
| func TestSkippingPaths(t *testing.T) {
 | |
| 	buffer := new(bytes.Buffer)
 | |
| 	router := New()
 | |
| 	router.Use(LoggerWithWriter(buffer, "/skipped"))
 | |
| 	router.GET("/logged", func(c *Context) {})
 | |
| 	router.GET("/skipped", func(c *Context) {})
 | |
| 
 | |
| 	performRequest(router, "GET", "/logged")
 | |
| 	assert.Contains(t, buffer.String(), "200")
 | |
| 
 | |
| 	buffer.Reset()
 | |
| 	performRequest(router, "GET", "/skipped")
 | |
| 	assert.Contains(t, buffer.String(), "")
 | |
| }
 | |
| 
 | |
| func TestDisableConsoleColor(t *testing.T) {
 | |
| 	New()
 | |
| 	assert.False(t, disableColor)
 | |
| 	DisableConsoleColor()
 | |
| 	assert.True(t, disableColor)
 | |
| }
 |