2009-04-30 07:54:54 +02:00
|
|
|
<?php
|
|
|
|
/**
|
|
|
|
* @package sapphire
|
|
|
|
* @subpackage tests
|
|
|
|
*/
|
|
|
|
class ComplexTableFieldTest extends FunctionalTest {
|
|
|
|
|
|
|
|
static $fixture_file = 'sapphire/tests/forms/ComplexTableFieldTest.yml';
|
|
|
|
|
|
|
|
/**
|
|
|
|
* An instance of {@link Controller} used for
|
|
|
|
* running tests against.
|
|
|
|
*
|
|
|
|
* @var Controller object
|
|
|
|
*/
|
|
|
|
protected $controller;
|
|
|
|
|
|
|
|
function setUp() {
|
|
|
|
parent::setUp();
|
|
|
|
|
|
|
|
$this->controller = new ComplexTableFieldTest_Controller();
|
2009-04-30 09:50:14 +02:00
|
|
|
$this->manyManyForm = $this->controller->ManyManyForm();
|
2009-04-30 07:54:54 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
function testCorrectNumberOfRowsInTable() {
|
2009-04-30 09:50:14 +02:00
|
|
|
$field = $this->manyManyForm->dataFieldByName('Players');
|
2009-04-30 07:54:54 +02:00
|
|
|
$parser = new CSSContentParser($field->FieldHolder());
|
|
|
|
|
|
|
|
$this->assertEquals(count($parser->getBySelector('tbody tr')), 2, 'There are 2 players (rows) in the table');
|
|
|
|
$this->assertEquals($field->Items()->Count(), 2, 'There are 2 CTF items in the DataObjectSet');
|
|
|
|
}
|
|
|
|
|
2009-05-01 05:55:43 +02:00
|
|
|
function testAddingManyManyNewPlayer() {
|
2009-04-30 07:54:54 +02:00
|
|
|
$team = DataObject::get_one('ComplexTableFieldTest_Team', "Name = 'The Awesome People'");
|
|
|
|
|
2009-04-30 09:50:14 +02:00
|
|
|
$this->post('ComplexTableFieldTest_Controller/ManyManyForm/field/Players/AddForm', array(
|
2009-04-30 07:54:54 +02:00
|
|
|
'Name' => 'Bobby Joe',
|
|
|
|
'ctf' => array(
|
|
|
|
'ClassName' => 'ComplexTableFieldTest_Player',
|
|
|
|
'manyManyRelation' => 'Players',
|
|
|
|
'parentClass' => 'ComplexTableFieldTest_Team',
|
|
|
|
'sourceID' => $team->ID
|
|
|
|
)
|
|
|
|
));
|
|
|
|
|
|
|
|
$newPlayer = DataObject::get_one('ComplexTableFieldTest_Player', "Name = 'Bobby Joe'");
|
|
|
|
$this->assertNotNull($newPlayer, 'A new ComplexTableFieldTest_Player record was created, Name = "Bobby Joe"');
|
|
|
|
$teams = $newPlayer->getManyManyComponents('Teams');
|
|
|
|
$this->assertEquals($teams->Count(), 1, 'Automatic many-many relation was set correctly on the new player');
|
|
|
|
}
|
2009-04-30 09:50:14 +02:00
|
|
|
|
|
|
|
function testAddingHasManyData() {
|
|
|
|
$team = DataObject::get_one('ComplexTableFieldTest_Team', "Name = 'The Awesome People'");
|
|
|
|
|
|
|
|
$this->post('ComplexTableFieldTest_Controller/HasManyForm/field/Sponsors/AddForm', array(
|
|
|
|
'Name' => 'Jim Beam',
|
|
|
|
'ctf' => array(
|
|
|
|
'ClassName' => 'ComplexTableFieldTest_Sponsor',
|
|
|
|
'hasManyRelation' => 'Sponsors',
|
|
|
|
'parentClass' => 'ComplexTableFieldTest_Team',
|
|
|
|
'sourceID' => $team->ID
|
|
|
|
)
|
|
|
|
));
|
|
|
|
|
|
|
|
$newSponsor = DataObject::get_one('ComplexTableFieldTest_Sponsor', "Name = 'Jim Beam'");
|
|
|
|
$this->assertNotNull($newSponsor, 'A new ComplexTableFieldTest_Sponsor record was created, Name = "Jim Beam"');
|
2009-05-25 10:59:13 +02:00
|
|
|
$this->assertEquals($newSponsor->TeamID, $team->ID, 'Automatic has-many/has-one relation was set correctly on the sponsor');
|
|
|
|
$this->assertEquals($newSponsor->getComponent('Team')->ID, $team->ID, 'Automatic has-many/has-one relation was set correctly on the sponsor');
|
2009-04-30 09:50:14 +02:00
|
|
|
|
2009-05-25 10:59:13 +02:00
|
|
|
$team = DataObject::get_by_id('ComplexTableFieldTest_Team', $team->ID);
|
|
|
|
$sponsor = DataObject::get_by_id('ComplexTableFieldTest_Sponsor', $newSponsor->ID);
|
2009-04-30 09:50:14 +02:00
|
|
|
$this->assertEquals($newSponsor->ID, $sponsor->ID, 'The sponsor is the same as the one we added');
|
2009-05-25 10:59:13 +02:00
|
|
|
$foundTeam = $sponsor->getComponent('Team');
|
|
|
|
$this->assertEquals($team->ID, $foundTeam->ID, 'The team ID matches on the other side of the relation');
|
2009-04-30 09:50:14 +02:00
|
|
|
}
|
|
|
|
|
2009-04-30 07:54:54 +02:00
|
|
|
}
|
|
|
|
class ComplexTableFieldTest_Controller extends Controller {
|
|
|
|
|
|
|
|
function Link($action = null) {
|
|
|
|
return "ComplexTableFieldTest_Controller/$action";
|
|
|
|
}
|
|
|
|
|
2009-04-30 09:50:14 +02:00
|
|
|
function ManyManyForm() {
|
2009-04-30 07:54:54 +02:00
|
|
|
$team = DataObject::get_one('ComplexTableFieldTest_Team', "Name = 'The Awesome People'");
|
|
|
|
|
|
|
|
$playersField = new ComplexTableField(
|
|
|
|
$this,
|
|
|
|
'Players',
|
|
|
|
'ComplexTableFieldTest_Player',
|
|
|
|
ComplexTableFieldTest_Player::$summary_fields,
|
|
|
|
'getCMSFields'
|
|
|
|
);
|
|
|
|
|
|
|
|
$playersField->setParentClass('ComplexTableFieldTest_Team');
|
|
|
|
|
|
|
|
$form = new Form(
|
|
|
|
$this,
|
2009-04-30 09:50:14 +02:00
|
|
|
'ManyManyForm',
|
2009-04-30 07:54:54 +02:00
|
|
|
new FieldSet(
|
|
|
|
new HiddenField('ID', '', $team->ID),
|
|
|
|
$playersField
|
|
|
|
),
|
|
|
|
new FieldSet(
|
|
|
|
new FormAction('doSubmit', 'Submit')
|
|
|
|
)
|
|
|
|
);
|
|
|
|
|
|
|
|
$form->disableSecurityToken();
|
|
|
|
|
|
|
|
return $form;
|
|
|
|
}
|
2009-04-30 09:50:14 +02:00
|
|
|
|
|
|
|
function HasManyForm() {
|
|
|
|
$team = DataObject::get_one('ComplexTableFieldTest_Team', "Name = 'The Awesome People'");
|
|
|
|
|
|
|
|
$sponsorsField = new ComplexTableField(
|
|
|
|
$this,
|
|
|
|
'Sponsors',
|
|
|
|
'ComplexTableFieldTest_Sponsor',
|
|
|
|
ComplexTableFieldTest_Sponsor::$summary_fields,
|
|
|
|
'getCMSFields'
|
|
|
|
);
|
|
|
|
|
|
|
|
$sponsorsField->setParentClass('ComplexTableFieldTest_Team');
|
|
|
|
|
|
|
|
$form = new Form(
|
|
|
|
$this,
|
|
|
|
'HasManyForm',
|
|
|
|
new FieldSet(
|
|
|
|
new HiddenField('ID', '', $team->ID),
|
|
|
|
$sponsorsField
|
|
|
|
),
|
|
|
|
new FieldSet(
|
|
|
|
new FormAction('doSubmit', 'Submit')
|
|
|
|
)
|
|
|
|
);
|
|
|
|
|
|
|
|
$form->disableSecurityToken();
|
|
|
|
|
|
|
|
return $form;
|
|
|
|
}
|
2009-04-30 07:54:54 +02:00
|
|
|
|
|
|
|
}
|
|
|
|
class ComplexTableFieldTest_Player extends DataObject implements TestOnly {
|
|
|
|
|
|
|
|
public static $db = array(
|
|
|
|
'Name' => 'Varchar(100)'
|
|
|
|
);
|
|
|
|
|
|
|
|
public static $many_many = array(
|
|
|
|
'Teams' => 'ComplexTableFieldTest_Team'
|
|
|
|
);
|
|
|
|
|
|
|
|
public static $many_many_extraFields = array(
|
|
|
|
'Teams' => array(
|
2009-04-30 23:14:34 +02:00
|
|
|
'Role' => 'Varchar(100)',
|
|
|
|
'Position' => "Enum('Admin,Player,Coach','Admin')",
|
|
|
|
'DateJoined' => 'Date'
|
2009-04-30 07:54:54 +02:00
|
|
|
)
|
|
|
|
);
|
|
|
|
|
|
|
|
}
|
|
|
|
class ComplexTableFieldTest_Team extends DataObject implements TestOnly {
|
|
|
|
|
|
|
|
public static $db = array(
|
|
|
|
'Name' => 'Varchar(100)'
|
|
|
|
);
|
|
|
|
|
|
|
|
public static $belongs_many_many = array(
|
|
|
|
'Players' => 'ComplexTableFieldTest_Player'
|
|
|
|
);
|
|
|
|
|
2009-04-30 09:50:14 +02:00
|
|
|
public static $has_many = array(
|
|
|
|
'Sponsors' => 'ComplexTableFieldTest_Sponsor'
|
|
|
|
);
|
|
|
|
|
|
|
|
}
|
|
|
|
class ComplexTableFieldTest_Sponsor extends DataObject implements TestOnly {
|
|
|
|
|
|
|
|
public static $db = array(
|
|
|
|
'Name' => 'Varchar(100)'
|
|
|
|
);
|
|
|
|
|
|
|
|
public static $has_one = array(
|
|
|
|
'Team' => 'ComplexTableFieldTest_Team'
|
|
|
|
);
|
|
|
|
|
2009-04-30 07:54:54 +02:00
|
|
|
}
|
|
|
|
?>
|