diff options
author | Simon Holywell <[email protected]> | 2012-11-12 13:18:47 +0000 |
---|---|---|
committer | Simon Holywell <[email protected]> | 2012-11-12 13:18:54 +0000 |
commit | 004bfacb21b529f252b2cc22c6c84445280d38ff (patch) | |
tree | 23a376bbebe6882fee3efd7b06ca764855ccf037 /test/test_queries.php | |
parent | b8795513004394dac0c9162fe05fb6b5ee4093d9 (diff) |
Add set_expr() closing issues #43 & #59
Diffstat (limited to 'test/test_queries.php')
-rw-r--r-- | test/test_queries.php | 31 |
1 files changed, 31 insertions, 0 deletions
diff --git a/test/test_queries.php b/test/test_queries.php index 693b898..b0dc88b 100644 --- a/test/test_queries.php +++ b/test/test_queries.php @@ -238,6 +238,14 @@ $expected = "INSERT INTO `widget` (`name`, `age`) VALUES ('Fred', '10')"; Tester::check_equal("Insert data", $expected); + $widget = ORM::for_table('widget')->create(); + $widget->name = "Fred"; + $widget->age = 10; + $widget->set_expr('added', 'NOW()'); + $widget->save(); + $expected = "INSERT INTO `widget` (`name`, `age`, `added`) VALUES ('Fred', '10', NOW())"; + Tester::check_equal("Insert data containing an expression", $expected); + $widget = ORM::for_table('widget')->find_one(1); $widget->name = "Fred"; $widget->age = 10; @@ -246,12 +254,35 @@ Tester::check_equal("Update data", $expected); $widget = ORM::for_table('widget')->find_one(1); + $widget->name = "Fred"; + $widget->age = 10; + $widget->set_expr('added', 'NOW()'); + $widget->save(); + $expected = "UPDATE `widget` SET `name` = 'Fred', `age` = '10', `added` = NOW() WHERE `id` = '1'"; + Tester::check_equal("Update data containing an expression", $expected); + + $widget = ORM::for_table('widget')->find_one(1); $widget->set(array("name" => "Fred", "age" => 10)); $widget->save(); $expected = "UPDATE `widget` SET `name` = 'Fred', `age` = '10' WHERE `id` = '1'"; Tester::check_equal("Update multiple fields", $expected); $widget = ORM::for_table('widget')->find_one(1); + $widget->set(array("name" => "Fred", "age" => 10)); + $widget->set_expr(array("added" => "NOW()", "lat_long" => "GeomFromText('POINT(1.2347 2.3436)')")); + $widget->save(); + $expected = "UPDATE `widget` SET `name` = 'Fred', `age` = '10', `added` = NOW(), `lat_long` = GeomFromText('POINT(1.2347 2.3436)') WHERE `id` = '1'"; + Tester::check_equal("Update multiple fields containing an expression", $expected); + + $widget = ORM::for_table('widget')->find_one(1); + $widget->set(array("name" => "Fred", "age" => 10)); + $widget->set_expr(array("added" => "NOW()", "lat_long" => "GeomFromText('POINT(1.2347 2.3436)')")); + $widget->lat_long = 'unknown'; + $widget->save(); + $expected = "UPDATE `widget` SET `name` = 'Fred', `age` = '10', `added` = NOW(), `lat_long` = 'unknown' WHERE `id` = '1'"; + Tester::check_equal("Update multiple fields containing an expression (override previously set expression with plain value)", $expected); + + $widget = ORM::for_table('widget')->find_one(1); $widget->delete(); $expected = "DELETE FROM `widget` WHERE `id` = '1'"; Tester::check_equal("Delete data", $expected); |