2017-02-16 17:05:55 +00:00
|
|
|
package oauth2_test
|
|
|
|
|
|
|
|
import (
|
|
|
|
"encoding/json"
|
|
|
|
"net/http"
|
|
|
|
"net/http/httptest"
|
|
|
|
"testing"
|
|
|
|
|
2017-02-16 19:26:08 +00:00
|
|
|
clog "github.com/influxdata/chronograf/log"
|
2017-02-16 17:05:55 +00:00
|
|
|
"github.com/influxdata/chronograf/oauth2"
|
|
|
|
)
|
|
|
|
|
|
|
|
func Test_Heroku_PrincipalID_ExtractsEmailAddress(t *testing.T) {
|
|
|
|
t.Parallel()
|
|
|
|
|
|
|
|
expected := struct {
|
|
|
|
Email string `json:"email"`
|
|
|
|
}{
|
|
|
|
"martymcfly@example.com",
|
|
|
|
}
|
|
|
|
|
|
|
|
mockAPI := httptest.NewServer(http.HandlerFunc(func(rw http.ResponseWriter, r *http.Request) {
|
|
|
|
if r.URL.Path != "/account" {
|
|
|
|
rw.WriteHeader(http.StatusNotFound)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
enc := json.NewEncoder(rw)
|
|
|
|
|
|
|
|
rw.WriteHeader(http.StatusOK)
|
|
|
|
_ = enc.Encode(expected)
|
|
|
|
}))
|
|
|
|
defer mockAPI.Close()
|
|
|
|
|
2017-02-16 19:26:08 +00:00
|
|
|
logger := clog.New(clog.ParseLevel("debug"))
|
|
|
|
prov := oauth2.Heroku{
|
|
|
|
Logger: logger,
|
|
|
|
}
|
|
|
|
tt, err := NewTestTripper(logger, mockAPI, http.DefaultTransport)
|
2017-02-16 17:05:55 +00:00
|
|
|
if err != nil {
|
|
|
|
t.Fatal("Error initializing TestTripper: err:", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
tc := &http.Client{
|
|
|
|
Transport: tt,
|
|
|
|
}
|
|
|
|
|
|
|
|
email, err := prov.PrincipalID(tc)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatal("Unexpected error while retrieiving PrincipalID: err:", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
if email != expected.Email {
|
|
|
|
t.Fatal("Retrieved email was not as expected. Want:", expected.Email, "Got:", email)
|
|
|
|
}
|
|
|
|
}
|