Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
D
doctrine-dbal
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Tomáš Trávníček
doctrine-dbal
Commits
4d527b93
Commit
4d527b93
authored
Oct 24, 2007
by
tamcy
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
add test case for ticket #438
parent
c610ba0a
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
159 additions
and
0 deletions
+159
-0
438TestCase.php
tests/Ticket/438TestCase.php
+159
-0
No files found.
tests/Ticket/438TestCase.php
0 → 100644
View file @
4d527b93
<?php
/*
* $Id$
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
* OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*
* This software consists of voluntary contributions made by many individuals
* and is licensed under the LGPL. For more information, see
* <http://www.phpdoctrine.com>.
*/
/**
* Doctrine_Ticket_438_TestCase
*
* @package Doctrine
* @author Tamcy <7am.online@gmail.com>
* @license http://www.opensource.org/licenses/lgpl-license.php LGPL
* @category Object Relational Mapping
* @link www.phpdoctrine.com
* @since 1.0
* @version $Revision$
*/
class
Doctrine_Ticket_438_TestCase
extends
Doctrine_UnitTestCase
{
public
function
prepareData
()
{
}
public
function
prepareTables
()
{
$this
->
tables
=
array
(
'T438_Student'
,
'T438_Course'
,
'T438_StudentCourse'
);
parent
::
prepareTables
();
}
protected
function
newCourse
(
$id
,
$name
)
{
$course
=
new
T438_Course
();
$course
->
id
=
$id
;
$course
->
name
=
$name
;
$course
->
save
();
return
$course
;
}
protected
function
newStudent
(
$id
,
$name
)
{
$u
=
new
T438_Student
();
$u
->
id
=
$id
;
$u
->
name
=
$name
;
$u
->
save
();
return
$u
;
}
protected
function
newStudentCourse
(
$student
,
$course
)
{
$sc
=
new
T438_StudentCourse
;
$sc
->
student_id
=
$student
->
id
;
$sc
->
course_id
=
$course
->
id
;
$sc
->
save
();
return
$sc
;
}
public
function
testTicket
()
{
$student1
=
$this
->
newStudent
(
'07090002'
,
'First Student'
);
$course1
=
$this
->
newCourse
(
'MATH001'
,
'Maths'
);
$course2
=
$this
->
newCourse
(
'ENG002'
,
'English Literature'
);
$this
->
newStudentCourse
(
$student1
,
$course1
);
$this
->
newStudentCourse
(
$student1
,
$course2
);
// 1. Fetch relationship on demand
$q
=
new
Doctrine_Query
();
$q
->
from
(
'T438_StudentCourse sc'
)
->
where
(
'sc.student_id = ? AND sc.course_id = ?'
,
array
(
'07090002'
,
'MATH001'
));
$record
=
$q
->
execute
()
->
getFirst
();
$this
->
assertEqual
(
$record
->
student_id
,
'07090002'
);
$this
->
assertEqual
(
$record
->
course_id
,
'MATH001'
);
$this
->
assertEqual
(
$record
->
get
(
'Student'
)
->
id
,
'07090002'
);
$this
->
assertEqual
(
$record
->
get
(
'Course'
)
->
id
,
'MATH001'
);
// 2. Fetch relationship in single query
$q
=
new
Doctrine_Query
();
$q
->
select
(
'sc.*, s.*, c.*'
)
->
from
(
'T438_StudentCourse sc, sc.Student s, sc.Course c'
)
->
where
(
'sc.student_id = ? AND sc.course_id = ?'
,
array
(
'07090002'
,
'MATH001'
));
$record
=
$q
->
execute
()
->
getFirst
();
$this
->
assertEqual
(
$record
->
student_id
,
'07090002'
);
$this
->
assertEqual
(
$record
->
course_id
,
'MATH001'
);
$this
->
assertEqual
(
$record
->
get
(
'Student'
)
->
id
,
'07090002'
);
$this
->
assertEqual
(
$record
->
get
(
'Course'
)
->
id
,
'MATH001'
);
}
}
class
T438_Student
extends
Doctrine_Record
{
public
function
setTableDefinition
()
{
$this
->
setTableName
(
't438_student_record'
);
$this
->
hasColumn
(
's_id as id'
,
'varchar'
,
30
,
array
(
'primary'
=>
true
,));
$this
->
hasColumn
(
's_name as name'
,
'varchar'
,
50
,
array
());
}
public
function
setUp
()
{
$this
->
hasMany
(
'T438_Course as StudyCourses'
,
array
(
'refClass'
=>
'T438_StudentCourse'
,
'local'
=>
'sc_student_id'
,
'foreign'
=>
'sc_course_id'
));
}
}
class
T438_Course
extends
Doctrine_Record
{
public
function
setTableDefinition
()
{
$this
->
setTableName
(
't438_course'
);
$this
->
hasColumn
(
'c_id as id'
,
'varchar'
,
20
,
array
(
'primary'
=>
true
,));
$this
->
hasColumn
(
'c_name as name'
,
'varchar'
,
50
,
array
());
}
public
function
setUp
()
{
$this
->
hasMany
(
'T438_Student as Students'
,
array
(
'refClass'
=>
'T438_StudentCourse'
,
'local'
=>
'sc_course_id'
,
'foreign'
=>
'sc_student_id'
));
}
}
class
T438_StudentCourse
extends
Doctrine_Record
{
public
function
setTableDefinition
()
{
$this
->
setTableName
(
't438_student_course'
);
$this
->
hasColumn
(
'sc_student_id as student_id'
,
'varchar'
,
30
,
array
(
'primary'
=>
true
,));
$this
->
hasColumn
(
'sc_course_id as course_id'
,
'varchar'
,
20
,
array
(
'primary'
=>
true
,));
$this
->
hasColumn
(
'sc_remark as remark'
,
'varchar'
,
500
,
array
());
}
public
function
setUp
()
{
$this
->
ownsOne
(
'T438_Student as Student'
,
array
(
'local'
=>
'sc_student_id'
,
'foreign'
=>
's_id'
));
$this
->
ownsOne
(
'T438_Course as Course'
,
array
(
'local'
=>
'sc_course_id'
,
'foreign'
=>
'c_id'
));
}
}
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment