123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197 |
- package auth
- import (
- "bytes"
- "encoding/json"
- "flag"
- "fmt"
- "io/ioutil"
- "net/http"
- "os"
- "strings"
- "sync"
- "testing"
- "devt.de/krotik/common/errorutil"
- "devt.de/krotik/common/httputil"
- "devt.de/krotik/common/httputil/user"
- )
- const TESTPORT = ":9090"
- const TESTQUERYURL = "http://localhost" + TESTPORT + "/foo"
- var handleCallback = func(w http.ResponseWriter, r *http.Request) {}
- var originalHandleFunction = func(w http.ResponseWriter, r *http.Request) {
- session, _ := user.UserSessionManager.GetSession("", w, r, false)
- handleCallback(w, r)
- if session == nil {
- w.Write([]byte("Content"))
- } else {
- w.Write([]byte(fmt.Sprint("Content - User session: ", session.User())))
- }
- }
- var wrappedHandleFunction = originalHandleFunction
- func TestMain(m *testing.M) {
- flag.Parse()
-
- ioutil.WriteFile("test.jpg", []byte("testpic"), 0777)
-
- hs, wg := startServer()
- if hs == nil {
- return
- }
-
- defer stopServer(hs, wg)
-
- http.HandleFunc("/", func(w http.ResponseWriter, r *http.Request) {
-
- wrappedHandleFunction(w, r)
- })
-
- res := m.Run()
-
- os.Remove("test.jpg")
- os.Exit(res)
- }
- func TestNoAuthNoSession(t *testing.T) {
-
- res, _ := sendTestRequest(TESTQUERYURL, "GET", nil, nil, nil)
- if res != "Content" {
- t.Error("Unexpected result:", res)
- return
- }
-
- r, _ := http.NewRequest("GET", "", nil)
- _, err := user.UserSessionManager.GetSession("", nil, r, true)
- if err.Error() != "Cannot create a session without a user" {
- t.Error("Unexpected error:", err)
- return
- }
- }
- func sendTestRequest(url string, method string, headers map[string]string,
- cookies []*http.Cookie, content []byte) (string, *http.Response) {
- var req *http.Request
- var err error
-
- if content != nil {
- req, err = http.NewRequest(method, url, bytes.NewBuffer(content))
- } else {
- req, err = http.NewRequest(method, url, nil)
- }
- errorutil.AssertOk(err)
-
- req.Header.Set("Content-Type", "application/json")
- for k, v := range headers {
- req.Header.Set(k, v)
- }
-
- for _, v := range cookies {
- req.AddCookie(v)
- }
- client := &http.Client{}
- resp, err := client.Do(req)
- if err != nil {
- panic(err)
- }
- defer resp.Body.Close()
- body, _ := ioutil.ReadAll(resp.Body)
- bodyStr := strings.Trim(string(body), " \n")
-
- out := bytes.Buffer{}
- err = json.Indent(&out, []byte(bodyStr), "", " ")
- if err == nil {
- return out.String(), resp
- }
-
- return bodyStr, resp
- }
- func startServer() (*httputil.HTTPServer, *sync.WaitGroup) {
- hs := &httputil.HTTPServer{}
- var wg sync.WaitGroup
- wg.Add(1)
- go hs.RunHTTPServer(TESTPORT, &wg)
- wg.Wait()
-
- if hs.LastError != nil {
- panic(hs.LastError)
- }
- return hs, &wg
- }
- func stopServer(hs *httputil.HTTPServer, wg *sync.WaitGroup) {
- if hs.Running == true {
- wg.Add(1)
-
- hs.Shutdown()
- wg.Wait()
- } else {
- panic("Server was not running as expected")
- }
- }
|