2016-04-20 11:54:57 -07:00
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
"io/ioutil"
|
|
|
|
"net"
|
|
|
|
"net/http"
|
|
|
|
"net/http/httptest"
|
|
|
|
"os"
|
|
|
|
"os/exec"
|
|
|
|
"regexp"
|
|
|
|
"strings"
|
|
|
|
"time"
|
|
|
|
|
2017-05-17 15:22:44 +02:00
|
|
|
"github.com/containous/traefik/integration/try"
|
2016-04-20 11:54:57 -07:00
|
|
|
"github.com/go-check/check"
|
|
|
|
shellwords "github.com/mattn/go-shellwords"
|
|
|
|
|
|
|
|
checker "github.com/vdemeester/shakers"
|
|
|
|
)
|
|
|
|
|
|
|
|
// AccessLogSuite
|
|
|
|
type AccessLogSuite struct{ BaseSuite }
|
|
|
|
|
|
|
|
func (s *AccessLogSuite) TestAccessLog(c *check.C) {
|
|
|
|
// Ensure working directory is clean
|
|
|
|
os.Remove("access.log")
|
|
|
|
os.Remove("traefik.log")
|
|
|
|
|
|
|
|
// Start Traefik
|
|
|
|
cmd := exec.Command(traefikBinary, "--configFile=fixtures/access_log_config.toml")
|
|
|
|
err := cmd.Start()
|
|
|
|
c.Assert(err, checker.IsNil)
|
|
|
|
defer cmd.Process.Kill()
|
2017-05-17 15:22:44 +02:00
|
|
|
|
2016-04-20 11:54:57 -07:00
|
|
|
defer os.Remove("access.log")
|
|
|
|
defer os.Remove("traefik.log")
|
|
|
|
|
2017-05-17 15:22:44 +02:00
|
|
|
err = try.Do(1*time.Second, func() error {
|
|
|
|
if _, err := os.Stat("traefik.log"); err != nil {
|
|
|
|
return fmt.Errorf("could not get stats for log file: %s", err)
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
})
|
|
|
|
c.Assert(err, checker.IsNil)
|
2016-04-20 11:54:57 -07:00
|
|
|
|
|
|
|
// Verify Traefik started OK
|
2016-04-28 10:53:02 +00:00
|
|
|
traefikLog, err := ioutil.ReadFile("traefik.log")
|
|
|
|
c.Assert(err, checker.IsNil)
|
|
|
|
if len(traefikLog) > 0 {
|
2016-04-20 11:54:57 -07:00
|
|
|
fmt.Printf("%s\n", string(traefikLog))
|
|
|
|
c.Assert(len(traefikLog), checker.Equals, 0)
|
|
|
|
}
|
|
|
|
|
|
|
|
// Start test servers
|
|
|
|
ts1 := startAccessLogServer(8081)
|
|
|
|
defer ts1.Close()
|
|
|
|
ts2 := startAccessLogServer(8082)
|
|
|
|
defer ts2.Close()
|
|
|
|
ts3 := startAccessLogServer(8083)
|
|
|
|
defer ts3.Close()
|
|
|
|
|
|
|
|
// Make some requests
|
2017-05-17 15:22:44 +02:00
|
|
|
err = try.GetRequest("http://127.0.0.1:8000/test1", 500*time.Millisecond)
|
2016-04-20 11:54:57 -07:00
|
|
|
c.Assert(err, checker.IsNil)
|
2017-05-17 15:22:44 +02:00
|
|
|
err = try.GetRequest("http://127.0.0.1:8000/test2", 500*time.Millisecond)
|
2016-04-20 11:54:57 -07:00
|
|
|
c.Assert(err, checker.IsNil)
|
2017-05-17 15:22:44 +02:00
|
|
|
err = try.GetRequest("http://127.0.0.1:8000/test2", 500*time.Millisecond)
|
2016-04-20 11:54:57 -07:00
|
|
|
c.Assert(err, checker.IsNil)
|
|
|
|
|
|
|
|
// Verify access.log output as expected
|
2016-04-28 10:53:02 +00:00
|
|
|
accessLog, err := ioutil.ReadFile("access.log")
|
|
|
|
c.Assert(err, checker.IsNil)
|
|
|
|
lines := strings.Split(string(accessLog), "\n")
|
|
|
|
count := 0
|
|
|
|
for i, line := range lines {
|
|
|
|
if len(line) > 0 {
|
|
|
|
count++
|
|
|
|
tokens, err := shellwords.Parse(line)
|
|
|
|
c.Assert(err, checker.IsNil)
|
|
|
|
c.Assert(len(tokens), checker.Equals, 13)
|
2017-05-17 15:22:44 +02:00
|
|
|
c.Assert(regexp.MustCompile(`^\d{3}$`).MatchString(tokens[6]), checker.True)
|
2016-04-28 10:53:02 +00:00
|
|
|
c.Assert(tokens[9], checker.Equals, fmt.Sprintf("%d", i+1))
|
|
|
|
c.Assert(strings.HasPrefix(tokens[10], "frontend"), checker.True)
|
|
|
|
c.Assert(strings.HasPrefix(tokens[11], "http://127.0.0.1:808"), checker.True)
|
2017-05-17 15:22:44 +02:00
|
|
|
c.Assert(regexp.MustCompile(`^\d+ms$`).MatchString(tokens[12]), checker.True)
|
2016-04-20 11:54:57 -07:00
|
|
|
}
|
|
|
|
}
|
2017-05-17 15:22:44 +02:00
|
|
|
c.Assert(count, checker.GreaterOrEqualThan, 3)
|
2016-04-20 11:54:57 -07:00
|
|
|
|
2016-04-27 09:25:13 -07:00
|
|
|
// Verify no other Traefik problems
|
2016-04-28 10:53:02 +00:00
|
|
|
traefikLog, err = ioutil.ReadFile("traefik.log")
|
|
|
|
c.Assert(err, checker.IsNil)
|
|
|
|
if len(traefikLog) > 0 {
|
2016-04-20 11:54:57 -07:00
|
|
|
fmt.Printf("%s\n", string(traefikLog))
|
|
|
|
c.Assert(len(traefikLog), checker.Equals, 0)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func startAccessLogServer(port int) (ts *httptest.Server) {
|
|
|
|
handler := http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
|
|
|
|
fmt.Fprintf(w, "Received query %s!\n", r.URL.Path[1:])
|
|
|
|
})
|
|
|
|
if listener, err := net.Listen("tcp", fmt.Sprintf("127.0.0.1:%d", port)); err != nil {
|
|
|
|
panic(err)
|
|
|
|
} else {
|
|
|
|
ts = &httptest.Server{
|
|
|
|
Listener: listener,
|
|
|
|
Config: &http.Server{Handler: handler},
|
|
|
|
}
|
|
|
|
ts.Start()
|
|
|
|
}
|
|
|
|
return
|
|
|
|
}
|