mirror of
https://github.com/grafana/grafana.git
synced 2025-02-25 18:55:37 -06:00
testdata: logs scenario (#17182)
Adds logs scenario which is quite basic and not that smart to begin with. This will hopefully ease development of Explore and support for logs in Grafana.
This commit is contained in:
committed by
GitHub
parent
c82df97bb2
commit
3b008d06b4
79
pkg/tsdb/testdata/scenarios.go
vendored
79
pkg/tsdb/testdata/scenarios.go
vendored
@@ -2,6 +2,7 @@ package testdata
|
||||
|
||||
import (
|
||||
"encoding/json"
|
||||
"fmt"
|
||||
"math"
|
||||
"math/rand"
|
||||
"strconv"
|
||||
@@ -261,6 +262,84 @@ func init() {
|
||||
return queryRes
|
||||
},
|
||||
})
|
||||
|
||||
registerScenario(&Scenario{
|
||||
Id: "logs",
|
||||
Name: "Logs",
|
||||
|
||||
Handler: func(query *tsdb.Query, context *tsdb.TsdbQuery) *tsdb.QueryResult {
|
||||
from := context.TimeRange.GetFromAsMsEpoch()
|
||||
to := context.TimeRange.GetToAsMsEpoch()
|
||||
lines := query.Model.Get("lines").MustInt64(10)
|
||||
includeLevelColumn := query.Model.Get("levelColumn").MustBool(false)
|
||||
|
||||
logLevelGenerator := newRandomStringProvider([]string{
|
||||
"emerg",
|
||||
"alert",
|
||||
"crit",
|
||||
"critical",
|
||||
"warn",
|
||||
"warning",
|
||||
"err",
|
||||
"eror",
|
||||
"error",
|
||||
"info",
|
||||
"notice",
|
||||
"dbug",
|
||||
"debug",
|
||||
"trace",
|
||||
"",
|
||||
})
|
||||
containerIDGenerator := newRandomStringProvider([]string{
|
||||
"f36a9eaa6d34310686f2b851655212023a216de955cbcc764210cefa71179b1a",
|
||||
"5a354a630364f3742c602f315132e16def594fe68b1e4a195b2fce628e24c97a",
|
||||
})
|
||||
hostnameGenerator := newRandomStringProvider([]string{
|
||||
"srv-001",
|
||||
"srv-002",
|
||||
})
|
||||
|
||||
table := tsdb.Table{
|
||||
Columns: []tsdb.TableColumn{
|
||||
{Text: "time"},
|
||||
{Text: "message"},
|
||||
{Text: "container_id"},
|
||||
{Text: "hostname"},
|
||||
},
|
||||
Rows: []tsdb.RowValues{},
|
||||
}
|
||||
|
||||
if includeLevelColumn {
|
||||
table.Columns = append(table.Columns, tsdb.TableColumn{Text: "level"})
|
||||
}
|
||||
|
||||
for i := int64(0); i < lines && to > from; i++ {
|
||||
row := tsdb.RowValues{float64(to)}
|
||||
|
||||
logLevel := logLevelGenerator.Next()
|
||||
timeFormatted := time.Unix(to/1000, 0).Format(time.RFC3339)
|
||||
lvlString := ""
|
||||
if !includeLevelColumn {
|
||||
lvlString = fmt.Sprintf("lvl=%s ", logLevel)
|
||||
}
|
||||
|
||||
row = append(row, fmt.Sprintf("t=%s %smsg=\"Request Completed\" logger=context userId=1 orgId=1 uname=admin method=GET path=/api/datasources/proxy/152/api/prom/label status=502 remote_addr=[::1] time_ms=1 size=0 referer=\"http://localhost:3000/explore?left=%%5B%%22now-6h%%22,%%22now%%22,%%22Prometheus%%202.x%%22,%%7B%%7D,%%7B%%22ui%%22:%%5Btrue,true,true,%%22none%%22%%5D%%7D%%5D\"", timeFormatted, lvlString))
|
||||
row = append(row, containerIDGenerator.Next())
|
||||
row = append(row, hostnameGenerator.Next())
|
||||
|
||||
if includeLevelColumn {
|
||||
row = append(row, logLevel)
|
||||
}
|
||||
|
||||
table.Rows = append(table.Rows, row)
|
||||
to -= query.IntervalMs
|
||||
}
|
||||
|
||||
queryRes := tsdb.NewQueryResult()
|
||||
queryRes.Tables = append(queryRes.Tables, &table)
|
||||
return queryRes
|
||||
},
|
||||
})
|
||||
}
|
||||
|
||||
func getRandomWalk(query *tsdb.Query, tsdbQuery *tsdb.TsdbQuery) *tsdb.QueryResult {
|
||||
|
||||
22
pkg/tsdb/testdata/utils.go
vendored
Normal file
22
pkg/tsdb/testdata/utils.go
vendored
Normal file
@@ -0,0 +1,22 @@
|
||||
package testdata
|
||||
|
||||
import (
|
||||
"math/rand"
|
||||
"time"
|
||||
)
|
||||
|
||||
type randomStringProvider struct {
|
||||
r *rand.Rand
|
||||
data []string
|
||||
}
|
||||
|
||||
func newRandomStringProvider(data []string) *randomStringProvider {
|
||||
return &randomStringProvider{
|
||||
r: rand.New(rand.NewSource(time.Now().UnixNano())),
|
||||
data: data,
|
||||
}
|
||||
}
|
||||
|
||||
func (p *randomStringProvider) Next() string {
|
||||
return p.data[p.r.Int31n(int32(len(p.data)))]
|
||||
}
|
||||
Reference in New Issue
Block a user