blob: 54b2a4e1863d32b9eb72b600567172d729bb8208 [file] [log] [blame]
Taufan Adityad6b41bb2012-05-04 15:05:22 +07001<?php
2
3class Join_test extends CI_TestCase {
4
5 /**
6 * @var object Database/Query Builder holder
7 */
8 protected $db;
9
10 public function set_up()
11 {
12 $this->db = Mock_Database_Schema_Skeleton::init(DB_DRIVER);
13
14 Mock_Database_Schema_Skeleton::create_tables();
15 Mock_Database_Schema_Skeleton::create_data();
16 }
17
18 // ------------------------------------------------------------------------
19
20 /**
21 * @see ./mocks/schema/skeleton.php
22 */
23 public function test_join_simple()
24 {
25 $job_user = $this->db->select('job.id as job_id, job.name as job_name, user.id as user_id, user.name as user_name')
26 ->from('job')
27 ->join('user', 'user.id = job.id')
28 ->get()
29 ->result_array();
30
31 // Check the result
32 $this->assertEquals('1', $job_user[0]['job_id']);
33 $this->assertEquals('1', $job_user[0]['user_id']);
34 $this->assertEquals('Derek Jones', $job_user[0]['user_name']);
35 $this->assertEquals('Developer', $job_user[0]['job_name']);
36 }
Andrey Andreevc1862882012-06-09 23:16:58 +030037
Andrey Andreev49aa45b2012-07-06 16:22:21 +030038 // ------------------------------------------------------------------------
39
Andrey Andreevc6011942016-02-11 23:49:37 +020040 public function test_join_escape_is_null()
41 {
42 $expected = 'SELECT '.$this->db->escape_identifiers('field')
43 ."\nFROM ".$this->db->escape_identifiers('table1')
44 ."\nJOIN ".$this->db->escape_identifiers('table2').' ON '.$this->db->escape_identifiers('field').' IS NULL';
45
46 $this->assertEquals(
47 $expected,
48 $this->db->select('field')->from('table1')->join('table2', 'field IS NULL')->get_compiled_select()
49 );
50
51 $expected = 'SELECT '.$this->db->escape_identifiers('field')
52 ."\nFROM ".$this->db->escape_identifiers('table1')
53 ."\nJOIN ".$this->db->escape_identifiers('table2').' ON '.$this->db->escape_identifiers('field').' IS NOT NULL';
54
55 $this->assertEquals(
56 $expected,
57 $this->db->select('field')->from('table1')->join('table2', 'field IS NOT NULL')->get_compiled_select()
58 );
59 }
60
61 // ------------------------------------------------------------------------
62
Andrey Andreev49aa45b2012-07-06 16:22:21 +030063 public function test_join_escape_multiple_conditions()
64 {
65 // We just need a valid query produced, not one that makes sense
66 $fields = array($this->db->protect_identifiers('table1.field1'), $this->db->protect_identifiers('table2.field2'));
67
68 $expected = 'SELECT '.implode(', ', $fields)
69 ."\nFROM ".$this->db->escape_identifiers('table1')
70 ."\nLEFT JOIN ".$this->db->escape_identifiers('table2').' ON '.implode(' = ', $fields)
71 .' AND '.$fields[0]." = 'foo' AND ".$fields[1].' = 0';
72
73 $result = $this->db->select('table1.field1, table2.field2')
74 ->from('table1')
75 ->join('table2', "table1.field1 = table2.field2 AND table1.field1 = 'foo' AND table2.field2 = 0", 'LEFT')
76 ->get_compiled_select();
77
Andrey Andreevb6490f52012-07-06 16:32:16 +030078 $this->assertEquals($expected, $result);
Andrey Andreev49aa45b2012-07-06 16:22:21 +030079 }
80
Andrey Andreev95bd7632016-02-05 14:15:45 +020081 // ------------------------------------------------------------------------
82
83 public function test_join_escape_multiple_conditions_with_parentheses()
84 {
85 // We just need a valid query produced, not one that makes sense
86 $fields = array($this->db->protect_identifiers('table1.field1'), $this->db->protect_identifiers('table2.field2'));
87
88 $expected = 'SELECT '.implode(', ', $fields)
89 ."\nFROM ".$this->db->escape_identifiers('table1')
90 ."\nRIGHT JOIN ".$this->db->escape_identifiers('table2').' ON '.implode(' = ', $fields)
Andrey Andreevc6011942016-02-11 23:49:37 +020091 .' AND ('.$fields[0]." = 'foo' OR ".$fields[1].' IS NULL)';
Andrey Andreev95bd7632016-02-05 14:15:45 +020092
93 $result = $this->db->select('table1.field1, table2.field2')
94 ->from('table1')
Andrey Andreevc6011942016-02-11 23:49:37 +020095 ->join('table2', "table1.field1 = table2.field2 AND (table1.field1 = 'foo' OR table2.field2 IS NULL)", 'RIGHT')
Andrey Andreev95bd7632016-02-05 14:15:45 +020096 ->get_compiled_select();
97
98 $this->assertEquals($expected, $result);
99 }
100
Taufan Adityad6b41bb2012-05-04 15:05:22 +0700101}