gitea源码

attachment_test.go 4.7KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135
  1. // Copyright 2019 The Gitea Authors. All rights reserved.
  2. // SPDX-License-Identifier: MIT
  3. package integration
  4. import (
  5. "bytes"
  6. "image"
  7. "image/png"
  8. "io"
  9. "mime/multipart"
  10. "net/http"
  11. "strings"
  12. "testing"
  13. repo_model "code.gitea.io/gitea/models/repo"
  14. "code.gitea.io/gitea/modules/storage"
  15. "code.gitea.io/gitea/modules/test"
  16. "code.gitea.io/gitea/tests"
  17. "github.com/stretchr/testify/assert"
  18. )
  19. func generateImg() bytes.Buffer {
  20. // Generate image
  21. myImage := image.NewRGBA(image.Rect(0, 0, 32, 32))
  22. var buff bytes.Buffer
  23. png.Encode(&buff, myImage)
  24. return buff
  25. }
  26. func createAttachment(t *testing.T, session *TestSession, csrf, repoURL, filename string, buff bytes.Buffer, expectedStatus int) string {
  27. body := &bytes.Buffer{}
  28. // Setup multi-part
  29. writer := multipart.NewWriter(body)
  30. part, err := writer.CreateFormFile("file", filename)
  31. assert.NoError(t, err)
  32. _, err = io.Copy(part, &buff)
  33. assert.NoError(t, err)
  34. err = writer.Close()
  35. assert.NoError(t, err)
  36. req := NewRequestWithBody(t, "POST", repoURL+"/issues/attachments", body)
  37. req.Header.Add("X-Csrf-Token", csrf)
  38. req.Header.Add("Content-Type", writer.FormDataContentType())
  39. resp := session.MakeRequest(t, req, expectedStatus)
  40. if expectedStatus != http.StatusOK {
  41. return ""
  42. }
  43. var obj map[string]string
  44. DecodeJSON(t, resp, &obj)
  45. return obj["uuid"]
  46. }
  47. func TestCreateAnonymousAttachment(t *testing.T) {
  48. defer tests.PrepareTestEnv(t)()
  49. session := emptyTestSession(t)
  50. createAttachment(t, session, GetAnonymousCSRFToken(t, session), "user2/repo1", "image.png", generateImg(), http.StatusSeeOther)
  51. }
  52. func TestCreateIssueAttachment(t *testing.T) {
  53. defer tests.PrepareTestEnv(t)()
  54. const repoURL = "user2/repo1"
  55. session := loginUser(t, "user2")
  56. uuid := createAttachment(t, session, GetUserCSRFToken(t, session), repoURL, "image.png", generateImg(), http.StatusOK)
  57. req := NewRequest(t, "GET", repoURL+"/issues/new")
  58. resp := session.MakeRequest(t, req, http.StatusOK)
  59. htmlDoc := NewHTMLParser(t, resp.Body)
  60. link, exists := htmlDoc.doc.Find("form#new-issue").Attr("action")
  61. assert.True(t, exists, "The template has changed")
  62. postData := map[string]string{
  63. "_csrf": htmlDoc.GetCSRF(),
  64. "title": "New Issue With Attachment",
  65. "content": "some content",
  66. "files": uuid,
  67. }
  68. req = NewRequestWithValues(t, "POST", link, postData)
  69. resp = session.MakeRequest(t, req, http.StatusOK)
  70. test.RedirectURL(resp) // check that redirect URL exists
  71. // Validate that attachment is available
  72. req = NewRequest(t, "GET", "/attachments/"+uuid)
  73. session.MakeRequest(t, req, http.StatusOK)
  74. // anonymous visit should be allowed because user2/repo1 is a public repository
  75. MakeRequest(t, req, http.StatusOK)
  76. }
  77. func TestGetAttachment(t *testing.T) {
  78. defer tests.PrepareTestEnv(t)()
  79. adminSession := loginUser(t, "user1")
  80. user2Session := loginUser(t, "user2")
  81. user8Session := loginUser(t, "user8")
  82. emptySession := emptyTestSession(t)
  83. testCases := []struct {
  84. name string
  85. uuid string
  86. createFile bool
  87. session *TestSession
  88. want int
  89. }{
  90. {"LinkedIssueUUID", "a0eebc99-9c0b-4ef8-bb6d-6bb9bd380a11", true, user2Session, http.StatusOK},
  91. {"LinkedCommentUUID", "a0eebc99-9c0b-4ef8-bb6d-6bb9bd380a17", true, user2Session, http.StatusOK},
  92. {"linked_release_uuid", "a0eebc99-9c0b-4ef8-bb6d-6bb9bd380a19", true, user2Session, http.StatusOK},
  93. {"NotExistingUUID", "b0eebc99-9c0b-4ef8-bb6d-6bb9bd380a18", false, user2Session, http.StatusNotFound},
  94. {"FileMissing", "a0eebc99-9c0b-4ef8-bb6d-6bb9bd380a18", false, user2Session, http.StatusInternalServerError},
  95. {"NotLinked", "a0eebc99-9c0b-4ef8-bb6d-6bb9bd380a20", true, user2Session, http.StatusNotFound},
  96. {"NotLinkedAccessibleByUploader", "a0eebc99-9c0b-4ef8-bb6d-6bb9bd380a20", true, user8Session, http.StatusOK},
  97. {"PublicByNonLogged", "a0eebc99-9c0b-4ef8-bb6d-6bb9bd380a11", true, emptySession, http.StatusOK},
  98. {"PrivateByNonLogged", "a0eebc99-9c0b-4ef8-bb6d-6bb9bd380a12", true, emptySession, http.StatusNotFound},
  99. {"PrivateAccessibleByAdmin", "a0eebc99-9c0b-4ef8-bb6d-6bb9bd380a12", true, adminSession, http.StatusOK},
  100. {"PrivateAccessibleByUser", "a0eebc99-9c0b-4ef8-bb6d-6bb9bd380a12", true, user2Session, http.StatusOK},
  101. {"RepoNotAccessibleByUser", "a0eebc99-9c0b-4ef8-bb6d-6bb9bd380a12", true, user8Session, http.StatusNotFound},
  102. {"OrgNotAccessibleByUser", "a0eebc99-9c0b-4ef8-bb6d-6bb9bd380a21", true, user8Session, http.StatusNotFound},
  103. }
  104. for _, tc := range testCases {
  105. t.Run(tc.name, func(t *testing.T) {
  106. // Write empty file to be available for response
  107. if tc.createFile {
  108. _, err := storage.Attachments.Save(repo_model.AttachmentRelativePath(tc.uuid), strings.NewReader("hello world"), -1)
  109. assert.NoError(t, err)
  110. }
  111. // Actual test
  112. req := NewRequest(t, "GET", "/attachments/"+tc.uuid)
  113. tc.session.MakeRequest(t, req, tc.want)
  114. })
  115. }
  116. }