Unverified Commit b2a10193 authored by alexpott's avatar alexpott
Browse files

Issue #2956556 by johndevman, daffie, Neslee Canil Pinto, dan.munn, aleevas,...

Issue #2956556 by johndevman, daffie, Neslee Canil Pinto, dan.munn, aleevas, dubcanada, alexpott: class isn't set in FETCH_OBJECT when class_name isn't set
parent e1b93214
......@@ -417,7 +417,10 @@ public function fetchObject($class_name = NULL, $constructor_args = []) {
}
else {
$this->fetchStyle = \PDO::FETCH_CLASS;
$this->fetchOptions = ['constructor_args' => $constructor_args];
$this->fetchOptions = [
'class' => $class_name,
'constructor_args' => $constructor_args,
];
// Grab the row in the format specified above.
$result = $this->current();
// Reset the fetch parameters to the value stored using setFetchMode().
......
......@@ -80,6 +80,23 @@ public function testQueryFetchClass() {
$this->assertIdentical(count($records), 1, 'There is only one record.');
}
/**
* Confirms that we can fetch a record into a class using fetchObject.
*
* @see \Drupal\system\Tests\Database\FakeRecord
* @see \Drupal\Core\Database\StatementPrefech::fetchObject
*/
public function testQueryFetchObjectClass() {
$records = 0;
$query = $this->connection->query('SELECT name FROM {test} WHERE age = :age', [':age' => 25]);
while ($result = $query->fetchObject(FakeRecord::class)) {
$records += 1;
$this->assertInstanceOf(FakeRecord::class, $result);
$this->assertSame('John', $result->name, '25 year old is John.');
}
$this->assertSame(1, $records, 'There is only one record.');
}
/**
* Confirms that we can fetch a record into a new instance of a custom class.
* The name of the class is determined from a value of the first column.
......
Markdown is supported
0% or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment