summaryrefslogtreecommitdiff
path: root/vendor/github.com/superseriousbusiness/go-png-image-structure/v2/testing_common.go
diff options
context:
space:
mode:
authorLibravatar kim <89579420+NyaaaWhatsUpDoc@users.noreply.github.com>2024-08-02 11:46:41 +0000
committerLibravatar GitHub <noreply@github.com>2024-08-02 12:46:41 +0100
commit94e87610c4ce9bbb1c614a61bab29c1422fed11b (patch)
tree2e06b8ce64212140e796f6077ba841b6cc678501 /vendor/github.com/superseriousbusiness/go-png-image-structure/v2/testing_common.go
parent[feature] Allow import of following and blocks via CSV (#3150) (diff)
downloadgotosocial-94e87610c4ce9bbb1c614a61bab29c1422fed11b.tar.xz
[chore] add back exif-terminator and use only for jpeg,png,webp (#3161)
* add back exif-terminator and use only for jpeg,png,webp * fix arguments passed to terminateExif() * pull in latest exif-terminator * fix test * update processed img --------- Co-authored-by: tobi <tobi.smethurst@protonmail.com>
Diffstat (limited to 'vendor/github.com/superseriousbusiness/go-png-image-structure/v2/testing_common.go')
-rw-r--r--vendor/github.com/superseriousbusiness/go-png-image-structure/v2/testing_common.go77
1 files changed, 77 insertions, 0 deletions
diff --git a/vendor/github.com/superseriousbusiness/go-png-image-structure/v2/testing_common.go b/vendor/github.com/superseriousbusiness/go-png-image-structure/v2/testing_common.go
new file mode 100644
index 000000000..42f28d282
--- /dev/null
+++ b/vendor/github.com/superseriousbusiness/go-png-image-structure/v2/testing_common.go
@@ -0,0 +1,77 @@
+package pngstructure
+
+import (
+ "fmt"
+ "os"
+ "path"
+)
+
+var (
+ assetsPath = "assets"
+)
+
+func getModuleRootPath() (string, error) {
+ moduleRootPath := os.Getenv("PNG_MODULE_ROOT_PATH")
+ if moduleRootPath != "" {
+ return moduleRootPath, nil
+ }
+
+ currentWd, err := os.Getwd()
+ if err != nil {
+ return "", err
+ }
+
+ currentPath := currentWd
+ visited := make([]string, 0)
+
+ for {
+ tryStampFilepath := path.Join(currentPath, ".MODULE_ROOT")
+
+ _, err := os.Stat(tryStampFilepath)
+ if err != nil && !os.IsNotExist(err) {
+ return "", err
+ } else if err == nil {
+ break
+ }
+
+ visited = append(visited, tryStampFilepath)
+
+ currentPath = path.Dir(currentPath)
+ if currentPath == "/" {
+ return "", fmt.Errorf("could not find module-root: %v", visited)
+ }
+ }
+
+ return currentPath, nil
+}
+
+func getTestAssetsPath() (string, error) {
+ if assetsPath == "" {
+ moduleRootPath, err := getModuleRootPath()
+ if err != nil {
+ return "", err
+ }
+
+ assetsPath = path.Join(moduleRootPath, "assets")
+ }
+
+ return assetsPath, nil
+}
+
+func getTestBasicImageFilepath() (string, error) {
+ assetsPath, err := getTestAssetsPath()
+ if err != nil {
+ return "", err
+ }
+
+ return path.Join(assetsPath, "libpng.png"), nil
+}
+
+func getTestExifImageFilepath() (string, error) {
+ assetsPath, err := getTestAssetsPath()
+ if err != nil {
+ return "", err
+ }
+
+ return path.Join(assetsPath, "exif.png"), nil
+}