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.

transferadapter_test.go 4.4KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171
  1. // Copyright 2021 The Gitea Authors. All rights reserved.
  2. // SPDX-License-Identifier: MIT
  3. package lfs
  4. import (
  5. "bytes"
  6. "context"
  7. "io"
  8. "net/http"
  9. "strings"
  10. "testing"
  11. "code.gitea.io/gitea/modules/json"
  12. "github.com/stretchr/testify/assert"
  13. )
  14. func TestBasicTransferAdapterName(t *testing.T) {
  15. a := &BasicTransferAdapter{}
  16. assert.Equal(t, "basic", a.Name())
  17. }
  18. func TestBasicTransferAdapter(t *testing.T) {
  19. p := Pointer{Oid: "b5a2c96250612366ea272ffac6d9744aaf4b45aacd96aa7cfcb931ee3b558259", Size: 5}
  20. roundTripHandler := func(req *http.Request) *http.Response {
  21. assert.Equal(t, MediaType, req.Header.Get("Accept"))
  22. assert.Equal(t, "test-value", req.Header.Get("test-header"))
  23. url := req.URL.String()
  24. if strings.Contains(url, "download-request") {
  25. assert.Equal(t, "GET", req.Method)
  26. return &http.Response{StatusCode: http.StatusOK, Body: io.NopCloser(bytes.NewBufferString("dummy"))}
  27. } else if strings.Contains(url, "upload-request") {
  28. assert.Equal(t, "PUT", req.Method)
  29. assert.Equal(t, "application/octet-stream", req.Header.Get("Content-Type"))
  30. b, err := io.ReadAll(req.Body)
  31. assert.NoError(t, err)
  32. assert.Equal(t, "dummy", string(b))
  33. return &http.Response{StatusCode: http.StatusOK}
  34. } else if strings.Contains(url, "verify-request") {
  35. assert.Equal(t, "POST", req.Method)
  36. assert.Equal(t, MediaType, req.Header.Get("Content-Type"))
  37. var vp Pointer
  38. err := json.NewDecoder(req.Body).Decode(&vp)
  39. assert.NoError(t, err)
  40. assert.Equal(t, p.Oid, vp.Oid)
  41. assert.Equal(t, p.Size, vp.Size)
  42. return &http.Response{StatusCode: http.StatusOK}
  43. } else if strings.Contains(url, "error-response") {
  44. er := &ErrorResponse{
  45. Message: "Object not found",
  46. }
  47. payload := new(bytes.Buffer)
  48. json.NewEncoder(payload).Encode(er)
  49. return &http.Response{StatusCode: http.StatusNotFound, Body: io.NopCloser(payload)}
  50. }
  51. t.Errorf("Unknown test case: %s", url)
  52. return nil
  53. }
  54. hc := &http.Client{Transport: RoundTripFunc(roundTripHandler)}
  55. a := &BasicTransferAdapter{hc}
  56. t.Run("Download", func(t *testing.T) {
  57. cases := []struct {
  58. link *Link
  59. expectederror string
  60. }{
  61. // case 0
  62. {
  63. link: &Link{
  64. Href: "https://download-request.io",
  65. Header: map[string]string{"test-header": "test-value"},
  66. },
  67. expectederror: "",
  68. },
  69. // case 1
  70. {
  71. link: &Link{
  72. Href: "https://error-response.io",
  73. Header: map[string]string{"test-header": "test-value"},
  74. },
  75. expectederror: "Object not found",
  76. },
  77. }
  78. for n, c := range cases {
  79. _, err := a.Download(context.Background(), c.link)
  80. if len(c.expectederror) > 0 {
  81. assert.True(t, strings.Contains(err.Error(), c.expectederror), "case %d: '%s' should contain '%s'", n, err.Error(), c.expectederror)
  82. } else {
  83. assert.NoError(t, err, "case %d", n)
  84. }
  85. }
  86. })
  87. t.Run("Upload", func(t *testing.T) {
  88. cases := []struct {
  89. link *Link
  90. expectederror string
  91. }{
  92. // case 0
  93. {
  94. link: &Link{
  95. Href: "https://upload-request.io",
  96. Header: map[string]string{"test-header": "test-value"},
  97. },
  98. expectederror: "",
  99. },
  100. // case 1
  101. {
  102. link: &Link{
  103. Href: "https://error-response.io",
  104. Header: map[string]string{"test-header": "test-value"},
  105. },
  106. expectederror: "Object not found",
  107. },
  108. }
  109. for n, c := range cases {
  110. err := a.Upload(context.Background(), c.link, p, bytes.NewBufferString("dummy"))
  111. if len(c.expectederror) > 0 {
  112. assert.True(t, strings.Contains(err.Error(), c.expectederror), "case %d: '%s' should contain '%s'", n, err.Error(), c.expectederror)
  113. } else {
  114. assert.NoError(t, err, "case %d", n)
  115. }
  116. }
  117. })
  118. t.Run("Verify", func(t *testing.T) {
  119. cases := []struct {
  120. link *Link
  121. expectederror string
  122. }{
  123. // case 0
  124. {
  125. link: &Link{
  126. Href: "https://verify-request.io",
  127. Header: map[string]string{"test-header": "test-value"},
  128. },
  129. expectederror: "",
  130. },
  131. // case 1
  132. {
  133. link: &Link{
  134. Href: "https://error-response.io",
  135. Header: map[string]string{"test-header": "test-value"},
  136. },
  137. expectederror: "Object not found",
  138. },
  139. }
  140. for n, c := range cases {
  141. err := a.Verify(context.Background(), c.link, p)
  142. if len(c.expectederror) > 0 {
  143. assert.True(t, strings.Contains(err.Error(), c.expectederror), "case %d: '%s' should contain '%s'", n, err.Error(), c.expectederror)
  144. } else {
  145. assert.NoError(t, err, "case %d", n)
  146. }
  147. }
  148. })
  149. }