mirror of
				https://github.com/go-gitea/gitea.git
				synced 2025-10-31 19:06:18 +01:00 
			
		
		
		
	Use standard HTTP library to serve files (#24693)
`http.ServeFile/ServeContent` handles `If-xxx`, `Content-Length`, `Range` and `Etag` correctly After this PR, storage files (eg: avatar) could be responded with correct Content-Length.
This commit is contained in:
		| @@ -6,6 +6,7 @@ package httplib | ||||
| import ( | ||||
| 	"fmt" | ||||
| 	"net/http" | ||||
| 	"net/http/httptest" | ||||
| 	"net/url" | ||||
| 	"os" | ||||
| 	"strings" | ||||
| @@ -25,12 +26,12 @@ func TestServeContentByReader(t *testing.T) { | ||||
| 			r.Header.Set("Range", fmt.Sprintf("bytes=%s", rangeStr)) | ||||
| 		} | ||||
| 		reader := strings.NewReader(data) | ||||
| 		w := NewMockResponseWriter() | ||||
| 		w := httptest.NewRecorder() | ||||
| 		ServeContentByReader(r, w, "test", int64(len(data)), reader) | ||||
| 		assert.Equal(t, expectedStatusCode, w.StatusCode) | ||||
| 		assert.Equal(t, expectedStatusCode, w.Code) | ||||
| 		if expectedStatusCode == http.StatusPartialContent || expectedStatusCode == http.StatusOK { | ||||
| 			assert.Equal(t, fmt.Sprint(len(expectedContent)), w.Header().Get("Content-Length")) | ||||
| 			assert.Equal(t, expectedContent, w.BodyBuffer.String()) | ||||
| 			assert.Equal(t, expectedContent, w.Body.String()) | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| @@ -76,12 +77,12 @@ func TestServeContentByReadSeeker(t *testing.T) { | ||||
| 		} | ||||
| 		defer seekReader.Close() | ||||
|  | ||||
| 		w := NewMockResponseWriter() | ||||
| 		w := httptest.NewRecorder() | ||||
| 		ServeContentByReadSeeker(r, w, "test", time.Time{}, seekReader) | ||||
| 		assert.Equal(t, expectedStatusCode, w.StatusCode) | ||||
| 		assert.Equal(t, expectedStatusCode, w.Code) | ||||
| 		if expectedStatusCode == http.StatusPartialContent || expectedStatusCode == http.StatusOK { | ||||
| 			assert.Equal(t, fmt.Sprint(len(expectedContent)), w.Header().Get("Content-Length")) | ||||
| 			assert.Equal(t, expectedContent, w.BodyBuffer.String()) | ||||
| 			assert.Equal(t, expectedContent, w.Body.String()) | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user