diff options
Diffstat (limited to 'internal/processing/status/util_test.go')
-rw-r--r-- | internal/processing/status/util_test.go | 349 |
1 files changed, 349 insertions, 0 deletions
diff --git a/internal/processing/status/util_test.go b/internal/processing/status/util_test.go new file mode 100644 index 000000000..9a4bd6515 --- /dev/null +++ b/internal/processing/status/util_test.go @@ -0,0 +1,349 @@ +package status_test + +import ( + "fmt" + "testing" + + "github.com/stretchr/testify/assert" + "github.com/stretchr/testify/suite" + "github.com/superseriousbusiness/gotosocial/internal/api/model" + "github.com/superseriousbusiness/gotosocial/internal/gtsmodel" + "github.com/superseriousbusiness/gotosocial/internal/processing/status" + "github.com/superseriousbusiness/gotosocial/testrig" +) + +const statusText1 = `Another test @foss_satan@fossbros-anonymous.io + +#Hashtag + +Text` +const statusText1ExpectedFull = `<p>Another test <span class="h-card"><a href="http://fossbros-anonymous.io/@foss_satan" class="u-url mention" rel="nofollow noreferrer noopener" target="_blank">@<span>foss_satan</span></a></span><br/><br/><a href="http://localhost:8080/tags/Hashtag" class="mention hashtag" rel="tag nofollow noreferrer noopener" target="_blank">#<span>Hashtag</span></a><br/><br/>Text</p>` +const statusText1ExpectedPartial = `<p>Another test <span class="h-card"><a href="http://fossbros-anonymous.io/@foss_satan" class="u-url mention" rel="nofollow noreferrer noopener" target="_blank">@<span>foss_satan</span></a></span><br/><br/>#Hashtag<br/><br/>Text</p>` + +const statusText2 = `Another test @foss_satan@fossbros-anonymous.io + +#Hashtag + +#hashTAG` + +const status2TextExpectedFull = `<p>Another test <span class="h-card"><a href="http://fossbros-anonymous.io/@foss_satan" class="u-url mention" rel="nofollow noreferrer noopener" target="_blank">@<span>foss_satan</span></a></span><br/><br/><a href="http://localhost:8080/tags/Hashtag" class="mention hashtag" rel="tag nofollow noreferrer noopener" target="_blank">#<span>Hashtag</span></a><br/><br/><a href="http://localhost:8080/tags/Hashtag" class="mention hashtag" rel="tag nofollow noreferrer noopener" target="_blank">#<span>hashTAG</span></a></p>` + +type UtilTestSuite struct { + StatusStandardTestSuite +} + +func (suite *UtilTestSuite) SetupSuite() { + suite.testTokens = testrig.NewTestTokens() + suite.testClients = testrig.NewTestClients() + suite.testApplications = testrig.NewTestApplications() + suite.testUsers = testrig.NewTestUsers() + suite.testAccounts = testrig.NewTestAccounts() + suite.testAttachments = testrig.NewTestAttachments() + suite.testStatuses = testrig.NewTestStatuses() + suite.testTags = testrig.NewTestTags() + suite.testMentions = testrig.NewTestMentions() +} + +func (suite *UtilTestSuite) SetupTest() { + suite.config = testrig.NewTestConfig() + suite.db = testrig.NewTestDB() + suite.log = testrig.NewTestLog() + suite.typeConverter = testrig.NewTestTypeConverter(suite.db) + suite.fromClientAPIChan = make(chan gtsmodel.FromClientAPI, 100) + suite.status = status.New(suite.db, suite.typeConverter, suite.config, suite.fromClientAPIChan, suite.log) + + testrig.StandardDBSetup(suite.db, nil) +} + +func (suite *UtilTestSuite) TearDownTest() { + testrig.StandardDBTeardown(suite.db) +} + +func (suite *UtilTestSuite) TestProcessMentions1() { + creatingAccount := suite.testAccounts["local_account_1"] + mentionedAccount := suite.testAccounts["remote_account_1"] + + form := &model.AdvancedStatusCreateForm{ + StatusCreateRequest: model.StatusCreateRequest{ + Status: statusText1, + MediaIDs: []string{}, + Poll: nil, + InReplyToID: "", + Sensitive: false, + SpoilerText: "", + Visibility: model.VisibilityPublic, + ScheduledAt: "", + Language: "en", + Format: model.StatusFormatPlain, + }, + AdvancedVisibilityFlagsForm: model.AdvancedVisibilityFlagsForm{ + Federated: nil, + Boostable: nil, + Replyable: nil, + Likeable: nil, + }, + } + + status := >smodel.Status{ + ID: "01FCTDD78JJMX3K9KPXQ7ZQ8BJ", + } + + err := suite.status.ProcessMentions(form, creatingAccount.ID, status) + assert.NoError(suite.T(), err) + + assert.Len(suite.T(), status.GTSMentions, 1) + newMention := status.GTSMentions[0] + assert.Equal(suite.T(), mentionedAccount.ID, newMention.TargetAccountID) + assert.Equal(suite.T(), creatingAccount.ID, newMention.OriginAccountID) + assert.Equal(suite.T(), creatingAccount.URI, newMention.OriginAccountURI) + assert.Equal(suite.T(), status.ID, newMention.StatusID) + assert.Equal(suite.T(), fmt.Sprintf("@%s@%s", mentionedAccount.Username, mentionedAccount.Domain), newMention.NameString) + assert.Equal(suite.T(), mentionedAccount.URI, newMention.MentionedAccountURI) + assert.Equal(suite.T(), mentionedAccount.URL, newMention.MentionedAccountURL) + assert.NotNil(suite.T(), newMention.GTSAccount) + + assert.Len(suite.T(), status.Mentions, 1) + assert.Equal(suite.T(), newMention.ID, status.Mentions[0]) +} + +func (suite *UtilTestSuite) TestProcessContentFull1() { + + /* + TEST PREPARATION + */ + // we need to partially process the status first since processContent expects a status with some stuff already set on it + creatingAccount := suite.testAccounts["local_account_1"] + form := &model.AdvancedStatusCreateForm{ + StatusCreateRequest: model.StatusCreateRequest{ + Status: statusText1, + MediaIDs: []string{}, + Poll: nil, + InReplyToID: "", + Sensitive: false, + SpoilerText: "", + Visibility: model.VisibilityPublic, + ScheduledAt: "", + Language: "en", + Format: model.StatusFormatPlain, + }, + AdvancedVisibilityFlagsForm: model.AdvancedVisibilityFlagsForm{ + Federated: nil, + Boostable: nil, + Replyable: nil, + Likeable: nil, + }, + } + + status := >smodel.Status{ + ID: "01FCTDD78JJMX3K9KPXQ7ZQ8BJ", + } + + err := suite.status.ProcessMentions(form, creatingAccount.ID, status) + assert.NoError(suite.T(), err) + assert.Empty(suite.T(), status.Content) // shouldn't be set yet + + err = suite.status.ProcessTags(form, creatingAccount.ID, status) + assert.NoError(suite.T(), err) + assert.Empty(suite.T(), status.Content) // shouldn't be set yet + + /* + ACTUAL TEST + */ + + err = suite.status.ProcessContent(form, creatingAccount.ID, status) + assert.NoError(suite.T(), err) + assert.Equal(suite.T(), statusText1ExpectedFull, status.Content) +} + +func (suite *UtilTestSuite) TestProcessContentPartial1() { + + /* + TEST PREPARATION + */ + // we need to partially process the status first since processContent expects a status with some stuff already set on it + creatingAccount := suite.testAccounts["local_account_1"] + form := &model.AdvancedStatusCreateForm{ + StatusCreateRequest: model.StatusCreateRequest{ + Status: statusText1, + MediaIDs: []string{}, + Poll: nil, + InReplyToID: "", + Sensitive: false, + SpoilerText: "", + Visibility: model.VisibilityPublic, + ScheduledAt: "", + Language: "en", + Format: model.StatusFormatPlain, + }, + AdvancedVisibilityFlagsForm: model.AdvancedVisibilityFlagsForm{ + Federated: nil, + Boostable: nil, + Replyable: nil, + Likeable: nil, + }, + } + + status := >smodel.Status{ + ID: "01FCTDD78JJMX3K9KPXQ7ZQ8BJ", + } + + err := suite.status.ProcessMentions(form, creatingAccount.ID, status) + assert.NoError(suite.T(), err) + assert.Empty(suite.T(), status.Content) // shouldn't be set yet + + /* + ACTUAL TEST + */ + + err = suite.status.ProcessContent(form, creatingAccount.ID, status) + assert.NoError(suite.T(), err) + assert.Equal(suite.T(), statusText1ExpectedPartial, status.Content) +} + +func (suite *UtilTestSuite) TestProcessMentions2() { + creatingAccount := suite.testAccounts["local_account_1"] + mentionedAccount := suite.testAccounts["remote_account_1"] + + form := &model.AdvancedStatusCreateForm{ + StatusCreateRequest: model.StatusCreateRequest{ + Status: statusText2, + MediaIDs: []string{}, + Poll: nil, + InReplyToID: "", + Sensitive: false, + SpoilerText: "", + Visibility: model.VisibilityPublic, + ScheduledAt: "", + Language: "en", + Format: model.StatusFormatPlain, + }, + AdvancedVisibilityFlagsForm: model.AdvancedVisibilityFlagsForm{ + Federated: nil, + Boostable: nil, + Replyable: nil, + Likeable: nil, + }, + } + + status := >smodel.Status{ + ID: "01FCTDD78JJMX3K9KPXQ7ZQ8BJ", + } + + err := suite.status.ProcessMentions(form, creatingAccount.ID, status) + assert.NoError(suite.T(), err) + + assert.Len(suite.T(), status.GTSMentions, 1) + newMention := status.GTSMentions[0] + assert.Equal(suite.T(), mentionedAccount.ID, newMention.TargetAccountID) + assert.Equal(suite.T(), creatingAccount.ID, newMention.OriginAccountID) + assert.Equal(suite.T(), creatingAccount.URI, newMention.OriginAccountURI) + assert.Equal(suite.T(), status.ID, newMention.StatusID) + assert.Equal(suite.T(), fmt.Sprintf("@%s@%s", mentionedAccount.Username, mentionedAccount.Domain), newMention.NameString) + assert.Equal(suite.T(), mentionedAccount.URI, newMention.MentionedAccountURI) + assert.Equal(suite.T(), mentionedAccount.URL, newMention.MentionedAccountURL) + assert.NotNil(suite.T(), newMention.GTSAccount) + + assert.Len(suite.T(), status.Mentions, 1) + assert.Equal(suite.T(), newMention.ID, status.Mentions[0]) +} + +func (suite *UtilTestSuite) TestProcessContentFull2() { + + /* + TEST PREPARATION + */ + // we need to partially process the status first since processContent expects a status with some stuff already set on it + creatingAccount := suite.testAccounts["local_account_1"] + form := &model.AdvancedStatusCreateForm{ + StatusCreateRequest: model.StatusCreateRequest{ + Status: statusText2, + MediaIDs: []string{}, + Poll: nil, + InReplyToID: "", + Sensitive: false, + SpoilerText: "", + Visibility: model.VisibilityPublic, + ScheduledAt: "", + Language: "en", + Format: model.StatusFormatPlain, + }, + AdvancedVisibilityFlagsForm: model.AdvancedVisibilityFlagsForm{ + Federated: nil, + Boostable: nil, + Replyable: nil, + Likeable: nil, + }, + } + + status := >smodel.Status{ + ID: "01FCTDD78JJMX3K9KPXQ7ZQ8BJ", + } + + err := suite.status.ProcessMentions(form, creatingAccount.ID, status) + assert.NoError(suite.T(), err) + assert.Empty(suite.T(), status.Content) // shouldn't be set yet + + err = suite.status.ProcessTags(form, creatingAccount.ID, status) + assert.NoError(suite.T(), err) + assert.Empty(suite.T(), status.Content) // shouldn't be set yet + + /* + ACTUAL TEST + */ + + err = suite.status.ProcessContent(form, creatingAccount.ID, status) + assert.NoError(suite.T(), err) + + assert.Equal(suite.T(), status2TextExpectedFull, status.Content) +} + +func (suite *UtilTestSuite) TestProcessContentPartial2() { + + /* + TEST PREPARATION + */ + // we need to partially process the status first since processContent expects a status with some stuff already set on it + creatingAccount := suite.testAccounts["local_account_1"] + form := &model.AdvancedStatusCreateForm{ + StatusCreateRequest: model.StatusCreateRequest{ + Status: statusText2, + MediaIDs: []string{}, + Poll: nil, + InReplyToID: "", + Sensitive: false, + SpoilerText: "", + Visibility: model.VisibilityPublic, + ScheduledAt: "", + Language: "en", + Format: model.StatusFormatPlain, + }, + AdvancedVisibilityFlagsForm: model.AdvancedVisibilityFlagsForm{ + Federated: nil, + Boostable: nil, + Replyable: nil, + Likeable: nil, + }, + } + + status := >smodel.Status{ + ID: "01FCTDD78JJMX3K9KPXQ7ZQ8BJ", + } + + err := suite.status.ProcessMentions(form, creatingAccount.ID, status) + assert.NoError(suite.T(), err) + assert.Empty(suite.T(), status.Content) // shouldn't be set yet + + /* + ACTUAL TEST + */ + + err = suite.status.ProcessContent(form, creatingAccount.ID, status) + assert.NoError(suite.T(), err) + + fmt.Println(status.Content) + // assert.Equal(suite.T(), statusText2ExpectedPartial, status.Content) +} + +func TestUtilTestSuite(t *testing.T) { + suite.Run(t, new(UtilTestSuite)) +} |