Encrypted messaging app
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

143 lines
2.9 KiB

  1. package Auth_test
  2. import (
  3. "bytes"
  4. "encoding/base64"
  5. "encoding/json"
  6. "io/ioutil"
  7. "log"
  8. "net/http"
  9. "net/http/cookiejar"
  10. "net/http/httptest"
  11. "net/url"
  12. "os"
  13. "testing"
  14. "time"
  15. "git.tovijaeschke.xyz/tovi/Capsule/Backend/Api"
  16. "git.tovijaeschke.xyz/tovi/Capsule/Backend/Api/Auth"
  17. "git.tovijaeschke.xyz/tovi/Capsule/Backend/Database"
  18. "git.tovijaeschke.xyz/tovi/Capsule/Backend/Database/Seeder"
  19. "git.tovijaeschke.xyz/tovi/Capsule/Backend/Models"
  20. "github.com/gorilla/mux"
  21. )
  22. func Test_AddProfileImage(t *testing.T) {
  23. log.SetOutput(ioutil.Discard)
  24. Database.InitTest()
  25. r := mux.NewRouter()
  26. Api.InitAPIEndpoints(r)
  27. ts := httptest.NewServer(r)
  28. defer ts.Close()
  29. userKey, _ := Seeder.GenerateAesKey()
  30. pubKey := Seeder.GetPubKey()
  31. p, _ := Auth.HashPassword("password")
  32. u := Models.User{
  33. Username: "test",
  34. Password: p,
  35. AsymmetricPublicKey: Seeder.PublicKey,
  36. AsymmetricPrivateKey: Seeder.EncryptedPrivateKey,
  37. SymmetricKey: base64.StdEncoding.EncodeToString(
  38. Seeder.EncryptWithPublicKey(userKey.Key, pubKey),
  39. ),
  40. }
  41. err := Database.CreateUser(&u)
  42. if err != nil {
  43. t.Errorf("Expected nil, recieved %s", err.Error())
  44. return
  45. }
  46. session := Models.Session{
  47. UserID: u.ID,
  48. Expiry: time.Now().Add(12 * time.Hour),
  49. }
  50. err = Database.CreateSession(&session)
  51. if err != nil {
  52. t.Errorf("Expected nil, recieved %s", err.Error())
  53. return
  54. }
  55. jar, err := cookiejar.New(nil)
  56. if err != nil {
  57. t.Errorf("Expected nil, recieved %s", err.Error())
  58. return
  59. }
  60. url, _ := url.Parse(ts.URL)
  61. jar.SetCookies(
  62. url,
  63. []*http.Cookie{
  64. {
  65. Name: "session_token",
  66. Value: session.ID.String(),
  67. MaxAge: 300,
  68. },
  69. },
  70. )
  71. key, err := Seeder.GenerateAesKey()
  72. if err != nil {
  73. t.Errorf("Expected nil, recieved %s", err.Error())
  74. return
  75. }
  76. dat, err := os.ReadFile("./profile_picture_test.png")
  77. if err != nil {
  78. t.Errorf("Expected nil, recieved %s", err.Error())
  79. return
  80. }
  81. encDat, err := key.AesEncrypt(dat)
  82. if err != nil {
  83. t.Errorf("Expected nil, recieved %s", err.Error())
  84. return
  85. }
  86. a := Models.Attachment{
  87. Mimetype: "image/png",
  88. Extension: "png",
  89. Data: base64.StdEncoding.EncodeToString(encDat),
  90. }
  91. jsonStr, _ := json.Marshal(a)
  92. req, _ := http.NewRequest("POST", ts.URL+"/api/v1/auth/image", bytes.NewBuffer(jsonStr))
  93. req.Header.Set("Content-Type", "application/json")
  94. client := &http.Client{
  95. Jar: jar,
  96. }
  97. resp, err := client.Do(req)
  98. if err != nil {
  99. t.Errorf("Expected nil, recieved %s", err.Error())
  100. return
  101. }
  102. if resp.StatusCode != http.StatusNoContent {
  103. t.Errorf("Expected %d, recieved %d", http.StatusNoContent, resp.StatusCode)
  104. return
  105. }
  106. u, err = Database.GetUserById(u.ID.String())
  107. if err != nil {
  108. t.Errorf("Expected nil, recieved %s", err.Error())
  109. return
  110. }
  111. if u.AttachmentID.IsNil() {
  112. t.Errorf("Attachment not assigned to user")
  113. }
  114. err = os.Remove("/app/attachments/" + u.Attachment.FilePath)
  115. if err != nil {
  116. t.Errorf("Expected nil, recieved %s", err.Error())
  117. return
  118. }
  119. }