summaryrefslogtreecommitdiff
path: root/modules/gallery
diff options
context:
space:
mode:
authorKriss Andsten <kriss@sverok.se>2010-12-21 09:03:46 +0800
committerBharat Mediratta <bharat@menalto.com>2010-12-22 08:22:25 +0800
commit48640005a4edac955d9087f62fed1ab5f756b686 (patch)
treec50bf8a9cad3a724ebc4e06af9c15e3cfd2d1b5b /modules/gallery
parent612ddd7050889974fc1f7e449e715b4c1129c0bb (diff)
Packaging + tests of Bharat's find_by_path routine.
Diffstat (limited to 'modules/gallery')
-rw-r--r--modules/gallery/helpers/item.php25
-rw-r--r--modules/gallery/tests/Item_Helper_Test.php48
2 files changed, 72 insertions, 1 deletions
diff --git a/modules/gallery/helpers/item.php b/modules/gallery/helpers/item.php
index 664da812..dbad59b9 100644
--- a/modules/gallery/helpers/item.php
+++ b/modules/gallery/helpers/item.php
@@ -208,7 +208,30 @@ class item_Core {
return $model;
}
-
+
+ static function find_by_path($path) {
+ $path = trim($path, '/');
+
+ // The root path name is NULL, not '', hence this workaround.
+ if ($path == '') {
+ return ORM::factory("item", 1);
+ }
+
+ $paths = explode("/", $path);
+ $count = count($paths);
+ foreach (ORM::factory("item")
+ ->where('name', '=', $paths[$count - 1])
+ ->where('level', '=', $count + 1)
+ ->find_all() as $item) {
+ if (urldecode($item->relative_path()) == $path) {
+ return $item;
+ }
+ }
+
+ return false;
+ }
+
+
/**
* Return the root Item_Model
* @return Item_Model
diff --git a/modules/gallery/tests/Item_Helper_Test.php b/modules/gallery/tests/Item_Helper_Test.php
index 26db5a63..1fced654 100644
--- a/modules/gallery/tests/Item_Helper_Test.php
+++ b/modules/gallery/tests/Item_Helper_Test.php
@@ -125,4 +125,52 @@ class Item_Helper_Test extends Gallery_Unit_Test_Case {
$this->assert_same($photo2->id, $album->album_cover_item_id);
$this->assert_same($photo2->id, $parent->album_cover_item_id);
}
+
+ public function find_by_path_does_the_right_thing_test() {
+ $level1 = test::random_album();
+ $level2 = test::random_album($level1);
+ $level3 = test::random_photo($level2);
+ $level3->name = 'same.jpg';
+ $level3->save();
+
+ $level2b = test::random_album($level1);
+ $level3b = test::random_photo($level2b);
+ $level3b->name = 'same.jpg';
+ $level3b->save();
+
+ // Item in album
+ $this->assert_same(
+ item::find_by_path('/' . $level1->name . '/' . $level2->name . '/' . $level3->name)->id,
+ $level3->id);
+
+ // Album, ends with a slash
+ $this->assert_same(
+ item::find_by_path($level1->name . '/' . $level2->name . '/')->id,
+ $level2->id);
+
+ // Album, ends without a slash
+ $this->assert_same(
+ item::find_by_path('/' . $level1->name . '/' . $level2->name)->id,
+ $level2->id);
+
+ // Return root if '' is passed
+ $this->assert_same(
+ item::find_by_path('')->id,
+ "1");
+
+ // Verify that we don't get confused by the part names
+ $this->assert_same(
+ item::find_by_path($level1->name . '/' . $level2->name . '/' . $level3->name)->id,
+ $level3->id);
+
+ $this->assert_same(
+ item::find_by_path($level1->name . '/' . $level2b->name . '/' . $level3b->name)->id,
+ $level3b->id);
+
+ // Verify that we don't get false positives
+ $this->assert_same(
+ item::find_by_path('foo/bar/baz'),
+ false);
+
+ }
}