diff options
| author | 2024-12-05 13:35:07 +0000 | |
|---|---|---|
| committer | 2024-12-05 13:35:07 +0000 | |
| commit | 23fc70f4e68730b7eec91d58dac54ec00099ed8d (patch) | |
| tree | 9ab22b85d1d2c9c7ff2db9371ab2dc752c085f07 /internal/api/client/statuses | |
| parent | [feature] unending polls (#3592) (diff) | |
| download | gotosocial-23fc70f4e68730b7eec91d58dac54ec00099ed8d.tar.xz | |
[feature] add support for receiving federated status edits (#3597)
* add support for extracting Updated field from Statusable implementers
* add support for status edits in the database, and update status dereferencer to handle them
* remove unused AdditionalInfo{}.CreatedAt
* remove unused AdditionalEmojiInfo{}.CreatedAt
* update new mention creation to use status.UpdatedAt
* remove mention.UpdatedAt, fixes related to NewULIDFromTime() change
* add migration to remove Mention{}.UpdatedAt field
* add migration to add the StatusEdit{} table
* start adding tests, add delete function for status edits
* add more of status edit migrations, fill in more of the necessary edit delete functionality
* remove unused function
* allow generating gotosocial compatible ulid via CLI with `go run ./cmd/gen-ulid`
* add StatusEdit{} test models
* fix new statusedits sql
* use model instead of table name
* actually remove the Mention.UpdatedAt field...
* fix tests now new models are added, add more status edit DB tests
* fix panic wording
* add test for deleting status edits
* don't automatically set `updated_at` field on updated statuses
* flesh out more of the dereferencer status edit tests, ensure updated at field set on outgoing AS statuses
* remove media_attachments.updated_at column
* fix up more tests, further complete the dereferencer status edit tests
* update more status serialization tests not expecting 'updated' AS property
* gah!! json serialization tests!!
* undo some gtscontext wrapping changes
* more serialization test fixing :smiling_face_with_tear:
* more test fixing, ensure the edit.status_id field is actually set :facepalm:
* fix status edit test
* grrr linter
* add edited_at field to apimodel status
* remove the choice of paging on the timeline public filtered test (otherwise it needs updating every time you add statuses ...)
* ensure that status.updated_at always fits chronologically
* fix more serialization tests ...
* add more code comments
* fix envparsing
* update swagger file
* properly handle media description changes during status edits
* slight formatting tweak
* code comment
Diffstat (limited to 'internal/api/client/statuses')
| -rw-r--r-- | internal/api/client/statuses/statusboost_test.go | 6 | ||||
| -rw-r--r-- | internal/api/client/statuses/statuscreate_test.go | 12 | ||||
| -rw-r--r-- | internal/api/client/statuses/statusfave_test.go | 2 | ||||
| -rw-r--r-- | internal/api/client/statuses/statushistory_test.go | 4 | ||||
| -rw-r--r-- | internal/api/client/statuses/statusmute_test.go | 10 | 
5 files changed, 28 insertions, 6 deletions
diff --git a/internal/api/client/statuses/statusboost_test.go b/internal/api/client/statuses/statusboost_test.go index 1f92d8b3f..51b7d7652 100644 --- a/internal/api/client/statuses/statusboost_test.go +++ b/internal/api/client/statuses/statusboost_test.go @@ -100,6 +100,7 @@ func (suite *StatusBoostTestSuite) TestPostBoost() {    "card": null,    "content": "",    "created_at": "right the hell just now babyee", +  "edited_at": null,    "emojis": [],    "favourited": true,    "favourites_count": 0, @@ -145,6 +146,7 @@ func (suite *StatusBoostTestSuite) TestPostBoost() {      "card": null,      "content": "hello world! #welcome ! first post on the instance :rainbow: !",      "created_at": "right the hell just now babyee", +    "edited_at": null,      "emojis": [        {          "category": "reactions", @@ -280,6 +282,7 @@ func (suite *StatusBoostTestSuite) TestPostBoostOwnFollowersOnly() {    "card": null,    "content": "",    "created_at": "right the hell just now babyee", +  "edited_at": null,    "emojis": [],    "favourited": false,    "favourites_count": 0, @@ -329,6 +332,7 @@ func (suite *StatusBoostTestSuite) TestPostBoostOwnFollowersOnly() {      "card": null,      "content": "hi!",      "created_at": "right the hell just now babyee", +    "edited_at": null,      "emojis": [],      "favourited": false,      "favourites_count": 0, @@ -494,6 +498,7 @@ func (suite *StatusBoostTestSuite) TestPostBoostImplicitAccept() {    "card": null,    "content": "",    "created_at": "right the hell just now babyee", +  "edited_at": null,    "emojis": [],    "favourited": false,    "favourites_count": 0, @@ -539,6 +544,7 @@ func (suite *StatusBoostTestSuite) TestPostBoostImplicitAccept() {      "card": null,      "content": "<p>Hi <span class=\"h-card\"><a href=\"http://localhost:8080/@1happyturtle\" class=\"u-url mention\" rel=\"nofollow noreferrer noopener\" target=\"_blank\">@<span>1happyturtle</span></a></span>, can I reply?</p>",      "created_at": "right the hell just now babyee", +    "edited_at": null,      "emojis": [],      "favourited": false,      "favourites_count": 0, diff --git a/internal/api/client/statuses/statuscreate_test.go b/internal/api/client/statuses/statuscreate_test.go index 5f5386dd5..227e7d83e 100644 --- a/internal/api/client/statuses/statuscreate_test.go +++ b/internal/api/client/statuses/statuscreate_test.go @@ -102,6 +102,7 @@ func (suite *StatusCreateTestSuite) TestPostNewStatus() {    "card": null,    "content": "<p>this is a brand new status! <a href=\"http://localhost:8080/tags/helloworld\" class=\"mention hashtag\" rel=\"tag nofollow noreferrer noopener\" target=\"_blank\">#<span>helloworld</span></a></p>",    "created_at": "right the hell just now babyee", +  "edited_at": null,    "emojis": [],    "favourited": false,    "favourites_count": 0, @@ -187,6 +188,7 @@ func (suite *StatusCreateTestSuite) TestPostNewStatusIntPolicy() {    "card": null,    "content": "<p>this is a brand new status! <a href=\"http://localhost:8080/tags/helloworld\" class=\"mention hashtag\" rel=\"tag nofollow noreferrer noopener\" target=\"_blank\">#<span>helloworld</span></a></p>",    "created_at": "right the hell just now babyee", +  "edited_at": null,    "emojis": [],    "favourited": false,    "favourites_count": 0, @@ -282,6 +284,7 @@ func (suite *StatusCreateTestSuite) TestPostNewStatusIntPolicyJSON() {    "card": null,    "content": "<p>this is a brand new status! <a href=\"http://localhost:8080/tags/helloworld\" class=\"mention hashtag\" rel=\"tag nofollow noreferrer noopener\" target=\"_blank\">#<span>helloworld</span></a></p>",    "created_at": "right the hell just now babyee", +  "edited_at": null,    "emojis": [],    "favourited": false,    "favourites_count": 0, @@ -407,6 +410,7 @@ func (suite *StatusCreateTestSuite) TestPostNewStatusMarkdown() {    "card": null,    "content": "<h1>Title</h1><h2>Smaller title</h2><p>This is a post written in <a href=\"https://www.markdownguide.org/\" rel=\"nofollow noreferrer noopener\" target=\"_blank\">markdown</a></p>",    "created_at": "right the hell just now babyee", +  "edited_at": null,    "emojis": [],    "favourited": false,    "favourites_count": 0, @@ -490,6 +494,7 @@ func (suite *StatusCreateTestSuite) TestMentionUnknownAccount() {    "card": null,    "content": "<p>hello <span class=\"h-card\"><a href=\"https://unknown-instance.com/@brand_new_person\" class=\"u-url mention\" rel=\"nofollow noreferrer noopener\" target=\"_blank\">@<span>brand_new_person</span></a></span></p>",    "created_at": "right the hell just now babyee", +  "edited_at": null,    "emojis": [],    "favourited": false,    "favourites_count": 0, @@ -567,6 +572,7 @@ func (suite *StatusCreateTestSuite) TestPostStatusWithLinksAndTags() {    "card": null,    "content": "<p><a href=\"http://localhost:8080/tags/test\" class=\"mention hashtag\" rel=\"tag nofollow noreferrer noopener\" target=\"_blank\">#<span>test</span></a> alright, should be able to post <a href=\"http://localhost:8080/tags/links\" class=\"mention hashtag\" rel=\"tag nofollow noreferrer noopener\" target=\"_blank\">#<span>links</span></a> with fragments in them now, let's see........<br><br><a href=\"https://docs.gotosocial.org/en/latest/user_guide/posts/#links\" rel=\"nofollow noreferrer noopener\" target=\"_blank\">https://docs.gotosocial.org/en/latest/user_guide/posts/#links</a><br><br><a href=\"http://localhost:8080/tags/gotosocial\" class=\"mention hashtag\" rel=\"tag nofollow noreferrer noopener\" target=\"_blank\">#<span>gotosocial</span></a><br><br>(tobi remember to pull the docker image challenge)</p>",    "created_at": "right the hell just now babyee", +  "edited_at": null,    "emojis": [],    "favourited": false,    "favourites_count": 0, @@ -650,6 +656,7 @@ func (suite *StatusCreateTestSuite) TestPostNewStatusWithEmoji() {    "card": null,    "content": "<p>here is a rainbow emoji a few times! :rainbow: :rainbow: :rainbow:<br>here's an emoji that isn't in the db: :test_emoji:</p>",    "created_at": "right the hell just now babyee", +  "edited_at": null,    "emojis": [      {        "category": "reactions", @@ -747,6 +754,7 @@ func (suite *StatusCreateTestSuite) TestReplyToLocalStatus() {    "card": null,    "content": "<p>hello <span class=\"h-card\"><a href=\"http://localhost:8080/@1happyturtle\" class=\"u-url mention\" rel=\"nofollow noreferrer noopener\" target=\"_blank\">@<span>1happyturtle</span></a></span> this reply should work!</p>",    "created_at": "right the hell just now babyee", +  "edited_at": null,    "emojis": [],    "favourited": false,    "favourites_count": 0, @@ -829,6 +837,7 @@ func (suite *StatusCreateTestSuite) TestAttachNewMediaSuccess() {    "card": null,    "content": "<p>here's an image attachment</p>",    "created_at": "right the hell just now babyee", +  "edited_at": null,    "emojis": [],    "favourited": false,    "favourites_count": 0, @@ -933,6 +942,7 @@ func (suite *StatusCreateTestSuite) TestPostNewStatusWithNoncanonicalLanguageTag    "card": null,    "content": "<p>English? what's English? i speak American</p>",    "created_at": "right the hell just now babyee", +  "edited_at": null,    "emojis": [],    "favourited": false,    "favourites_count": 0, @@ -1007,6 +1017,7 @@ func (suite *StatusCreateTestSuite) TestPostNewStatusWithPollForm() {    "card": null,    "content": "<p>this is a status with a poll!</p>",    "created_at": "right the hell just now babyee", +  "edited_at": null,    "emojis": [],    "favourited": false,    "favourites_count": 0, @@ -1103,6 +1114,7 @@ func (suite *StatusCreateTestSuite) TestPostNewStatusWithPollJSON() {    "card": null,    "content": "<p>this is a status with a poll!</p>",    "created_at": "right the hell just now babyee", +  "edited_at": null,    "emojis": [],    "favourited": false,    "favourites_count": 0, diff --git a/internal/api/client/statuses/statusfave_test.go b/internal/api/client/statuses/statusfave_test.go index bd81c0cf9..8851b4d58 100644 --- a/internal/api/client/statuses/statusfave_test.go +++ b/internal/api/client/statuses/statusfave_test.go @@ -105,6 +105,7 @@ func (suite *StatusFaveTestSuite) TestPostFave() {    "card": null,    "content": "🐕🐕🐕🐕🐕",    "created_at": "right the hell just now babyee", +  "edited_at": null,    "emojis": [],    "favourited": true,    "favourites_count": 1, @@ -228,6 +229,7 @@ func (suite *StatusFaveTestSuite) TestPostFaveImplicitAccept() {    "card": null,    "content": "<p>Hi <span class=\"h-card\"><a href=\"http://localhost:8080/@1happyturtle\" class=\"u-url mention\" rel=\"nofollow noreferrer noopener\" target=\"_blank\">@<span>1happyturtle</span></a></span>, can I reply?</p>",    "created_at": "right the hell just now babyee", +  "edited_at": null,    "emojis": [],    "favourited": true,    "favourites_count": 1, diff --git a/internal/api/client/statuses/statushistory_test.go b/internal/api/client/statuses/statushistory_test.go index aea666dbb..3878f54e4 100644 --- a/internal/api/client/statuses/statushistory_test.go +++ b/internal/api/client/statuses/statushistory_test.go @@ -116,8 +116,8 @@ func (suite *StatusHistoryTestSuite) TestGetHistory() {        "header_media_id": "01PFPMWK2FF0D9WMHEJHR07C3Q",        "followers_count": 2,        "following_count": 2, -      "statuses_count": 8, -      "last_status_at": "2024-01-10", +      "statuses_count": 9, +      "last_status_at": "2024-11-01",        "emojis": [],        "fields": [],        "enable_rss": true diff --git a/internal/api/client/statuses/statusmute_test.go b/internal/api/client/statuses/statusmute_test.go index 384761fc6..66bd4a420 100644 --- a/internal/api/client/statuses/statusmute_test.go +++ b/internal/api/client/statuses/statusmute_test.go @@ -91,6 +91,7 @@ func (suite *StatusMuteTestSuite) TestMuteUnmuteStatus() {  	suite.Equal(`{    "id": "01F8MHAMCHF6Y650WCRSCP4WMY",    "created_at": "2021-10-20T10:40:37.000Z", +  "edited_at": null,    "in_reply_to_id": null,    "in_reply_to_account_id": null,    "sensitive": true, @@ -134,8 +135,8 @@ func (suite *StatusMuteTestSuite) TestMuteUnmuteStatus() {      "header_media_id": "01PFPMWK2FF0D9WMHEJHR07C3Q",      "followers_count": 2,      "following_count": 2, -    "statuses_count": 8, -    "last_status_at": "2024-01-10", +    "statuses_count": 9, +    "last_status_at": "2024-11-01",      "emojis": [],      "fields": [],      "enable_rss": true @@ -178,6 +179,7 @@ func (suite *StatusMuteTestSuite) TestMuteUnmuteStatus() {  	suite.Equal(`{    "id": "01F8MHAMCHF6Y650WCRSCP4WMY",    "created_at": "2021-10-20T10:40:37.000Z", +  "edited_at": null,    "in_reply_to_id": null,    "in_reply_to_account_id": null,    "sensitive": true, @@ -221,8 +223,8 @@ func (suite *StatusMuteTestSuite) TestMuteUnmuteStatus() {      "header_media_id": "01PFPMWK2FF0D9WMHEJHR07C3Q",      "followers_count": 2,      "following_count": 2, -    "statuses_count": 8, -    "last_status_at": "2024-01-10", +    "statuses_count": 9, +    "last_status_at": "2024-11-01",      "emojis": [],      "fields": [],      "enable_rss": true  | 
