| 
									
										
										
										
											2023-03-12 16:00:57 +01:00
										 |  |  | // GoToSocial | 
					
						
							|  |  |  | // Copyright (C) GoToSocial Authors admin@gotosocial.org | 
					
						
							|  |  |  | // SPDX-License-Identifier: AGPL-3.0-or-later | 
					
						
							|  |  |  | // | 
					
						
							|  |  |  | // This program is free software: you can redistribute it and/or modify | 
					
						
							|  |  |  | // it under the terms of the GNU Affero General Public License as published by | 
					
						
							|  |  |  | // the Free Software Foundation, either version 3 of the License, or | 
					
						
							|  |  |  | // (at your option) any later version. | 
					
						
							|  |  |  | // | 
					
						
							|  |  |  | // This program is distributed in the hope that it will be useful, | 
					
						
							|  |  |  | // but WITHOUT ANY WARRANTY; without even the implied warranty of | 
					
						
							|  |  |  | // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | 
					
						
							|  |  |  | // GNU Affero General Public License for more details. | 
					
						
							|  |  |  | // | 
					
						
							|  |  |  | // You should have received a copy of the GNU Affero General Public License | 
					
						
							|  |  |  | // along with this program.  If not, see <http://www.gnu.org/licenses/>. | 
					
						
							| 
									
										
										
										
											2022-04-29 15:53:04 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | package federation_test | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | import ( | 
					
						
							| 
									
										
										
										
											2023-01-13 17:02:45 +01:00
										 |  |  | 	"bytes" | 
					
						
							| 
									
										
										
										
											2022-04-29 15:53:04 +02:00
										 |  |  | 	"context" | 
					
						
							| 
									
										
										
										
											2023-01-13 17:02:45 +01:00
										 |  |  | 	"encoding/json" | 
					
						
							| 
									
										
										
										
											2024-04-11 10:45:35 +01:00
										 |  |  | 	"io" | 
					
						
							| 
									
										
										
										
											2022-04-29 15:53:04 +02:00
										 |  |  | 	"net/url" | 
					
						
							|  |  |  | 	"testing" | 
					
						
							|  |  |  | 	"time" | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	"github.com/stretchr/testify/suite" | 
					
						
							|  |  |  | 	"github.com/superseriousbusiness/gotosocial/internal/federation" | 
					
						
							| 
									
										
										
										
											2024-03-04 12:30:12 +00:00
										 |  |  | 	"github.com/superseriousbusiness/gotosocial/internal/filter/visibility" | 
					
						
							| 
									
										
										
										
											2022-04-29 15:53:04 +02:00
										 |  |  | 	"github.com/superseriousbusiness/gotosocial/internal/gtsmodel" | 
					
						
							| 
									
										
										
										
											2023-08-07 19:38:11 +02:00
										 |  |  | 	"github.com/superseriousbusiness/gotosocial/internal/util" | 
					
						
							| 
									
										
										
										
											2022-04-29 15:53:04 +02:00
										 |  |  | 	"github.com/superseriousbusiness/gotosocial/testrig" | 
					
						
							|  |  |  | ) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | type FederatingActorTestSuite struct { | 
					
						
							|  |  |  | 	FederatorStandardTestSuite | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func (suite *FederatingActorTestSuite) TestSendNoRemoteFollowers() { | 
					
						
							|  |  |  | 	ctx := context.Background() | 
					
						
							|  |  |  | 	testAccount := suite.testAccounts["local_account_1"] | 
					
						
							|  |  |  | 	testNote := testrig.NewAPNote( | 
					
						
							|  |  |  | 		testrig.URLMustParse("http://localhost:8080/users/the_mighty_zork/statuses/01G1TR6BADACCZWQMNF9X21TV5"), | 
					
						
							|  |  |  | 		testrig.URLMustParse("http://localhost:8080/@the_mighty_zork/statuses/01G1TR6BADACCZWQMNF9X21TV5"), | 
					
						
							|  |  |  | 		time.Now(), | 
					
						
							|  |  |  | 		"boobies", | 
					
						
							|  |  |  | 		"", | 
					
						
							|  |  |  | 		testrig.URLMustParse(testAccount.URI), | 
					
						
							|  |  |  | 		[]*url.URL{testrig.URLMustParse(testAccount.FollowersURI)}, | 
					
						
							|  |  |  | 		nil, | 
					
						
							|  |  |  | 		false, | 
					
						
							|  |  |  | 		nil, | 
					
						
							|  |  |  | 		nil, | 
					
						
							| 
									
										
										
										
											2023-07-31 15:47:35 +02:00
										 |  |  | 		nil, | 
					
						
							| 
									
										
										
										
											2022-04-29 15:53:04 +02:00
										 |  |  | 	) | 
					
						
							|  |  |  | 	testActivity := testrig.WrapAPNoteInCreate(testrig.URLMustParse("http://localhost:8080/whatever_some_create"), testrig.URLMustParse(testAccount.URI), time.Now(), testNote) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// setup transport controller with a no-op client so we don't make external calls | 
					
						
							| 
									
										
										
										
											2022-06-11 11:01:34 +02:00
										 |  |  | 	httpClient := testrig.NewMockHTTPClient(nil, "../../testrig/media") | 
					
						
							| 
									
										
										
										
											2023-03-01 18:26:53 +00:00
										 |  |  | 	tc := testrig.NewTestTransportController(&suite.state, httpClient) | 
					
						
							| 
									
										
										
										
											2022-06-11 11:01:34 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-04-29 15:53:04 +02:00
										 |  |  | 	// setup module being tested | 
					
						
							| 
									
										
										
										
											2024-03-04 12:30:12 +00:00
										 |  |  | 	federator := federation.NewFederator( | 
					
						
							|  |  |  | 		&suite.state, | 
					
						
							|  |  |  | 		testrig.NewTestFederatingDB(&suite.state), | 
					
						
							|  |  |  | 		tc, | 
					
						
							|  |  |  | 		suite.typeconverter, | 
					
						
							|  |  |  | 		visibility.NewFilter(&suite.state), | 
					
						
							|  |  |  | 		testrig.NewTestMediaManager(&suite.state), | 
					
						
							|  |  |  | 	) | 
					
						
							| 
									
										
										
										
											2022-04-29 15:53:04 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	activity, err := federator.FederatingActor().Send(ctx, testrig.URLMustParse(testAccount.OutboxURI), testActivity) | 
					
						
							|  |  |  | 	suite.NoError(err) | 
					
						
							|  |  |  | 	suite.NotNil(activity) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// because zork has no remote followers, sent messages should be empty (no messages sent to own instance) | 
					
						
							| 
									
										
										
										
											2024-03-04 12:30:12 +00:00
										 |  |  | 	suite.Empty(&httpClient.SentMessages) | 
					
						
							| 
									
										
										
										
											2022-04-29 15:53:04 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func (suite *FederatingActorTestSuite) TestSendRemoteFollower() { | 
					
						
							|  |  |  | 	ctx := context.Background() | 
					
						
							|  |  |  | 	testAccount := suite.testAccounts["local_account_1"] | 
					
						
							|  |  |  | 	testRemoteAccount := suite.testAccounts["remote_account_1"] | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-06-13 16:47:56 +02:00
										 |  |  | 	err := suite.state.DB.Put(ctx, >smodel.Follow{ | 
					
						
							| 
									
										
										
										
											2022-04-29 15:53:04 +02:00
										 |  |  | 		ID:              "01G1TRWV4AYCDBX5HRWT2EVBCV", | 
					
						
							| 
									
										
										
										
											2022-06-11 11:01:34 +02:00
										 |  |  | 		CreatedAt:       testrig.TimeMustParse("2022-06-02T12:22:21+02:00"), | 
					
						
							|  |  |  | 		UpdatedAt:       testrig.TimeMustParse("2022-06-02T12:22:21+02:00"), | 
					
						
							| 
									
										
										
										
											2022-04-29 15:53:04 +02:00
										 |  |  | 		AccountID:       testRemoteAccount.ID, | 
					
						
							|  |  |  | 		TargetAccountID: testAccount.ID, | 
					
						
							| 
									
										
										
										
											2023-08-07 19:38:11 +02:00
										 |  |  | 		ShowReblogs:     util.Ptr(true), | 
					
						
							| 
									
										
										
										
											2022-04-29 15:53:04 +02:00
										 |  |  | 		URI:             "http://fossbros-anonymous.io/users/foss_satan/follows/01G1TRWV4AYCDBX5HRWT2EVBCV", | 
					
						
							| 
									
										
										
										
											2023-08-07 19:38:11 +02:00
										 |  |  | 		Notify:          util.Ptr(false), | 
					
						
							| 
									
										
										
										
											2022-04-29 15:53:04 +02:00
										 |  |  | 	}) | 
					
						
							|  |  |  | 	suite.NoError(err) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	testNote := testrig.NewAPNote( | 
					
						
							|  |  |  | 		testrig.URLMustParse("http://localhost:8080/users/the_mighty_zork/statuses/01G1TR6BADACCZWQMNF9X21TV5"), | 
					
						
							|  |  |  | 		testrig.URLMustParse("http://localhost:8080/@the_mighty_zork/statuses/01G1TR6BADACCZWQMNF9X21TV5"), | 
					
						
							| 
									
										
										
										
											2022-06-11 11:01:34 +02:00
										 |  |  | 		testrig.TimeMustParse("2022-06-02T12:22:21+02:00"), | 
					
						
							| 
									
										
										
										
											2022-04-29 15:53:04 +02:00
										 |  |  | 		"boobies", | 
					
						
							|  |  |  | 		"", | 
					
						
							|  |  |  | 		testrig.URLMustParse(testAccount.URI), | 
					
						
							|  |  |  | 		[]*url.URL{testrig.URLMustParse(testAccount.FollowersURI)}, | 
					
						
							|  |  |  | 		nil, | 
					
						
							|  |  |  | 		false, | 
					
						
							|  |  |  | 		nil, | 
					
						
							|  |  |  | 		nil, | 
					
						
							| 
									
										
										
										
											2023-07-31 15:47:35 +02:00
										 |  |  | 		nil, | 
					
						
							| 
									
										
										
										
											2022-04-29 15:53:04 +02:00
										 |  |  | 	) | 
					
						
							| 
									
										
										
										
											2022-06-11 11:01:34 +02:00
										 |  |  | 	testActivity := testrig.WrapAPNoteInCreate(testrig.URLMustParse("http://localhost:8080/whatever_some_create"), testrig.URLMustParse(testAccount.URI), testrig.TimeMustParse("2022-06-02T12:22:21+02:00"), testNote) | 
					
						
							| 
									
										
										
										
											2022-04-29 15:53:04 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-06-11 11:01:34 +02:00
										 |  |  | 	httpClient := testrig.NewMockHTTPClient(nil, "../../testrig/media") | 
					
						
							| 
									
										
										
										
											2023-03-01 18:26:53 +00:00
										 |  |  | 	tc := testrig.NewTestTransportController(&suite.state, httpClient) | 
					
						
							| 
									
										
										
										
											2024-03-04 12:30:12 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-04-29 15:53:04 +02:00
										 |  |  | 	// setup module being tested | 
					
						
							| 
									
										
										
										
											2024-03-04 12:30:12 +00:00
										 |  |  | 	federator := federation.NewFederator( | 
					
						
							|  |  |  | 		&suite.state, | 
					
						
							|  |  |  | 		testrig.NewTestFederatingDB(&suite.state), | 
					
						
							|  |  |  | 		tc, | 
					
						
							|  |  |  | 		suite.typeconverter, | 
					
						
							|  |  |  | 		visibility.NewFilter(&suite.state), | 
					
						
							|  |  |  | 		testrig.NewTestMediaManager(&suite.state), | 
					
						
							|  |  |  | 	) | 
					
						
							| 
									
										
										
										
											2022-04-29 15:53:04 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	activity, err := federator.FederatingActor().Send(ctx, testrig.URLMustParse(testAccount.OutboxURI), testActivity) | 
					
						
							|  |  |  | 	suite.NoError(err) | 
					
						
							|  |  |  | 	suite.NotNil(activity) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// because we added 1 remote follower for zork, there should be a url in sentMessage | 
					
						
							| 
									
										
										
										
											2024-04-11 10:45:35 +01:00
										 |  |  | 	var sent []byte | 
					
						
							| 
									
										
										
										
											2022-08-31 17:31:21 +02:00
										 |  |  | 	if !testrig.WaitFor(func() bool { | 
					
						
							| 
									
										
										
										
											2024-04-11 10:45:35 +01:00
										 |  |  | 		delivery, ok := suite.state.Workers.Delivery.Queue.Pop() | 
					
						
							|  |  |  | 		if !ok { | 
					
						
							|  |  |  | 			return false | 
					
						
							| 
									
										
										
										
											2022-08-31 17:31:21 +02:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2024-04-11 10:45:35 +01:00
										 |  |  | 		if !testrig.EqualRequestURIs(delivery.Request.URL, *testRemoteAccount.SharedInboxURI) { | 
					
						
							|  |  |  | 			panic("differing request uris") | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		sent, err = io.ReadAll(delivery.Request.Body) | 
					
						
							|  |  |  | 		if err != nil { | 
					
						
							|  |  |  | 			panic("error reading body: " + err.Error()) | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		return true | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-08-31 17:31:21 +02:00
										 |  |  | 	}) { | 
					
						
							|  |  |  | 		suite.FailNow("timed out waiting for message") | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-01-13 17:02:45 +01:00
										 |  |  | 	dst := new(bytes.Buffer) | 
					
						
							| 
									
										
										
										
											2024-04-11 10:45:35 +01:00
										 |  |  | 	err = json.Indent(dst, sent, "", "  ") | 
					
						
							| 
									
										
										
										
											2023-01-13 17:02:45 +01:00
										 |  |  | 	suite.NoError(err) | 
					
						
							|  |  |  | 	suite.Equal(`{ | 
					
						
							|  |  |  |   "@context": "https://www.w3.org/ns/activitystreams", | 
					
						
							|  |  |  |   "actor": "http://localhost:8080/users/the_mighty_zork", | 
					
						
							|  |  |  |   "id": "http://localhost:8080/whatever_some_create", | 
					
						
							|  |  |  |   "object": { | 
					
						
							|  |  |  |     "attributedTo": "http://localhost:8080/users/the_mighty_zork", | 
					
						
							|  |  |  |     "content": "boobies", | 
					
						
							|  |  |  |     "id": "http://localhost:8080/users/the_mighty_zork/statuses/01G1TR6BADACCZWQMNF9X21TV5", | 
					
						
							|  |  |  |     "published": "2022-06-02T12:22:21+02:00", | 
					
						
							|  |  |  |     "tag": [], | 
					
						
							|  |  |  |     "to": "http://localhost:8080/users/the_mighty_zork/followers", | 
					
						
							|  |  |  |     "type": "Note", | 
					
						
							|  |  |  |     "url": "http://localhost:8080/@the_mighty_zork/statuses/01G1TR6BADACCZWQMNF9X21TV5" | 
					
						
							|  |  |  |   }, | 
					
						
							|  |  |  |   "published": "2022-06-02T12:22:21+02:00", | 
					
						
							|  |  |  |   "to": "http://localhost:8080/users/the_mighty_zork/followers", | 
					
						
							|  |  |  |   "type": "Create" | 
					
						
							|  |  |  | }`, dst.String()) | 
					
						
							| 
									
										
										
										
											2022-04-29 15:53:04 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func TestFederatingActorTestSuite(t *testing.T) { | 
					
						
							|  |  |  | 	suite.Run(t, new(FederatingActorTestSuite)) | 
					
						
							|  |  |  | } |