1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
|
<?php
require_once(dirname(__FILE__).'/BaseCase.php');
/**
* @package System.Data.SqlMap
*/
class DelegateTest extends BaseCase
{
function __construct()
{
parent::__construct();
$this->initSqlMap();
}
function testListDelegate()
{
$list = $this->sqlmap->queryWithRowDelegate(
"GetAllAccountsViaResultMap", array($this, 'listHandler'));
$this->assertSame(5, count($list));
$this->assertAccount1($list[0]);
$this->assertSame(1, $list[0]->getID());
$this->assertSame(2, $list[1]->getID());
$this->assertSame(3, $list[2]->getID());
$this->assertSame(4, $list[3]->getID());
$this->assertSame(5, $list[4]->getID());
}
/**
* Test ExecuteQueryForMap : Hashtable.
*/
function testExecuteQueryForMap()
{
$map = $this->sqlmap->QueryForMapWithRowDelegate(
"GetAllAccountsViaResultClass", array($this, 'mapHandler'), null, "FirstName");
$this->assertSame(5, count($map));
$this->assertAccount1($map["Joe"]);
$this->assertSame(1, $map["Joe"]->getID());
$this->assertSame(2, $map["Averel"]->getID());
$this->assertSame(3, $map["William"]->getID());
$this->assertSame(4, $map["Jack"]->getID());
$this->assertSame(5, $map["Gilles"]->getID());
}
public function listHandler($sender, $param)
{
$list = &$param->getList();
$list[] = $param->result;
$this->assertTrue($param->result instanceof Account);
}
public function mapHandler($sender, $param)
{
$map = &$param->getMap();
$map[$param->getKey()] = $param->getValue();
$this->assertTrue($param->getValue() instanceof Account);
}
}
|