2019-05-06 23:18:10 +02:00
|
|
|
package config
|
2019-05-03 18:57:28 +02:00
|
|
|
|
|
|
|
import (
|
|
|
|
"flag"
|
|
|
|
"fmt"
|
|
|
|
"os"
|
|
|
|
"testing"
|
|
|
|
|
|
|
|
_ "github.com/jinzhu/gorm/dialects/mysql"
|
|
|
|
_ "github.com/jinzhu/gorm/dialects/sqlite"
|
2019-05-06 23:18:10 +02:00
|
|
|
"github.com/photoprism/photoprism/internal/util"
|
2019-05-03 18:57:28 +02:00
|
|
|
"github.com/urfave/cli"
|
|
|
|
|
|
|
|
log "github.com/sirupsen/logrus"
|
|
|
|
)
|
|
|
|
|
|
|
|
const (
|
|
|
|
TestDataZip = "/tmp/photoprism/testdata.zip"
|
2019-05-04 00:53:02 +02:00
|
|
|
TestDataURL = "https://dl.photoprism.org/fixtures/testdata.zip"
|
2019-05-03 18:57:28 +02:00
|
|
|
TestDataHash = "1a59b358b80221ab3e76efb683ad72402f0b0844"
|
|
|
|
)
|
|
|
|
|
2019-05-06 23:18:10 +02:00
|
|
|
var testConfig *Config
|
2019-05-03 18:57:28 +02:00
|
|
|
|
|
|
|
func testDataPath(assetsPath string) string {
|
|
|
|
return assetsPath + "/testdata"
|
|
|
|
}
|
|
|
|
|
2019-05-06 23:18:10 +02:00
|
|
|
func NewTestParams() *Params {
|
|
|
|
assetsPath := util.ExpandedFilename("../../assets")
|
2019-05-04 05:25:00 +02:00
|
|
|
|
2019-05-03 18:57:28 +02:00
|
|
|
testDataPath := testDataPath(assetsPath)
|
|
|
|
|
2019-05-06 23:18:10 +02:00
|
|
|
c := &Params{
|
2019-05-03 18:57:28 +02:00
|
|
|
DarktableCli: "/usr/bin/darktable-cli",
|
|
|
|
AssetsPath: assetsPath,
|
|
|
|
CachePath: testDataPath + "/cache",
|
|
|
|
OriginalsPath: testDataPath + "/originals",
|
|
|
|
ImportPath: testDataPath + "/import",
|
|
|
|
ExportPath: testDataPath + "/export",
|
|
|
|
DatabaseDriver: "mysql",
|
2019-05-20 16:39:41 +02:00
|
|
|
DatabaseDsn: "photoprism:photoprism@tcp(photoprism-mysql:4001)/photoprism?parseTime=true",
|
2019-05-03 18:57:28 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
return c
|
|
|
|
}
|
|
|
|
|
2019-05-06 23:18:10 +02:00
|
|
|
func TestConfig() *Config {
|
|
|
|
if testConfig == nil {
|
|
|
|
testConfig = NewTestConfig()
|
2019-05-03 18:57:28 +02:00
|
|
|
}
|
|
|
|
|
2019-05-06 23:18:10 +02:00
|
|
|
return testConfig
|
2019-05-03 18:57:28 +02:00
|
|
|
}
|
|
|
|
|
2019-05-06 23:18:10 +02:00
|
|
|
func NewTestConfig() *Config {
|
2019-05-04 05:25:00 +02:00
|
|
|
log.SetLevel(log.DebugLevel)
|
2019-05-03 18:57:28 +02:00
|
|
|
|
2019-05-06 23:18:10 +02:00
|
|
|
c := &Config{config: NewTestParams()}
|
2019-05-03 18:57:28 +02:00
|
|
|
|
|
|
|
c.MigrateDb()
|
|
|
|
|
|
|
|
return c
|
|
|
|
}
|
|
|
|
|
2019-05-06 23:18:10 +02:00
|
|
|
// Returns example cli config for testing
|
2019-05-03 18:57:28 +02:00
|
|
|
func CliTestContext() *cli.Context {
|
2019-05-06 23:18:10 +02:00
|
|
|
config := NewTestParams()
|
2019-05-03 18:57:28 +02:00
|
|
|
|
|
|
|
globalSet := flag.NewFlagSet("test", 0)
|
|
|
|
globalSet.Bool("debug", false, "doc")
|
|
|
|
globalSet.String("config-file", config.ConfigFile, "doc")
|
|
|
|
globalSet.String("assets-path", config.AssetsPath, "doc")
|
|
|
|
globalSet.String("originals-path", config.OriginalsPath, "doc")
|
|
|
|
globalSet.String("darktable-cli", config.DarktableCli, "doc")
|
|
|
|
|
|
|
|
app := cli.NewApp()
|
|
|
|
|
|
|
|
c := cli.NewContext(app, globalSet, nil)
|
|
|
|
|
|
|
|
c.Set("config-file", config.ConfigFile)
|
|
|
|
c.Set("assets-path", config.AssetsPath)
|
|
|
|
c.Set("originals-path", config.OriginalsPath)
|
|
|
|
c.Set("darktable-cli", config.DarktableCli)
|
|
|
|
|
|
|
|
return c
|
|
|
|
}
|
|
|
|
|
2019-05-06 23:18:10 +02:00
|
|
|
func (c *Config) RemoveTestData(t *testing.T) {
|
2019-05-03 18:57:28 +02:00
|
|
|
os.RemoveAll(c.ImportPath())
|
|
|
|
os.RemoveAll(c.ExportPath())
|
|
|
|
os.RemoveAll(c.OriginalsPath())
|
|
|
|
os.RemoveAll(c.CachePath())
|
|
|
|
}
|
|
|
|
|
2019-05-06 23:18:10 +02:00
|
|
|
func (c *Config) DownloadTestData(t *testing.T) {
|
|
|
|
if util.Exists(TestDataZip) {
|
|
|
|
hash := util.Hash(TestDataZip)
|
2019-05-03 18:57:28 +02:00
|
|
|
|
|
|
|
if hash != TestDataHash {
|
|
|
|
os.Remove(TestDataZip)
|
2019-05-04 05:25:00 +02:00
|
|
|
t.Logf("removed outdated test data zip file (fingerprint %s)\n", hash)
|
2019-05-03 18:57:28 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-05-06 23:18:10 +02:00
|
|
|
if !util.Exists(TestDataZip) {
|
2019-05-04 05:25:00 +02:00
|
|
|
fmt.Printf("downloading latest test data zip file from %s\n", TestDataURL)
|
2019-05-03 18:57:28 +02:00
|
|
|
|
2019-05-06 23:18:10 +02:00
|
|
|
if err := util.Download(TestDataZip, TestDataURL); err != nil {
|
2019-05-03 18:57:28 +02:00
|
|
|
fmt.Printf("Download failed: %s\n", err.Error())
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-05-06 23:18:10 +02:00
|
|
|
func (c *Config) UnzipTestData(t *testing.T) {
|
|
|
|
if _, err := util.Unzip(TestDataZip, testDataPath(c.AssetsPath())); err != nil {
|
2019-05-04 05:25:00 +02:00
|
|
|
t.Logf("could not unzip test data: %s\n", err.Error())
|
2019-05-03 18:57:28 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-05-06 23:18:10 +02:00
|
|
|
func (c *Config) InitializeTestData(t *testing.T) {
|
2019-05-04 05:25:00 +02:00
|
|
|
t.Log("initializing test data")
|
2019-05-03 18:57:28 +02:00
|
|
|
|
|
|
|
c.RemoveTestData(t)
|
|
|
|
|
|
|
|
c.DownloadTestData(t)
|
|
|
|
|
|
|
|
c.UnzipTestData(t)
|
|
|
|
}
|