Skip to content

Commit 9929189

Browse files
authored
feat: add tag and value in validation error details (#1760)
* add tag and value in validation error details * fix unit tests and linter * add quotes around value * fix unit tests
1 parent c5f06ac commit 9929189

File tree

2 files changed

+5
-5
lines changed

2 files changed

+5
-5
lines changed

coderd/httpapi/httpapi.go

+1-1
Original file line numberDiff line numberDiff line change
@@ -104,7 +104,7 @@ func Read(rw http.ResponseWriter, r *http.Request, value interface{}) bool {
104104
for _, validationError := range validationErrors {
105105
apiErrors = append(apiErrors, Error{
106106
Field: validationError.Field(),
107-
Detail: validationError.Tag(),
107+
Detail: fmt.Sprintf("Validation failed for tag %q with value: \"%v\"", validationError.Tag(), validationError.Value()),
108108
})
109109
}
110110
Write(rw, http.StatusBadRequest, Response{

coderd/httpapi/httpapi_test.go

+4-4
Original file line numberDiff line numberDiff line change
@@ -58,7 +58,7 @@ func TestRead(t *testing.T) {
5858

5959
var validate toValidate
6060
require.True(t, httpapi.Read(rw, r, &validate))
61-
require.Equal(t, validate.Value, "hi")
61+
require.Equal(t, "hi", validate.Value)
6262
})
6363

6464
t.Run("ValidateFailure", func(t *testing.T) {
@@ -75,8 +75,8 @@ func TestRead(t *testing.T) {
7575
err := json.NewDecoder(rw.Body).Decode(&v)
7676
require.NoError(t, err)
7777
require.Len(t, v.Errors, 1)
78-
require.Equal(t, v.Errors[0].Field, "value")
79-
require.Equal(t, v.Errors[0].Detail, "required")
78+
require.Equal(t, "value", v.Errors[0].Field)
79+
require.Equal(t, "Validation failed for tag \"required\" with value: \"\"", v.Errors[0].Detail)
8080
})
8181
}
8282

@@ -140,7 +140,7 @@ func TestReadUsername(t *testing.T) {
140140
r := httptest.NewRequest("POST", "/", bytes.NewBuffer(data))
141141

142142
var validate toValidate
143-
require.Equal(t, httpapi.Read(rw, r, &validate), testCase.Valid)
143+
require.Equal(t, testCase.Valid, httpapi.Read(rw, r, &validate))
144144
})
145145
}
146146
}

0 commit comments

Comments
 (0)