mattermost-community-enterp.../channels/app/imaging/orientation_test.go
Claude ec1f89217a Merge: Complete Mattermost Server with Community Enterprise
Full Mattermost server source with integrated Community Enterprise features.
Includes vendor directory for offline/air-gapped builds.

Structure:
- enterprise-impl/: Enterprise feature implementations
- enterprise-community/: Init files that register implementations
- enterprise/: Bridge imports (community_imports.go)
- vendor/: All dependencies for offline builds

Build (online):
  go build ./cmd/mattermost

Build (offline/air-gapped):
  go build -mod=vendor ./cmd/mattermost

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
2025-12-17 23:59:07 +09:00

200 lines
5.4 KiB
Go

// Copyright (c) 2015-present Mattermost, Inc. All Rights Reserved.
// See LICENSE.txt for license information.
package imaging
import (
"bytes"
"fmt"
"io"
"os"
"path/filepath"
"testing"
"github.com/mattermost/mattermost/server/v8/channels/utils/fileutils"
"github.com/stretchr/testify/require"
)
func TestFwSeeker(t *testing.T) {
t.Run("Read", func(t *testing.T) {
data := []byte("hello world")
reader := bytes.NewReader(data)
seeker := &fwSeeker{r: reader}
// Read the first 5 bytes
buf := make([]byte, 5)
n, err := seeker.Read(buf)
require.NoError(t, err)
require.Equal(t, 5, n)
require.Equal(t, []byte("hello"), buf)
// Read the next 6 bytes
buf = make([]byte, 6)
n, err = seeker.Read(buf)
require.NoError(t, err)
require.Equal(t, 6, n)
require.Equal(t, []byte(" world"), buf)
// Try to read more, should get EOF
buf = make([]byte, 1)
n, err = seeker.Read(buf)
require.Equal(t, 0, n)
require.Equal(t, io.EOF, err)
})
t.Run("Seek forward from start", func(t *testing.T) {
data := []byte("hello world")
reader := bytes.NewReader(data)
seeker := &fwSeeker{r: reader}
// Seek forward 6 bytes
pos, err := seeker.Seek(6, io.SeekStart)
require.NoError(t, err)
require.Equal(t, int64(6), pos)
// Seeking from the same position should work
pos, err = seeker.Seek(6, io.SeekStart)
require.NoError(t, err)
require.Equal(t, int64(6), pos)
// Seeking again from start should work.
pos, err = seeker.Seek(7, io.SeekStart)
require.NoError(t, err)
require.Equal(t, int64(7), pos)
// Seeking backwards should not be supported
_, err = seeker.Seek(6, io.SeekStart)
require.EqualError(t, err, "seeking backwards is not supported")
// Read the remaining data
buf := make([]byte, 4)
n, err := seeker.Read(buf)
require.NoError(t, err)
require.Equal(t, 4, n)
require.Equal(t, []byte("orld"), buf)
})
t.Run("Seek forward from current", func(t *testing.T) {
data := []byte("hello world")
reader := bytes.NewReader(data)
seeker := &fwSeeker{r: reader}
// Read first 6 bytes
buf := make([]byte, 6)
n, err := seeker.Read(buf)
require.NoError(t, err)
require.Equal(t, 6, n)
require.Equal(t, []byte("hello "), buf)
// Seek forward 2 more bytes from current position
pos, err := seeker.Seek(2, io.SeekCurrent)
require.NoError(t, err)
require.Equal(t, int64(8), pos)
// Read the remaining data
buf = make([]byte, 3)
n, err = seeker.Read(buf)
require.NoError(t, err)
require.Equal(t, 3, n)
require.Equal(t, []byte("rld"), buf)
})
t.Run("Seek backward not supported", func(t *testing.T) {
data := []byte("hello world")
reader := bytes.NewReader(data)
seeker := &fwSeeker{r: reader}
// Try to seek backward
_, err := seeker.Seek(-1, io.SeekCurrent)
require.EqualError(t, err, "seeking backwards is not supported")
// Try to seek from end
_, err = seeker.Seek(0, io.SeekEnd)
require.EqualError(t, err, "seeking backwards is not supported")
})
t.Run("Seek beyond EOF", func(t *testing.T) {
data := []byte("hello")
reader := bytes.NewReader(data)
seeker := &fwSeeker{r: reader}
// Try to seek beyond EOF
n, err := seeker.Seek(10, io.SeekStart)
require.EqualError(t, err, "failed to seek: EOF")
require.Equal(t, int64(5), n) // Should have read until EOF (5 bytes)
})
}
func TestGetImageOrientation(t *testing.T) {
imgDir, ok := fileutils.FindDir("tests/exif_samples")
require.True(t, ok, "Failed to find exif samples directory")
// Define orientations and their corresponding file prefixes
orientations := map[string]int{
"up": Upright,
"up-mirrored": UprightMirrored,
"down": UpsideDown,
"down-mirrored": UpsideDownMirrored,
"left": RotatedCCW,
"left-mirrored": RotatedCWMirrored,
"right": RotatedCW,
"right-mirrored": RotatedCCWMirrored,
}
// Define supported formats
formats := []string{"jpg", "png", "tiff", "webp"}
// Generate test cases for all combinations
var testCases []struct {
name string
fileName string
expectedOrientation int
}
for prefix, orientation := range orientations {
for _, format := range formats {
testCases = append(testCases, struct {
name string
fileName string
expectedOrientation int
}{
name: fmt.Sprintf("%s (%s)", prefix, format),
fileName: fmt.Sprintf("%s.%s", prefix, format),
expectedOrientation: orientation,
})
}
}
dec, err := NewDecoder(DecoderOptions{})
require.NoError(t, err)
for _, tc := range testCases {
var orientation int
imgPath := filepath.Join(imgDir, tc.fileName)
file, err := os.Open(imgPath)
require.NoError(t, err)
defer file.Close()
_, format, err := dec.DecodeConfig(file)
require.NoError(t, err)
t.Run(tc.name+"_file", func(t *testing.T) {
_, err = file.Seek(0, io.SeekStart)
require.NoError(t, err)
orientation, err = GetImageOrientation(file, format)
require.NoError(t, err)
require.Equal(t, tc.expectedOrientation, orientation, "Incorrect orientation detected for %s", tc.fileName)
})
t.Run(tc.name+"_reader", func(t *testing.T) {
_, err = file.Seek(0, io.SeekStart)
require.NoError(t, err)
orientation, err = GetImageOrientation(&io.LimitedReader{R: file, N: 1024 * 1024}, format)
require.NoError(t, err)
require.Equal(t, tc.expectedOrientation, orientation, "Incorrect orientation detected for %s", tc.fileName)
})
}
}