mirror of https://github.com/v2ray/v2ray-core
37 lines
1.0 KiB
Go
37 lines
1.0 KiB
Go
package log
|
|
|
|
import (
|
|
"io/ioutil"
|
|
"os"
|
|
"testing"
|
|
"time"
|
|
|
|
"github.com/v2ray/v2ray-core/common/serial"
|
|
v2testing "github.com/v2ray/v2ray-core/testing"
|
|
"github.com/v2ray/v2ray-core/testing/assert"
|
|
)
|
|
|
|
func TestAccessLog(t *testing.T) {
|
|
v2testing.Current(t)
|
|
|
|
filename := "/tmp/test_access_log.log"
|
|
InitAccessLogger(filename)
|
|
_, err := os.Stat(filename)
|
|
assert.Error(err).IsNil()
|
|
|
|
Access(serial.StringLiteral("test_from"), serial.StringLiteral("test_to"), AccessAccepted, serial.StringLiteral("test_reason"))
|
|
<-time.After(2 * time.Second)
|
|
|
|
accessLoggerInstance.(*fileLogWriter).close()
|
|
accessLoggerInstance = &noOpLogWriter{}
|
|
|
|
content, err := ioutil.ReadFile(filename)
|
|
assert.Error(err).IsNil()
|
|
|
|
contentStr := serial.StringLiteral(content)
|
|
assert.String(contentStr).Contains(serial.StringLiteral("test_from"))
|
|
assert.String(contentStr).Contains(serial.StringLiteral("test_to"))
|
|
assert.String(contentStr).Contains(serial.StringLiteral("test_reason"))
|
|
assert.String(contentStr).Contains(serial.StringLiteral("accepted"))
|
|
}
|