From 88d79d1b62944fad6f6819e78d8afd4bf50b44b9 Mon Sep 17 00:00:00 2001 From: Sam Minnee Date: Sat, 26 Apr 2008 06:44:06 +0000 Subject: [PATCH] Merged revisions 52224 via svnmerge from http://svn.silverstripe.com/open/modules/sapphire/branches/2.2.2 ........ r52224 | sminnee | 2008-04-07 11:45:23 +1200 (Mon, 07 Apr 2008) | 1 line #2314 - Fixed SQLMap implementation so that Group::map() returns appropriate data, and the group dropdown on the access tab works. ........ git-svn-id: svn://svn.silverstripe.com/silverstripe/open/modules/sapphire/trunk@53508 467b73ca-7a2a-4603-9d3b-597d59a354a9 --- core/model/SQLMap.php | 40 +++++++++++++++++++++++++++++++----- tests/security/GroupTest.php | 25 ++++++++++++++++++++++ tests/security/GroupTest.yml | 5 +++++ 3 files changed, 65 insertions(+), 5 deletions(-) create mode 100644 tests/security/GroupTest.php create mode 100644 tests/security/GroupTest.yml diff --git a/core/model/SQLMap.php b/core/model/SQLMap.php index bbd0a4348..583e04aa6 100755 --- a/core/model/SQLMap.php +++ b/core/model/SQLMap.php @@ -48,12 +48,9 @@ class SQLMap extends Object implements IteratorAggregate { } } - /* - * Iterator - necessary for foreach to work - */ public function getIterator() { $this->genItems(); - return $this->items->getIterator(); + return new SQLMap_Iterator($this->items->getIterator()); } /** @@ -87,4 +84,37 @@ class SQLMap extends Object implements IteratorAggregate { } } -?> +class SQLMap_Iterator extends Object implements Iterator { + protected $items; + + function __construct(Iterator $items) { + $this->items = $items; + } + + + /* + * Iterator functions - necessary for foreach to work + */ + public function rewind() { + return $this->items->rewind() ? $this->items->rewind()->Title : null; + } + + public function current() { + return $this->items->current()->Title; + } + + public function key() { + return $this->items->current()->ID; + } + + public function next() { + $next = $this->items->next(); + return isset($next->Title) ? $next->Title : null; + } + + public function valid() { + return $this->items->valid(); + } +} + +?> \ No newline at end of file diff --git a/tests/security/GroupTest.php b/tests/security/GroupTest.php new file mode 100644 index 000000000..df591e38c --- /dev/null +++ b/tests/security/GroupTest.php @@ -0,0 +1,25 @@ + $v) { + $mapOutput[$k] = $v; + } + + $group1 = $this->objFromFixture('Group', 'group1'); + $group2 = $this->objFromFixture('Group', 'group2'); + + /* We have added 2 groups to our fixture. They should both appear in $mapOutput. */ + $this->assertEquals($mapOutput[$group1->ID], $group1->Title); + $this->assertEquals($mapOutput[$group2->ID], $group2->Title); + } +} \ No newline at end of file diff --git a/tests/security/GroupTest.yml b/tests/security/GroupTest.yml new file mode 100644 index 000000000..9fa04d760 --- /dev/null +++ b/tests/security/GroupTest.yml @@ -0,0 +1,5 @@ +Group: + group1: + Title: Group 1 + group2: + Title: Group 2 \ No newline at end of file