blocky/querylog/database_writer_test.go

120 lines
2.7 KiB
Go
Raw Normal View History

package querylog
import (
"time"
"github.com/0xERR0R/blocky/helpertest"
"github.com/0xERR0R/blocky/model"
"github.com/0xERR0R/blocky/util"
"github.com/miekg/dns"
"github.com/sirupsen/logrus"
"gorm.io/driver/sqlite"
. "github.com/onsi/gomega"
. "github.com/onsi/ginkgo"
)
var _ = Describe("DatabaseWriter", func() {
Describe("Database query log", func() {
When("New log entry was created", func() {
It("should be persisted in the database", func() {
sqlite := sqlite.Open("file::memory:")
2021-09-12 22:26:07 +02:00
writer := newDatabaseWriter(sqlite, 7, 1)
request := &model.Request{
Req: util.NewMsgWithQuestion("google.de.", dns.TypeA),
Log: logrus.NewEntry(logrus.New()),
}
res, err := util.NewMsgWithAnswer("example.com", 123, dns.TypeA, "123.124.122.122")
Expect(err).Should(Succeed())
response := &model.Response{
Res: res,
Reason: "Resolved",
2021-09-09 22:57:05 +02:00
RType: model.ResponseTypeRESOLVED,
}
writer.Write(&Entry{
Request: request,
Response: response,
Start: time.Now(),
DurationMs: 20,
})
2021-09-12 22:26:07 +02:00
time.Sleep(500 * time.Millisecond)
result := writer.db.Find(&logEntry{})
var cnt int64
result.Count(&cnt)
Expect(cnt).Should(Equal(int64(1)))
})
})
When("There are log entries with timestamp exceeding the retention period", func() {
It("these old entries should be deleted", func() {
sqlite := sqlite.Open("file::memory:")
2021-09-12 22:26:07 +02:00
writer := newDatabaseWriter(sqlite, 1, 1)
request := &model.Request{
Req: util.NewMsgWithQuestion("google.de.", dns.TypeA),
Log: logrus.NewEntry(logrus.New()),
}
res, err := util.NewMsgWithAnswer("example.com", 123, dns.TypeA, "123.124.122.122")
Expect(err).Should(Succeed())
response := &model.Response{
Res: res,
Reason: "Resolved",
2021-09-09 22:57:05 +02:00
RType: model.ResponseTypeRESOLVED,
}
// one entry with now as timestamp
writer.Write(&Entry{
Request: request,
Response: response,
Start: time.Now(),
DurationMs: 20,
})
// one entry before 2 days -> should be deleted
writer.Write(&Entry{
Request: request,
Response: response,
Start: time.Now().AddDate(0, 0, -2),
DurationMs: 20,
})
result := writer.db.Find(&logEntry{})
2021-09-12 22:26:07 +02:00
time.Sleep(500 * time.Millisecond)
var cnt int64
result.Count(&cnt)
// 2 entries in the database
Expect(cnt).Should(Equal(int64(2)))
// do cleanup now
writer.CleanUp()
result.Count(&cnt)
// now only 1 entry in the database
Expect(cnt).Should(Equal(int64(1)))
})
})
When("connection parameters wrong", func() {
It("should be log with fatal", func() {
helpertest.ShouldLogFatal(func() {
2021-09-12 22:26:07 +02:00
NewDatabaseWriter("wrong param", 7, 1)
})
})
})
})
})