more thorough testing for path_to_tags, and handle more edge cases
This commit is contained in:
parent
bf03c0849a
commit
a828c3e0e5
3 changed files with 45 additions and 5 deletions
|
@ -20,9 +20,6 @@ function add_dir(string $base): array
|
||||||
$filename = basename($full_path);
|
$filename = basename($full_path);
|
||||||
|
|
||||||
$tags = path_to_tags($short_path);
|
$tags = path_to_tags($short_path);
|
||||||
if ($tags[0] == "\\") {
|
|
||||||
$tags = "";
|
|
||||||
}
|
|
||||||
$result = "$short_path (".str_replace(" ", ", ", $tags).")... ";
|
$result = "$short_path (".str_replace(" ", ", ", $tags).")... ";
|
||||||
try {
|
try {
|
||||||
add_image($full_path, $filename, $tags);
|
add_image($full_path, $filename, $tags);
|
||||||
|
|
|
@ -85,4 +85,44 @@ class UtilTest extends TestCase
|
||||||
load_balance_url("https://{foo=10,bar=5,baz=5}.mycdn.com/$hash.$ext", $hash, 1)
|
load_balance_url("https://{foo=10,bar=5,baz=5}.mycdn.com/$hash.$ext", $hash, 1)
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function test_path_to_tags()
|
||||||
|
{
|
||||||
|
$this->assertEquals(
|
||||||
|
"",
|
||||||
|
path_to_tags("nope.jpg")
|
||||||
|
);
|
||||||
|
$this->assertEquals(
|
||||||
|
"",
|
||||||
|
path_to_tags("\\")
|
||||||
|
);
|
||||||
|
$this->assertEquals(
|
||||||
|
"",
|
||||||
|
path_to_tags("/")
|
||||||
|
);
|
||||||
|
$this->assertEquals(
|
||||||
|
"",
|
||||||
|
path_to_tags("C:\\")
|
||||||
|
);
|
||||||
|
$this->assertEquals(
|
||||||
|
"test tag",
|
||||||
|
path_to_tags("123 - test tag.jpg")
|
||||||
|
);
|
||||||
|
$this->assertEquals(
|
||||||
|
"foo bar",
|
||||||
|
path_to_tags("/foo/bar/baz.jpg")
|
||||||
|
);
|
||||||
|
$this->assertEquals(
|
||||||
|
"cake pie foo bar",
|
||||||
|
path_to_tags("/foo/bar/123 - cake pie.jpg")
|
||||||
|
);
|
||||||
|
$this->assertEquals(
|
||||||
|
"bacon lemon",
|
||||||
|
path_to_tags("\\bacon\\lemon\\baz.jpg")
|
||||||
|
);
|
||||||
|
$this->assertEquals(
|
||||||
|
"category:tag",
|
||||||
|
path_to_tags("/category:/tag/baz.jpg")
|
||||||
|
);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -354,10 +354,13 @@ function path_to_tags(string $path): string
|
||||||
$tags = explode(" ", $matches[1]);
|
$tags = explode(" ", $matches[1]);
|
||||||
}
|
}
|
||||||
|
|
||||||
$path = dirname($path);
|
$path = str_replace("\\", "/", $path);
|
||||||
$path = str_replace(";", ":", $path);
|
$path = str_replace(";", ":", $path);
|
||||||
$path = str_replace("__", " ", $path);
|
$path = str_replace("__", " ", $path);
|
||||||
|
$path = dirname($path);
|
||||||
|
if ($path == "\\" || $path == "/" || $path == ".") {
|
||||||
|
$path = "";
|
||||||
|
}
|
||||||
|
|
||||||
$category = "";
|
$category = "";
|
||||||
foreach (explode("/", $path) as $dir) {
|
foreach (explode("/", $path) as $dir) {
|
||||||
|
|
Reference in a new issue