diff --git a/build.xml b/build.xml
index cbc23738f..9fef9518f 100644
--- a/build.xml
+++ b/build.xml
@@ -62,26 +62,40 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
-
+
-
-
+
+
-
+
-
-
+
+
diff --git a/lib/Doctrine/ORM/Query/SqlWalker.php b/lib/Doctrine/ORM/Query/SqlWalker.php
index e736b4caf..57d5df346 100644
--- a/lib/Doctrine/ORM/Query/SqlWalker.php
+++ b/lib/Doctrine/ORM/Query/SqlWalker.php
@@ -41,7 +41,7 @@ class SqlWalker implements TreeWalker
private $_aliasCounter = 0;
/** Counter for generating unique table aliases. */
private $_tableAliasCounter = 0;
- private $_scalarResultCounter = 0;
+ private $_scalarResultCounter = 1;
/** Counter for SQL parameter positions. */
private $_sqlParamIndex = 1;
/** The ParserResult. */
diff --git a/lib/vendor/addendum/annotations.php b/lib/vendor/addendum/annotations.php
index 9728950d7..cf058cd43 100755
--- a/lib/vendor/addendum/annotations.php
+++ b/lib/vendor/addendum/annotations.php
@@ -24,23 +24,30 @@
class Annotation {
public $value;
+ private static $creationStack = array();
public final function __construct($data, $target) {
$reflection = new ReflectionClass($this);
+ $class = $reflection->getName();
+ if(isset(self::$creationStack[$class])) {
+ trigger_error("Circular annotation reference on '$class'", E_USER_ERROR);
+ return;
+ }
+ self::$creationStack[$class] = true;
foreach($data as $key => $value) {
if($reflection->hasProperty($key)) {
$this->$key = $value;
} else {
- $class = $reflection->getName();
trigger_error("Property '$key' not defined for annotation '$class'");
}
}
$this->checkTargetConstraints($target);
$this->checkConstraints($target);
+ unset(self::$creationStack[$class]);
}
private function checkTargetConstraints($target) {
- $reflection = new ReflectionAnnotatedClass($this);
+ /*$reflection = new ReflectionAnnotatedClass($this);
if($reflection->hasAnnotation('Target')) {
$value = $reflection->getAnnotation('Target')->value;
$values = is_array($value) ? $value : array($value);
@@ -50,7 +57,7 @@
if($value == 'property' && $target instanceof ReflectionProperty) return;
}
trigger_error("Annotation '".get_class($this)."' not allowed on ".$this->createName($target), E_USER_ERROR);
- }
+ }*/
}
private function createName($target) {
@@ -66,7 +73,7 @@
protected function checkConstraints($target) {}
}
- class Target extends Annotation {}
+ //class Target extends Annotation {}
class AnnotationsBuilder {
private static $cache = array();
@@ -75,7 +82,7 @@
$data = $this->parse($targetReflection);
$annotations = array();
foreach($data as $class => $parameters) {
- if(!Addendum::ignores($class)) {
+ if(is_subclass_of($class, 'Annotation') && !Addendum::ignores($class)) {
foreach($parameters as $params) {
$annotationReflection = new ReflectionClass($class);
$annotations[$class][] = $annotationReflection->newInstance($params, $targetReflection);
diff --git a/lib/vendor/addendum/annotations/annotation_parser.php b/lib/vendor/addendum/annotations/annotation_parser.php
index 5d7c41d9c..f20514958 100755
--- a/lib/vendor/addendum/annotations/annotation_parser.php
+++ b/lib/vendor/addendum/annotations/annotation_parser.php
@@ -190,6 +190,7 @@
$this->add(new AnnotationStringMatcher);
$this->add(new AnnotationNumberMatcher);
$this->add(new AnnotationArrayMatcher);
+ $this->add(new AnnotationStaticConstantMatcher);
}
}
@@ -332,4 +333,20 @@
return $matches[1];
}
}
+
+ class AnnotationStaticConstantMatcher extends RegexMatcher {
+ public function __construct() {
+ parent::__construct('(\w+::\w+)');
+ }
+
+ protected function process($matches) {
+ $name = $matches[1];
+ if(!defined($name)) {
+ trigger_error("Constant '$name' used in annotation was not defined.");
+ return false;
+ }
+ return constant($name);
+ }
+
+ }
?>
diff --git a/lib/vendor/addendum/annotations/tests/acceptance_test.php b/lib/vendor/addendum/annotations/tests/acceptance_test.php
index e5597a86e..9bdd6b073 100755
--- a/lib/vendor/addendum/annotations/tests/acceptance_test.php
+++ b/lib/vendor/addendum/annotations/tests/acceptance_test.php
@@ -35,6 +35,32 @@
class FirstAnnotation extends Annotation {}
class SecondAnnotation extends Annotation {}
+
+ class NoAnnotation {}
+
+ /** @NoAnnotation @FirstAnnotation */
+ class ExampleWithInvalidAnnotation {}
+
+ /** @SelfReferencingAnnotation */
+ class SelfReferencingAnnotation extends Annotation {}
+
+ /** @IndirectReferenceLoopAnnotationHelper */
+ class IndirectReferenceLoopAnnotation extends Annotation {}
+
+ /** @IndirectReferenceLoopAnnotation */
+ class IndirectReferenceLoopAnnotationHelper extends Annotation {}
+
+
+ class Statics {
+ const A_CONSTANT = 'constant';
+ static public $static = 'static';
+ }
+
+ /** @FirstAnnotation(Statics::A_CONSTANT) */
+ class ClassAnnotatedWithStaticConstant {}
+
+ /** @FirstAnnotation(Statics::UNKNOWN_CONSTANT) */
+ class ClassAnnotatedWithNonExistingConstant {}
class TestOfAnnotations extends UnitTestCase {
public function testReflectionAnnotatedClass() {
@@ -192,6 +218,36 @@
$this->assertIsA($annotations[0], 'FirstAnnotation');
$this->assertIsA($annotations[1], 'FirstAnnotation');
}
+
+ public function testClassWithNoAnnotationParentShouldNotBeParsed() {
+ $reflection = new ReflectionAnnotatedClass('ExampleWithInvalidAnnotation');
+ $annotations = $reflection = $reflection->getAnnotations();
+ $this->assertEqual(count($annotations), 1);
+ $this->assertIsA($annotations[0], 'FirstAnnotation');
+ }
+
+ public function testCircularReferenceShouldThrowError() {
+ $this->expectError("Circular annotation reference on 'SelfReferencingAnnotation'");
+ $reflection = new ReflectionAnnotatedClass('SelfReferencingAnnotation');
+ $reflection->getAnnotations();
+
+ $this->expectError("Circular annotation reference on 'IndirectReferenceLoopAnnotationHelper'");
+ $reflection = new ReflectionAnnotatedClass('IndirectReferenceLoopAnnotation');
+ $reflection->getAnnotations();
+ }
+
+ public function testConstInAnnotationShouldReturnCorrectValue() {
+ $reflection = new ReflectionAnnotatedClass('ClassAnnotatedWithStaticConstant');
+ $annotation = $reflection->getAnnotation('FirstAnnotation');
+ $this->assertEqual($annotation->value, Statics::A_CONSTANT);
+ }
+
+ public function testBadConstInAnnotationShouldCauseError() {
+ $this->expectError("Constant 'Statics::UNKNOWN_CONSTANT' used in annotation was not defined.");
+ $reflection = new ReflectionAnnotatedClass('ClassAnnotatedWithNonExistingConstant');
+ $annotation = $reflection->getAnnotation('FirstAnnotation');
+ }
+
}
Mock::generatePartial('AnnotationsBuilder', 'MockedAnnotationsBuilder', array('getDocComment'));
diff --git a/lib/vendor/addendum/annotations/tests/all_tests.php b/lib/vendor/addendum/annotations/tests/all_tests.php
index f64dc0772..a37274170 100755
--- a/lib/vendor/addendum/annotations/tests/all_tests.php
+++ b/lib/vendor/addendum/annotations/tests/all_tests.php
@@ -8,26 +8,21 @@
require_once(dirname(__FILE__).'/annotation_parser_test.php');
require_once(dirname(__FILE__).'/doc_comment_test.php');
- class AllTests extends GroupTest {
- function __construct($title = false) {
- parent::__construct($title);
- $this->addTestClass('TestOfAnnotations');
- $this->addTestClass('TestOfPerformanceFeatures');
- $this->addTestClass('TestOfSupportingFeatures');
- $this->addTestClass('TestOfAnnotation');
- $this->addTestClass('TestOfConstrainedAnnotation');
- $this->addTestClass('TestOfMatchers');
- $this->addTestClass('TestOfAnnotationMatchers');
- $this->addTestClass('TestOfDocComment');
-
- }
- }
-
+ $suite = new TestSuite('All tests');
+ $suite->add(new TestOfAnnotations);
+ $suite->add(new TestOfPerformanceFeatures);
+ $suite->add(new TestOfSupportingFeatures);
+ $suite->add(new TestOfAnnotation);
+ $suite->add(new TestOfConstrainedAnnotation);
+ $suite->add(new TestOfMatchers);
+ $suite->add(new TestOfAnnotationMatchers);
+ $suite->add(new TestOfDocComment);
+
+ $reporter = TextReporter::inCli() ? new TextReporter() : new HtmlReporter();
+
Addendum::setRawMode(false);
- $test = new AllTests('All tests in reflection mode');
- $test->run(new HtmlReporter());
+ $suite->run($reporter);
Addendum::setRawMode(true);
- $test = new AllTests('All tests in raw mode');
- $test->run(new HtmlReporter());
+ $suite->run($reporter);
?>
diff --git a/lib/vendor/addendum/annotations/tests/annotation_parser_test.php b/lib/vendor/addendum/annotations/tests/annotation_parser_test.php
index cb9563733..6f2eaff0a 100755
--- a/lib/vendor/addendum/annotations/tests/annotation_parser_test.php
+++ b/lib/vendor/addendum/annotations/tests/annotation_parser_test.php
@@ -48,6 +48,11 @@
$this->assertEqual($value, '1234');
}
}
+
+ class StaticClass {
+ const A_CONSTANT = 'constant';
+ }
+
class TestOfAnnotationMatchers extends UnitTestCase {
public function testAnnotationsMatcherShouldMatchAnnotationWithGarbage() {
@@ -185,6 +190,11 @@
$matcher = new AnnotationValueMatcher;
$this->assertMatcherResult($matcher, '{1}', array(1));
}
+
+ public function testValueMatcherShouldMatchStaticConstant() {
+ $matcher = new AnnotationValueMatcher;
+ $this->assertMatcherResult($matcher, 'StaticClass::A_CONSTANT', StaticClass::A_CONSTANT);
+ }
public function testArrayMatcherShouldMatchEmptyArray() {
$matcher = new AnnotationArrayMatcher;
@@ -299,6 +309,18 @@
$this->assertMatcherResult($matcher, '"string\"string"', 'string"string');
$this->assertMatcherResult($matcher, "'string\'string'", "string'string");
}
+
+ public function testStaticConstantMatcherShouldMatchConstants() {
+ $matcher = new AnnotationStaticConstantMatcher;
+ $this->assertMatcherResult($matcher, 'StaticClass::A_CONSTANT', StaticClass::A_CONSTANT);
+ }
+
+ public function testStaticConstantMatcherShouldThrowErrorOnBadConstant() {
+ $this->expectError("Constant 'StaticClass::NO_CONSTANT' used in annotation was not defined.");
+ $matcher = new AnnotationStaticConstantMatcher;
+ $matcher->matches('StaticClass::NO_CONSTANT', $value);
+ }
+
private function assertNotFalse($value) {
$this->assertNotIdentical($value, false);
@@ -309,4 +331,4 @@
$this->assertIdentical($value, $expected);
}
}
-?>
\ No newline at end of file
+?>
diff --git a/lib/vendor/addendum/annotations/tests/annotation_test.php b/lib/vendor/addendum/annotations/tests/annotation_test.php
index 936e115ef..46a5130d6 100755
--- a/lib/vendor/addendum/annotations/tests/annotation_test.php
+++ b/lib/vendor/addendum/annotations/tests/annotation_test.php
@@ -15,13 +15,13 @@
}
public function testConstructorThrowsErrorOnInvalidParameter() {
+ $this->expectError("Property 'unknown' not defined for annotation 'TestingAnnotation'");
$annotation = new TestingAnnotation(array('unknown' => 1), $this);
- $this->assertError("Property 'unknown' not defined for annotation 'TestingAnnotation'");
}
public function TODO_testConstructorThrowsErrorWithoutSpecifingRequiredParameters() {
+ $this->expectError("Property 'required' in annotation 'TestingAnnotation' is required");
$annotation = new TestingAnnotation();
- $this->assertError("Property 'required' in annotation 'TestingAnnotation' is required");
}
}
?>
diff --git a/lib/vendor/addendum/annotations/tests/constrained_annotation_test.php b/lib/vendor/addendum/annotations/tests/constrained_annotation_test.php
index a1cc765e1..bd74077aa 100755
--- a/lib/vendor/addendum/annotations/tests/constrained_annotation_test.php
+++ b/lib/vendor/addendum/annotations/tests/constrained_annotation_test.php
@@ -55,7 +55,6 @@
$reflection = new ReflectionAnnotatedClass('SuccesfullyAnnotatedClass');
$method = $reflection->getMethod('method');
$property = $reflection->getProperty('property');
- $this->assertNoErrors();
}
public function testMultiTargetAnnotationThrowsErrorWhenOnWrongPlace() {
@@ -67,7 +66,6 @@
public function testMultiTargetAnnotationThrowsNoErrorWhenOnRightPlace() {
$reflection = new ReflectionAnnotatedClass('SuccesfullyAnnotatedClass');
$method = $reflection->getProperty('property2');
- $this->assertNoErrors();
}
}
-?>
\ No newline at end of file
+?>
diff --git a/tests/Doctrine/Tests/Common/ClassLoaderTest.php b/tests/Doctrine/Tests/Common/ClassLoaderTest.php
index ac3b2b361..7ac1d4182 100644
--- a/tests/Doctrine/Tests/Common/ClassLoaderTest.php
+++ b/tests/Doctrine/Tests/Common/ClassLoaderTest.php
@@ -4,6 +4,8 @@ namespace Doctrine\Tests\Common;
use Doctrine\Common\ClassLoader;
+require_once __DIR__ . '/../TestInit.php';
+
class ClassLoaderTest extends \Doctrine\Tests\DoctrineTestCase
{
public function testCustomFileExtensionAndNamespaceSeparator()
diff --git a/tests/Doctrine/Tests/Common/DoctrineExceptionTest.php b/tests/Doctrine/Tests/Common/DoctrineExceptionTest.php
index dd54fd15c..bfaaab550 100644
--- a/tests/Doctrine/Tests/Common/DoctrineExceptionTest.php
+++ b/tests/Doctrine/Tests/Common/DoctrineExceptionTest.php
@@ -2,6 +2,8 @@
namespace Doctrine\Tests\Common;
+require_once __DIR__ . '/../TestInit.php';
+
class DoctrineExceptionTest extends \Doctrine\Tests\DoctrineTestCase
{
public function testStaticCall()
diff --git a/tests/Doctrine/Tests/Common/EventManagerTest.php b/tests/Doctrine/Tests/Common/EventManagerTest.php
index d79f86a74..38e492dfb 100644
--- a/tests/Doctrine/Tests/Common/EventManagerTest.php
+++ b/tests/Doctrine/Tests/Common/EventManagerTest.php
@@ -5,6 +5,8 @@ namespace Doctrine\Tests\Common;
use Doctrine\Common\EventManager;
use Doctrine\Common\EventArgs;
+require_once __DIR__ . '/../TestInit.php';
+
class EventManagerTest extends \Doctrine\Tests\DoctrineTestCase
{
/* Some pseudo events */
diff --git a/tests/Doctrine/Tests/DBAL/Functional/Schema/MySqlSchemaManagerTest.php b/tests/Doctrine/Tests/DBAL/Functional/Schema/MySqlSchemaManagerTest.php
index ecacc797c..0e29cb846 100644
--- a/tests/Doctrine/Tests/DBAL/Functional/Schema/MySqlSchemaManagerTest.php
+++ b/tests/Doctrine/Tests/DBAL/Functional/Schema/MySqlSchemaManagerTest.php
@@ -6,7 +6,7 @@ use Doctrine\DBAL\Schema;
require_once __DIR__ . '/../../../TestInit.php';
-class MySqlSchemaManagerTest extends SchemaManagerFunctionalTest
+class MySqlSchemaManagerTest extends SchemaManagerFunctionalTestCase
{
public function testListDatabases()
{
@@ -15,14 +15,20 @@ class MySqlSchemaManagerTest extends SchemaManagerFunctionalTest
$this->assertEquals(true, in_array('test_create_database', $databases));
}
+ /**
+ * @expectedException \Exception
+ */
public function testListFunctions()
{
- return $this->assertUnsupportedMethod('listFunctions');
+ $this->_sm->listFunctions();
}
+ /**
+ * @expectedException \Exception
+ */
public function testListTriggers()
{
- return $this->assertUnsupportedMethod('listTriggers');
+ $this->_sm->listTriggers();
}
public function testListSequences()
diff --git a/tests/Doctrine/Tests/DBAL/Functional/Schema/OracleSchemaManagerTest.php b/tests/Doctrine/Tests/DBAL/Functional/Schema/OracleSchemaManagerTest.php
index 71b7bf2ff..76199bf9b 100644
--- a/tests/Doctrine/Tests/DBAL/Functional/Schema/OracleSchemaManagerTest.php
+++ b/tests/Doctrine/Tests/DBAL/Functional/Schema/OracleSchemaManagerTest.php
@@ -6,7 +6,7 @@ use Doctrine\DBAL\Schema;
require_once __DIR__ . '/../../../TestInit.php';
-class OracleSchemaManagerTest extends SchemaManagerFunctionalTest
+class OracleSchemaManagerTest extends SchemaManagerFunctionalTestCase
{
public function testListDatabases()
{
@@ -21,9 +21,12 @@ class OracleSchemaManagerTest extends SchemaManagerFunctionalTest
$this->assertEquals(array(), $functions);
}
+ /**
+ * @expectedException \Exception
+ */
public function testListTriggers()
{
- return $this->assertUnsupportedMethod('listTriggers');
+ $this->_sm->listTriggers();
}
public function testListSequences()
diff --git a/tests/Doctrine/Tests/DBAL/Functional/Schema/PostgreSqlSchemaManagerTest.php b/tests/Doctrine/Tests/DBAL/Functional/Schema/PostgreSqlSchemaManagerTest.php
index 94193963a..d944aafad 100644
--- a/tests/Doctrine/Tests/DBAL/Functional/Schema/PostgreSqlSchemaManagerTest.php
+++ b/tests/Doctrine/Tests/DBAL/Functional/Schema/PostgreSqlSchemaManagerTest.php
@@ -6,7 +6,7 @@ use Doctrine\DBAL\Schema;
require_once __DIR__ . '/../../../TestInit.php';
-class PostgreSqlSchemaManagerTest extends SchemaManagerFunctionalTest
+class PostgreSqlSchemaManagerTest extends SchemaManagerFunctionalTestCase
{
public function testListDatabases()
{
@@ -15,9 +15,12 @@ class PostgreSqlSchemaManagerTest extends SchemaManagerFunctionalTest
$this->assertEquals(true, in_array('test_create_database', $databases));
}
+ /**
+ * @expectedException \Exception
+ */
public function testListFunctions()
{
- return $this->assertUnsupportedMethod('listFunctions');
+ $this->_sm->listFunctions();
}
public function testListTriggers()
diff --git a/tests/Doctrine/Tests/DBAL/Functional/Schema/SchemaManagerFunctionalTest.php b/tests/Doctrine/Tests/DBAL/Functional/Schema/SchemaManagerFunctionalTestCase.php
similarity index 74%
rename from tests/Doctrine/Tests/DBAL/Functional/Schema/SchemaManagerFunctionalTest.php
rename to tests/Doctrine/Tests/DBAL/Functional/Schema/SchemaManagerFunctionalTestCase.php
index 201472e5f..6241bd5ee 100644
--- a/tests/Doctrine/Tests/DBAL/Functional/Schema/SchemaManagerFunctionalTest.php
+++ b/tests/Doctrine/Tests/DBAL/Functional/Schema/SchemaManagerFunctionalTestCase.php
@@ -4,7 +4,9 @@ namespace Doctrine\Tests\DBAL\Functional\Schema;
use Doctrine\DBAL\Types\Type;
-class SchemaManagerFunctionalTest extends \Doctrine\Tests\DbalFunctionalTestCase
+require_once __DIR__ . '/../../../TestInit.php';
+
+class SchemaManagerFunctionalTestCase extends \Doctrine\Tests\DbalFunctionalTestCase
{
protected function setUp()
{
@@ -23,7 +25,7 @@ class SchemaManagerFunctionalTest extends \Doctrine\Tests\DbalFunctionalTestCase
$this->_sm = $this->_conn->getSchemaManager();
}
- public function createTestTable($name = 'test_table', $data = array())
+ protected function createTestTable($name = 'test_table', $data = array())
{
if ( ! isset($data['columns'])) {
$columns = array(
@@ -52,15 +54,4 @@ class SchemaManagerFunctionalTest extends \Doctrine\Tests\DbalFunctionalTestCase
$this->_sm->dropAndCreateTable($name, $columns, $options);
}
-
- public function assertUnsupportedMethod($method)
- {
- try {
- $this->_sm->$method();
- } catch (\Exception $e) {
- return;
- }
-
- $this->fail($method . '() should throw an exception because it is not supported in ' . $this->_conn->getDatabasePlatform()->getName());
- }
}
\ No newline at end of file
diff --git a/tests/Doctrine/Tests/DBAL/Functional/Schema/SqliteSchemaManagerTest.php b/tests/Doctrine/Tests/DBAL/Functional/Schema/SqliteSchemaManagerTest.php
index 5cce24138..3c95bd117 100644
--- a/tests/Doctrine/Tests/DBAL/Functional/Schema/SqliteSchemaManagerTest.php
+++ b/tests/Doctrine/Tests/DBAL/Functional/Schema/SqliteSchemaManagerTest.php
@@ -6,21 +6,30 @@ use Doctrine\DBAL\Schema;
require_once __DIR__ . '/../../../TestInit.php';
-class SqliteSchemaManagerTest extends SchemaManagerFunctionalTest
+class SqliteSchemaManagerTest extends SchemaManagerFunctionalTestCase
{
+ /**
+ * @expectedException \Exception
+ */
public function testListDatabases()
{
- return $this->assertUnsupportedMethod('listDatabases');
+ $this->_sm->listDatabases();
}
+ /**
+ * @expectedException \Exception
+ */
public function testListFunctions()
{
- return $this->assertUnsupportedMethod('listFunctions');
+ $this->_sm->listFunctions();
}
+ /**
+ * @expectedException \Exception
+ */
public function testListTriggers()
{
- return $this->assertUnsupportedMethod('listTriggers');
+ $this->_sm->listTriggers();
}
public function testListSequences()
@@ -92,9 +101,12 @@ class SqliteSchemaManagerTest extends SchemaManagerFunctionalTest
$this->assertEquals(true, in_array('list_tables_test', $tables));
}
+ /**
+ * @expectedException \Exception
+ */
public function testListUsers()
{
- return $this->assertUnsupportedMethod('listUsers');
+ $this->_sm->listUsers();
}
public function testListViews()
@@ -157,14 +169,12 @@ class SqliteSchemaManagerTest extends SchemaManagerFunctionalTest
$this->assertEquals(null, $tableColumns[1]['default']);
}
+ /**
+ * @expectedException \Exception
+ */
public function testCreateSequence()
{
- return $this->assertUnsupportedMethod('createSequence');
- }
-
- public function testCreateConstraint()
- {
- return $this->assertUnsupportedMethod('createConstraint');
+ $this->_sm->createSequence('seqname', 1, 1);
}
/* FIXME: See comment in AbstractSchemaManager#dropIndex($table, $name)
@@ -185,34 +195,51 @@ class SqliteSchemaManagerTest extends SchemaManagerFunctionalTest
$this->assertEquals(true, $tableIndexes[0]['unique']);
}*/
+ /**
+ * @expectedException \Exception
+ */
public function testCreateForeignKey()
{
- return $this->assertUnsupportedMethod('createForeignKey');
+ $this->_sm->createForeignKey('table', array());
}
+ /**
+ * @expectedException \Exception
+ */
public function testRenameTable()
{
- return $this->assertUnsupportedMethod('renameTable');
+ $this->_sm->renameTable('oldname', 'newname');
}
-
+ /**
+ * @expectedException \Exception
+ */
public function testAddTableColumn()
{
- return $this->assertUnsupportedMethod('addTableColumn');
+ return $this->_sm->addTableColumn('table', 'column', array());
}
+ /**
+ * @expectedException \Exception
+ */
public function testRemoveTableColumn()
{
- return $this->assertUnsupportedMethod('removeTableColumn');
+ $this->_sm->removeTableColumn('table', 'column');
}
+ /**
+ * @expectedException \Exception
+ */
public function testChangeTableColumn()
{
- return $this->assertUnsupportedMethod('changeTableColumn');
+ $this->_sm->changeTableColumn('name', 'type', null, array());
}
-
+
+ /**
+ * @expectedException \Exception
+ */
public function testRenameTableColumn()
{
- return $this->assertUnsupportedMethod('renameTableColumn');
+ $this->_sm->renameTableColumn('table', 'old', 'new', array());
}
}
\ No newline at end of file
diff --git a/tests/Doctrine/Tests/ORM/AllTests.php b/tests/Doctrine/Tests/ORM/AllTests.php
index ab1e4b4c8..c7e208f9a 100644
--- a/tests/Doctrine/Tests/ORM/AllTests.php
+++ b/tests/Doctrine/Tests/ORM/AllTests.php
@@ -30,7 +30,6 @@ class AllTests
$suite->addTestSuite('Doctrine\Tests\ORM\UnitOfWorkTest');
$suite->addTestSuite('Doctrine\Tests\ORM\EntityManagerTest');
- //$suite->addTestSuite('Doctrine\Tests\ORM\EntityPersisterTest');
$suite->addTestSuite('Doctrine\Tests\ORM\CommitOrderCalculatorTest');
$suite->addTest(Query\AllTests::suite());
diff --git a/tests/Doctrine/Tests/ORM/Criteria/DqlGenerationTest.php b/tests/Doctrine/Tests/ORM/Criteria/DqlGenerationTest.php
index 4d4a082ce..f2d223d02 100644
--- a/tests/Doctrine/Tests/ORM/Criteria/DqlGenerationTest.php
+++ b/tests/Doctrine/Tests/ORM/Criteria/DqlGenerationTest.php
@@ -36,6 +36,10 @@ require_once __DIR__ . '/../../TestInit.php';
*/
class DqlGenerationTest extends \Doctrine\Tests\OrmTestCase
{
+ protected function setUp() {
+ $this->markTestSkipped('Not yet implemented.');
+ }
+
protected function createQuery()
{
return $this->_em->createQuery();
diff --git a/tests/Doctrine/Tests/ORM/EntityPersisterTest.php b/tests/Doctrine/Tests/ORM/EntityPersisterTest.php
deleted file mode 100644
index f4d3d9600..000000000
--- a/tests/Doctrine/Tests/ORM/EntityPersisterTest.php
+++ /dev/null
@@ -1,74 +0,0 @@
-_connMock = new ConnectionMock(array(), new \Doctrine\Tests\Mocks\DriverMock());
- $this->_emMock = EntityManagerMock::create($this->_connMock);
- $this->_uowMock = new UnitOfWorkMock($this->_emMock);
- $this->_emMock->setUnitOfWork($this->_uowMock);
- $this->_idGenMock = new SequenceMock($this->_emMock, 'seq', 20);
- //$this->_emMock->setIdGenerator('Doctrine\Tests\Models\Forum\ForumUser', $this->_idGenMock);
- }
-
- public function testSimpleInsert()
- {
- $userPersister = new \Doctrine\ORM\Persisters\SingleTablePersister(
- $this->_emMock, $this->_emMock->getClassMetadata("Doctrine\Tests\Models\Forum\ForumUser"));
- $avatarPersister = new \Doctrine\ORM\Persisters\StandardEntityPersister(
- $this->_emMock, $this->_emMock->getClassMetadata("Doctrine\Tests\Models\Forum\ForumAvatar"));
-
- $user = new ForumUser();
- $user->username = "romanb";
- $user->avatar = new ForumAvatar();
-
- $this->_uowMock->setDataChangeSet($user, array(
- 'username' => array('', 'romanb'),
- 'avatar' => array('', $user->avatar)));
-
- //insert
- $avatarPersister->insert($user->avatar);
- $inserts = $this->_connMock->getInserts();
- //check
- $this->assertEquals(1, count($inserts));
- $this->assertTrue(isset($inserts['forum_avatars']));
- $this->assertEquals(1, count($inserts['forum_avatars']));
- $this->assertEquals(null, $user->avatar->id);
- $user->avatar->id = 0; // Fake that we got an id
-
- //insert
- $userPersister->insert($user);
- $inserts = $this->_connMock->getInserts();
- //check
- $this->assertEquals(2, count($inserts));
- $this->assertEquals(null, $user->id);
- $this->assertTrue(isset($inserts['forum_users']));
- $this->assertEquals(1, count($inserts['forum_users']));
- $this->assertEquals(3, count($inserts['forum_users'][0]));
- //username column
- $this->assertTrue(isset($inserts['forum_users'][0]['username']));
- $this->assertEquals('romanb', $inserts['forum_users'][0]['username']);
- //avatar_id join column
- $this->assertTrue(isset($inserts['forum_users'][0]['avatar_id']));
- $this->assertEquals(0, $inserts['forum_users'][0]['avatar_id']);
- }
-}
\ No newline at end of file
diff --git a/tests/Doctrine/Tests/ORM/Functional/AllTests.php b/tests/Doctrine/Tests/ORM/Functional/AllTests.php
index 51ff5cf80..e73cbf33d 100644
--- a/tests/Doctrine/Tests/ORM/Functional/AllTests.php
+++ b/tests/Doctrine/Tests/ORM/Functional/AllTests.php
@@ -25,6 +25,7 @@ class AllTests
$suite->addTestSuite('Doctrine\Tests\ORM\Functional\ClassTableInheritanceTest');
$suite->addTestSuite('Doctrine\Tests\ORM\Functional\DetachedEntityTest');
$suite->addTestSuite('Doctrine\Tests\ORM\Functional\QueryCacheTest');
+ $suite->addTestSuite('Doctrine\Tests\ORM\Functional\QueryTest');
return $suite;
}
diff --git a/tests/Doctrine/Tests/ORM/Functional/QueryTest.php b/tests/Doctrine/Tests/ORM/Functional/QueryTest.php
index 4957704fa..e8dce76b2 100644
--- a/tests/Doctrine/Tests/ORM/Functional/QueryTest.php
+++ b/tests/Doctrine/Tests/ORM/Functional/QueryTest.php
@@ -31,9 +31,9 @@ class QueryTest extends \Doctrine\Tests\OrmFunctionalTestCase
$this->_em->clear();
$query = $this->_em->createQuery("select u, upper(u.name) from Doctrine\Tests\Models\CMS\CmsUser u where u.username = 'gblanco'");
-
+
$result = $query->getResultList();
-
+
$this->assertEquals(1, count($result));
$this->assertTrue($result[0][0] instanceof CmsUser);
$this->assertEquals('Guilherme', $result[0][0]->name);
@@ -54,7 +54,7 @@ class QueryTest extends \Doctrine\Tests\OrmFunctionalTestCase
$this->assertEquals('Guilherme', $scalarResult[0]['u_name']);
$this->assertEquals('gblanco', $scalarResult[0]['u_username']);
$this->assertEquals('developer', $scalarResult[0]['u_status']);
- $this->assertEquals('GUILHERME', $scalarResult[0]['dctrn_1']);
+ $this->assertEquals('GUILHERME', $scalarResult[0][1]);
$query = $this->_em->createQuery("select upper(u.name) from Doctrine\Tests\Models\CMS\CmsUser u where u.username = 'gblanco'");
$this->assertEquals('GUILHERME', $query->getSingleScalarResult());
diff --git a/tests/Doctrine/Tests/ORM/Hydration/ArrayHydratorTest.php b/tests/Doctrine/Tests/ORM/Hydration/ArrayHydratorTest.php
index e30c2aa41..c5894ea0e 100644
--- a/tests/Doctrine/Tests/ORM/Hydration/ArrayHydratorTest.php
+++ b/tests/Doctrine/Tests/ORM/Hydration/ArrayHydratorTest.php
@@ -7,12 +7,12 @@ use Doctrine\ORM\Query\ResultSetMapping;
require_once __DIR__ . '/../../TestInit.php';
-class ArrayHydratorTest extends HydrationTest
+class ArrayHydratorTest extends HydrationTestCase
{
/**
* Select u.id, u.name from Doctrine\Tests\Models\CMS\CmsUser u
*/
- public function testNewHydrationSimpleEntityQuery()
+ public function testSimpleEntityQuery()
{
$rsm = new ResultSetMapping;
$rsm->addEntityResult('Doctrine\Tests\Models\CMS\CmsUser', 'u');
@@ -48,7 +48,7 @@ class ArrayHydratorTest extends HydrationTest
/**
*
*/
- public function testNewHydrationSimpleMultipleRootEntityQuery()
+ public function testSimpleMultipleRootEntityQuery()
{
$rsm = new ResultSetMapping;
$rsm->addEntityResult('Doctrine\Tests\Models\CMS\CmsUser', 'u');
@@ -99,7 +99,7 @@ class ArrayHydratorTest extends HydrationTest
* select u.id, u.status, p.phonenumber, upper(u.name) as u__0 from USERS u
* INNER JOIN PHONENUMBERS p ON u.id = p.user_id
*/
- public function testNewHydrationMixedQueryFetchJoin()
+ public function testMixedQueryFetchJoin()
{
$rsm = new ResultSetMapping;
$rsm->addEntityResult('Doctrine\Tests\Models\CMS\CmsUser', 'u');
@@ -166,7 +166,7 @@ class ArrayHydratorTest extends HydrationTest
* select u.id, u.status, count(p.phonenumber) as p__0 from USERS u
* INNER JOIN PHONENUMBERS p ON u.id = p.user_id group by u.id, u.status
*/
- public function testNewHydrationMixedQueryNormalJoin()
+ public function testMixedQueryNormalJoin()
{
$rsm = new ResultSetMapping;
$rsm->addEntityResult('Doctrine\Tests\Models\CMS\CmsUser', 'u');
@@ -211,7 +211,7 @@ class ArrayHydratorTest extends HydrationTest
* select u.id, u.status, upper(u.name) as p__0 from USERS u
* INNER JOIN PHONENUMBERS p ON u.id = p.user_id
*/
- public function testNewHydrationMixedQueryFetchJoinCustomIndex()
+ public function testMixedQueryFetchJoinCustomIndex()
{
$rsm = new ResultSetMapping;
$rsm->addEntityResult('Doctrine\Tests\Models\CMS\CmsUser', 'u');
@@ -286,7 +286,7 @@ class ArrayHydratorTest extends HydrationTest
* inner join PHONENUMBERS p ON u.id = p.user_id
* inner join ARTICLES a ON u.id = a.user_id
*/
- public function testNewHydrationMixedQueryMultipleFetchJoin()
+ public function testMixedQueryMultipleFetchJoin()
{
$rsm = new ResultSetMapping;
$rsm->addEntityResult('Doctrine\Tests\Models\CMS\CmsUser', 'u');
@@ -405,7 +405,7 @@ class ArrayHydratorTest extends HydrationTest
* inner join ARTICLES a ON u.id = a.user_id
* left outer join COMMENTS c ON a.id = c.article_id
*/
- public function testNewHydrationMixedQueryMultipleDeepMixedFetchJoin()
+ public function testMixedQueryMultipleDeepMixedFetchJoin()
{
$rsm = new ResultSetMapping;
@@ -563,7 +563,7 @@ class ArrayHydratorTest extends HydrationTest
* 1 | 0 | First | 1 | 3 | 1
* 1 | 0 | First | 2 | 4 | 1
*/
- public function testNewHydrationEntityQueryCustomResultSetOrder()
+ public function testEntityQueryCustomResultSetOrder()
{
$rsm = new ResultSetMapping;
$rsm->addEntityResult('Doctrine\Tests\Models\Forum\ForumCategory', 'c');
diff --git a/tests/Doctrine/Tests/ORM/Hydration/HydrationTest.php b/tests/Doctrine/Tests/ORM/Hydration/HydrationTestCase.php
similarity index 92%
rename from tests/Doctrine/Tests/ORM/Hydration/HydrationTest.php
rename to tests/Doctrine/Tests/ORM/Hydration/HydrationTestCase.php
index 035c655f7..660240391 100644
--- a/tests/Doctrine/Tests/ORM/Hydration/HydrationTest.php
+++ b/tests/Doctrine/Tests/ORM/Hydration/HydrationTestCase.php
@@ -7,7 +7,7 @@ require_once __DIR__ . '/../../TestInit.php';
use Doctrine\ORM\Query\ParserResult;
use Doctrine\ORM\Query\Parser;
-class HydrationTest extends \Doctrine\Tests\OrmTestCase
+class HydrationTestCase extends \Doctrine\Tests\OrmTestCase
{
protected $_em;
diff --git a/tests/Doctrine/Tests/ORM/Hydration/ObjectHydratorTest.php b/tests/Doctrine/Tests/ORM/Hydration/ObjectHydratorTest.php
index af3a68346..d453e708c 100644
--- a/tests/Doctrine/Tests/ORM/Hydration/ObjectHydratorTest.php
+++ b/tests/Doctrine/Tests/ORM/Hydration/ObjectHydratorTest.php
@@ -7,12 +7,12 @@ use Doctrine\ORM\Query\ResultSetMapping;
require_once __DIR__ . '/../../TestInit.php';
-class ObjectHydratorTest extends HydrationTest
+class ObjectHydratorTest extends HydrationTestCase
{
/**
* Select u.id, u.name from \Doctrine\Tests\Models\CMS\CmsUser u
*/
- public function testNewHydrationSimpleEntityQuery()
+ public function testSimpleEntityQuery()
{
$rsm = new ResultSetMapping;
$rsm->addEntityResult('Doctrine\Tests\Models\CMS\CmsUser', 'u');
@@ -49,7 +49,7 @@ class ObjectHydratorTest extends HydrationTest
/**
* Select u.id, u.name from \Doctrine\Tests\Models\CMS\CmsUser u
*/
- public function testNewHydrationSimpleMultipleRootEntityQuery()
+ public function testSimpleMultipleRootEntityQuery()
{
$rsm = new ResultSetMapping;
$rsm->addEntityResult('Doctrine\Tests\Models\CMS\CmsUser', 'u');
@@ -105,7 +105,7 @@ class ObjectHydratorTest extends HydrationTest
* select u.id, u.status, p.phonenumber, upper(u.name) as u__0 from USERS u
* INNER JOIN PHONENUMBERS p ON u.id = p.user_id
*/
- public function testNewHydrationMixedQueryFetchJoin()
+ public function testMixedQueryFetchJoin()
{
$rsm = new ResultSetMapping;
$rsm->addEntityResult('Doctrine\Tests\Models\CMS\CmsUser', 'u');
@@ -179,7 +179,7 @@ class ObjectHydratorTest extends HydrationTest
* select u.id, u.status, count(p.phonenumber) as p__0 from USERS u
* INNER JOIN PHONENUMBERS p ON u.id = p.user_id group by u.id, u.status
*/
- public function testNewHydrationMixedQueryNormalJoin()
+ public function testMixedQueryNormalJoin()
{
$rsm = new ResultSetMapping;
$rsm->addEntityResult('Doctrine\Tests\Models\CMS\CmsUser', 'u');
@@ -226,7 +226,7 @@ class ObjectHydratorTest extends HydrationTest
* select u.id, u.status, upper(u.name) as p__0 from USERS u
* INNER JOIN PHONENUMBERS p ON u.id = p.user_id
*/
- public function testNewHydrationMixedQueryFetchJoinCustomIndex()
+ public function testMixedQueryFetchJoinCustomIndex()
{
$rsm = new ResultSetMapping;
$rsm->addEntityResult('Doctrine\Tests\Models\CMS\CmsUser', 'u');
@@ -305,7 +305,7 @@ class ObjectHydratorTest extends HydrationTest
* inner join PHONENUMBERS p ON u.id = p.user_id
* inner join ARTICLES a ON u.id = a.user_id
*/
- public function testNewHydrationMixedQueryMultipleFetchJoin()
+ public function testMixedQueryMultipleFetchJoin()
{
$rsm = new ResultSetMapping;
$rsm->addEntityResult('Doctrine\Tests\Models\CMS\CmsUser', 'u');
@@ -420,7 +420,7 @@ class ObjectHydratorTest extends HydrationTest
* inner join ARTICLES a ON u.id = a.user_id
* left outer join COMMENTS c ON a.id = c.article_id
*/
- public function testNewHydrationMixedQueryMultipleDeepMixedFetchJoin()
+ public function testMixedQueryMultipleDeepMixedFetchJoin()
{
$rsm = new ResultSetMapping;
$rsm->addEntityResult('Doctrine\Tests\Models\CMS\CmsUser', 'u');
@@ -571,7 +571,7 @@ class ObjectHydratorTest extends HydrationTest
* 1 | 0 | First | 1 | 3 | 1
* 1 | 0 | First | 2 | 4 | 1
*/
- public function testNewHydrationEntityQueryCustomResultSetOrder()
+ public function testEntityQueryCustomResultSetOrder()
{
$rsm = new ResultSetMapping;
$rsm->addEntityResult('Doctrine\Tests\Models\Forum\ForumCategory', 'c');
diff --git a/tests/Doctrine/Tests/ORM/Hydration/ScalarHydratorTest.php b/tests/Doctrine/Tests/ORM/Hydration/ScalarHydratorTest.php
index f0e6ba03f..6af318eba 100644
--- a/tests/Doctrine/Tests/ORM/Hydration/ScalarHydratorTest.php
+++ b/tests/Doctrine/Tests/ORM/Hydration/ScalarHydratorTest.php
@@ -7,7 +7,7 @@ use Doctrine\ORM\Query\ResultSetMapping;
require_once __DIR__ . '/../../TestInit.php';
-class ScalarHydratorTest extends HydrationTest
+class ScalarHydratorTest extends HydrationTestCase
{
/**
* Select u.id, u.name from CmsUser u
diff --git a/tests/Doctrine/Tests/ORM/Hydration/SingleScalarHydratorTest.php b/tests/Doctrine/Tests/ORM/Hydration/SingleScalarHydratorTest.php
index babc4442b..761882868 100644
--- a/tests/Doctrine/Tests/ORM/Hydration/SingleScalarHydratorTest.php
+++ b/tests/Doctrine/Tests/ORM/Hydration/SingleScalarHydratorTest.php
@@ -7,7 +7,7 @@ use Doctrine\ORM\Query\ResultSetMapping;
require_once __DIR__ . '/../../TestInit.php';
-class SingleScalarHydratorTest extends HydrationTest
+class SingleScalarHydratorTest extends HydrationTestCase
{
/** Result set provider for the HYDRATE_SINGLE_SCALAR tests */
public static function singleScalarResultSetProvider() {
diff --git a/tests/Doctrine/Tests/ORM/Query/AllTests.php b/tests/Doctrine/Tests/ORM/Query/AllTests.php
index 2e76d68d3..23813b51c 100644
--- a/tests/Doctrine/Tests/ORM/Query/AllTests.php
+++ b/tests/Doctrine/Tests/ORM/Query/AllTests.php
@@ -19,7 +19,6 @@ class AllTests
{
$suite = new \Doctrine\Tests\DoctrineTestSuite('Doctrine Orm Query');
- //$suite->addTestSuite('Doctrine\Tests\ORM\Query\IdentifierRecognitionTest');
$suite->addTestSuite('Doctrine\Tests\ORM\Query\SelectSqlGenerationTest');
$suite->addTestSuite('Doctrine\Tests\ORM\Query\LanguageRecognitionTest');
$suite->addTestSuite('Doctrine\Tests\ORM\Query\LexerTest');
diff --git a/tests/Doctrine/Tests/ORM/Query/IdentifierRecognitionTest.php b/tests/Doctrine/Tests/ORM/Query/IdentifierRecognitionTest.php
deleted file mode 100644
index 0fc497c4d..000000000
--- a/tests/Doctrine/Tests/ORM/Query/IdentifierRecognitionTest.php
+++ /dev/null
@@ -1,130 +0,0 @@
-.
- */
-
-namespace Doctrine\Tests\ORM\Query;
-
-require_once __DIR__ . '/../../TestInit.php';
-
-/**
- * Test case for testing the saving and referencing of query identifiers.
- *
- * @author Guilherme Blanco
- * @author Janne Vanhala
- * @author Konsta Vesterinen
- * @license http://www.opensource.org/licenses/lgpl-license.php LGPL
- * @link http://www.phpdoctrine.org
- * @since 2.0
- * @version $Revision$
- */
-class IdentifierRecognitionTest extends \Doctrine\Tests\OrmTestCase
-{
- private $_em;
-
- protected function setUp() {
- parent::setUp();
- $this->_em = $this->_getTestEntityManager();
- }
-
- public function testSingleAliasDeclarationIsSupported()
- {
- $entityManager = $this->_em;
- $query = $entityManager->createQuery('SELECT u FROM Doctrine\Tests\Models\CMS\CmsUser u');
- $parserResult = $query->parse();
-
- $decl = $parserResult->getQueryComponent('u');
-
- $this->assertTrue($decl['metadata'] instanceof \Doctrine\ORM\Mapping\ClassMetadata);
- $this->assertEquals(null, $decl['relation']);
- $this->assertEquals(null, $decl['parent']);
- $this->assertEquals(null, $decl['scalar']);
- $this->assertEquals(null, $decl['map']);
- }
-
- public function testSingleAliasDeclarationWithIndexByIsSupported()
- {
- $entityManager = $this->_em;
- $query = $entityManager->createQuery('SELECT u FROM Doctrine\Tests\Models\CMS\CmsUser u INDEX BY u.id');
- $parserResult = $query->parse();
-
- $decl = $parserResult->getQueryComponent('u');
-
- $this->assertTrue($decl['metadata'] instanceof \Doctrine\ORM\Mapping\ClassMetadata);
- $this->assertEquals(null, $decl['relation']);
- $this->assertEquals(null, $decl['parent']);
- $this->assertEquals(null, $decl['scalar']);
- $this->assertEquals('id', $decl['map']);
- }
-
- public function testQueryParserSupportsMultipleAliasDeclarations()
- {
- $entityManager = $this->_em;
- $query = $entityManager->createQuery('SELECT u FROM Doctrine\Tests\Models\CMS\CmsUser u INDEX BY u.id LEFT JOIN u.phonenumbers p');
- $parserResult = $query->parse();
-
- $decl = $parserResult->getQueryComponent('u');
-
- $this->assertTrue($decl['metadata'] instanceof \Doctrine\ORM\Mapping\ClassMetadata);
- $this->assertEquals(null, $decl['relation']);
- $this->assertEquals(null, $decl['parent']);
- $this->assertEquals(null, $decl['scalar']);
- $this->assertEquals('id', $decl['map']);
-
- $decl = $parserResult->getQueryComponent('p');
-
- $this->assertTrue($decl['metadata'] instanceof \Doctrine\ORM\Mapping\ClassMetadata);
- $this->assertTrue($decl['relation'] instanceof \Doctrine\ORM\Mapping\AssociationMapping);
- $this->assertEquals('u', $decl['parent']);
- $this->assertEquals(null, $decl['scalar']);
- $this->assertEquals(null, $decl['map']);
- }
-
-
- public function testQueryParserSupportsMultipleAliasDeclarationsWithIndexBy()
- {
- $entityManager = $this->_em;
- $query = $entityManager->createQuery('SELECT u FROM Doctrine\Tests\Models\CMS\CmsUser u INDEX BY u.id LEFT JOIN u.articles a INNER JOIN u.phonenumbers pn INDEX BY pn.phonenumber');
- $parserResult = $query->parse();
-
- $decl = $parserResult->getQueryComponent('u');
-
- $this->assertTrue($decl['metadata'] instanceof \Doctrine\ORM\Mapping\ClassMetadata);
- $this->assertEquals(null, $decl['relation']);
- $this->assertEquals(null, $decl['parent']);
- $this->assertEquals(null, $decl['scalar']);
- $this->assertEquals('id', $decl['map']);
-
- $decl = $parserResult->getQueryComponent('a');
-
- $this->assertTrue($decl['metadata'] instanceof \Doctrine\ORM\Mapping\ClassMetadata);
- $this->assertTrue($decl['relation'] instanceof \Doctrine\ORM\Mapping\AssociationMapping);
- $this->assertEquals('u', $decl['parent']);
- $this->assertEquals(null, $decl['scalar']);
- $this->assertEquals(null, $decl['map']);
-
- $decl = $parserResult->getQueryComponent('pn');
-
- $this->assertTrue($decl['metadata'] instanceof \Doctrine\ORM\Mapping\ClassMetadata);
- $this->assertTrue($decl['relation'] instanceof \Doctrine\ORM\Mapping\AssociationMapping);
- $this->assertEquals('u', $decl['parent']);
- $this->assertEquals(null, $decl['scalar']);
- $this->assertEquals('phonenumber', $decl['map']);
- }
-}
diff --git a/tests/Doctrine/Tests/TestInit.php b/tests/Doctrine/Tests/TestInit.php
index 628908313..d36cc63e6 100644
--- a/tests/Doctrine/Tests/TestInit.php
+++ b/tests/Doctrine/Tests/TestInit.php
@@ -6,7 +6,7 @@ namespace Doctrine\Tests;
require_once 'PHPUnit/Framework.php';
require_once 'PHPUnit/TextUI/TestRunner.php';
-require_once '../lib/Doctrine/Common/ClassLoader.php';
+require_once __DIR__ . '/../../../lib/Doctrine/Common/ClassLoader.php';
$classLoader = new \Doctrine\Common\ClassLoader();