|
|
- 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")
- }
- }
|