diff options
Diffstat (limited to 'test/test_queries.php')
-rw-r--r-- | test/test_queries.php | 67 |
1 files changed, 34 insertions, 33 deletions
diff --git a/test/test_queries.php b/test/test_queries.php index a7fbafa..7afc0d5 100644 --- a/test/test_queries.php +++ b/test/test_queries.php @@ -9,114 +9,115 @@ require_once dirname(__FILE__) . "/../idiorm.php"; require_once dirname(__FILE__) . "/test_classes.php"; + // Enable logging + ORM::configure('logging', true); + // Set up the dummy database connection - $db = new DummyPDO(); + $db = new DummyPDO('sqlite::memory:'); ORM::set_db($db); - Tester::set_db($db); ORM::for_table('widget')->find_many(); - $expected = 'SELECT * FROM `widget`'; + $expected = "SELECT * FROM `widget`"; Tester::check_equal("Basic unfiltered query", $expected); ORM::for_table('widget')->find_one(5); - $expected = 'SELECT * FROM `widget` WHERE `id` = "5"'; + $expected = "SELECT * FROM `widget` WHERE `id` = '5'"; Tester::check_equal("Filtering on ID", $expected); ORM::for_table('widget')->count(); - $expected = 'SELECT COUNT(*) AS `count` FROM `widget`'; + $expected = "SELECT COUNT(*) AS `count` FROM `widget`"; Tester::check_equal("COUNT query", $expected); ORM::for_table('widget')->where('name', 'Fred')->find_one(); - $expected = 'SELECT * FROM `widget` WHERE `name` = "Fred"'; + $expected = "SELECT * FROM `widget` WHERE `name` = 'Fred'"; Tester::check_equal("Single where clause", $expected); ORM::for_table('widget')->where('name', 'Fred')->where('age', 10)->find_one(); - $expected = 'SELECT * FROM `widget` WHERE `name` = "Fred" AND `age` = "10"'; + $expected = "SELECT * FROM `widget` WHERE `name` = 'Fred' AND `age` = '10'"; Tester::check_equal("Multiple WHERE clauses", $expected); ORM::for_table('widget')->where_like('name', '%Fred%')->find_one(); - $expected = 'SELECT * FROM `widget` WHERE `name` LIKE "%Fred%"'; + $expected = "SELECT * FROM `widget` WHERE `name` LIKE '%Fred%'"; Tester::check_equal("where_like method", $expected); ORM::for_table('widget')->where_not_like('name', '%Fred%')->find_one(); - $expected = 'SELECT * FROM `widget` WHERE `name` NOT LIKE "%Fred%"'; + $expected = "SELECT * FROM `widget` WHERE `name` NOT LIKE '%Fred%'"; Tester::check_equal("where_not_like method", $expected); ORM::for_table('widget')->where_in('name', array('Fred', 'Joe'))->find_many(); - $expected = 'SELECT * FROM `widget` WHERE `name` IN ("Fred", "Joe")'; + $expected = "SELECT * FROM `widget` WHERE `name` IN ('Fred', 'Joe')"; Tester::check_equal("where_in method", $expected); ORM::for_table('widget')->where_not_in('name', array('Fred', 'Joe'))->find_many(); - $expected = 'SELECT * FROM `widget` WHERE `name` NOT IN ("Fred", "Joe")'; + $expected = "SELECT * FROM `widget` WHERE `name` NOT IN ('Fred', 'Joe')"; Tester::check_equal("where_not_in method", $expected); ORM::for_table('widget')->limit(5)->find_one(); - $expected = 'SELECT * FROM `widget` LIMIT 5'; + $expected = "SELECT * FROM `widget` LIMIT 5"; Tester::check_equal("LIMIT clause", $expected); ORM::for_table('widget')->limit(5)->offset(5)->find_one(); - $expected = 'SELECT * FROM `widget` LIMIT 5 OFFSET 5'; + $expected = "SELECT * FROM `widget` LIMIT 5 OFFSET 5"; Tester::check_equal("LIMIT and OFFSET clause", $expected); ORM::for_table('widget')->order_by_desc('name')->find_one(); - $expected = 'SELECT * FROM `widget` ORDER BY `name` DESC'; + $expected = "SELECT * FROM `widget` ORDER BY `name` DESC"; Tester::check_equal("ORDER BY DESC", $expected); ORM::for_table('widget')->order_by_asc('name')->find_one(); - $expected = 'SELECT * FROM `widget` ORDER BY `name` ASC'; + $expected = "SELECT * FROM `widget` ORDER BY `name` ASC"; Tester::check_equal("ORDER BY ASC", $expected); ORM::for_table('widget')->order_by_asc('name')->order_by_desc('age')->find_one(); - $expected = 'SELECT * FROM `widget` ORDER BY `name` ASC, `age` DESC'; + $expected = "SELECT * FROM `widget` ORDER BY `name` ASC, `age` DESC"; Tester::check_equal("Multiple ORDER BY", $expected); ORM::for_table('widget')->where('name', 'Fred')->limit(5)->offset(5)->order_by_asc('name')->find_many(); - $expected = 'SELECT * FROM `widget` WHERE `name` = "Fred" ORDER BY `name` ASC LIMIT 5 OFFSET 5'; + $expected = "SELECT * FROM `widget` WHERE `name` = 'Fred' ORDER BY `name` ASC LIMIT 5 OFFSET 5"; Tester::check_equal("Complex query", $expected); ORM::for_table('widget')->where_lt('age', 10)->where_gt('age', 5)->find_many(); - $expected = 'SELECT * FROM `widget` WHERE `age` < "10" AND `age` > "5"'; + $expected = "SELECT * FROM `widget` WHERE `age` < '10' AND `age` > '5'"; Tester::check_equal("Less than and greater than", $expected); ORM::for_table('widget')->where_lte('age', 10)->where_gte('age', 5)->find_many(); - $expected = 'SELECT * FROM `widget` WHERE `age` <= "10" AND `age` >= "5"'; + $expected = "SELECT * FROM `widget` WHERE `age` <= '10' AND `age` >= '5'"; Tester::check_equal("Less than or equal and greater than or equal", $expected); ORM::for_table('widget')->where_raw('`name` = ? AND (`age` = ? OR `age` = ?)', array('Fred', 5, 10))->find_many(); - $expected = 'SELECT * FROM `widget` WHERE `name` = "Fred" AND (`age` = "5" OR `age` = "10")'; + $expected = "SELECT * FROM `widget` WHERE `name` = 'Fred' AND (`age` = '5' OR `age` = '10')"; Tester::check_equal("Raw WHERE clause", $expected); ORM::for_table('widget')->where('age', 18)->where_raw('(`name` = ? OR `name` = ?)', array('Fred', 'Bob'))->where('size', 'large')->find_many(); - $expected = 'SELECT * FROM `widget` WHERE `age` = "18" AND (`name` = "Fred" OR `name` = "Bob") AND `size` = "large"'; + $expected = "SELECT * FROM `widget` WHERE `age` = '18' AND (`name` = 'Fred' OR `name` = 'Bob') AND `size` = 'large'"; Tester::check_equal("Raw WHERE clause in method chain", $expected); - ORM::for_table('widget')->raw_query('SELECT `w`.* FROM `widget` w WHERE `name` = ? AND `age` = ?', array('Fred', 5))->find_many(); - $expected = 'SELECT `w`.* FROM `widget` w WHERE `name` = "Fred" AND `age` = "5"'; + $expected = "SELECT `w`.* FROM `widget` w WHERE `name` = 'Fred' AND `age` = '5'"; Tester::check_equal("Raw query", $expected); $widget = ORM::for_table('widget')->create(); $widget->name = "Fred"; $widget->age = 10; $widget->save(); - $expected = 'INSERT INTO `widget` (`name`, `age`) VALUES ("Fred", "10")'; + $expected = "INSERT INTO `widget` (`name`, `age`) VALUES ('Fred', '10')"; Tester::check_equal("Insert data", $expected); $widget = ORM::for_table('widget')->find_one(1); $widget->name = "Fred"; $widget->age = 10; $widget->save(); - $expected = 'UPDATE `widget` SET `name` = "Fred", `age` = "10" WHERE `id` = "1"'; + $expected = "UPDATE `widget` SET `name` = 'Fred', `age` = '10' WHERE `id` = '1'"; Tester::check_equal("Update data", $expected); $widget = ORM::for_table('widget')->find_one(1); $widget->delete(); - $expected = 'DELETE FROM `widget` WHERE `id` = "1"'; + $expected = "DELETE FROM `widget` WHERE `id` = '1'"; Tester::check_equal("Delete data", $expected); ORM::configure('id_column', 'primary_key'); ORM::for_table('widget')->find_one(5); - $expected = 'SELECT * FROM `widget` WHERE `primary_key` = "5"'; + $expected = "SELECT * FROM `widget` WHERE `primary_key` = '5'"; Tester::check_equal("Setting: id_column", $expected); ORM::configure('id_column_overrides', array( @@ -125,27 +126,27 @@ )); ORM::for_table('widget')->find_one(5); - $expected = 'SELECT * FROM `widget` WHERE `widget_id` = "5"'; + $expected = "SELECT * FROM `widget` WHERE `widget_id` = '5'"; Tester::check_equal("Setting: id_column_overrides, first test", $expected); ORM::for_table('widget_handle')->find_one(5); - $expected = 'SELECT * FROM `widget_handle` WHERE `widget_handle_id` = "5"'; + $expected = "SELECT * FROM `widget_handle` WHERE `widget_handle_id` = '5'"; Tester::check_equal("Setting: id_column_overrides, second test", $expected); ORM::for_table('widget_nozzle')->find_one(5); - $expected = 'SELECT * FROM `widget_nozzle` WHERE `primary_key` = "5"'; + $expected = "SELECT * FROM `widget_nozzle` WHERE `primary_key` = '5'"; Tester::check_equal("Setting: id_column_overrides, third test", $expected); ORM::for_table('widget')->use_id_column('new_id')->find_one(5); - $expected = 'SELECT * FROM `widget` WHERE `new_id` = "5"'; + $expected = "SELECT * FROM `widget` WHERE `new_id` = '5'"; Tester::check_equal("Instance ID column, first test", $expected); ORM::for_table('widget_handle')->use_id_column('new_id')->find_one(5); - $expected = 'SELECT * FROM `widget_handle` WHERE `new_id` = "5"'; + $expected = "SELECT * FROM `widget_handle` WHERE `new_id` = '5'"; Tester::check_equal("Instance ID column, second test", $expected); ORM::for_table('widget_nozzle')->use_id_column('new_id')->find_one(5); - $expected = 'SELECT * FROM `widget_nozzle` WHERE `new_id` = "5"'; + $expected = "SELECT * FROM `widget_nozzle` WHERE `new_id` = '5'"; Tester::check_equal("Instance ID column, third test", $expected); Tester::report(); |