mirror of
https://github.com/grafana/grafana.git
synced 2025-09-24 10:33:58 +08:00
Merge pull request #13498 from svenklemm/sql-macros2
move timeFrom, timeTo, unixEpochFrom and unixEpochTo macros to sql_engine
This commit is contained in:
@ -66,10 +66,6 @@ func (m *msSqlMacroEngine) evaluateMacro(name string, args []string) (string, er
|
|||||||
}
|
}
|
||||||
|
|
||||||
return fmt.Sprintf("%s BETWEEN '%s' AND '%s'", args[0], m.timeRange.GetFromAsTimeUTC().Format(time.RFC3339), m.timeRange.GetToAsTimeUTC().Format(time.RFC3339)), nil
|
return fmt.Sprintf("%s BETWEEN '%s' AND '%s'", args[0], m.timeRange.GetFromAsTimeUTC().Format(time.RFC3339), m.timeRange.GetToAsTimeUTC().Format(time.RFC3339)), nil
|
||||||
case "__timeFrom":
|
|
||||||
return fmt.Sprintf("'%s'", m.timeRange.GetFromAsTimeUTC().Format(time.RFC3339)), nil
|
|
||||||
case "__timeTo":
|
|
||||||
return fmt.Sprintf("'%s'", m.timeRange.GetToAsTimeUTC().Format(time.RFC3339)), nil
|
|
||||||
case "__timeGroup":
|
case "__timeGroup":
|
||||||
if len(args) < 2 {
|
if len(args) < 2 {
|
||||||
return "", fmt.Errorf("macro %v needs time column and interval", name)
|
return "", fmt.Errorf("macro %v needs time column and interval", name)
|
||||||
@ -96,10 +92,6 @@ func (m *msSqlMacroEngine) evaluateMacro(name string, args []string) (string, er
|
|||||||
return "", fmt.Errorf("missing time column argument for macro %v", name)
|
return "", fmt.Errorf("missing time column argument for macro %v", name)
|
||||||
}
|
}
|
||||||
return fmt.Sprintf("%s >= %d AND %s <= %d", args[0], m.timeRange.GetFromAsSecondsEpoch(), args[0], m.timeRange.GetToAsSecondsEpoch()), nil
|
return fmt.Sprintf("%s >= %d AND %s <= %d", args[0], m.timeRange.GetFromAsSecondsEpoch(), args[0], m.timeRange.GetToAsSecondsEpoch()), nil
|
||||||
case "__unixEpochFrom":
|
|
||||||
return fmt.Sprintf("%d", m.timeRange.GetFromAsSecondsEpoch()), nil
|
|
||||||
case "__unixEpochTo":
|
|
||||||
return fmt.Sprintf("%d", m.timeRange.GetToAsSecondsEpoch()), nil
|
|
||||||
case "__unixEpochGroup":
|
case "__unixEpochGroup":
|
||||||
if len(args) < 2 {
|
if len(args) < 2 {
|
||||||
return "", fmt.Errorf("macro %v needs time column and interval and optional fill value", name)
|
return "", fmt.Errorf("macro %v needs time column and interval and optional fill value", name)
|
||||||
|
@ -111,20 +111,6 @@ func TestMacroEngine(t *testing.T) {
|
|||||||
So(fillInterval, ShouldEqual, 5*time.Minute.Seconds())
|
So(fillInterval, ShouldEqual, 5*time.Minute.Seconds())
|
||||||
})
|
})
|
||||||
|
|
||||||
Convey("interpolate __timeFrom function", func() {
|
|
||||||
sql, err := engine.Interpolate(query, timeRange, "select $__timeFrom(time_column)")
|
|
||||||
So(err, ShouldBeNil)
|
|
||||||
|
|
||||||
So(sql, ShouldEqual, fmt.Sprintf("select '%s'", from.Format(time.RFC3339)))
|
|
||||||
})
|
|
||||||
|
|
||||||
Convey("interpolate __timeTo function", func() {
|
|
||||||
sql, err := engine.Interpolate(query, timeRange, "select $__timeTo(time_column)")
|
|
||||||
So(err, ShouldBeNil)
|
|
||||||
|
|
||||||
So(sql, ShouldEqual, fmt.Sprintf("select '%s'", to.Format(time.RFC3339)))
|
|
||||||
})
|
|
||||||
|
|
||||||
Convey("interpolate __unixEpochFilter function", func() {
|
Convey("interpolate __unixEpochFilter function", func() {
|
||||||
sql, err := engine.Interpolate(query, timeRange, "select $__unixEpochFilter(time_column)")
|
sql, err := engine.Interpolate(query, timeRange, "select $__unixEpochFilter(time_column)")
|
||||||
So(err, ShouldBeNil)
|
So(err, ShouldBeNil)
|
||||||
@ -132,20 +118,6 @@ func TestMacroEngine(t *testing.T) {
|
|||||||
So(sql, ShouldEqual, fmt.Sprintf("select time_column >= %d AND time_column <= %d", from.Unix(), to.Unix()))
|
So(sql, ShouldEqual, fmt.Sprintf("select time_column >= %d AND time_column <= %d", from.Unix(), to.Unix()))
|
||||||
})
|
})
|
||||||
|
|
||||||
Convey("interpolate __unixEpochFrom function", func() {
|
|
||||||
sql, err := engine.Interpolate(query, timeRange, "select $__unixEpochFrom()")
|
|
||||||
So(err, ShouldBeNil)
|
|
||||||
|
|
||||||
So(sql, ShouldEqual, fmt.Sprintf("select %d", from.Unix()))
|
|
||||||
})
|
|
||||||
|
|
||||||
Convey("interpolate __unixEpochTo function", func() {
|
|
||||||
sql, err := engine.Interpolate(query, timeRange, "select $__unixEpochTo()")
|
|
||||||
So(err, ShouldBeNil)
|
|
||||||
|
|
||||||
So(sql, ShouldEqual, fmt.Sprintf("select %d", to.Unix()))
|
|
||||||
})
|
|
||||||
|
|
||||||
Convey("interpolate __unixEpochGroup function", func() {
|
Convey("interpolate __unixEpochGroup function", func() {
|
||||||
|
|
||||||
sql, err := engine.Interpolate(query, timeRange, "SELECT $__unixEpochGroup(time_column,'5m')")
|
sql, err := engine.Interpolate(query, timeRange, "SELECT $__unixEpochGroup(time_column,'5m')")
|
||||||
@ -171,40 +143,12 @@ func TestMacroEngine(t *testing.T) {
|
|||||||
So(sql, ShouldEqual, fmt.Sprintf("WHERE time_column BETWEEN '%s' AND '%s'", from.Format(time.RFC3339), to.Format(time.RFC3339)))
|
So(sql, ShouldEqual, fmt.Sprintf("WHERE time_column BETWEEN '%s' AND '%s'", from.Format(time.RFC3339), to.Format(time.RFC3339)))
|
||||||
})
|
})
|
||||||
|
|
||||||
Convey("interpolate __timeFrom function", func() {
|
|
||||||
sql, err := engine.Interpolate(query, timeRange, "select $__timeFrom(time_column)")
|
|
||||||
So(err, ShouldBeNil)
|
|
||||||
|
|
||||||
So(sql, ShouldEqual, fmt.Sprintf("select '%s'", from.Format(time.RFC3339)))
|
|
||||||
})
|
|
||||||
|
|
||||||
Convey("interpolate __timeTo function", func() {
|
|
||||||
sql, err := engine.Interpolate(query, timeRange, "select $__timeTo(time_column)")
|
|
||||||
So(err, ShouldBeNil)
|
|
||||||
|
|
||||||
So(sql, ShouldEqual, fmt.Sprintf("select '%s'", to.Format(time.RFC3339)))
|
|
||||||
})
|
|
||||||
|
|
||||||
Convey("interpolate __unixEpochFilter function", func() {
|
Convey("interpolate __unixEpochFilter function", func() {
|
||||||
sql, err := engine.Interpolate(query, timeRange, "select $__unixEpochFilter(time_column)")
|
sql, err := engine.Interpolate(query, timeRange, "select $__unixEpochFilter(time_column)")
|
||||||
So(err, ShouldBeNil)
|
So(err, ShouldBeNil)
|
||||||
|
|
||||||
So(sql, ShouldEqual, fmt.Sprintf("select time_column >= %d AND time_column <= %d", from.Unix(), to.Unix()))
|
So(sql, ShouldEqual, fmt.Sprintf("select time_column >= %d AND time_column <= %d", from.Unix(), to.Unix()))
|
||||||
})
|
})
|
||||||
|
|
||||||
Convey("interpolate __unixEpochFrom function", func() {
|
|
||||||
sql, err := engine.Interpolate(query, timeRange, "select $__unixEpochFrom()")
|
|
||||||
So(err, ShouldBeNil)
|
|
||||||
|
|
||||||
So(sql, ShouldEqual, fmt.Sprintf("select %d", from.Unix()))
|
|
||||||
})
|
|
||||||
|
|
||||||
Convey("interpolate __unixEpochTo function", func() {
|
|
||||||
sql, err := engine.Interpolate(query, timeRange, "select $__unixEpochTo()")
|
|
||||||
So(err, ShouldBeNil)
|
|
||||||
|
|
||||||
So(sql, ShouldEqual, fmt.Sprintf("select %d", to.Unix()))
|
|
||||||
})
|
|
||||||
})
|
})
|
||||||
|
|
||||||
Convey("Given a time range between 1960-02-01 07:00 and 1980-02-03 08:00", func() {
|
Convey("Given a time range between 1960-02-01 07:00 and 1980-02-03 08:00", func() {
|
||||||
@ -219,40 +163,12 @@ func TestMacroEngine(t *testing.T) {
|
|||||||
So(sql, ShouldEqual, fmt.Sprintf("WHERE time_column BETWEEN '%s' AND '%s'", from.Format(time.RFC3339), to.Format(time.RFC3339)))
|
So(sql, ShouldEqual, fmt.Sprintf("WHERE time_column BETWEEN '%s' AND '%s'", from.Format(time.RFC3339), to.Format(time.RFC3339)))
|
||||||
})
|
})
|
||||||
|
|
||||||
Convey("interpolate __timeFrom function", func() {
|
|
||||||
sql, err := engine.Interpolate(query, timeRange, "select $__timeFrom(time_column)")
|
|
||||||
So(err, ShouldBeNil)
|
|
||||||
|
|
||||||
So(sql, ShouldEqual, fmt.Sprintf("select '%s'", from.Format(time.RFC3339)))
|
|
||||||
})
|
|
||||||
|
|
||||||
Convey("interpolate __timeTo function", func() {
|
|
||||||
sql, err := engine.Interpolate(query, timeRange, "select $__timeTo(time_column)")
|
|
||||||
So(err, ShouldBeNil)
|
|
||||||
|
|
||||||
So(sql, ShouldEqual, fmt.Sprintf("select '%s'", to.Format(time.RFC3339)))
|
|
||||||
})
|
|
||||||
|
|
||||||
Convey("interpolate __unixEpochFilter function", func() {
|
Convey("interpolate __unixEpochFilter function", func() {
|
||||||
sql, err := engine.Interpolate(query, timeRange, "select $__unixEpochFilter(time_column)")
|
sql, err := engine.Interpolate(query, timeRange, "select $__unixEpochFilter(time_column)")
|
||||||
So(err, ShouldBeNil)
|
So(err, ShouldBeNil)
|
||||||
|
|
||||||
So(sql, ShouldEqual, fmt.Sprintf("select time_column >= %d AND time_column <= %d", from.Unix(), to.Unix()))
|
So(sql, ShouldEqual, fmt.Sprintf("select time_column >= %d AND time_column <= %d", from.Unix(), to.Unix()))
|
||||||
})
|
})
|
||||||
|
|
||||||
Convey("interpolate __unixEpochFrom function", func() {
|
|
||||||
sql, err := engine.Interpolate(query, timeRange, "select $__unixEpochFrom()")
|
|
||||||
So(err, ShouldBeNil)
|
|
||||||
|
|
||||||
So(sql, ShouldEqual, fmt.Sprintf("select %d", from.Unix()))
|
|
||||||
})
|
|
||||||
|
|
||||||
Convey("interpolate __unixEpochTo function", func() {
|
|
||||||
sql, err := engine.Interpolate(query, timeRange, "select $__unixEpochTo()")
|
|
||||||
So(err, ShouldBeNil)
|
|
||||||
|
|
||||||
So(sql, ShouldEqual, fmt.Sprintf("select %d", to.Unix()))
|
|
||||||
})
|
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
@ -676,6 +676,30 @@ func TestMSSQL(t *testing.T) {
|
|||||||
So(queryResult.Series[3].Name, ShouldEqual, "Metric B valueTwo")
|
So(queryResult.Series[3].Name, ShouldEqual, "Metric B valueTwo")
|
||||||
})
|
})
|
||||||
|
|
||||||
|
Convey("When doing a query with timeFrom,timeTo,unixEpochFrom,unixEpochTo macros", func() {
|
||||||
|
tsdb.Interpolate = origInterpolate
|
||||||
|
query := &tsdb.TsdbQuery{
|
||||||
|
TimeRange: tsdb.NewFakeTimeRange("5m", "now", fromStart),
|
||||||
|
Queries: []*tsdb.Query{
|
||||||
|
{
|
||||||
|
DataSource: &models.DataSource{JsonData: simplejson.New()},
|
||||||
|
Model: simplejson.NewFromAny(map[string]interface{}{
|
||||||
|
"rawSql": `SELECT time FROM metric_values WHERE time > $__timeFrom() OR time < $__timeFrom() OR 1 < $__unixEpochFrom() OR $__unixEpochTo() > 1 ORDER BY 1`,
|
||||||
|
"format": "time_series",
|
||||||
|
}),
|
||||||
|
RefId: "A",
|
||||||
|
},
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
resp, err := endpoint.Query(nil, nil, query)
|
||||||
|
So(err, ShouldBeNil)
|
||||||
|
queryResult := resp.Results["A"]
|
||||||
|
So(queryResult.Error, ShouldBeNil)
|
||||||
|
So(queryResult.Meta.Get("sql").MustString(), ShouldEqual, "SELECT time FROM metric_values WHERE time > '2018-03-15T12:55:00Z' OR time < '2018-03-15T12:55:00Z' OR 1 < 1521118500 OR 1521118800 > 1 ORDER BY 1")
|
||||||
|
|
||||||
|
})
|
||||||
|
|
||||||
Convey("Given a stored procedure that takes @from and @to in epoch time", func() {
|
Convey("Given a stored procedure that takes @from and @to in epoch time", func() {
|
||||||
sql := `
|
sql := `
|
||||||
IF object_id('sp_test_epoch') IS NOT NULL
|
IF object_id('sp_test_epoch') IS NOT NULL
|
||||||
@ -720,9 +744,11 @@ func TestMSSQL(t *testing.T) {
|
|||||||
So(err, ShouldBeNil)
|
So(err, ShouldBeNil)
|
||||||
|
|
||||||
Convey("When doing a metric query using stored procedure should return correct result", func() {
|
Convey("When doing a metric query using stored procedure should return correct result", func() {
|
||||||
|
tsdb.Interpolate = origInterpolate
|
||||||
query := &tsdb.TsdbQuery{
|
query := &tsdb.TsdbQuery{
|
||||||
Queries: []*tsdb.Query{
|
Queries: []*tsdb.Query{
|
||||||
{
|
{
|
||||||
|
DataSource: &models.DataSource{JsonData: simplejson.New()},
|
||||||
Model: simplejson.NewFromAny(map[string]interface{}{
|
Model: simplejson.NewFromAny(map[string]interface{}{
|
||||||
"rawSql": `DECLARE
|
"rawSql": `DECLARE
|
||||||
@from int = $__unixEpochFrom(),
|
@from int = $__unixEpochFrom(),
|
||||||
@ -797,9 +823,11 @@ func TestMSSQL(t *testing.T) {
|
|||||||
So(err, ShouldBeNil)
|
So(err, ShouldBeNil)
|
||||||
|
|
||||||
Convey("When doing a metric query using stored procedure should return correct result", func() {
|
Convey("When doing a metric query using stored procedure should return correct result", func() {
|
||||||
|
tsdb.Interpolate = origInterpolate
|
||||||
query := &tsdb.TsdbQuery{
|
query := &tsdb.TsdbQuery{
|
||||||
Queries: []*tsdb.Query{
|
Queries: []*tsdb.Query{
|
||||||
{
|
{
|
||||||
|
DataSource: &models.DataSource{JsonData: simplejson.New()},
|
||||||
Model: simplejson.NewFromAny(map[string]interface{}{
|
Model: simplejson.NewFromAny(map[string]interface{}{
|
||||||
"rawSql": `DECLARE
|
"rawSql": `DECLARE
|
||||||
@from int = $__unixEpochFrom(),
|
@from int = $__unixEpochFrom(),
|
||||||
|
@ -61,10 +61,6 @@ func (m *mySqlMacroEngine) evaluateMacro(name string, args []string) (string, er
|
|||||||
}
|
}
|
||||||
|
|
||||||
return fmt.Sprintf("%s BETWEEN '%s' AND '%s'", args[0], m.timeRange.GetFromAsTimeUTC().Format(time.RFC3339), m.timeRange.GetToAsTimeUTC().Format(time.RFC3339)), nil
|
return fmt.Sprintf("%s BETWEEN '%s' AND '%s'", args[0], m.timeRange.GetFromAsTimeUTC().Format(time.RFC3339), m.timeRange.GetToAsTimeUTC().Format(time.RFC3339)), nil
|
||||||
case "__timeFrom":
|
|
||||||
return fmt.Sprintf("'%s'", m.timeRange.GetFromAsTimeUTC().Format(time.RFC3339)), nil
|
|
||||||
case "__timeTo":
|
|
||||||
return fmt.Sprintf("'%s'", m.timeRange.GetToAsTimeUTC().Format(time.RFC3339)), nil
|
|
||||||
case "__timeGroup":
|
case "__timeGroup":
|
||||||
if len(args) < 2 {
|
if len(args) < 2 {
|
||||||
return "", fmt.Errorf("macro %v needs time column and interval", name)
|
return "", fmt.Errorf("macro %v needs time column and interval", name)
|
||||||
@ -91,10 +87,6 @@ func (m *mySqlMacroEngine) evaluateMacro(name string, args []string) (string, er
|
|||||||
return "", fmt.Errorf("missing time column argument for macro %v", name)
|
return "", fmt.Errorf("missing time column argument for macro %v", name)
|
||||||
}
|
}
|
||||||
return fmt.Sprintf("%s >= %d AND %s <= %d", args[0], m.timeRange.GetFromAsSecondsEpoch(), args[0], m.timeRange.GetToAsSecondsEpoch()), nil
|
return fmt.Sprintf("%s >= %d AND %s <= %d", args[0], m.timeRange.GetFromAsSecondsEpoch(), args[0], m.timeRange.GetToAsSecondsEpoch()), nil
|
||||||
case "__unixEpochFrom":
|
|
||||||
return fmt.Sprintf("%d", m.timeRange.GetFromAsSecondsEpoch()), nil
|
|
||||||
case "__unixEpochTo":
|
|
||||||
return fmt.Sprintf("%d", m.timeRange.GetToAsSecondsEpoch()), nil
|
|
||||||
case "__unixEpochGroup":
|
case "__unixEpochGroup":
|
||||||
if len(args) < 2 {
|
if len(args) < 2 {
|
||||||
return "", fmt.Errorf("macro %v needs time column and interval and optional fill value", name)
|
return "", fmt.Errorf("macro %v needs time column and interval and optional fill value", name)
|
||||||
|
@ -63,20 +63,6 @@ func TestMacroEngine(t *testing.T) {
|
|||||||
So(sql, ShouldEqual, fmt.Sprintf("WHERE time_column BETWEEN '%s' AND '%s'", from.Format(time.RFC3339), to.Format(time.RFC3339)))
|
So(sql, ShouldEqual, fmt.Sprintf("WHERE time_column BETWEEN '%s' AND '%s'", from.Format(time.RFC3339), to.Format(time.RFC3339)))
|
||||||
})
|
})
|
||||||
|
|
||||||
Convey("interpolate __timeFrom function", func() {
|
|
||||||
sql, err := engine.Interpolate(query, timeRange, "select $__timeFrom(time_column)")
|
|
||||||
So(err, ShouldBeNil)
|
|
||||||
|
|
||||||
So(sql, ShouldEqual, fmt.Sprintf("select '%s'", from.Format(time.RFC3339)))
|
|
||||||
})
|
|
||||||
|
|
||||||
Convey("interpolate __timeTo function", func() {
|
|
||||||
sql, err := engine.Interpolate(query, timeRange, "select $__timeTo(time_column)")
|
|
||||||
So(err, ShouldBeNil)
|
|
||||||
|
|
||||||
So(sql, ShouldEqual, fmt.Sprintf("select '%s'", to.Format(time.RFC3339)))
|
|
||||||
})
|
|
||||||
|
|
||||||
Convey("interpolate __unixEpochFilter function", func() {
|
Convey("interpolate __unixEpochFilter function", func() {
|
||||||
sql, err := engine.Interpolate(query, timeRange, "select $__unixEpochFilter(time)")
|
sql, err := engine.Interpolate(query, timeRange, "select $__unixEpochFilter(time)")
|
||||||
So(err, ShouldBeNil)
|
So(err, ShouldBeNil)
|
||||||
@ -84,20 +70,6 @@ func TestMacroEngine(t *testing.T) {
|
|||||||
So(sql, ShouldEqual, fmt.Sprintf("select time >= %d AND time <= %d", from.Unix(), to.Unix()))
|
So(sql, ShouldEqual, fmt.Sprintf("select time >= %d AND time <= %d", from.Unix(), to.Unix()))
|
||||||
})
|
})
|
||||||
|
|
||||||
Convey("interpolate __unixEpochFrom function", func() {
|
|
||||||
sql, err := engine.Interpolate(query, timeRange, "select $__unixEpochFrom()")
|
|
||||||
So(err, ShouldBeNil)
|
|
||||||
|
|
||||||
So(sql, ShouldEqual, fmt.Sprintf("select %d", from.Unix()))
|
|
||||||
})
|
|
||||||
|
|
||||||
Convey("interpolate __unixEpochTo function", func() {
|
|
||||||
sql, err := engine.Interpolate(query, timeRange, "select $__unixEpochTo()")
|
|
||||||
So(err, ShouldBeNil)
|
|
||||||
|
|
||||||
So(sql, ShouldEqual, fmt.Sprintf("select %d", to.Unix()))
|
|
||||||
})
|
|
||||||
|
|
||||||
Convey("interpolate __unixEpochGroup function", func() {
|
Convey("interpolate __unixEpochGroup function", func() {
|
||||||
|
|
||||||
sql, err := engine.Interpolate(query, timeRange, "SELECT $__unixEpochGroup(time_column,'5m')")
|
sql, err := engine.Interpolate(query, timeRange, "SELECT $__unixEpochGroup(time_column,'5m')")
|
||||||
@ -123,40 +95,12 @@ func TestMacroEngine(t *testing.T) {
|
|||||||
So(sql, ShouldEqual, fmt.Sprintf("WHERE time_column BETWEEN '%s' AND '%s'", from.Format(time.RFC3339), to.Format(time.RFC3339)))
|
So(sql, ShouldEqual, fmt.Sprintf("WHERE time_column BETWEEN '%s' AND '%s'", from.Format(time.RFC3339), to.Format(time.RFC3339)))
|
||||||
})
|
})
|
||||||
|
|
||||||
Convey("interpolate __timeFrom function", func() {
|
|
||||||
sql, err := engine.Interpolate(query, timeRange, "select $__timeFrom(time_column)")
|
|
||||||
So(err, ShouldBeNil)
|
|
||||||
|
|
||||||
So(sql, ShouldEqual, fmt.Sprintf("select '%s'", from.Format(time.RFC3339)))
|
|
||||||
})
|
|
||||||
|
|
||||||
Convey("interpolate __timeTo function", func() {
|
|
||||||
sql, err := engine.Interpolate(query, timeRange, "select $__timeTo(time_column)")
|
|
||||||
So(err, ShouldBeNil)
|
|
||||||
|
|
||||||
So(sql, ShouldEqual, fmt.Sprintf("select '%s'", to.Format(time.RFC3339)))
|
|
||||||
})
|
|
||||||
|
|
||||||
Convey("interpolate __unixEpochFilter function", func() {
|
Convey("interpolate __unixEpochFilter function", func() {
|
||||||
sql, err := engine.Interpolate(query, timeRange, "select $__unixEpochFilter(time)")
|
sql, err := engine.Interpolate(query, timeRange, "select $__unixEpochFilter(time)")
|
||||||
So(err, ShouldBeNil)
|
So(err, ShouldBeNil)
|
||||||
|
|
||||||
So(sql, ShouldEqual, fmt.Sprintf("select time >= %d AND time <= %d", from.Unix(), to.Unix()))
|
So(sql, ShouldEqual, fmt.Sprintf("select time >= %d AND time <= %d", from.Unix(), to.Unix()))
|
||||||
})
|
})
|
||||||
|
|
||||||
Convey("interpolate __unixEpochFrom function", func() {
|
|
||||||
sql, err := engine.Interpolate(query, timeRange, "select $__unixEpochFrom()")
|
|
||||||
So(err, ShouldBeNil)
|
|
||||||
|
|
||||||
So(sql, ShouldEqual, fmt.Sprintf("select %d", from.Unix()))
|
|
||||||
})
|
|
||||||
|
|
||||||
Convey("interpolate __unixEpochTo function", func() {
|
|
||||||
sql, err := engine.Interpolate(query, timeRange, "select $__unixEpochTo()")
|
|
||||||
So(err, ShouldBeNil)
|
|
||||||
|
|
||||||
So(sql, ShouldEqual, fmt.Sprintf("select %d", to.Unix()))
|
|
||||||
})
|
|
||||||
})
|
})
|
||||||
|
|
||||||
Convey("Given a time range between 1960-02-01 07:00 and 1980-02-03 08:00", func() {
|
Convey("Given a time range between 1960-02-01 07:00 and 1980-02-03 08:00", func() {
|
||||||
@ -171,40 +115,12 @@ func TestMacroEngine(t *testing.T) {
|
|||||||
So(sql, ShouldEqual, fmt.Sprintf("WHERE time_column BETWEEN '%s' AND '%s'", from.Format(time.RFC3339), to.Format(time.RFC3339)))
|
So(sql, ShouldEqual, fmt.Sprintf("WHERE time_column BETWEEN '%s' AND '%s'", from.Format(time.RFC3339), to.Format(time.RFC3339)))
|
||||||
})
|
})
|
||||||
|
|
||||||
Convey("interpolate __timeFrom function", func() {
|
|
||||||
sql, err := engine.Interpolate(query, timeRange, "select $__timeFrom(time_column)")
|
|
||||||
So(err, ShouldBeNil)
|
|
||||||
|
|
||||||
So(sql, ShouldEqual, fmt.Sprintf("select '%s'", from.Format(time.RFC3339)))
|
|
||||||
})
|
|
||||||
|
|
||||||
Convey("interpolate __timeTo function", func() {
|
|
||||||
sql, err := engine.Interpolate(query, timeRange, "select $__timeTo(time_column)")
|
|
||||||
So(err, ShouldBeNil)
|
|
||||||
|
|
||||||
So(sql, ShouldEqual, fmt.Sprintf("select '%s'", to.Format(time.RFC3339)))
|
|
||||||
})
|
|
||||||
|
|
||||||
Convey("interpolate __unixEpochFilter function", func() {
|
Convey("interpolate __unixEpochFilter function", func() {
|
||||||
sql, err := engine.Interpolate(query, timeRange, "select $__unixEpochFilter(time)")
|
sql, err := engine.Interpolate(query, timeRange, "select $__unixEpochFilter(time)")
|
||||||
So(err, ShouldBeNil)
|
So(err, ShouldBeNil)
|
||||||
|
|
||||||
So(sql, ShouldEqual, fmt.Sprintf("select time >= %d AND time <= %d", from.Unix(), to.Unix()))
|
So(sql, ShouldEqual, fmt.Sprintf("select time >= %d AND time <= %d", from.Unix(), to.Unix()))
|
||||||
})
|
})
|
||||||
|
|
||||||
Convey("interpolate __unixEpochFrom function", func() {
|
|
||||||
sql, err := engine.Interpolate(query, timeRange, "select $__unixEpochFrom()")
|
|
||||||
So(err, ShouldBeNil)
|
|
||||||
|
|
||||||
So(sql, ShouldEqual, fmt.Sprintf("select %d", from.Unix()))
|
|
||||||
})
|
|
||||||
|
|
||||||
Convey("interpolate __unixEpochTo function", func() {
|
|
||||||
sql, err := engine.Interpolate(query, timeRange, "select $__unixEpochTo()")
|
|
||||||
So(err, ShouldBeNil)
|
|
||||||
|
|
||||||
So(sql, ShouldEqual, fmt.Sprintf("select %d", to.Unix()))
|
|
||||||
})
|
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
@ -314,7 +314,7 @@ func TestMySQL(t *testing.T) {
|
|||||||
query := &tsdb.TsdbQuery{
|
query := &tsdb.TsdbQuery{
|
||||||
Queries: []*tsdb.Query{
|
Queries: []*tsdb.Query{
|
||||||
{
|
{
|
||||||
DataSource: &models.DataSource{},
|
DataSource: &models.DataSource{JsonData: simplejson.New()},
|
||||||
Model: simplejson.NewFromAny(map[string]interface{}{
|
Model: simplejson.NewFromAny(map[string]interface{}{
|
||||||
"rawSql": "SELECT $__timeGroup(time, $__interval) AS time, avg(value) as value FROM metric GROUP BY 1 ORDER BY 1",
|
"rawSql": "SELECT $__timeGroup(time, $__interval) AS time, avg(value) as value FROM metric GROUP BY 1 ORDER BY 1",
|
||||||
"format": "time_series",
|
"format": "time_series",
|
||||||
@ -753,6 +753,30 @@ func TestMySQL(t *testing.T) {
|
|||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|
||||||
|
Convey("When doing a query with timeFrom,timeTo,unixEpochFrom,unixEpochTo macros", func() {
|
||||||
|
tsdb.Interpolate = origInterpolate
|
||||||
|
query := &tsdb.TsdbQuery{
|
||||||
|
TimeRange: tsdb.NewFakeTimeRange("5m", "now", fromStart),
|
||||||
|
Queries: []*tsdb.Query{
|
||||||
|
{
|
||||||
|
DataSource: &models.DataSource{JsonData: simplejson.New()},
|
||||||
|
Model: simplejson.NewFromAny(map[string]interface{}{
|
||||||
|
"rawSql": `SELECT time FROM metric_values WHERE time > $__timeFrom() OR time < $__timeFrom() OR 1 < $__unixEpochFrom() OR $__unixEpochTo() > 1 ORDER BY 1`,
|
||||||
|
"format": "time_series",
|
||||||
|
}),
|
||||||
|
RefId: "A",
|
||||||
|
},
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
resp, err := endpoint.Query(nil, nil, query)
|
||||||
|
So(err, ShouldBeNil)
|
||||||
|
queryResult := resp.Results["A"]
|
||||||
|
So(queryResult.Error, ShouldBeNil)
|
||||||
|
So(queryResult.Meta.Get("sql").MustString(), ShouldEqual, "SELECT time FROM metric_values WHERE time > '2018-03-15T12:55:00Z' OR time < '2018-03-15T12:55:00Z' OR 1 < 1521118500 OR 1521118800 > 1 ORDER BY 1")
|
||||||
|
|
||||||
|
})
|
||||||
|
|
||||||
Convey("Given a table with event data", func() {
|
Convey("Given a table with event data", func() {
|
||||||
type event struct {
|
type event struct {
|
||||||
TimeSec int64
|
TimeSec int64
|
||||||
|
@ -87,10 +87,6 @@ func (m *postgresMacroEngine) evaluateMacro(name string, args []string) (string,
|
|||||||
}
|
}
|
||||||
|
|
||||||
return fmt.Sprintf("%s BETWEEN '%s' AND '%s'", args[0], m.timeRange.GetFromAsTimeUTC().Format(time.RFC3339), m.timeRange.GetToAsTimeUTC().Format(time.RFC3339)), nil
|
return fmt.Sprintf("%s BETWEEN '%s' AND '%s'", args[0], m.timeRange.GetFromAsTimeUTC().Format(time.RFC3339), m.timeRange.GetToAsTimeUTC().Format(time.RFC3339)), nil
|
||||||
case "__timeFrom":
|
|
||||||
return fmt.Sprintf("'%s'", m.timeRange.GetFromAsTimeUTC().Format(time.RFC3339)), nil
|
|
||||||
case "__timeTo":
|
|
||||||
return fmt.Sprintf("'%s'", m.timeRange.GetToAsTimeUTC().Format(time.RFC3339)), nil
|
|
||||||
case "__timeGroup":
|
case "__timeGroup":
|
||||||
if len(args) < 2 {
|
if len(args) < 2 {
|
||||||
return "", fmt.Errorf("macro %v needs time column and interval and optional fill value", name)
|
return "", fmt.Errorf("macro %v needs time column and interval and optional fill value", name)
|
||||||
@ -122,10 +118,6 @@ func (m *postgresMacroEngine) evaluateMacro(name string, args []string) (string,
|
|||||||
return "", fmt.Errorf("missing time column argument for macro %v", name)
|
return "", fmt.Errorf("missing time column argument for macro %v", name)
|
||||||
}
|
}
|
||||||
return fmt.Sprintf("%s >= %d AND %s <= %d", args[0], m.timeRange.GetFromAsSecondsEpoch(), args[0], m.timeRange.GetToAsSecondsEpoch()), nil
|
return fmt.Sprintf("%s >= %d AND %s <= %d", args[0], m.timeRange.GetFromAsSecondsEpoch(), args[0], m.timeRange.GetToAsSecondsEpoch()), nil
|
||||||
case "__unixEpochFrom":
|
|
||||||
return fmt.Sprintf("%d", m.timeRange.GetFromAsSecondsEpoch()), nil
|
|
||||||
case "__unixEpochTo":
|
|
||||||
return fmt.Sprintf("%d", m.timeRange.GetToAsSecondsEpoch()), nil
|
|
||||||
case "__unixEpochGroup":
|
case "__unixEpochGroup":
|
||||||
if len(args) < 2 {
|
if len(args) < 2 {
|
||||||
return "", fmt.Errorf("macro %v needs time column and interval and optional fill value", name)
|
return "", fmt.Errorf("macro %v needs time column and interval and optional fill value", name)
|
||||||
|
@ -44,13 +44,6 @@ func TestMacroEngine(t *testing.T) {
|
|||||||
So(sql, ShouldEqual, fmt.Sprintf("WHERE time_column BETWEEN '%s' AND '%s'", from.Format(time.RFC3339), to.Format(time.RFC3339)))
|
So(sql, ShouldEqual, fmt.Sprintf("WHERE time_column BETWEEN '%s' AND '%s'", from.Format(time.RFC3339), to.Format(time.RFC3339)))
|
||||||
})
|
})
|
||||||
|
|
||||||
Convey("interpolate __timeFrom function", func() {
|
|
||||||
sql, err := engine.Interpolate(query, timeRange, "select $__timeFrom(time_column)")
|
|
||||||
So(err, ShouldBeNil)
|
|
||||||
|
|
||||||
So(sql, ShouldEqual, fmt.Sprintf("select '%s'", from.Format(time.RFC3339)))
|
|
||||||
})
|
|
||||||
|
|
||||||
Convey("interpolate __timeGroup function pre 5.3 compatibility", func() {
|
Convey("interpolate __timeGroup function pre 5.3 compatibility", func() {
|
||||||
|
|
||||||
sql, err := engine.Interpolate(query, timeRange, "SELECT $__timeGroup(time_column,'5m'), value")
|
sql, err := engine.Interpolate(query, timeRange, "SELECT $__timeGroup(time_column,'5m'), value")
|
||||||
@ -102,13 +95,6 @@ func TestMacroEngine(t *testing.T) {
|
|||||||
So(sql, ShouldEqual, "GROUP BY time_bucket('300s',time_column)")
|
So(sql, ShouldEqual, "GROUP BY time_bucket('300s',time_column)")
|
||||||
})
|
})
|
||||||
|
|
||||||
Convey("interpolate __timeTo function", func() {
|
|
||||||
sql, err := engine.Interpolate(query, timeRange, "select $__timeTo(time_column)")
|
|
||||||
So(err, ShouldBeNil)
|
|
||||||
|
|
||||||
So(sql, ShouldEqual, fmt.Sprintf("select '%s'", to.Format(time.RFC3339)))
|
|
||||||
})
|
|
||||||
|
|
||||||
Convey("interpolate __unixEpochFilter function", func() {
|
Convey("interpolate __unixEpochFilter function", func() {
|
||||||
sql, err := engine.Interpolate(query, timeRange, "select $__unixEpochFilter(time)")
|
sql, err := engine.Interpolate(query, timeRange, "select $__unixEpochFilter(time)")
|
||||||
So(err, ShouldBeNil)
|
So(err, ShouldBeNil)
|
||||||
@ -116,20 +102,6 @@ func TestMacroEngine(t *testing.T) {
|
|||||||
So(sql, ShouldEqual, fmt.Sprintf("select time >= %d AND time <= %d", from.Unix(), to.Unix()))
|
So(sql, ShouldEqual, fmt.Sprintf("select time >= %d AND time <= %d", from.Unix(), to.Unix()))
|
||||||
})
|
})
|
||||||
|
|
||||||
Convey("interpolate __unixEpochFrom function", func() {
|
|
||||||
sql, err := engine.Interpolate(query, timeRange, "select $__unixEpochFrom()")
|
|
||||||
So(err, ShouldBeNil)
|
|
||||||
|
|
||||||
So(sql, ShouldEqual, fmt.Sprintf("select %d", from.Unix()))
|
|
||||||
})
|
|
||||||
|
|
||||||
Convey("interpolate __unixEpochTo function", func() {
|
|
||||||
sql, err := engine.Interpolate(query, timeRange, "select $__unixEpochTo()")
|
|
||||||
So(err, ShouldBeNil)
|
|
||||||
|
|
||||||
So(sql, ShouldEqual, fmt.Sprintf("select %d", to.Unix()))
|
|
||||||
})
|
|
||||||
|
|
||||||
Convey("interpolate __unixEpochGroup function", func() {
|
Convey("interpolate __unixEpochGroup function", func() {
|
||||||
|
|
||||||
sql, err := engine.Interpolate(query, timeRange, "SELECT $__unixEpochGroup(time_column,'5m')")
|
sql, err := engine.Interpolate(query, timeRange, "SELECT $__unixEpochGroup(time_column,'5m')")
|
||||||
@ -155,40 +127,12 @@ func TestMacroEngine(t *testing.T) {
|
|||||||
So(sql, ShouldEqual, fmt.Sprintf("WHERE time_column BETWEEN '%s' AND '%s'", from.Format(time.RFC3339), to.Format(time.RFC3339)))
|
So(sql, ShouldEqual, fmt.Sprintf("WHERE time_column BETWEEN '%s' AND '%s'", from.Format(time.RFC3339), to.Format(time.RFC3339)))
|
||||||
})
|
})
|
||||||
|
|
||||||
Convey("interpolate __timeFrom function", func() {
|
|
||||||
sql, err := engine.Interpolate(query, timeRange, "select $__timeFrom(time_column)")
|
|
||||||
So(err, ShouldBeNil)
|
|
||||||
|
|
||||||
So(sql, ShouldEqual, fmt.Sprintf("select '%s'", from.Format(time.RFC3339)))
|
|
||||||
})
|
|
||||||
|
|
||||||
Convey("interpolate __timeTo function", func() {
|
|
||||||
sql, err := engine.Interpolate(query, timeRange, "select $__timeTo(time_column)")
|
|
||||||
So(err, ShouldBeNil)
|
|
||||||
|
|
||||||
So(sql, ShouldEqual, fmt.Sprintf("select '%s'", to.Format(time.RFC3339)))
|
|
||||||
})
|
|
||||||
|
|
||||||
Convey("interpolate __unixEpochFilter function", func() {
|
Convey("interpolate __unixEpochFilter function", func() {
|
||||||
sql, err := engine.Interpolate(query, timeRange, "select $__unixEpochFilter(time)")
|
sql, err := engine.Interpolate(query, timeRange, "select $__unixEpochFilter(time)")
|
||||||
So(err, ShouldBeNil)
|
So(err, ShouldBeNil)
|
||||||
|
|
||||||
So(sql, ShouldEqual, fmt.Sprintf("select time >= %d AND time <= %d", from.Unix(), to.Unix()))
|
So(sql, ShouldEqual, fmt.Sprintf("select time >= %d AND time <= %d", from.Unix(), to.Unix()))
|
||||||
})
|
})
|
||||||
|
|
||||||
Convey("interpolate __unixEpochFrom function", func() {
|
|
||||||
sql, err := engine.Interpolate(query, timeRange, "select $__unixEpochFrom()")
|
|
||||||
So(err, ShouldBeNil)
|
|
||||||
|
|
||||||
So(sql, ShouldEqual, fmt.Sprintf("select %d", from.Unix()))
|
|
||||||
})
|
|
||||||
|
|
||||||
Convey("interpolate __unixEpochTo function", func() {
|
|
||||||
sql, err := engine.Interpolate(query, timeRange, "select $__unixEpochTo()")
|
|
||||||
So(err, ShouldBeNil)
|
|
||||||
|
|
||||||
So(sql, ShouldEqual, fmt.Sprintf("select %d", to.Unix()))
|
|
||||||
})
|
|
||||||
})
|
})
|
||||||
|
|
||||||
Convey("Given a time range between 1960-02-01 07:00 and 1980-02-03 08:00", func() {
|
Convey("Given a time range between 1960-02-01 07:00 and 1980-02-03 08:00", func() {
|
||||||
@ -203,40 +147,12 @@ func TestMacroEngine(t *testing.T) {
|
|||||||
So(sql, ShouldEqual, fmt.Sprintf("WHERE time_column BETWEEN '%s' AND '%s'", from.Format(time.RFC3339), to.Format(time.RFC3339)))
|
So(sql, ShouldEqual, fmt.Sprintf("WHERE time_column BETWEEN '%s' AND '%s'", from.Format(time.RFC3339), to.Format(time.RFC3339)))
|
||||||
})
|
})
|
||||||
|
|
||||||
Convey("interpolate __timeFrom function", func() {
|
|
||||||
sql, err := engine.Interpolate(query, timeRange, "select $__timeFrom(time_column)")
|
|
||||||
So(err, ShouldBeNil)
|
|
||||||
|
|
||||||
So(sql, ShouldEqual, fmt.Sprintf("select '%s'", from.Format(time.RFC3339)))
|
|
||||||
})
|
|
||||||
|
|
||||||
Convey("interpolate __timeTo function", func() {
|
|
||||||
sql, err := engine.Interpolate(query, timeRange, "select $__timeTo(time_column)")
|
|
||||||
So(err, ShouldBeNil)
|
|
||||||
|
|
||||||
So(sql, ShouldEqual, fmt.Sprintf("select '%s'", to.Format(time.RFC3339)))
|
|
||||||
})
|
|
||||||
|
|
||||||
Convey("interpolate __unixEpochFilter function", func() {
|
Convey("interpolate __unixEpochFilter function", func() {
|
||||||
sql, err := engine.Interpolate(query, timeRange, "select $__unixEpochFilter(time)")
|
sql, err := engine.Interpolate(query, timeRange, "select $__unixEpochFilter(time)")
|
||||||
So(err, ShouldBeNil)
|
So(err, ShouldBeNil)
|
||||||
|
|
||||||
So(sql, ShouldEqual, fmt.Sprintf("select time >= %d AND time <= %d", from.Unix(), to.Unix()))
|
So(sql, ShouldEqual, fmt.Sprintf("select time >= %d AND time <= %d", from.Unix(), to.Unix()))
|
||||||
})
|
})
|
||||||
|
|
||||||
Convey("interpolate __unixEpochFrom function", func() {
|
|
||||||
sql, err := engine.Interpolate(query, timeRange, "select $__unixEpochFrom()")
|
|
||||||
So(err, ShouldBeNil)
|
|
||||||
|
|
||||||
So(sql, ShouldEqual, fmt.Sprintf("select %d", from.Unix()))
|
|
||||||
})
|
|
||||||
|
|
||||||
Convey("interpolate __unixEpochTo function", func() {
|
|
||||||
sql, err := engine.Interpolate(query, timeRange, "select $__unixEpochTo()")
|
|
||||||
So(err, ShouldBeNil)
|
|
||||||
|
|
||||||
So(sql, ShouldEqual, fmt.Sprintf("select %d", to.Unix()))
|
|
||||||
})
|
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
@ -684,6 +684,30 @@ func TestPostgres(t *testing.T) {
|
|||||||
So(queryResult.Series[0].Name, ShouldEqual, "valueOne")
|
So(queryResult.Series[0].Name, ShouldEqual, "valueOne")
|
||||||
So(queryResult.Series[1].Name, ShouldEqual, "valueTwo")
|
So(queryResult.Series[1].Name, ShouldEqual, "valueTwo")
|
||||||
})
|
})
|
||||||
|
|
||||||
|
Convey("When doing a query with timeFrom,timeTo,unixEpochFrom,unixEpochTo macros", func() {
|
||||||
|
tsdb.Interpolate = origInterpolate
|
||||||
|
query := &tsdb.TsdbQuery{
|
||||||
|
TimeRange: tsdb.NewFakeTimeRange("5m", "now", fromStart),
|
||||||
|
Queries: []*tsdb.Query{
|
||||||
|
{
|
||||||
|
DataSource: &models.DataSource{JsonData: simplejson.New()},
|
||||||
|
Model: simplejson.NewFromAny(map[string]interface{}{
|
||||||
|
"rawSql": `SELECT time FROM metric_values WHERE time > $__timeFrom() OR time < $__timeFrom() OR 1 < $__unixEpochFrom() OR $__unixEpochTo() > 1 ORDER BY 1`,
|
||||||
|
"format": "time_series",
|
||||||
|
}),
|
||||||
|
RefId: "A",
|
||||||
|
},
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
resp, err := endpoint.Query(nil, nil, query)
|
||||||
|
So(err, ShouldBeNil)
|
||||||
|
queryResult := resp.Results["A"]
|
||||||
|
So(queryResult.Error, ShouldBeNil)
|
||||||
|
So(queryResult.Meta.Get("sql").MustString(), ShouldEqual, "SELECT time FROM metric_values WHERE time > '2018-03-15T12:55:00Z' OR time < '2018-03-15T12:55:00Z' OR 1 < 1521118500 OR 1521118800 > 1 ORDER BY 1")
|
||||||
|
|
||||||
|
})
|
||||||
})
|
})
|
||||||
|
|
||||||
Convey("Given a table with event data", func() {
|
Convey("Given a table with event data", func() {
|
||||||
|
@ -184,6 +184,10 @@ var Interpolate = func(query *Query, timeRange *TimeRange, sql string) (string,
|
|||||||
|
|
||||||
sql = strings.Replace(sql, "$__interval_ms", strconv.FormatInt(interval.Milliseconds(), 10), -1)
|
sql = strings.Replace(sql, "$__interval_ms", strconv.FormatInt(interval.Milliseconds(), 10), -1)
|
||||||
sql = strings.Replace(sql, "$__interval", interval.Text, -1)
|
sql = strings.Replace(sql, "$__interval", interval.Text, -1)
|
||||||
|
sql = strings.Replace(sql, "$__timeFrom()", fmt.Sprintf("'%s'", timeRange.GetFromAsTimeUTC().Format(time.RFC3339)), -1)
|
||||||
|
sql = strings.Replace(sql, "$__timeTo()", fmt.Sprintf("'%s'", timeRange.GetToAsTimeUTC().Format(time.RFC3339)), -1)
|
||||||
|
sql = strings.Replace(sql, "$__unixEpochFrom()", fmt.Sprintf("%d", timeRange.GetFromAsSecondsEpoch()), -1)
|
||||||
|
sql = strings.Replace(sql, "$__unixEpochTo()", fmt.Sprintf("%d", timeRange.GetToAsSecondsEpoch()), -1)
|
||||||
|
|
||||||
return sql, nil
|
return sql, nil
|
||||||
}
|
}
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
package tsdb
|
package tsdb
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"fmt"
|
||||||
"testing"
|
"testing"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
@ -43,6 +44,34 @@ func TestSqlEngine(t *testing.T) {
|
|||||||
So(sql, ShouldEqual, "select 60000 ")
|
So(sql, ShouldEqual, "select 60000 ")
|
||||||
})
|
})
|
||||||
|
|
||||||
|
Convey("interpolate __timeFrom function", func() {
|
||||||
|
sql, err := Interpolate(query, timeRange, "select $__timeFrom()")
|
||||||
|
So(err, ShouldBeNil)
|
||||||
|
|
||||||
|
So(sql, ShouldEqual, fmt.Sprintf("select '%s'", from.Format(time.RFC3339)))
|
||||||
|
})
|
||||||
|
|
||||||
|
Convey("interpolate __timeTo function", func() {
|
||||||
|
sql, err := Interpolate(query, timeRange, "select $__timeTo()")
|
||||||
|
So(err, ShouldBeNil)
|
||||||
|
|
||||||
|
So(sql, ShouldEqual, fmt.Sprintf("select '%s'", to.Format(time.RFC3339)))
|
||||||
|
})
|
||||||
|
|
||||||
|
Convey("interpolate __unixEpochFrom function", func() {
|
||||||
|
sql, err := Interpolate(query, timeRange, "select $__unixEpochFrom()")
|
||||||
|
So(err, ShouldBeNil)
|
||||||
|
|
||||||
|
So(sql, ShouldEqual, fmt.Sprintf("select %d", from.Unix()))
|
||||||
|
})
|
||||||
|
|
||||||
|
Convey("interpolate __unixEpochTo function", func() {
|
||||||
|
sql, err := Interpolate(query, timeRange, "select $__unixEpochTo()")
|
||||||
|
So(err, ShouldBeNil)
|
||||||
|
|
||||||
|
So(sql, ShouldEqual, fmt.Sprintf("select %d", to.Unix()))
|
||||||
|
})
|
||||||
|
|
||||||
})
|
})
|
||||||
|
|
||||||
Convey("Given row values with time.Time as time columns", func() {
|
Convey("Given row values with time.Time as time columns", func() {
|
||||||
|
Reference in New Issue
Block a user