package Auth_test import ( "bytes" "encoding/base64" "encoding/json" "io/ioutil" "log" "net/http" "net/http/cookiejar" "net/http/httptest" "net/url" "testing" "time" "git.tovijaeschke.xyz/tovi/Capsule/Backend/Api" "git.tovijaeschke.xyz/tovi/Capsule/Backend/Api/Auth" "git.tovijaeschke.xyz/tovi/Capsule/Backend/Database" "git.tovijaeschke.xyz/tovi/Capsule/Backend/Database/Seeder" "git.tovijaeschke.xyz/tovi/Capsule/Backend/Models" "github.com/gorilla/mux" ) func Test_ChangeMessageExpiry(t *testing.T) { log.SetOutput(ioutil.Discard) Database.InitTest() r := mux.NewRouter() Api.InitAPIEndpoints(r) ts := httptest.NewServer(r) defer ts.Close() userKey, _ := Seeder.GenerateAesKey() pubKey := Seeder.GetPubKey() p, _ := Auth.HashPassword("password") u := Models.User{ Username: "test", Password: p, AsymmetricPublicKey: Seeder.PublicKey, AsymmetricPrivateKey: Seeder.EncryptedPrivateKey, SymmetricKey: base64.StdEncoding.EncodeToString( Seeder.EncryptWithPublicKey(userKey.Key, pubKey), ), } err := Database.CreateUser(&u) if err != nil { t.Errorf("Expected nil, recieved %s", err.Error()) return } session := Models.Session{ UserID: u.ID, Expiry: time.Now().Add(12 * time.Hour), } err = Database.CreateSession(&session) if err != nil { t.Errorf("Expected nil, recieved %s", err.Error()) return } jar, err := cookiejar.New(nil) if err != nil { t.Errorf("Expected nil, recieved %s", err.Error()) return } url, _ := url.Parse(ts.URL) jar.SetCookies( url, []*http.Cookie{ { Name: "session_token", Value: session.ID.String(), MaxAge: 300, }, }, ) d := struct { MessageExpiry string `json:"message_expiry"` }{ MessageExpiry: "fifteen_min", } jsonStr, _ := json.Marshal(d) req, _ := http.NewRequest("POST", ts.URL+"/api/v1/auth/message_expiry", bytes.NewBuffer(jsonStr)) req.Header.Set("Content-Type", "application/json") client := &http.Client{ Jar: jar, } resp, err := client.Do(req) if err != nil { t.Errorf("Expected nil, recieved %s", err.Error()) return } if resp.StatusCode != http.StatusNoContent { t.Errorf("Expected %d, recieved %d", http.StatusNoContent, resp.StatusCode) } u, err = Database.GetUserById(u.ID.String()) if err != nil { t.Errorf("Expected nil, recieved %s", err.Error()) return } if u.MessageExpiryDefault.String() != "fifteen_min" { t.Errorf("Failed to verify the MessageExpiryDefault has been changed") } } func Test_ChangeMessageExpiryInvalidData(t *testing.T) { log.SetOutput(ioutil.Discard) Database.InitTest() r := mux.NewRouter() Api.InitAPIEndpoints(r) ts := httptest.NewServer(r) defer ts.Close() userKey, _ := Seeder.GenerateAesKey() pubKey := Seeder.GetPubKey() p, _ := Auth.HashPassword("password") u := Models.User{ Username: "test", Password: p, AsymmetricPublicKey: Seeder.PublicKey, AsymmetricPrivateKey: Seeder.EncryptedPrivateKey, SymmetricKey: base64.StdEncoding.EncodeToString( Seeder.EncryptWithPublicKey(userKey.Key, pubKey), ), } err := Database.CreateUser(&u) if err != nil { t.Errorf("Expected nil, recieved %s", err.Error()) return } session := Models.Session{ UserID: u.ID, Expiry: time.Now().Add(12 * time.Hour), } err = Database.CreateSession(&session) if err != nil { t.Errorf("Expected nil, recieved %s", err.Error()) return } jar, err := cookiejar.New(nil) if err != nil { t.Errorf("Expected nil, recieved %s", err.Error()) return } url, _ := url.Parse(ts.URL) jar.SetCookies( url, []*http.Cookie{ { Name: "session_token", Value: session.ID.String(), MaxAge: 300, }, }, ) d := struct { MessageExpiry string `json:"message_expiry"` }{ MessageExpiry: "invalid_message_expiry", } jsonStr, _ := json.Marshal(d) req, _ := http.NewRequest("POST", ts.URL+"/api/v1/auth/message_expiry", bytes.NewBuffer(jsonStr)) req.Header.Set("Content-Type", "application/json") client := &http.Client{ Jar: jar, } resp, err := client.Do(req) if err != nil { t.Errorf("Expected nil, recieved %s", err.Error()) return } if resp.StatusCode != http.StatusUnprocessableEntity { t.Errorf("Expected %d, recieved %d", http.StatusUnprocessableEntity, resp.StatusCode) } u, err = Database.GetUserById(u.ID.String()) if err != nil { t.Errorf("Expected nil, recieved %s", err.Error()) return } if u.MessageExpiryDefault.String() != "no_expiry" { t.Errorf("Failed to verify the MessageExpiryDefault has not been changed") } }