2021-07-16 05:47:26 -05:00
|
|
|
package azuremonitor
|
|
|
|
|
|
|
|
import (
|
2022-08-10 08:37:51 -05:00
|
|
|
"io"
|
2021-07-16 05:47:26 -05:00
|
|
|
"net/http"
|
|
|
|
"net/http/httptest"
|
|
|
|
"testing"
|
|
|
|
|
2022-04-04 04:23:13 -05:00
|
|
|
"github.com/grafana/grafana-azure-sdk-go/azsettings"
|
|
|
|
|
2022-03-02 08:41:07 -06:00
|
|
|
"github.com/grafana/grafana/pkg/tsdb/azuremonitor/metrics"
|
|
|
|
"github.com/grafana/grafana/pkg/tsdb/azuremonitor/types"
|
2022-04-04 04:23:13 -05:00
|
|
|
|
2021-07-16 05:47:26 -05:00
|
|
|
"github.com/stretchr/testify/require"
|
|
|
|
)
|
|
|
|
|
|
|
|
func Test_parseResourcePath(t *testing.T) {
|
|
|
|
tests := []struct {
|
|
|
|
name string
|
|
|
|
original string
|
|
|
|
expectedTarget string
|
|
|
|
Err require.ErrorAssertionFunc
|
|
|
|
}{
|
|
|
|
{
|
|
|
|
"Path with a subscription",
|
|
|
|
"/azuremonitor/subscriptions/44693801",
|
|
|
|
"/subscriptions/44693801",
|
|
|
|
require.NoError,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
"Malformed path",
|
|
|
|
"/subscriptions?44693801",
|
|
|
|
"",
|
|
|
|
require.Error,
|
|
|
|
},
|
|
|
|
}
|
|
|
|
for _, tt := range tests {
|
|
|
|
t.Run(tt.name, func(t *testing.T) {
|
|
|
|
target, err := getTarget(tt.original)
|
|
|
|
if target != tt.expectedTarget {
|
|
|
|
t.Errorf("Unexpected target %s expecting %s", target, tt.expectedTarget)
|
|
|
|
}
|
|
|
|
tt.Err(t, err)
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func Test_proxyRequest(t *testing.T) {
|
|
|
|
tests := []struct {
|
|
|
|
name string
|
|
|
|
}{
|
|
|
|
{"forwards headers and body"},
|
|
|
|
}
|
|
|
|
for _, tt := range tests {
|
|
|
|
t.Run(tt.name, func(t *testing.T) {
|
|
|
|
srv := httptest.NewServer(http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
|
|
|
|
w.Header().Add("foo", "bar")
|
|
|
|
_, err := w.Write([]byte("result"))
|
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
}))
|
|
|
|
req, err := http.NewRequest(http.MethodGet, srv.URL, nil)
|
|
|
|
if err != nil {
|
|
|
|
t.Error(err)
|
|
|
|
}
|
|
|
|
rw := httptest.NewRecorder()
|
|
|
|
proxy := httpServiceProxy{}
|
|
|
|
res := proxy.Do(rw, req, srv.Client())
|
|
|
|
if res.Header().Get("foo") != "bar" {
|
|
|
|
t.Errorf("Unexpected headers: %v", res.Header())
|
|
|
|
}
|
|
|
|
result := rw.Result()
|
2022-08-10 08:37:51 -05:00
|
|
|
body, err := io.ReadAll(result.Body)
|
2021-07-16 05:47:26 -05:00
|
|
|
if err != nil {
|
|
|
|
t.Error(err)
|
|
|
|
}
|
|
|
|
err = result.Body.Close()
|
|
|
|
if err != nil {
|
|
|
|
t.Error(err)
|
|
|
|
}
|
|
|
|
if string(body) != "result" {
|
|
|
|
t.Errorf("Unexpected body: %v", string(body))
|
|
|
|
}
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
type fakeProxy struct {
|
|
|
|
requestedURL string
|
|
|
|
}
|
|
|
|
|
|
|
|
func (s *fakeProxy) Do(rw http.ResponseWriter, req *http.Request, cli *http.Client) http.ResponseWriter {
|
|
|
|
s.requestedURL = req.URL.String()
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
2022-01-20 11:16:22 -06:00
|
|
|
func Test_handleResourceReq(t *testing.T) {
|
2021-07-16 05:47:26 -05:00
|
|
|
proxy := &fakeProxy{}
|
|
|
|
s := Service{
|
|
|
|
im: &fakeInstance{
|
2022-03-02 08:41:07 -06:00
|
|
|
services: map[string]types.DatasourceService{
|
2021-07-16 05:47:26 -05:00
|
|
|
azureMonitor: {
|
2022-04-01 06:26:49 -05:00
|
|
|
URL: routes[azsettings.AzurePublic][azureMonitor].URL,
|
2021-07-16 05:47:26 -05:00
|
|
|
HTTPClient: &http.Client{},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
executors: map[string]azDatasourceExecutor{
|
2022-03-02 08:41:07 -06:00
|
|
|
azureMonitor: &metrics.AzureMonitorDatasource{
|
|
|
|
Proxy: proxy,
|
2021-07-16 05:47:26 -05:00
|
|
|
},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
rw := httptest.NewRecorder()
|
|
|
|
req, err := http.NewRequest(http.MethodGet, "http://foo/azuremonitor/subscriptions/44693801", nil)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("Unexpected error %v", err)
|
|
|
|
}
|
2022-01-20 11:16:22 -06:00
|
|
|
s.handleResourceReq(azureMonitor)(rw, req)
|
2021-07-16 05:47:26 -05:00
|
|
|
expectedURL := "https://management.azure.com/subscriptions/44693801"
|
|
|
|
if proxy.requestedURL != expectedURL {
|
|
|
|
t.Errorf("Unexpected result URL. Got %s, expecting %s", proxy.requestedURL, expectedURL)
|
|
|
|
}
|
|
|
|
}
|