2010-12-03 04:34:57 +00:00
|
|
|
// Copyright 2009 The Go Authors. All rights reserved.
|
|
|
|
// Use of this source code is governed by a BSD-style
|
|
|
|
// license that can be found in the LICENSE file.
|
|
|
|
package syslog
|
|
|
|
|
|
|
|
import (
|
|
|
|
"io"
|
|
|
|
"log"
|
|
|
|
"net"
|
|
|
|
"testing"
|
|
|
|
)
|
|
|
|
|
|
|
|
var serverAddr string
|
|
|
|
|
|
|
|
func runSyslog(c net.PacketConn, done chan<- string) {
|
|
|
|
var buf [4096]byte
|
|
|
|
var rcvd string = ""
|
|
|
|
for {
|
|
|
|
n, _, err := c.ReadFrom(buf[0:])
|
|
|
|
if err != nil || n == 0 {
|
|
|
|
break
|
|
|
|
}
|
|
|
|
rcvd += string(buf[0:n])
|
|
|
|
}
|
|
|
|
done <- rcvd
|
|
|
|
}
|
|
|
|
|
|
|
|
func startServer(done chan<- string) {
|
|
|
|
c, e := net.ListenPacket("udp", "127.0.0.1:0")
|
|
|
|
if e != nil {
|
2011-03-16 23:05:44 +00:00
|
|
|
log.Fatalf("net.ListenPacket failed udp :0 %v", e)
|
2010-12-03 04:34:57 +00:00
|
|
|
}
|
|
|
|
serverAddr = c.LocalAddr().String()
|
|
|
|
c.SetReadTimeout(100e6) // 100ms
|
|
|
|
go runSyslog(c, done)
|
|
|
|
}
|
|
|
|
|
2011-05-20 00:18:15 +00:00
|
|
|
func skipNetTest(t *testing.T) bool {
|
|
|
|
if testing.Short() {
|
|
|
|
// Depends on syslog daemon running, and sometimes it's not.
|
|
|
|
t.Logf("skipping syslog test during -short")
|
|
|
|
return true
|
|
|
|
}
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
|
2010-12-03 04:34:57 +00:00
|
|
|
func TestNew(t *testing.T) {
|
2011-05-20 00:18:15 +00:00
|
|
|
if skipNetTest(t) {
|
|
|
|
return
|
|
|
|
}
|
2010-12-03 04:34:57 +00:00
|
|
|
s, err := New(LOG_INFO, "")
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("New() failed: %s", err)
|
|
|
|
}
|
|
|
|
// Don't send any messages.
|
|
|
|
s.Close()
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestNewLogger(t *testing.T) {
|
2011-05-20 00:18:15 +00:00
|
|
|
if skipNetTest(t) {
|
|
|
|
return
|
|
|
|
}
|
2010-12-03 04:34:57 +00:00
|
|
|
f := NewLogger(LOG_INFO, 0)
|
|
|
|
if f == nil {
|
2011-01-21 18:19:03 +00:00
|
|
|
t.Error("NewLogger() failed")
|
2010-12-03 04:34:57 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestDial(t *testing.T) {
|
2011-05-20 00:18:15 +00:00
|
|
|
if skipNetTest(t) {
|
|
|
|
return
|
|
|
|
}
|
2010-12-03 04:34:57 +00:00
|
|
|
l, err := Dial("", "", LOG_ERR, "syslog_test")
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("Dial() failed: %s", err)
|
|
|
|
}
|
|
|
|
l.Close()
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestUDPDial(t *testing.T) {
|
|
|
|
done := make(chan string)
|
|
|
|
startServer(done)
|
|
|
|
l, err := Dial("udp", serverAddr, LOG_INFO, "syslog_test")
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("syslog.Dial() failed: %s", err)
|
|
|
|
}
|
|
|
|
msg := "udp test"
|
|
|
|
l.Info(msg)
|
|
|
|
expected := "<6>syslog_test: udp test\n"
|
|
|
|
rcvd := <-done
|
|
|
|
if rcvd != expected {
|
|
|
|
t.Fatalf("s.Info() = '%q', but wanted '%q'", rcvd, expected)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestWrite(t *testing.T) {
|
|
|
|
done := make(chan string)
|
|
|
|
startServer(done)
|
|
|
|
l, err := Dial("udp", serverAddr, LOG_ERR, "syslog_test")
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("syslog.Dial() failed: %s", err)
|
|
|
|
}
|
|
|
|
msg := "write test"
|
|
|
|
_, err = io.WriteString(l, msg)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("WriteString() failed: %s", err)
|
|
|
|
}
|
|
|
|
expected := "<3>syslog_test: write test\n"
|
|
|
|
rcvd := <-done
|
|
|
|
if rcvd != expected {
|
|
|
|
t.Fatalf("s.Info() = '%q', but wanted '%q'", rcvd, expected)
|
|
|
|
}
|
|
|
|
}
|