|
1 | 1 | package openai //nolint:testpackage // testing private field
|
2 | 2 |
|
3 | 3 | import (
|
| 4 | + "errors" |
4 | 5 | "io"
|
5 | 6 |
|
6 | 7 | "github.com/sashabaranov/go-openai/internal/test/checks"
|
7 | 8 |
|
8 | 9 | "bytes"
|
9 |
| - "errors" |
10 | 10 | "os"
|
11 | 11 | "testing"
|
12 | 12 | )
|
13 | 13 |
|
| 14 | +type mockFormBuilder struct { |
| 15 | + mockCreateFormFile func(string, *os.File) error |
| 16 | + mockWriteField func(string, string) error |
| 17 | + mockClose func() error |
| 18 | +} |
| 19 | + |
| 20 | +func (m *mockFormBuilder) CreateFormFile(fieldname string, file *os.File) error { |
| 21 | + return m.mockCreateFormFile(fieldname, file) |
| 22 | +} |
| 23 | + |
| 24 | +func (m *mockFormBuilder) WriteField(fieldname, value string) error { |
| 25 | + return m.mockWriteField(fieldname, value) |
| 26 | +} |
| 27 | + |
| 28 | +func (m *mockFormBuilder) Close() error { |
| 29 | + return m.mockClose() |
| 30 | +} |
| 31 | + |
| 32 | +func (m *mockFormBuilder) FormDataContentType() string { |
| 33 | + return "" |
| 34 | +} |
| 35 | + |
| 36 | +func TestCloseMethod(t *testing.T) { |
| 37 | + t.Run("NormalClose", func(t *testing.T) { |
| 38 | + body := &bytes.Buffer{} |
| 39 | + builder := NewFormBuilder(body) |
| 40 | + checks.NoError(t, builder.Close(), "正常关闭应成功") |
| 41 | + }) |
| 42 | + |
| 43 | + t.Run("ErrorPropagation", func(t *testing.T) { |
| 44 | + errorMock := errors.New("mock close error") |
| 45 | + mockBuilder := &mockFormBuilder{ |
| 46 | + mockClose: func() error { |
| 47 | + return errorMock |
| 48 | + }, |
| 49 | + } |
| 50 | + err := mockBuilder.Close() |
| 51 | + checks.ErrorIs(t, err, errorMock, "应传递关闭错误") |
| 52 | + }) |
| 53 | +} |
| 54 | + |
14 | 55 | type failingWriter struct {
|
15 | 56 | }
|
16 | 57 |
|
@@ -90,3 +131,33 @@ func TestFormBuilderWithReader(t *testing.T) {
|
90 | 131 | err = builder.CreateFormFileReader("file", rnc, "")
|
91 | 132 | checks.NoError(t, err, "formbuilder should not return error")
|
92 | 133 | }
|
| 134 | + |
| 135 | +func TestFormDataContentType(t *testing.T) { |
| 136 | + t.Run("ReturnsUnderlyingWriterContentType", func(t *testing.T) { |
| 137 | + buf := &bytes.Buffer{} |
| 138 | + builder := NewFormBuilder(buf) |
| 139 | + |
| 140 | + contentType := builder.FormDataContentType() |
| 141 | + if contentType == "" { |
| 142 | + t.Errorf("expected non-empty content type, got empty string") |
| 143 | + } |
| 144 | + }) |
| 145 | +} |
| 146 | + |
| 147 | +func TestWriteField(t *testing.T) { |
| 148 | + t.Run("EmptyFieldNameShouldReturnError", func(t *testing.T) { |
| 149 | + buf := &bytes.Buffer{} |
| 150 | + builder := NewFormBuilder(buf) |
| 151 | + |
| 152 | + err := builder.WriteField("", "some value") |
| 153 | + checks.HasError(t, err, "fieldname is required") |
| 154 | + }) |
| 155 | + |
| 156 | + t.Run("ValidFieldNameShouldSucceed", func(t *testing.T) { |
| 157 | + buf := &bytes.Buffer{} |
| 158 | + builder := NewFormBuilder(buf) |
| 159 | + |
| 160 | + err := builder.WriteField("key", "value") |
| 161 | + checks.NoError(t, err, "should write field without error") |
| 162 | + }) |
| 163 | +} |
0 commit comments