mirror of https://github.com/v2ray/v2ray-core
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
35 lines
848 B
35 lines
848 B
9 years ago
|
package log
|
||
|
|
||
|
import (
|
||
|
"io/ioutil"
|
||
|
"os"
|
||
|
"strings"
|
||
|
"testing"
|
||
|
"time"
|
||
|
|
||
|
"github.com/v2ray/v2ray-core/testing/unit"
|
||
|
)
|
||
|
|
||
|
func TestAccessLog(t *testing.T) {
|
||
|
assert := unit.Assert(t)
|
||
|
|
||
|
filename := "/tmp/test_access_log.log"
|
||
|
InitAccessLogger(filename)
|
||
|
_, err := os.Stat(filename)
|
||
|
assert.Error(err).IsNil()
|
||
|
|
||
|
Access("test_from", "test_to", AccessAccepted, "test_reason")
|
||
|
<-time.After(2 * time.Second)
|
||
|
|
||
|
accessLoggerInstance.(*fileAccessLogger).close()
|
||
|
accessLoggerInstance = &noOpAccessLogger{}
|
||
|
|
||
|
content, err := ioutil.ReadFile(filename)
|
||
|
assert.Error(err).IsNil()
|
||
|
|
||
|
assert.Bool(strings.Contains(string(content), "test_from")).IsTrue()
|
||
|
assert.Bool(strings.Contains(string(content), "test_to")).IsTrue()
|
||
|
assert.Bool(strings.Contains(string(content), "test_reason")).IsTrue()
|
||
|
assert.Bool(strings.Contains(string(content), "accepted")).IsTrue()
|
||
|
}
|