| 
									
										
										
										
											2022-01-09 18:41:22 +01:00
										 |  |  | /* | 
					
						
							|  |  |  |    GoToSocial | 
					
						
							|  |  |  |    Copyright (C) 2021-2022 GoToSocial Authors admin@gotosocial.org | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    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-01-08 17:17:01 +01:00
										 |  |  | package media_test | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-01-09 18:41:22 +01:00
										 |  |  | import ( | 
					
						
							| 
									
										
										
										
											2022-01-16 18:52:55 +01:00
										 |  |  | 	"bytes" | 
					
						
							| 
									
										
										
										
											2022-01-10 18:36:09 +01:00
										 |  |  | 	"context" | 
					
						
							|  |  |  | 	"fmt" | 
					
						
							| 
									
										
										
										
											2022-01-16 18:52:55 +01:00
										 |  |  | 	"io" | 
					
						
							| 
									
										
										
										
											2022-01-10 18:36:09 +01:00
										 |  |  | 	"os" | 
					
						
							| 
									
										
										
										
											2022-01-29 12:16:12 +01:00
										 |  |  | 	"path" | 
					
						
							| 
									
										
										
										
											2022-01-10 18:36:09 +01:00
										 |  |  | 	"testing" | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-01-24 18:11:27 +01:00
										 |  |  | 	"codeberg.org/gruf/go-store/kv" | 
					
						
							|  |  |  | 	"codeberg.org/gruf/go-store/storage" | 
					
						
							| 
									
										
										
										
											2022-01-09 18:41:22 +01:00
										 |  |  | 	"github.com/stretchr/testify/suite" | 
					
						
							| 
									
										
										
										
											2022-03-07 11:08:26 +01:00
										 |  |  | 	gtsmodel "github.com/superseriousbusiness/gotosocial/internal/gtsmodel" | 
					
						
							| 
									
										
										
										
											2022-01-09 18:41:22 +01:00
										 |  |  | 	"github.com/superseriousbusiness/gotosocial/internal/media" | 
					
						
							| 
									
										
										
										
											2022-07-03 12:08:30 +02:00
										 |  |  | 	gtsstorage "github.com/superseriousbusiness/gotosocial/internal/storage" | 
					
						
							| 
									
										
										
										
											2022-08-31 17:31:21 +02:00
										 |  |  | 	"github.com/superseriousbusiness/gotosocial/testrig" | 
					
						
							| 
									
										
										
										
											2022-01-09 18:41:22 +01:00
										 |  |  | ) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-01-10 18:36:09 +01:00
										 |  |  | type ManagerTestSuite struct { | 
					
						
							|  |  |  | 	MediaStandardTestSuite | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-09-24 11:11:47 +02:00
										 |  |  | func (suite *ManagerTestSuite) TestEmojiProcessBlocking() { | 
					
						
							|  |  |  | 	ctx := context.Background() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	data := func(_ context.Context) (io.Reader, int, error) { | 
					
						
							|  |  |  | 		// load bytes from a test image | 
					
						
							|  |  |  | 		b, err := os.ReadFile("./test/rainbow-original.png") | 
					
						
							|  |  |  | 		if err != nil { | 
					
						
							|  |  |  | 			panic(err) | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		return bytes.NewBuffer(b), len(b), nil | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	emojiID := "01GDQ9G782X42BAMFASKP64343" | 
					
						
							|  |  |  | 	emojiURI := "http://localhost:8080/emoji/01GDQ9G782X42BAMFASKP64343" | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	processingEmoji, err := suite.manager.ProcessEmoji(ctx, data, nil, "rainbow_test", emojiID, emojiURI, nil) | 
					
						
							|  |  |  | 	suite.NoError(err) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// do a blocking call to fetch the emoji | 
					
						
							|  |  |  | 	emoji, err := processingEmoji.LoadEmoji(ctx) | 
					
						
							|  |  |  | 	suite.NoError(err) | 
					
						
							|  |  |  | 	suite.NotNil(emoji) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// make sure it's got the stuff set on it that we expect | 
					
						
							|  |  |  | 	suite.Equal(emojiID, emoji.ID) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// file meta should be correctly derived from the image | 
					
						
							|  |  |  | 	suite.Equal("image/png", emoji.ImageContentType) | 
					
						
							|  |  |  | 	suite.Equal("image/png", emoji.ImageStaticContentType) | 
					
						
							|  |  |  | 	suite.Equal(36702, emoji.ImageFileSize) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// now make sure the emoji is in the database | 
					
						
							|  |  |  | 	dbEmoji, err := suite.db.GetEmojiByID(ctx, emojiID) | 
					
						
							|  |  |  | 	suite.NoError(err) | 
					
						
							|  |  |  | 	suite.NotNil(dbEmoji) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// make sure the processed emoji file is in storage | 
					
						
							|  |  |  | 	processedFullBytes, err := suite.storage.Get(ctx, emoji.ImagePath) | 
					
						
							|  |  |  | 	suite.NoError(err) | 
					
						
							|  |  |  | 	suite.NotEmpty(processedFullBytes) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// load the processed bytes from our test folder, to compare | 
					
						
							|  |  |  | 	processedFullBytesExpected, err := os.ReadFile("./test/rainbow-original.png") | 
					
						
							|  |  |  | 	suite.NoError(err) | 
					
						
							|  |  |  | 	suite.NotEmpty(processedFullBytesExpected) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// the bytes in storage should be what we expected | 
					
						
							|  |  |  | 	suite.Equal(processedFullBytesExpected, processedFullBytes) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// now do the same for the thumbnail and make sure it's what we expected | 
					
						
							|  |  |  | 	processedStaticBytes, err := suite.storage.Get(ctx, emoji.ImageStaticPath) | 
					
						
							|  |  |  | 	suite.NoError(err) | 
					
						
							|  |  |  | 	suite.NotEmpty(processedStaticBytes) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	processedStaticBytesExpected, err := os.ReadFile("./test/rainbow-static.png") | 
					
						
							|  |  |  | 	suite.NoError(err) | 
					
						
							|  |  |  | 	suite.NotEmpty(processedStaticBytesExpected) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	suite.Equal(processedStaticBytesExpected, processedStaticBytes) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func (suite *ManagerTestSuite) TestEmojiProcessBlockingTooLarge() { | 
					
						
							|  |  |  | 	ctx := context.Background() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	data := func(_ context.Context) (io.Reader, int, error) { | 
					
						
							|  |  |  | 		// load bytes from a test image | 
					
						
							|  |  |  | 		b, err := os.ReadFile("./test/big-panda.gif") | 
					
						
							|  |  |  | 		if err != nil { | 
					
						
							|  |  |  | 			panic(err) | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		return bytes.NewBuffer(b), len(b), nil | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	emojiID := "01GDQ9G782X42BAMFASKP64343" | 
					
						
							|  |  |  | 	emojiURI := "http://localhost:8080/emoji/01GDQ9G782X42BAMFASKP64343" | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	processingEmoji, err := suite.manager.ProcessEmoji(ctx, data, nil, "big_panda", emojiID, emojiURI, nil) | 
					
						
							|  |  |  | 	suite.NoError(err) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// do a blocking call to fetch the emoji | 
					
						
							|  |  |  | 	emoji, err := processingEmoji.LoadEmoji(ctx) | 
					
						
							|  |  |  | 	suite.EqualError(err, "store: given emoji fileSize (645688b) is larger than allowed size (51200b)") | 
					
						
							|  |  |  | 	suite.Nil(emoji) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func (suite *ManagerTestSuite) TestEmojiProcessBlockingTooLargeNoSizeGiven() { | 
					
						
							|  |  |  | 	ctx := context.Background() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	data := func(_ context.Context) (io.Reader, int, error) { | 
					
						
							|  |  |  | 		// load bytes from a test image | 
					
						
							|  |  |  | 		b, err := os.ReadFile("./test/big-panda.gif") | 
					
						
							|  |  |  | 		if err != nil { | 
					
						
							|  |  |  | 			panic(err) | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		return bytes.NewBuffer(b), len(b), nil | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	emojiID := "01GDQ9G782X42BAMFASKP64343" | 
					
						
							|  |  |  | 	emojiURI := "http://localhost:8080/emoji/01GDQ9G782X42BAMFASKP64343" | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	processingEmoji, err := suite.manager.ProcessEmoji(ctx, data, nil, "big_panda", emojiID, emojiURI, nil) | 
					
						
							|  |  |  | 	suite.NoError(err) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// do a blocking call to fetch the emoji | 
					
						
							|  |  |  | 	emoji, err := processingEmoji.LoadEmoji(ctx) | 
					
						
							|  |  |  | 	suite.EqualError(err, "store: given emoji fileSize (645688b) is larger than allowed size (51200b)") | 
					
						
							|  |  |  | 	suite.Nil(emoji) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func (suite *ManagerTestSuite) TestEmojiProcessBlockingNoFileSizeGiven() { | 
					
						
							|  |  |  | 	ctx := context.Background() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	data := func(_ context.Context) (io.Reader, int, error) { | 
					
						
							|  |  |  | 		// load bytes from a test image | 
					
						
							|  |  |  | 		b, err := os.ReadFile("./test/rainbow-original.png") | 
					
						
							|  |  |  | 		if err != nil { | 
					
						
							|  |  |  | 			panic(err) | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		return bytes.NewBuffer(b), -1, nil | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	emojiID := "01GDQ9G782X42BAMFASKP64343" | 
					
						
							|  |  |  | 	emojiURI := "http://localhost:8080/emoji/01GDQ9G782X42BAMFASKP64343" | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// process the media with no additional info provided | 
					
						
							|  |  |  | 	processingEmoji, err := suite.manager.ProcessEmoji(ctx, data, nil, "rainbow_test", emojiID, emojiURI, nil) | 
					
						
							|  |  |  | 	suite.NoError(err) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// do a blocking call to fetch the emoji | 
					
						
							|  |  |  | 	emoji, err := processingEmoji.LoadEmoji(ctx) | 
					
						
							|  |  |  | 	suite.NoError(err) | 
					
						
							|  |  |  | 	suite.NotNil(emoji) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// make sure it's got the stuff set on it that we expect | 
					
						
							|  |  |  | 	suite.Equal(emojiID, emoji.ID) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// file meta should be correctly derived from the image | 
					
						
							|  |  |  | 	suite.Equal("image/png", emoji.ImageContentType) | 
					
						
							|  |  |  | 	suite.Equal("image/png", emoji.ImageStaticContentType) | 
					
						
							|  |  |  | 	suite.Equal(36702, emoji.ImageFileSize) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// now make sure the emoji is in the database | 
					
						
							|  |  |  | 	dbEmoji, err := suite.db.GetEmojiByID(ctx, emojiID) | 
					
						
							|  |  |  | 	suite.NoError(err) | 
					
						
							|  |  |  | 	suite.NotNil(dbEmoji) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// make sure the processed emoji file is in storage | 
					
						
							|  |  |  | 	processedFullBytes, err := suite.storage.Get(ctx, emoji.ImagePath) | 
					
						
							|  |  |  | 	suite.NoError(err) | 
					
						
							|  |  |  | 	suite.NotEmpty(processedFullBytes) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// load the processed bytes from our test folder, to compare | 
					
						
							|  |  |  | 	processedFullBytesExpected, err := os.ReadFile("./test/rainbow-original.png") | 
					
						
							|  |  |  | 	suite.NoError(err) | 
					
						
							|  |  |  | 	suite.NotEmpty(processedFullBytesExpected) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// the bytes in storage should be what we expected | 
					
						
							|  |  |  | 	suite.Equal(processedFullBytesExpected, processedFullBytes) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// now do the same for the thumbnail and make sure it's what we expected | 
					
						
							|  |  |  | 	processedStaticBytes, err := suite.storage.Get(ctx, emoji.ImageStaticPath) | 
					
						
							|  |  |  | 	suite.NoError(err) | 
					
						
							|  |  |  | 	suite.NotEmpty(processedStaticBytes) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	processedStaticBytesExpected, err := os.ReadFile("./test/rainbow-static.png") | 
					
						
							|  |  |  | 	suite.NoError(err) | 
					
						
							|  |  |  | 	suite.NotEmpty(processedStaticBytesExpected) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	suite.Equal(processedStaticBytesExpected, processedStaticBytes) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-01-10 18:36:09 +01:00
										 |  |  | func (suite *ManagerTestSuite) TestSimpleJpegProcessBlocking() { | 
					
						
							|  |  |  | 	ctx := context.Background() | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-01-23 14:41:58 +01:00
										 |  |  | 	data := func(_ context.Context) (io.Reader, int, error) { | 
					
						
							| 
									
										
										
										
											2022-01-11 17:49:14 +01:00
										 |  |  | 		// load bytes from a test image | 
					
						
							| 
									
										
										
										
											2022-01-16 18:52:55 +01:00
										 |  |  | 		b, err := os.ReadFile("./test/test-jpeg.jpg") | 
					
						
							|  |  |  | 		if err != nil { | 
					
						
							|  |  |  | 			panic(err) | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2022-01-23 14:41:58 +01:00
										 |  |  | 		return bytes.NewBuffer(b), len(b), nil | 
					
						
							| 
									
										
										
										
											2022-01-11 17:49:14 +01:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2022-01-10 18:36:09 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	accountID := "01FS1X72SK9ZPW0J1QQ68BD264" | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// process the media with no additional info provided | 
					
						
							| 
									
										
										
										
											2022-02-22 13:50:33 +01:00
										 |  |  | 	processingMedia, err := suite.manager.ProcessMedia(ctx, data, nil, accountID, nil) | 
					
						
							| 
									
										
										
										
											2022-09-24 11:11:47 +02:00
										 |  |  | 	suite.NoError(err) | 
					
						
							|  |  |  | 	// fetch the attachment id from the processing media | 
					
						
							|  |  |  | 	attachmentID := processingMedia.AttachmentID() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// do a blocking call to fetch the attachment | 
					
						
							|  |  |  | 	attachment, err := processingMedia.LoadAttachment(ctx) | 
					
						
							|  |  |  | 	suite.NoError(err) | 
					
						
							|  |  |  | 	suite.NotNil(attachment) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// make sure it's got the stuff set on it that we expect | 
					
						
							|  |  |  | 	// the attachment ID and accountID we expect | 
					
						
							|  |  |  | 	suite.Equal(attachmentID, attachment.ID) | 
					
						
							|  |  |  | 	suite.Equal(accountID, attachment.AccountID) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// file meta should be correctly derived from the image | 
					
						
							|  |  |  | 	suite.EqualValues(gtsmodel.Original{ | 
					
						
							|  |  |  | 		Width: 1920, Height: 1080, Size: 2073600, Aspect: 1.7777777777777777, | 
					
						
							|  |  |  | 	}, attachment.FileMeta.Original) | 
					
						
							|  |  |  | 	suite.EqualValues(gtsmodel.Small{ | 
					
						
							|  |  |  | 		Width: 512, Height: 288, Size: 147456, Aspect: 1.7777777777777777, | 
					
						
							|  |  |  | 	}, attachment.FileMeta.Small) | 
					
						
							|  |  |  | 	suite.Equal("image/jpeg", attachment.File.ContentType) | 
					
						
							|  |  |  | 	suite.Equal("image/jpeg", attachment.Thumbnail.ContentType) | 
					
						
							|  |  |  | 	suite.Equal(269739, attachment.File.FileSize) | 
					
						
							|  |  |  | 	suite.Equal("LiBzRk#6V[WF_NvzV@WY_3rqV@a$", attachment.Blurhash) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// now make sure the attachment is in the database | 
					
						
							|  |  |  | 	dbAttachment, err := suite.db.GetAttachmentByID(ctx, attachmentID) | 
					
						
							|  |  |  | 	suite.NoError(err) | 
					
						
							|  |  |  | 	suite.NotNil(dbAttachment) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// make sure the processed file is in storage | 
					
						
							|  |  |  | 	processedFullBytes, err := suite.storage.Get(ctx, attachment.File.Path) | 
					
						
							|  |  |  | 	suite.NoError(err) | 
					
						
							|  |  |  | 	suite.NotEmpty(processedFullBytes) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// load the processed bytes from our test folder, to compare | 
					
						
							|  |  |  | 	processedFullBytesExpected, err := os.ReadFile("./test/test-jpeg-processed.jpg") | 
					
						
							|  |  |  | 	suite.NoError(err) | 
					
						
							|  |  |  | 	suite.NotEmpty(processedFullBytesExpected) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// the bytes in storage should be what we expected | 
					
						
							|  |  |  | 	suite.Equal(processedFullBytesExpected, processedFullBytes) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// now do the same for the thumbnail and make sure it's what we expected | 
					
						
							|  |  |  | 	processedThumbnailBytes, err := suite.storage.Get(ctx, attachment.Thumbnail.Path) | 
					
						
							|  |  |  | 	suite.NoError(err) | 
					
						
							|  |  |  | 	suite.NotEmpty(processedThumbnailBytes) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	processedThumbnailBytesExpected, err := os.ReadFile("./test/test-jpeg-thumbnail.jpg") | 
					
						
							|  |  |  | 	suite.NoError(err) | 
					
						
							|  |  |  | 	suite.NotEmpty(processedThumbnailBytesExpected) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	suite.Equal(processedThumbnailBytesExpected, processedThumbnailBytes) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func (suite *ManagerTestSuite) TestSimpleJpegProcessBlockingNoContentLengthGiven() { | 
					
						
							|  |  |  | 	ctx := context.Background() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	data := func(_ context.Context) (io.Reader, int, error) { | 
					
						
							|  |  |  | 		// load bytes from a test image | 
					
						
							|  |  |  | 		b, err := os.ReadFile("./test/test-jpeg.jpg") | 
					
						
							|  |  |  | 		if err != nil { | 
					
						
							|  |  |  | 			panic(err) | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		// give length as -1 to indicate unknown | 
					
						
							|  |  |  | 		return bytes.NewBuffer(b), -1, nil | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	accountID := "01FS1X72SK9ZPW0J1QQ68BD264" | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// process the media with no additional info provided | 
					
						
							|  |  |  | 	processingMedia, err := suite.manager.ProcessMedia(ctx, data, nil, accountID, nil) | 
					
						
							|  |  |  | 	suite.NoError(err) | 
					
						
							|  |  |  | 	// fetch the attachment id from the processing media | 
					
						
							|  |  |  | 	attachmentID := processingMedia.AttachmentID() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// do a blocking call to fetch the attachment | 
					
						
							|  |  |  | 	attachment, err := processingMedia.LoadAttachment(ctx) | 
					
						
							|  |  |  | 	suite.NoError(err) | 
					
						
							|  |  |  | 	suite.NotNil(attachment) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// make sure it's got the stuff set on it that we expect | 
					
						
							|  |  |  | 	// the attachment ID and accountID we expect | 
					
						
							|  |  |  | 	suite.Equal(attachmentID, attachment.ID) | 
					
						
							|  |  |  | 	suite.Equal(accountID, attachment.AccountID) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// file meta should be correctly derived from the image | 
					
						
							|  |  |  | 	suite.EqualValues(gtsmodel.Original{ | 
					
						
							|  |  |  | 		Width: 1920, Height: 1080, Size: 2073600, Aspect: 1.7777777777777777, | 
					
						
							|  |  |  | 	}, attachment.FileMeta.Original) | 
					
						
							|  |  |  | 	suite.EqualValues(gtsmodel.Small{ | 
					
						
							|  |  |  | 		Width: 512, Height: 288, Size: 147456, Aspect: 1.7777777777777777, | 
					
						
							|  |  |  | 	}, attachment.FileMeta.Small) | 
					
						
							|  |  |  | 	suite.Equal("image/jpeg", attachment.File.ContentType) | 
					
						
							|  |  |  | 	suite.Equal("image/jpeg", attachment.Thumbnail.ContentType) | 
					
						
							|  |  |  | 	suite.Equal(269739, attachment.File.FileSize) | 
					
						
							|  |  |  | 	suite.Equal("LiBzRk#6V[WF_NvzV@WY_3rqV@a$", attachment.Blurhash) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// now make sure the attachment is in the database | 
					
						
							|  |  |  | 	dbAttachment, err := suite.db.GetAttachmentByID(ctx, attachmentID) | 
					
						
							|  |  |  | 	suite.NoError(err) | 
					
						
							|  |  |  | 	suite.NotNil(dbAttachment) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// make sure the processed file is in storage | 
					
						
							|  |  |  | 	processedFullBytes, err := suite.storage.Get(ctx, attachment.File.Path) | 
					
						
							|  |  |  | 	suite.NoError(err) | 
					
						
							|  |  |  | 	suite.NotEmpty(processedFullBytes) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// load the processed bytes from our test folder, to compare | 
					
						
							|  |  |  | 	processedFullBytesExpected, err := os.ReadFile("./test/test-jpeg-processed.jpg") | 
					
						
							|  |  |  | 	suite.NoError(err) | 
					
						
							|  |  |  | 	suite.NotEmpty(processedFullBytesExpected) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// the bytes in storage should be what we expected | 
					
						
							|  |  |  | 	suite.Equal(processedFullBytesExpected, processedFullBytes) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// now do the same for the thumbnail and make sure it's what we expected | 
					
						
							|  |  |  | 	processedThumbnailBytes, err := suite.storage.Get(ctx, attachment.Thumbnail.Path) | 
					
						
							|  |  |  | 	suite.NoError(err) | 
					
						
							|  |  |  | 	suite.NotEmpty(processedThumbnailBytes) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	processedThumbnailBytesExpected, err := os.ReadFile("./test/test-jpeg-thumbnail.jpg") | 
					
						
							|  |  |  | 	suite.NoError(err) | 
					
						
							|  |  |  | 	suite.NotEmpty(processedThumbnailBytesExpected) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	suite.Equal(processedThumbnailBytesExpected, processedThumbnailBytes) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func (suite *ManagerTestSuite) TestSimpleJpegProcessBlockingReadCloser() { | 
					
						
							|  |  |  | 	ctx := context.Background() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	data := func(_ context.Context) (io.Reader, int, error) { | 
					
						
							|  |  |  | 		// open test image as a file | 
					
						
							|  |  |  | 		f, err := os.Open("./test/test-jpeg.jpg") | 
					
						
							|  |  |  | 		if err != nil { | 
					
						
							|  |  |  | 			panic(err) | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		// give length as -1 to indicate unknown | 
					
						
							|  |  |  | 		return f, -1, nil | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	accountID := "01FS1X72SK9ZPW0J1QQ68BD264" | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// process the media with no additional info provided | 
					
						
							|  |  |  | 	processingMedia, err := suite.manager.ProcessMedia(ctx, data, nil, accountID, nil) | 
					
						
							| 
									
										
										
										
											2022-01-10 18:36:09 +01:00
										 |  |  | 	suite.NoError(err) | 
					
						
							|  |  |  | 	// fetch the attachment id from the processing media | 
					
						
							|  |  |  | 	attachmentID := processingMedia.AttachmentID() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// do a blocking call to fetch the attachment | 
					
						
							| 
									
										
										
										
											2022-01-11 17:49:14 +01:00
										 |  |  | 	attachment, err := processingMedia.LoadAttachment(ctx) | 
					
						
							| 
									
										
										
										
											2022-01-10 18:36:09 +01:00
										 |  |  | 	suite.NoError(err) | 
					
						
							|  |  |  | 	suite.NotNil(attachment) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// make sure it's got the stuff set on it that we expect | 
					
						
							|  |  |  | 	// the attachment ID and accountID we expect | 
					
						
							|  |  |  | 	suite.Equal(attachmentID, attachment.ID) | 
					
						
							|  |  |  | 	suite.Equal(accountID, attachment.AccountID) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// file meta should be correctly derived from the image | 
					
						
							|  |  |  | 	suite.EqualValues(gtsmodel.Original{ | 
					
						
							|  |  |  | 		Width: 1920, Height: 1080, Size: 2073600, Aspect: 1.7777777777777777, | 
					
						
							|  |  |  | 	}, attachment.FileMeta.Original) | 
					
						
							|  |  |  | 	suite.EqualValues(gtsmodel.Small{ | 
					
						
							|  |  |  | 		Width: 512, Height: 288, Size: 147456, Aspect: 1.7777777777777777, | 
					
						
							|  |  |  | 	}, attachment.FileMeta.Small) | 
					
						
							|  |  |  | 	suite.Equal("image/jpeg", attachment.File.ContentType) | 
					
						
							| 
									
										
										
										
											2022-02-21 11:26:26 +01:00
										 |  |  | 	suite.Equal("image/jpeg", attachment.Thumbnail.ContentType) | 
					
						
							| 
									
										
										
										
											2022-01-23 15:52:18 +01:00
										 |  |  | 	suite.Equal(269739, attachment.File.FileSize) | 
					
						
							| 
									
										
										
										
											2022-08-10 14:05:14 +02:00
										 |  |  | 	suite.Equal("LiBzRk#6V[WF_NvzV@WY_3rqV@a$", attachment.Blurhash) | 
					
						
							| 
									
										
										
										
											2022-01-10 18:36:09 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	// now make sure the attachment is in the database | 
					
						
							|  |  |  | 	dbAttachment, err := suite.db.GetAttachmentByID(ctx, attachmentID) | 
					
						
							|  |  |  | 	suite.NoError(err) | 
					
						
							|  |  |  | 	suite.NotNil(dbAttachment) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// make sure the processed file is in storage | 
					
						
							| 
									
										
										
										
											2022-07-03 12:08:30 +02:00
										 |  |  | 	processedFullBytes, err := suite.storage.Get(ctx, attachment.File.Path) | 
					
						
							| 
									
										
										
										
											2022-01-10 18:36:09 +01:00
										 |  |  | 	suite.NoError(err) | 
					
						
							|  |  |  | 	suite.NotEmpty(processedFullBytes) | 
					
						
							| 
									
										
										
										
											2022-01-09 18:41:22 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-01-10 18:36:09 +01:00
										 |  |  | 	// load the processed bytes from our test folder, to compare | 
					
						
							|  |  |  | 	processedFullBytesExpected, err := os.ReadFile("./test/test-jpeg-processed.jpg") | 
					
						
							|  |  |  | 	suite.NoError(err) | 
					
						
							|  |  |  | 	suite.NotEmpty(processedFullBytesExpected) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// the bytes in storage should be what we expected | 
					
						
							|  |  |  | 	suite.Equal(processedFullBytesExpected, processedFullBytes) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// now do the same for the thumbnail and make sure it's what we expected | 
					
						
							| 
									
										
										
										
											2022-07-03 12:08:30 +02:00
										 |  |  | 	processedThumbnailBytes, err := suite.storage.Get(ctx, attachment.Thumbnail.Path) | 
					
						
							| 
									
										
										
										
											2022-01-10 18:36:09 +01:00
										 |  |  | 	suite.NoError(err) | 
					
						
							|  |  |  | 	suite.NotEmpty(processedThumbnailBytes) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	processedThumbnailBytesExpected, err := os.ReadFile("./test/test-jpeg-thumbnail.jpg") | 
					
						
							|  |  |  | 	suite.NoError(err) | 
					
						
							|  |  |  | 	suite.NotEmpty(processedThumbnailBytesExpected) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	suite.Equal(processedThumbnailBytesExpected, processedThumbnailBytes) | 
					
						
							| 
									
										
										
										
											2022-01-09 18:41:22 +01:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-04-25 14:45:44 +02:00
										 |  |  | func (suite *ManagerTestSuite) TestPngNoAlphaChannelProcessBlocking() { | 
					
						
							|  |  |  | 	ctx := context.Background() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	data := func(_ context.Context) (io.Reader, int, error) { | 
					
						
							|  |  |  | 		// load bytes from a test image | 
					
						
							|  |  |  | 		b, err := os.ReadFile("./test/test-png-noalphachannel.png") | 
					
						
							|  |  |  | 		if err != nil { | 
					
						
							|  |  |  | 			panic(err) | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		return bytes.NewBuffer(b), len(b), nil | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	accountID := "01FS1X72SK9ZPW0J1QQ68BD264" | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// process the media with no additional info provided | 
					
						
							|  |  |  | 	processingMedia, err := suite.manager.ProcessMedia(ctx, data, nil, accountID, nil) | 
					
						
							|  |  |  | 	suite.NoError(err) | 
					
						
							|  |  |  | 	// fetch the attachment id from the processing media | 
					
						
							|  |  |  | 	attachmentID := processingMedia.AttachmentID() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// do a blocking call to fetch the attachment | 
					
						
							|  |  |  | 	attachment, err := processingMedia.LoadAttachment(ctx) | 
					
						
							|  |  |  | 	suite.NoError(err) | 
					
						
							|  |  |  | 	suite.NotNil(attachment) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// make sure it's got the stuff set on it that we expect | 
					
						
							|  |  |  | 	// the attachment ID and accountID we expect | 
					
						
							|  |  |  | 	suite.Equal(attachmentID, attachment.ID) | 
					
						
							|  |  |  | 	suite.Equal(accountID, attachment.AccountID) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// file meta should be correctly derived from the image | 
					
						
							|  |  |  | 	suite.EqualValues(gtsmodel.Original{ | 
					
						
							|  |  |  | 		Width: 186, Height: 187, Size: 34782, Aspect: 0.9946524064171123, | 
					
						
							|  |  |  | 	}, attachment.FileMeta.Original) | 
					
						
							|  |  |  | 	suite.EqualValues(gtsmodel.Small{ | 
					
						
							|  |  |  | 		Width: 186, Height: 187, Size: 34782, Aspect: 0.9946524064171123, | 
					
						
							|  |  |  | 	}, attachment.FileMeta.Small) | 
					
						
							|  |  |  | 	suite.Equal("image/png", attachment.File.ContentType) | 
					
						
							|  |  |  | 	suite.Equal("image/jpeg", attachment.Thumbnail.ContentType) | 
					
						
							|  |  |  | 	suite.Equal(17471, attachment.File.FileSize) | 
					
						
							| 
									
										
										
										
											2022-08-10 14:05:14 +02:00
										 |  |  | 	suite.Equal("LFQT7e.A%O%4?co$M}M{_1W9~TxV", attachment.Blurhash) | 
					
						
							| 
									
										
										
										
											2022-04-25 14:45:44 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	// now make sure the attachment is in the database | 
					
						
							|  |  |  | 	dbAttachment, err := suite.db.GetAttachmentByID(ctx, attachmentID) | 
					
						
							|  |  |  | 	suite.NoError(err) | 
					
						
							|  |  |  | 	suite.NotNil(dbAttachment) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// make sure the processed file is in storage | 
					
						
							| 
									
										
										
										
											2022-07-03 12:08:30 +02:00
										 |  |  | 	processedFullBytes, err := suite.storage.Get(ctx, attachment.File.Path) | 
					
						
							| 
									
										
										
										
											2022-04-25 14:45:44 +02:00
										 |  |  | 	suite.NoError(err) | 
					
						
							|  |  |  | 	suite.NotEmpty(processedFullBytes) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// load the processed bytes from our test folder, to compare | 
					
						
							|  |  |  | 	processedFullBytesExpected, err := os.ReadFile("./test/test-png-noalphachannel-processed.png") | 
					
						
							|  |  |  | 	suite.NoError(err) | 
					
						
							|  |  |  | 	suite.NotEmpty(processedFullBytesExpected) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// the bytes in storage should be what we expected | 
					
						
							|  |  |  | 	suite.Equal(processedFullBytesExpected, processedFullBytes) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// now do the same for the thumbnail and make sure it's what we expected | 
					
						
							| 
									
										
										
										
											2022-07-03 12:08:30 +02:00
										 |  |  | 	processedThumbnailBytes, err := suite.storage.Get(ctx, attachment.Thumbnail.Path) | 
					
						
							| 
									
										
										
										
											2022-04-25 14:45:44 +02:00
										 |  |  | 	suite.NoError(err) | 
					
						
							|  |  |  | 	suite.NotEmpty(processedThumbnailBytes) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	processedThumbnailBytesExpected, err := os.ReadFile("./test/test-png-noalphachannel-thumbnail.jpg") | 
					
						
							|  |  |  | 	suite.NoError(err) | 
					
						
							|  |  |  | 	suite.NotEmpty(processedThumbnailBytesExpected) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	suite.Equal(processedThumbnailBytesExpected, processedThumbnailBytes) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func (suite *ManagerTestSuite) TestPngAlphaChannelProcessBlocking() { | 
					
						
							|  |  |  | 	ctx := context.Background() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	data := func(_ context.Context) (io.Reader, int, error) { | 
					
						
							|  |  |  | 		// load bytes from a test image | 
					
						
							|  |  |  | 		b, err := os.ReadFile("./test/test-png-alphachannel.png") | 
					
						
							|  |  |  | 		if err != nil { | 
					
						
							|  |  |  | 			panic(err) | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		return bytes.NewBuffer(b), len(b), nil | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	accountID := "01FS1X72SK9ZPW0J1QQ68BD264" | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// process the media with no additional info provided | 
					
						
							|  |  |  | 	processingMedia, err := suite.manager.ProcessMedia(ctx, data, nil, accountID, nil) | 
					
						
							|  |  |  | 	suite.NoError(err) | 
					
						
							|  |  |  | 	// fetch the attachment id from the processing media | 
					
						
							|  |  |  | 	attachmentID := processingMedia.AttachmentID() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// do a blocking call to fetch the attachment | 
					
						
							|  |  |  | 	attachment, err := processingMedia.LoadAttachment(ctx) | 
					
						
							|  |  |  | 	suite.NoError(err) | 
					
						
							|  |  |  | 	suite.NotNil(attachment) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// make sure it's got the stuff set on it that we expect | 
					
						
							|  |  |  | 	// the attachment ID and accountID we expect | 
					
						
							|  |  |  | 	suite.Equal(attachmentID, attachment.ID) | 
					
						
							|  |  |  | 	suite.Equal(accountID, attachment.AccountID) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// file meta should be correctly derived from the image | 
					
						
							|  |  |  | 	suite.EqualValues(gtsmodel.Original{ | 
					
						
							|  |  |  | 		Width: 186, Height: 187, Size: 34782, Aspect: 0.9946524064171123, | 
					
						
							|  |  |  | 	}, attachment.FileMeta.Original) | 
					
						
							|  |  |  | 	suite.EqualValues(gtsmodel.Small{ | 
					
						
							|  |  |  | 		Width: 186, Height: 187, Size: 34782, Aspect: 0.9946524064171123, | 
					
						
							|  |  |  | 	}, attachment.FileMeta.Small) | 
					
						
							|  |  |  | 	suite.Equal("image/png", attachment.File.ContentType) | 
					
						
							|  |  |  | 	suite.Equal("image/jpeg", attachment.Thumbnail.ContentType) | 
					
						
							|  |  |  | 	suite.Equal(18904, attachment.File.FileSize) | 
					
						
							| 
									
										
										
										
											2022-08-10 14:05:14 +02:00
										 |  |  | 	suite.Equal("LFQT7e.A%O%4?co$M}M{_1W9~TxV", attachment.Blurhash) | 
					
						
							| 
									
										
										
										
											2022-04-25 14:45:44 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	// now make sure the attachment is in the database | 
					
						
							|  |  |  | 	dbAttachment, err := suite.db.GetAttachmentByID(ctx, attachmentID) | 
					
						
							|  |  |  | 	suite.NoError(err) | 
					
						
							|  |  |  | 	suite.NotNil(dbAttachment) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// make sure the processed file is in storage | 
					
						
							| 
									
										
										
										
											2022-07-03 12:08:30 +02:00
										 |  |  | 	processedFullBytes, err := suite.storage.Get(ctx, attachment.File.Path) | 
					
						
							| 
									
										
										
										
											2022-04-25 14:45:44 +02:00
										 |  |  | 	suite.NoError(err) | 
					
						
							|  |  |  | 	suite.NotEmpty(processedFullBytes) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// load the processed bytes from our test folder, to compare | 
					
						
							|  |  |  | 	processedFullBytesExpected, err := os.ReadFile("./test/test-png-alphachannel-processed.png") | 
					
						
							|  |  |  | 	suite.NoError(err) | 
					
						
							|  |  |  | 	suite.NotEmpty(processedFullBytesExpected) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// the bytes in storage should be what we expected | 
					
						
							|  |  |  | 	suite.Equal(processedFullBytesExpected, processedFullBytes) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// now do the same for the thumbnail and make sure it's what we expected | 
					
						
							| 
									
										
										
										
											2022-07-03 12:08:30 +02:00
										 |  |  | 	processedThumbnailBytes, err := suite.storage.Get(ctx, attachment.Thumbnail.Path) | 
					
						
							| 
									
										
										
										
											2022-04-25 14:45:44 +02:00
										 |  |  | 	suite.NoError(err) | 
					
						
							|  |  |  | 	suite.NotEmpty(processedThumbnailBytes) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	processedThumbnailBytesExpected, err := os.ReadFile("./test/test-png-alphachannel-thumbnail.jpg") | 
					
						
							|  |  |  | 	suite.NoError(err) | 
					
						
							|  |  |  | 	suite.NotEmpty(processedThumbnailBytesExpected) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	suite.Equal(processedThumbnailBytesExpected, processedThumbnailBytes) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-02-22 13:50:33 +01:00
										 |  |  | func (suite *ManagerTestSuite) TestSimpleJpegProcessBlockingWithCallback() { | 
					
						
							|  |  |  | 	ctx := context.Background() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	data := func(_ context.Context) (io.Reader, int, error) { | 
					
						
							|  |  |  | 		// load bytes from a test image | 
					
						
							|  |  |  | 		b, err := os.ReadFile("./test/test-jpeg.jpg") | 
					
						
							|  |  |  | 		if err != nil { | 
					
						
							|  |  |  | 			panic(err) | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		return bytes.NewBuffer(b), len(b), nil | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// test the callback function by setting a simple boolean | 
					
						
							|  |  |  | 	var calledPostData bool | 
					
						
							|  |  |  | 	postData := func(_ context.Context) error { | 
					
						
							|  |  |  | 		calledPostData = true | 
					
						
							|  |  |  | 		return nil | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	suite.False(calledPostData) // not called yet (obvs) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	accountID := "01FS1X72SK9ZPW0J1QQ68BD264" | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// process the media with no additional info provided | 
					
						
							|  |  |  | 	processingMedia, err := suite.manager.ProcessMedia(ctx, data, postData, accountID, nil) | 
					
						
							|  |  |  | 	suite.NoError(err) | 
					
						
							|  |  |  | 	// fetch the attachment id from the processing media | 
					
						
							|  |  |  | 	attachmentID := processingMedia.AttachmentID() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// do a blocking call to fetch the attachment | 
					
						
							|  |  |  | 	attachment, err := processingMedia.LoadAttachment(ctx) | 
					
						
							|  |  |  | 	suite.NoError(err) | 
					
						
							|  |  |  | 	suite.NotNil(attachment) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// the post data callback should have been called | 
					
						
							|  |  |  | 	suite.True(calledPostData) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// make sure it's got the stuff set on it that we expect | 
					
						
							|  |  |  | 	// the attachment ID and accountID we expect | 
					
						
							|  |  |  | 	suite.Equal(attachmentID, attachment.ID) | 
					
						
							|  |  |  | 	suite.Equal(accountID, attachment.AccountID) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// file meta should be correctly derived from the image | 
					
						
							|  |  |  | 	suite.EqualValues(gtsmodel.Original{ | 
					
						
							|  |  |  | 		Width: 1920, Height: 1080, Size: 2073600, Aspect: 1.7777777777777777, | 
					
						
							|  |  |  | 	}, attachment.FileMeta.Original) | 
					
						
							|  |  |  | 	suite.EqualValues(gtsmodel.Small{ | 
					
						
							|  |  |  | 		Width: 512, Height: 288, Size: 147456, Aspect: 1.7777777777777777, | 
					
						
							|  |  |  | 	}, attachment.FileMeta.Small) | 
					
						
							|  |  |  | 	suite.Equal("image/jpeg", attachment.File.ContentType) | 
					
						
							|  |  |  | 	suite.Equal("image/jpeg", attachment.Thumbnail.ContentType) | 
					
						
							|  |  |  | 	suite.Equal(269739, attachment.File.FileSize) | 
					
						
							| 
									
										
										
										
											2022-08-10 14:05:14 +02:00
										 |  |  | 	suite.Equal("LiBzRk#6V[WF_NvzV@WY_3rqV@a$", attachment.Blurhash) | 
					
						
							| 
									
										
										
										
											2022-02-22 13:50:33 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	// now make sure the attachment is in the database | 
					
						
							|  |  |  | 	dbAttachment, err := suite.db.GetAttachmentByID(ctx, attachmentID) | 
					
						
							|  |  |  | 	suite.NoError(err) | 
					
						
							|  |  |  | 	suite.NotNil(dbAttachment) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// make sure the processed file is in storage | 
					
						
							| 
									
										
										
										
											2022-07-03 12:08:30 +02:00
										 |  |  | 	processedFullBytes, err := suite.storage.Get(ctx, attachment.File.Path) | 
					
						
							| 
									
										
										
										
											2022-02-22 13:50:33 +01:00
										 |  |  | 	suite.NoError(err) | 
					
						
							|  |  |  | 	suite.NotEmpty(processedFullBytes) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// load the processed bytes from our test folder, to compare | 
					
						
							|  |  |  | 	processedFullBytesExpected, err := os.ReadFile("./test/test-jpeg-processed.jpg") | 
					
						
							|  |  |  | 	suite.NoError(err) | 
					
						
							|  |  |  | 	suite.NotEmpty(processedFullBytesExpected) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// the bytes in storage should be what we expected | 
					
						
							|  |  |  | 	suite.Equal(processedFullBytesExpected, processedFullBytes) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// now do the same for the thumbnail and make sure it's what we expected | 
					
						
							| 
									
										
										
										
											2022-07-03 12:08:30 +02:00
										 |  |  | 	processedThumbnailBytes, err := suite.storage.Get(ctx, attachment.Thumbnail.Path) | 
					
						
							| 
									
										
										
										
											2022-02-22 13:50:33 +01:00
										 |  |  | 	suite.NoError(err) | 
					
						
							|  |  |  | 	suite.NotEmpty(processedThumbnailBytes) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	processedThumbnailBytesExpected, err := os.ReadFile("./test/test-jpeg-thumbnail.jpg") | 
					
						
							|  |  |  | 	suite.NoError(err) | 
					
						
							|  |  |  | 	suite.NotEmpty(processedThumbnailBytesExpected) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	suite.Equal(processedThumbnailBytesExpected, processedThumbnailBytes) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-01-10 18:36:09 +01:00
										 |  |  | func (suite *ManagerTestSuite) TestSimpleJpegProcessAsync() { | 
					
						
							|  |  |  | 	ctx := context.Background() | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-01-23 14:41:58 +01:00
										 |  |  | 	data := func(_ context.Context) (io.Reader, int, error) { | 
					
						
							| 
									
										
										
										
											2022-01-11 17:49:14 +01:00
										 |  |  | 		// load bytes from a test image | 
					
						
							| 
									
										
										
										
											2022-01-16 18:52:55 +01:00
										 |  |  | 		b, err := os.ReadFile("./test/test-jpeg.jpg") | 
					
						
							|  |  |  | 		if err != nil { | 
					
						
							|  |  |  | 			panic(err) | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2022-01-23 14:41:58 +01:00
										 |  |  | 		return bytes.NewBuffer(b), len(b), nil | 
					
						
							| 
									
										
										
										
											2022-01-11 17:49:14 +01:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2022-01-10 18:36:09 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	accountID := "01FS1X72SK9ZPW0J1QQ68BD264" | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// process the media with no additional info provided | 
					
						
							| 
									
										
										
										
											2022-02-22 13:50:33 +01:00
										 |  |  | 	processingMedia, err := suite.manager.ProcessMedia(ctx, data, nil, accountID, nil) | 
					
						
							| 
									
										
										
										
											2022-01-10 18:36:09 +01:00
										 |  |  | 	suite.NoError(err) | 
					
						
							|  |  |  | 	// fetch the attachment id from the processing media | 
					
						
							|  |  |  | 	attachmentID := processingMedia.AttachmentID() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// wait for the media to finish processing | 
					
						
							| 
									
										
										
										
											2022-08-31 17:31:21 +02:00
										 |  |  | 	if !testrig.WaitFor(func() bool { | 
					
						
							|  |  |  | 		return processingMedia.Finished() | 
					
						
							|  |  |  | 	}) { | 
					
						
							|  |  |  | 		suite.FailNow("timed out waiting for media to be processed") | 
					
						
							| 
									
										
										
										
											2022-01-10 18:36:09 +01:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// fetch the attachment from the database | 
					
						
							|  |  |  | 	attachment, err := suite.db.GetAttachmentByID(ctx, attachmentID) | 
					
						
							|  |  |  | 	suite.NoError(err) | 
					
						
							|  |  |  | 	suite.NotNil(attachment) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// make sure it's got the stuff set on it that we expect | 
					
						
							|  |  |  | 	// the attachment ID and accountID we expect | 
					
						
							|  |  |  | 	suite.Equal(attachmentID, attachment.ID) | 
					
						
							|  |  |  | 	suite.Equal(accountID, attachment.AccountID) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// file meta should be correctly derived from the image | 
					
						
							|  |  |  | 	suite.EqualValues(gtsmodel.Original{ | 
					
						
							|  |  |  | 		Width: 1920, Height: 1080, Size: 2073600, Aspect: 1.7777777777777777, | 
					
						
							|  |  |  | 	}, attachment.FileMeta.Original) | 
					
						
							|  |  |  | 	suite.EqualValues(gtsmodel.Small{ | 
					
						
							|  |  |  | 		Width: 512, Height: 288, Size: 147456, Aspect: 1.7777777777777777, | 
					
						
							|  |  |  | 	}, attachment.FileMeta.Small) | 
					
						
							|  |  |  | 	suite.Equal("image/jpeg", attachment.File.ContentType) | 
					
						
							| 
									
										
										
										
											2022-02-21 11:26:26 +01:00
										 |  |  | 	suite.Equal("image/jpeg", attachment.Thumbnail.ContentType) | 
					
						
							| 
									
										
										
										
											2022-01-23 15:52:18 +01:00
										 |  |  | 	suite.Equal(269739, attachment.File.FileSize) | 
					
						
							| 
									
										
										
										
											2022-08-10 14:05:14 +02:00
										 |  |  | 	suite.Equal("LiBzRk#6V[WF_NvzV@WY_3rqV@a$", attachment.Blurhash) | 
					
						
							| 
									
										
										
										
											2022-01-09 18:41:22 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-01-10 18:36:09 +01:00
										 |  |  | 	// now make sure the attachment is in the database | 
					
						
							|  |  |  | 	dbAttachment, err := suite.db.GetAttachmentByID(ctx, attachmentID) | 
					
						
							|  |  |  | 	suite.NoError(err) | 
					
						
							|  |  |  | 	suite.NotNil(dbAttachment) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// make sure the processed file is in storage | 
					
						
							| 
									
										
										
										
											2022-07-03 12:08:30 +02:00
										 |  |  | 	processedFullBytes, err := suite.storage.Get(ctx, attachment.File.Path) | 
					
						
							| 
									
										
										
										
											2022-01-10 18:36:09 +01:00
										 |  |  | 	suite.NoError(err) | 
					
						
							|  |  |  | 	suite.NotEmpty(processedFullBytes) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// load the processed bytes from our test folder, to compare | 
					
						
							|  |  |  | 	processedFullBytesExpected, err := os.ReadFile("./test/test-jpeg-processed.jpg") | 
					
						
							|  |  |  | 	suite.NoError(err) | 
					
						
							|  |  |  | 	suite.NotEmpty(processedFullBytesExpected) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// the bytes in storage should be what we expected | 
					
						
							|  |  |  | 	suite.Equal(processedFullBytesExpected, processedFullBytes) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// now do the same for the thumbnail and make sure it's what we expected | 
					
						
							| 
									
										
										
										
											2022-07-03 12:08:30 +02:00
										 |  |  | 	processedThumbnailBytes, err := suite.storage.Get(ctx, attachment.Thumbnail.Path) | 
					
						
							| 
									
										
										
										
											2022-01-10 18:36:09 +01:00
										 |  |  | 	suite.NoError(err) | 
					
						
							|  |  |  | 	suite.NotEmpty(processedThumbnailBytes) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	processedThumbnailBytesExpected, err := os.ReadFile("./test/test-jpeg-thumbnail.jpg") | 
					
						
							|  |  |  | 	suite.NoError(err) | 
					
						
							|  |  |  | 	suite.NotEmpty(processedThumbnailBytesExpected) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	suite.Equal(processedThumbnailBytesExpected, processedThumbnailBytes) | 
					
						
							| 
									
										
										
										
											2022-01-09 18:41:22 +01:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2022-01-08 17:17:01 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-01-10 18:36:09 +01:00
										 |  |  | func (suite *ManagerTestSuite) TestSimpleJpegQueueSpamming() { | 
					
						
							|  |  |  | 	// in this test, we spam the manager queue with 50 new media requests, just to see how it holds up | 
					
						
							|  |  |  | 	ctx := context.Background() | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-01-16 18:52:55 +01:00
										 |  |  | 	b, err := os.ReadFile("./test/test-jpeg.jpg") | 
					
						
							|  |  |  | 	if err != nil { | 
					
						
							|  |  |  | 		panic(err) | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2022-01-10 18:36:09 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-01-23 14:41:58 +01:00
										 |  |  | 	data := func(_ context.Context) (io.Reader, int, error) { | 
					
						
							| 
									
										
										
										
											2022-01-16 18:52:55 +01:00
										 |  |  | 		// load bytes from a test image | 
					
						
							| 
									
										
										
										
											2022-01-23 14:41:58 +01:00
										 |  |  | 		return bytes.NewReader(b), len(b), nil | 
					
						
							| 
									
										
										
										
											2022-01-11 17:49:14 +01:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-01-10 18:36:09 +01:00
										 |  |  | 	accountID := "01FS1X72SK9ZPW0J1QQ68BD264" | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	spam := 50 | 
					
						
							| 
									
										
										
										
											2022-01-11 17:49:14 +01:00
										 |  |  | 	inProcess := []*media.ProcessingMedia{} | 
					
						
							| 
									
										
										
										
											2022-01-10 18:36:09 +01:00
										 |  |  | 	for i := 0; i < spam; i++ { | 
					
						
							|  |  |  | 		// process the media with no additional info provided | 
					
						
							| 
									
										
										
										
											2022-02-22 13:50:33 +01:00
										 |  |  | 		processingMedia, err := suite.manager.ProcessMedia(ctx, data, nil, accountID, nil) | 
					
						
							| 
									
										
										
										
											2022-01-10 18:36:09 +01:00
										 |  |  | 		suite.NoError(err) | 
					
						
							|  |  |  | 		inProcess = append(inProcess, processingMedia) | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	for _, processingMedia := range inProcess { | 
					
						
							|  |  |  | 		// fetch the attachment id from the processing media | 
					
						
							|  |  |  | 		attachmentID := processingMedia.AttachmentID() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		// do a blocking call to fetch the attachment | 
					
						
							| 
									
										
										
										
											2022-01-11 17:49:14 +01:00
										 |  |  | 		attachment, err := processingMedia.LoadAttachment(ctx) | 
					
						
							| 
									
										
										
										
											2022-01-10 18:36:09 +01:00
										 |  |  | 		suite.NoError(err) | 
					
						
							|  |  |  | 		suite.NotNil(attachment) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		// make sure it's got the stuff set on it that we expect | 
					
						
							|  |  |  | 		// the attachment ID and accountID we expect | 
					
						
							|  |  |  | 		suite.Equal(attachmentID, attachment.ID) | 
					
						
							|  |  |  | 		suite.Equal(accountID, attachment.AccountID) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		// file meta should be correctly derived from the image | 
					
						
							|  |  |  | 		suite.EqualValues(gtsmodel.Original{ | 
					
						
							|  |  |  | 			Width: 1920, Height: 1080, Size: 2073600, Aspect: 1.7777777777777777, | 
					
						
							|  |  |  | 		}, attachment.FileMeta.Original) | 
					
						
							|  |  |  | 		suite.EqualValues(gtsmodel.Small{ | 
					
						
							|  |  |  | 			Width: 512, Height: 288, Size: 147456, Aspect: 1.7777777777777777, | 
					
						
							|  |  |  | 		}, attachment.FileMeta.Small) | 
					
						
							|  |  |  | 		suite.Equal("image/jpeg", attachment.File.ContentType) | 
					
						
							| 
									
										
										
										
											2022-02-21 11:26:26 +01:00
										 |  |  | 		suite.Equal("image/jpeg", attachment.Thumbnail.ContentType) | 
					
						
							| 
									
										
										
										
											2022-01-23 15:52:18 +01:00
										 |  |  | 		suite.Equal(269739, attachment.File.FileSize) | 
					
						
							| 
									
										
										
										
											2022-08-10 14:05:14 +02:00
										 |  |  | 		suite.Equal("LiBzRk#6V[WF_NvzV@WY_3rqV@a$", attachment.Blurhash) | 
					
						
							| 
									
										
										
										
											2022-01-10 18:36:09 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		// now make sure the attachment is in the database | 
					
						
							|  |  |  | 		dbAttachment, err := suite.db.GetAttachmentByID(ctx, attachmentID) | 
					
						
							|  |  |  | 		suite.NoError(err) | 
					
						
							|  |  |  | 		suite.NotNil(dbAttachment) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		// make sure the processed file is in storage | 
					
						
							| 
									
										
										
										
											2022-07-03 12:08:30 +02:00
										 |  |  | 		processedFullBytes, err := suite.storage.Get(ctx, attachment.File.Path) | 
					
						
							| 
									
										
										
										
											2022-01-10 18:36:09 +01:00
										 |  |  | 		suite.NoError(err) | 
					
						
							|  |  |  | 		suite.NotEmpty(processedFullBytes) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		// load the processed bytes from our test folder, to compare | 
					
						
							|  |  |  | 		processedFullBytesExpected, err := os.ReadFile("./test/test-jpeg-processed.jpg") | 
					
						
							|  |  |  | 		suite.NoError(err) | 
					
						
							|  |  |  | 		suite.NotEmpty(processedFullBytesExpected) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		// the bytes in storage should be what we expected | 
					
						
							|  |  |  | 		suite.Equal(processedFullBytesExpected, processedFullBytes) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		// now do the same for the thumbnail and make sure it's what we expected | 
					
						
							| 
									
										
										
										
											2022-07-03 12:08:30 +02:00
										 |  |  | 		processedThumbnailBytes, err := suite.storage.Get(ctx, attachment.Thumbnail.Path) | 
					
						
							| 
									
										
										
										
											2022-01-10 18:36:09 +01:00
										 |  |  | 		suite.NoError(err) | 
					
						
							|  |  |  | 		suite.NotEmpty(processedThumbnailBytes) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		processedThumbnailBytesExpected, err := os.ReadFile("./test/test-jpeg-thumbnail.jpg") | 
					
						
							|  |  |  | 		suite.NoError(err) | 
					
						
							|  |  |  | 		suite.NotEmpty(processedThumbnailBytesExpected) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		suite.Equal(processedThumbnailBytesExpected, processedThumbnailBytes) | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2022-01-09 18:41:22 +01:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2022-01-08 17:17:01 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-01-24 18:11:27 +01:00
										 |  |  | func (suite *ManagerTestSuite) TestSimpleJpegProcessBlockingWithDiskStorage() { | 
					
						
							|  |  |  | 	ctx := context.Background() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	data := func(_ context.Context) (io.Reader, int, error) { | 
					
						
							|  |  |  | 		// load bytes from a test image | 
					
						
							|  |  |  | 		b, err := os.ReadFile("./test/test-jpeg.jpg") | 
					
						
							|  |  |  | 		if err != nil { | 
					
						
							|  |  |  | 			panic(err) | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		return bytes.NewBuffer(b), len(b), nil | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	accountID := "01FS1X72SK9ZPW0J1QQ68BD264" | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-01-29 12:16:12 +01:00
										 |  |  | 	temp := fmt.Sprintf("%s/gotosocial-test", os.TempDir()) | 
					
						
							| 
									
										
										
										
											2022-01-24 18:11:27 +01:00
										 |  |  | 	defer os.RemoveAll(temp) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-01-29 12:16:12 +01:00
										 |  |  | 	diskStorage, err := kv.OpenFile(temp, &storage.DiskConfig{ | 
					
						
							|  |  |  | 		LockFile: path.Join(temp, "store.lock"), | 
					
						
							|  |  |  | 	}) | 
					
						
							| 
									
										
										
										
											2022-01-24 18:11:27 +01:00
										 |  |  | 	if err != nil { | 
					
						
							|  |  |  | 		panic(err) | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-07-03 12:08:30 +02:00
										 |  |  | 	diskManager, err := media.NewManager(suite.db, >sstorage.Local{KVStore: diskStorage}) | 
					
						
							| 
									
										
										
										
											2022-01-24 18:11:27 +01:00
										 |  |  | 	if err != nil { | 
					
						
							|  |  |  | 		panic(err) | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	suite.manager = diskManager | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// process the media with no additional info provided | 
					
						
							| 
									
										
										
										
											2022-02-22 13:50:33 +01:00
										 |  |  | 	processingMedia, err := diskManager.ProcessMedia(ctx, data, nil, accountID, nil) | 
					
						
							| 
									
										
										
										
											2022-01-24 18:11:27 +01:00
										 |  |  | 	suite.NoError(err) | 
					
						
							|  |  |  | 	// fetch the attachment id from the processing media | 
					
						
							|  |  |  | 	attachmentID := processingMedia.AttachmentID() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// do a blocking call to fetch the attachment | 
					
						
							|  |  |  | 	attachment, err := processingMedia.LoadAttachment(ctx) | 
					
						
							|  |  |  | 	suite.NoError(err) | 
					
						
							|  |  |  | 	suite.NotNil(attachment) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// make sure it's got the stuff set on it that we expect | 
					
						
							|  |  |  | 	// the attachment ID and accountID we expect | 
					
						
							|  |  |  | 	suite.Equal(attachmentID, attachment.ID) | 
					
						
							|  |  |  | 	suite.Equal(accountID, attachment.AccountID) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// file meta should be correctly derived from the image | 
					
						
							|  |  |  | 	suite.EqualValues(gtsmodel.Original{ | 
					
						
							|  |  |  | 		Width: 1920, Height: 1080, Size: 2073600, Aspect: 1.7777777777777777, | 
					
						
							|  |  |  | 	}, attachment.FileMeta.Original) | 
					
						
							|  |  |  | 	suite.EqualValues(gtsmodel.Small{ | 
					
						
							|  |  |  | 		Width: 512, Height: 288, Size: 147456, Aspect: 1.7777777777777777, | 
					
						
							|  |  |  | 	}, attachment.FileMeta.Small) | 
					
						
							|  |  |  | 	suite.Equal("image/jpeg", attachment.File.ContentType) | 
					
						
							| 
									
										
										
										
											2022-02-21 11:26:26 +01:00
										 |  |  | 	suite.Equal("image/jpeg", attachment.Thumbnail.ContentType) | 
					
						
							| 
									
										
										
										
											2022-01-24 18:11:27 +01:00
										 |  |  | 	suite.Equal(269739, attachment.File.FileSize) | 
					
						
							| 
									
										
										
										
											2022-08-10 14:05:14 +02:00
										 |  |  | 	suite.Equal("LiBzRk#6V[WF_NvzV@WY_3rqV@a$", attachment.Blurhash) | 
					
						
							| 
									
										
										
										
											2022-01-24 18:11:27 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	// now make sure the attachment is in the database | 
					
						
							|  |  |  | 	dbAttachment, err := suite.db.GetAttachmentByID(ctx, attachmentID) | 
					
						
							|  |  |  | 	suite.NoError(err) | 
					
						
							|  |  |  | 	suite.NotNil(dbAttachment) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// make sure the processed file is in storage | 
					
						
							|  |  |  | 	processedFullBytes, err := diskStorage.Get(attachment.File.Path) | 
					
						
							|  |  |  | 	suite.NoError(err) | 
					
						
							|  |  |  | 	suite.NotEmpty(processedFullBytes) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// load the processed bytes from our test folder, to compare | 
					
						
							|  |  |  | 	processedFullBytesExpected, err := os.ReadFile("./test/test-jpeg-processed.jpg") | 
					
						
							|  |  |  | 	suite.NoError(err) | 
					
						
							|  |  |  | 	suite.NotEmpty(processedFullBytesExpected) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// the bytes in storage should be what we expected | 
					
						
							|  |  |  | 	suite.Equal(processedFullBytesExpected, processedFullBytes) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// now do the same for the thumbnail and make sure it's what we expected | 
					
						
							|  |  |  | 	processedThumbnailBytes, err := diskStorage.Get(attachment.Thumbnail.Path) | 
					
						
							|  |  |  | 	suite.NoError(err) | 
					
						
							|  |  |  | 	suite.NotEmpty(processedThumbnailBytes) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	processedThumbnailBytesExpected, err := os.ReadFile("./test/test-jpeg-thumbnail.jpg") | 
					
						
							|  |  |  | 	suite.NoError(err) | 
					
						
							|  |  |  | 	suite.NotEmpty(processedThumbnailBytesExpected) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	suite.Equal(processedThumbnailBytesExpected, processedThumbnailBytes) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-01-10 18:36:09 +01:00
										 |  |  | func TestManagerTestSuite(t *testing.T) { | 
					
						
							|  |  |  | 	suite.Run(t, &ManagerTestSuite{}) | 
					
						
							| 
									
										
										
										
											2022-01-09 18:41:22 +01:00
										 |  |  | } |