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.

download_test.go 2.9KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293
  1. // Copyright 2018 The Gitea Authors. All rights reserved.
  2. // Use of this source code is governed by a MIT-style
  3. // license that can be found in the LICENSE file.
  4. package integrations
  5. import (
  6. "net/http"
  7. "testing"
  8. "code.gitea.io/gitea/modules/setting"
  9. "github.com/stretchr/testify/assert"
  10. )
  11. func TestDownloadByID(t *testing.T) {
  12. defer prepareTestEnv(t)()
  13. session := loginUser(t, "user2")
  14. // Request raw blob
  15. req := NewRequest(t, "GET", "/user2/repo1/raw/blob/4b4851ad51df6a7d9f25c979345979eaeb5b349f")
  16. resp := session.MakeRequest(t, req, http.StatusOK)
  17. assert.Equal(t, "# repo1\n\nDescription for repo1", resp.Body.String())
  18. }
  19. func TestDownloadByIDForSVGUsesSecureHeaders(t *testing.T) {
  20. defer prepareTestEnv(t)()
  21. session := loginUser(t, "user2")
  22. // Request raw blob
  23. req := NewRequest(t, "GET", "/user2/repo2/raw/blob/6395b68e1feebb1e4c657b4f9f6ba2676a283c0b")
  24. resp := session.MakeRequest(t, req, http.StatusOK)
  25. assert.Equal(t, "default-src 'none'; style-src 'unsafe-inline'; sandbox", resp.HeaderMap.Get("Content-Security-Policy"))
  26. assert.Equal(t, "image/svg+xml", resp.HeaderMap.Get("Content-Type"))
  27. assert.Equal(t, "nosniff", resp.HeaderMap.Get("X-Content-Type-Options"))
  28. }
  29. func TestDownloadByIDMedia(t *testing.T) {
  30. defer prepareTestEnv(t)()
  31. session := loginUser(t, "user2")
  32. // Request raw blob
  33. req := NewRequest(t, "GET", "/user2/repo1/media/blob/4b4851ad51df6a7d9f25c979345979eaeb5b349f")
  34. resp := session.MakeRequest(t, req, http.StatusOK)
  35. assert.Equal(t, "# repo1\n\nDescription for repo1", resp.Body.String())
  36. }
  37. func TestDownloadByIDMediaForSVGUsesSecureHeaders(t *testing.T) {
  38. defer prepareTestEnv(t)()
  39. session := loginUser(t, "user2")
  40. // Request raw blob
  41. req := NewRequest(t, "GET", "/user2/repo2/media/blob/6395b68e1feebb1e4c657b4f9f6ba2676a283c0b")
  42. resp := session.MakeRequest(t, req, http.StatusOK)
  43. assert.Equal(t, "default-src 'none'; style-src 'unsafe-inline'; sandbox", resp.HeaderMap.Get("Content-Security-Policy"))
  44. assert.Equal(t, "image/svg+xml", resp.HeaderMap.Get("Content-Type"))
  45. assert.Equal(t, "nosniff", resp.HeaderMap.Get("X-Content-Type-Options"))
  46. }
  47. func TestDownloadRawTextFileWithoutMimeTypeMapping(t *testing.T) {
  48. defer prepareTestEnv(t)()
  49. session := loginUser(t, "user2")
  50. req := NewRequest(t, "GET", "/user2/repo2/raw/branch/master/test.xml")
  51. resp := session.MakeRequest(t, req, http.StatusOK)
  52. assert.Equal(t, "text/plain; charset=utf-8", resp.HeaderMap.Get("Content-Type"))
  53. }
  54. func TestDownloadRawTextFileWithMimeTypeMapping(t *testing.T) {
  55. defer prepareTestEnv(t)()
  56. setting.MimeTypeMap.Map[".xml"] = "text/xml"
  57. setting.MimeTypeMap.Enabled = true
  58. session := loginUser(t, "user2")
  59. req := NewRequest(t, "GET", "/user2/repo2/raw/branch/master/test.xml")
  60. resp := session.MakeRequest(t, req, http.StatusOK)
  61. assert.Equal(t, "text/xml; charset=utf-8", resp.HeaderMap.Get("Content-Type"))
  62. delete(setting.MimeTypeMap.Map, ".xml")
  63. setting.MimeTypeMap.Enabled = false
  64. }