mirror of
https://github.com/kamilwylegala/cakephp2-php8.git
synced 2025-01-19 19:16:16 +00:00
db1876d837
Even though there was some code in place to prevent results in random order from PostgreSQL we were still experiencing this with Jenkins and Travis. This commit removes the old code that handled this. From now on this will be handled differently. Every test model will order by its primary key. You can disable this by changing the order property of the model to `null`: `$testModel->order = null`.
299 lines
9.5 KiB
PHP
299 lines
9.5 KiB
PHP
<?php
|
|
/**
|
|
* TreeBehaviorUuidTest file
|
|
*
|
|
* Tree test using UUIDs
|
|
*
|
|
* PHP 5
|
|
*
|
|
* CakePHP(tm) Tests <http://book.cakephp.org/2.0/en/development/testing.html>
|
|
* Copyright (c) Cake Software Foundation, Inc. (http://cakefoundation.org)
|
|
*
|
|
* Licensed under The MIT License
|
|
* For full copyright and license information, please see the LICENSE.txt
|
|
* Redistributions of files must retain the above copyright notice
|
|
*
|
|
* @copyright Copyright (c) Cake Software Foundation, Inc. (http://cakefoundation.org)
|
|
* @link http://book.cakephp.org/2.0/en/development/testing.html CakePHP(tm) Tests
|
|
* @package Cake.Test.Case.Model.Behavior
|
|
* @since CakePHP(tm) v 1.2.0.5330
|
|
* @license http://www.opensource.org/licenses/mit-license.php MIT License
|
|
*/
|
|
|
|
App::uses('Model', 'Model');
|
|
App::uses('AppModel', 'Model');
|
|
App::uses('String', 'Utility');
|
|
require_once dirname(dirname(__FILE__)) . DS . 'models.php';
|
|
|
|
/**
|
|
* TreeBehaviorUuidTest class
|
|
*
|
|
* @package Cake.Test.Case.Model.Behavior
|
|
*/
|
|
class TreeBehaviorUuidTest extends CakeTestCase {
|
|
|
|
/**
|
|
* Whether backup global state for each test method or not
|
|
*
|
|
* @var bool false
|
|
*/
|
|
public $backupGlobals = false;
|
|
|
|
/**
|
|
* settings property
|
|
*
|
|
* @var array
|
|
*/
|
|
public $settings = array(
|
|
'modelClass' => 'UuidTree',
|
|
'leftField' => 'lft',
|
|
'rightField' => 'rght',
|
|
'parentField' => 'parent_id'
|
|
);
|
|
|
|
/**
|
|
* fixtures property
|
|
*
|
|
* @var array
|
|
*/
|
|
public $fixtures = array('core.uuid_tree');
|
|
|
|
/**
|
|
* testAddWithPreSpecifiedId method
|
|
*
|
|
* @return void
|
|
*/
|
|
public function testAddWithPreSpecifiedId() {
|
|
extract($this->settings);
|
|
$this->Tree = new $modelClass();
|
|
$this->Tree->order = null;
|
|
$this->Tree->initialize(2, 2);
|
|
|
|
$data = $this->Tree->find('first', array(
|
|
'fields' => array('id'),
|
|
'conditions' => array($modelClass . '.name' => '1.1')
|
|
));
|
|
|
|
$id = String::uuid();
|
|
$this->Tree->create();
|
|
$result = $this->Tree->save(array($modelClass => array(
|
|
'id' => $id,
|
|
'name' => 'testAddMiddle',
|
|
$parentField => $data[$modelClass]['id'])
|
|
));
|
|
$expected = array_merge(
|
|
array($modelClass => array('id' => $id, 'name' => 'testAddMiddle', $parentField => '2')),
|
|
$result
|
|
);
|
|
$this->assertSame($expected, $result);
|
|
|
|
$this->assertTrue($this->Tree->verify());
|
|
}
|
|
|
|
/**
|
|
* testMovePromote method
|
|
*
|
|
* @return void
|
|
*/
|
|
public function testMovePromote() {
|
|
extract($this->settings);
|
|
$this->Tree = new $modelClass();
|
|
$this->Tree->order = null;
|
|
$this->Tree->initialize(2, 2);
|
|
$this->Tree->id = null;
|
|
|
|
$parent = $this->Tree->find('first', array('conditions' => array($modelClass . '.name' => '1. Root')));
|
|
$parentId = $parent[$modelClass]['id'];
|
|
|
|
$data = $this->Tree->find('first', array('fields' => array('id'), 'conditions' => array($modelClass . '.name' => '1.1.1')));
|
|
$this->Tree->id = $data[$modelClass]['id'];
|
|
$this->Tree->saveField($parentField, $parentId);
|
|
$direct = $this->Tree->children($parentId, true, array('name', $leftField, $rightField));
|
|
$expects = array(array($modelClass => array('name' => '1.1', $leftField => 2, $rightField => 5)),
|
|
array($modelClass => array('name' => '1.2', $leftField => 6, $rightField => 11)),
|
|
array($modelClass => array('name' => '1.1.1', $leftField => 12, $rightField => 13)));
|
|
$this->assertEquals($direct, $expects);
|
|
$validTree = $this->Tree->verify();
|
|
$this->assertSame($validTree, true);
|
|
}
|
|
|
|
/**
|
|
* testMoveWithWhitelist method
|
|
*
|
|
* @return void
|
|
*/
|
|
public function testMoveWithWhitelist() {
|
|
extract($this->settings);
|
|
$this->Tree = new $modelClass();
|
|
$this->Tree->order = null;
|
|
$this->Tree->initialize(2, 2);
|
|
$this->Tree->id = null;
|
|
|
|
$parent = $this->Tree->find('first', array('conditions' => array($modelClass . '.name' => '1. Root')));
|
|
$parentId = $parent[$modelClass]['id'];
|
|
|
|
$data = $this->Tree->find('first', array('fields' => array('id'), 'conditions' => array($modelClass . '.name' => '1.1.1')));
|
|
$this->Tree->id = $data[$modelClass]['id'];
|
|
$this->Tree->whitelist = array($parentField, 'name', 'description');
|
|
$this->Tree->saveField($parentField, $parentId);
|
|
|
|
$result = $this->Tree->children($parentId, true, array('name', $leftField, $rightField));
|
|
$expected = array(array($modelClass => array('name' => '1.1', $leftField => 2, $rightField => 5)),
|
|
array($modelClass => array('name' => '1.2', $leftField => 6, $rightField => 11)),
|
|
array($modelClass => array('name' => '1.1.1', $leftField => 12, $rightField => 13)));
|
|
$this->assertEquals($expected, $result);
|
|
$this->assertTrue($this->Tree->verify());
|
|
}
|
|
|
|
/**
|
|
* testRemoveNoChildren method
|
|
*
|
|
* @return void
|
|
*/
|
|
public function testRemoveNoChildren() {
|
|
extract($this->settings);
|
|
$this->Tree = new $modelClass();
|
|
$this->Tree->order = null;
|
|
$this->Tree->initialize(2, 2);
|
|
$initialCount = $this->Tree->find('count');
|
|
|
|
$result = $this->Tree->findByName('1.1.1');
|
|
$this->Tree->removeFromTree($result[$modelClass]['id']);
|
|
|
|
$laterCount = $this->Tree->find('count');
|
|
$this->assertEquals($initialCount, $laterCount);
|
|
|
|
$nodes = $this->Tree->find('list', array('order' => $leftField));
|
|
$expects = array(
|
|
'1. Root',
|
|
'1.1',
|
|
'1.1.2',
|
|
'1.2',
|
|
'1.2.1',
|
|
'1.2.2',
|
|
'1.1.1',
|
|
);
|
|
|
|
$this->assertEquals(array_values($nodes), $expects);
|
|
|
|
$validTree = $this->Tree->verify();
|
|
$this->assertSame($validTree, true);
|
|
}
|
|
|
|
/**
|
|
* testRemoveAndDeleteNoChildren method
|
|
*
|
|
* @return void
|
|
*/
|
|
public function testRemoveAndDeleteNoChildren() {
|
|
extract($this->settings);
|
|
$this->Tree = new $modelClass();
|
|
$this->Tree->order = null;
|
|
$this->Tree->initialize(2, 2);
|
|
$initialCount = $this->Tree->find('count');
|
|
|
|
$result = $this->Tree->findByName('1.1.1');
|
|
$this->Tree->removeFromTree($result[$modelClass]['id'], true);
|
|
|
|
$laterCount = $this->Tree->find('count');
|
|
$this->assertEquals($initialCount - 1, $laterCount);
|
|
|
|
$nodes = $this->Tree->find('list', array('order' => $leftField));
|
|
$expects = array(
|
|
'1. Root',
|
|
'1.1',
|
|
'1.1.2',
|
|
'1.2',
|
|
'1.2.1',
|
|
'1.2.2',
|
|
);
|
|
$this->assertEquals(array_values($nodes), $expects);
|
|
|
|
$validTree = $this->Tree->verify();
|
|
$this->assertSame($validTree, true);
|
|
}
|
|
|
|
/**
|
|
* testChildren method
|
|
*
|
|
* @return void
|
|
*/
|
|
public function testChildren() {
|
|
extract($this->settings);
|
|
$this->Tree = new $modelClass();
|
|
$this->Tree->order = null;
|
|
$this->Tree->initialize(2, 2);
|
|
|
|
$data = $this->Tree->find('first', array('conditions' => array($modelClass . '.name' => '1. Root')));
|
|
$this->Tree->id = $data[$modelClass]['id'];
|
|
|
|
$direct = $this->Tree->children(null, true, array('name', $leftField, $rightField));
|
|
$expects = array(array($modelClass => array('name' => '1.1', $leftField => 2, $rightField => 7)),
|
|
array($modelClass => array('name' => '1.2', $leftField => 8, $rightField => 13)));
|
|
$this->assertEquals($direct, $expects);
|
|
|
|
$total = $this->Tree->children(null, null, array('name', $leftField, $rightField));
|
|
$expects = array(array($modelClass => array('name' => '1.1', $leftField => 2, $rightField => 7)),
|
|
array($modelClass => array('name' => '1.1.1', $leftField => 3, $rightField => 4)),
|
|
array($modelClass => array('name' => '1.1.2', $leftField => 5, $rightField => 6)),
|
|
array($modelClass => array('name' => '1.2', $leftField => 8, $rightField => 13)),
|
|
array($modelClass => array('name' => '1.2.1', $leftField => 9, $rightField => 10)),
|
|
array($modelClass => array('name' => '1.2.2', $leftField => 11, $rightField => 12)));
|
|
$this->assertEquals($total, $expects);
|
|
}
|
|
|
|
/**
|
|
* testNoAmbiguousColumn method
|
|
*
|
|
* @return void
|
|
*/
|
|
public function testNoAmbiguousColumn() {
|
|
extract($this->settings);
|
|
$this->Tree = new $modelClass();
|
|
$this->Tree->order = null;
|
|
$this->Tree->initialize(2, 2);
|
|
|
|
$this->Tree->bindModel(array('belongsTo' => array('Dummy' =>
|
|
array('className' => $modelClass, 'foreignKey' => $parentField, 'conditions' => array('Dummy.id' => null)))), false);
|
|
|
|
$data = $this->Tree->find('first', array(
|
|
'conditions' => array($modelClass . '.name' => '1. Root'),
|
|
'recursive' => -1
|
|
));
|
|
$this->Tree->id = $data[$modelClass]['id'];
|
|
|
|
$direct = $this->Tree->children(null, true, array('name', $leftField, $rightField));
|
|
$expects = array(array($modelClass => array('name' => '1.1', $leftField => 2, $rightField => 7)),
|
|
array($modelClass => array('name' => '1.2', $leftField => 8, $rightField => 13)));
|
|
$this->assertEquals($direct, $expects);
|
|
|
|
$total = $this->Tree->children(null, null, array('name', $leftField, $rightField));
|
|
$expects = array(
|
|
array($modelClass => array('name' => '1.1', $leftField => 2, $rightField => 7)),
|
|
array($modelClass => array('name' => '1.1.1', $leftField => 3, $rightField => 4)),
|
|
array($modelClass => array('name' => '1.1.2', $leftField => 5, $rightField => 6)),
|
|
array($modelClass => array('name' => '1.2', $leftField => 8, $rightField => 13)),
|
|
array($modelClass => array('name' => '1.2.1', $leftField => 9, $rightField => 10)),
|
|
array($modelClass => array('name' => '1.2.2', $leftField => 11, $rightField => 12))
|
|
);
|
|
$this->assertEquals($total, $expects);
|
|
}
|
|
|
|
/**
|
|
* testGenerateTreeListWithSelfJoin method
|
|
*
|
|
* @return void
|
|
*/
|
|
public function testGenerateTreeListWithSelfJoin() {
|
|
extract($this->settings);
|
|
$this->Tree = new $modelClass();
|
|
$this->Tree->order = null;
|
|
$this->Tree->bindModel(array('belongsTo' => array('Dummy' =>
|
|
array('className' => $modelClass, 'foreignKey' => $parentField, 'conditions' => array('Dummy.id' => null)))), false);
|
|
$this->Tree->initialize(2, 2);
|
|
|
|
$result = $this->Tree->generateTreeList();
|
|
$expected = array('1. Root', '_1.1', '__1.1.1', '__1.1.2', '_1.2', '__1.2.1', '__1.2.2');
|
|
$this->assertSame(array_values($result), $expected);
|
|
}
|
|
}
|