photoprism/internal/query/files_test.go

290 lines
6 KiB
Go
Raw Normal View History

2020-01-28 20:59:26 +01:00
package query
import (
"testing"
"time"
2020-01-28 20:59:26 +01:00
"github.com/photoprism/photoprism/internal/entity"
"github.com/stretchr/testify/assert"
2020-01-28 20:59:26 +01:00
)
func TestFilesByPath(t *testing.T) {
t.Run("Holiday", func(t *testing.T) {
files, err := FilesByPath(10, 0, entity.RootOriginals, "Holiday", false)
t.Logf("files: %+v", files)
if err != nil {
t.Fatal(err)
}
assert.LessOrEqual(t, 1, len(files))
})
t.Run("SlashHoliday", func(t *testing.T) {
files, err := FilesByPath(10, 0, entity.RootOriginals, "/Holiday", false)
t.Logf("files: %+v", files)
if err != nil {
t.Fatal(err)
}
assert.LessOrEqual(t, 1, len(files))
})
t.Run("2790Public", func(t *testing.T) {
files, err := FilesByPath(10, 0, entity.RootOriginals, "2790/07", true)
t.Logf("files: %+v", files)
if err != nil {
t.Fatal(err)
}
assert.LessOrEqual(t, 1, len(files))
})
t.Run("HolidayPublic", func(t *testing.T) {
files, err := FilesByPath(10, 0, entity.RootOriginals, "Holiday", true)
t.Logf("files: %+v", files)
if err != nil {
t.Fatal(err)
}
assert.LessOrEqual(t, 1, len(files))
})
}
func TestExistingFiles(t *testing.T) {
2020-01-28 20:59:26 +01:00
t.Run("files found", func(t *testing.T) {
files, err := Files(1000, 0, "/", true)
t.Logf("files: %+v", files)
2020-01-28 20:59:26 +01:00
2020-05-13 10:16:12 +02:00
if err != nil {
t.Fatal(err)
}
assert.LessOrEqual(t, 5, len(files))
2020-01-28 20:59:26 +01:00
})
t.Run("files found - includeMissing false", func(t *testing.T) {
files, err := Files(1000, 0, "/", false)
t.Logf("files: %+v", files)
if err != nil {
t.Fatal(err)
}
assert.LessOrEqual(t, 5, len(files))
})
2020-05-13 10:16:12 +02:00
t.Run("search for files path", func(t *testing.T) {
files, err := Files(1000, 0, "Photos", true)
2020-05-13 10:16:12 +02:00
t.Logf("files: %+v", files)
if err != nil {
t.Fatal(err)
}
2020-05-13 10:16:12 +02:00
assert.Empty(t, files)
})
2020-01-28 20:59:26 +01:00
}
func TestFilesByUID(t *testing.T) {
2020-01-28 20:59:26 +01:00
t.Run("files found", func(t *testing.T) {
files, err := FilesByUID([]string{"fs6sg6bw45bnlqdw"}, 100, 0)
2020-01-28 20:59:26 +01:00
2020-05-13 10:16:12 +02:00
if err != nil {
t.Fatal(err)
}
2020-01-28 20:59:26 +01:00
assert.Equal(t, 1, len(files))
2021-08-05 12:33:52 +02:00
assert.Equal(t, "2790/07/27900704_070228_D6D51B6C.jpg", files[0].FileName)
2020-01-28 20:59:26 +01:00
})
2020-05-13 10:16:12 +02:00
t.Run("no files found", func(t *testing.T) {
files, err := FilesByUID([]string{"fs6sg6bw45bnlxxx"}, 100, 0)
2020-05-13 10:16:12 +02:00
if err != nil {
t.Fatal(err)
}
assert.Equal(t, 0, len(files))
})
//TODO fails on mariadb
2021-03-03 11:49:32 +01:00
t.Run("error", func(t *testing.T) {
files, err := FilesByUID([]string{"fs6sg6bw45bnlxxx"}, -100, 0)
2021-03-03 11:49:32 +01:00
assert.Error(t, err)
assert.Equal(t, 0, len(files))
})
2020-01-28 20:59:26 +01:00
}
func TestFileByPhotoUID(t *testing.T) {
2020-01-28 20:59:26 +01:00
t.Run("files found", func(t *testing.T) {
file, err := FileByPhotoUID("ps6sg6be2lvl0y11")
2020-01-28 20:59:26 +01:00
2020-05-13 10:16:12 +02:00
if err != nil {
t.Fatal(err)
}
2021-08-16 17:15:06 +02:00
assert.Equal(t, "Germany/bridge.jpg", file.FileName)
2020-01-28 20:59:26 +01:00
})
t.Run("no files found", func(t *testing.T) {
file, err := FileByPhotoUID("111")
2020-01-28 20:59:26 +01:00
assert.Error(t, err, "record not found")
t.Log(file)
})
}
func TestVideoByPhotoUID(t *testing.T) {
t.Run("files found", func(t *testing.T) {
file, err := VideoByPhotoUID("ps6sg6be2lvl0yh0")
if err != nil {
t.Fatal(err)
}
2021-08-16 17:15:06 +02:00
assert.Equal(t, "1990/04/bridge2.mp4", file.FileName)
})
t.Run("no files found", func(t *testing.T) {
file, err := VideoByPhotoUID("111")
assert.Error(t, err, "record not found")
t.Log(file)
})
}
func TestFileByUID(t *testing.T) {
2020-01-28 20:59:26 +01:00
t.Run("files found", func(t *testing.T) {
file, err := FileByUID("fs6sg6bw45bnlqdw")
2020-01-28 20:59:26 +01:00
if err != nil {
t.Fatal(err)
}
2021-08-05 12:33:52 +02:00
assert.Equal(t, "2790/07/27900704_070228_D6D51B6C.jpg", file.FileName)
2020-01-28 20:59:26 +01:00
})
t.Run("no files found", func(t *testing.T) {
file, err := FileByUID("111")
if err == nil {
t.Fatal("error expected")
}
2020-01-28 20:59:26 +01:00
assert.Error(t, err, "record not found")
t.Log(file)
})
}
func TestFileByHash(t *testing.T) {
2020-01-28 20:59:26 +01:00
t.Run("files found", func(t *testing.T) {
file, err := FileByHash("2cad9168fa6acc5c5c2965ddf6ec465ca42fd818")
2020-01-28 20:59:26 +01:00
2020-05-13 10:16:12 +02:00
if err != nil {
t.Fatal(err)
}
2021-08-05 12:33:52 +02:00
assert.Equal(t, "2790/07/27900704_070228_D6D51B6C.jpg", file.FileName)
2020-01-28 20:59:26 +01:00
})
t.Run("no files found", func(t *testing.T) {
file, err := FileByHash("111")
2020-01-28 20:59:26 +01:00
assert.Error(t, err, "record not found")
t.Log(file)
})
}
2020-05-13 10:16:12 +02:00
func TestSetPhotoPrimary(t *testing.T) {
t.Run("success", func(t *testing.T) {
assert.Equal(t, false, entity.FileFixturesExampleXMP.FilePrimary)
2020-05-13 10:16:12 +02:00
err := SetPhotoPrimary("ps6sg6be2lvl0yh7", "fs6sg6bwhhbnlqdn")
2020-05-13 10:16:12 +02:00
if err != nil {
t.Fatal(err)
}
})
t.Run("no_file_uid", func(t *testing.T) {
err := SetPhotoPrimary("ps6sg6be2lvl0yh7", "")
if err != nil {
t.Fatal(err)
}
})
t.Run("no_uid", func(t *testing.T) {
err := SetPhotoPrimary("", "")
if err == nil {
t.Fatal("error expected")
}
})
2021-08-31 16:33:55 +02:00
t.Run("file missing", func(t *testing.T) {
err := SetPhotoPrimary("ps6sg6be2lvl0y22", "")
2021-08-31 16:33:55 +02:00
if err == nil {
t.Fatal("error expected")
}
assert.Contains(t, err.Error(), "cannot find primary file")
2021-08-31 16:33:55 +02:00
})
2020-05-13 10:16:12 +02:00
}
func TestSetFileError(t *testing.T) {
assert.Equal(t, "", entity.FileFixturesExampleXMP.FileError)
SetFileError("fs6sg6bwhhbnlqdn", "errorFromTest")
//TODO How to assert
//assert.Equal(t, true, entity.FileFixturesExampleXMP.FilePrimary)
}
2021-09-30 15:50:10 +02:00
func TestRenameFile(t *testing.T) {
t.Run("empty name", func(t *testing.T) {
err := RenameFile("xxx", "", "yyy", "yyy")
if err == nil {
t.Fatal(err)
}
})
t.Run("success", func(t *testing.T) {
assert.Equal(t, "2790/02/Photo01.xmp", entity.FileFixturesExampleXMP.FileName)
assert.Equal(t, "/", entity.FileFixturesExampleXMP.FileRoot)
err := RenameFile("/", "exampleXmpFile.xmp", "test-root", "yyy.jpg")
if err != nil {
t.Fatal(err)
}
//TODO how to assert?
//assert.Equal(t, "", entity.FileFixturesExampleXMP.FileName)
})
}
func TestIndexedFiles(t *testing.T) {
if err := entity.AddDuplicate(
"Photo18.jpg",
entity.RootSidecar,
"3cad9168fa6acc5c5c2965ddf6ec465ca42fd818",
661858,
time.Date(2019, 3, 6, 2, 6, 51, 0, time.UTC).Unix(),
); err != nil {
t.Fatal(err)
}
result, err := IndexedFiles()
if err != nil {
t.Fatal(err)
}
2021-09-30 15:50:10 +02:00
t.Logf("indexed files: %#v", result)
}
2021-09-30 15:50:10 +02:00
func TestOrphanFiles(t *testing.T) {
files, err := OrphanFiles()
2021-03-03 11:49:32 +01:00
2021-09-30 15:50:10 +02:00
if err != nil {
t.Fatal(err)
}
2021-03-03 11:49:32 +01:00
2021-09-30 15:50:10 +02:00
assert.IsType(t, entity.Files{}, files)
2021-03-03 11:49:32 +01:00
}