diff options
| author | 2022-08-06 12:09:21 +0200 | |
|---|---|---|
| committer | 2022-08-06 12:09:21 +0200 | |
| commit | f5689a9e5fa5dbcae6c56fa9f393c2fc4686ac19 (patch) | |
| tree | ad66c13bc927e72dd072f1cabace27f9c5bd31b9 /internal/api/client/account | |
| parent | [bugfix] Parse source first before checking if empty form (#738) (diff) | |
| download | gotosocial-f5689a9e5fa5dbcae6c56fa9f393c2fc4686ac19.tar.xz | |
[feature] Let accounts set default status format, and use this when processing new statuses (#739)
* add post_format to acct & use it when making post
* update swagger docs
* add status_format updating to frontend
* fix up tests
* post_format => status_format
* add status_format to account validation
Diffstat (limited to 'internal/api/client/account')
| -rw-r--r-- | internal/api/client/account/accountupdate.go | 9 | ||||
| -rw-r--r-- | internal/api/client/account/accountupdate_test.go | 75 | 
2 files changed, 84 insertions, 0 deletions
| diff --git a/internal/api/client/account/accountupdate.go b/internal/api/client/account/accountupdate.go index 786aefb38..3ba214ed1 100644 --- a/internal/api/client/account/accountupdate.go +++ b/internal/api/client/account/accountupdate.go @@ -88,6 +88,10 @@ import (  //   in: formData  //   description: Default language to use for authored statuses (ISO 6391).  //   type: string +// - name: source[status_format] +//   in: formData +//   description: Default format to use for authored statuses (plain or markdown). +//   type: string  //  // security:  // - OAuth2 Bearer: @@ -163,6 +167,10 @@ func parseUpdateAccountForm(c *gin.Context) (*model.UpdateCredentialsRequest, er  		form.Source.Language = &language  	} +	if statusFormat, ok := sourceMap["status_format"]; ok { +		form.Source.StatusFormat = &statusFormat +	} +  	if form == nil ||  		(form.Discoverable == nil &&  			form.Bot == nil && @@ -174,6 +182,7 @@ func parseUpdateAccountForm(c *gin.Context) (*model.UpdateCredentialsRequest, er  			form.Source.Privacy == nil &&  			form.Source.Sensitive == nil &&  			form.Source.Language == nil && +			form.Source.StatusFormat == nil &&  			form.FieldsAttributes == nil) {  		return nil, errors.New("empty form submitted")  	} diff --git a/internal/api/client/account/accountupdate_test.go b/internal/api/client/account/accountupdate_test.go index 91f886721..d59cd02a5 100644 --- a/internal/api/client/account/accountupdate_test.go +++ b/internal/api/client/account/accountupdate_test.go @@ -362,6 +362,81 @@ func (suite *AccountUpdateTestSuite) TestAccountUpdateCredentialsPATCHHandlerUpd  	suite.True(apimodelAccount.Locked)  } +func (suite *AccountUpdateTestSuite) TestAccountUpdateCredentialsPATCHHandlerUpdateStatusFormatOK() { +	// set up the request +	// we're updating the language of zork +	requestBody, w, err := testrig.CreateMultipartFormData( +		"", "", +		map[string]string{ +			"source[status_format]": "markdown", +		}) +	if err != nil { +		panic(err) +	} +	bodyBytes := requestBody.Bytes() +	recorder := httptest.NewRecorder() +	ctx := suite.newContext(recorder, http.MethodPatch, bodyBytes, account.UpdateCredentialsPath, w.FormDataContentType()) + +	// call the handler +	suite.accountModule.AccountUpdateCredentialsPATCHHandler(ctx) + +	// 1. we should have OK because our request was valid +	suite.Equal(http.StatusOK, recorder.Code) + +	// 2. we should have no error message in the result body +	result := recorder.Result() +	defer result.Body.Close() + +	// check the response +	b, err := ioutil.ReadAll(result.Body) +	suite.NoError(err) + +	// unmarshal the returned account +	apimodelAccount := &apimodel.Account{} +	err = json.Unmarshal(b, apimodelAccount) +	suite.NoError(err) + +	// check the returned api model account +	// fields should be updated +	suite.Equal("markdown", apimodelAccount.Source.StatusFormat) + +	dbAccount, err := suite.db.GetAccountByID(context.Background(), suite.testAccounts["local_account_1"].ID) +	if err != nil { +		suite.FailNow(err.Error()) +	} +	suite.Equal(dbAccount.StatusFormat, "markdown") +} + +func (suite *AccountUpdateTestSuite) TestAccountUpdateCredentialsPATCHHandlerUpdateStatusFormatBad() { +	// set up the request +	// we're updating the language of zork +	requestBody, w, err := testrig.CreateMultipartFormData( +		"", "", +		map[string]string{ +			"source[status_format]": "peepeepoopoo", +		}) +	if err != nil { +		panic(err) +	} +	bodyBytes := requestBody.Bytes() +	recorder := httptest.NewRecorder() +	ctx := suite.newContext(recorder, http.MethodPatch, bodyBytes, account.UpdateCredentialsPath, w.FormDataContentType()) + +	// call the handler +	suite.accountModule.AccountUpdateCredentialsPATCHHandler(ctx) + +	suite.Equal(http.StatusBadRequest, recorder.Code) + +	result := recorder.Result() +	defer result.Body.Close() + +	// check the response +	b, err := ioutil.ReadAll(result.Body) +	suite.NoError(err) + +	suite.Equal(`{"error":"Bad Request: status format 'peepeepoopoo' was not recognized, valid options are 'plain', 'markdown'"}`, string(b)) +} +  func TestAccountUpdateTestSuite(t *testing.T) {  	suite.Run(t, new(AccountUpdateTestSuite))  } | 
