2023-01-18 13:24:40 -06:00
|
|
|
package historian
|
|
|
|
|
|
|
|
import (
|
2023-01-26 03:31:20 -06:00
|
|
|
"context"
|
2023-01-18 13:24:40 -06:00
|
|
|
"net/url"
|
|
|
|
"testing"
|
2023-02-02 16:31:51 -06:00
|
|
|
"time"
|
2023-01-18 13:24:40 -06:00
|
|
|
|
2023-01-30 16:30:05 -06:00
|
|
|
"github.com/grafana/grafana/pkg/setting"
|
2023-01-18 13:24:40 -06:00
|
|
|
"github.com/stretchr/testify/require"
|
2023-01-30 02:55:35 -06:00
|
|
|
|
|
|
|
"github.com/grafana/grafana/pkg/infra/log"
|
2023-01-18 13:24:40 -06:00
|
|
|
)
|
|
|
|
|
2023-01-30 16:30:05 -06:00
|
|
|
func TestLokiConfig(t *testing.T) {
|
|
|
|
t.Run("test URL options", func(t *testing.T) {
|
|
|
|
type testCase struct {
|
|
|
|
name string
|
|
|
|
in setting.UnifiedAlertingStateHistorySettings
|
|
|
|
expRead string
|
|
|
|
expWrite string
|
|
|
|
expErr string
|
|
|
|
}
|
|
|
|
|
|
|
|
cases := []testCase{
|
|
|
|
{
|
|
|
|
name: "remote url only",
|
|
|
|
in: setting.UnifiedAlertingStateHistorySettings{
|
|
|
|
LokiRemoteURL: "http://url.com",
|
|
|
|
},
|
|
|
|
expRead: "http://url.com",
|
|
|
|
expWrite: "http://url.com",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "separate urls",
|
|
|
|
in: setting.UnifiedAlertingStateHistorySettings{
|
|
|
|
LokiReadURL: "http://read.url.com",
|
|
|
|
LokiWriteURL: "http://write.url.com",
|
|
|
|
},
|
|
|
|
expRead: "http://read.url.com",
|
|
|
|
expWrite: "http://write.url.com",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "single fallback",
|
|
|
|
in: setting.UnifiedAlertingStateHistorySettings{
|
|
|
|
LokiRemoteURL: "http://url.com",
|
|
|
|
LokiReadURL: "http://read.url.com",
|
|
|
|
},
|
|
|
|
expRead: "http://read.url.com",
|
|
|
|
expWrite: "http://url.com",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "invalid",
|
|
|
|
in: setting.UnifiedAlertingStateHistorySettings{
|
|
|
|
LokiRemoteURL: "://://",
|
|
|
|
},
|
|
|
|
expErr: "failed to parse",
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
for _, tc := range cases {
|
|
|
|
t.Run(tc.name, func(t *testing.T) {
|
|
|
|
res, err := NewLokiConfig(tc.in)
|
|
|
|
if tc.expErr != "" {
|
|
|
|
require.ErrorContains(t, err, tc.expErr)
|
|
|
|
} else {
|
|
|
|
require.Equal(t, tc.expRead, res.ReadPathURL.String())
|
|
|
|
require.Equal(t, tc.expWrite, res.WritePathURL.String())
|
|
|
|
}
|
|
|
|
})
|
|
|
|
}
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
2023-01-18 13:24:40 -06:00
|
|
|
// This function can be used for local testing, just remove the skip call.
|
|
|
|
func TestLokiHTTPClient(t *testing.T) {
|
|
|
|
t.Skip()
|
|
|
|
|
2023-01-23 16:31:03 -06:00
|
|
|
t.Run("smoke test pinging Loki", func(t *testing.T) {
|
|
|
|
url, err := url.Parse("https://logs-prod-eu-west-0.grafana.net")
|
|
|
|
require.NoError(t, err)
|
2023-01-18 13:24:40 -06:00
|
|
|
|
2023-01-23 16:31:03 -06:00
|
|
|
client := newLokiClient(LokiConfig{
|
2023-01-30 16:30:05 -06:00
|
|
|
ReadPathURL: url,
|
|
|
|
WritePathURL: url,
|
2023-01-23 16:31:03 -06:00
|
|
|
}, log.NewNopLogger())
|
2023-01-18 13:24:40 -06:00
|
|
|
|
2023-01-23 16:31:03 -06:00
|
|
|
// Unauthorized request should fail against Grafana Cloud.
|
2023-01-26 03:31:20 -06:00
|
|
|
err = client.ping(context.Background())
|
2023-01-23 16:31:03 -06:00
|
|
|
require.Error(t, err)
|
2023-01-18 13:24:40 -06:00
|
|
|
|
2023-01-23 16:31:03 -06:00
|
|
|
client.cfg.BasicAuthUser = "<your_username>"
|
|
|
|
client.cfg.BasicAuthPassword = "<your_password>"
|
2023-01-18 13:24:40 -06:00
|
|
|
|
2023-01-23 16:31:03 -06:00
|
|
|
// When running on prem, you might need to set the tenant id,
|
|
|
|
// so the x-scope-orgid header is set.
|
|
|
|
// client.cfg.TenantID = "<your_tenant_id>"
|
2023-01-18 13:24:40 -06:00
|
|
|
|
2023-02-02 16:31:51 -06:00
|
|
|
// Authorized request should not fail against Grafana Cloud.
|
2023-01-26 03:31:20 -06:00
|
|
|
err = client.ping(context.Background())
|
2023-01-23 16:31:03 -06:00
|
|
|
require.NoError(t, err)
|
|
|
|
})
|
2023-02-02 16:31:51 -06:00
|
|
|
|
2023-02-07 14:26:43 -06:00
|
|
|
t.Run("smoke test range querying Loki", func(t *testing.T) {
|
2023-02-02 16:31:51 -06:00
|
|
|
url, err := url.Parse("https://logs-prod-eu-west-0.grafana.net")
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
client := newLokiClient(LokiConfig{
|
|
|
|
ReadPathURL: url,
|
|
|
|
WritePathURL: url,
|
|
|
|
BasicAuthUser: "<your_username>",
|
|
|
|
BasicAuthPassword: "<your_password>",
|
|
|
|
}, log.NewNopLogger())
|
|
|
|
|
|
|
|
// When running on prem, you might need to set the tenant id,
|
|
|
|
// so the x-scope-orgid header is set.
|
|
|
|
// client.cfg.TenantID = "<your_tenant_id>"
|
|
|
|
|
|
|
|
// Create an array of selectors that should be used for the
|
|
|
|
// query.
|
|
|
|
selectors := []Selector{
|
|
|
|
{Label: "probe", Op: Eq, Value: "Paris"},
|
|
|
|
}
|
|
|
|
|
|
|
|
// Define the query time range
|
|
|
|
start := time.Now().Add(-30 * time.Minute).UnixNano()
|
|
|
|
end := time.Now().UnixNano()
|
|
|
|
|
|
|
|
// Authorized request should not fail against Grafana Cloud.
|
2023-02-07 14:26:43 -06:00
|
|
|
res, err := client.rangeQuery(context.Background(), selectors, start, end)
|
2023-02-02 16:31:51 -06:00
|
|
|
require.NoError(t, err)
|
|
|
|
require.NotNil(t, res)
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestSelectorString(t *testing.T) {
|
|
|
|
selectors := []Selector{{"name", "=", "Bob"}, {"age", "=~", "30"}}
|
|
|
|
expected := "{name=\"Bob\",age=~\"30\"}"
|
|
|
|
result := selectorString(selectors)
|
|
|
|
require.Equal(t, expected, result)
|
|
|
|
|
|
|
|
selectors = []Selector{}
|
|
|
|
expected = "{}"
|
|
|
|
result = selectorString(selectors)
|
|
|
|
require.Equal(t, expected, result)
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestNewSelector(t *testing.T) {
|
|
|
|
selector, err := NewSelector("label", "=", "value")
|
|
|
|
require.NoError(t, err)
|
|
|
|
require.Equal(t, "label", selector.Label)
|
|
|
|
require.Equal(t, Eq, selector.Op)
|
|
|
|
require.Equal(t, "value", selector.Value)
|
|
|
|
|
|
|
|
selector, err = NewSelector("label", "invalid", "value")
|
|
|
|
require.Error(t, err)
|
2023-01-18 13:24:40 -06:00
|
|
|
}
|