mirror of
https://github.com/kamilwylegala/cakephp2-php8.git
synced 2025-01-19 02:56:15 +00:00
Tests for a generic custom datasource
Default startQuote and endQuote to avoid error with non-database datasources
This commit is contained in:
parent
2333c8f33f
commit
6cf73c763c
2 changed files with 253 additions and 1 deletions
|
@ -1319,7 +1319,9 @@ class Model extends Object implements CakeEventListener {
|
|||
$cols = $this->schema();
|
||||
$model = null;
|
||||
|
||||
$column = str_replace(array($db->startQuote, $db->endQuote), '', $column);
|
||||
$startQuote = isset($db->startQuote) ? $db->startQuote : null;
|
||||
$endQuote = isset($db->endQuote) ? $db->endQuote : null;
|
||||
$column = str_replace(array($startQuote, $endQuote), '', $column);
|
||||
|
||||
if (strpos($column, '.')) {
|
||||
list($model, $column) = explode('.', $column);
|
||||
|
|
250
lib/Cake/Test/Case/Model/Datasource/DataSourceTest.php
Normal file
250
lib/Cake/Test/Case/Model/Datasource/DataSourceTest.php
Normal file
|
@ -0,0 +1,250 @@
|
|||
<?php
|
||||
/**
|
||||
* DataSourceTest file
|
||||
*
|
||||
* PHP 5
|
||||
*
|
||||
* CakePHP(tm) Tests <http://book.cakephp.org/view/1196/Testing>
|
||||
* Copyright 2005-2012, Cake Software Foundation, Inc. (http://cakefoundation.org)
|
||||
*
|
||||
* Licensed under The Open Group Test Suite License
|
||||
* Redistributions of files must retain the above copyright notice.
|
||||
*
|
||||
* @copyright Copyright 2005-2012, Cake Software Foundation, Inc. (http://cakefoundation.org)
|
||||
* @link http://book.cakephp.org/view/1196/Testing CakePHP(tm) Tests
|
||||
* @package Cake.Test.Case.Model.Datasource
|
||||
* @since CakePHP(tm) v 1.2.0.4206
|
||||
* @license MIT License (http://www.opensource.org/licenses/mit-license.php)
|
||||
*/
|
||||
|
||||
App::uses('Model', 'Model');
|
||||
App::uses('DataSource', 'Model/Datasource');
|
||||
|
||||
/**
|
||||
* TestSource
|
||||
*
|
||||
* @package Cake.Test.Case.Model.Datasource
|
||||
*/
|
||||
class TestSource extends DataSource {
|
||||
|
||||
/**
|
||||
* _schema
|
||||
* @var type
|
||||
*/
|
||||
protected $_schema = array(
|
||||
'id' => array(
|
||||
'type' => 'integer',
|
||||
'null' => false,
|
||||
'key' => 'primary',
|
||||
'length' => 11,
|
||||
),
|
||||
'text' => array(
|
||||
'type' => 'string',
|
||||
'null' => true,
|
||||
'length' => 140,
|
||||
),
|
||||
'status' => array(
|
||||
'type' => 'string',
|
||||
'null' => true,
|
||||
'length' => 140,
|
||||
),
|
||||
'customField' => array(
|
||||
'type' => 'string',
|
||||
'null' => true,
|
||||
'length' => 255,
|
||||
),
|
||||
);
|
||||
|
||||
/**
|
||||
* listSources
|
||||
*
|
||||
* @return boolean
|
||||
*/
|
||||
public function listSources() {
|
||||
return null;
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns the schema for the datasource to enable create/update
|
||||
*
|
||||
* @param object $Model
|
||||
* @return array
|
||||
*/
|
||||
public function describe(Model $Model) {
|
||||
return $this->_schema;
|
||||
}
|
||||
|
||||
/**
|
||||
* Just return $func to pass to read() to figure out the COUNT
|
||||
* Required for delete/update to work
|
||||
*
|
||||
* @param Model $Model
|
||||
* @param type $func
|
||||
* @param type $params
|
||||
* @return array
|
||||
*/
|
||||
public function calculate(Model $Model, $func, $params = array()) {
|
||||
return $func;
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
/**
|
||||
* DataSourceTest class
|
||||
*
|
||||
* @package Cake.Test.Case.Model.Datasource
|
||||
*/
|
||||
class DataSourceTest extends CakeTestCase {
|
||||
|
||||
/**
|
||||
* Name of test source
|
||||
*
|
||||
* @var string
|
||||
*/
|
||||
public $sourceName = 'myapitest';
|
||||
|
||||
/**
|
||||
* setUp method
|
||||
*
|
||||
* @return void
|
||||
*/
|
||||
public function setUp() {
|
||||
parent::setUp();
|
||||
$this->Source = $this->getMock(
|
||||
'TestSource',
|
||||
array('create', 'read', 'update', 'delete')
|
||||
);
|
||||
ConnectionManager::create($this->sourceName, array(
|
||||
'datasource' => get_class($this->Source),
|
||||
'apiKey' => '1234abcd',
|
||||
));
|
||||
$this->Model = $this->getMock(
|
||||
'Model',
|
||||
array('getDataSource'),
|
||||
array(array('ds' => $this->sourceName))
|
||||
);
|
||||
$this->Model->expects($this->any())
|
||||
->method('getDataSource')
|
||||
->will($this->returnValue($this->Source));
|
||||
}
|
||||
|
||||
/**
|
||||
* tearDown method
|
||||
*
|
||||
* @return void
|
||||
*/
|
||||
public function tearDown() {
|
||||
parent::tearDown();
|
||||
unset($this->Model, $this->Source);
|
||||
ConnectionManager::drop($this->sourceName);
|
||||
}
|
||||
|
||||
/**
|
||||
* testCreate
|
||||
*
|
||||
* @return void
|
||||
*/
|
||||
public function testCreate() {
|
||||
$data = array(
|
||||
$this->Model->alias => array(
|
||||
'text' => 'This is a test',
|
||||
'status' => 'Test status',
|
||||
'customField' => array(
|
||||
'array', 'field', 'type',
|
||||
'for', 'custom', 'datasources',
|
||||
),
|
||||
),
|
||||
);
|
||||
$this->Source->expects($this->once())
|
||||
->method('create')
|
||||
->with(
|
||||
$this->equalTo($this->Model),
|
||||
$this->equalTo(array_keys($data[$this->Model->alias])),
|
||||
$this->equalTo(array_values($data[$this->Model->alias]))
|
||||
);
|
||||
$this->Model->save($data);
|
||||
}
|
||||
|
||||
/**
|
||||
* testRead
|
||||
*
|
||||
* @return void
|
||||
*/
|
||||
public function testRead() {
|
||||
$expected = array(
|
||||
'conditions' => array('status' => 'test'),
|
||||
'fields' => null,
|
||||
'joins' => array(),
|
||||
'limit' => 10,
|
||||
'offset' => null,
|
||||
'order' => array(array('status')),
|
||||
'page' => 1,
|
||||
'group' => null,
|
||||
'callbacks' => true,
|
||||
);
|
||||
$this->Source->expects($this->once())
|
||||
->method('read')
|
||||
->with(
|
||||
$this->anything(),
|
||||
$this->equalTo($expected)
|
||||
);
|
||||
$this->Model->find('all', array(
|
||||
'conditions' => array('status' => 'test'),
|
||||
'limit' => 10,
|
||||
'order' => array('status'),
|
||||
));
|
||||
}
|
||||
|
||||
/**
|
||||
* testUpdate
|
||||
*
|
||||
* @return void
|
||||
*/
|
||||
public function testUpdate() {
|
||||
$data = array(
|
||||
$this->Model->alias => array(
|
||||
'id' => 1,
|
||||
'text' => 'This is a test',
|
||||
'status' => 'Test status',
|
||||
'customField' => array(
|
||||
'array', 'field', 'type',
|
||||
'for', 'custom', 'datasources',
|
||||
),
|
||||
),
|
||||
);
|
||||
$this->Source->expects($this->any())
|
||||
->method('read')
|
||||
->will($this->returnValue(array(
|
||||
array($this->Model->alias => array('count' => 1))
|
||||
)));
|
||||
$this->Source->expects($this->once())
|
||||
->method('update')
|
||||
->with(
|
||||
$this->equalTo($this->Model),
|
||||
$this->equalTo(array_keys($data[$this->Model->alias])),
|
||||
$this->equalTo(array_values($data[$this->Model->alias]))
|
||||
);
|
||||
$this->Model->save($data);
|
||||
}
|
||||
|
||||
/**
|
||||
* testDelete
|
||||
*
|
||||
* @return void
|
||||
*/
|
||||
public function testDelete() {
|
||||
$this->Source->expects($this->any())
|
||||
->method('read')
|
||||
->will($this->returnValue(array(
|
||||
array($this->Model->alias => array('count' => 1))
|
||||
)));
|
||||
$this->Source->expects($this->once())
|
||||
->method('delete')
|
||||
->with(
|
||||
$this->equalTo($this->Model),
|
||||
$this->equalTo(array($this->Model->alias . '.id' => 1))
|
||||
);
|
||||
$this->Model->delete(1);
|
||||
}
|
||||
|
||||
}
|
Loading…
Add table
Reference in a new issue