mirror of
https://github.com/grafana/grafana.git
synced 2024-12-01 04:59:15 -06:00
36 lines
1.0 KiB
Go
36 lines
1.0 KiB
Go
package sqlstore
|
|
|
|
import (
|
|
"testing"
|
|
|
|
m "github.com/grafana/grafana/pkg/models"
|
|
. "github.com/smartystreets/goconvey/convey"
|
|
)
|
|
|
|
func TestSearchBuilder(t *testing.T) {
|
|
Convey("Testing building a search", t, func() {
|
|
signedInUser := &m.SignedInUser{
|
|
OrgId: 1,
|
|
UserId: 1,
|
|
}
|
|
|
|
sb := NewSearchBuilder(signedInUser, 1000, m.PERMISSION_VIEW)
|
|
|
|
Convey("When building a normal search", func() {
|
|
sql, params := sb.IsStarred().WithTitle("test").ToSql()
|
|
So(sql, ShouldStartWith, "SELECT")
|
|
So(sql, ShouldContainSubstring, "INNER JOIN dashboard on ids.id = dashboard.id")
|
|
So(sql, ShouldContainSubstring, "ORDER BY dashboard.title ASC")
|
|
So(len(params), ShouldBeGreaterThan, 0)
|
|
})
|
|
|
|
Convey("When building a search with tag filter", func() {
|
|
sql, params := sb.WithTags([]string{"tag1", "tag2"}).ToSql()
|
|
So(sql, ShouldStartWith, "SELECT")
|
|
So(sql, ShouldContainSubstring, "LEFT OUTER JOIN dashboard_tag")
|
|
So(sql, ShouldContainSubstring, "ORDER BY dashboard.title ASC")
|
|
So(len(params), ShouldBeGreaterThan, 0)
|
|
})
|
|
})
|
|
}
|