summaryrefslogtreecommitdiff
path: root/modules/gallery_unit_test
diff options
context:
space:
mode:
Diffstat (limited to 'modules/gallery_unit_test')
-rw-r--r--modules/gallery_unit_test/controllers/gallery_unit_test.php6
-rw-r--r--modules/gallery_unit_test/helpers/test.php85
-rw-r--r--modules/gallery_unit_test/libraries/Gallery_Unit_Test_Case.php36
-rw-r--r--modules/gallery_unit_test/views/kohana/error.php6
-rw-r--r--modules/gallery_unit_test/views/kohana_error_page.php18
-rw-r--r--modules/gallery_unit_test/views/kohana_unit_test_cli.php6
6 files changed, 139 insertions, 18 deletions
diff --git a/modules/gallery_unit_test/controllers/gallery_unit_test.php b/modules/gallery_unit_test/controllers/gallery_unit_test.php
index 498dd756..e05fcbaa 100644
--- a/modules/gallery_unit_test/controllers/gallery_unit_test.php
+++ b/modules/gallery_unit_test/controllers/gallery_unit_test.php
@@ -127,6 +127,12 @@ class Gallery_Unit_Test_Controller extends Controller {
$filter = count($_SERVER["argv"]) > 2 ? $_SERVER["argv"][2] : null;
print new Unit_Test($modules, $filter);
+ } catch (ORM_Validation_Exception $e) {
+ print "Validation Exception: {$e->getMessage()}\n";
+ print $e->getTraceAsString() . "\n";
+ foreach ($e->validation->errors() as $field => $msg) {
+ print "$field: $msg\n";
+ }
} catch (Exception $e) {
print "Exception: {$e->getMessage()}\n";
print $e->getTraceAsString() . "\n";
diff --git a/modules/gallery_unit_test/helpers/test.php b/modules/gallery_unit_test/helpers/test.php
new file mode 100644
index 00000000..3e116808
--- /dev/null
+++ b/modules/gallery_unit_test/helpers/test.php
@@ -0,0 +1,85 @@
+<?php defined("SYSPATH") or die("No direct script access.");
+/**
+ * Gallery - a web based photo album viewer and editor
+ * Copyright (C) 2000-2009 Bharat Mediratta
+ *
+ * This program is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation; either version 2 of the License, or (at
+ * your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful, but
+ * WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ * General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston, MA 02110-1301, USA.
+ */
+class test_Core {
+ static function random_album_unsaved($parent=null) {
+ $rand = rand();
+
+ $album = ORM::factory("item");
+ $album->type = "album";
+ $album->parent_id = $parent ? $parent->id : 1;
+ $album->name = "name_$rand";
+ $album->title = "title_$rand";
+ return $album;
+ }
+
+ static function random_album($parent=null) {
+ return test::random_album_unsaved($parent)->save()->reload();
+ }
+
+ static function random_photo_unsaved($parent=null) {
+ $rand = rand();
+ $photo = ORM::factory("item");
+ $photo->type = "photo";
+ $photo->parent_id = $parent ? $parent->id : 1;
+ $photo->set_data_file(MODPATH . "gallery/tests/test.jpg");
+ $photo->name = "name_$rand.jpg";
+ $photo->title = "title_$rand";
+ return $photo;
+ }
+
+ static function random_photo($parent=null) {
+ return test::random_photo_unsaved($parent)->save()->reload();
+ }
+
+ static function random_user($password="password") {
+ $rand = "name_" . rand();
+ return identity::create_user($rand, $rand, $password, "$rand@rand.com");
+ }
+
+ static function random_group() {
+ return identity::create_group((string)rand());
+ }
+
+ static function random_name($item=null) {
+ $rand = "name_" . rand();
+ if ($item && $item->is_photo()) {
+ $rand .= ".jpg";
+ }
+ return $rand;
+ }
+
+ static function starts_with($outer, $inner) {
+ return strpos($outer, $inner) === 0;
+ }
+
+ static function call_and_capture($callback) {
+ ob_start();
+ call_user_func($callback);
+ return ob_get_clean();
+ }
+
+ static function random_tag() {
+ $tag = ORM::factory("tag");
+ $tag->name = (string)rand();
+
+ // Reload so that ORM coerces all fields into strings.
+ return $tag->save()->reload();
+ }
+}
diff --git a/modules/gallery_unit_test/libraries/Gallery_Unit_Test_Case.php b/modules/gallery_unit_test/libraries/Gallery_Unit_Test_Case.php
new file mode 100644
index 00000000..509b4125
--- /dev/null
+++ b/modules/gallery_unit_test/libraries/Gallery_Unit_Test_Case.php
@@ -0,0 +1,36 @@
+<?php defined("SYSPATH") or die("No direct script access.");
+/**
+ * Gallery - a web based photo album viewer and editor
+ * Copyright (C) 2000-2009 Bharat Mediratta
+ *
+ * This program is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation; either version 2 of the License, or (at
+ * your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful, but
+ * WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ * General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston, MA 02110-1301, USA.
+ */
+class Gallery_Unit_Test_Case extends Unit_Test_Case {
+ public function assert_equal_array($expected, $actual, $debug=null) {
+ if ($expected !== $actual) {
+ throw new Kohana_Unit_Test_Exception(
+ sprintf("Expected (%s) %s but received (%s) %s\n Diff: %s",
+ gettype($expected), var_export($expected, true),
+ gettype($actual), var_export($actual, true),
+ diff::compare(var_export($expected, true), var_export($actual, true))),
+ $debug);
+ }
+ return $this;
+ }
+
+ public function assert_array_equal_to_json($expected_array, $actual_json, $debug=null) {
+ return $this->assert_equal_array($expected_array, json_decode($actual_json, true), $debug);
+ }
+}
diff --git a/modules/gallery_unit_test/views/kohana/error.php b/modules/gallery_unit_test/views/kohana/error.php
new file mode 100644
index 00000000..079a279b
--- /dev/null
+++ b/modules/gallery_unit_test/views/kohana/error.php
@@ -0,0 +1,6 @@
+<?php defined("SYSPATH") or die("No direct script access.") ?>
+<?
+echo $e->getMessage(), "\n";
+echo $e->getFile(), ":", $e->getLine(), "\n";
+echo $e->getTraceAsString(), "\n";
+
diff --git a/modules/gallery_unit_test/views/kohana_error_page.php b/modules/gallery_unit_test/views/kohana_error_page.php
deleted file mode 100644
index c0ae7173..00000000
--- a/modules/gallery_unit_test/views/kohana_error_page.php
+++ /dev/null
@@ -1,18 +0,0 @@
-<?php defined("SYSPATH") or die("No direct script access.") ?>
-<?
-echo $error, "\n\n";
-echo wordwrap($description, 80), "\n\n";
-if (!empty($line) && !empty($file)) {
- echo $file, "[", $line, "]:\n";
-}
-echo $message, "\n\n";
-
-if (!empty($trace)) {
- $trace = preg_replace(
- array('/<li>/', '/<(.*?)>/', '/&gt;/'),
- array(" ", '', '>'),
- $trace);
- echo "Stack Trace:\n";
- echo $trace, "\n";
-}
-
diff --git a/modules/gallery_unit_test/views/kohana_unit_test_cli.php b/modules/gallery_unit_test/views/kohana_unit_test_cli.php
index 3203ee44..a0de0f52 100644
--- a/modules/gallery_unit_test/views/kohana_unit_test_cli.php
+++ b/modules/gallery_unit_test/views/kohana_unit_test_cli.php
@@ -57,6 +57,12 @@ foreach ($results as $class => $methods) {
if ($result->getMessage()) {
echo " ", $result->getMessage(), "\n";
}
+ if ($result instanceof ORM_Validation_Exception) {
+ echo " Validation errors:\n";
+ foreach ($result->validation->errors() as $key => $value) {
+ echo " $key: $value\n";
+ }
+ }
echo " ", $result->getFile(), " (Line ", $result->getLine(), ")\n";
echo "\n";
echo $result->getTraceAsString(), "\n";