2022-01-09 17:41:22 +00: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 16:17:01 +00:00
|
|
|
package media_test
|
|
|
|
|
2022-01-09 17:41:22 +00:00
|
|
|
import (
|
2022-01-16 17:52:55 +00:00
|
|
|
"bytes"
|
2022-01-10 17:36:09 +00:00
|
|
|
"context"
|
|
|
|
"fmt"
|
2022-01-16 17:52:55 +00:00
|
|
|
"io"
|
2022-01-10 17:36:09 +00:00
|
|
|
"os"
|
2022-01-29 11:16:12 +00:00
|
|
|
"path"
|
2022-01-10 17:36:09 +00:00
|
|
|
"testing"
|
|
|
|
"time"
|
|
|
|
|
2022-01-24 17:11:27 +00:00
|
|
|
"codeberg.org/gruf/go-store/kv"
|
|
|
|
"codeberg.org/gruf/go-store/storage"
|
2022-01-09 17:41:22 +00:00
|
|
|
"github.com/stretchr/testify/suite"
|
2022-03-07 10:08:26 +00:00
|
|
|
gtsmodel "github.com/superseriousbusiness/gotosocial/internal/gtsmodel"
|
2022-01-09 17:41:22 +00:00
|
|
|
"github.com/superseriousbusiness/gotosocial/internal/media"
|
2022-07-03 10:08:30 +00:00
|
|
|
gtsstorage "github.com/superseriousbusiness/gotosocial/internal/storage"
|
2022-01-09 17:41:22 +00:00
|
|
|
)
|
|
|
|
|
2022-01-10 17:36:09 +00:00
|
|
|
type ManagerTestSuite struct {
|
|
|
|
MediaStandardTestSuite
|
|
|
|
}
|
|
|
|
|
|
|
|
func (suite *ManagerTestSuite) TestSimpleJpegProcessBlocking() {
|
|
|
|
ctx := context.Background()
|
|
|
|
|
2022-01-23 13:41:58 +00:00
|
|
|
data := func(_ context.Context) (io.Reader, int, error) {
|
2022-01-11 16:49:14 +00:00
|
|
|
// load bytes from a test image
|
2022-01-16 17:52:55 +00:00
|
|
|
b, err := os.ReadFile("./test/test-jpeg.jpg")
|
|
|
|
if err != nil {
|
|
|
|
panic(err)
|
|
|
|
}
|
2022-01-23 13:41:58 +00:00
|
|
|
return bytes.NewBuffer(b), len(b), nil
|
2022-01-11 16:49:14 +00:00
|
|
|
}
|
2022-01-10 17:36:09 +00:00
|
|
|
|
|
|
|
accountID := "01FS1X72SK9ZPW0J1QQ68BD264"
|
|
|
|
|
|
|
|
// process the media with no additional info provided
|
2022-02-22 12:50:33 +00:00
|
|
|
processingMedia, err := suite.manager.ProcessMedia(ctx, data, nil, accountID, nil)
|
2022-01-10 17:36:09 +00: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 16:49:14 +00:00
|
|
|
attachment, err := processingMedia.LoadAttachment(ctx)
|
2022-01-10 17:36:09 +00: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 10:26:26 +00:00
|
|
|
suite.Equal("image/jpeg", attachment.Thumbnail.ContentType)
|
2022-01-23 14:52:18 +00:00
|
|
|
suite.Equal(269739, attachment.File.FileSize)
|
2022-01-10 17:36:09 +00:00
|
|
|
suite.Equal("LjBzUo#6RQR._NvzRjWF?urqV@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
|
2022-07-03 10:08:30 +00:00
|
|
|
processedFullBytes, err := suite.storage.Get(ctx, attachment.File.Path)
|
2022-01-10 17:36:09 +00:00
|
|
|
suite.NoError(err)
|
|
|
|
suite.NotEmpty(processedFullBytes)
|
2022-01-09 17:41:22 +00:00
|
|
|
|
2022-01-10 17:36:09 +00: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 10:08:30 +00:00
|
|
|
processedThumbnailBytes, err := suite.storage.Get(ctx, attachment.Thumbnail.Path)
|
2022-01-10 17:36:09 +00: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 17:41:22 +00:00
|
|
|
}
|
|
|
|
|
2022-04-25 12:45:44 +00: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)
|
|
|
|
suite.Equal("LFP?{^.A-?xd.9o#RVRQ~oj:_0xW", 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
|
2022-07-03 10:08:30 +00:00
|
|
|
processedFullBytes, err := suite.storage.Get(ctx, attachment.File.Path)
|
2022-04-25 12:45:44 +00: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 10:08:30 +00:00
|
|
|
processedThumbnailBytes, err := suite.storage.Get(ctx, attachment.Thumbnail.Path)
|
2022-04-25 12:45:44 +00: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)
|
|
|
|
suite.Equal("LFP?{^.A-?xd.9o#RVRQ~oj:_0xW", 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
|
2022-07-03 10:08:30 +00:00
|
|
|
processedFullBytes, err := suite.storage.Get(ctx, attachment.File.Path)
|
2022-04-25 12:45:44 +00: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 10:08:30 +00:00
|
|
|
processedThumbnailBytes, err := suite.storage.Get(ctx, attachment.Thumbnail.Path)
|
2022-04-25 12:45:44 +00: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 12:50:33 +00: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)
|
|
|
|
suite.Equal("LjBzUo#6RQR._NvzRjWF?urqV@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
|
2022-07-03 10:08:30 +00:00
|
|
|
processedFullBytes, err := suite.storage.Get(ctx, attachment.File.Path)
|
2022-02-22 12:50:33 +00: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 10:08:30 +00:00
|
|
|
processedThumbnailBytes, err := suite.storage.Get(ctx, attachment.Thumbnail.Path)
|
2022-02-22 12:50:33 +00: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 17:36:09 +00:00
|
|
|
func (suite *ManagerTestSuite) TestSimpleJpegProcessAsync() {
|
|
|
|
ctx := context.Background()
|
|
|
|
|
2022-01-23 13:41:58 +00:00
|
|
|
data := func(_ context.Context) (io.Reader, int, error) {
|
2022-01-11 16:49:14 +00:00
|
|
|
// load bytes from a test image
|
2022-01-16 17:52:55 +00:00
|
|
|
b, err := os.ReadFile("./test/test-jpeg.jpg")
|
|
|
|
if err != nil {
|
|
|
|
panic(err)
|
|
|
|
}
|
2022-01-23 13:41:58 +00:00
|
|
|
return bytes.NewBuffer(b), len(b), nil
|
2022-01-11 16:49:14 +00:00
|
|
|
}
|
2022-01-10 17:36:09 +00:00
|
|
|
|
|
|
|
accountID := "01FS1X72SK9ZPW0J1QQ68BD264"
|
|
|
|
|
|
|
|
// process the media with no additional info provided
|
2022-02-22 12:50:33 +00:00
|
|
|
processingMedia, err := suite.manager.ProcessMedia(ctx, data, nil, accountID, nil)
|
2022-01-10 17:36:09 +00:00
|
|
|
suite.NoError(err)
|
|
|
|
// fetch the attachment id from the processing media
|
|
|
|
attachmentID := processingMedia.AttachmentID()
|
|
|
|
|
|
|
|
// wait for the media to finish processing
|
|
|
|
for finished := processingMedia.Finished(); !finished; finished = processingMedia.Finished() {
|
|
|
|
time.Sleep(10 * time.Millisecond)
|
|
|
|
fmt.Printf("\n\nnot finished yet...\n\n")
|
|
|
|
}
|
|
|
|
fmt.Printf("\n\nfinished!\n\n")
|
|
|
|
|
|
|
|
// 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 10:26:26 +00:00
|
|
|
suite.Equal("image/jpeg", attachment.Thumbnail.ContentType)
|
2022-01-23 14:52:18 +00:00
|
|
|
suite.Equal(269739, attachment.File.FileSize)
|
2022-01-10 17:36:09 +00:00
|
|
|
suite.Equal("LjBzUo#6RQR._NvzRjWF?urqV@a$", attachment.Blurhash)
|
2022-01-09 17:41:22 +00:00
|
|
|
|
2022-01-10 17:36:09 +00: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 10:08:30 +00:00
|
|
|
processedFullBytes, err := suite.storage.Get(ctx, attachment.File.Path)
|
2022-01-10 17:36:09 +00: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 10:08:30 +00:00
|
|
|
processedThumbnailBytes, err := suite.storage.Get(ctx, attachment.Thumbnail.Path)
|
2022-01-10 17:36:09 +00: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 17:41:22 +00:00
|
|
|
}
|
2022-01-08 16:17:01 +00:00
|
|
|
|
2022-01-10 17:36:09 +00: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 17:52:55 +00:00
|
|
|
b, err := os.ReadFile("./test/test-jpeg.jpg")
|
|
|
|
if err != nil {
|
|
|
|
panic(err)
|
|
|
|
}
|
2022-01-10 17:36:09 +00:00
|
|
|
|
2022-01-23 13:41:58 +00:00
|
|
|
data := func(_ context.Context) (io.Reader, int, error) {
|
2022-01-16 17:52:55 +00:00
|
|
|
// load bytes from a test image
|
2022-01-23 13:41:58 +00:00
|
|
|
return bytes.NewReader(b), len(b), nil
|
2022-01-11 16:49:14 +00:00
|
|
|
}
|
|
|
|
|
2022-01-10 17:36:09 +00:00
|
|
|
accountID := "01FS1X72SK9ZPW0J1QQ68BD264"
|
|
|
|
|
|
|
|
spam := 50
|
2022-01-11 16:49:14 +00:00
|
|
|
inProcess := []*media.ProcessingMedia{}
|
2022-01-10 17:36:09 +00:00
|
|
|
for i := 0; i < spam; i++ {
|
|
|
|
// process the media with no additional info provided
|
2022-02-22 12:50:33 +00:00
|
|
|
processingMedia, err := suite.manager.ProcessMedia(ctx, data, nil, accountID, nil)
|
2022-01-10 17:36:09 +00: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 16:49:14 +00:00
|
|
|
attachment, err := processingMedia.LoadAttachment(ctx)
|
2022-01-10 17:36:09 +00: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 10:26:26 +00:00
|
|
|
suite.Equal("image/jpeg", attachment.Thumbnail.ContentType)
|
2022-01-23 14:52:18 +00:00
|
|
|
suite.Equal(269739, attachment.File.FileSize)
|
2022-01-10 17:36:09 +00:00
|
|
|
suite.Equal("LjBzUo#6RQR._NvzRjWF?urqV@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
|
2022-07-03 10:08:30 +00:00
|
|
|
processedFullBytes, err := suite.storage.Get(ctx, attachment.File.Path)
|
2022-01-10 17:36:09 +00: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 10:08:30 +00:00
|
|
|
processedThumbnailBytes, err := suite.storage.Get(ctx, attachment.Thumbnail.Path)
|
2022-01-10 17:36:09 +00: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 17:41:22 +00:00
|
|
|
}
|
2022-01-08 16:17:01 +00:00
|
|
|
|
2022-01-24 17:11:27 +00: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 11:16:12 +00:00
|
|
|
temp := fmt.Sprintf("%s/gotosocial-test", os.TempDir())
|
2022-01-24 17:11:27 +00:00
|
|
|
defer os.RemoveAll(temp)
|
|
|
|
|
2022-01-29 11:16:12 +00:00
|
|
|
diskStorage, err := kv.OpenFile(temp, &storage.DiskConfig{
|
|
|
|
LockFile: path.Join(temp, "store.lock"),
|
|
|
|
})
|
2022-01-24 17:11:27 +00:00
|
|
|
if err != nil {
|
|
|
|
panic(err)
|
|
|
|
}
|
|
|
|
|
2022-07-03 10:08:30 +00:00
|
|
|
diskManager, err := media.NewManager(suite.db, >sstorage.Local{KVStore: diskStorage})
|
2022-01-24 17:11:27 +00:00
|
|
|
if err != nil {
|
|
|
|
panic(err)
|
|
|
|
}
|
|
|
|
suite.manager = diskManager
|
|
|
|
|
|
|
|
// process the media with no additional info provided
|
2022-02-22 12:50:33 +00:00
|
|
|
processingMedia, err := diskManager.ProcessMedia(ctx, data, nil, accountID, nil)
|
2022-01-24 17:11:27 +00: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 10:26:26 +00:00
|
|
|
suite.Equal("image/jpeg", attachment.Thumbnail.ContentType)
|
2022-01-24 17:11:27 +00:00
|
|
|
suite.Equal(269739, attachment.File.FileSize)
|
|
|
|
suite.Equal("LjBzUo#6RQR._NvzRjWF?urqV@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 := 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 17:36:09 +00:00
|
|
|
func TestManagerTestSuite(t *testing.T) {
|
|
|
|
suite.Run(t, &ManagerTestSuite{})
|
2022-01-09 17:41:22 +00:00
|
|
|
}
|