<?php require_once(dirname(__FILE__).'/BaseCase.php'); /** * @package System.DataAccess.SQLMap */ class ResultClassTest extends BaseCase { function __construct() { parent::__construct(); $this->initSqlMap(); } /** * Test a boolean resultClass */ function testBoolean() { $bit = $this->sqlmap->queryForObject("GetBoolean", 1); $this->assertIdentical(true, $bit); } /** * Test a boolean implicit resultClass */ function testBooleanWithoutResultClass() { $bit = (boolean)$this->sqlmap->queryForObject("GetBooleanWithoutResultClass", 1); $this->assertIdentical(true, $bit); } /** * Test a byte resultClass */ function testByte() { $letter = $this->sqlmap->queryForObject("GetByte", 1); $this->assertIdentical(155, (int)$letter); } /** * Test a byte implicit resultClass */ function testByteWithoutResultClass() { $letter = $this->sqlmap->queryForObject("GetByteWithoutResultClass", 1); $this->assertIdentical(155, (int)$letter); } /** * Test a char resultClass */ function testChar() { $letter = $this->sqlmap->queryForObject("GetChar", 1); $this->assertIdentical('a', trim($letter)); } /** * Test a char implicit resultClass */ function testCharWithoutResultClass() { $letter = $this->sqlmap->queryForObject("GetCharWithoutResultClass", 1); $this->assertIdentical('a', trim($letter)); } /** * Test a DateTime resultClass */ function testDateTime() { $orderDate = $this->sqlmap->queryForObject("GetDate", 1); $date = @mktime(8, 15, 00, 2, 15, 2003); $this->assertIdentical($date, $orderDate->getTimeStamp()); } /** * Test a DateTime implicit resultClass */ function testDateTimeWithoutResultClass() { $date = $this->sqlmap->queryForObject("GetDateWithoutResultClass", 1); $orderDate = new TDateTime; $orderDate->setDateTime($date); $date = @mktime(8, 15, 00, 2, 15, 2003); $this->assertIdentical($date, $orderDate->getTimeStamp()); } /** * Test a decimal resultClass */ function testDecimal() { $price = $this->sqlmap->queryForObject("GetDecimal", 1); $this->assertIdentical(1.56, $price); } /** * Test a decimal implicit resultClass */ function testDecimalWithoutResultClass() { $price = $this->sqlmap->queryForObject("GetDecimalWithoutResultClass", 1); $this->assertIdentical(1.56, (float)$price); } /** * Test a double resultClass */ function testDouble() { $price = $this->sqlmap->queryForObject("GetDouble", 1); $this->assertIdentical(99.5, $price); } /** * Test a double implicit resultClass */ function testDoubleWithoutResultClass() { $price = $this->sqlmap->queryForObject("GetDoubleWithoutResultClass", 1); $this->assertIdentical(99.5, (float)$price); } /** * IBATISNET-25 Error applying ResultMap when using 'Guid' in resultClass */ /* function testGuid() { Guid newGuid = new Guid("CD5ABF17-4BBC-4C86-92F1-257735414CF4"); Guid guid = (Guid) $this->sqlmap->queryForObject("GetGuid", 1); $this->assertIdentical(newGuid, guid); } */ /** * Test a Guid implicit resultClass */ /* function testGuidWithoutResultClass() { Guid newGuid = new Guid("CD5ABF17-4BBC-4C86-92F1-257735414CF4"); string guidString = Convert.ToString($this->sqlmap->queryForObject("GetGuidWithoutResultClass", 1)); Guid guid = new Guid(guidString); $this->assertIdentical(newGuid, guid); } */ /** * Test a int16 resultClass (integer in PHP) */ function testInt16() { $integer = $this->sqlmap->queryForObject("GetInt16", 1); $this->assertIdentical(32111, $integer); } /** * Test a int16 implicit resultClass (integer in PHP) */ function testInt16WithoutResultClass() { $integer = $this->sqlmap->queryForObject("GetInt16WithoutResultClass", 1); $this->assertIdentical(32111, (int)$integer); } /** * Test a int 32 resultClass (integer in PHP) */ function testInt32() { $integer = $this->sqlmap->queryForObject("GetInt32", 1); $this->assertIdentical(999999, $integer); } /** * Test a int 32 implicit resultClass (integer in PHP) */ function testInt32WithoutResultClass() { $integer = $this->sqlmap->queryForObject("GetInt32WithoutResultClass", 1); $this->assertIdentical(999999, (int)$integer); } /** * Test a int64 resultClass (float in PHP) */ function testInt64() { $bigInt = $this->sqlmap->queryForObject("GetInt64", 1); $this->assertIdentical(9223372036854775800, $bigInt); } /** * Test a int64 implicit resultClass (float in PHP) */ function testInt64WithoutResultClass() { $bigInt = $this->sqlmap->queryForObject("GetInt64WithoutResultClass", 1); $this->assertIdentical(9223372036854775800, (double)$bigInt); } /** * Test a single/float resultClass */ function testSingle() { $price = (float)$this->sqlmap->queryForObject("GetSingle", 1); $this->assertIdentical(92233.5, $price); } /** * Test a single/float implicit resultClass */ function testSingleWithoutResultClass() { $price = $this->sqlmap->queryForObject("GetSingleWithoutResultClass", 1); $this->assertIdentical(92233.5, (float)$price); } /** * Test a string resultClass */ function testString() { $cardType = $this->sqlmap->queryForObject("GetString", 1); $this->assertIdentical("VISA", $cardType); } /** * Test a string implicit resultClass */ function testStringWithoutResultClass() { $cardType = $this->sqlmap->queryForObject("GetStringWithoutResultClass", 1); $this->assertIdentical("VISA", $cardType); } /**/ }