From f1d25bcc20467ca3fb58576b952e64283568f265 Mon Sep 17 00:00:00 2001
From: "mariano.iglesias"
Date: Sat, 14 Mar 2009 22:24:42 +0000
Subject: [PATCH 01/67] Removing need to explicitly set IDs for Containable
test, added in r6989
git-svn-id: https://svn.cakephp.org/repo/branches/1.2.x.x@8098 3807eeeb-6ff5-0310-8944-8be069107fe0
---
.../libs/model/behaviors/containable.test.php | 21 ++++++++++++-------
cake/tests/fixtures/comment_fixture.php | 12 +++++------
2 files changed, 20 insertions(+), 13 deletions(-)
diff --git a/cake/tests/cases/libs/model/behaviors/containable.test.php b/cake/tests/cases/libs/model/behaviors/containable.test.php
index 5c7b23e6e..9a7a2f4e1 100644
--- a/cake/tests/cases/libs/model/behaviors/containable.test.php
+++ b/cake/tests/cases/libs/model/behaviors/containable.test.php
@@ -2868,25 +2868,32 @@ class ContainableTest extends CakeTestCase {
$this->assertEqual($result, $expected);
$result = $this->Article->find('all', array('contain' => array('Comment(comment, published)' => 'Attachment(attachment)', 'User(user)'), 'fields' => array('title')));
+ if (!empty($result)) {
+ foreach($result as $i=>$article) {
+ foreach($article['Comment'] as $j=>$comment) {
+ $result[$i]['Comment'][$j] = array_diff_key($comment, array('id'=>true));
+ }
+ }
+ }
$expected = array(
array(
'Article' => array('title' => 'First Article', 'id' => 1),
'User' => array('user' => 'mariano', 'id' => 1),
'Comment' => array(
- array('comment' => 'First Comment for First Article', 'published' => 'Y', 'id' => 1, 'article_id' => 1, 'Attachment' => array()),
- array('comment' => 'Second Comment for First Article', 'published' => 'Y', 'id' => 2, 'article_id' => 1, 'Attachment' => array()),
- array('comment' => 'Third Comment for First Article', 'published' => 'Y', 'id' => 3, 'article_id' => 1, 'Attachment' => array()),
- array('comment' => 'Fourth Comment for First Article', 'published' => 'N', 'id' => 4, 'article_id' => 1, 'Attachment' => array()),
+ array('comment' => 'First Comment for First Article', 'published' => 'Y', 'article_id' => 1, 'Attachment' => array()),
+ array('comment' => 'Second Comment for First Article', 'published' => 'Y', 'article_id' => 1, 'Attachment' => array()),
+ array('comment' => 'Third Comment for First Article', 'published' => 'Y', 'article_id' => 1, 'Attachment' => array()),
+ array('comment' => 'Fourth Comment for First Article', 'published' => 'N', 'article_id' => 1, 'Attachment' => array()),
)
),
array(
'Article' => array('title' => 'Second Article', 'id' => 2),
'User' => array('user' => 'larry', 'id' => 3),
'Comment' => array(
- array('comment' => 'First Comment for Second Article', 'published' => 'Y', 'id' => 5, 'article_id' => 2, 'Attachment' => array(
+ array('comment' => 'First Comment for Second Article', 'published' => 'Y', 'article_id' => 2, 'Attachment' => array(
'attachment' => 'attachment.zip', 'id' => 1
)),
- array('comment' => 'Second Comment for Second Article', 'published' => 'Y', 'id' => 6, 'article_id' => 2, 'Attachment' => array())
+ array('comment' => 'Second Comment for Second Article', 'published' => 'Y', 'article_id' => 2, 'Attachment' => array())
)
),
array(
@@ -3535,4 +3542,4 @@ class ContainableTest extends CakeTestCase {
}
}
-?>
\ No newline at end of file
+?>
diff --git a/cake/tests/fixtures/comment_fixture.php b/cake/tests/fixtures/comment_fixture.php
index 3c563102b..0c5a11be3 100644
--- a/cake/tests/fixtures/comment_fixture.php
+++ b/cake/tests/fixtures/comment_fixture.php
@@ -60,12 +60,12 @@ class CommentFixture extends CakeTestFixture {
* @access public
*/
var $records = array(
- array('id' => 1, 'article_id' => 1, 'user_id' => 2, 'comment' => 'First Comment for First Article', 'published' => 'Y', 'created' => '2007-03-18 10:45:23', 'updated' => '2007-03-18 10:47:31'),
- array('id' => 2, 'article_id' => 1, 'user_id' => 4, 'comment' => 'Second Comment for First Article', 'published' => 'Y', 'created' => '2007-03-18 10:47:23', 'updated' => '2007-03-18 10:49:31'),
- array('id' => 3, 'article_id' => 1, 'user_id' => 1, 'comment' => 'Third Comment for First Article', 'published' => 'Y', 'created' => '2007-03-18 10:49:23', 'updated' => '2007-03-18 10:51:31'),
- array('id' => 4, 'article_id' => 1, 'user_id' => 1, 'comment' => 'Fourth Comment for First Article', 'published' => 'N', 'created' => '2007-03-18 10:51:23', 'updated' => '2007-03-18 10:53:31'),
- array('id' => 5, 'article_id' => 2, 'user_id' => 1, 'comment' => 'First Comment for Second Article', 'published' => 'Y', 'created' => '2007-03-18 10:53:23', 'updated' => '2007-03-18 10:55:31'),
- array('id' => 6, 'article_id' => 2, 'user_id' => 2, 'comment' => 'Second Comment for Second Article', 'published' => 'Y', 'created' => '2007-03-18 10:55:23', 'updated' => '2007-03-18 10:57:31')
+ array('article_id' => 1, 'user_id' => 2, 'comment' => 'First Comment for First Article', 'published' => 'Y', 'created' => '2007-03-18 10:45:23', 'updated' => '2007-03-18 10:47:31'),
+ array('article_id' => 1, 'user_id' => 4, 'comment' => 'Second Comment for First Article', 'published' => 'Y', 'created' => '2007-03-18 10:47:23', 'updated' => '2007-03-18 10:49:31'),
+ array('article_id' => 1, 'user_id' => 1, 'comment' => 'Third Comment for First Article', 'published' => 'Y', 'created' => '2007-03-18 10:49:23', 'updated' => '2007-03-18 10:51:31'),
+ array('article_id' => 1, 'user_id' => 1, 'comment' => 'Fourth Comment for First Article', 'published' => 'N', 'created' => '2007-03-18 10:51:23', 'updated' => '2007-03-18 10:53:31'),
+ array('article_id' => 2, 'user_id' => 1, 'comment' => 'First Comment for Second Article', 'published' => 'Y', 'created' => '2007-03-18 10:53:23', 'updated' => '2007-03-18 10:55:31'),
+ array('article_id' => 2, 'user_id' => 2, 'comment' => 'Second Comment for Second Article', 'published' => 'Y', 'created' => '2007-03-18 10:55:23', 'updated' => '2007-03-18 10:57:31')
);
}
From ed43e95cf3fc7891cdf484bcf5fe659a21406afb Mon Sep 17 00:00:00 2001
From: phpnut
Date: Sun, 15 Mar 2009 00:08:56 +0000
Subject: [PATCH 02/67] Adding methods for setting headers and handling header
output, will make testing easier on the class
git-svn-id: https://svn.cakephp.org/repo/branches/1.2.x.x@8099 3807eeeb-6ff5-0310-8944-8be069107fe0
---
cake/libs/view/media.php | 88 ++++++++++++++++++++++++++++++----------
1 file changed, 66 insertions(+), 22 deletions(-)
diff --git a/cake/libs/view/media.php b/cake/libs/view/media.php
index c1746544b..e56e73aa4 100644
--- a/cake/libs/view/media.php
+++ b/cake/libs/view/media.php
@@ -79,6 +79,13 @@ class MediaView extends View {
'iges' => 'model/iges', 'igs' => 'model/iges', 'mesh' => 'model/mesh', 'msh' => 'model/mesh',
'silo' => 'model/mesh', 'vrml' => 'model/vrml', 'wrl' => 'model/vrml',
'mime' => 'www/mime', 'pdb' => 'chemical/x-pdb', 'xyz' => 'chemical/x-pdb');
+/**
+ * Holds headers sent to browser before rendering media
+ *
+ * @var array
+ * @access protected
+ */
+ var $_headers = array();
/**
* Constructor
*
@@ -105,7 +112,7 @@ class MediaView extends View {
} else {
$path = APP . $path . $id;
}
-
+
if (!file_exists($path)) {
header('Content-Type: text/html');
$this->cakeError('error404');
@@ -118,7 +125,7 @@ class MediaView extends View {
if (is_array($mimeType)) {
$this->mimeType = array_merge($this->mimeType, $mimeType);
}
-
+
if (isset($extension) && isset($this->mimeType[$extension]) && connection_status() == 0) {
$chunkSize = 8192;
$buffer = '';
@@ -148,13 +155,14 @@ class MediaView extends View {
));
}
foreach($contentTypes as $contentType) {
- header('Content-Type: ' . $contentType);
+ $this->_header('Content-Type: ' . $contentType);
}
- header('Content-Disposition: attachment; filename="' . $name . '.' . $extension . '";');
- header('Expires: 0');
- header('Accept-Ranges: bytes');
- header('Cache-Control: private', false);
- header('Pragma: private');
+ $this->_header(array(
+ 'Content-Disposition: attachment; filename="' . $name . '.' . $extension . '";',
+ 'Expires: 0',
+ 'Accept-Ranges: bytes',
+ 'Cache-Control: private' => false,
+ 'Pragma: private'));
$httpRange = env('HTTP_RANGE');
if (isset($httpRange)) {
@@ -163,30 +171,36 @@ class MediaView extends View {
$size = $fileSize - 1;
$length = $fileSize - $range;
- header('HTTP/1.1 206 Partial Content');
- header('Content-Length: ' . $length);
- header('Content-Range: bytes ' . $range . $size . '/' . $fileSize);
+ $this->_header(array(
+ 'HTTP/1.1 206 Partial Content',
+ 'Content-Length: ' . $length,
+ 'Content-Range: bytes ' . $range . $size . '/' . $fileSize));
+
fseek($handle, $range);
} else {
- header('Content-Length: ' . $fileSize);
+ $this->_header('Content-Length: ' . $fileSize);
}
} else {
- header('Date: ' . gmdate('D, d M Y H:i:s', time()) . ' GMT');
+ $this->_header('Date: ' . gmdate('D, d M Y H:i:s', time()) . ' GMT');
if ($cache) {
if (!is_numeric($cache)) {
$cache = strtotime($cache) - time();
}
- header('Cache-Control: max-age=' . $cache);
- header('Expires: ' . gmdate('D, d M Y H:i:s', time() + $cache) . ' GMT');
- header('Pragma: cache');
+ $this->_header(array(
+ 'Cache-Control: max-age=' . $cache,
+ 'Expires: ' . gmdate('D, d M Y H:i:s', time() + $cache) . ' GMT',
+ 'Pragma: cache'));
} else {
- header('Cache-Control: must-revalidate, post-check=0, pre-check=0');
- header('Pragma: no-cache');
+ $this->_header(array(
+ 'Cache-Control: must-revalidate, post-check=0, pre-check=0',
+ 'Pragma: no-cache'));
}
- header('Last-Modified: ' . $modified);
- header('Content-Type: ' . $this->mimeType[$extension]);
- header('Content-Length: ' . $fileSize);
+ $this->_header(array(
+ 'Last-Modified: ' . $modified,
+ 'Content-Type: ' . $this->mimeType[$extension],
+ 'Content-Length: ' . $fileSize));
}
+ $this->_output();
@ob_end_clean();
while (!feof($handle) && connection_status() == 0 && !connection_aborted()) {
@@ -201,5 +215,35 @@ class MediaView extends View {
}
return false;
}
+/**
+ * Method to set headers
+ * @param mixed $key
+ * @param boolean $boolean
+ * @access protected
+ */
+ function _header($header, $boolean = true) {
+ if (is_array($header)) {
+ foreach ($header as $string => $boolean) {
+ if (is_numeric($string)) {
+ $this->_headers[] = array($boolean => true);
+ } else {
+ $this->_headers[] = array($string => $boolean);
+ }
+ }
+ return;
+ }
+ $this->_headers[] = array($header => $boolean);
+ return;
+ }
+/**
+ * Method to output headers
+ * @access protected
+ */
+ function _output() {
+ foreach ($this->_headers as $header => $value) {
+ $string = key($header);
+ header($string, $value[$string]);
+ }
+ }
}
-?>
+?>
\ No newline at end of file
From 70f18af78d7be4a9d8252078d1e6983c4f1e7d67 Mon Sep 17 00:00:00 2001
From: davidpersson
Date: Sun, 15 Mar 2009 00:10:53 +0000
Subject: [PATCH 03/67] Adding Folder tests, fixes cases where ordered
directory entries were expected
git-svn-id: https://svn.cakephp.org/repo/branches/1.2.x.x@8100 3807eeeb-6ff5-0310-8944-8be069107fe0
---
cake/tests/cases/libs/folder.test.php | 35 ++++++++++++++++++++++++---
1 file changed, 32 insertions(+), 3 deletions(-)
diff --git a/cake/tests/cases/libs/folder.test.php b/cake/tests/cases/libs/folder.test.php
index 1dd8e8ff0..34fe46e0e 100644
--- a/cake/tests/cases/libs/folder.test.php
+++ b/cake/tests/cases/libs/folder.test.php
@@ -271,13 +271,16 @@ class FolderTest extends CakeTestCase {
);
$result = $Folder->tree(TEST_CAKE_CORE_INCLUDE_PATH . 'config', false);
- $this->assertEqual($result, $expected);
+ $this->assertIdentical(array_diff($expected[0], $result[0]), array());
+ $this->assertIdentical(array_diff($result[0], $expected[0]), array());
$result = $Folder->tree(TEST_CAKE_CORE_INCLUDE_PATH . 'config', false, 'dir');
- $this->assertEqual($result, $expected[0]);
+ $this->assertIdentical(array_diff($expected[0], $result), array());
+ $this->assertIdentical(array_diff($result, $expected[0]), array());
$result = $Folder->tree(TEST_CAKE_CORE_INCLUDE_PATH . 'config', false, 'files');
- $this->assertEqual($result, $expected[1]);
+ $this->assertIdentical(array_diff($expected[1], $result), array());
+ $this->assertIdentical(array_diff($result, $expected[1]), array());
}
/**
* testWindowsPath method
@@ -405,10 +408,20 @@ class FolderTest extends CakeTestCase {
$Folder->cd(TEST_CAKE_CORE_INCLUDE_PATH . 'config');
$result = $Folder->find();
$expected = array('config.php', 'paths.php');
+ $this->assertIdentical(array_diff($expected, $result), array());
+ $this->assertIdentical(array_diff($result, $expected), array());
+
+ $result = $Folder->find('.*', true);
+ $expected = array('config.php', 'paths.php');
$this->assertIdentical($result, $expected);
$result = $Folder->find('.*\.php');
$expected = array('config.php', 'paths.php');
+ $this->assertIdentical(array_diff($expected, $result), array());
+ $this->assertIdentical(array_diff($result, $expected), array());
+
+ $result = $Folder->find('.*\.php', true);
+ $expected = array('config.php', 'paths.php');
$this->assertIdentical($result, $expected);
$result = $Folder->find('.*ig\.php');
@@ -450,6 +463,14 @@ class FolderTest extends CakeTestCase {
TEST_CAKE_CORE_INCLUDE_PATH . 'config' . DS . 'config.php',
TEST_CAKE_CORE_INCLUDE_PATH . 'config' . DS . 'paths.php'
);
+ $this->assertIdentical(array_diff($expected, $result), array());
+ $this->assertIdentical(array_diff($result, $expected), array());
+
+ $result = $Folder->findRecursive('(config|paths)\.php', true);
+ $expected = array(
+ TEST_CAKE_CORE_INCLUDE_PATH . 'config' . DS . 'config.php',
+ TEST_CAKE_CORE_INCLUDE_PATH . 'config' . DS . 'paths.php'
+ );
$this->assertIdentical($result, $expected);
$Folder->cd(TMP);
@@ -472,6 +493,14 @@ class FolderTest extends CakeTestCase {
TMP . 'testme' . DS . 'my.php',
TMP . 'testme' . DS . 'paths.php'
);
+ $this->assertIdentical(array_diff($expected, $result), array());
+ $this->assertIdentical(array_diff($result, $expected), array());
+
+ $result = $Folder->findRecursive('(paths|my)\.php', true);
+ $expected = array(
+ TMP . 'testme' . DS . 'my.php',
+ TMP . 'testme' . DS . 'paths.php'
+ );
$this->assertIdentical($result, $expected);
$Folder->cd(TEST_CAKE_CORE_INCLUDE_PATH . 'config');
From e89bc0be102219410b2a7cc70ddaa05b913d8037 Mon Sep 17 00:00:00 2001
From: phpnut
Date: Sun, 15 Mar 2009 00:19:02 +0000
Subject: [PATCH 04/67] Committed [8099] before I finished changing variable
names
git-svn-id: https://svn.cakephp.org/repo/branches/1.2.x.x@8101 3807eeeb-6ff5-0310-8944-8be069107fe0
---
cake/libs/view/media.php | 8 ++++----
1 file changed, 4 insertions(+), 4 deletions(-)
diff --git a/cake/libs/view/media.php b/cake/libs/view/media.php
index e56e73aa4..5be837840 100644
--- a/cake/libs/view/media.php
+++ b/cake/libs/view/media.php
@@ -217,7 +217,7 @@ class MediaView extends View {
}
/**
* Method to set headers
- * @param mixed $key
+ * @param mixed $header
* @param boolean $boolean
* @access protected
*/
@@ -240,9 +240,9 @@ class MediaView extends View {
* @access protected
*/
function _output() {
- foreach ($this->_headers as $header => $value) {
- $string = key($header);
- header($string, $value[$string]);
+ foreach ($this->_headers as $key => $value) {
+ $header = key($value);
+ header($header, $value[$header]);
}
}
}
From 374898759941e77b0fbed7614cd1ca395b126202 Mon Sep 17 00:00:00 2001
From: phpnut
Date: Sun, 15 Mar 2009 00:21:28 +0000
Subject: [PATCH 05/67] Adding fix from davidpersson: sort not working for
subdirectories in Folder::findRecursive
git-svn-id: https://svn.cakephp.org/repo/branches/1.2.x.x@8102 3807eeeb-6ff5-0310-8944-8be069107fe0
---
cake/libs/folder.php | 5 +++--
1 file changed, 3 insertions(+), 2 deletions(-)
diff --git a/cake/libs/folder.php b/cake/libs/folder.php
index 7bf8716ef..28f32672a 100644
--- a/cake/libs/folder.php
+++ b/cake/libs/folder.php
@@ -212,17 +212,18 @@ class Folder extends Object {
*/
function _findRecursive($pattern, $sort = false) {
list($dirs, $files) = $this->read($sort);
-
$found = array();
+
foreach ($files as $file) {
if (preg_match('/^' . $pattern . '$/i', $file)) {
$found[] = Folder::addPathElement($this->path, $file);
}
}
$start = $this->path;
+
foreach ($dirs as $dir) {
$this->cd(Folder::addPathElement($start, $dir));
- $found = array_merge($found, $this->findRecursive($pattern));
+ $found = array_merge($found, $this->findRecursive($pattern, $sort));
}
return $found;
}
From e3b027288bf6c5990d632dc34f1d4f7495d91f22 Mon Sep 17 00:00:00 2001
From: phpnut
Date: Sun, 15 Mar 2009 00:27:25 +0000
Subject: [PATCH 06/67] Removing unused setting in Session configuration. Fixed
bug in CakeSession::watch(); that allowed setting multiple vars to watch and
CakeSession::ignore(); would only unset the first one found. Fixed errors
being thrown when testing database sessions and the database was dropped
before script process ended.
git-svn-id: https://svn.cakephp.org/repo/branches/1.2.x.x@8103 3807eeeb-6ff5-0310-8944-8be069107fe0
---
cake/libs/session.php | 6 +++---
cake/tests/cases/libs/session.test.php | 5 +++++
2 files changed, 8 insertions(+), 3 deletions(-)
diff --git a/cake/libs/session.php b/cake/libs/session.php
index 2bd4ab0fd..88b90da52 100644
--- a/cake/libs/session.php
+++ b/cake/libs/session.php
@@ -349,7 +349,9 @@ class CakeSession extends Object {
if (empty($var)) {
return false;
}
- $this->watchKeys[] = $var;
+ if (!in_array($var, $this->watchKeys, true)) {
+ $this->watchKeys[] = $var;
+ }
}
/**
* Tells Session to stop watching a given key path
@@ -571,10 +573,8 @@ class CakeSession extends Object {
$this->__setError(1, 'Session Highjacking Attempted !!!');
}
} else {
- srand ((double)microtime() * 1000000);
$this->write('Config.userAgent', $this->_userAgent);
$this->write('Config.time', $this->sessionTime);
- $this->write('Config.rand', mt_rand());
$this->write('Config.timeout', 10);
$this->valid = true;
$this->__setError(1, 'Session is valid');
diff --git a/cake/tests/cases/libs/session.test.php b/cake/tests/cases/libs/session.test.php
index 91d773cc7..d3f9f5ec0 100644
--- a/cake/tests/cases/libs/session.test.php
+++ b/cake/tests/cases/libs/session.test.php
@@ -369,6 +369,11 @@ class SessionTest extends CakeTestCase {
$this->Session->destroy();
$this->assertFalse($this->Session->read('SessionTestCase'));
session_write_close();
+
+ unset($_SESSION);
+ ini_set('session.save_handler', 'files');
+ Configure::write('Session.save', 'php');
+ $this->setUp();
}
}
?>
\ No newline at end of file
From 93bf4fd0dc39b1059de7c3dbc9921389488ee247 Mon Sep 17 00:00:00 2001
From: davidpersson
Date: Sun, 15 Mar 2009 19:31:59 +0000
Subject: [PATCH 07/67] Fixing debug() test making it match truncated paths
too. Adding skip to uses() test to make running all tests in sequence more
smooth.
git-svn-id: https://svn.cakephp.org/repo/branches/1.2.x.x@8104 3807eeeb-6ff5-0310-8944-8be069107fe0
---
cake/tests/cases/basics.test.php | 12 ++++++++----
1 file changed, 8 insertions(+), 4 deletions(-)
diff --git a/cake/tests/cases/basics.test.php b/cake/tests/cases/basics.test.php
index 14a5e99c4..06ef9a37c 100644
--- a/cake/tests/cases/basics.test.php
+++ b/cake/tests/cases/basics.test.php
@@ -119,6 +119,8 @@ class BasicsTest extends CakeTestCase {
* @return void
*/
function testUses() {
+ $this->skipIf(class_exists('Security') || class_exists('Sanitize'), 'Security and/or Sanitize class already loaded');
+
$this->assertFalse(class_exists('Security'));
$this->assertFalse(class_exists('Sanitize'));
@@ -532,15 +534,17 @@ class BasicsTest extends CakeTestCase {
ob_start();
debug('this-is-a-test');
$result = ob_get_clean();
- $pattern = '/.*' . preg_quote(substr(__FILE__, 1), '/')
- . '.*line.*' . (__LINE__ - 3) . '.*this-is-a-test.*/s';
+ $pattern = '/.*\>(cake(\/|\\\)tests(\/|\\\)cases(\/|\\\)basics\.test\.php|';
+ $pattern .= preg_quote(substr(__FILE__, 1), '/') . ')';
+ $pattern .= '.*line.*' . (__LINE__ - 4) . '.*this-is-a-test.*/s';
$this->assertPattern($pattern, $result);
ob_start();
debug('this-is-a-test
', true);
$result = ob_get_clean();
- $pattern = '/.*' . preg_quote(substr(__FILE__, 1), '/')
- . '.*line.*' . (__LINE__ - 3) . '.*<div>this-is-a-test<\/div>.*/s';
+ $pattern = '/.*\>(cake(\/|\\\)tests(\/|\\\)cases(\/|\\\)basics\.test\.php|';
+ $pattern .= preg_quote(substr(__FILE__, 1), '/') . ')';
+ $pattern .= '.*line.*' . (__LINE__ - 4) . '.*<div>this-is-a-test<\/div>.*/s';
$this->assertPattern($pattern, $result);
}
/**
From 056402efa708d986b9da283d5f5b831840cdabcd Mon Sep 17 00:00:00 2001
From: gwoo
Date: Sun, 15 Mar 2009 19:39:35 +0000
Subject: [PATCH 08/67] moving checks for Set::extract() so that null will be
returned when empty data is passed and classicExtract is expected.
git-svn-id: https://svn.cakephp.org/repo/branches/1.2.x.x@8105 3807eeeb-6ff5-0310-8944-8be069107fe0
---
cake/libs/set.php | 6 +++---
cake/tests/cases/libs/set.test.php | 8 +++++---
2 files changed, 8 insertions(+), 6 deletions(-)
diff --git a/cake/libs/set.php b/cake/libs/set.php
index 4376f5c05..bed03379a 100644
--- a/cake/libs/set.php
+++ b/cake/libs/set.php
@@ -374,12 +374,12 @@ class Set extends Object {
$data = $path;
$path = $tmp;
}
- if (empty($data)) {
- return array();
- }
if (strpos($path, '/') === false) {
return Set::classicExtract($data, $path);
}
+ if (empty($data)) {
+ return array();
+ }
if ($path === '/') {
return $data;
}
diff --git a/cake/tests/cases/libs/set.test.php b/cake/tests/cases/libs/set.test.php
index ed2f4f04c..81f884394 100644
--- a/cake/tests/cases/libs/set.test.php
+++ b/cake/tests/cases/libs/set.test.php
@@ -1052,15 +1052,17 @@ class SetTest extends CakeTestCase {
*/
function testSetExtractReturnsEmptyArray() {
- $this->assertEqual(Set::extract(array(), '/Post/id'), array());
+ $this->assertIdentical(Set::extract(array(), '/Post/id'), array());
- $this->assertEqual(Set::extract('/Post/id', array()), array());
+ $this->assertIdentical(Set::extract('/Post/id', array()), array());
- $this->assertEqual(Set::extract('/Post/id', array(
+ $this->assertIdentical(Set::extract('/Post/id', array(
array('Post' => array('name' => 'bob')),
array('Post' => array('name' => 'jim'))
)), array());
+ $this->assertIdentical(Set::extract(array(), 'Message.flash'), null);
+
}
/**
* testClassicExtract method
From beb6aeec0c884a5a8183ae669fd7b3370d500505 Mon Sep 17 00:00:00 2001
From: jperras
Date: Sun, 15 Mar 2009 23:01:21 +0000
Subject: [PATCH 09/67] Fixing incorrect doc blocks for connection_manager.php.
Thanks to ADmad for noticing the inconsistency.
git-svn-id: https://svn.cakephp.org/repo/branches/1.2.x.x@8106 3807eeeb-6ff5-0310-8944-8be069107fe0
---
cake/libs/model/connection_manager.php | 13 +++++++------
1 file changed, 7 insertions(+), 6 deletions(-)
diff --git a/cake/libs/model/connection_manager.php b/cake/libs/model/connection_manager.php
index 524d2bd36..3cb92901b 100644
--- a/cake/libs/model/connection_manager.php
+++ b/cake/libs/model/connection_manager.php
@@ -1,9 +1,9 @@
\ No newline at end of file
+?>
From 4dceb5be3179811b32d8a59a576cf917826f320d Mon Sep 17 00:00:00 2001
From: mark_story
Date: Mon, 16 Mar 2009 03:01:51 +0000
Subject: [PATCH 10/67] Adding doc blocks for properties that previously had no
documentation. Closes #6199
git-svn-id: https://svn.cakephp.org/repo/branches/1.2.x.x@8107 3807eeeb-6ff5-0310-8944-8be069107fe0
---
cake/libs/controller/controller.php | 26 ++++++++++++++++++++++++++
1 file changed, 26 insertions(+)
diff --git a/cake/libs/controller/controller.php b/cake/libs/controller/controller.php
index f50a98913..f07a2b723 100644
--- a/cake/libs/controller/controller.php
+++ b/cake/libs/controller/controller.php
@@ -291,6 +291,32 @@ class Controller extends Object {
* @link
*/
var $methods = array();
+/**
+ * This controller's primary model class name, the Inflector::classify()'ed verision of
+ * the controller's $name property.
+ *
+ * Example: For a controller named 'Comments', the modelClass would be 'Comment'
+ *
+ * @var string
+ * @access public
+ */
+ var $modelClass = null;
+/**
+ * This controller's model key name, an underscored version of the controller's $modelClass property.
+ *
+ * Example: For a controller named 'ArticleComments', the modelKey would be 'article_comment'
+ *
+ * @var string
+ * @access public
+ */
+ var $modelKey = null;
+/**
+ * Holds any validation errors produced by the last call of the validateErrors() method/
+ *
+ * @var array Validation errors, or false if none
+ * @access public
+ */
+ var $validationErrors = null;
/**
* Constructor.
*
From eba2e78d06e8bd3a2a4f6676bc80c6ebb0c45647 Mon Sep 17 00:00:00 2001
From: mark_story
Date: Mon, 16 Mar 2009 03:06:28 +0000
Subject: [PATCH 11/67] Fixing typo in last commit.
git-svn-id: https://svn.cakephp.org/repo/branches/1.2.x.x@8108 3807eeeb-6ff5-0310-8944-8be069107fe0
---
cake/libs/controller/controller.php | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/cake/libs/controller/controller.php b/cake/libs/controller/controller.php
index f07a2b723..116e993d8 100644
--- a/cake/libs/controller/controller.php
+++ b/cake/libs/controller/controller.php
@@ -292,7 +292,7 @@ class Controller extends Object {
*/
var $methods = array();
/**
- * This controller's primary model class name, the Inflector::classify()'ed verision of
+ * This controller's primary model class name, the Inflector::classify()'ed version of
* the controller's $name property.
*
* Example: For a controller named 'Comments', the modelClass would be 'Comment'
From a9062e2e0293b70a984fdb9b431cd3a57d36de04 Mon Sep 17 00:00:00 2001
From: "mariano.iglesias"
Date: Mon, 16 Mar 2009 12:54:25 +0000
Subject: [PATCH 12/67] Adding new email validation
git-svn-id: https://svn.cakephp.org/repo/branches/1.2.x.x@8109 3807eeeb-6ff5-0310-8944-8be069107fe0
---
cake/tests/cases/libs/validation.test.php | 5 +++--
1 file changed, 3 insertions(+), 2 deletions(-)
diff --git a/cake/tests/cases/libs/validation.test.php b/cake/tests/cases/libs/validation.test.php
index c8c4c145c..310b7a8ae 100644
--- a/cake/tests/cases/libs/validation.test.php
+++ b/cake/tests/cases/libs/validation.test.php
@@ -83,7 +83,7 @@ class ValidationTestCase extends CakeTestCase {
$this->assertTrue(Validation::notEmpty('π'));
$this->assertFalse(Validation::notEmpty("\t "));
$this->assertFalse(Validation::notEmpty(""));
-
+
}
/**
* testNotEmptyISO88591Encoding method
@@ -1514,6 +1514,7 @@ class ValidationTestCase extends CakeTestCase {
$this->assertTrue(Validation::email('abc@g.cn'));
$this->assertTrue(Validation::email('abc@x.com'));
$this->assertTrue(Validation::email('henrik@sbcglobal.net'));
+ $this->assertTrue(Validation::email('sani@sbcglobal.net'));
// all ICANN TLDs
$this->assertTrue(Validation::email('abc@example.aero'));
@@ -1974,4 +1975,4 @@ class ValidationTestCase extends CakeTestCase {
// $this->assertTrue(Validation::file(TEST_CAKE_CORE_INCLUDE_PATH. 'VERSION.txt'));
// }
}
-?>
\ No newline at end of file
+?>
From 0ead89639a77f4e958240230d36296e2b172aaad Mon Sep 17 00:00:00 2001
From: davidpersson
Date: Mon, 16 Mar 2009 14:07:26 +0000
Subject: [PATCH 13/67] Adding tests for Controller::redirect. Proves #6200 is
invalid. Making original tests more strict.
git-svn-id: https://svn.cakephp.org/repo/branches/1.2.x.x@8110 3807eeeb-6ff5-0310-8944-8be069107fe0
---
.../cases/libs/controller/controller.test.php | 98 +++++++++++++++----
1 file changed, 79 insertions(+), 19 deletions(-)
diff --git a/cake/tests/cases/libs/controller/controller.test.php b/cake/tests/cases/libs/controller/controller.test.php
index e0bbfeda9..3f64adbc8 100644
--- a/cake/tests/cases/libs/controller/controller.test.php
+++ b/cake/tests/cases/libs/controller/controller.test.php
@@ -30,14 +30,14 @@ App::import('Component', 'Cookie');
/**
* AppController class
*
- * @package cake
+ * @package cake.tests
* @subpackage cake.tests.cases.libs.controller
*/
if (!class_exists('AppController')) {
/**
* AppController class
*
- * @package cake
+ * @package cake.tests
* @subpackage cake.tests.cases.libs.controller
*/
class AppController extends Controller {
@@ -131,7 +131,7 @@ class ControllerPost extends CakeTestModel {
/**
* ControllerPostsController class
*
- * @package cake
+ * @package cake.tests
* @subpackage cake.tests.cases.libs.controller
*/
class ControllerCommentsController extends AppController {
@@ -251,7 +251,7 @@ class ControllerPaginateModel extends CakeTestModel {
/**
* NameTest class
*
- * @package cake
+ * @package cake.tests
* @subpackage cake.tests.cases.libs.controller
*/
class NameTest extends CakeTestModel {
@@ -278,7 +278,7 @@ class NameTest extends CakeTestModel {
/**
* TestController class
*
- * @package cake
+ * @package cake.tests
* @subpackage cake.tests.cases.libs.controller
*/
class TestController extends AppController {
@@ -325,7 +325,7 @@ class TestController extends AppController {
/**
* TestComponent class
*
- * @package cake
+ * @package cake.tests
* @subpackage cake.tests.cases.libs.controller
*/
class TestComponent extends Object {
@@ -336,13 +336,12 @@ class TestComponent extends Object {
* @return void
*/
function beforeRedirect() {
- return true;
}
}
/**
* AnotherTestController class
*
- * @package cake
+ * @package cake.tests
* @subpackage cake.tests.cases.libs.controller
*/
class AnotherTestController extends AppController {
@@ -352,7 +351,6 @@ class AnotherTestController extends AppController {
* @access public
*/
var $name = 'AnotherTest';
-
/**
* uses property
*
@@ -417,7 +415,12 @@ class ControllerTest extends CakeTestCase {
Configure::write('pluginPaths', $_back['pluginPaths']);
unset($Controller);
}
-
+/**
+ * testAliasName method
+ *
+ * @access public
+ * @return void
+ */
function testAliasName() {
$Controller =& new Controller();
$Controller->uses = array('NameTest');
@@ -428,7 +431,6 @@ class ControllerTest extends CakeTestCase {
unset($Controller);
}
-
/**
* testPersistent method
*
@@ -735,7 +737,6 @@ class ControllerTest extends CakeTestCase {
* @return void
*/
function testRedirect() {
- $url = 'cakephp.org';
$codes = array(
100 => "Continue",
101 => "Switching Protocols",
@@ -779,26 +780,85 @@ class ControllerTest extends CakeTestCase {
);
Mock::generatePartial('Controller', 'MockController', array('header'));
+ Mock::generate('TestComponent', 'MockTestComponent');
+ Mock::generate('TestComponent', 'MockTestBComponent');
+
App::import('Helper', 'Cache');
-// $codes = array_merge($codes, array_flip($codes));
foreach ($codes as $code => $msg) {
$MockController =& new MockController();
- $MockController->components = array('Test');
$MockController->Component =& new Component();
$MockController->Component->init($MockController);
+ $MockController->expectAt(0, 'header', array("HTTP/1.1 {$code} {$msg}"));
+ $MockController->expectAt(1, 'header', array('Location: http://cakephp.org'));
$MockController->expectCallCount('header', 2);
- $MockController->redirect($url, (int) $code, false);
+ $MockController->redirect('http://cakephp.org', (int)$code, false);
+ $this->assertFalse($MockController->autoRender);
}
- $codes = array_flip($codes);
foreach ($codes as $code => $msg) {
$MockController =& new MockController();
- $MockController->components = array('Test');
$MockController->Component =& new Component();
$MockController->Component->init($MockController);
+ $MockController->expectAt(0, 'header', array("HTTP/1.1 {$code} {$msg}"));
+ $MockController->expectAt(1, 'header', array('Location: http://cakephp.org'));
$MockController->expectCallCount('header', 2);
- $MockController->redirect($url, $code, false);
+ $MockController->redirect('http://cakephp.org', $msg, false);
+ $this->assertFalse($MockController->autoRender);
}
+
+ $MockController =& new MockController();
+ $MockController->Component =& new Component();
+ $MockController->Component->init($MockController);
+ $MockController->expectAt(0, 'header', array('Location: http://www.example.org/users/login'));
+ $MockController->expectCallCount('header', 1);
+ $MockController->redirect('http://www.example.org/users/login', null, false);
+
+ $MockController =& new MockController();
+ $MockController->Component =& new Component();
+ $MockController->Component->init($MockController);
+ $MockController->expectAt(0, 'header', array('HTTP/1.1 301 Moved Permanently'));
+ $MockController->expectAt(1, 'header', array('Location: http://www.example.org/users/login'));
+ $MockController->expectCallCount('header', 2);
+ $MockController->redirect('http://www.example.org/users/login', 301, false);
+
+ $MockController =& new MockController();
+ $MockController->components = array('MockTest');
+ $MockController->Component =& new Component();
+ $MockController->Component->init($MockController);
+ $MockController->MockTest->setReturnValue('beforeRedirect', null);
+ $MockController->expectAt(0, 'header', array('HTTP/1.1 301 Moved Permanently'));
+ $MockController->expectAt(1, 'header', array('Location: http://cakephp.org'));
+ $MockController->expectCallCount('header', 2);
+ $MockController->redirect('http://cakephp.org', 301, false);
+
+ $MockController =& new MockController();
+ $MockController->components = array('MockTest');
+ $MockController->Component =& new Component();
+ $MockController->Component->init($MockController);
+ $MockController->MockTest->setReturnValue('beforeRedirect', 'http://book.cakephp.org');
+ $MockController->expectAt(0, 'header', array('HTTP/1.1 301 Moved Permanently'));
+ $MockController->expectAt(1, 'header', array('Location: http://book.cakephp.org'));
+ $MockController->expectCallCount('header', 2);
+ $MockController->redirect('http://cakephp.org', 301, false);
+
+ $MockController =& new MockController();
+ $MockController->components = array('MockTest');
+ $MockController->Component =& new Component();
+ $MockController->Component->init($MockController);
+ $MockController->MockTest->setReturnValue('beforeRedirect', false);
+ $MockController->expectNever('header');
+ $MockController->redirect('http://cakephp.org', 301, false);
+
+ $MockController =& new MockController();
+ $MockController->components = array('MockTest', 'MockTestB');
+ $MockController->Component =& new Component();
+ $MockController->Component->init($MockController);
+ $MockController->MockTest->setReturnValue('beforeRedirect', 'http://book.cakephp.org');
+ $MockController->MockTestB->setReturnValue('beforeRedirect', 'http://bakery.cakephp.org');
+ $MockController->expectAt(0, 'header', array('HTTP/1.1 301 Moved Permanently'));
+ $MockController->expectAt(1, 'header', array('Location: http://bakery.cakephp.org'));
+ $MockController->expectCallCount('header', 2);
+ $MockController->redirect('http://cakephp.org', 301, false);
}
/**
* testMergeVars method
@@ -859,7 +919,7 @@ class ControllerTest extends CakeTestCase {
$this->assertTrue(isset($TestController->ControllerComment));
}
/**
- * Ensure that __mergeVars is not being greedy and merging with
+ * Ensure that __mergeVars is not being greedy and merging with
* AppController when you make an instance of Controller
*
* @return void
From 1c76e2e18eda4379e3537b35f0f4e620b90b2b33 Mon Sep 17 00:00:00 2001
From: davidpersson
Date: Mon, 16 Mar 2009 22:54:22 +0000
Subject: [PATCH 14/67] Fixing ShellDispatcher tests. Order of paths should not
be taken into account. CONSOLE_LIBS constant is not guaranteed to hold a
relative path only. Matching expectations for the output of help command to
show correct shortened paths.
git-svn-id: https://svn.cakephp.org/repo/branches/1.2.x.x@8111 3807eeeb-6ff5-0310-8944-8be069107fe0
---
cake/tests/cases/console/cake.test.php | 32 +++++++++++++-------------
1 file changed, 16 insertions(+), 16 deletions(-)
diff --git a/cake/tests/cases/console/cake.test.php b/cake/tests/cases/console/cake.test.php
index 04e4ecae2..14227718b 100644
--- a/cake/tests/cases/console/cake.test.php
+++ b/cake/tests/cases/console/cake.test.php
@@ -76,7 +76,6 @@ class TestShellDispatcher extends ShellDispatcher {
* @return void
*/
function _initEnvironment() {
- //
}
/**
* stderr method
@@ -128,10 +127,11 @@ class ShellDispatcherTest extends UnitTestCase {
$this->pluginPaths = Configure::read('pluginPaths');
$this->shellPaths = Configure::read('shellPaths');
}
-
- Configure::write('pluginPaths', array(TEST_CAKE_CORE_INCLUDE_PATH . 'tests' . DS . 'test_app' . DS . 'plugins' . DS));
+ Configure::write('pluginPaths', array(
+ TEST_CAKE_CORE_INCLUDE_PATH . 'tests' . DS . 'test_app' . DS . 'plugins' . DS
+ ));
Configure::write('shellPaths', array(
- ROOT . DS . CONSOLE_LIBS,
+ CORE_PATH ? CONSOLE_LIBS : ROOT . DS . CONSOLE_LIBS,
TEST_CAKE_CORE_INCLUDE_PATH . 'tests' . DS . 'test_app' . DS . 'vendors' . DS . 'shells' . DS
));
}
@@ -406,14 +406,18 @@ class ShellDispatcherTest extends UnitTestCase {
*/
function testBuildPaths() {
$Dispatcher =& new TestShellDispatcher();
- $this->assertEqual($Dispatcher->shellPaths, array(
+
+ $result = $Dispatcher->shellPaths;
+ $expected = array(
TEST_CAKE_CORE_INCLUDE_PATH . 'tests' . DS . 'test_app' . DS . 'plugins' . DS . 'test_plugin' . DS . 'vendors' . DS . 'shells' . DS,
TEST_CAKE_CORE_INCLUDE_PATH . 'tests' . DS . 'test_app' . DS . 'plugins' . DS . 'test_plugin_two' . DS . 'vendors' . DS . 'shells' . DS,
APP . 'vendors' . DS . 'shells' . DS,
VENDORS . 'shells' . DS,
- ROOT . DS . CONSOLE_LIBS,
+ CORE_PATH ? CONSOLE_LIBS : ROOT . DS . CONSOLE_LIBS,
TEST_CAKE_CORE_INCLUDE_PATH . 'tests' . DS . 'test_app' . DS . 'vendors' . DS . 'shells' . DS,
- ));
+ );
+ $this->assertIdentical(array_diff($result, $expected), array());
+ $this->assertIdentical(array_diff($expected, $result), array());
}
/**
* testDispatch method
@@ -440,20 +444,18 @@ class ShellDispatcherTest extends UnitTestCase {
function testHelpCommand() {
$Dispatcher =& new TestShellDispatcher();
- $expected = "/ ROOT(\\\|\/)cake(\\\|\/)tests(\\\|\/)test_app(\\\|\/)plugins(\\\|\/)test_plugin(\\\|\/)vendors(\\\|\/)shells:";
+ $expected = "/ CORE(\\\|\/)tests(\\\|\/)test_app(\\\|\/)plugins(\\\|\/)test_plugin(\\\|\/)vendors(\\\|\/)shells:";
$expected .= "\n\t example";
$expected .= "\n/";
$this->assertPattern($expected, $Dispatcher->stdout);
- // Shells need to be returned ordered
- // See Configure::__list/Folder::read
- $expected = "/ ROOT(\\\|\/)cake(\\\|\/)tests(\\\|\/)test_app(\\\|\/)plugins(\\\|\/)test_plugin_two(\\\|\/)vendors(\\\|\/)shells:";
+ $expected = "/ CORE(\\\|\/)tests(\\\|\/)test_app(\\\|\/)plugins(\\\|\/)test_plugin_two(\\\|\/)vendors(\\\|\/)shells:";
$expected .= "\n\t example";
$expected .= "\n\t welcome";
$expected .= "\n/";
$this->assertPattern($expected, $Dispatcher->stdout);
- $expected = "/ ROOT(\\\|\/)app(\\\|\/)vendors(\\\|\/)shells:";
+ $expected = "/ APP(\\\|\/)vendors(\\\|\/)shells:";
$expected .= "\n\t - none";
$expected .= "\n/";
$this->assertPattern($expected, $Dispatcher->stdout);
@@ -463,9 +465,7 @@ class ShellDispatcherTest extends UnitTestCase {
$expected .= "\n/";
$this->assertPattern($expected, $Dispatcher->stdout);
- // Shells need to be returned ordered
- // See Configure::__list/Folder::read
- $expected = "/ ROOT(\\\|\/)cake(\\\|\/)console(\\\|\/)libs:";
+ $expected = "/ CORE(\\\|\/)console(\\\|\/)libs:";
$expected .= "\n\t acl";
$expected .= "\n\t api";
$expected .= "\n\t bake";
@@ -476,7 +476,7 @@ class ShellDispatcherTest extends UnitTestCase {
$expected .= "\n/";
$this->assertPattern($expected, $Dispatcher->stdout);
- $expected = "/ ROOT(\\\|\/)cake(\\\|\/)tests(\\\|\/)test_app(\\\|\/)vendors(\\\|\/)shells:";
+ $expected = "/ CORE(\\\|\/)tests(\\\|\/)test_app(\\\|\/)vendors(\\\|\/)shells:";
$expected .= "\n\t sample";
$expected .= "\n/";
$this->assertPattern($expected, $Dispatcher->stdout);
From 7f853532d9a47040aaabf8c60fb525b6e7667ef4 Mon Sep 17 00:00:00 2001
From: gwoo
Date: Mon, 16 Mar 2009 23:08:39 +0000
Subject: [PATCH 15/67] updating ShellDispatcher to pass tests
git-svn-id: https://svn.cakephp.org/repo/branches/1.2.x.x@8112 3807eeeb-6ff5-0310-8944-8be069107fe0
---
cake/console/cake.php | 14 ++++++++++----
cake/tests/cases/console/cake.test.php | 2 --
2 files changed, 10 insertions(+), 6 deletions(-)
diff --git a/cake/console/cake.php b/cake/console/cake.php
index 97824e62d..823e6fc00 100644
--- a/cake/console/cake.php
+++ b/cake/console/cake.php
@@ -198,10 +198,14 @@ class ShellDispatcher {
*/
function __buildPaths() {
$paths = array();
-
$pluginPaths = Configure::read('pluginPaths');
+ if (!class_exists('Folder')) {
+ require LIBS . 'folder.php';
+ }
+
foreach ($pluginPaths as $pluginPath) {
- $plugins = Configure::listObjects('plugin', $pluginPath);
+ $Folder =& new Folder($pluginPath);
+ list($plugins,) = $Folder->read(false, true);
foreach ((array)$plugins as $plugin) {
$path = $pluginPath . Inflector::underscore($plugin) . DS . 'vendors' . DS . 'shells' . DS;
if (file_exists($path)) {
@@ -262,7 +266,6 @@ class ShellDispatcher {
Configure::write('debug', 1);
return true;
}
-
/**
* Dispatches a CLI request
*
@@ -542,16 +545,19 @@ class ShellDispatcher {
$this->stdout("\nAvailable Shells:");
$_shells = array();
+
foreach ($this->shellPaths as $path) {
if (is_dir($path)) {
$shells = Configure::listObjects('file', $path);
- $path = str_replace(CORE_PATH, 'CORE/', $path);
+ $path = str_replace(CAKE_CORE_INCLUDE_PATH . DS . 'cake' . DS, 'CORE' . DS, $path);
+ $path = str_replace(APP, 'APP' . DS, $path);
$path = str_replace(ROOT, 'ROOT', $path);
$path = rtrim($path, DS);
$this->stdout("\n " . $path . ":");
if (empty($shells)) {
$this->stdout("\t - none");
} else {
+ sort($shells);
foreach ($shells as $shell) {
if ($shell !== 'shell.php') {
$this->stdout("\t " . str_replace('.php', '', $shell));
diff --git a/cake/tests/cases/console/cake.test.php b/cake/tests/cases/console/cake.test.php
index 14227718b..c881a67de 100644
--- a/cake/tests/cases/console/cake.test.php
+++ b/cake/tests/cases/console/cake.test.php
@@ -456,12 +456,10 @@ class ShellDispatcherTest extends UnitTestCase {
$this->assertPattern($expected, $Dispatcher->stdout);
$expected = "/ APP(\\\|\/)vendors(\\\|\/)shells:";
- $expected .= "\n\t - none";
$expected .= "\n/";
$this->assertPattern($expected, $Dispatcher->stdout);
$expected = "/ ROOT(\\\|\/)vendors(\\\|\/)shells:";
- $expected .= "\n\t - none";
$expected .= "\n/";
$this->assertPattern($expected, $Dispatcher->stdout);
From de5907326e567cbeb083a7d58b97165e823537bd Mon Sep 17 00:00:00 2001
From: gwoo
Date: Tue, 17 Mar 2009 18:19:12 +0000
Subject: [PATCH 16/67] fixes #6203, Model::invalidFields respecting
Model::whitelist
git-svn-id: https://svn.cakephp.org/repo/branches/1.2.x.x@8113 3807eeeb-6ff5-0310-8944-8be069107fe0
---
cake/libs/model/model.php | 10 +++++--
cake/tests/cases/libs/model/model.test.php | 33 +++++++++++++---------
2 files changed, 28 insertions(+), 15 deletions(-)
diff --git a/cake/libs/model/model.php b/cake/libs/model/model.php
index 5bc46348e..838d51b7e 100644
--- a/cake/libs/model/model.php
+++ b/cake/libs/model/model.php
@@ -2343,9 +2343,15 @@ class Model extends Overloadable {
$this->exists();
$_validate = $this->validate;
- if (array_key_exists('fieldList', $options) && is_array($options['fieldList']) && !empty($options['fieldList'])) {
+ $whitelist = $this->whitelist;
+
+ if (array_key_exists('fieldList', $options)) {
+ $whitelist = $options['fieldList'];
+ }
+
+ if (!empty($whitelist)) {
$validate = array();
- foreach ($options['fieldList'] as $f) {
+ foreach ((array)$whitelist as $f) {
if (!empty($this->validate[$f])) {
$validate[$f] = $this->validate[$f];
}
diff --git a/cake/tests/cases/libs/model/model.test.php b/cake/tests/cases/libs/model/model.test.php
index 51d3d2f5f..6c9760b81 100644
--- a/cake/tests/cases/libs/model/model.test.php
+++ b/cake/tests/cases/libs/model/model.test.php
@@ -2999,16 +2999,16 @@ class ModelTest extends CakeTestCase {
)
);
$this->assertEqual($result, $expected);
-
-
+
+
$this->loadFixtures('JoinA', 'JoinC', 'JoinAC', 'JoinB', 'JoinAB');
$TestModel = new JoinA();
$TestModel->hasBelongsToMany['JoinC']['unique'] = true;
$data = array(
'JoinA' => array(
'id' => 1,
- 'name' => 'Join A 1',
- 'body' => 'Join A 1 Body',
+ 'name' => 'Join A 1',
+ 'body' => 'Join A 1 Body',
),
'JoinC' => array(
'JoinC' => array(
@@ -3279,10 +3279,10 @@ class ModelTest extends CakeTestCase {
$this->assertEqual(count($result['Comment']), 1);
$this->assertEqual(count($result['Comment'][0]['comment']['Article comment']), 1);
}
-
+
function testSaveAllHabtmWithExtraJoinTableFields() {
$this->loadFixtures('Something', 'SomethingElse', 'JoinThing');
-
+
$data = array(
'Something' => array(
'id' => 4,
@@ -3301,18 +3301,18 @@ class ModelTest extends CakeTestCase {
$result = $Something->saveAll($data);
$this->assertTrue($result);
$result = $Something->read();
-
+
$this->assertEqual(count($result['SomethingElse']), 3);
$this->assertTrue(Set::matches('/Something[id=4]', $result));
-
+
$this->assertTrue(Set::matches('/SomethingElse[id=1]', $result));
$this->assertTrue(Set::matches('/SomethingElse[id=1]/JoinThing[something_else_id=1]', $result));
$this->assertTrue(Set::matches('/SomethingElse[id=1]/JoinThing[doomed=1]', $result));
-
+
$this->assertTrue(Set::matches('/SomethingElse[id=2]', $result));
$this->assertTrue(Set::matches('/SomethingElse[id=2]/JoinThing[something_else_id=2]', $result));
$this->assertTrue(Set::matches('/SomethingElse[id=2]/JoinThing[doomed=0]', $result));
-
+
$this->assertTrue(Set::matches('/SomethingElse[id=3]', $result));
$this->assertTrue(Set::matches('/SomethingElse[id=3]/JoinThing[something_else_id=3]', $result));
$this->assertTrue(Set::matches('/SomethingElse[id=3]/JoinThing[doomed=1]', $result));
@@ -3800,8 +3800,8 @@ class ModelTest extends CakeTestCase {
$model->deleteAll(true);
$data = array(
'Article' => array(
- 'title' => 'Post with Author saveAlled from comment',
- 'body' => 'This post will be saved with an author',
+ 'title' => 'Post with Author saveAlled from comment',
+ 'body' => 'This post will be saved with an author',
'user_id' => 2
),
'Comment' => array(
@@ -3810,7 +3810,7 @@ class ModelTest extends CakeTestCase {
);
$result = $model->Comment->saveAll($data, array('validate' => 'first'));
$this->assertTrue($result);
-
+
$result = $model->find('all');
$this->assertEqual($result[0]['Article']['title'], 'Post with Author saveAlled from comment');
$this->assertEqual($result[0]['Comment'][0]['comment'], 'Only new comment');
@@ -4983,6 +4983,13 @@ class ModelTest extends CakeTestCase {
$TestModel->invalidFields(array('fieldList' => array('name', 'title')));
$expected = array('name' => 'This field cannot be left blank', 'title' => 'This field cannot be left blank');
$this->assertEqual($TestModel->validationErrors, $expected);
+ $TestModel->validationErrors = array();
+
+ $TestModel->whitelist = array('name');
+ $TestModel->invalidFields();
+ $expected = array('name' => 'This field cannot be left blank');
+ $this->assertEqual($TestModel->validationErrors, $expected);
+ $TestModel->validationErrors = array();
$this->assertEqual($TestModel->validate, $validate);
}
From 76e0f17dbcaeaffa0484c62e26a6b9922b9cc27e Mon Sep 17 00:00:00 2001
From: "renan.saddam"
Date: Tue, 17 Mar 2009 21:10:28 +0000
Subject: [PATCH 17/67] Updating documentation to improve code completion
git-svn-id: https://svn.cakephp.org/repo/branches/1.2.x.x@8114 3807eeeb-6ff5-0310-8944-8be069107fe0
---
cake/console/libs/acl.php | 2 +-
cake/console/libs/shell.php | 4 +-
cake/libs/cache.php | 2 +-
cake/libs/cache/file.php | 2 +-
cake/libs/cache/memcache.php | 2 +-
cake/libs/controller/scaffold.php | 2 +-
cake/libs/error.php | 2 +-
cake/libs/file.php | 4 +-
cake/libs/i18n.php | 2 +-
cake/libs/model/behavior.php | 4 +-
cake/libs/model/connection_manager.php | 4 +-
cake/libs/model/model.php | 2 +-
cake/libs/object.php | 2 +-
cake/libs/view/helpers/ajax.php | 6 +-
cake/libs/view/helpers/cache.php | 2 +-
cake/tests/cases/libs/magic_db.test.php | 2 +-
.../model/datasources/dbo/dbo_adodb.test.php | 2 +-
.../model/datasources/dbo/dbo_mssql.test.php | 14 +-
.../model/datasources/dbo/dbo_mysql.test.php | 134 +++++++++---------
.../model/datasources/dbo/dbo_mysqli.test.php | 2 +-
.../datasources/dbo/dbo_postgres.test.php | 24 ++--
.../model/datasources/dbo/dbo_sqlite.test.php | 12 +-
22 files changed, 116 insertions(+), 116 deletions(-)
diff --git a/cake/console/libs/acl.php b/cake/console/libs/acl.php
index c1593bba4..0e44bd82b 100644
--- a/cake/console/libs/acl.php
+++ b/cake/console/libs/acl.php
@@ -36,7 +36,7 @@ class AclShell extends Shell {
/**
* Contains instance of AclComponent
*
- * @var object
+ * @var AclComponent
* @access public
*/
var $Acl;
diff --git a/cake/console/libs/shell.php b/cake/console/libs/shell.php
index 04e444d2d..bac6c347b 100644
--- a/cake/console/libs/shell.php
+++ b/cake/console/libs/shell.php
@@ -34,7 +34,7 @@ class Shell extends Object {
/**
* An instance of the ShellDispatcher object that loaded this script
*
- * @var object
+ * @var ShellDispatcher
* @access public
*/
var $Dispatch = null;
@@ -49,7 +49,7 @@ class Shell extends Object {
* Holds the DATABASE_CONFIG object for the app. Null if database.php could not be found,
* or the app does not exist.
*
- * @var object
+ * @var DATABASE_CONFIG
* @access public
*/
var $DbConfig = null;
diff --git a/cake/libs/cache.php b/cake/libs/cache.php
index 6a6550cdb..aabd27951 100644
--- a/cake/libs/cache.php
+++ b/cake/libs/cache.php
@@ -33,7 +33,7 @@ class Cache extends Object {
/**
* Cache engine to use
*
- * @var object
+ * @var CacheEngine
* @access protected
*/
var $_Engine = null;
diff --git a/cake/libs/cache/file.php b/cake/libs/cache/file.php
index 40ec52c27..29dde9249 100644
--- a/cake/libs/cache/file.php
+++ b/cake/libs/cache/file.php
@@ -34,7 +34,7 @@ class FileEngine extends CacheEngine {
/**
* Instance of File class
*
- * @var object
+ * @var File
* @access private
*/
var $__File = null;
diff --git a/cake/libs/cache/memcache.php b/cake/libs/cache/memcache.php
index c2118098e..2d70a6e86 100644
--- a/cake/libs/cache/memcache.php
+++ b/cake/libs/cache/memcache.php
@@ -33,7 +33,7 @@ class MemcacheEngine extends CacheEngine {
/**
* Memcache wrapper.
*
- * @var object
+ * @var Memcache
* @access private
*/
var $__Memcache = null;
diff --git a/cake/libs/controller/scaffold.php b/cake/libs/controller/scaffold.php
index a76966bdb..1c326cffe 100644
--- a/cake/libs/controller/scaffold.php
+++ b/cake/libs/controller/scaffold.php
@@ -39,7 +39,7 @@ class Scaffold extends Object {
/**
* Controller object
*
- * @var object
+ * @var Controller
* @access public
*/
var $controller = null;
diff --git a/cake/libs/error.php b/cake/libs/error.php
index 2cce9861f..e8db8276a 100644
--- a/cake/libs/error.php
+++ b/cake/libs/error.php
@@ -70,7 +70,7 @@ class ErrorHandler extends Object {
/**
* Controller instance.
*
- * @var object
+ * @var Controller
* @access public
*/
var $controller = null;
diff --git a/cake/libs/file.php b/cake/libs/file.php
index fbb5aa8c7..e22031749 100644
--- a/cake/libs/file.php
+++ b/cake/libs/file.php
@@ -42,7 +42,7 @@ class File extends Object {
/**
* Folder object of the File
*
- * @var object
+ * @var Folder
* @access public
*/
var $Folder = null;
@@ -376,7 +376,7 @@ class File extends Object {
}
/**
* Returns the full path of the File.
- *
+ *
* @return string Full path to file
* @access public
*/
diff --git a/cake/libs/i18n.php b/cake/libs/i18n.php
index 36af0284d..850ac5782 100644
--- a/cake/libs/i18n.php
+++ b/cake/libs/i18n.php
@@ -40,7 +40,7 @@ class I18n extends Object {
/**
* Instance of the I10n class for localization
*
- * @var object
+ * @var I10n
* @access public
*/
var $l10n = null;
diff --git a/cake/libs/model/behavior.php b/cake/libs/model/behavior.php
index ff98f5144..fdbc64e30 100644
--- a/cake/libs/model/behavior.php
+++ b/cake/libs/model/behavior.php
@@ -205,11 +205,11 @@ class ModelBehavior extends Object {
* @subpackage cake.cake.libs.model
*/
class BehaviorCollection extends Object {
-
/**
* Stores a reference to the attached name
*
- * @var object
+ * @var string
+ * @access public
*/
var $modelName = null;
/**
diff --git a/cake/libs/model/connection_manager.php b/cake/libs/model/connection_manager.php
index 3cb92901b..32f169840 100644
--- a/cake/libs/model/connection_manager.php
+++ b/cake/libs/model/connection_manager.php
@@ -3,7 +3,7 @@
/**
* Datasource connection manager
*
- * Provides an interface for loading and enumerating connections defined in app/config/database.php
+ * Provides an interface for loading and enumerating connections defined in app/config/database.php
*
* PHP versions 4 and 5
*
@@ -39,7 +39,7 @@ class ConnectionManager extends Object {
/**
* Holds a loaded instance of the Connections object
*
- * @var object
+ * @var DATABASE_CONFIG
* @access public
*/
var $config = null;
diff --git a/cake/libs/model/model.php b/cake/libs/model/model.php
index 838d51b7e..d1da65496 100644
--- a/cake/libs/model/model.php
+++ b/cake/libs/model/model.php
@@ -221,7 +221,7 @@ class Model extends Overloadable {
/**
* Holds the Behavior objects currently bound to this model.
*
- * @var object
+ * @var BehaviorCollection
* @access public
*/
var $Behaviors = null;
diff --git a/cake/libs/object.php b/cake/libs/object.php
index 538a858b4..7b62f4e76 100644
--- a/cake/libs/object.php
+++ b/cake/libs/object.php
@@ -38,7 +38,7 @@ class Object {
/**
* Log object
*
- * @var object
+ * @var CakeLog
* @access protected
*/
var $_log = null;
diff --git a/cake/libs/view/helpers/ajax.php b/cake/libs/view/helpers/ajax.php
index e8df8f759..bc4aad584 100644
--- a/cake/libs/view/helpers/ajax.php
+++ b/cake/libs/view/helpers/ajax.php
@@ -42,14 +42,14 @@ class AjaxHelper extends AppHelper {
/**
* HtmlHelper instance
*
- * @var object
+ * @var HtmlHelper
* @access public
*/
var $Html = null;
/**
* JavaScriptHelper instance
*
- * @var object
+ * @var JavaScriptHelper
* @access public
*/
var $Javascript = null;
@@ -901,7 +901,7 @@ class AjaxHelper extends AppHelper {
}
if (isset($options['bind'])) {
$bind = $options['bind'];
-
+
$hasBinding = (
(is_array($bind) && in_array($callback, $bind)) ||
(is_string($bind) && strpos($bind, $callback) !== false)
diff --git a/cake/libs/view/helpers/cache.php b/cake/libs/view/helpers/cache.php
index c40de01b5..dd4f1b499 100644
--- a/cake/libs/view/helpers/cache.php
+++ b/cake/libs/view/helpers/cache.php
@@ -52,7 +52,7 @@ class CacheHelper extends AppHelper {
/**
* holds the View object passed in final call to CacheHelper::cache()
*
- * @var object
+ * @var View
* @access public
*/
var $view;
diff --git a/cake/tests/cases/libs/magic_db.test.php b/cake/tests/cases/libs/magic_db.test.php
index def8d11de..db270803e 100644
--- a/cake/tests/cases/libs/magic_db.test.php
+++ b/cake/tests/cases/libs/magic_db.test.php
@@ -34,7 +34,7 @@ class MagicDbTest extends UnitTestCase {
/**
* The MagicDb instance to be tested
*
- * @var object
+ * @var MagicDb
* @access public
*/
var $Db = null;
diff --git a/cake/tests/cases/libs/model/datasources/dbo/dbo_adodb.test.php b/cake/tests/cases/libs/model/datasources/dbo/dbo_adodb.test.php
index 63a80779a..1621c6f11 100644
--- a/cake/tests/cases/libs/model/datasources/dbo/dbo_adodb.test.php
+++ b/cake/tests/cases/libs/model/datasources/dbo/dbo_adodb.test.php
@@ -182,7 +182,7 @@ class DboAdodbTest extends CakeTestCase {
/**
* The Dbo instance to be tested
*
- * @var object
+ * @var DboSource
* @access public
*/
var $db = null;
diff --git a/cake/tests/cases/libs/model/datasources/dbo/dbo_mssql.test.php b/cake/tests/cases/libs/model/datasources/dbo/dbo_mssql.test.php
index d1c1801cb..cc8448a3e 100644
--- a/cake/tests/cases/libs/model/datasources/dbo/dbo_mssql.test.php
+++ b/cake/tests/cases/libs/model/datasources/dbo/dbo_mssql.test.php
@@ -54,7 +54,7 @@ class DboMssqlTestDb extends DboMssql {
var $simulated = array();
/**
* fetchAllResultsStack
- *
+ *
* @var array
* @access public
*/
@@ -72,8 +72,8 @@ class DboMssqlTestDb extends DboMssql {
}
/**
* fetchAll method
- *
- * @param mixed $sql
+ *
+ * @param mixed $sql
* @access protected
* @return void
*/
@@ -82,8 +82,8 @@ class DboMssqlTestDb extends DboMssql {
}
/**
* fetchAll method
- *
- * @param mixed $sql
+ *
+ * @param mixed $sql
* @access protected
* @return void
*/
@@ -192,7 +192,7 @@ class DboMssqlTest extends CakeTestCase {
/**
* The Dbo instance to be tested
*
- * @var object
+ * @var DboSource
* @access public
*/
var $db = null;
@@ -284,7 +284,7 @@ class DboMssqlTest extends CakeTestCase {
}
/**
* testDescribe method
- *
+ *
* @access public
* @return void
*/
diff --git a/cake/tests/cases/libs/model/datasources/dbo/dbo_mysql.test.php b/cake/tests/cases/libs/model/datasources/dbo/dbo_mysql.test.php
index 54e029077..dda8322cf 100644
--- a/cake/tests/cases/libs/model/datasources/dbo/dbo_mysql.test.php
+++ b/cake/tests/cases/libs/model/datasources/dbo/dbo_mysql.test.php
@@ -156,7 +156,7 @@ class DboMysqlTest extends CakeTestCase {
/**
* The Dbo instance to be tested
*
- * @var object
+ * @var DboSource
* @access public
*/
var $Db = null;
@@ -372,76 +372,76 @@ class DboMysqlTest extends CakeTestCase {
$name = $this->db->fullTableName('simple');
$mockDbo =& new QueryMockDboMysql($this);
- $columnData = array(
+ $columnData = array(
array('0' => array(
- 'Table' => 'with_compound_keys',
- 'Non_unique' => '0',
- 'Key_name' => 'PRIMARY',
- 'Seq_in_index' => '1',
- 'Column_name' => 'id',
- 'Collation' => 'A',
- 'Cardinality' => '0',
- 'Sub_part' => NULL,
- 'Packed' => NULL,
- 'Null' => '',
- 'Index_type' => 'BTREE',
- 'Comment' => ''
- )),
- array('0' => array(
- 'Table' => 'with_compound_keys',
- 'Non_unique' => '1',
- 'Key_name' => 'pointless_bool',
- 'Seq_in_index' => '1',
- 'Column_name' => 'bool',
- 'Collation' => 'A',
- 'Cardinality' => NULL,
- 'Sub_part' => NULL,
- 'Packed' => NULL,
- 'Null' => 'YES',
- 'Index_type' => 'BTREE',
+ 'Table' => 'with_compound_keys',
+ 'Non_unique' => '0',
+ 'Key_name' => 'PRIMARY',
+ 'Seq_in_index' => '1',
+ 'Column_name' => 'id',
+ 'Collation' => 'A',
+ 'Cardinality' => '0',
+ 'Sub_part' => NULL,
+ 'Packed' => NULL,
+ 'Null' => '',
+ 'Index_type' => 'BTREE',
'Comment' => ''
)),
array('0' => array(
- 'Table' => 'with_compound_keys',
- 'Non_unique' => '1',
- 'Key_name' => 'pointless_small_int',
- 'Seq_in_index' => '1',
- 'Column_name' => 'small_int',
- 'Collation' => 'A',
- 'Cardinality' => NULL,
- 'Sub_part' => NULL,
- 'Packed' => NULL,
- 'Null' => 'YES',
- 'Index_type' => 'BTREE',
+ 'Table' => 'with_compound_keys',
+ 'Non_unique' => '1',
+ 'Key_name' => 'pointless_bool',
+ 'Seq_in_index' => '1',
+ 'Column_name' => 'bool',
+ 'Collation' => 'A',
+ 'Cardinality' => NULL,
+ 'Sub_part' => NULL,
+ 'Packed' => NULL,
+ 'Null' => 'YES',
+ 'Index_type' => 'BTREE',
'Comment' => ''
- )),
+ )),
array('0' => array(
- 'Table' => 'with_compound_keys',
- 'Non_unique' => '1',
- 'Key_name' => 'one_way',
- 'Seq_in_index' => '1',
- 'Column_name' => 'bool',
- 'Collation' => 'A',
- 'Cardinality' => NULL,
- 'Sub_part' => NULL,
- 'Packed' => NULL,
- 'Null' => 'YES',
- 'Index_type' => 'BTREE',
+ 'Table' => 'with_compound_keys',
+ 'Non_unique' => '1',
+ 'Key_name' => 'pointless_small_int',
+ 'Seq_in_index' => '1',
+ 'Column_name' => 'small_int',
+ 'Collation' => 'A',
+ 'Cardinality' => NULL,
+ 'Sub_part' => NULL,
+ 'Packed' => NULL,
+ 'Null' => 'YES',
+ 'Index_type' => 'BTREE',
'Comment' => ''
- )),
+ )),
array('0' => array(
- 'Table' => 'with_compound_keys',
- 'Non_unique' => '1',
- 'Key_name' => 'one_way',
- 'Seq_in_index' => '2',
- 'Column_name' => 'small_int',
- 'Collation' => 'A',
- 'Cardinality' => NULL,
- 'Sub_part' => NULL,
- 'Packed' => NULL,
- 'Null' => 'YES',
- 'Index_type' => 'BTREE',
- 'Comment' => ''
+ 'Table' => 'with_compound_keys',
+ 'Non_unique' => '1',
+ 'Key_name' => 'one_way',
+ 'Seq_in_index' => '1',
+ 'Column_name' => 'bool',
+ 'Collation' => 'A',
+ 'Cardinality' => NULL,
+ 'Sub_part' => NULL,
+ 'Packed' => NULL,
+ 'Null' => 'YES',
+ 'Index_type' => 'BTREE',
+ 'Comment' => ''
+ )),
+ array('0' => array(
+ 'Table' => 'with_compound_keys',
+ 'Non_unique' => '1',
+ 'Key_name' => 'one_way',
+ 'Seq_in_index' => '2',
+ 'Column_name' => 'small_int',
+ 'Collation' => 'A',
+ 'Cardinality' => NULL,
+ 'Sub_part' => NULL,
+ 'Packed' => NULL,
+ 'Null' => 'YES',
+ 'Index_type' => 'BTREE',
+ 'Comment' => ''
))
);
$mockDbo->setReturnValue('query', $columnData, array('SHOW INDEX FROM ' . $name));
@@ -504,7 +504,7 @@ class DboMysqlTest extends CakeTestCase {
}
/**
* testAlterSchemaIndexes method
- *
+ *
* @access public
* @return void
*/
@@ -538,10 +538,10 @@ class DboMysqlTest extends CakeTestCase {
'PRIMARY' => array('column' => 'id', 'unique' => 1))
)));
$this->db->query($this->db->alterSchema($schema2->compare($schema1)));
-
+
$indexes = $this->db->index('altertest');
$this->assertEqual($schema2->tables['altertest']['indexes'], $indexes);
-
+
// Change three indexes, delete one and add another one
$schema3 =& new CakeSchema(array(
'name' => 'AlterTest3',
@@ -552,7 +552,7 @@ class DboMysqlTest extends CakeTestCase {
'group1' => array('type' => 'integer', 'null' => true),
'group2' => array('type' => 'integer', 'null' => true),
'indexes' => array(
- 'name_idx' => array('column' => 'name', 'unique' => 1),
+ 'name_idx' => array('column' => 'name', 'unique' => 1),
'group_idx' => array('column' => 'group2', 'unique' => 0),
'compound_idx' => array('column' => array('group2', 'group1'), 'unique' => 0),
'id_name_idx' => array('column' => array('id', 'name'), 'unique' => 0))
diff --git a/cake/tests/cases/libs/model/datasources/dbo/dbo_mysqli.test.php b/cake/tests/cases/libs/model/datasources/dbo/dbo_mysqli.test.php
index ea1dd7b26..38ab1b891 100644
--- a/cake/tests/cases/libs/model/datasources/dbo/dbo_mysqli.test.php
+++ b/cake/tests/cases/libs/model/datasources/dbo/dbo_mysqli.test.php
@@ -159,7 +159,7 @@ class DboMysqliTest extends CakeTestCase {
/**
* The Dbo instance to be tested
*
- * @var object
+ * @var DboSource
* @access public
*/
var $Db = null;
diff --git a/cake/tests/cases/libs/model/datasources/dbo/dbo_postgres.test.php b/cake/tests/cases/libs/model/datasources/dbo/dbo_postgres.test.php
index d27289a2e..c6ff8a5f0 100644
--- a/cake/tests/cases/libs/model/datasources/dbo/dbo_postgres.test.php
+++ b/cake/tests/cases/libs/model/datasources/dbo/dbo_postgres.test.php
@@ -159,19 +159,19 @@ class DboPostgresTest extends CakeTestCase {
* @var object
* @access public
*/
- var $fixtures = array('core.user', 'core.binary_test', 'core.comment', 'core.article',
+ var $fixtures = array('core.user', 'core.binary_test', 'core.comment', 'core.article',
'core.tag', 'core.articles_tag', 'core.attachment', 'core.person', 'core.post', 'core.author');
/**
* Actual DB connection used in testing
*
- * @var object
+ * @var DboSource
* @access public
*/
var $db = null;
/**
* Simulated DB connection used in testing
*
- * @var object
+ * @var DboSource
* @access public
*/
var $db2 = null;
@@ -479,7 +479,7 @@ class DboPostgresTest extends CakeTestCase {
$db1->query('DROP TABLE ' . $db1->fullTableName('datatypes'));
}
-
+
/**
* Test index generation from table info.
*
@@ -498,7 +498,7 @@ class DboPostgresTest extends CakeTestCase {
);
$result = $this->db->index($name);
$this->assertEqual($expected, $result);
-
+
$this->db->query('DROP TABLE ' . $name);
$name = $this->db->fullTableName('index_test_2', false);
$this->db->query('CREATE TABLE ' . $name . ' ("id" serial NOT NULL PRIMARY KEY, "bool" integer, "small_char" varchar(50), "description" varchar(40) )');
@@ -532,7 +532,7 @@ class DboPostgresTest extends CakeTestCase {
)
));
$this->db->query($this->db->createSchema($Old));
-
+
$New =& new CakeSchema(array(
'connection' => 'test_suite',
'name' => 'AlterPosts',
@@ -547,13 +547,13 @@ class DboPostgresTest extends CakeTestCase {
)
));
$this->db->query($this->db->alterSchema($New->compare($Old), 'alter_posts'));
-
+
$model = new CakeTestModel(array('table' => 'alter_posts', 'ds' => 'test_suite'));
$result = $model->schema();
$this->assertTrue(isset($result['status']));
$this->assertFalse(isset($result['published']));
$this->assertEqual($result['body']['type'], 'string');
-
+
$this->db->query($this->db->dropSchema($New));
}
/**
@@ -561,7 +561,7 @@ class DboPostgresTest extends CakeTestCase {
*
* @access public
* @return void
- */
+ */
function testAlterIndexes() {
$this->db->cacheSources = false;
@@ -594,10 +594,10 @@ class DboPostgresTest extends CakeTestCase {
)
));
$this->db->query($this->db->alterSchema($schema2->compare($schema1)));
-
+
$indexes = $this->db->index('altertest');
$this->assertEqual($schema2->tables['altertest']['indexes'], $indexes);
-
+
// Change three indexes, delete one and add another one
$schema3 =& new CakeSchema(array(
'name' => 'AlterTest3',
@@ -608,7 +608,7 @@ class DboPostgresTest extends CakeTestCase {
'group1' => array('type' => 'integer', 'null' => true),
'group2' => array('type' => 'integer', 'null' => true),
'indexes' => array(
- 'name_idx' => array('column' => 'name', 'unique' => 1),
+ 'name_idx' => array('column' => 'name', 'unique' => 1),
'group_idx' => array('column' => 'group2', 'unique' => 0),
'compound_idx' => array('column' => array('group2', 'group1'), 'unique' => 0),
'another_idx' => array('column' => array('group1', 'name'), 'unique' => 0))
diff --git a/cake/tests/cases/libs/model/datasources/dbo/dbo_sqlite.test.php b/cake/tests/cases/libs/model/datasources/dbo/dbo_sqlite.test.php
index 47f1acea5..a22cc7721 100644
--- a/cake/tests/cases/libs/model/datasources/dbo/dbo_sqlite.test.php
+++ b/cake/tests/cases/libs/model/datasources/dbo/dbo_sqlite.test.php
@@ -83,14 +83,14 @@ class DboSqliteTest extends CakeTestCase {
/**
* Actual DB connection used in testing
*
- * @var object
+ * @var DboSource
* @access public
*/
var $db = null;
/**
* Simulated DB connection used in testing
*
- * @var object
+ * @var DboSource
* @access public
*/
var $db2 = null;
@@ -150,7 +150,7 @@ class DboSqliteTest extends CakeTestCase {
*
* @access public
* @return void
- */
+ */
function testIndex() {
$name = $this->db->fullTableName('with_a_key');
$this->db->query('CREATE TABLE ' . $name . ' ("id" int(11) PRIMARY KEY, "bool" int(1), "small_char" varchar(50), "description" varchar(40) );');
@@ -160,12 +160,12 @@ class DboSqliteTest extends CakeTestCase {
'PRIMARY' => array('column' => 'id', 'unique' => 1),
'pointless_bool' => array('column' => 'bool', 'unique' => 0),
'char_index' => array('column' => 'small_char', 'unique' => 1),
-
+
);
$result = $this->db->index($name);
$this->assertEqual($expected, $result);
$this->db->query('DROP TABLE ' . $name);
-
+
$this->db->query('CREATE TABLE ' . $name . ' ("id" int(11) PRIMARY KEY, "bool" int(1), "small_char" varchar(50), "description" varchar(40) );');
$this->db->query('CREATE UNIQUE INDEX multi_col ON ' . $name . '("small_char", "bool")');
$expected = array(
@@ -199,7 +199,7 @@ class DboSqliteTest extends CakeTestCase {
$db->cacheSources = false;
$fileName = '_' . preg_replace('/[^A-Za-z0-9_\-+]/', '_', TMP . $dbName) . '_list';
-
+
$result = Cache::read($fileName, '_cake_model_');
$this->assertEqual($result, array('test_list'));
From 78daa139008b0a71126511fc3eaffd6d0bcfa6c0 Mon Sep 17 00:00:00 2001
From: "renan.saddam"
Date: Wed, 18 Mar 2009 00:43:21 +0000
Subject: [PATCH 18/67] Defining the default answer as the current path. Fixes
#6204
git-svn-id: https://svn.cakephp.org/repo/branches/1.2.x.x@8115 3807eeeb-6ff5-0310-8944-8be069107fe0
---
cake/console/libs/tasks/extract.php | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/cake/console/libs/tasks/extract.php b/cake/console/libs/tasks/extract.php
index 644cf5ed3..7918e8cd7 100644
--- a/cake/console/libs/tasks/extract.php
+++ b/cake/console/libs/tasks/extract.php
@@ -135,7 +135,7 @@ class ExtractTask extends Shell{
} else {
$response = '';
while ($response == '') {
- $response = $this->in("What is the full path you would like to extract?\nExample: " . $this->params['root'] . DS . "myapp\n[Q]uit", null, 'Q');
+ $response = $this->in("What is the full path you would like to extract?\nExample: " . $this->params['root'] . DS . "myapp\n[Q]uit", null, $this->params['working']);
if (strtoupper($response) === 'Q') {
$this->out('Extract Aborted');
$this->_stop();
From 3c3b8520991700a2208219aae78191cf27388d3c Mon Sep 17 00:00:00 2001
From: davidpersson
Date: Wed, 18 Mar 2009 17:55:58 +0000
Subject: [PATCH 19/67] Changing package of tests from "cake.tests" to "cake".
Moving tearDown et al. to the top of each test class. Adding short
descriptions to docblocks. Adding missing docblocks. Removing unnecessary
blank lines and whitespaces. Updating labels of test groups.
git-svn-id: https://svn.cakephp.org/repo/branches/1.2.x.x@8116 3807eeeb-6ff5-0310-8944-8be069107fe0
---
cake/tests/cases/basics.test.php | 6 +-
cake/tests/cases/console/cake.test.php | 8 +-
cake/tests/cases/console/libs/shell.test.php | 14 +-
.../cases/console/libs/tasks/extract.test.php | 17 +-
.../cases/console/libs/tasks/test.test.php | 8 +-
cake/tests/cases/dispatcher.test.php | 31 +-
cake/tests/cases/libs/cache.test.php | 8 +-
cake/tests/cases/libs/cache/apc.test.php | 26 +-
cake/tests/cases/libs/cache/file.test.php | 17 +-
cake/tests/cases/libs/cache/memcache.test.php | 9 +-
cake/tests/cases/libs/cache/xcache.test.php | 26 +-
cake/tests/cases/libs/cake_log.test.php | 9 +-
cake/tests/cases/libs/cake_test_case.test.php | 57 +--
.../cases/libs/cake_test_fixture.test.php | 57 +--
cake/tests/cases/libs/class_registry.test.php | 20 +-
.../cases/libs/code_coverage_manager.test.php | 26 +-
cake/tests/cases/libs/configure.test.php | 13 +-
.../cases/libs/controller/component.test.php | 51 ++-
.../libs/controller/components/acl.test.php | 27 +-
.../libs/controller/components/auth.test.php | 57 ++-
.../controller/components/cookie.test.php | 86 +++--
.../libs/controller/components/email.test.php | 36 +-
.../components/request_handler.test.php | 59 ++--
.../controller/components/security.test.php | 46 ++-
.../controller/components/session.test.php | 38 +-
.../cases/libs/controller/controller.test.php | 30 +-
.../libs/controller/pages_controller.test.php | 8 +-
.../cases/libs/controller/scaffold.test.php | 69 ++--
cake/tests/cases/libs/debugger.test.php | 70 ++--
cake/tests/cases/libs/error.test.php | 28 +-
cake/tests/cases/libs/file.test.php | 9 +-
cake/tests/cases/libs/flay.test.php | 12 +-
cake/tests/cases/libs/folder.test.php | 8 +-
cake/tests/cases/libs/http_socket.test.php | 71 ++--
cake/tests/cases/libs/i18n.test.php | 15 +-
cake/tests/cases/libs/inflector.test.php | 26 +-
cake/tests/cases/libs/l10n.test.php | 6 +-
cake/tests/cases/libs/magic_db.test.php | 16 +-
cake/tests/cases/libs/model/behavior.test.php | 33 +-
.../cases/libs/model/behaviors/acl.test.php | 90 +++--
.../libs/model/behaviors/containable.test.php | 10 +-
.../libs/model/behaviors/translate.test.php | 11 +-
.../cases/libs/model/behaviors/tree.test.php | 26 +-
.../model/datasources/dbo/dbo_adodb.test.php | 27 +-
.../model/datasources/dbo/dbo_mssql.test.php | 65 ++--
.../model/datasources/dbo/dbo_mysql.test.php | 15 +-
.../model/datasources/dbo/dbo_mysqli.test.php | 17 +-
.../model/datasources/dbo/dbo_oracle.test.php | 12 +-
.../datasources/dbo/dbo_postgres.test.php | 19 +-
.../model/datasources/dbo/dbo_sqlite.test.php | 13 +-
.../model/datasources/dbo_source.test.php | 55 +--
cake/tests/cases/libs/model/db_acl.test.php | 84 +++--
cake/tests/cases/libs/model/model.test.php | 64 ++--
cake/tests/cases/libs/model/models.php | 219 ++++++------
cake/tests/cases/libs/model/schema.test.php | 57 ++-
cake/tests/cases/libs/multibyte.test.php | 8 +-
cake/tests/cases/libs/object.test.php | 36 +-
cake/tests/cases/libs/overloadable.test.php | 10 +-
cake/tests/cases/libs/router.test.php | 10 +-
cake/tests/cases/libs/sanitize.test.php | 11 +-
cake/tests/cases/libs/security.test.php | 8 +-
cake/tests/cases/libs/session.test.php | 8 +-
cake/tests/cases/libs/set.test.php | 11 +-
cake/tests/cases/libs/socket.test.php | 26 +-
cake/tests/cases/libs/string.test.php | 8 +-
cake/tests/cases/libs/test_manager.test.php | 47 +--
cake/tests/cases/libs/validation.test.php | 13 +-
cake/tests/cases/libs/view/helper.test.php | 42 ++-
.../cases/libs/view/helpers/ajax.test.php | 44 ++-
.../cases/libs/view/helpers/cache.test.php | 76 ++--
.../cases/libs/view/helpers/form.test.php | 77 ++--
.../cases/libs/view/helpers/html.test.php | 25 +-
.../libs/view/helpers/javascript.test.php | 9 +-
.../tests/cases/libs/view/helpers/js.test.php | 21 +-
.../cases/libs/view/helpers/number.test.php | 33 +-
.../libs/view/helpers/paginator.test.php | 30 +-
.../cases/libs/view/helpers/rss.test.php | 11 +-
.../cases/libs/view/helpers/session.test.php | 9 +-
.../cases/libs/view/helpers/text.test.php | 30 +-
.../cases/libs/view/helpers/time.test.php | 30 +-
.../cases/libs/view/helpers/xml.test.php | 27 +-
cake/tests/cases/libs/view/theme.test.php | 32 +-
cake/tests/cases/libs/view/view.test.php | 33 +-
cake/tests/cases/libs/xml.test.php | 328 +++++++++---------
cake/tests/fixtures/account_fixture.php | 4 +-
cake/tests/fixtures/aco_action_fixture.php | 4 +-
cake/tests/fixtures/aco_fixture.php | 4 +-
cake/tests/fixtures/aco_two_fixture.php | 4 +-
cake/tests/fixtures/advertisement_fixture.php | 4 +-
.../fixtures/another_article_fixture.php | 4 +-
cake/tests/fixtures/apple_fixture.php | 4 +-
cake/tests/fixtures/aro_fixture.php | 4 +-
cake/tests/fixtures/aro_two_fixture.php | 4 +-
cake/tests/fixtures/aros_aco_fixture.php | 4 +-
cake/tests/fixtures/aros_aco_two_fixture.php | 4 +-
.../fixtures/article_featured_fixture.php | 4 +-
.../article_featureds_tags_fixture.php | 4 +-
cake/tests/fixtures/article_fixture.php | 4 +-
cake/tests/fixtures/articles_tag_fixture.php | 4 +-
cake/tests/fixtures/attachment_fixture.php | 4 +-
.../auth_user_custom_field_fixture.php | 4 +-
cake/tests/fixtures/auth_user_fixture.php | 4 +-
cake/tests/fixtures/author_fixture.php | 4 +-
cake/tests/fixtures/basket_fixture.php | 4 +-
cake/tests/fixtures/bid_fixture.php | 4 +-
cake/tests/fixtures/binary_test_fixture.php | 4 +-
cake/tests/fixtures/book_fixture.php | 4 +-
.../fixtures/cache_test_model_fixture.php | 4 +-
cake/tests/fixtures/callback_fixture.php | 4 +-
cake/tests/fixtures/category_fixture.php | 4 +-
.../fixtures/category_thread_fixture.php | 4 +-
cake/tests/fixtures/cd_fixture.php | 4 +-
cake/tests/fixtures/comment_fixture.php | 4 +-
.../fixtures/content_account_fixture.php | 4 +-
cake/tests/fixtures/content_fixture.php | 4 +-
.../fixtures/counter_cache_post_fixture.php | 4 +-
.../fixtures/counter_cache_user_fixture.php | 4 +-
cake/tests/fixtures/data_test_fixture.php | 4 +-
cake/tests/fixtures/datatype_fixture.php | 4 +-
cake/tests/fixtures/dependency_fixture.php | 4 +-
cake/tests/fixtures/device_fixture.php | 4 +-
.../fixtures/device_type_category_fixture.php | 4 +-
cake/tests/fixtures/device_type_fixture.php | 4 +-
.../fixtures/document_directory_fixture.php | 4 +-
cake/tests/fixtures/document_fixture.php | 4 +-
.../exterior_type_category_fixture.php | 4 +-
cake/tests/fixtures/feature_set_fixture.php | 4 +-
cake/tests/fixtures/featured_fixture.php | 4 +-
cake/tests/fixtures/film_file_fixture.php | 4 +-
cake/tests/fixtures/flag_tree_fixture.php | 2 +-
cake/tests/fixtures/fruit_fixture.php | 4 +-
.../fixtures/fruits_uuid_tag_fixture.php | 4 +-
cake/tests/fixtures/home_fixture.php | 4 +-
cake/tests/fixtures/image_fixture.php | 4 +-
cake/tests/fixtures/item_fixture.php | 4 +-
.../fixtures/items_portfolio_fixture.php | 4 +-
cake/tests/fixtures/join_a_b_fixture.php | 4 +-
cake/tests/fixtures/join_a_c_fixture.php | 4 +-
cake/tests/fixtures/join_a_fixture.php | 4 +-
cake/tests/fixtures/join_b_fixture.php | 4 +-
cake/tests/fixtures/join_c_fixture.php | 4 +-
cake/tests/fixtures/join_thing_fixture.php | 4 +-
cake/tests/fixtures/message_fixture.php | 4 +-
.../my_categories_my_products_fixture.php | 4 +-
.../my_categories_my_users_fixture.php | 4 +-
cake/tests/fixtures/my_category_fixture.php | 4 +-
cake/tests/fixtures/my_product_fixture.php | 4 +-
cake/tests/fixtures/my_user_fixture.php | 4 +-
cake/tests/fixtures/node_fixture.php | 4 +-
cake/tests/fixtures/number_tree_fixture.php | 2 +-
.../fixtures/numeric_article_fixture.php | 4 +-
.../fixtures/overall_favorite_fixture.php | 4 +-
cake/tests/fixtures/person_fixture.php | 4 +-
cake/tests/fixtures/portfolio_fixture.php | 4 +-
cake/tests/fixtures/post_fixture.php | 4 +-
cake/tests/fixtures/posts_tag_fixture.php | 4 +-
cake/tests/fixtures/primary_model_fixture.php | 4 +-
cake/tests/fixtures/product_fixture.php | 4 +-
cake/tests/fixtures/project_fixture.php | 4 +-
cake/tests/fixtures/sample_fixture.php | 4 +-
.../fixtures/secondary_model_fixture.php | 4 +-
cake/tests/fixtures/session_fixture.php | 4 +-
.../tests/fixtures/something_else_fixture.php | 4 +-
cake/tests/fixtures/something_fixture.php | 4 +-
cake/tests/fixtures/stories_tag_fixture.php | 4 +-
cake/tests/fixtures/story_fixture.php | 4 +-
cake/tests/fixtures/syfile_fixture.php | 4 +-
cake/tests/fixtures/tag_fixture.php | 4 +-
.../fixtures/test_plugin_article_fixture.php | 4 +-
.../fixtures/test_plugin_comment_fixture.php | 4 +-
.../fixtures/the_paper_monkies_fixture.php | 4 +-
cake/tests/fixtures/thread_fixture.php | 4 +-
.../fixtures/translate_article_fixture.php | 4 +-
cake/tests/fixtures/translate_fixture.php | 4 +-
.../fixtures/translate_table_fixture.php | 4 +-
.../fixtures/translated_article_fixture.php | 4 +-
.../fixtures/translated_item_fixture.php | 4 +-
.../fixtures/unconventional_tree_fixture.php | 2 +-
.../fixtures/underscore_field_fixture.php | 2 +-
cake/tests/fixtures/user_fixture.php | 4 +-
cake/tests/fixtures/uuid_fixture.php | 4 +-
cake/tests/fixtures/uuid_tag_fixture.php | 4 +-
cake/tests/fixtures/uuid_tree_fixture.php | 2 +-
cake/tests/fixtures/uuiditem_fixture.php | 4 +-
.../uuiditems_uuidportfolio_fixture.php | 4 +-
...ditems_uuidportfolio_numericid_fixture.php | 6 +-
cake/tests/fixtures/uuidportfolio_fixture.php | 4 +-
cake/tests/groups/acl.group.php | 17 +-
cake/tests/groups/cache.group.php | 17 +-
cake/tests/groups/components.group.php | 17 +-
cake/tests/groups/configure.group.php | 17 +-
cake/tests/groups/console.group.php | 15 +-
cake/tests/groups/helpers.group.php | 17 +-
cake/tests/groups/lib.group.php | 17 +-
cake/tests/groups/lib_controller.group.php | 10 +-
cake/tests/groups/model.group.php | 17 +-
cake/tests/groups/no_database.group.php | 21 +-
cake/tests/groups/routing_system.group.php | 17 +-
cake/tests/groups/socket.group.php | 17 +-
cake/tests/groups/test_suite.group.php | 17 +-
cake/tests/groups/view.group.php | 17 +-
cake/tests/groups/xml.group.php | 17 +-
.../controllers/tests_apps_controller.php | 2 +-
.../tests_apps_posts_controller.php | 2 +-
.../components/other_component.php | 2 +-
.../components/plugins_component.php | 2 +-
.../components/test_plugin_component.php | 2 +-
.../test_plugin_other_component.php | 2 +-
.../controllers/tests_controller.php | 2 +-
.../test_plugin_app_controller.php | 2 +-
.../test_plugin/test_plugin_app_model.php | 2 +-
.../vendors/sample/sample_plugin.php | 2 +-
.../test_plugin/vendors/shells/example.php | 2 +-
.../plugins/test_plugin/vendors/welcome.php | 2 +-
.../views/helpers/other_helper.php | 2 +-
.../views/helpers/plugged_helper.php | 2 +-
.../vendors/shells/example.php | 2 +-
.../vendors/shells/welcome.php | 2 +-
cake/tests/test_app/vendors/Test/MyTest.php | 2 +-
cake/tests/test_app/vendors/Test/hello.php | 2 +-
.../sample/configure_test_vendor_sample.php | 2 +-
cake/tests/test_app/vendors/shells/sample.php | 2 +-
.../test_app/vendors/somename/some.name.php | 2 +-
cake/tests/test_app/vendors/welcome.php | 2 +-
224 files changed, 1884 insertions(+), 1804 deletions(-)
diff --git a/cake/tests/cases/basics.test.php b/cake/tests/cases/basics.test.php
index 06ef9a37c..141473cde 100644
--- a/cake/tests/cases/basics.test.php
+++ b/cake/tests/cases/basics.test.php
@@ -1,7 +1,7 @@
_get;
+ }
/**
* testParseParamsWithoutZerosAndEmptyPost method
*
@@ -2088,14 +2092,5 @@ class DispatcherTest extends CakeTestCase {
}
return $filename;
}
-/**
- * tearDown method
- *
- * @access public
- * @return void
- */
- function tearDown() {
- $_GET = $this->_get;
- }
}
?>
\ No newline at end of file
diff --git a/cake/tests/cases/libs/cache.test.php b/cake/tests/cases/libs/cache.test.php
index 54079700f..84102a13e 100644
--- a/cake/tests/cases/libs/cache.test.php
+++ b/cake/tests/cases/libs/cache.test.php
@@ -1,7 +1,7 @@
'Apc', 'prefix' => 'cake_'));
}
+/**
+ * tearDown method
+ *
+ * @access public
+ * @return void
+ */
+ function tearDown() {
+ Cache::config('default');
+ }
/**
* testReadAndWriteCache method
*
@@ -127,14 +136,5 @@ class ApcEngineTest extends UnitTestCase {
$result = Cache::delete('delete_test');
$this->assertTrue($result);
}
-/**
- * tearDown method
- *
- * @access public
- * @return void
- */
- function tearDown() {
- Cache::config('default');
- }
}
?>
\ No newline at end of file
diff --git a/cake/tests/cases/libs/cache/file.test.php b/cake/tests/cases/libs/cache/file.test.php
index 5a57b704e..cc8e0fbc6 100644
--- a/cake/tests/cases/libs/cache/file.test.php
+++ b/cake/tests/cases/libs/cache/file.test.php
@@ -1,7 +1,7 @@
assertEqual($result, $expecting);
-
+
Cache::delete('test');
}
/**
@@ -331,7 +331,12 @@ class FileEngineTest extends CakeTestCase {
Cache::delete('test_dir_map');
$this->assertEqual($expected, $data);
}
-
+/**
+ * testWriteQuotedString method
+ *
+ * @access public
+ * @return void
+ */
function testWriteQuotedString() {
Cache::engine('File', array('path' => TMP . 'tests'));
Cache::write('App.doubleQuoteTest', '"this is a quoted string"');
diff --git a/cake/tests/cases/libs/cache/memcache.test.php b/cake/tests/cases/libs/cache/memcache.test.php
index e258c66d9..09d454739 100644
--- a/cake/tests/cases/libs/cache/memcache.test.php
+++ b/cake/tests/cases/libs/cache/memcache.test.php
@@ -1,7 +1,7 @@
_Engine['Memcache']->connect('127.0.0.1');
$this->assertTrue($result);
}
-
/**
* testReadAndWriteCache method
*
diff --git a/cake/tests/cases/libs/cache/xcache.test.php b/cake/tests/cases/libs/cache/xcache.test.php
index 15d535b68..9a50a8757 100644
--- a/cake/tests/cases/libs/cache/xcache.test.php
+++ b/cake/tests/cases/libs/cache/xcache.test.php
@@ -1,7 +1,7 @@
'Xcache', 'prefix' => 'cake_'));
}
+/**
+ * tearDown method
+ *
+ * @access public
+ * @return void
+ */
+ function tearDown() {
+ Cache::config('default');
+ }
/**
* testSettings method
*
@@ -156,14 +165,5 @@ class XcacheEngineTest extends UnitTestCase {
$result = Cache::clear();
$this->assertTrue($result);
}
-/**
- * tearDown method
- *
- * @access public
- * @return void
- */
- function tearDown() {
- Cache::config('default');
- }
}
?>
\ No newline at end of file
diff --git a/cake/tests/cases/libs/cake_log.test.php b/cake/tests/cases/libs/cake_log.test.php
index bb688af41..05dc39452 100644
--- a/cake/tests/cases/libs/cake_log.test.php
+++ b/cake/tests/cases/libs/cake_log.test.php
@@ -1,7 +1,7 @@
\ No newline at end of file
diff --git a/cake/tests/cases/libs/cake_test_case.test.php b/cake/tests/cases/libs/cake_test_case.test.php
index 7be184316..bd1550bf6 100644
--- a/cake/tests/cases/libs/cake_test_case.test.php
+++ b/cake/tests/cases/libs/cake_test_case.test.php
@@ -1,9 +1,9 @@
_reporter = &$reporter;
}
-
+/**
+ * testDummy method
+ *
+ * @return void
+ * @access public
+ */
function testDummy() {
-
}
}
-
/**
* CakeTestCaseTest
*
- * @package cake.tests
+ * @package cake
* @subpackage cake.tests.cases.libs
- **/
+ */
class CakeTestCaseTest extends CakeTestCase {
/**
* setUp
@@ -76,6 +78,16 @@ class CakeTestCaseTest extends CakeTestCase {
$this->Case->setReporter($reporter);
$this->Reporter = $reporter;
}
+/**
+ * tearDown
+ *
+ * @access public
+ * @return void
+ */
+ function tearDown() {
+ unset($this->Case);
+ unset($this->Reporter);
+ }
/**
* testAssertGoodTags
*
@@ -214,7 +226,6 @@ class CakeTestCaseTest extends CakeTestCase {
$this->assertEqual(array_slice($result, 0, 2), array('start', 'startCase'));
$this->assertEqual(array_slice($result, -2), array('endCase', 'end'));
}
-
/**
* TestTestAction
*
@@ -303,7 +314,7 @@ class CakeTestCaseTest extends CakeTestCase {
$fixture =& new PostFixture($db);
$fixture->create($db);
$fixture->insert($db);
-
+
$result = $this->Case->testAction('/tests_apps_posts/fixtured', array(
'return' => 'vars',
'fixturize' => true,
@@ -334,17 +345,17 @@ class CakeTestCaseTest extends CakeTestCase {
$fixture =& new PostFixture($db);
$fixture->create($db);
$fixture->insert($db);
-
+
$this->Case->dropTables = false;
$result = $this->Case->testAction('/tests_apps_posts/fixtured', array(
'return' => 'vars',
'fixturize' => true,
'connection' => 'cake_test_case',
));
-
+
$tables = $db->listSources();
$this->assertTrue(in_array('cake_testaction_test_suite_posts', $tables));
-
+
$fixture->drop($db);
$db =& ConnectionManager::getDataSource('test_suite');
$db->config['prefix'] = $_backPrefix;
@@ -396,15 +407,5 @@ class CakeTestCaseTest extends CakeTestCase {
Configure::write('viewPaths', $_back['view']);
Configure::write('pluginPaths', $_back['plugin']);
}
-/**
- * tearDown
- *
- * @access public
- * @return void
- */
- function tearDown() {
- unset($this->Case);
- unset($this->Reporter);
- }
}
?>
\ No newline at end of file
diff --git a/cake/tests/cases/libs/cake_test_fixture.test.php b/cake/tests/cases/libs/cake_test_fixture.test.php
index d7b04cfc7..5e17ed25b 100644
--- a/cake/tests/cases/libs/cake_test_fixture.test.php
+++ b/cake/tests/cases/libs/cake_test_fixture.test.php
@@ -1,7 +1,7 @@
'Chewbacca')
);
}
-
-
/**
- * Import Fixture Test Fixture
+ * CakeTestFixtureImportFixture class
*
* @package cake
* @subpackage cake.cake.tests.cases.libs
@@ -88,9 +85,8 @@ class CakeTestFixtureImportFixture extends CakeTestFixture {
*/
var $import = array('table' => 'fixture_tests', 'connection' => 'test_suite');
}
-
/**
- * Import Fixture Test Fixture
+ * CakeTestFixtureDefaultImportFixture class
*
* @package cake
* @subpackage cake.cake.tests.cases.libs
@@ -103,9 +99,8 @@ class CakeTestFixtureDefaultImportFixture extends CakeTestFixture {
*/
var $name = 'ImportFixture';
}
-
/**
- * Fixture Test Case Model
+ * FixtureImportTestModel class
*
* @package default
* @subpackage cake.cake.tests.cases.libs.
@@ -115,9 +110,7 @@ class FixtureImportTestModel extends Model {
var $useTable = 'fixture_tests';
var $useDbConfig = 'test_suite';
}
-
Mock::generate('DboSource', 'FixtureMockDboSource');
-
/**
* Test case for CakeTestFixture
*
@@ -125,10 +118,25 @@ Mock::generate('DboSource', 'FixtureMockDboSource');
* @subpackage cake.cake.tests.cases.libs
*/
class CakeTestFixtureTest extends CakeTestCase {
+/**
+ * setUp method
+ *
+ * @access public
+ * @return void
+ */
function setUp() {
$this->criticDb =& new FixtureMockDboSource();
$this->criticDb->fullDebug = true;
}
+/**
+ * tearDown
+ *
+ * @access public
+ * @return void
+ */
+ function tearDown() {
+ unset($this->criticDb);
+ }
/**
* testInit
*
@@ -215,8 +223,9 @@ class CakeTestFixtureTest extends CakeTestCase {
/**
* test create method
*
+ * @access public
* @return void
- **/
+ */
function testCreate() {
$Fixture =& new CakeTestFixtureTestFixture();
$this->criticDb->expectAtLeastOnce('execute');
@@ -229,12 +238,12 @@ class CakeTestFixtureTest extends CakeTestCase {
$return = $Fixture->create($this->criticDb);
$this->assertFalse($return);
}
-
/**
* test the insert method
*
+ * @access public
* @return void
- **/
+ */
function testInsert() {
$Fixture =& new CakeTestFixtureTestFixture();
$this->criticDb->setReturnValue('insertMulti', true);
@@ -244,12 +253,12 @@ class CakeTestFixtureTest extends CakeTestCase {
$this->assertTrue($this->criticDb->fullDebug);
$this->assertTrue($return);
}
-
/**
* Test the drop method
*
+ * @access public
* @return void
- **/
+ */
function testDrop() {
$Fixture =& new CakeTestFixtureTestFixture();
$this->criticDb->setReturnValueAt(0, 'execute', true);
@@ -267,22 +276,14 @@ class CakeTestFixtureTest extends CakeTestCase {
/**
* Test the truncate method.
*
+ * @access public
* @return void
- **/
+ */
function testTruncate() {
$Fixture =& new CakeTestFixtureTestFixture();
$this->criticDb->expectAtLeastOnce('truncate');
$Fixture->truncate($this->criticDb);
$this->assertTrue($this->criticDb->fullDebug);
}
-/**
- * tearDown
- *
- * @access public
- * @return void
- */
- function tearDown() {
- unset($this->criticDb);
- }
}
-?>
+?>
\ No newline at end of file
diff --git a/cake/tests/cases/libs/class_registry.test.php b/cake/tests/cases/libs/class_registry.test.php
index fd145ea8e..d40ed0e83 100644
--- a/cake/tests/cases/libs/class_registry.test.php
+++ b/cake/tests/cases/libs/class_registry.test.php
@@ -1,7 +1,7 @@
skipif (!extension_loaded('xdebug'), 'XDebug not installed');
+ }
/**
* startTest Method
* Store reference of $_GET to restore later.
@@ -44,7 +51,6 @@ class CodeCoverageManagerTest extends CakeTestCase {
function startCase() {
$this->_get = $_GET;
}
-
/**
* End Case - restore GET vars.
*
@@ -53,14 +59,6 @@ class CodeCoverageManagerTest extends CakeTestCase {
function endCase() {
$_GET = $this->_get;
}
-/**
- * Skip if XDebug not installed
- *
- * @access public
- */
- function skip() {
- $this->skipif (!extension_loaded('xdebug'), 'XDebug not installed');
- }
/**
* testNoTestCaseSupplied method
*
diff --git a/cake/tests/cases/libs/configure.test.php b/cake/tests/cases/libs/configure.test.php
index a8cd784c5..f5da1d324 100644
--- a/cake/tests/cases/libs/configure.test.php
+++ b/cake/tests/cases/libs/configure.test.php
@@ -1,9 +1,9 @@
assertEqual($result, null);
}
-
/**
* testSetErrorReporting Level
*
@@ -537,5 +535,4 @@ class AppImportTest extends UnitTestCase {
$this->assertEqual($text, 'This is the welcome.php file in test_plugin/vendors directory');
}
}
-
?>
\ No newline at end of file
diff --git a/cake/tests/cases/libs/controller/component.test.php b/cake/tests/cases/libs/controller/component.test.php
index a3204e4fd..25b0d6fb6 100644
--- a/cake/tests/cases/libs/controller/component.test.php
+++ b/cake/tests/cases/libs/controller/component.test.php
@@ -1,7 +1,7 @@
Banana->testField = 'OrangeField';
$this->settings = $settings;
}
-
+/**
+ * startup method
+ *
+ * @param Controller $controller
+ * @return string
+ * @access public
+ */
function startup(&$controller) {
$controller->foo = 'pass';
}
@@ -204,7 +211,13 @@ class BananaComponent extends Object {
* @access public
*/
var $testField = 'BananaField';
-
+/**
+ * startup method
+ *
+ * @param Controller $controller
+ * @return string
+ * @access public
+ */
function startup(&$controller) {
$controller->bar = 'fail';
}
@@ -216,6 +229,12 @@ class BananaComponent extends Object {
* @subpackage cake.tests.cases.libs.controller
*/
class MutuallyReferencingOneComponent extends Object {
+/**
+ * components property
+ *
+ * @var array
+ * @access public
+ */
var $components = array('MutuallyReferencingTwo');
}
/**
@@ -225,9 +244,14 @@ class MutuallyReferencingOneComponent extends Object {
* @subpackage cake.tests.cases.libs.controller
*/
class MutuallyReferencingTwoComponent extends Object {
+/**
+ * components property
+ *
+ * @var array
+ * @access public
+ */
var $components = array('MutuallyReferencingOne');
}
-
/**
* SomethingWithEmailComponent class
*
@@ -235,6 +259,12 @@ class MutuallyReferencingTwoComponent extends Object {
* @subpackage cake.tests.cases.libs.controller
*/
class SomethingWithEmailComponent extends Object {
+/**
+ * components property
+ *
+ * @var array
+ * @access public
+ */
var $components = array('Email');
}
/**
@@ -321,7 +351,7 @@ class ComponentTest extends CakeTestCase {
$this->assertTrue(is_a($Controller->Apple->Orange->Banana, 'BananaComponent'));
$this->assertTrue(is_a($Controller->Apple->Orange->Controller, 'ComponentTestController'));
$this->assertTrue(empty($Controller->Apple->Session));
- $this->assertTrue(empty($Controller->Apple->Orange->Session));
+ $this->assertTrue(empty($Controller->Apple->Orange->Session));
}
/**
* Tests Component::startup() and only running callbacks for components directly attached to
@@ -430,7 +460,7 @@ class ComponentTest extends CakeTestCase {
$Controller->Component->initialize($Controller);
$Controller->beforeFilter();
$Controller->Component->startup($Controller);
-
+
$this->assertTrue(is_a(
$Controller->SomethingWithEmail,
'SomethingWithEmailComponent'
@@ -458,5 +488,4 @@ class ComponentTest extends CakeTestCase {
$this->assertEqual($Controller->components, array('Session' => '', 'Orange' => array('colour' => 'blood orange')));
}
}
-
?>
\ No newline at end of file
diff --git a/cake/tests/cases/libs/controller/components/acl.test.php b/cake/tests/cases/libs/controller/components/acl.test.php
index 7e6856dae..e651ebe0d 100644
--- a/cake/tests/cases/libs/controller/components/acl.test.php
+++ b/cake/tests/cases/libs/controller/components/acl.test.php
@@ -1,7 +1,7 @@
Acl);
+ }
/**
* testAclCreate method
*
@@ -543,15 +549,6 @@ class AclComponentTest extends CakeTestCase {
$this->assertFalse($this->Acl->check('nobody', 'comments'));
}
-/**
- * tearDown method
- *
- * @access public
- * @return void
- */
- function tearDown() {
- unset($this->Acl);
- }
/**
* debug function - to help editing/creating test cases for the ACL component
*
diff --git a/cake/tests/cases/libs/controller/components/auth.test.php b/cake/tests/cases/libs/controller/components/auth.test.php
index 83f7cc8a2..8daeee4f6 100644
--- a/cake/tests/cases/libs/controller/components/auth.test.php
+++ b/cake/tests/cases/libs/controller/components/auth.test.php
@@ -1,7 +1,7 @@
redirect($this->Auth->logout());
+ // $this->redirect($this->Auth->logout());
}
/**
* add method
@@ -403,9 +403,9 @@ class AjaxAuthController extends Controller {
}
}
/**
-* Short description for class.
+* AuthTest class
*
-* @package cake.tests
+* @package cake
* @subpackage cake.tests.cases.libs.controller.components
*/
class AuthTest extends CakeTestCase {
@@ -448,6 +448,15 @@ class AuthTest extends CakeTestCase {
$this->Controller->Session->del('Message.auth');
$this->initialized = true;
}
+/**
+ * tearDown method
+ *
+ * @access public
+ * @return void
+ */
+ function tearDown() {
+ unset($this->Controller, $this->AuthUser);
+ }
/**
* testNoAuth method
*
@@ -622,7 +631,6 @@ class AuthTest extends CakeTestCase {
$result = $this->Controller->Auth->isAuthorized();
$this->assertFalse($result);
}
-
/**
* testAuthorizeCrud method
*
@@ -1035,7 +1043,6 @@ class AuthTest extends CakeTestCase {
$user = $this->Controller->Auth->user();
$this->assertTrue(!!$user);
}
-
/**
* testCustomField method
*
@@ -1070,7 +1077,6 @@ class AuthTest extends CakeTestCase {
$user = $this->Controller->Auth->user();
$this->assertTrue(!!$user);
}
-
/**
* testAdminRoute method
*
@@ -1177,14 +1183,5 @@ class AuthTest extends CakeTestCase {
$this->Controller->Auth->shutdown($this->Controller);
$this->assertFalse($this->Controller->Session->read('Auth.redirect'));
}
-/**
- * tearDown method
- *
- * @access public
- * @return void
- */
- function tearDown() {
- unset($this->Controller, $this->AuthUser);
- }
}
?>
\ No newline at end of file
diff --git a/cake/tests/cases/libs/controller/components/cookie.test.php b/cake/tests/cases/libs/controller/components/cookie.test.php
index 7503d5a46..5d8d87aa0 100644
--- a/cake/tests/cases/libs/controller/components/cookie.test.php
+++ b/cake/tests/cases/libs/controller/components/cookie.test.php
@@ -1,7 +1,7 @@
Cookie->name = 'CakeTestCookie';
$this->Cookie->time = 10;
@@ -38,29 +55,19 @@ class CookieComponentTestController extends Controller {
}
}
/**
- * Short description for class.
+ * CookieComponentTest class
*
- * @package cake.tests
+ * @package cake
* @subpackage cake.tests.cases.libs.controller.components
*/
class CookieComponentTest extends CakeTestCase {
+/**
+ * Controller property
+ *
+ * @var CookieComponentTestController
+ * @access public
+ */
var $Controller;
-
- function __encrypt($value) {
- if (is_array($value)) {
- $value = $this->__implode($value);
- }
- return "Q2FrZQ==." .base64_encode(Security::cipher($value, $this->Controller->Cookie->key));
- }
-
-
- function __implode($array) {
- $string = '';
- foreach ($array as $key => $value) {
- $string .= ',' . $key . '|' . $value;
- }
- return substr($string, 1);
- }
/**
* start
*
@@ -75,6 +82,15 @@ class CookieComponentTest extends CakeTestCase {
$this->Controller->Component->startup($this->Controller);
$this->Controller->Cookie->destroy();
}
+/**
+ * end
+ *
+ * @access public
+ * @return void
+ */
+ function end() {
+ $this->Controller->Cookie->destroy();
+ }
/**
* testCookieName
*
@@ -393,13 +409,31 @@ class CookieComponentTest extends CakeTestCase {
unset($_COOKIE['CakeTestCookie']);
}
/**
- * end
+ * encrypt method
*
- * @access public
- * @return void
+ * @param mixed $value
+ * @return string
+ * @access private
*/
- function end() {
- $this->Controller->Cookie->destroy();
+ function __encrypt($value) {
+ if (is_array($value)) {
+ $value = $this->__implode($value);
+ }
+ return "Q2FrZQ==." . base64_encode(Security::cipher($value, $this->Controller->Cookie->key));
+ }
+/**
+ * implode method
+ *
+ * @param array $value
+ * @return string
+ * @access private
+ */
+ function __implode($array) {
+ $string = '';
+ foreach ($array as $key => $value) {
+ $string .= ',' . $key . '|' . $value;
+ }
+ return substr($string, 1);
}
}
?>
\ No newline at end of file
diff --git a/cake/tests/cases/libs/controller/components/email.test.php b/cake/tests/cases/libs/controller/components/email.test.php
index 18c0f7c57..bf42ad877 100644
--- a/cake/tests/cases/libs/controller/components/email.test.php
+++ b/cake/tests/cases/libs/controller/components/email.test.php
@@ -1,9 +1,9 @@
My own html content
";
$this->assertEqual($result, $expected);
}
-
+/**
+ * testMultibyte method
+ *
+ * @access public
+ * @return void
+ */
function testMultibyte() {
$this->Controller->Email->reset();
$this->Controller->Email->to = 'postmaster@localhost';
@@ -396,10 +413,15 @@ TEXTBLOC;
preg_match('/Subject: (.*)Header:/s', $this->Controller->Session->read('Message.email.message'), $matches);
$this->assertEqual(trim($matches[1]), $subject);
}
-
+/**
+ * osFix method
+ *
+ * @param string $string
+ * @access private
+ * @return string
+ */
function __osFix($string) {
return str_replace(array("\r\n", "\r"), "\n", $string);
}
}
-
?>
\ No newline at end of file
diff --git a/cake/tests/cases/libs/controller/components/request_handler.test.php b/cake/tests/cases/libs/controller/components/request_handler.test.php
index a839dd213..3a597e8de 100644
--- a/cake/tests/cases/libs/controller/components/request_handler.test.php
+++ b/cake/tests/cases/libs/controller/components/request_handler.test.php
@@ -1,7 +1,7 @@
RequestHandler->enabled = false;
}
}
/**
- * Short description for class.
+ * RequestHandlerComponentTest class
*
- * @package cake.tests
+ * @package cake
* @subpackage cake.tests.cases.libs.controller.components
*/
class RequestHandlerComponentTest extends CakeTestCase {
+/**
+ * Controller property
+ *
+ * @var RequestHandlerTestController
+ * @access public
+ */
+ var $Controller;
+/**
+ * RequestHandler property
+ *
+ * @var RequestHandlerComponent
+ * @access public
+ */
+ var $RequestHandler;
/**
* setUp method
*
@@ -114,15 +133,17 @@ class RequestHandlerComponentTest extends CakeTestCase {
$this->_init();
}
/**
- * init method
+ * tearDown method
*
- * @access protected
+ * @access public
* @return void
*/
- function _init() {
- $this->Controller = new RequestHandlerTestController(array('components' => array('RequestHandler')));
- $this->Controller->constructClasses();
- $this->RequestHandler =& $this->Controller->RequestHandler;
+ function tearDown() {
+ unset($this->RequestHandler);
+ unset($this->Controller);
+ if (!headers_sent()) {
+ header('Content-type: text/html'); //reset content type.
+ }
}
/**
* testInitializeCallback method
@@ -196,7 +217,7 @@ class RequestHandlerComponentTest extends CakeTestCase {
$_SERVER['CONTENT_TYPE'] = 'application/xml; charset=UTF-8';
$this->RequestHandler->startup($this->Controller);
$this->assertTrue(is_object($this->Controller->data));
- $this->assertEqual(strtolower(get_class($this->Controller->data)), 'xml');
+ $this->assertEqual(strtolower(get_class($this->Controller->data)), 'xml');
}
/**
* testNonAjaxRedirect method
@@ -481,17 +502,15 @@ class RequestHandlerComponentTest extends CakeTestCase {
unset($_SERVER['HTTP_X_REQUESTED_WITH']);
}
/**
- * tearDown method
+ * init method
*
- * @access public
+ * @access protected
* @return void
*/
- function tearDown() {
- unset($this->RequestHandler);
- unset($this->Controller);
- if (!headers_sent()) {
- header('Content-type: text/html'); //reset content type.
- }
+ function _init() {
+ $this->Controller = new RequestHandlerTestController(array('components' => array('RequestHandler')));
+ $this->Controller->constructClasses();
+ $this->RequestHandler =& $this->Controller->RequestHandler;
}
}
?>
\ No newline at end of file
diff --git a/cake/tests/cases/libs/controller/components/security.test.php b/cake/tests/cases/libs/controller/components/security.test.php
index 468f68452..8314a18a2 100644
--- a/cake/tests/cases/libs/controller/components/security.test.php
+++ b/cake/tests/cases/libs/controller/components/security.test.php
@@ -1,7 +1,7 @@
_validatePost($controller);
}
}
/**
-* Short description for class.
+* SecurityTestController
*
-* @package cake.tests
+* @package cake
* @subpackage cake.tests.cases.libs.controller.components
*/
class SecurityTestController extends Controller {
@@ -104,14 +109,27 @@ class SecurityTestController extends Controller {
$this->testHeaders[] = $status;
}
}
-
/**
- * Short description for class.
+ * SecurityComponentTest class
*
- * @package cake.tests
+ * @package cake
* @subpackage cake.tests.cases.libs.controller.components
*/
class SecurityComponentTest extends CakeTestCase {
+/**
+ * Controller property
+ *
+ * @var SecurityTestController
+ * @access public
+ */
+ var $Controller;
+/**
+ * oldSalt property
+ *
+ * @var string
+ * @access public
+ */
+ var $oldSalt;
/**
* setUp method
*
@@ -128,7 +146,7 @@ class SecurityComponentTest extends CakeTestCase {
Configure::write('Security.salt', 'foo!');
}
/**
- * Tear-down method. Resets environment state.
+ * Tear-down method. Resets environment state.
*
* @access public
* @return void
@@ -139,7 +157,6 @@ class SecurityComponentTest extends CakeTestCase {
unset($this->Controller);
Configure::write('Security.salt', $this->oldSalt);
}
-
/**
* testStartup method
*
@@ -584,7 +601,6 @@ DIGEST;
$result = $this->Controller->Security->validatePost($this->Controller);
$this->assertTrue($result);
}
-
/**
* test ValidatePost with multiple select elements.
*
@@ -776,7 +792,6 @@ DIGEST;
$result = $this->Controller->Security->validatePost($this->Controller);
$this->assertTrue($result);
}
-
/**
* testValidateHasManyRecordsPass method
*
@@ -1079,5 +1094,4 @@ DIGEST;
$this->assertEqual(current($this->Controller->testHeaders), $expected);
}
}
-
-?>
+?>
\ No newline at end of file
diff --git a/cake/tests/cases/libs/controller/components/session.test.php b/cake/tests/cases/libs/controller/components/session.test.php
index f0dde24b1..1fe1f61e6 100644
--- a/cake/tests/cases/libs/controller/components/session.test.php
+++ b/cake/tests/cases/libs/controller/components/session.test.php
@@ -1,7 +1,7 @@
Session->id();
}
@@ -42,20 +53,31 @@ class SessionTestController extends Controller {
/**
* OrangeSessionTestController class
*
- * @package cake.tests
+ * @package cake
* @subpackage cake.tests.cases.libs.controller.components
*/
class OrangeSessionTestController extends Controller {
+/**
+ * uses property
+ *
+ * @var array
+ * @access public
+ */
var $uses = array();
-
+/**
+ * session_id method
+ *
+ * @return string
+ * @access public
+ */
function session_id() {
return $this->Session->id();
}
}
/**
- * Short description for class.
+ * SessionComponentTest class
*
- * @package cake.tests
+ * @package cake
* @subpackage cake.tests.cases.libs.controller.components
*/
class SessionComponentTest extends CakeTestCase {
diff --git a/cake/tests/cases/libs/controller/controller.test.php b/cake/tests/cases/libs/controller/controller.test.php
index 3f64adbc8..5e16708a8 100644
--- a/cake/tests/cases/libs/controller/controller.test.php
+++ b/cake/tests/cases/libs/controller/controller.test.php
@@ -1,7 +1,7 @@
_params;
}
}
-
/**
* ScaffoldMock class
*
@@ -112,9 +110,8 @@ class ScaffoldMock extends CakeTestModel {
)
);
}
-
/**
- * ScaffoldAuthor class
+ * ScaffoldUser class
*
* @package cake
* @subpackage cake.tests.cases.libs.controller
@@ -140,7 +137,6 @@ class ScaffoldUser extends CakeTestModel {
)
);
}
-
/**
* ScaffoldComment class
*
@@ -168,7 +164,6 @@ class ScaffoldComment extends CakeTestModel {
)
);
}
-
/**
* TestScaffoldView class
*
@@ -188,9 +183,9 @@ class TestScaffoldView extends ScaffoldView {
}
}
/**
- * ScaffoldViewTest Case.
+ * ScaffoldViewTest class
*
- * @package cake.tests
+ * @package cake
* @subpackage cake.tests.cases.libs.controller
*/
class ScaffoldViewTest extends CakeTestCase {
@@ -210,6 +205,15 @@ class ScaffoldViewTest extends CakeTestCase {
function setUp() {
$this->Controller =& new ScaffoldMockController();
}
+/**
+ * tearDown method
+ *
+ * @access public
+ * @return void
+ */
+ function tearDown() {
+ unset($this->Controller);
+ }
/**
* testGetViewFilename method
*
@@ -298,7 +302,6 @@ class ScaffoldViewTest extends CakeTestCase {
Configure::write('pluginPaths', $_back['pluginPaths']);
Configure::write('Routing.admin', $_admin);
}
-
/**
* test default index scaffold generation
*
@@ -505,26 +508,21 @@ class ScaffoldViewTest extends CakeTestCase {
Configure::write('Routing.admin', $_backAdmin);
}
-
-/**
- * tearDown method
- *
- * @access public
- * @return void
- */
- function tearDown() {
- unset($this->Controller);
- }
}
-
-
/**
- * Scaffold Test Case
+ * Scaffold Test class
*
* @package cake
* @subpackage cake.tests.cases.libs.controller
*/
-class ScaffoldTestCase extends CakeTestCase {
+class ScaffoldTest extends CakeTestCase {
+/**
+ * Controller property
+ *
+ * @var SecurityTestController
+ * @access public
+ */
+ var $Controller;
/**
* fixtures property
*
@@ -541,6 +539,15 @@ class ScaffoldTestCase extends CakeTestCase {
function setUp() {
$this->Controller =& new ScaffoldMockController();
}
+/**
+ * tearDown method
+ *
+ * @access public
+ * @return void
+ */
+ function tearDown() {
+ unset($this->Controller);
+ }
/**
* Test the correct Generation of Scaffold Params.
* This ensures that the correct action and view will be generated
@@ -573,15 +580,5 @@ class ScaffoldTestCase extends CakeTestCase {
$result = $Scaffold->getParams();
$this->assertEqual($result['action'], 'admin_edit');
}
-/**
- * tearDown method
- *
- * @access public
- * @return void
- */
- function tearDown() {
- unset($this->Controller);
- }
}
-
?>
\ No newline at end of file
diff --git a/cake/tests/cases/libs/debugger.test.php b/cake/tests/cases/libs/debugger.test.php
index 0f80d2bf8..57f8b03dc 100644
--- a/cake/tests/cases/libs/debugger.test.php
+++ b/cake/tests/cases/libs/debugger.test.php
@@ -1,7 +1,7 @@
assertEqual(ini_get('docref_root'), 'http://php.net/');
}
-
/**
* test Excerpt writing
*
+ * @access public
* @return void
- **/
+ */
function testExcerpt() {
$return = Debugger::excerpt(__FILE__, 2, 2);
$this->assertTrue(is_array($return));
$this->assertEqual(count($return), 4);
$this->assertPattern('#/* SVN FILE: \$Id: debugger.test.php#', $return[1]);
-
+
$return = Debugger::excerpt('[internal]', 2, 2);
$this->assertTrue(empty($return));
}
@@ -247,34 +257,24 @@ class DebuggerTest extends CakeTestCase {
$expected = "array(\n\t\"People\" => array()\n)
";
$this->assertEqual($expected, $result);
}
-
/**
* test getInstance.
*
- * @return void
- **/
- function testGetInstance() {
- $result = Debugger::getInstance();
- $this->assertIsA($result, 'Debugger');
-
- $result = Debugger::getInstance('DebuggerTestCaseDebugger');
- $this->assertIsA($result, 'DebuggerTestCaseDebugger');
-
- $result = Debugger::getInstance();
- $this->assertIsA($result, 'DebuggerTestCaseDebugger');
-
- $result = Debugger::getInstance('Debugger');
- $this->assertIsA($result, 'Debugger');
- }
-/**
- * tearDown method
- *
* @access public
* @return void
*/
- function tearDown() {
- Configure::write('log', true);
- }
+ function testGetInstance() {
+ $result = Debugger::getInstance();
+ $this->assertIsA($result, 'Debugger');
+ $result = Debugger::getInstance('DebuggerTestCaseDebugger');
+ $this->assertIsA($result, 'DebuggerTestCaseDebugger');
+
+ $result = Debugger::getInstance();
+ $this->assertIsA($result, 'DebuggerTestCaseDebugger');
+
+ $result = Debugger::getInstance('Debugger');
+ $this->assertIsA($result, 'Debugger');
+ }
}
?>
\ No newline at end of file
diff --git a/cake/tests/cases/libs/error.test.php b/cake/tests/cases/libs/error.test.php
index b0b85947f..ef09072c0 100644
--- a/cake/tests/cases/libs/error.test.php
+++ b/cake/tests/cases/libs/error.test.php
@@ -1,7 +1,7 @@
assertPattern('/Not Found<\/h2>/', $result);
$this->assertPattern("/'\/test_error'<\/strong>/", $result);
-
+
ob_start();
$TestErrorHandler =& new TestErrorHandler('error404', array('message' => 'Page not found'));
ob_get_clean();
diff --git a/cake/tests/cases/libs/file.test.php b/cake/tests/cases/libs/file.test.php
index 6ec5ffbb9..2daff0f20 100644
--- a/cake/tests/cases/libs/file.test.php
+++ b/cake/tests/cases/libs/file.test.php
@@ -1,7 +1,7 @@
skipif (true, 'FlayTest not implemented');
+ $this->skipif(true, 'FlayTest not implemented');
}
}
?>
\ No newline at end of file
diff --git a/cake/tests/cases/libs/folder.test.php b/cake/tests/cases/libs/folder.test.php
index 34fe46e0e..d9edfc83f 100644
--- a/cake/tests/cases/libs/folder.test.php
+++ b/cake/tests/cases/libs/folder.test.php
@@ -1,7 +1,7 @@
Socket, $this->RequestSocket);
@@ -69,6 +73,8 @@ class HttpSocketTest extends CakeTestCase {
/**
* Test that HttpSocket::__construct does what one would expect it to do
*
+ * @access public
+ * @return void
*/
function testConstruct() {
$this->Socket->reset();
@@ -92,10 +98,11 @@ class HttpSocketTest extends CakeTestCase {
$this->Socket->__construct(array('request' => array('uri' => 'http://www.cakephp.org:23/')));
$this->assertIdentical($this->Socket->config, $baseConfig);
}
-
/**
* Test that HttpSocket::configUri works properly with different types of arguments
*
+ * @access public
+ * @return void
*/
function testConfigUri() {
$this->Socket->reset();
@@ -158,10 +165,11 @@ class HttpSocketTest extends CakeTestCase {
$this->assertIdentical($this->Socket->config, $expected);
$this->assertIdentical($r, false);
}
-
/**
* Tests that HttpSocket::request (the heart of the HttpSocket) is working properly.
*
+ * @access public
+ * @return void
*/
function testRequest() {
$this->Socket->reset();
@@ -515,10 +523,11 @@ class HttpSocketTest extends CakeTestCase {
$this->RequestSocket->{low($method)}('http://www.google.com/', null, array('line' => 'Hey Server'));
}
}
-
/**
- * Enter description here...
+ * testParseResponse method
*
+ * @access public
+ * @return void
*/
function testParseResponse() {
$this->Socket->reset();
@@ -605,10 +614,11 @@ class HttpSocketTest extends CakeTestCase {
}
}
}
-
/**
- * Enter description here...
+ * testDecodeBody method
*
+ * @access public
+ * @return void
*/
function testDecodeBody() {
$this->Socket->reset();
@@ -647,10 +657,11 @@ class HttpSocketTest extends CakeTestCase {
}
}
}
-
/**
- * Enter description here...
+ * testDecodeChunkedBody method
*
+ * @access public
+ * @return void
*/
function testDecodeChunkedBody() {
$this->Socket->reset();
@@ -763,10 +774,11 @@ class HttpSocketTest extends CakeTestCase {
$r = $this->Socket->buildRequestLine("GET * HTTP/1.1\r\n");
$this->assertIdentical($r, "GET * HTTP/1.1\r\n");
}
-
/**
* Asserts that HttpSocket::parseUri is working properly
*
+ * @access public
+ * @return void
*/
function testParseUri() {
$this->Socket->reset();
@@ -867,10 +879,11 @@ class HttpSocketTest extends CakeTestCase {
'port' => 8080,
));
}
-
/**
* Tests that HttpSocket::buildUri can turn all kinds of uri arrays (and strings) into fully or partially qualified URI's
*
+ * @access public
+ * @return void
*/
function testBuildUri() {
$this->Socket->reset();
@@ -929,10 +942,11 @@ class HttpSocketTest extends CakeTestCase {
$r = $this->Socket->buildUri(array('scheme' => 'foo', 'host' => 'www.cakephp.org'));
$this->assertIdentical($r, 'foo://www.cakephp.org:80/');
}
-
/**
* Asserts that HttpSocket::parseQuery is working properly
*
+ * @access public
+ * @return void
*/
function testParseQuery() {
$this->Socket->reset();
@@ -1033,11 +1047,12 @@ class HttpSocketTest extends CakeTestCase {
);
$this->assertIdentical($query, $expectedQuery);
}
-
/**
* Tests that HttpSocket::buildHeader can turn a given $header array into a proper header string according to
* HTTP 1.1 specs.
*
+ * @access public
+ * @return void
*/
function testBuildHeader() {
$this->Socket->reset();
@@ -1070,10 +1085,11 @@ class HttpSocketTest extends CakeTestCase {
$this->assertIdentical($r, "Test\"@\"Field: My value\r\n");
}
-
/**
* Test that HttpSocket::parseHeader can take apart a given (and valid) $header string and turn it into an array.
*
+ * @access public
+ * @return void
*/
function testParseHeader() {
$this->Socket->reset();
@@ -1131,10 +1147,10 @@ class HttpSocketTest extends CakeTestCase {
$this->assertIdentical($r, $expected);
}
/**
- * undocumented function
+ * testParseCookies method
*
- * @return void
* @access public
+ * @return void
*/
function testParseCookies() {
$header = array(
@@ -1168,7 +1184,7 @@ class HttpSocketTest extends CakeTestCase {
$this->assertEqual($cookies, $expected);
}
/**
- * undocumented function
+ * testBuildCookies method
*
* @return void
* @access public
@@ -1191,6 +1207,8 @@ class HttpSocketTest extends CakeTestCase {
/**
* Tests that HttpSocket::__tokenEscapeChars() returns the right characters.
*
+ * @access public
+ * @return void
*/
function testTokenEscapeChars() {
$this->Socket->reset();
@@ -1211,10 +1229,11 @@ class HttpSocketTest extends CakeTestCase {
$r = $this->Socket->__tokenEscapeChars(false);
$this->assertEqual($r, $expected);
}
-
/**
* Test that HttpSocket::escapeToken is escaping all characters as descriped in RFC 2616 (HTTP 1.1 specs)
*
+ * @access public
+ * @return void
*/
function testEscapeToken() {
$this->Socket->reset();
@@ -1235,10 +1254,11 @@ class HttpSocketTest extends CakeTestCase {
$expectedToken = 'Extreme-":"Token-" "-""""@"-test';
$this->assertIdentical($expectedToken, $escapedToken);
}
-
/**
* Test that escaped token strings are properly unescaped by HttpSocket::unescapeToken
*
+ * @access public
+ * @return void
*/
function testUnescapeToken() {
$this->Socket->reset();
@@ -1259,11 +1279,12 @@ class HttpSocketTest extends CakeTestCase {
$expectedToken = 'Extreme-:Token- -"@-test';
$this->assertIdentical($expectedToken, $escapedToken);
}
-
/**
* This tests asserts HttpSocket::reset() resets a HttpSocket instance to it's initial state (before Object::__construct
* got executed)
*
+ * @access public
+ * @return void
*/
function testReset() {
$this->Socket->reset();
@@ -1281,11 +1302,12 @@ class HttpSocketTest extends CakeTestCase {
$this->assertIdentical($return, true);
}
-
/**
* This tests asserts HttpSocket::reset(false) resets certain HttpSocket properties to their initial state (before
* Object::__construct got executed).
*
+ * @access public
+ * @return void
*/
function testPartialReset() {
$this->Socket->reset();
@@ -1308,6 +1330,5 @@ class HttpSocketTest extends CakeTestCase {
}
$this->assertIdentical($return, true);
}
-
}
?>
\ No newline at end of file
diff --git a/cake/tests/cases/libs/i18n.test.php b/cake/tests/cases/libs/i18n.test.php
index d10a61f73..89d87cc23 100644
--- a/cake/tests/cases/libs/i18n.test.php
+++ b/cake/tests/cases/libs/i18n.test.php
@@ -1,7 +1,7 @@
assertFalse(in_array('24 everything else (from core translated)', $corePlurals));
$this->assertFalse(in_array('25 everything else (from core translated)', $corePlurals));
}
-
+/**
+ * testPluginTranslation method
+ *
+ * @access public
+ * @return void
+ */
function testPluginTranslation() {
$pluginPaths = Configure::read('pluginPaths');
Configure::write('pluginPaths', array(TEST_CAKE_CORE_INCLUDE_PATH . 'tests' . DS . 'test_app' . DS . 'plugins'));
diff --git a/cake/tests/cases/libs/inflector.test.php b/cake/tests/cases/libs/inflector.test.php
index e3f1b5710..089fe5e9c 100644
--- a/cake/tests/cases/libs/inflector.test.php
+++ b/cake/tests/cases/libs/inflector.test.php
@@ -1,7 +1,7 @@
Inflector = Inflector::getInstance();
}
+/**
+ * tearDown method
+ *
+ * @access public
+ * @return void
+ */
+ function tearDown() {
+ unset($this->Inflector);
+ }
/**
* testInstantiation method
*
@@ -246,14 +255,5 @@ class InflectorTest extends CakeTestCase {
$this->assertEqual(Inflector::humanize('posts_tags'), 'Posts Tags');
$this->assertEqual(Inflector::humanize('file_systems'), 'File Systems');
}
-/**
- * tearDown method
- *
- * @access public
- * @return void
- */
- function tearDown() {
- unset($this->Inflector);
- }
}
?>
\ No newline at end of file
diff --git a/cake/tests/cases/libs/l10n.test.php b/cake/tests/cases/libs/l10n.test.php
index 4737ff4a6..f3aaea211 100644
--- a/cake/tests/cases/libs/l10n.test.php
+++ b/cake/tests/cases/libs/l10n.test.php
@@ -1,7 +1,7 @@
Db =& new MagicDb();
}
-
/**
* MagicDb::analyze should properly detect the file type and output additional info as requested.
*
@@ -63,7 +60,6 @@ class MagicDbTest extends UnitTestCase {
$r = $this->Db->analyze(WWW_ROOT.'img'.DS.'cake.icon.gif');
// TODO: Check several serialized file samples for accurate detection
}
-
/**
* MagicDb::read should properly read MagicDb databases from .php-/.db-files and plain data arguments passed in and return false if the file wasn't found or
* if the readed data did not validate.
@@ -103,7 +99,6 @@ class MagicDbTest extends UnitTestCase {
$r = $this->Db->read(MagicDbTestData::get('magic.snippet.db'));
$this->assertTrue($r === true);
}
-
/**
* MagicDb::toArray should either return the MagicDb::db property, or the parsed array data if a magic.db dump is passed in as the first argument
*
@@ -127,7 +122,6 @@ class MagicDbTest extends UnitTestCase {
$r = $this->Db->toArray(MagicDbTestData::get('magic.snippet.db'));
$this->assertTrue($r === MagicDbTestData::get('magic.snippet.db.result'));
}
-
/**
* The MagicDb::validates function should return if the array passed to it or the local db property contains a valid MagicDb record set
*
@@ -152,11 +146,10 @@ class MagicDbTest extends UnitTestCase {
$this->assertTrue($r === true);
}
}
-
/**
* Test data holding object for MagicDb tests
*
- * @package cake.tests
+ * @package cake
* @subpackage cake.tests.cases.libs
*/
/**
@@ -177,7 +170,6 @@ class MagicDbTestData extends Object {
'magic.snippet.db.result' => 'YToyOntzOjY6ImhlYWRlciI7YToyOntzOjQ6IkRhdGUiO3M6MTA6IjIwMDUtMDMtMjkiO3M6NjoiU291cmNlIjtzOjIyOiJodHRwOi8vd3d3Lm1hZ2ljZGIub3JnIjt9czo4OiJkYXRhYmFzZSI7YToyOntpOjA7YTo0OntpOjA7YTo0OntpOjA7czoxOiIwIjtpOjE7czo2OiJzdHJpbmciO2k6MjtzOjg6IlxceEZGV1BDIjtpOjM7czo1OToiW2ZpZD0wMDAwMDEwMDgtMDAtMDAwMDAwMTtleHQ9O21pbWU9O11Xb3JkcGVyZmVjdCBoZWxwIGZpbGUiO31pOjE7YTo0OntpOjA7czoyOiImOSI7aToxO3M6NDoiYnl0ZSI7aToyO3M6NDoiMHgwMiI7aTozO3M6MDoiIjt9aToyO2E6Mzp7aTowO3M6ODoiPjEwIGJ5dGUiO2k6MTtzOjE6IngiO2k6MjtzOjEyOiIsIHZlcnNpb24gJWQiO31pOjM7YTo0OntpOjA7czozOiI+MTEiO2k6MTtzOjQ6ImJ5dGUiO2k6MjtzOjE6IngiO2k6MztzOjM6Ii4lZCI7fX1pOjE7YTo0OntpOjA7YTo0OntpOjA7czoxOiIwIjtpOjE7czo2OiJzdHJpbmciO2k6MjtzOjg6IlxceEZGV1BDIjtpOjM7czo3ODoiW2ZpZD0wMDAwMDEwMDgtMDAtMDAwMDAwMTtleHQ9O21pbWU9O11Xb3JkcGVyZmVjdCBhcHBsaWNhdGlvbiByZXNvdXJjZSBsaWJyYXJ5Ijt9aToxO2E6NDp7aTowO3M6MjoiJjkiO2k6MTtzOjQ6ImJ5dGUiO2k6MjtzOjI6IjUxIjtpOjM7czowOiIiO31pOjI7YTo0OntpOjA7czozOiI+MTAiO2k6MTtzOjQ6ImJ5dGUiO2k6MjtzOjE6IngiO2k6MztzOjEyOiIsIHZlcnNpb24gJWQiO31pOjM7YTo0OntpOjA7czozOiI+MTEiO2k6MTtzOjQ6ImJ5dGUiO2k6MjtzOjE6IngiO2k6MztzOjM6Ii4lZCI7fX19fQ==',
'magic.db' => '# FILE_ID DB
# Date:2005-03-29
# Source:http://www.magicdb.org

# Magic ID for Wordperfect files.
# Submitted on 2004-02-14 by Carl
0	string	\\xFFWPC	[fid=000001008-00-0000001;ext=;mime=;]Wordperfect help file
&9	byte	0x02	
>10 byte	x	, version %d
>11	byte	x	.%d

# Magic ID for Wordperfect files.
# Submitted on 2004-02-14 by Carl
0	string	\\xFFWPC	[fid=000001008-00-0000001;ext=;mime=;]Wordperfect application resource library
&9	byte	51	
>10	byte	x	, version %d
>11	byte	x	.%d

# Magic ID for Wordperfect files.
# Submitted on 2004-02-14 by Carl
0	string	\\xFFWPC	[fid=000001008-00-0000001;ext=;mime=;]Wordperfect block file
&9	byte	13	
>10	byte	x	, version %d
>11	byte	x	.%d

# Magic ID for Wordperfect files.
# Submitted on 2004-02-14 by Carl
0	string	\\xFFWPC	[fid=000001008-00-0000001;ext=;mime=;]Wordperfect column block
&9	byte	15	
>10	byte	x	, version %d
>11	byte	x	.%d

# Magic ID for Wordperfect files.
# Submitted on 2004-02-14 by Carl
0	string	\\xFFWPC	[fid=000001008-00-0000001;ext=;mime=;]Wordperfect dictionary file
&9	byte	0x0B	
>10	byte	x	, version %d
>11	byte	x	.%d

# Magic ID for Wordperfect files.
# Submitted on 2004-02-14 by Carl
0	string	\\xFFWPC	[fid=000001008-00-0000001;ext=;mime=;]Wordperfect dictionary rules file
&9	byte	34	
>10	byte	x	, version %d
>11	byte	x	.%d

# Magic ID for Wordperfect files.
# Submitted on 2004-02-14 by Carl
0	string	\\xFFWPC	[fid=000001008-00-0000001;ext=;mime=;]Wordperfect external spell code module file
&9	byte	46	
>10	byte	x	, version %d
>11	byte	x	.%d

# Magic ID for Wordperfect files.
# Submitted on 2004-02-14 by Carl
0	string	\\xFFWPC	[fid=000001008-00-0000001;ext=;mime=;]Wordperfect external spell dictionary file
&9	byte	47	
>10	byte	x	, version %d
>11	byte	x	.%d

# Magic ID for Wordperfect files.
# Submitted on 2004-02-14 by Carl
0	string	\\xFFWPC	[fid=000001008-00-0000001;ext=;mime=;]Wordperfect Graphics screen driver file
&9	byte	26	
>10	byte	x	, version %d
>11	byte	x	.%d

# Magic ID for Wordperfect files.
# Submitted on 2004-02-14 by Carl
0	string	\\xFFWPC	[fid=000001008-00-0000001;ext=;mime=;]Wordperfect hyphenation code module file
&9	byte	23	
>10	byte	x	, version %d
>11	byte	x	.%d

# Magic ID for Wordperfect files.
# Submitted on 2004-02-14 by Carl
0	string	\\xFFWPC	[fid=000001008-00-0000001;ext=;mime=;]Wordperfect hyphenation data module file
&9	byte	24	
>10	byte	x	, version %d
>11	byte	x	.%d

# Magic ID for Wordperfect files.
# Submitted on 2004-02-14 by Carl
0	string	\\xFFWPC	[fid=000001008-00-0000001;ext=;mime=;]Wordperfect hyphenation lex module
&9	byte	27	
>10	byte	x	, version %d
>11	byte	x	.%d

# Magic ID for Wordperfect files.
# Submitted on 2004-02-14 by Carl
0	string	\\xFFWPC	[fid=000001008-00-0000001;ext=;mime=;]Wordperfect installation information file
&9	byte	41	
>10	byte	x	, version %d
>11	byte	x	.%d

# Magic ID for Wordperfect files.
# Submitted on 2004-02-14 by Carl
0	string	\\xFFWPC	[fid=000001008-00-0000001;ext=;mime=;]Wordperfect keyboard definition file
&9	byte	0x03	
>10	byte	x	, version %d
>11	byte	x	.%d

# Magic ID for Wordperfect files.
# Submitted on 2004-02-14 by Carl
0	string	\\xFFWPC	[fid=000001008-00-0000001;ext=;mime=;]Wordperfect macro data file
&9	byte	0x01	
>10	byte	x	, version %d
>11	byte	x	.%d

# Magic ID for Wordperfect files.
# Submitted on 2004-02-14 by Carl
0	string	\\xFFWPC	[fid=000001008-00-0000001;ext=;mime=;]Wordperfect macro resource file
&9	byte	25	
>10	byte	x	, version %d
>11	byte	x	.%d

# Magic ID for Wordperfect files.
# Submitted on 2004-02-14 by Carl
0	string	\\xFFWPC	[fid=000001008-00-0000001;ext=;mime=;]Wordperfect printer Q codes (used by VAX/DG)
&9	byte	28	
>10	byte	x	, version %d
>11	byte	x	.%d

# Magic ID for Wordperfect files.
# Submitted on 2004-02-14 by Carl
0	string	\\xFFWPC	[fid=000001008-00-0000001;ext=;mime=;]Wordperfect rectangular block file
&9	byte	14	
>10	byte	x	, version %d
>11	byte	x	.%d

# Magic ID for Wordperfect files.
# Submitted on 2004-02-14 by Carl
0	string	\\xFFWPC	[fid=000001008-00-0000001;ext=;mime=;]Wordperfect spell code module rules file
&9	byte	33	
>10	byte	x	, version %d
>11	byte	x	.%d

# Magic ID for Wordperfect files.
# Submitted on 2004-02-14 by Carl
0	string	\\xFFWPC	[fid=000001008-00-0000001;ext=;mime=;]Wordperfect spell code module word list
&9	byte	29	
>10	byte	x	, version %d
>11	byte	x	.%d

# Magic ID for Wordperfect files.
# Submitted on 2004-02-14 by Carl
0	string	\\xFFWPC	[fid=000001008-00-0000001;ext=;mime=;]Wordperfect thesarus file
&9	byte	12	
>10	byte	x	, version %d
>11	byte	x	.%d

# Magic ID for Wordperfect files.
# Submitted on 2004-02-14 by Carl
0	string	\\xFFWPC	[fid=000001008-00-0000001;ext=;mime=;]Wordperfect VAX keyboard definition file
&9	byte	0x04	
>10	byte	x	, version %d
>11	byte	x	.%d

# Magic ID for Wordperfect files.
# Submitted on 2004-02-14 by Carl
0	string	\\xFFWPC	[fid=000001008-00-0000ALL;ext=all;mime=;]Wordperfect printer resource file
&9	byte	19	
>10	byte	x	, version %d
>11	byte	x	.%d

# Submitted on 2004-02-11 by Carl
0	string	RIFF	[fid=000001001-00-0000CON;ext=con;mime=;]Microsoft Animated cursor, little-endian
&8	string	ACON	

# Submitted on 2004-02-11 by Carl
0	string	RIFX	[fid=000001001-00-0000CON;ext=con;mime=;]Microsoft Animated cursor, big-endian
&8	string	ACON	

# Magic ID for Wordperfect files.
# Submitted on 2004-02-14 by Carl
0	string	\\xFFWPC	[fid=000001008-00-0000DOC;ext=doc;mime=;]Macintosh Wordperfect document file
&9	byte	44	
>10	byte	x	, version %d
>11	byte	x	.%d

# Magic ID for Wordperfect files.
# Submitted on 2004-02-14 by Carl
0	string	\\xFFWPC	[fid=000001008-00-0000DOC;ext=doc;mime=;]VAX Wordperfect document file
&9	byte	45	
>10	byte	x	, version %d
>11	byte	x	.%d

# Magic ID for Wordperfect files.
# Submitted on 2004-02-14 by Carl
0	string	\\xFFWPC	[fid=000001008-00-0000DRS;ext=drs;mime=;]Wordperfect display resource file
&9	byte	20	
>10	byte	x	, version %d
>11	byte	x	.%d

# Magic ID for Wordperfect files.
# Submitted on 2004-02-14 by Carl
0	string	\\xFFWPC	[fid=000001008-00-0000FIL;ext=fil;mime=;]Wordperfect overlay file
&9	byte	21	
>10	byte	x	, version %d
>11	byte	x	.%d

# Submitted on 2004-02-14 by Carl
0	string	PMCC	[fid=000001001-00-0000GRP;ext=grp;mime=;]Microsoft windows group file

# Submitted on 2004-02-14 by Carl
0	beshort	0xE310	[fid=000001007-00-000INFO;ext=info;mime=;]Amiga shortcut / icon file

# Magic ID for Wordperfect files.
# Submitted on 2004-02-14 by Carl
0	string	\\xFFWPC	[fid=000001008-00-0000INS;ext=ins;mime=;]Wordperfect installation information file
&9	byte	43	
>10	byte	x	, version %d
>11	byte	x	.%d

# Submitted on 2004-02-14 by Carl
0	lelong	0x0000004C	[fid=000001001-00-0000LNK;ext=lnk;mime=;]Microsoft Windows shortcut file
&4	string	\\x01\\x14\\x02	

# Magic ID for Wordperfect files.
# Submitted on 2004-02-14 by Carl
0	string	\\xFFWPC	[fid=000001008-00-0000PRS;ext=prs;mime=;]Wordperfect printer resource file
&9	byte	16	
>10	byte	x	, version %d
>11	byte	x	.%d

# Magic ID for Wordperfect files.
# Submitted on 2004-02-14 by Carl
0	string	\\xFFWPC	[fid=000001008-00-0000QRS;ext=qrs;mime=;]Wordperfect 5.1 equation resource file
&9	byte	30	
>10	byte	x	, version %d
>11	byte	x	.%d

# Magic ID for Wordperfect files.
# Submitted on 2004-02-14 by Carl
0	string	\\xFFWPC	[fid=000001008-00-0000SET;ext=set;mime=;]Wordperfect setup data
&9	byte	17	
>10	byte	x	, version %d
>11	byte	x	.%d

# Submitted on 2004-02-08 by Carl
0	string	RIFF	[fid=000001001-0E-0000PAL;ext=pal,riff;mime=;]Microsoft Palette, little-endian
&8	string	PAL	

# Submitted on 2004-02-08 by Carl
0	string	RIFX	[fid=000001001-0E-0000PAL;ext=pal,rifx;mime=;]Microsoft Palette, big-endian
&8	string	PAL	

# Submitted on 2004-03-04 by Carl
0	string	DOS	[fid=000001007-0F-0000ADF;ext=adf;mime=;]AmigaOS File system
&3	byte&0xf8	0	
>3	byte&1	0	, OFS
>3	byte&1	1	, FFS

# Submitted on 2004-05-11 by Carl
0	belong	0x03F3	[fid=000001007-10-LIBRARY;ext=,library;mime=;]Amiga Classic executable file (680x0 family)

# Submitted on 2004-02-11 by Carl
0	string	\\x7fELF	[fid=000000003-10-000000O;ext=,o,so,out;mime=;]Executable linkable file (ELF)
&4	byte	=1	, 32-bit

# Submitted on 2004-02-11 by Carl
0	string	\\x7fELF	[fid=000000003-10-000000O;ext=,o,so,out;mime=;]Executable linkable file (ELF)
&4	byte	=2	, 64-bit

# Submitted on 2004-04-14 by Carl
0	string	MZ	[fid=000001001-10-0000EXE;ext=exe,dll;mime=;]New executable file
&0x18	leshort	>0x3F	
&(60.l)	string	NE	

# Submitted on 2004-04-14 by Carl
0	string	ZM	[fid=000001001-10-0000EXE;ext=exe,dll;mime=;]New executable file
&0x18	leshort	>0x3F	
&(60.l)	string	NE	

# Submitted on 2004-04-14 by Carl
0	string	MZ	[fid=000001001-10-0000EXE;ext=exe,dll;mime=;]Microsoft Windows 3.x New Executable file
&0x18	leshort	>0x3F	
&(60.l)	string	NE	
&(60.l+54)	byte	0x02	

# Submitted on 2004-04-14 by Carl
0	string	ZM	[fid=000001001-10-0000EXE;ext=exe,dll;mime=;]Microsoft Windows 3.x New Executable file
&0x18	leshort	>0x3F	
&(60.l)	string	NE	
&(60.l+54)	byte	0x02	

# Submitted on 2004-04-14 by Carl
0	string	MZ	[fid=000001009-10-0000EXE;ext=exe,dll;mime=;]IBM OS/2 New Executable file
&0x18	leshort	>0x3F	
&(60.l)	string	NE	
&(60.l+54)	byte	0x01	

# Submitted on 2004-04-14 by Carl
0	string	ZM	[fid=000001009-10-0000EXE;ext=exe,dll;mime=;]IBM OS/2 New Executable file
&0x18	leshort	>0x3F	
&(60.l)	string	NE	
&(60.l+54)	byte	0x01	

# Magic ID for Microsoft Windows files.
# Submitted on 2004-04-13 by Carl
0	string	MZ	[fid=000001001-10-0000EXE;ext=exe,dll;mime=;]Microsoft Windows NT Portable Executable file
&0x18	leshort	0x40	
&(60.l)	string	PE\\x00\\x00	

# Magic ID for Microsoft Windows files.
# Submitted on 2004-04-13 by Carl
0	string	ZM	[fid=000001001-10-0000EXE;ext=exe,dll;mime=;]Microsoft Windows NT Portable Executable file
&0x18	leshort	0x40	
&(60.l)	string	PE\\x00\\x00	

# Magic ID for Microsoft Windows,DOS4GW files.
# Submitted on 2004-04-14 by Carl
0	string	MZ	[fid=000001001-10-0000EXE;ext=exe,dll,drv;mime=;]Microsoft Windows Linear executable
&0x18	leshort	>0x3F	
&(60.l)	string	LE	

# Magic ID for Microsoft Windows,DOS4GW files.
# Submitted on 2004-04-14 by Carl
0	string	ZM	[fid=000001001-10-0000EXE;ext=exe,dll,drv;mime=;]Microsoft Windows Linear executable
&0x18	leshort	>0x3F	
&(60.l)	string	LE	

# Magic ID for OS/2,DOS4GW files.
# Submitted on 2004-04-14 by Carl
0	string	MZ	[fid=000001009-10-0000EXE;ext=exe,dll,drv;mime=;]OS/2 Linear executable
&0x18	leshort	>0x3F	
&(60.l)	string	LX	

# Magic ID for OS/2,DOS4GW files.
# Submitted on 2004-04-14 by Carl
0	string	ZM	[fid=000001009-10-0000EXE;ext=exe,dll,drv;mime=;]OS/2 Linear executable
&0x18	leshort	>0x3F	
&(60.l)	string	LX	

# Submitted on 2004-07-30 by Carl
0	string	MSFT	[fid=000001001-10-0000TLB;ext=tlb;mime=;]Microsoft component type library

# Submitted on 2004-05-11 by Carl
0	beshort	0x601A	[fid=000001006-10-0000TTP;ext=ttp,gem,prg;mime=;]Atari MiNT executable/object file
&0x12	string	MiNT	

# Submitted on 2004-05-11 by Carl
0	beshort	0x601A	[fid=000001006-10-0000TTP;ext=ttp,gem,prg;mime=;]Atari TOS executable/object file
&0x12	belong	0x0000	

# Magic ID for Virtual Pascal files.
# Submitted on 2004-07-30 by Carl
0	string	VPI	[fid=000000000-10-0000VPI;ext=vpi;mime=;]Virtual pascal unit file
&0x03	byte	>47	
&0x03	byte	<58	

# Magic ID for Java compiler files.
# Submitted on 2004-05-11 by Carl
0	belong	0xCAFEBABE	[fid=000001011-11-00CLASS;ext=class;mime=;]Javal virtual machine class file
>6	beshort	x	, version %d
>4	beshort	x	.%d

# Magic ID for Borland Delphi files.
# Submitted on 2004-07-30 by Carl
0	string	PKG	[fid=000001005-11-0000DCP;ext=dcp;mime=;]Borland Delphi compiled package code file
&0x03	byte	>47	
&0x03	byte	<58	

# Magic ID for Borland Delphi files.
# Submitted on 2004-07-30 by Carl
0	string	\\xDF\\x00\\x00\\x0F	[fid=000001005-11-0000DCU;ext=dcu;mime=;]Borland Delphi code unit file

# Magic ID for Turbo Pascal files.
# Submitted on 2004-07-29 by Carl
0	string	TPU9	[fid=000001005-11-0000TPU;ext=tpu;mime=;]Turbo Pascal 6.0 code unit file

# Magic ID for Turbo Pascal, Borland Pascal files.
# Submitted on 2004-07-29 by Carl
0	string	TPUQ	[fid=000001005-11-0000TPU;ext=tpu,tpp,tpw;mime=;]Borland Pascal 7.0 code unit file

# Submitted on 2004-02-15 by Carl
2	string	ADLIB-	[fid=000001016-20-0000BNK;ext=bnk;mime=;]Adlib FM instrument bank file
>0	byte	x	, version %d
>1	byte	x	.%d

# Submitted on 2004-02-16 by Carl
0	string	IBK\\x1A	[fid=000001013-20-0000IBK;ext=ibk;mime=;]Creative Labs FM instrument bank file

# Magic ID for Microsoft Instrument Definition file files.
# Submitted on 2004-03-04 by Carl
0	string	RIFF	[fid=000001001-20-0000IDF;ext=idf;mime=;]Microsoft instrument definition file, little-endian
&8	string	IDF\\ 	

# Magic ID for Microsoft Instrument Definition file files.
# Submitted on 2004-03-04 by Carl
0	string	RIFX	[fid=000001001-20-0000IDF;ext=idf;mime=;]Microsoft instrument definition file, big-endian
&8	string	IDF\\ 	

# Magic ID for Digitrakker files.
# Submitted on 2004-03-04 by Carl
0	string	DIST	[fid=000100088-20-0000IST;ext=ist;mime=;]Digitrakker Instrument file
&4	byte	<2	

# Magic ID for Impulse tracker files.
# Submitted on 2004-03-04 by Carl
0	string	IMPI	[fid=000100032-20-0000ITI;ext=iti;mime=;]Impulse tracker instrument file
>0x20	string	x	[title=%.26s]

# Magic ID for Madtracker files.
# Submitted on 2004-03-05 by Carl
0	string	MI21	[fid=000100091-20-0000MTI;ext=mti;mime=;]Madtracker instrument file

# Magic ID for Gravis Ultrasound files.
# Submitted on 2004-02-15 by Carl
0	string	GF1PATCH100\\0ID#000002\\0	[fid=000001018-20-0000PAT;ext=pat;mime=;]Gravis Ultrasound Patch (old instrument data)

# Magic ID for Gravis Ultrasound files.
# Submitted on 2004-02-15 by Carl
0	string	GF1PATCH110\\0ID#000002\\0	[fid=000001018-20-0000PAT;ext=pat;mime=;]Gravis Ultrasound Patch (instrument data)

# Submitted on 2004-02-15 by Carl
0	string	SBI\\x1A	[fid=000001013-20-0000SBI;ext=sbi;mime=;]Creative Labs FM instrument data file
>4	string	>0	[title=%.32s]

# Magic ID for Sidplay files.
# Submitted on 2004-03-05 by Carl
0	string	SIDPLAY\\ INFOFILE	[fid=000000000-20-0000SID;ext=sid;mime=;]SIDPlayer music file

# Magic ID for Fasttracker 2.0 files.
# Submitted on 2004-02-15 by Carl
0	string	Extended\\ Instrument:\\ 	[fid=000100026-20-00000XI;ext=xi;mime=;]FastTracker II instrument file

# Submitted on 2004-02-15 by Carl
0	string	RIFF	[fid=000001001-21-0000000;ext=;mime=;]MIDI music file, little-endian
&8	string	RMID	

# Submitted on 2004-02-15 by Carl
0	string	RIFX	[fid=000001001-21-0000000;ext=;mime=;]MIDI music file, big-endian
&8	string	RMID	

# Magic ID for Abyss\'s highest experience (AHX) files.
# Submitted on 2004-02-15 by Carl
0	string	THX	[fid=000100029-21-0000AHX;ext=ahx;mime=;]AHX module music file

# Magic ID for Amusic files.
# Submitted on 2004-02-15 by Carl
1062	string	\\x3c\\x6f\\xef\\x51\\x55\\xEE\\x52\\x6F\\x52	[fid=000100034-21-0000AMD;ext=amd;mime=;]Amusic Adlib tracker music file
>0	string	>\\x00	[title=%.23s]
>24	string	>\\0	[creator=%.24s]

# Magic ID for Velvet Studio files.
# Submitted on 2004-02-15 by Carl
0	string	AMShdr\\x1a	[fid=000001276-21-0000AMS;ext=ams;mime=;]Velvet Studio module music file

# Magic ID for Audio visual research files.
# Submitted on 2004-03-04 by Carl
0	string	2BIT	[fid=000001301-21-0000AVR;ext=avr;mime=;]Audio visual research audio file
>4	string	x	[title=%.8s]

# Magic ID for Soundmon files.
# Submitted on 2004-02-15 by Carl
26	string	V.2	[fid=000100028-21-00000BP;ext=bp;mime=;]Soundmon module music file, version 2.x
>0	string	>\\0	[title=%.26s]

# Magic ID for Soundmon files.
# Submitted on 2004-02-15 by Carl
26	string	V.3	[fid=000100028-21-0000BP3;ext=bp3;mime=;]Soundmon module music file, version 3.x
>0	string	>\\0	[title=%.26s]

# Submitted on 2004-02-15 by Carl
0	string	CTMF	[fid=000001013-21-0000CMF;ext=cmf;mime=;]Creative Labs music file
>4	byte	x	, version %d
>5	byte	x	.%d

# Magic ID for Digibooster files.
# Submitted on 2004-03-04 by Carl
0	string	DIGI Booster module\\0	[fid=000001302-21-000DIGI;ext=digi;mime=;]Digibooster music file
>610	string	x	[title=%.32s]

# Magic ID for Delusion Xtracker files.
# Submitted on 2004-02-15 by Carl
0	string	DDMF	[fid=000000000-21-0000DMF;ext=dmf;mime=;]Delusion tracker module music file
>4	byte	x	, version %d.0
>13	string	>\\0	[title=%.30s]
>43	string	>\\0	[creator=%.20s]

# Magic ID for DOS Sound interface kit (DSIK) files.
# Submitted on 2004-02-15 by Carl
0	string	RIFF	[fid=000000000-21-0000DSM;ext=dsm;mime=;]DOS Sound interface kit module music file
&8	string	DSMF	

# Magic ID for Edlib files.
# Submitted on 2004-03-07 by Carl
0	string	\\x00\\x06\\xFE\\xFD	[fid=000100027-21-0000EDL;ext=edl;mime=;]Edlib FM tracker music file

# Magic ID for Quadra Composer files.
# Submitted on 2004-03-04 by Carl
0	string	FORM	[fid=000100085-21-0000EMD;ext=emd;mime=;]Enhanced module music file (IFF)
&8	string	EMOD	

# Magic ID for Farandole composer files.
# Submitted on 2004-02-15 by Carl
0	string	FAR\\xFE	[fid=000100087-21-0000FAR;ext=far;mime=;]Farandole composer module music file
>4	string	>\\0	[title=%.40s]

# Magic ID for Funktracker Gold files.
# Submitted on 2004-03-04 by Carl
0	string	Funk	[fid=000100086-21-0000FNK;ext=fnk;mime=;]Funktracker Gold music file

# Magic ID for Bells, Whistles, and Sound Boards files.
# Submitted on 2004-02-16 by Carl
0	string	GDM\\xFE	[fid=000001280-21-0000GDM;ext=gdm;mime=;]General DigiMusic module music file
>4	string	>\\x00	[title=%.32s]

# Magic ID for Graoumf Tracker 2 files.
# Submitted on 2004-02-15 by Carl
0	string	GT2	[fid=000100031-21-0000GT2;ext=gt2;mime=;]Graoumf Tracker module music file

# Magic ID for Imago Morpheus files.
# Submitted on 2004-03-04 by Carl
0x3C	string	IM10	[fid=000001279-21-0000IMF;ext=imf;mime=;]Imago morpheus music file, 32 channels
>0	string	x	[title=%.31s]

# Magic ID for Impulse tracker files.
# Submitted on 2004-02-15 by Carl
0	string	IMPM	[fid=000100032-21-00000IT;ext=it;mime=;]Impulse Tracker module music file
>4	string	>\\x00	[title=%.26s]

# Magic ID for Jamcracker files.
# Submitted on 2004-03-04 by Carl
0	string	BeEp	[fid=000000000-21-0000JAM;ext=jam;mime=;]Jamcracker tracker module music file

# Magic ID for Liquid tracker files.
# Submitted on 2004-03-04 by Carl
0	string	Liquid Module:	[fid=000100090-21-0000LIQ;ext=liq;mime=;]Liquid tracker module music file
&0x40	byte	0x1A	
>0x0E	string	>\\0	[title=%.30s]
>0x2c	string	>\\0	[creator=%.20s]

# Magic ID for Digitrakker files.
# Submitted on 2004-03-04 by Carl
0	string	DMDL	[fid=000100088-21-0000MDL;ext=mdl;mime=;]Digitrakker module music file
&4	byte	<0x12	

# Magic ID for MED Soundstudio / OctaMED files.
# Submitted on 2004-02-15 by Carl
0	string	MMD0	[fid=000001278-21-0000MED;ext=med;mime=;]Octamed tracker module music file

# Magic ID for MED Soundstudio / OctaMED files.
# Submitted on 2004-02-15 by Carl
0	string	MMD1	[fid=000001278-21-0000MED;ext=med;mime=;]Octamed Pro Tracker module music file

# Magic ID for MED Soundstudio / OctaMED files.
# Submitted on 2004-02-15 by Carl
0	string	MMD2	[fid=000001278-21-0000MED;ext=med;mime=;]Octamed Pro Tracker module music file

# Magic ID for MED Soundstudio / OctaMED files.
# Submitted on 2004-02-15 by Carl
0	string	MMD3	[fid=000001278-21-0000MED;ext=med;mime=;]Octamed Sound Studio module music file

# Magic ID for Musicline files.
# Submitted on 2004-03-05 by Carl
0	string	MLEDMODL	[fid=000001304-21-00000ML;ext=ml;mime=;]Musicline module music file

# Magic ID for Protracker files.
# Submitted on 2004-02-15 by Carl
1080	string	M!K!	[fid=000100022-21-0000MOD;ext=mod;mime=;]Protracker 2.3 module music file
>0	string	>\\0	[title=%.20s]

# Magic ID for Protracker files.
# Submitted on 2004-02-15 by Carl
1080	string	M.K.	[fid=000100022-21-0000MOD;ext=mod;mime=;]Protracker module music file
>0	string	>\\0	[title=%.20s]

# Magic ID for Protracker files.
# Submitted on 2004-03-05 by Carl
0	string	FORM	[fid=000100022-21-0000MOD;ext=mod;mime=;]Protracker module music file, version 3.x
&8	string	MODL	

# Magic ID for Startrekker files.
# Submitted on 2004-02-15 by Carl
1080	string	FLT4	[fid=000100024-21-0000MOD;ext=mod;mime=;]Startrekker module music file, 4 channels
>0	string	>\\0	[title=%.20s]

# Magic ID for Startrekker files.
# Submitted on 2004-02-15 by Carl
1080	string	FLT8	[fid=000100024-21-0000MOD;ext=mod;mime=;]Startrekker module music file, 8 channels
>0	string	>\\0	[title=%.20s]

# Magic ID for Fasttracker files.
# Submitted on 2004-02-15 by Carl
1080	string	6CHN	[fid=000001275-21-0000MOD;ext=mod;mime=;]Fasttracker module music file, 6 channels
>0	string	>\\0	[title=%.20s]

# Magic ID for Fasttracker files.
# Submitted on 2004-02-15 by Carl
1080	string	8CHN	[fid=000001275-21-0000MOD;ext=mod;mime=;]Fasttracker module music file, 6 channels
>0	string	>\\0	[title=%.20s]

# Magic ID for Madtracker files.
# Submitted on 2004-03-05 by Carl
0	string	MT20	[fid=000100091-21-0000MT2;ext=mt2;mime=;]Madtracker module music file
>42	string	x	[title=%.64s]
>112	leshort	x	[chn=%d]

# Magic ID for Multitracker Module editor files.
# Submitted on 2004-02-15 by Carl
0	string	MTM	[fid=000100089-21-0000MTM;ext=mtm;mime=;]MultiTracker module music file
>4	string	>\\x00	[title=%.20s]

# Magic ID for Madtracker files.
# Submitted on 2004-03-05 by Carl
0	string	MTP2	[fid=000100091-21-0000MTP;ext=mtp;mime=;]Madtracker pattern file

# Magic ID for A/NES files.
# Submitted on 2004-03-07 by Carl
0	string	NESA	[fid=000100094-21-0000NSA;ext=nsa;mime=;]A/NES ripped audio file

# Submitted on 2004-03-07 by Carl
0	string	NESM\\x1A	[fid=000100093-21-0000NSF;ext=nsf;mime=;]NES ripped audio file
>5	byte	x	, version %d.0
>0x0E	string	x	[title=%.32s]
>0x2E	string	x	[creator=%.32s]

# Magic ID for Noisetracker files.
# Submitted on 2004-02-15 by Carl
1080	string	M&K!	[fid=000100023-21-0000NST;ext=nst;mime=;]Noisetracker module music file
>0	string	>\\0	[title=%.20s]

# Magic ID for Oktalyzer tracker files.
# Submitted on 2004-02-15 by Carl
0	string	OKTASONG	[fid=000100030-21-0000OKT;ext=okt;mime=;]Oktalyzer module music file

# Magic ID for SBStudio sound files.
# Submitted on 2004-03-05 by Carl
0	string	PACG	[fid=000100020-21-0000PAC;ext=pac;mime=;]SBStudio module music file

# Magic ID for Polytracker files.
# Submitted on 2004-02-15 by Carl
44	string	PTMF	[fid=000000000-21-0000PTM;ext=ptm;mime=;]Poly Tracker module music file
>38	leshort	>0	[chn=%d]
>0	string	>\\0	[title=%.28s]

# Magic ID for Reality Adlib tracker files.
# Submitted on 2004-02-15 by Carl
0	string	RAD\\ by	[fid=000000000-21-0000RAD;ext=rad;mime=;]Reality Adlib tracker music file

# Submitted on 2004-02-15 by Carl
0	string	RIFF	[fid=000000000-21-0000RMI;ext=rmi;mime=application/vnd.music-niff;]Song notation data file, little-endian
&8	string	NIFF	

# Submitted on 2004-02-15 by Carl
0	string	RIFX	[fid=000000000-21-0000RMI;ext=rmi;mime=application/vnd.music-niff;]Song notation data file, big-endian
&8	string	NIFF	

# Magic ID for Adlib Visual Composer files.
# Submitted on 2004-02-15 by Carl
0	leshort	0x0000	[fid=000001016-21-0000ROL;ext=rol;mime=;]Adlib music file
&2	leshort	0x0004	

# Magic ID for Screamtracker 3 files.
# Submitted on 2004-02-15 by Carl
0x2C	string	SCRM	[fid=000100025-21-0000S3M;ext=s3m;mime=;]Scream tracker module music file
>0x2A	leshort	>0	, version %d.0
>0	string	>\\0	[title=%.28s]

# Magic ID for Surprise! Adlib Tracker files.
# Submitted on 2004-02-15 by Carl
0	string	SAdT	[fid=000100021-21-0000SA2;ext=sa2;mime=;]Surprise Productions Adlib tracker music file
>4	byte	x	, version 0.%d

# Magic ID for SoundFX files.
# Submitted on 2004-02-15 by Carl
60	string	SONG	[fid=000001277-21-0000SFX;ext=sfx;mime=;]SoundFX Tracker module music file

# Magic ID for PlaySID, Sidplay files.
# Submitted on 2004-03-05 by Carl
0	string	PSID	[fid=000000000-21-0000SID;ext=sid;mime=;]PlaySID music file
>16	string	x	[title=%.20s]
>36	string	x	[creator=%.20s]

# Submitted on 2004-02-15 by Carl
0	string	MThd	[fid=000001017-21-0000SMF;ext=smf,midi;mime=;]Standard MIDI music file
>10	beshort	>0	[chn=%d]

# Submitted on 2004-03-05 by Carl
0	string	FORM	[fid=000001010-21-000SMUS;ext=smus,mus;mime=;]IFF Simple Musical Score file
&8	string	SMUS	

# Magic ID for Sndtool2,nezplay files.
# Submitted on 2004-03-05 by Carl
0	string	SND\\x1A	[fid=000000000-21-0000SND;ext=snd;mime=;]Nintendo Entertainment System audio file (NES)
&4	byte	3	, version %3.0
>5	byte	x	[chn=%d]

# Magic ID for iNES files.
# Submitted on 2004-03-05 by Carl
0	string	SND\\x1A	[fid=000100092-21-0000SND;ext=snd;mime=;]iNES emulator audio file
&4	byte	1	, version %1.0
>5	byte	x	[chn=%d]

# Magic ID for STMIK files.
# Submitted on 2004-02-15 by Carl
0x15	string	Scream!	[fid=000100025-21-0000STX;ext=stx;mime=;]STMIK module music file

# Magic ID for The Final Musicsystem eXtended (TFMX) files.
# Submitted on 2004-03-07 by Carl
0	string	TFMX-SONG\\ 	[fid=000100096-21-0000TFX;ext=tfx,tfmx;mime=;]TFMX tracker module music file

# Magic ID for Ultra Tracker files.
# Submitted on 2004-03-07 by Carl
0	string	MAS_UTrack_V00	[fid=000100097-21-0000ULT;ext=ult;mime=;]Ultra Tracker module music file
>15	string	x	[title=%.32s]

# Magic ID for APlayer files.
# Submitted on 2004-02-15 by Carl
0	string	APUN\\x01	[fid=000000000-21-0000UNI;ext=uni;mime=;]APlayer module music file

# Magic ID for Mikmod files.
# Submitted on 2004-02-15 by Carl
0	string	UN0	[fid=000000000-21-0000UNI;ext=uni;mime=;]Mikmod module music file
>4	byte	x	[chn=%d]

# Magic ID for Fasttracker 2.0 files.
# Submitted on 2004-02-15 by Carl
0	string	Extended\\ Module:\\ 	[fid=000100026-21-00000XM;ext=xm;mime=;]FastTracker II module music file
>59	byte	x	, version %d
>58	byte	x	.0%d
>17	string	x	[title=%.20s]

# Submitted on 2004-02-11 by Carl
0	string	FORM	[fid=000001010-22-0008SVX;ext=8svx;mime=;]Amiga Sampled audio file
&8	string	8SVX	

# Submitted on 2004-02-11 by Carl
0	string	FORM	[fid=000001002-22-000AIFC;ext=aifc,aif;mime=;]Audio Compressed Interchange File Format
&8	string	AIFC	

# Submitted on 2004-02-11 by Carl
0	string	FORM	[fid=000001002-22-000AIFF;ext=aiff,aif;mime=;]Audio Interchange File Format
&8	string	AIFF	

# Magic ID for MonkeyAudio software files.
# Submitted on 2004-05-20 by Carl
0	string	MAC\\ 	[fid=000100120-22-0000APE;ext=ape;mime=;]MonkeyAudio compressed audio file

# Submitted on 2004-02-11 by Carl
0	string	.snd	[fid=000001011-22-00000AU;ext=au,snd;mime=;]Sun / NeXt sampled audio file
>16	belong	>0	[freq=%d]

# Magic ID for Sppack files.
# Submitted on 2004-03-04 by Carl
252	beshort	0x40C3	[fid=000001019-22-000000D;ext=d;mime=;]Sppack audio sample file
&254	beshort	0xFC0E	

# Magic ID for Flac files.
# Submitted on 2004-03-08 by Carl
0	string	fLaC	[fid=000100098-22-000FLAC;ext=flac;mime=;]Free Lossless Audio Codec raw audio file

# Magic ID for Farandole Composer files.
# Submitted on 2004-03-04 by Carl
0	string	FSM\\xFE	[fid=000100087-22-0000FSM;ext=fsm;mime=;]Farandole composer audio sample file
>4	string	x	[title=%.32s]

# Magic ID for MAUD files.
# Submitted on 2004-03-04 by Carl
0	string	FORM	[fid=000000000-22-000MAUD;ext=maud;mime=;]MAUD audio sample file
&4	string	MAUD	

# Submitted on 2004-05-04 by Carl
0	beshort&0xFFE0	0xffe0	[fid=000000001-22-0011172;ext=mp1,mp2,mp3;mime=audio/mpeg;]MP3 Audio stream file
&Z128	string	TAG	
>Z125	string	x	[title=%.30s]
>Z95	string	x	[creator=%.30s]

# Submitted on 2004-05-04 by Carl
0	string	ID3	[fid=000000001-22-0011172;ext=mp1,mp2,mp3;mime=audio/mpeg;]MP3 Audio stream file

# Submitted on 2004-02-11 by Carl
0	string	\\0\\001\\243\\144	[fid=000001014-22-00000SF;ext=sf;mime=;]IRCAM audio sample file

# Submitted on 2004-02-11 by Carl
0	string	\\0\\002\\243\\144	[fid=000001014-22-00000SF;ext=sf;mime=;]IRCAM audio sample file, little-endian

# Submitted on 2004-02-11 by Carl
0	string	\\0\\003\\243\\144	[fid=000001014-22-00000SF;ext=sf;mime=;]IRCAM audio sample file, big-endian

# Submitted on 2004-02-11 by Carl
0	string	\\144\\243\\001\\0	[fid=000001014-22-00000SF;ext=sf;mime=;]IRCAM audio sample file

# Submitted on 2004-02-11 by Carl
0	string	\\144\\243\\002\\0	[fid=000001014-22-00000SF;ext=sf;mime=;]IRCAM audio sample file, big-endian

# Submitted on 2004-02-11 by Carl
0	string	\\144\\243\\003\\0	[fid=000001014-22-00000SF;ext=sf;mime=;]IRCAM audio sample file, little-endian

# Submitted on 2004-02-11 by Carl
0	string	\\144\\243\\004\\0	[fid=000001014-22-00000SF;ext=sf;mime=;]IRCAM audio sample file, big-endian

# Magic ID for Screamtracker files.
# Submitted on 2004-03-05 by Carl
0x4C	string	SCRS	[fid=000100025-22-0000SMP;ext=smp;mime=;]Screamtracker audio sample
>0x30	string	x	[title=%.30s]

# Magic ID for SoundTool files.
# Submitted on 2004-03-07 by Carl
0	string	SOUND\\x1A	[fid=000100095-22-0000SND;ext=snd;mime=;]Sound tool audio data file
>14	leshort	x	[freq=%d]

# Magic ID for SBStudio files.
# Submitted on 2004-02-11 by Carl
0	string	SND\\ 	[fid=000100020-22-0000SOU;ext=sou;mime=;]SBStudio sampled audio file

# Submitted on 2004-05-18 by Carl
0	string	Speex	[fid=000000000-22-00SPEEX;ext=speex;mime=;]Speex Lossy Audio Codec raw audio file

# Magic ID for Sound Blaster SDK files.
# Submitted on 2004-02-11 by Carl
0	string	Creative\\ Voice\\ File\\x1A	[fid=000001013-22-0000VOC;ext=voc;mime=;]Creative Voice audio file

# Submitted on 2004-05-18 by Carl
0	string	vorbis	[fid=000000000-22-0VORBIS;ext=vorbis;mime=;]Vorbis Lossy Audio Codec raw audio file

# Submitted on 2004-02-11 by Carl
0	string	RIFF	[fid=000001001-22-0000WAV;ext=wav;mime=;]Microsoft Waveform Audio file, little-endian
&8	string	WAVE	
>24	lelong	>0	[freq=%d]

# Submitted on 2004-02-11 by Carl
0	string	RIFX	[fid=000001001-22-0000WAV;ext=wav;mime=;]Microsoft Waveform Audio file, big-endian
&8	string	WAVE	
>24	belong	>0	[freq=%d]

# Magic ID for Maya files.
# Submitted on 2004-04-12 by Carl
0	string	FOR4	[fid=000001312-31-0000000;ext=;mime=;]Maya image file
&8	string	CIMG	

# Magic ID for Maya files.
# Submitted on 2004-04-12 by Carl
0	string	FOR8	[fid=000001312-31-0000000;ext=;mime=;]Maya image file
&8	string	CIMG	

# Magic ID for AOL files.
# Submitted on 2004-04-02 by Carl
0	string	JG\\x04\\x0E	[fid=000001023-31-0000ART;ext=art;mime=;]AOL/Johnson-Grace image file, version 2.0
>0x0D	leshort	x	[res=%dx
>0x0F	leshort	x	%d]

# Magic ID for BMF image compressor files.
# Submitted on 2004-02-27 by Carl
0	string	\\x81\\x8A0	[fid=000100048-31-0000BMF;ext=bmf;mime=;]BMF image file
>2	string	x	, version %.1s
>3	string	x	.%.1s

# Magic ID for BMF image compressor files.
# Submitted on 2004-02-27 by Carl
0	string	\\x81\\x8A2	[fid=000100048-31-0000BMF;ext=bmf;mime=;]BMF image file
>2	string	x	, version %.1s
>3	string	x	.%.1s

# Magic ID for BMF image compressor files.
# Submitted on 2004-02-27 by Carl
0	string	\\x81\\x8A1	[fid=000100048-31-0000BMF;ext=bmf;mime=;]BMF image file
>2	string	x	, version %.1s
>3	string	x	.%.1s

# Submitted on 2004-02-14 by Carl
0	string	BM	[fid=000001001-31-0000BMP;ext=bmp;mime=;]Windows or OS/2 Bitmap image file
&6	lelong	0	

# Magic ID for Autodesk Animator files.
# Submitted on 2004-04-08 by Carl
0	leshort	0x9119	[fid=000001254-31-0000CEL;ext=cel,pic;mime=;]Autodesk animator image file
&10	byte	8	
&11	byte	0	
>2	leshort	x	[res=%d
>4	leshort	x	x%dx8bpp]

# Magic ID for Andrew User Interface System files.
# Submitted on 2004-04-02 by Carl
1	string	begindata{raster	[fid=000001315-31-0000CMU;ext=cmu;mime=;]Andrew toolkit raster image file

# Magic ID for Anivga toolkit files.
# Submitted on 2004-04-02 by Carl
38	string	KR\\x01\\x00	[fid=000100104-31-0000COD;ext=cod;mime=;]Anivga sprite image file

# Magic ID for Windows Cursor files.
# Submitted on 2004-04-01 by Carl
0	string	\\x00\\x00\\x02\\x00	[fid=000001001-31-0000CUR;ext=cur;mime=;]Microsoft windows cursor image file
&0x08	byte	0	
>4	leshort	x	, %d cursor(s)
>6	byte	x	[res=%dx
>7	byte	x	%dx8bpp]

# Magic ID for Windows Cursor files.
# Submitted on 2004-04-01 by Carl
0	string	\\x00\\x00\\x02\\x00	[fid=000001001-31-0000CUR;ext=cur;mime=;]Microsoft windows cursor image file
&0x08	byte	16	
>4	leshort	x	, %d cursor(s)
>6	byte	x	[res=%dx
>7	byte	x	%dx4bpp]

# Magic ID for Windows Cursor files.
# Submitted on 2004-04-01 by Carl
0	string	\\x00\\x00\\x02\\x00	[fid=000001001-31-0000CUR;ext=cur;mime=;]Microsoft windows cursor image file
&0x08	byte	2	
>4	leshort	x	, %d cursor(s)
>6	byte	x	[res=%dx
>7	byte	x	%dx1bpp]

# Magic ID for Windows Cursor files.
# Submitted on 2004-04-01 by Carl
0	string	\\x00\\x00\\x02\\x00	[fid=000001001-31-0000CUR;ext=cur;mime=;]Microsoft windows cursor image file
&0x08	byte	32	
>4	leshort	x	, %d cursor(s)
>6	byte	x	[res=%dx
>7	byte	x	%dx5bpp]

# Magic ID for Windows Cursor files.
# Submitted on 2004-04-01 by Carl
0	string	\\x00\\x00\\x02\\x00	[fid=000001001-31-0000CUR;ext=cur;mime=;]Microsoft windows cursor image file
&0x08	byte	64	
>4	leshort	x	, %d cursor(s)
>6	byte	x	[res=%dx
>7	byte	x	%dx6bpp]

# Magic ID for Windows Cursor files.
# Submitted on 2004-04-01 by Carl
0	string	\\x00\\x00\\x02\\x00	[fid=000001001-31-0000CUR;ext=cur;mime=;]Microsoft windows cursor image file
&0x08	byte	8	
>4	leshort	x	, %d cursor(s)
>6	byte	x	[res=%dx
>7	byte	x	%dx3bpp]

# Submitted on 2004-04-13 by Carl
128	string	DICM	[fid=000000004-31-000DICM;ext=dicm,dcm;mime=;]Digital imaging and communication in medecine img.

# Submitted on 2004-04-01 by Carl
0	string	SDPX	[fid=000001309-31-0000DPX;ext=dpx;mime=;]Digital Moving-Picture Exchange image file
>160	string	>\\x00	[creator=%.100s]
>260	string	>\\x00	[title=%.200s]

# Submitted on 2004-04-01 by Carl
0	string	XPDS	[fid=000001309-31-0000DPX;ext=dpx;mime=;]Digital Moving-Picture Exchange image file
>160	string	>\\x00	[creator=%.100s]
>260	string	>\\x00	[title=%.200s]

# Magic ID for Lightwave 3D files.
# Submitted on 2004-04-12 by Carl
0	string	FORM	[fid=000001251-31-000FPBM;ext=fpbm;mime=;]Flexible Precision Buffer Map image file
&8	string	FPBM	

# Submitted on 2004-02-14 by Carl
0	string	GIF8	[fid=000001274-31-0000GIF;ext=gif;mime=image/gif;]GIF image file
&10	byte&0x70	!0x70	
>4	string	x	, version 8%.2s
>6	leshort	>0	[res=%dx
>8	leshort	>0	%d]

# Submitted on 2004-02-14 by Carl
0	string	GIF8	[fid=000001274-31-0000GIF;ext=gif;mime=image/gif;]GIF image file
&10	byte&0x70	0x70	
>4	string	x	, version 8%.2s
>6	leshort	>0	[res=%dx
>8	leshort	>0	%dx8bpp]

# Magic ID for Windows Icon files.
# Submitted on 2004-04-01 by Carl
0	string	\\x00\\x00\\x01\\x00	[fid=000001001-31-0000ICO;ext=ico;mime=image/vnd.microsoft.icon;]Microsoft windows Icon image file
&0x08	byte	0	
>4	leshort	x	, %d icon(s)
>6	byte	x	[res=%dx
>7	byte	x	%dx8bpp]

# Magic ID for Windows Icon files.
# Submitted on 2004-04-01 by Carl
0	string	\\x00\\x00\\x01\\x00	[fid=000001001-31-0000ICO;ext=ico;mime=image/vnd.microsoft.icon;]Microsoft windows Icon image file
&0x08	byte	16	
>4	leshort	x	, %d icon(s)
>6	byte	x	[res=%dx
>7	byte	x	%dx4bpp]

# Magic ID for Windows Icon files.
# Submitted on 2004-04-01 by Carl
0	string	\\x00\\x00\\x01\\x00	[fid=000001001-31-0000ICO;ext=ico;mime=image/vnd.microsoft.icon;]Microsoft windows Icon image file
&0x08	byte	2	
>4	leshort	x	, %d icon(s)
>6	byte	x	[res=%dx
>7	byte	x	%dx1bpp]

# Magic ID for Windows Icon files.
# Submitted on 2004-04-01 by Carl
0	string	\\x00\\x00\\x01\\x00	[fid=000001001-31-0000ICO;ext=ico;mime=image/vnd.microsoft.icon;]Microsoft windows Icon image file
&0x08	byte	32	
>4	leshort	x	, %d icon(s)
>6	byte	x	[res=%dx
>7	byte	x	%dx5bpp]

# Magic ID for Windows Icon files.
# Submitted on 2004-04-01 by Carl
0	string	\\x00\\x00\\x01\\x00	[fid=000001001-31-0000ICO;ext=ico;mime=image/vnd.microsoft.icon;]Microsoft windows Icon image file
&0x08	byte	64	
>4	leshort	x	, %d icon(s)
>6	byte	x	[res=%dx
>7	byte	x	%dx6bpp]

# Magic ID for Windows Icon files.
# Submitted on 2004-04-01 by Carl
0	string	\\x00\\x00\\x01\\x00	[fid=000001001-31-0000ICO;ext=ico;mime=image/vnd.microsoft.icon;]Microsoft windows Icon image file
&0x08	byte	8	
>4	leshort	x	, %d icon(s)
>6	byte	x	[res=%dx
>7	byte	x	%dx3bpp]

# Magic ID for SunOS Icon files.
# Submitted on 2004-04-02 by Carl
0	string	/*\\ Format_version=1,\\ 	[fid=000001011-31-000ICON;ext=icon;mime=;]SunOS icon image file

# Submitted on 2004-03-31 by Carl
0	beshort	0x01	[fid=000001273-31-0000IMG;ext=img;mime=;]GEM Bit Image
&2	beshort	0x08	
>12	beshort	>0	[res=%dx
>14	beshort	>0	%d
>4	beshort	>0	x%dbpp]

# Submitted on 2004-04-02 by Carl
0	string	\\x8bJNG\\x0d\\x0a\\x1a\\x0a	[fid=000000000-31-0000JNG;ext=jng;mime=;]JPEG Network graphics image file
&12	string	JHDR	
>16	belong	x	[res=%d
>20	belong	x	x%d]

# Submitted on 2004-04-13 by Carl
0	string	\\x00\\x00\\x00\\x0cjP\\x20\\x20	[fid=000000001-31-0015444;ext=jp2;mime=image/jp2;]JPEG 2000 image file

# Submitted on 2004-04-13 by Carl
0	string	\\xff\\x4f\\xff\\x51	[fid=000000001-31-0015444;ext=jpc;mime=;]JPEG 2000 code stream image file
&Z2	beshort	0xFFD9	
>8	belong	x	[res=%dx
>12	belong	x	%d]

# Submitted on 2004-03-31 by Carl
0	belong	0xffd8ffe0	[fid=000001305-31-000JPEG;ext=jpeg,jpg;mime=image/jpeg;]Joint Photographic Experts Group JFIF image file
&6	string	JFIF\\x00	
>11	byte	x	, version %d
>12	byte	x	.0%d

# Submitted on 2004-04-13 by Carl
0	string	\\xff\\xd8\\xff\\xe1	[fid=000000005-31-000JPEG;ext=jpg,jpeg;mime=image/jpeg;]Digital still camera image file
&6	string	Exif	

# Magic ID for Deluxe Paint files.
# Submitted on 2004-03-31 by Carl
0	string	FORM	[fid=000001010-31-0000LBM;ext=lbm;mime=;]Interleaved bitmap image file
&8	string	ILBM	

# Submitted on 2004-04-13 by Carl
0	string	This\\ is\\ a\\ BitMap\\ file	[fid=000000000-31-000LISP;ext=lisp;mime=;]Lisp machine format image file

# Magic ID for Microdesign2, Microdesign3 files.
# Submitted on 2004-04-02 by Carl
0	string	.MDA	[fid=000001316-31-0000MDA;ext=mda;mime=;]Microdesign Area image file

# Magic ID for Microdesign2, Microdesign3 files.
# Submitted on 2004-04-02 by Carl
0	string	.MDP	[fid=000001316-31-0000MDP;ext=mdp;mime=;]Microdesign page image file

# Magic ID for Imagemagick files.
# Submitted on 2004-04-01 by Carl
0	string	id=ImageMagick	[fid=000100101-31-000MIFF;ext=miff,mif;mime=;]Imagemagick image file

# Magic ID for Netpbm files.
# Submitted on 2004-04-02 by Carl
0	string	MRF1	[fid=000100105-31-0000MRF;ext=mrf;mime=;]Monochrome recursive format image file
>4	belong	x	[res=%dx
>8	belong	x	%dx1bpp]

# Magic ID for Microsoft Paint files.
# Submitted on 2004-04-02 by Carl
0	leshort	0x6144	[fid=000001001-31-0000MSP;ext=msp;mime=;]Microsoft paint image file, version 1.0
&2	leshort	0x4d6e	
>4	leshort	x	[res=%dx
>6	leshort	x	%dx1bpp]

# Magic ID for Microsoft Paint files.
# Submitted on 2004-04-02 by Carl
0	leshort	0x694c	[fid=000001001-31-0000MSP;ext=msp;mime=;]Microsoft paint image file, version 2.0
&2	leshort	0x536e	
>4	leshort	x	[res=%dx
>6	leshort	x	%dx1bpp]

# Magic ID for Netpbm files.
# Submitted on 2004-03-31 by Carl
0	string	P7\\x0A	[fid=000100100-31-0000PAM;ext=pam;mime=;]Portable arbitrary map image file

# Magic ID for Netpbm files.
# Submitted on 2004-03-31 by Carl
0	string	P1	[fid=000100100-31-0000PBM;ext=pbm;mime=;]Portable bitmap image file, ascii

# Magic ID for Netpbm files.
# Submitted on 2004-03-31 by Carl
0	string	P4	[fid=000100100-31-0000PBM;ext=pbm;mime=;]Portable bitmap image file, binary

# Magic ID for PC-Paintbrush files.
# Submitted on 2004-03-31 by Carl
0	beshort	0x0A00	[fid=000001257-31-0000PCX;ext=pcx;mime=;]PC-Paintbrush image file, version 2.5
&2	byte	1	

# Magic ID for PC-Paintbrush files.
# Submitted on 2004-03-31 by Carl
0	beshort	0x0A02	[fid=000001257-31-0000PCX;ext=pcx;mime=;]PC-Paintbrush image file, version 2.8
&2	byte	1	

# Magic ID for PC-Paintbrush files.
# Submitted on 2004-03-31 by Carl
0	beshort	0x0A03	[fid=000001257-31-0000PCX;ext=pcx;mime=;]PC-Paintbrush image file, version 2.8
&2	byte	1	

# Magic ID for PC-Paintbrush files.
# Submitted on 2004-03-31 by Carl
0	beshort	0x0A04	[fid=000001257-31-0000PCX;ext=pcx;mime=;]PC-Paintbrush for windows image file
&2	byte	1	

# Magic ID for PC-Paintbrush files.
# Submitted on 2004-03-31 by Carl
0	beshort	0x0A05	[fid=000001257-31-0000PCX;ext=pcx;mime=;]PC-Paintbrush image file, version 3.0
&2	byte	1	

# Magic ID for Netpbm files.
# Submitted on 2004-03-31 by Carl
0	string	P2	[fid=000100100-31-0000PGM;ext=pgm;mime=;]Portable gray map image file, ascii

# Magic ID for Netpbm files.
# Submitted on 2004-03-31 by Carl
0	string	P5	[fid=000100100-31-0000PGM;ext=pgm;mime=;]Portable gray map image file, binary

# Magic ID for PC Paint files.
# Submitted on 2004-04-08 by Carl
0	leshort	0x1234	[fid=000001318-31-0000PIC;ext=pic;mime=;]Pictor PC Paint image file
&11	byte	0xFF	
&10	byte	0x02	
>2	leshort	x	[res=%d
>4	leshort	x	x%d]

# Magic ID for PC Paint files.
# Submitted on 2004-04-08 by Carl
0	leshort	0x1234	[fid=000001318-31-0000PIC;ext=pic;mime=;]Pictor PC Paint image file
&11	byte	0xFF	
&10	byte	0x08	
>2	leshort	x	[res=%d
>4	leshort	x	x%d]

# Magic ID for PC Paint files.
# Submitted on 2004-04-08 by Carl
0	leshort	0x1234	[fid=000001318-31-0000PIC;ext=pic;mime=;]Pictor PC Paint image file
&11	byte	0xFF	
&10	byte	0x31	
>2	leshort	x	[res=%d
>4	leshort	x	x%d]

# Magic ID for Softimage 3D files.
# Submitted on 2004-04-08 by Carl
0	belong	0x5380f634	[fid=000001321-31-0000PIC;ext=pic;mime=;]Softimage 3D image file
&88	string	PICT	
>8	string	>\\x00	[title=%.80s]
>92	beshort	x	[res=%d
>94	beshort	x	x%d]

# Magic ID for Bio-rad microscope files.
# Submitted on 2004-04-08 by Carl
54	leshort	12345	[fid=000001322-31-0000PIC;ext=pic;mime=;]Bio-rad confocal microscope image file
&16	leshort	0	
>0	leshort	>0	[res=%d
>2	leshort	>0	x%d]

# Submitted on 2004-02-06 by Carl
0	string	\\x89PNG\\x0d\\x0a\\x1a\\x0a	[fid=000000001-31-0015948;ext=png;mime=image/png;]Portable Network Graphic file
&12	string	IHDR	
>16	belong	>0	[res=%d
>20	belong	>0	x%d
>24	byte	x	x%dbpp]

# Magic ID for Netpbm files.
# Submitted on 2004-03-31 by Carl
0	string	P3	[fid=000100100-31-0000PPM;ext=ppm;mime=;]Portable pixel map image file, ascii

# Magic ID for Netpbm files.
# Submitted on 2004-03-31 by Carl
0	string	P6	[fid=000100100-31-0000PPM;ext=ppm;mime=;]Portable pixel map image file, binary

# Magic ID for Photoshop files.
# Submitted on 2004-04-01 by Carl
0	string	8BPS\\x00\\x01	[fid=000001003-31-0000PSD;ext=psd;mime=;]Adobe Photoshop image file
>18	belong	>0	[res=%dx
>14	belong	>0	%d]

# Magic ID for Paint shop pro files.
# Submitted on 2004-04-01 by Carl
0	string	Paint Shop Pro Image File\\x0a\\x1a	[fid=000001310-31-0000PSP;ext=psp;mime=;]Paintshop pro image file
>50	lelong	>0	[res=%dx
>54	lelong	>0	%d
>69	leshort	>0	x%dbpp]

# Submitted on 2004-02-08 by Carl
0	belong	0x59a66a95	[fid=000001011-31-0000RAS;ext=ras;mime=;]Sun raster image
>4	belong	>0	[res=%dx
>8	belong	>0	%d
>12	belong	>0	x%dbpp]

# Submitted on 2004-03-31 by Carl
0	string	\\0x01\\xDA	[fid=000001004-31-0000RGB;ext=rgb;mime=;]SGI Image file
>24	string	>\\x00	[title=%.80s]

# Submitted on 2004-03-31 by Carl
0	string	\\x01\\xDA\\x00\\x01	[fid=000001004-31-0000RGB;ext=rgb;mime=;]SGI Image file
&10	beshort	1	
>6	beshort	x	[res=%dx
>8	beshort	x	%dx8bpp]
>24	string	>\\x0	[title=%.80s]

# Submitted on 2004-03-31 by Carl
0	string	\\x01\\xDA\\x00\\x01	[fid=000001004-31-0000RGB;ext=rgb;mime=;]SGI Image file
&10	beshort	3	
>6	beshort	x	[res=%dx
>8	beshort	x	%dx24bpp]
>24	string	>\\x0	[title=%.80s]

# Submitted on 2004-03-31 by Carl
0	string	\\x01\\xDA\\x00\\x01	[fid=000001004-31-0000RGB;ext=rgb;mime=;]SGI Image file
&10	beshort	4	
>6	beshort	x	[res=%dx
>8	beshort	x	%dx24bpp]
>24	string	>\\x0	[title=%.80s]

# Submitted on 2004-03-31 by Carl
0	string	\\x01\\xDA\\x01\\x01	[fid=000001004-31-0000RGB;ext=rgb;mime=;]SGI Image file, compressed
&10	beshort	1	
>6	beshort	x	[res=%dx
>8	beshort	x	%dx8bpp]
>24	string	>\\x0	[title=%.80s]

# Submitted on 2004-03-31 by Carl
0	string	\\x01\\xDA\\x01\\x01	[fid=000001004-31-0000RGB;ext=rgb;mime=;]SGI Image file, compressed
&10	beshort	3	
>6	beshort	x	[res=%dx
>8	beshort	x	%dx24bpp]
>24	string	>\\x0	[title=%.80s]

# Submitted on 2004-03-31 by Carl
0	string	\\x01\\xDA\\x01\\x01	[fid=000001004-31-0000RGB;ext=rgb;mime=;]SGI Image file, compressed
&10	beshort	4	
>6	beshort	x	[res=%dx
>8	beshort	x	%dx24bpp]
>24	string	>\\x0	[title=%.80s]

# Magic ID for Turbo Silver files.
# Submitted on 2004-04-13 by Carl
0	string	FORM	[fid=000001252-31-000RGB8;ext=rgb8,rgb;mime=;]Turbo Silver 24-bit RGB image file
&8	string	RGB8	

# Magic ID for Turbo Silver files.
# Submitted on 2004-04-13 by Carl
0	string	FORM	[fid=000001252-31-000RGBN;ext=rgbn,rgb;mime=;]Turbo Silver 12-bit RGB image file
&8	string	RGBN	

# Magic ID for ColoRIX VGA Paint files.
# Submitted on 2004-04-08 by Carl
0	string	RIX3	[fid=000001320-31-0000SCZ;ext=scz;mime=;]ColorRIX VGA Paint image file
>4	leshort	x	[res=%d
>6	leshort	x	x%d]

# Submitted on 2004-04-13 by Bryan Henderson
0	string	\\117\\072	[fid=000000000-31-0000SIR;ext=sir;mime=;]Solitaire image recorder image file, MGI type 11
&4	string	\\013	

# Submitted on 2004-04-13 by Bryan Henderson
0	string	\\117\\072	[fid=000000000-31-0000SIR;ext=sir;mime=;]Solitaire image recorder image file, MGI type 17
&4	string	\\021	

# Submitted on 2004-04-01 by Carl
Z18	string	TRUEVISION-XFILE	[fid=000001306-31-0000TGA;ext=tga;mime=;]Truevision Targa image file
>12	leshort	x	[res=%dx
>14	leshort	x	%d
>16	byte	x	x%dbpp]

# Magic ID for Graphics Workshop files.
# Submitted on 2004-04-01 by Carl
0	string	THNL	[fid=000001258-31-0000THN;ext=thn;mime=;]Graphics workshop thumbnail image file

# Submitted on 2004-03-31 by Carl
0	string	II	[fid=000001003-31-0000TIF;ext=tif,tiff,dng;mime=image/tiff;]Tagged image file format image file, little-endian
&2	leshort	42	

# Submitted on 2004-03-31 by Carl
0	string	MM	[fid=000001003-31-0000TIF;ext=tif,tiff,dng;mime=image/tiff;]Tagged image file format image file, big-endian
&2	leshort		

# Magic ID for VICAR files.
# Submitted on 2004-04-01 by Carl
0	string	LBLSIZE=	[fid=000001022-31-0000VIC;ext=vic,vicar;mime=;]Vicar image file

# Magic ID for Khoros files.
# Submitted on 2004-04-01 by Carl
0	string	\\xAB\\x01\\x01\\x03	[fid=000001308-31-0000VIF;ext=vif,viff;mime=;]Khoros Visualization/Image File Format, version 1.3
&4	byte	2	
>520	belong	>0	[res=%dx
>524	belong	>0	%d]

# Submitted on 2004-04-02 by Carl
0	string	FIASCO	[fid=000100107-31-0000WFA;ext=wfa;mime=;]Fractal Image And Sequence Codec image file

# Magic ID for X-Windows files.
# Submitted on 2004-04-01 by Carl
0	string	/* XPM */	[fid=000001020-31-0000XPM;ext=xpm;mime=;]X-Windows pixel map image file

# Magic ID for XV files.
# Submitted on 2004-04-01 by Carl
0	string	P7\\ 332	[fid=000100103-31-00000XV;ext=xv;mime=;]XV Thumbnail image file

# Magic ID for XWindows files.
# Submitted on 2004-04-02 by Carl
0	belong	0x40	[fid=000001020-31-0000XWD;ext=xwd;mime=;]X10 XWindows dump image file
&4	belong	0x06	
>24	belong	x	[res=%d
>28	belong	x	x%d]

# Magic ID for XWindows files.
# Submitted on 2004-04-02 by Carl
0	lelong	0x40	[fid=000001020-31-0000XWD;ext=xwd;mime=;]X10 XWindows dump image file
&4	lelong	0x06	
>24	lelong	x	[res=%d
>28	lelong	x	x%d]

# Magic ID for Provector files.
# Submitted on 2004-04-08 by Carl
0	string	FORM	[fid=000001319-32-000DR2D;ext=dr2d;mime=;]Provector 2D image file
&8	string	DR2D	

# Magic ID for XFig, WinFig, jFig files.
# Submitted on 2004-02-08 by Carl
0	string	#FIG	[fid=000100011-32-0000FIG;ext=fig;mime=;]Facility for Interactive Generation file
>5	string	x	, version %.1s.
>7	string	x	%.1s

# Magic ID for Lotus 1-2-3 files.
# Submitted on 2004-04-02 by Carl
0	string	\\x01\\x00\\x00\\x00\\x01\\x00\\x08\\x00\\x44	[fid=000001009-32-0000PIC;ext=pic;mime=;]Lotus 1-2-3 image file

# Magic ID for Autocad files.
# Submitted on 2004-04-12 by Carl
0	string	AutoCAD Slide	[fid=000001254-32-0000SLD;ext=sld;mime=;]Autocad slide image file

# Magic ID for Wordperfect files.
# Submitted on 2004-02-08 by Carl
0	string	\\xffWPC	[fid=000001008-32-0000WPG;ext=wpg;mime=;]Wordperfect Graphics vectors
&8	byte	1	
&9	byte	0x16	
>10	byte	x	, version %d.
>11	byte	x	%d

# Submitted on 2004-02-11 by Carl
0	string	FORM	[fid=000100019-33-000AMFF;ext=amff;mime=;]Amiga metafile
&8	string	AMFF	

# Submitted on 2004-02-11 by Carl
0	lelong	0x9AC6CDD7	[fid=000001003-33-0000APM;ext=apm;mime=;]Aldus placeable Windows metafile
&4	leshort	0	

# Magic ID for CorelDRAW files.
# Submitted on 2004-02-11 by Carl
0	string	RIFF	[fid=000001008-33-0000CDR;ext=cdr;mime=;]Coreldraw  little-endian metafile
&8	string	CDR	

# Magic ID for CorelDRAW files.
# Submitted on 2004-02-11 by Carl
0	string	RIFX	[fid=000001008-33-0000CDR;ext=cdr;mime=;]Coreldraw  big-endian metafile
&8	string	CDR	

# Submitted on 2004-04-08 by Carl
0	beshort&0xFF20	0x0020	[fid=000000001-33-0008632;ext=cgm;mime=image/cgm;]Computer graphics metafile, binary encoded
&Z0x02	beshort&0xFF40	0x0040	

# Submitted on 2004-04-08 by Carl
0	string	BEGMF	[fid=000000001-33-0008632;ext=cgm;mime=image/cgm;]Computer graphics metafile, ascii encoded

# Magic ID for CorelDRAW files.
# Submitted on 2004-02-11 by Carl
0	string	RIFF	[fid=000001008-33-0000CMX;ext=cmx;mime=;]Corel little-endian metafile
&8	string	CMX1	

# Magic ID for CorelDRAW files.
# Submitted on 2004-02-11 by Carl
0	string	RIFX	[fid=000001008-33-0000CMX;ext=cmx;mime=;]Corel big-endian metafile
&8	string	CMX1	

# Submitted on 2004-02-11 by Carl
0	lelong	0x00000001	[fid=000001001-33-0000EMF;ext=emf;mime=;]Microsoft Windows Enhanced metafile
&40	lelong	0x464D4520	

# Submitted on 2004-02-11 by Carl
0	string	%!PS-Adobe-2.0\\ EPSF-1.2	[fid=000001003-33-000EPSF;ext=epsf;mime=application/postscript;]Adobe Encapsulated Postscript Level 2, version 1.2

# Submitted on 2004-02-11 by Carl
0	string	%!PS-Adobe-2.0\\ EPSF-2.0	[fid=000001003-33-000EPSF;ext=epsf;mime=application/postscript;]Adobe Encapsulated Postscript Level 2, version 2.0

# Submitted on 2004-02-11 by Carl
0	string	%!PS-Adobe-3.0\\ EPSF-3.0	[fid=000001003-33-000EPSF;ext=epsf;mime=application/postscript;]Adobe Encapsulated Postscript Level 3, version 3.0

# Submitted on 2004-02-11 by Carl
0	string	\\xC5\\xD0\\xD3\\xC6	[fid=000001003-33-000EPSF;ext=epsf,ai;mime=application/postscript;]Adobe Encapsulated Postscript, version 3.0, binary

# Magic ID for GEM Paint files.
# Submitted on 2004-03-31 by Carl
0	beshort	0xFFFF	[fid=000001273-33-0000GEM;ext=gem;mime=;]GemDOS Motorola Metafile, version 1.01
&4	beshort	101	

# Submitted on 2004-02-11 by http://www.seasip.info/Gem/ff_gem.html
0	leshort	0xFFFF	[fid=000001273-33-0000GEM;ext=gem;mime=;]GemDOS Metafile
&4	leshort	0	

# Magic ID for Artline files.
# Submitted on 2004-02-11 by http://www.seasip.info/Gem/ff_gem.html
0	leshort	0xFFFF	[fid=000001273-33-0000GEM;ext=gem;mime=;]GemDOS Intel Metafile, version 4.00
&4	leshort	400	

# Magic ID for Deskpress files.
# Submitted on 2004-02-11 by http://www.seasip.info/Gem/ff_gem.html
0	leshort	0xFFFF	[fid=000001273-33-0000GEM;ext=gem;mime=;]GemDOS Intel Metafile, version 3.10
&4	leshort	310	

# Magic ID for GEM Paint files.
# Submitted on 2004-02-11 by http://www.seasip.info/Gem/ff_gem.html
0	leshort	0xFFFF	[fid=000001273-33-0000GEM;ext=gem;mime=;]GemDOS Intel Metafile, version 1.01
&4	leshort	101	

# Magic ID for Quickdraw files.
# Submitted on 2004-04-01 by Carl
0x20A	belong	0x001102FF	[fid=000001002-33-0000PCT;ext=pct;mime=;]Macintosh Quickdraw metafile \'PICT\', version 2.0

# Submitted on 2004-02-11 by Carl
0	leshort	0x0001	[fid=000001001-33-0000WMF;ext=wmf;mime=;]Microsoft Windows metafile
&2	leshort	9	

# Magic ID for Cinema 4D Version 5.x files.
# Submitted on 2004-02-06 by Carl
0	string	MC50	[fid=000001255-40-0000000;ext=;mime=;]Maxon Cinema 4D version 5 3D data

# Magic ID for Quickdraw 3D files.
# Submitted on 2004-02-06 by Carl
0	string	3DMF	[fid=000001002-40-0003DMF;ext=3dmf;mime=;]Apple Quickdraw 3D metafile

# Magic ID for Rhino 3d files.
# Submitted on 2004-04-12 by Carl
0	string	3D Geometry File Format	[fid=000001330-40-0003DMF;ext=3dmf;mime=;]Rhino3d / OpenNurbs 3d model

# Magic ID for Quickdraw 3D files.
# Submitted on 2004-04-11 by Carl
0	string	3DMetafile	[fid=000001002-40-0003DMF;ext=3dmf,a3d;mime=;]Apple Quickdraw 3D metafile

# Magic ID for AC3d files.
# Submitted on 2004-04-12 by Carl
0	string	AC3D	[fid=000000000-40-00000AC;ext=ac;mime=;]Ac3d 3d model

# Magic ID for 3dStudio Max files.
# Submitted on 2004-04-12 by Carl
0	string	*3DSMAX_ASCIIEXPORT	[fid=000001326-40-0000ASE;ext=ase;mime=;]3d studio max ascii export 3D model

# Magic ID for Caligari Truespace Modeler files.
# Submitted on 2004-02-06 by Carl
0	string	Caligari\\ V	[fid=000001256-40-0000COB;ext=cob,scn;mime=;]Caligari Truespace2 3D model

# Magic ID for Tachyon parallel raytracer files.
# Submitted on 2004-04-12 by Carl
0	string	BEGIN_SCENE	[fid=000100116-40-0000DAT;ext=dat;mime=;]Tachyon ray-tracer 3d model

# Magic ID for Autocad files.
# Submitted on 2004-04-12 by Carl
0	string	AC10	[fid=000001254-40-0000DWG;ext=dwg;mime=image/vnd.dwg;]Autocad drawing format 3d model

# Magic ID for Autocad files.
# Submitted on 2004-04-12 by Carl
0	string	AutoCAD Binary DXF	[fid=000001254-40-0000DXF;ext=dxf;mime=image/vnd.dxf;]Autocad drawing interchange 3d model, binary

# Magic ID for Multigen creator files.
# Submitted on 2004-04-12 by Carl
0	beshort	1	[fid=000001332-40-0000FLT;ext=flt;mime=;]Openflight scene description 3d model
&4	string	db	

# Magic ID for Videoscape 3D files.
# Submitted on 2004-04-12 by Carl
0	string	GOUR	[fid=000001328-40-0000GEO;ext=geo;mime=;]Videoscape 3d model with colored vertices

# Magic ID for Videoscape 3D, Blender files.
# Submitted on 2004-04-12 by Carl
0	string	3DG1	[fid=000001328-40-0000GEO;ext=geo;mime=;]Videoscape 3d model with colored faces

# Magic ID for Videoscape 3D, Blender files.
# Submitted on 2004-04-12 by Carl
0	string	3DG2	[fid=000001328-40-0000GEO;ext=geo;mime=;]Videoscape 3d model light source

# Magic ID for Videoscape 3D, Blender files.
# Submitted on 2004-04-12 by Carl
0	string	3DG3	[fid=000001328-40-0000GEO;ext=geo;mime=;]Videoscape 3d model with gouraud curves

# Magic ID for Softimage 4D Creative environment files.
# Submitted on 2004-04-12 by Carl
0	string	HRCH:	[fid=000001321-40-0000HRC;ext=hrc;mime=;]Softimage 4d model, ascii encoded

# Magic ID for Open Inventor Toolkit files.
# Submitted on 2004-02-06 by Carl
0	string	#Inventor	[fid=000001004-40-00000IV;ext=iv;mime=;]Open Inventor 3d model
>11	string	x	, version %.1s.
>13	string	x	%.1s
>15	string	binary	, binary encoded
>15	string	ascii	, ascii encoded

# Magic ID for Geomview files.
# Submitted on 2004-04-12 by Carl
0	string	LIST	[fid=000100118-40-000LIST;ext=list;mime=;]Geomview list of 3D models and objects

# Magic ID for Lightwave 3D files.
# Submitted on 2004-04-12 by Carl
0	string	FORM	[fid=000001251-40-0000LWO;ext=lwo,lwob;mime=;]Lightwave 3D object
&8	string	LWO2	

# Magic ID for Lightwave 3D files.
# Submitted on 2004-02-06 by Carl
0	string	FORM	[fid=000001251-40-0000LWO;ext=lwob,lwo;mime=;]Lightwave 3D object
&8	string	LWOB	

# Magic ID for Lightwave 3D files.
# Submitted on 2004-02-06 by Carl
0	string	LWSC	[fid=000001251-40-0000LWS;ext=lwsc,lws;mime=;]Lightwave 3D scene

# Magic ID for Maya files.
# Submitted on 2004-04-12 by Carl
0	string	//Maya	[fid=000001312-40-00000MA;ext=ma;mime=;]Maya 3d model, ascii encoded

# Magic ID for Cinema 4D Version 4.x and earlier files.
# Submitted on 2004-02-06 by Carl
0	string	FORM	[fid=000001255-40-000MC4D;ext=mc4d;mime=;]Maxon Cinema 4D v4.x 3D data
&8	string	MC4D	

# Magic ID for Geomview files.
# Submitted on 2004-04-12 by Carl
0	string	CMESH	[fid=000100118-40-000MESH;ext=mesh;mime=;]Geomview polygon

# Magic ID for Geomview files.
# Submitted on 2004-04-12 by Carl
0	string	MESH	[fid=000100118-40-000MESH;ext=mesh;mime=;]Geomview polygon

# Magic ID for Milshape 3d files.
# Submitted on 2004-04-12 by Carl
0	string	MS3D000000	[fid=000100117-40-000MS3D;ext=ms3d;mime=;]Milkshape 3d model, binary encoded

# Magic ID for Worldtoolkit files.
# Submitted on 2004-02-06 by Carl
0	string	nff	[fid=000001253-40-0000NFF;ext=nff;mime=;]Sense8 Worldtoolkit 3D object

# Magic ID for Autodesk Animator files.
# Submitted on 2004-04-12 by Carl
2	lelong	0x0000	[fid=000001254-40-0000PLY;ext=ply;mime=;]Autodesk animator polygon file
&6	byte	0	
&7	byte	0x99	

# Magic ID for Autodesk Animator files.
# Submitted on 2004-04-12 by Carl
2	lelong	0x0000	[fid=000001254-40-0000PLY;ext=ply;mime=;]Autodesk animator polygon file
&6	byte	1	
&7	byte	0x99	

# Magic ID for Quick3d files.
# Submitted on 2004-04-12 by Carl
0	string	quick3Do	[fid=000001334-40-0000Q3O;ext=q3o;mime=;]Quick3d 3D object

# Magic ID for Quick3d files.
# Submitted on 2004-04-12 by Carl
0	string	quick3Ds	[fid=000001334-40-0000Q3S;ext=q3s;mime=;]Quick3d 3D scene

# Magic ID for Renderman files.
# Submitted on 2004-04-12 by Carl
0	string	##RenderMan\\ RIB-Structure	[fid=000001323-40-0000RIB;ext=rib;mime=;]Renderman bytestream 3D model

# Magic ID for Sculpt 3d files.
# Submitted on 2004-04-12 by Carl
0	string	FORM	[fid=000000000-40-00SCENE;ext=scene;mime=;]Sculpt 3d scene model
&8	string	SC3D	

# Magic ID for Imagine 3D Studio, Turbo Silver files.
# Submitted on 2004-02-06 by Carl
0	string	FORM	[fid=000001252-40-000TDDD;ext=tddd,obj;mime=;]Imagine 3D object
&8	string	TDDD	

# Magic ID for Macromedia Director files.
# Submitted on 2004-04-12 by Carl
0	string	IFX	[fid=000001259-40-0000W3D;ext=w3d;mime=;]Shockwave 3D model

# Submitted on 2004-02-06 by Carl
0	string	#VRML	[fid=000000001-40-0014772;ext=wrl;mime=model/vrml;]Virtual Reality modeling language
>7	string	x	, version %.1s.
>9	string	x	%.1s

# Submitted on 2004-04-12 by Carl
0	string	<WORLD>	[fid=000000000-40-0000XGL;ext=xgl;mime=;]XGL 3d model

# Magic ID for Direct3D files.
# Submitted on 2004-04-11 by Carl
0	string	xof\\ 	[fid=000001001-40-0000XIE;ext=xie;mime=;]Microsoft direct3d 3D model

# Magic ID for Softimage XSI files.
# Submitted on 2004-04-12 by Carl
0	string	xsi\\ 	[fid=000001321-40-0000XSI;ext=xsi;mime=;]Softimage 3d model

# Magic ID for Kaboom files.
# Submitted on 2004-02-08 by Carl
0	string	\\xA8MP\\xA8	[fid=000000000-50-0000000;ext=;mime=;]Kboom archive file

# Magic ID for CTW files.
# Submitted on 2004-03-04 by Carl
0	leshort	12	[fid=000100077-50-0000000;ext=;mime=;]Context tree weighing (CTW) archive file
&2	leshort	0	

# Magic ID for Microsoft Compress files.
# Submitted on 2004-03-04 by Carl
0	string	SZDD\\x88\\xF0\\x27\\x33	[fid=000001001-50-0000000;ext=;mime=;]Microsoft LZSS compressed file

# Magic ID for AAX files.
# Submitted on 2004-02-18 by Carl
0	string	\\x40\\xFE\\x00\\x00	[fid=000001281-50-0000AAX;ext=aax;mime=;]AAX archive file

# Magic ID for ABComp files.
# Submitted on 2004-02-18 by Carl
0	string	\\x03AB2	[fid=000001282-50-0000ABP;ext=abp;mime=;]ABComp archive file

# Magic ID for Ace / WinAce files.
# Submitted on 2004-02-08 by Carl
7	string	**ACE**	[fid=000001265-50-0000ACE;ext=ace;mime=;]Ace / WinACE archive file

# Magic ID for Ai Archiver files.
# Submitted on 2004-02-18 by Carl
0	string	Ai	[fid=000000000-50-00000AI;ext=ai;mime=;]Ai archive file

# Magic ID for Akt archiver files.
# Submitted on 2004-02-18 by Carl
0	string	AKT\\x0A	[fid=000000000-50-0000AKT;ext=akt;mime=;]AKT archive file

# Magic ID for AMG Archiver files.
# Submitted on 2004-02-18 by Carl
0	string	\\xAD\\x36	[fid=000001284-50-0000AMG;ext=amg;mime=;]AMG archive file
>2	byte	x	, version %bh.
>2	byte	x	%bl
&3	byte	0	

# Magic ID for ar files.
# Submitted on 2004-03-04 by Carl
0	string	\\x21<arch>\\x0A	[fid=000000003-50-00000AR;ext=ar;mime=;]UNIX archive file (ar)

# Magic ID for AR7 files.
# Submitted on 2004-02-18 by Carl
0	string	,AR7 e-mailable archive:	[fid=000100036-50-0000AR7;ext=ar7;mime=;]AR7 archive file

# Magic ID for Squash files.
# Submitted on 2004-02-18 by Carl
3	string	OctSqu	[fid=000100038-50-0000ARH;ext=arh;mime=;]Squash archive file

# Magic ID for Arj files.
# Submitted on 2004-02-18 by Carl
0	string	\\x60\\xEA	[fid=000001285-50-0000ARJ;ext=arj;mime=;]ARJ archive file
&10	byte	2	

# Magic ID for ASD files.
# Submitted on 2004-02-18 by Carl
0	string	ASD01\\x1A	[fid=000001287-50-0000ASD;ext=asd;mime=;]ASD archive file

# Magic ID for Boa constrictor files.
# Submitted on 2004-02-18 by Carl
0	string	BOA\\x00	[fid=000100040-50-0000B58;ext=b58;mime=;]BOA constrictor archive file

# Magic ID for BWC files.
# Submitted on 2004-02-18 by Carl
0	string	BWC	[fid=000100042-50-00000BC;ext=bc;mime=;]BWC archive file

# Magic ID for Bix files.
# Submitted on 2004-02-18 by Carl
0	string	BIX0	[fid=000100037-50-0000BIX;ext=bix;mime=;]BIX archive file

# Magic ID for Btoa files.
# Submitted on 2004-02-18 by Carl
0	string	xbtoa5	[fid=000100043-50-0000BOO;ext=boo;mime=;]Btoa encoded file

# Magic ID for Bsa files.
# Submitted on 2004-02-18 by Carl
0	string	\\xFFBSG\\x00\\x00\\xFFBSA	[fid=000001289-50-0000BSN;ext=bsn;mime=;]Bsa archive file

# Magic ID for BTPC files.
# Submitted on 2004-03-03 by Carl
0	string	btpc\\ 	[fid=000100074-50-000BTPC;ext=btpc;mime=;]BTPC compressed image file

# Magic ID for BTS files.
# Submitted on 2004-02-18 by Carl
0	string	\\x1A\\x03Descript	[fid=000100044-50-0000BTS;ext=bts;mime=;]BTSpk archive file
&0x521	string	BTSPK!	

# Magic ID for Bzip files.
# Submitted on 2004-02-18 by Carl
0	string	BZ0	[fid=000100008-50-00000BZ;ext=bz;mime=;]Bzip archive file

# Magic ID for Bzip2 files.
# Submitted on 2004-02-08 by Carl
0	string	BZh	[fid=000100008-50-0000BZ2;ext=bz2;mime=;]Bzip2 archive file

# Submitted on 2004-02-08 by Carl
0	string	MSCF	[fid=000001001-50-0000CAB;ext=cab;mime=;]Microsoft Cabinet file
>25	byte	x	, version %d.
>24	byte	x	%d

# Magic ID for Crush files.
# Submitted on 2004-02-23 by Carl
0	string	CRUSH\\ v1.8	[fid=000001290-50-0000CRU;ext=cru;mime=;]Crush archive file

# Magic ID for Ctxf files.
# Submitted on 2004-02-23 by Carl
0	string	CXF\\x1A	[fid=000100045-50-0000CXF;ext=cxf;mime=;]Ctx archive file

# Magic ID for DAXWav files.
# Submitted on 2004-03-04 by Carl
0	string	FORM	[fid=000000000-50-0000DAX;ext=dax;mime=;]DAX audio archive file
&8	string	daxA	

# Magic ID for Diskmasher files.
# Submitted on 2004-02-23 by Carl
0	string	DMS!	[fid=000000000-50-0000DMS;ext=dms;mime=;]Diskmasher archive file

# Magic ID for Dpae files.
# Submitted on 2004-02-23 by Carl
0	string	Dirk\\ Paehl(c)	[fid=000100046-50-0000DPA;ext=dpa;mime=;]Dpae archive file

# Magic ID for Disintegrator files.
# Submitted on 2004-02-23 by Carl
0	string	DSTb	[fid=000100047-50-0000DST;ext=dst;mime=;]Disintegrator archive file

# Magic ID for Enhanced compressor (ENC) files.
# Submitted on 2004-02-23 by Carl
0	string	Ench	[fid=000100051-50-0000ENC;ext=enc;mime=;]Enhanced compressor archive file

# Magic ID for ESP files.
# Submitted on 2004-02-08 by Carl
0	string	ESP>	[fid=000100002-50-0000ESP;ext=esp;mime=;]ESP archive file

# Magic ID for ESP files.
# Submitted on 2004-02-08 by Carl
0x53f	string	ESP	[fid=000100002-50-0000EXE;ext=exe;mime=;]ESP Self-extracting archivew (MS-DOS)

# Magic ID for Freeze files.
# Submitted on 2004-02-11 by Carl
0	string	\\x1F\\x9E	[fid=000000000-50-000000F;ext=f;mime=;]Freeze archive file, version 1.0

# Magic ID for Freeze files.
# Submitted on 2004-02-11 by Carl
0	string	\\x1F\\x9F	[fid=000000000-50-000000F;ext=f;mime=;]Freeze archive file, version 2.0

# Magic ID for Qlfc files.
# Submitted on 2004-02-23 by Carl
0	string	\\x47\\x68\\x69\\x64\\x6f	[fid=000100055-50-00000GQ;ext=gq;mime=;]Qlfc archive file

# Magic ID for Gzip files.
# Submitted on 2004-02-08 by Carl
0	string	\\x1F\\x8B	[fid=000000002-50-0001952;ext=gz;mime=;]Gzip archive file

# Magic ID for Ha files.
# Submitted on 2004-02-10 by Carl
0	string	HA	[fid=000100013-50-00000HA;ext=ha;mime=;]HA archive file

# Magic ID for HAP files.
# Submitted on 2004-02-23 by Carl
0	string	\\x913HF	[fid=000001291-50-0000HAP;ext=hap;mime=;]HAP archive file

# Magic ID for Hpack files.
# Submitted on 2004-02-11 by Carl
0	string	HPAK	[fid=000100016-50-0000HPK;ext=hpk;mime=;]Hpack archive file
&Z4	string	HPAK	

# Submitted on 2004-02-10 by Carl
11	string	must\\ be\\ converted\\ with\\ BinHex	[fid=000001002-50-0000HQX;ext=hqx;mime=;]BinHex archive

# Magic ID for HYP files.
# Submitted on 2004-02-23 by Carl
0	string	\\x1AHP\\x25	[fid=000100056-50-0000HYP;ext=hyp;mime=;]HYP archive file

# Magic ID for HYP files.
# Submitted on 2004-02-23 by Carl
0	string	\\x1AST\\x25	[fid=000100056-50-0000HYP;ext=hyp;mime=;]HYP archive file

# Magic ID for Winimp files.
# Submitted on 2004-02-08 by Carl
0	lelong	0xA504D49	[fid=000001270-50-0000IMP;ext=imp;mime=;]Winimp archive file

# Magic ID for JRchive files.
# Submitted on 2004-02-08 by Carl
0	string	JRchive	[fid=000001263-50-0000JRC;ext=jrc;mime=;]JRchive archive file

# Magic ID for Archive Handler files.
# Submitted on 2004-02-08 by Carl
0	string	LG	[fid=000100001-50-00000LG;ext=lg;mime=;]Arhangel archive file

# Magic ID for Limit files.
# Submitted on 2004-02-08 by Carl
0	string	LM\\x1A	[fid=000100003-50-0000LIM;ext=lim;mime=;]Limit archive file

# Magic ID for Larc files.
# Submitted on 2004-02-11 by Carl
2	string	-lz4-	[fid=000100017-50-0000LZH;ext=lzh;mime=;]Larc archive

# Magic ID for Larc files.
# Submitted on 2004-02-11 by Carl
2	string	-lz5-	[fid=000100017-50-0000LZH;ext=lzh;mime=;]Larc archive file

# Magic ID for Larc files.
# Submitted on 2004-02-11 by Carl
2	string	-lzs-	[fid=000100017-50-0000LZH;ext=lzh;mime=;]Larc archive file

# Magic ID for lha files.
# Submitted on 2004-02-11 by Carl
2	string	-lh\\ -	[fid=000100017-50-0000LZH;ext=lzh,lha;mime=;]LHarc archive file, version 2.x

# Magic ID for lha files.
# Submitted on 2004-02-11 by Carl
2	string	-lh0-	[fid=000100017-50-0000LZH;ext=lzh,lha;mime=;]LHarc archive file, version 1.x

# Magic ID for lha files.
# Submitted on 2004-02-11 by Carl
2	string	-lh1-	[fid=000100017-50-0000LZH;ext=lzh,lha;mime=;]LHarc archive file, version 1.x

# Magic ID for lha files.
# Submitted on 2004-02-11 by Carl
2	string	-lh2-	[fid=000100017-50-0000LZH;ext=lzh,lha;mime=;]LHarc archive file, version 2.x

# Magic ID for lha files.
# Submitted on 2004-02-11 by Carl
2	string	-lh3-	[fid=000100017-50-0000LZH;ext=lzh,lha;mime=;]LHarc archive file, version 2.x

# Magic ID for lha files.
# Submitted on 2004-02-11 by Carl
2	string	-lh4-	[fid=000100017-50-0000LZH;ext=lzh,lha;mime=;]LHarc archive file, version 2.x

# Magic ID for lha files.
# Submitted on 2004-02-11 by Carl
2	string	-lh5-	[fid=000100017-50-0000LZH;ext=lzh,lha;mime=;]LHarc archive file, version 2.x

# Magic ID for lha files.
# Submitted on 2004-02-11 by Carl
2	string	-lh6-	[fid=000100017-50-0000LZH;ext=lzh,lha;mime=;]LHarc archive file, version 2.x

# Magic ID for lha files.
# Submitted on 2004-02-11 by Carl
2	string	-lh7-	[fid=000100017-50-0000LZH;ext=lzh,lha;mime=;]LHarc archive file, version 2.x

# Magic ID for lha files.
# Submitted on 2004-02-11 by Carl
2	string	-lhd-	[fid=000100017-50-0000LZH;ext=lzh,lha;mime=;]LHarc archive file, version 2.x

# Magic ID for lzo files.
# Submitted on 2004-02-11 by Carl
0	string	\\x89\\x4c\\x5a\\x4f\\x00\\x0d\\x0a\\x1a\\x0a	[fid=000100018-50-0000LZO;ext=lzo;mime=;]LZOP archive file

# Magic ID for Lzx files.
# Submitted on 2004-02-23 by Carl
0	string	LZX	[fid=000100058-50-0000LZX;ext=lzx;mime=;]LZX archive file

# Magic ID for Mdcd (Mike Davenport compressor) files.
# Submitted on 2004-02-08 by Carl
0	string	MDmd	[fid=000100004-50-00000MD;ext=md;mime=;]Mike Davenport archive file
>4	byte	x	, version %d
&5	byte	1	

# Magic ID for Nashrink files.
# Submitted on 2004-02-23 by Carl
0	string	NSK	[fid=000001292-50-0000NSK;ext=nsk;mime=;]NaShrink archive file

# Magic ID for Semone archiver files.
# Submitted on 2004-02-27 by Carl
0	string	SEMh	[fid=000100068-50-0000ONE;ext=one;mime=;]Semone archive file

# Magic ID for Lpac files.
# Submitted on 2004-03-04 by Carl
0	string	LPAC	[fid=000100084-50-0000PAC;ext=pac;mime=;]LPAC audio archive file

# Magic ID for CrossePAC files.
# Submitted on 2004-02-08 by Carl
0	string	DSIGDCC	[fid=000001262-50-0000PAC;ext=pac;mime=;]CrossePAC archive file

# Magic ID for High Compression Markov Predictive Coder files.
# Submitted on 2004-02-23 by Carl
0	string	PPZ2	[fid=000100061-50-0000PMZ;ext=pmz;mime=;]PPMZ2 archive file

# Magic ID for Powerpacker files.
# Submitted on 2004-02-27 by Carl
0	string	PP20	[fid=000100062-50-00000PP;ext=pp;mime=;]Powerpacker archive file

# Magic ID for PAQ1 files.
# Submitted on 2004-02-27 by Carl
0	string	PAQ1\\x0D\\x0A	[fid=000100064-50-0000PQ1;ext=pq1;mime=;]PAQ1 archive file

# Magic ID for PAQ3 files.
# Submitted on 2004-02-27 by Carl
0	string	PAQ3\\x0D\\x0A	[fid=000100064-50-0000PQ3;ext=pq3;mime=;]PAQ3 archive file

# Magic ID for PAQ6 files.
# Submitted on 2004-02-27 by Carl
0	string	PAQ6	[fid=000100064-50-0000PQ6;ext=pq6;mime=;]PAQ6 archive file

# Magic ID for Pretty simple archiver files.
# Submitted on 2004-02-27 by Carl
0	string	PSA\\x01\\x03	[fid=000100065-50-0000PSA;ext=psa;mime=;]Pretty simple archiver archive file

# Magic ID for Quantum compressor files.
# Submitted on 2004-02-27 by Carl
0	string	DS	[fid=000001294-50-000000Q;ext=q;mime=;]Quantum archive file
&2	byte	<2	
>2	byte	x	, version %d
>3	byte	x	.%d

# Magic ID for Rar files.
# Submitted on 2004-02-08 by Carl
0	string	\\x52\\x61\\x72\\x21\\x1a\\x07\\x00	[fid=000001267-50-0000RAR;ext=rar;mime=;]RAR archive file

# Magic ID for Romanian archiver eXpert (RAX) files.
# Submitted on 2004-02-27 by Carl
0	string	ULEB	[fid=000001295-50-0000RAX;ext=rax;mime=;]RAX archive file

# Magic ID for Reduq files.
# Submitted on 2004-02-27 by Carl
0	string	rdqx	[fid=000100066-50-0000RDQ;ext=rdq;mime=;]Reduq archive file

# Magic ID for RPM files.
# Submitted on 2004-03-04 by Carl
0	string	\\xed\\xab\\xee\\xdb	[fid=000000000-50-0000RPM;ext=rpm;mime=;]RPM archive
>4	byte	x	, version %d
>5	byte	x	.%d

# Magic ID for rzip files.
# Submitted on 2004-03-04 by Carl
0	string	RZIP	[fid=000100076-50-00000RZ;ext=rz;mime=;]Rzip archive file
>4	byte	x	, version %d
>5	byte	x	.%d

# Magic ID for Streamline Archival Utility files.
# Submitted on 2004-02-08 by Carl
3	string	LH0	[fid=000001264-50-0000SAR;ext=sar;mime=;]Streaming Archiver Utility archive file

# Magic ID for Streamline Archival Utility files.
# Submitted on 2004-02-08 by Carl
3	string	LH4	[fid=000001264-50-0000SAR;ext=sar;mime=;]Streaming Archiver Utility archive file

# Magic ID for Streamline Archival Utility files.
# Submitted on 2004-02-08 by Carl
3	string	LH5	[fid=000001264-50-0000SAR;ext=sar;mime=;]Streaming Archiver Utility archive file

# Magic ID for SBX Archiver files.
# Submitted on 2004-02-27 by Carl
0	string	SB1\\x00	[fid=000001297-50-00000SB;ext=sb;mime=;]SBX archive file

# Magic ID for SBC Archiver files.
# Submitted on 2004-02-27 by Carl
0	string	SBC\\x1E	[fid=000100067-50-0000SBC;ext=sbc;mime=;]SBC archive file

# Submitted on 2004-02-10 by Carl
10	string	#\\ This\\ is\\ a\\ shell\\ archive	[fid=000000000-50-000SHAR;ext=shar;mime=;]UNIX shell archive

# Submitted on 2004-02-10 by Carl
11	string	#\\ This\\ is\\ a\\ shell\\ archive	[fid=000000000-50-000SHAR;ext=shar;mime=;]UNIX shell archive

# Magic ID for Nulib files.
# Submitted on 2004-02-08 by Carl
0	string	\\x4e\\xf5\\x46\\xd8	[fid=000100005-50-0000SHK;ext=shk;mime=;]Shrinkit/Nulib archive file

# Magic ID for Nulib files.
# Submitted on 2004-02-08 by Carl
0	string	\\x4e\\xf5\\x46\\xe9\\x6c\\xe5	[fid=000100005-50-0000SHK;ext=shk;mime=;]Shrinkit/Nulib archive file

# Magic ID for Stuffit files.
# Submitted on 2004-03-04 by Carl
0	string	StuffIt\\ 	[fid=000001272-50-0000SIT;ext=sit;mime=;]Stuffit archive file

# Magic ID for Stuffit files.
# Submitted on 2004-02-11 by Carl
0	string	SIT!	[fid=000001272-50-0000SIT;ext=sit;mime=;]Stuffit archive file
&10	string	rLau	
>14	byte	x	, version %d.0

# Magic ID for Stuffit Extended files.
# Submitted on 2004-03-04 by Carl
0	string	StuffIt!	[fid=000001272-50-000SITX;ext=sitx;mime=;]Stuffit extended archive file

# Magic ID for Sof files.
# Submitted on 2004-03-04 by Carl
0	string	PK\\x03\\x06	[fid=000000000-50-0000SOF;ext=sof;mime=;]SOF archive file

# Magic ID for Splint files.
# Submitted on 2004-02-08 by Carl
0	string	\\x93\\xB9\\x06	[fid=000100006-50-0000SPL;ext=spl;mime=;]Splint archive file

# Magic ID for Sqweez files.
# Submitted on 2004-02-10 by Carl
0	string	SQWEZ\\ 	[fid=000100014-50-0000SQZ;ext=sqz;mime=;]Sqwez archive file

# Magic ID for Sqz files.
# Submitted on 2004-02-10 by Carl
0	string	HLSQZ	[fid=000100015-50-0000SQZ;ext=sqz;mime=;]Squeeze archive file
>5	string	x	, version %.1s.0

# Magic ID for Stonecracker files.
# Submitted on 2004-02-27 by Carl
0	string	S401	[fid=000100063-50-0000STC;ext=stc;mime=;]Stonecracker archive file
>0	string	S401	, version 4.01

# Magic ID for Stonecracker files.
# Submitted on 2004-02-27 by Carl
0	string	S403	[fid=000100063-50-0000STC;ext=stc;mime=;]Stonecracker archive file
>0	string	S403	, version 4.03

# Magic ID for Stonecracker files.
# Submitted on 2004-02-27 by Carl
0	string	S404	[fid=000100063-50-0000STC;ext=stc;mime=;]Stonecracker archive file
>0	string	S404	, version 4.04

# Magic ID for Szip files.
# Submitted on 2004-02-08 by Carl
0	string	SZ\\x0A\\x04	[fid=000100009-50-00000SZ;ext=sz;mime=;]SZIP archive file
>4	byte	x	, version %d
>5	byte	x	.%d

# Magic ID for Tar,pax files.
# Submitted on 2004-02-10 by Carl
257	string	ustar\\040\\040\\0	[fid=000000000-50-0000TAR;ext=tar;mime=;]GNU tar archive

# Magic ID for Tar,pax files.
# Submitted on 2004-02-10 by Carl
257	string	ustar\\0\\x06	[fid=000000003-50-0001003;ext=tar;mime=;]Opengroup/POSIX tar archive

# Magic ID for uc2 files.
# Submitted on 2004-02-10 by Carl
0	string	UC2\\x1a	[fid=000001271-50-0000UC2;ext=uc2;mime=;]Ultra Compressor archive file

# Magic ID for Uharc files.
# Submitted on 2004-03-04 by Carl
0	string	UHA	[fid=000100083-50-0000UHA;ext=uha;mime=;]UHArc archive file

# Magic ID for YBS archiver files.
# Submitted on 2004-02-27 by Carl
0	string	YBS3	[fid=000100071-50-0000YBS;ext=ybs;mime=;]YBS archive file

# Submitted on 2004-02-11 by Carl
0	string	\\037\\235	[fid=000000000-50-000000Z;ext=z;mime=;]UNIX archive file

# Magic ID for Pkunzip, Info-zip Unzip files.
# Submitted on 2004-02-08 by Carl
0	lelong	0x04034b50	[fid=000001266-50-0000ZIP;ext=zip;mime=application/zip;]Pkzip archive file

# Magic ID for zoo files.
# Submitted on 2004-02-10 by Carl
0	string	ZOO	[fid=000100012-50-0000ZOO;ext=zoo;mime=;]Zoo archive file
&0x14	lelong	0x0FDC4A7DC	
>32	byte	x	, version %d
>33	byte	x	.%d

# Magic ID for Zzip files.
# Submitted on 2004-02-08 by Carl
0	string	ZZ	[fid=000100007-50-00000ZZ;ext=zz;mime=;]ZZip archive file
>2	byte	x	, version %d.0

# Magic ID for 624 files.
# Submitted on 2004-03-03 by Carl
0	string	[ESP]\\xB5\\x78	[fid=000100002-51-0000COM;ext=com;mime=;]624 executable compressed file (MS-DOS)

# Magic ID for 624 files.
# Submitted on 2004-03-03 by Carl
0	string	PULP\\x83	[fid=000100002-51-0000COM;ext=com;mime=;]624 executable compressed file (MS-DOS)

# Magic ID for Lzexe files.
# Submitted on 2004-02-23 by Carl
0x1C	string	LZ91	[fid=000100053-51-0000EXE;ext=exe;mime=;]Lzexe compressed executable file (MS-DOS)

# Magic ID for HTML Help Workshop files.
# Submitted on 2004-02-08 by Carl
0	string	ITSF	[fid=000001001-60-0000CHM;ext=chm;mime=;]Microsoft compiled hypertext document

# Magic ID for Borland Delphi files.
# Submitted on 2004-07-30 by Carl
2	string	DELPHI.DIAGRAM.PORTFOLIO	[fid=000001005-60-0000DDP;ext=ddp;mime=;]Delphi Diagram Portfolio file

# Magic ID for Pagestream files.
# Submitted on 2004-02-08 by Carl
0	string	FORM	[fid=000001268-60-0000DOC;ext=doc;mime=;]Pagestream document
&8	string	DOC\\ 	

# Submitted on 2004-02-08 by Carl
0	string	CAT\\ 	[fid=000001010-60-000FTXT;ext=ftxt;mime=;]Formatted text interchange file
&8	string	FTXT	

# Submitted on 2004-02-08 by Carl
0	string	FORM	[fid=000001010-60-000FTXT;ext=ftxt;mime=;]Formatted text interchange file
&8	string	FTXT	

# Submitted on 2004-02-08 by Carl
0	string	LIST	[fid=000001010-60-000FTXT;ext=ftxt;mime=;]Formatted text interchange file
&8	string	FTXT	

# Submitted on 2004-02-08 by Carl
0	string	@database	[fid=000001007-60-00GUIDE;ext=guide;mime=;]AmigaGuide hypertext document

# Submitted on 2004-02-14 by Carl
0	lelong	0x00035F3F	[fid=000001001-60-0000HLP;ext=hlp;mime=;]Microsoft Windows Help file

# Submitted on 2004-10-08 by Carl
0	string	<!DOCTYPE\\ 	[fid=000000001-60-0015445;ext=html,htm;mime=text/html;]HyperText Markup Language document (HTML)
&10	string/c	html	

# Submitted on 2004-02-08 by Carl
0	string	HDOC	[fid=000001006-60-0000HYP;ext=hyp;mime=;]Atari ST-Guide hypertext document

# Magic ID for OS/2 files.
# Submitted on 2004-02-08 by Carl
0	string	HSP	[fid=000001009-60-0000INF;ext=inf;mime=;]OS/2 Guide hypertext document

# Submitted on 2004-02-08 by Carl
0	string	This\\ is\\ Info\\ file	[fid=000100010-60-000INFO;ext=info;mime=;]GNU Info hypertext document

# Magic ID for Adobe Acrobat files.
# Submitted on 2004-10-08 by Carl
0	string	%PDF-	[fid=000000001-60-0015930;ext=pdf;mime=application/pdf;]Portable document format document file (PDF)
>5	string	x	, version %.1s
>7	string	x	.%.1s

# Magic ID for Microsoft Wordpad files.
# Submitted on 2004-02-08 by Carl
0	string	{\\\\rtf	[fid=000001001-60-0000RTF;ext=rtf;mime=text/rtf;]Rich Text Format document
>5	string	x	, version %.1s.x

# Magic ID for DocBook files.
# Submitted on 2004-10-08 by Carl
0	string	<!DOCTYPE\\ 	[fid=000000001-60-0008879;ext=sgml,sgm;mime=text/sgml;]Standard general markup language document (SGML)

# Magic ID for Turbo C files.
# Submitted on 2004-02-14 by Carl
0	string	TURBO\\ C\\ HELP\\ FILE\\x00	[fid=000001005-60-0000TCH;ext=tch;mime=;]Turbo C help file

# Magic ID for Turbo Pascal files.
# Submitted on 2004-02-08 by Carl
0	string	TURBO\\ PASCAL\\ HELP\\ FILE\\x00	[fid=000001005-60-0000TPH;ext=tph;mime=;]Borland Pascal help file

# Magic ID for Turbo Vision files.
# Submitted on 2004-02-08 by Carl
0	lelong	0x46484246	[fid=000001005-60-0000TVH;ext=tvh;mime=;]Borland Turbo Vision help file

# Magic ID for Wordperfect files.
# Submitted on 2004-02-08 by Carl
0	string	\\xFFWPC	[fid=000001008-60-0000WPD;ext=wpd,doc;mime=application/vnd.wordperfect;]Wordperfect document
&9	byte	0x0A	
>10	byte	x	, version %d
>11	byte	x	.%d

# Magic ID for Microsoft Write files.
# Submitted on 2004-02-08 by Carl
0	leshort	0137061	[fid=000001001-60-0000WRI;ext=wri;mime=;]Microsoft Write document
&2	leshort	0x0000	

# Magic ID for Microsoft Write files.
# Submitted on 2004-02-08 by Carl
0	leshort	0137062	[fid=000001001-60-0000WRI;ext=wri;mime=;]Microsoft Write document
&2	leshort	0x0000	

# Magic ID for X-Windows files.
# Submitted on 2004-09-01 by Carl
0	string	STARTFONT\\ 	[fid=000001003-70-0000BDF;ext=bdf;mime=;]Adobe glyph bitmap distribution format font file

# Magic ID for Deluxe Paint files.
# Submitted on 2004-09-01 by Carl
0	string	CF\\x01\\x00	[fid=000001010-70-000000C;ext=c;mime=;]Deluxe paint multi-colour font file

# Magic ID for Figlet files.
# Submitted on 2004-09-01 by Carl
0	string	flf2	[fid=000100122-70-0000FLF;ext=flf;mime=;]Figlet font file

# Magic ID for PCL 5 files.
# Submitted on 2004-09-01 by Carl
0	string	\\x00\\x44\\x00\\x01\\x00\\x00\\x00\\x1A	[fid=000001336-70-0000LIB;ext=lib,type;mime=;]Intellifont Scalable Typeface Format  file

# Magic ID for Deluxe Paint files.
# Submitted on 2004-09-01 by Carl
0	string	\\x1B\\x29\\x73\\x36\\x34\\x57\\x00\\x40	[fid=000001010-70-000000M;ext=m;mime=;]Deluxe paint mono colour font file

# Submitted on 2004-05-20 by Carl
0	belong	0x00010000	[fid=000001001-70-0000TTF;ext=otf,ttf;mime=;]Opentype font file

# Submitted on 2004-05-20 by Carl
0	string	OTTO	[fid=000001001-70-0000TTF;ext=otf,ttf;mime=;]Opentype font file, CFF type

# Magic ID for X-Windows files.
# Submitted on 2004-09-01 by Carl
0	belong	0x01666370	[fid=000000000-70-0000PCF;ext=pcf;mime=;]Portable compiled format (PCF) font file

# Submitted on 2004-05-20 by Carl
0	string	%!FontType1	[fid=000000001-70-0009541;ext=pfa;mime=;]Type 1 font file

# Submitted on 2004-05-20 by Carl
0	string	%!PS-AdobeFont-1.0	[fid=000000001-70-0009541;ext=pfa;mime=;]Type 1 font file

# Submitted on 2004-05-20 by Carl
6	string	%!FontType1	[fid=000001003-70-0000PFB;ext=pfb;mime=;]Type 1 printer font binary file
&0	byte	0x80	

# Submitted on 2004-05-20 by Carl
6	string	%!PS-AdobeFont-1.0	[fid=000001003-70-0000PFB;ext=pfb;mime=;]Type 1 printer font binary file
&0	byte	0x80	

# Magic ID for X-Windows, GemDOS files.
# Submitted on 2004-09-01 by Carl
2	string	\\x2E\\x30\\x0D\\x0A\\x00\\x00	[fid=000001337-70-0000SPD;ext=spd;mime=;]Bitstream Speedo font file
&0	string	D	
>24	string	x	[title=%.70s]
>1	string	x	,version %.1s.0

# Submitted on 2004-05-20 by Carl
0	string	true	[fid=000001002-70-0000TTF;ext=ttf;mime=;]Truetype font file

# Submitted on 2004-05-20 by Carl
0	string	typ1	[fid=000001002-70-0000TTF;ext=ttf;mime=;]Truetype font file

# Submitted on 2004-05-20 by Carl
0	string	StartCompFontMetrics	[fid=000001003-70-0000AFM;ext=afm;mime=;]Adobe composite font metrics file

# Submitted on 2004-05-20 by Carl
0	string	StartFontMetrics	[fid=000001003-70-0000AFM;ext=afm;mime=;]Adobe font metrics file

# Submitted on 2004-05-20 by Carl
0	string	StartMasterFontMetrics	[fid=000001003-70-0000AFM;ext=afm;mime=;]Adobe master font metrics file

# Submitted on 2004-05-20 by Carl
0	leshort	0x0100	[fid=000001001-70-0000PFM;ext=pfm;mime=;]Printer Font Metrics file for Type 1 fonts
&66	leshort	0x0081	

# Submitted on 2004-02-08 by Carl
0	lelong	0x75B22630	[fid=000001001-81-0000ASF;ext=asf,wma,wmv;mime=;]Microsoft Advanced Streaming format multimedia file
&6	leshort	0x11CF	

# Submitted on 2004-02-08 by Carl
0	string	RIFF	[fid=000001001-81-0000AVI;ext=avi;mime=;]Audio-video interleaved movie, little-endian
&8	string	AVI\\ 	

# Submitted on 2004-02-13 by Carl
0	string	RIFX	[fid=000001001-81-0000AVI;ext=avi;mime=;]Audio-video interleaved movie, big-endian
&8	string	AVI\\ 	

# Magic ID for Quicktime files.
# Submitted on 2004-02-08 by Carl
4	string	mdat	[fid=000001002-81-0000MOV;ext=mov,qt;mime=video/quicktime;]Apple QuickTime movie data (mdat)

# Magic ID for Quicktime files.
# Submitted on 2004-02-08 by Carl
4	string	moov	[fid=000001002-81-0000MOV;ext=mov,qt;mime=video/quicktime;]Apple QuickTime movie resource (moov)

# Submitted on 2004-05-20 by Carl
0	belong	0x1B3	[fid=000000001-81-000MPEG;ext=mpe,mpeg,mpg;mime=video/mpeg;]MPEG multimedia (audio/video) stream file
&Z4	belong	0x01B9	

# Submitted on 2004-05-20 by Carl
0	belong	0x1BA	[fid=000000001-81-000MPEG;ext=mpe,mpeg,mpg;mime=video/mpeg;]MPEG multimedia (audio/video) stream file
&Z4	belong	0x01B9	

# Submitted on 2004-05-20 by Carl
0	belong	0x1E0	[fid=000000001-81-000MPEG;ext=mpe,mpeg,mpg;mime=video/mpeg;]MPEG multimedia (audio/video) stream file
&Z4	belong	0x01B9	

# Magic ID for Alias/Wavefront files.
# Submitted on 2004-02-08 by Carl
0	string	MOVI	[fid=000001004-81-00000MV;ext=mv;mime=;]Alias/Wavefront movie file

# Submitted on 2004-05-18 by Carl
0	string	OggS	[fid=000000000-81-0000OGG;ext=ogg;mime=application/ogg;]OGG Multimedia container stream file

# Magic ID for Realplayer files.
# Submitted on 2004-05-19 by Carl
0	string	.RMF	[fid=000001027-81-00000RM;ext=rm,ra,rt,rp,rpa;mime=;]RealMedia multimedia container stream file

# Magic ID for Macromedia Flash files.
# Submitted on 2004-02-08 by Carl
0	string	FWS	[fid=000001259-81-0000SWF;ext=swf;mime=;]Shockwave Macromedia animation
>3	byte	x	, version %d.0

# Magic ID for Vivo player files.
# Submitted on 2004-05-20 by Carl
5	string	Version:Vivo	[fid=000000000-81-000VIVO;ext=viv,vivo;mime=video/vnd.vivo;]Vivo multimedia stream file

# Magic ID for Aegis Animator files.
# Submitted on 2004-02-08 by Carl
0	string	FORM	[fid=000001261-82-000ANIM;ext=anim;mime=;]Amiga / Sparta software animation
&8	string	ANIM	

# Magic ID for Fantavision movie maker files.
# Submitted on 2004-02-08 by Carl
0	string	FORM	[fid=000001260-82-000FANT;ext=fant;mime=;]Fantavision movie
&8	string	FANT	

# Magic ID for Autodesk Animator Pro files.
# Submitted on 2004-02-08 by Carl
4	leshort	0xAF12	[fid=000001254-82-0000FLC;ext=flc;mime=;]Autodesk Animator Pro animation
&12	leshort	0x08	
>8	leshort	x	[res=%dx
>10	leshort	x	%d
>12	leshort	x	x8bpp]

# Magic ID for Autodesk Animator files.
# Submitted on 2004-02-08 by Carl
4	leshort	0xAF11	[fid=000001254-82-0000FLI;ext=fli;mime=;]Autodesk Animator animation
&12	leshort	0x08	
>8	leshort	x	[res=%dx
>10	leshort	x	%d
>12	leshort	x	x8bpp]

# Submitted on 2004-04-13 by Carl
0	string	\\x8AMNG\\x0d\\x0A\\x1A\\x0A	[fid=000000000-82-0000MNG;ext=mng;mime=;]Multi-image network graphics animation file
>0x10	belong	x	[res=%dx
>0x14	belong	x	%d]

# Magic ID for Cyberpaint files.
# Submitted on 2004-02-08 by Carl
0	beshort	0xFEDB	[fid=000000000-82-0000SEQ;ext=seq;mime=;]Cyberpaint Animation Sequence
&2	beshort	0x0000	

# Magic ID for Quicken,Money files.
# Submitted on 2004-08-01 by Carl
0	string	OFXHEADER:	[fid=000000008-91-0000QFX;ext=qfx;mime=;]Open financial exchange file (SGML)

# Magic ID for Quicken files.
# Submitted on 2004-08-01 by Carl
1	string	Account	[fid=000001335-91-0000QIF;ext=qif;mime=;]Quicken interchange file
&0	byte	33	

# Magic ID for Quicken files.
# Submitted on 2004-08-01 by Carl
1	string	Type:Bank	[fid=000001335-91-0000QIF;ext=qif;mime=;]Quicken interchange file
&0	byte	33	

# Magic ID for Quicken files.
# Submitted on 2004-08-01 by Carl
1	string	Type:Cash	[fid=000001335-91-0000QIF;ext=qif;mime=;]Quicken interchange file
&0	byte	33	

# Magic ID for Quicken files.
# Submitted on 2004-08-01 by Carl
1	string	Type:Cat	[fid=000001335-91-0000QIF;ext=qif;mime=;]Quicken interchange file
&0	byte	33	

# Magic ID for Quicken files.
# Submitted on 2004-08-01 by Carl
1	string	Type:CCard	[fid=000001335-91-0000QIF;ext=qif;mime=;]Quicken interchange file
&0	byte	33	

# Magic ID for Quicken files.
# Submitted on 2004-08-01 by Carl
1	string	Type:Class	[fid=000001335-91-0000QIF;ext=qif;mime=;]Quicken interchange file
&0	byte	33	

# Magic ID for Quicken files.
# Submitted on 2004-08-01 by Carl
1	string	Type:Invst	[fid=000001335-91-0000QIF;ext=qif;mime=;]Quicken interchange file
&0	byte	33	

# Magic ID for Quicken files.
# Submitted on 2004-08-01 by Carl
1	string	Type:Memorized	[fid=000001335-91-0000QIF;ext=qif;mime=;]Quicken interchange file
&0	byte	33	

# Magic ID for Quicken files.
# Submitted on 2004-08-01 by Carl
1	string	Type:Oth A	[fid=000001335-91-0000QIF;ext=qif;mime=;]Quicken interchange file
&0	byte	33	

# Magic ID for Quicken files.
# Submitted on 2004-08-01 by Carl
1	string	Type:Oth L	[fid=000001335-91-0000QIF;ext=qif;mime=;]Quicken interchange file
&0	byte	33	

# Submitted on 2004-02-11 by Carl
0	string	RRG	[fid=000001001-B0-0000CRD;ext=crd;mime=;]Windows 3.x cardfile

# Submitted on 2004-02-11 by Carl
0	string	MGC	[fid=000001001-B0-0000CRD;ext=crd;mime=;]Windows NT 3.51 card file

# Submitted on 2004-02-14 by Carl
0	string	BEGIN:VCARD	[fid=000001015-B0-0000VCF;ext=vcf;mime=;]vCard Business Card file

# Submitted on 2004-02-14 by Carl
0	string	\\xb5\\xa2\\xb0\\xb3\\xb3\\xb0\\xa2\\xb5	[fid=000001001-B1-0000CAL;ext=cal;mime=;]Microsoft windows calendar file

# Submitted on 2004-02-14 by Carl
0	string	BEGIN:VCALENDAR	[fid=000001016-B1-0000VCS;ext=vcs;mime=;]vCalendar/iCalendar Agenda file

# Submitted on 2004-05-17 by Carl
0	string	\\x00\\x00\\x00\\x3C\\x00\\x00\\x00\\x3F	[fid=000000007-F3-0000XML;ext=xml;mime=text/xml;]Extensible Markup language (XML) file, UTF-32BE encoded
&8	belong	0x00000078	
&12	belong	0x0000006d	

# Submitted on 2004-05-17 by Carl
0	string	\\x00\\x00\\xfe\\xff\\x00\\x00\\x00\\x3C	[fid=000000007-F3-0000XML;ext=xml;mime=text/xml;]Extensible Markup language (XML) file, UTF-32BE encoded
&8	belong	0x0000003F	
&12	belong	0x00000078	

# Submitted on 2004-05-17 by Carl
0	string	\\x00\\x3C\\x00\\x3F\\x00\\x78\\x00\\x6D\\x00\\x6c	[fid=000000007-F3-0000XML;ext=xml;mime=text/xml;]Extensible Markup language (XML) file, UTF-16BE encoded

# Submitted on 2004-05-17 by Carl
0	string	\\x3C\\x00\\x00\\x00\\x3F\\x00\\x00\\x00	[fid=000000007-F3-0000XML;ext=xml;mime=text/xml;]Extensible Markup language (XML) file, UTF-32LE encoded
&8	beshort	0x00000078	
&12	beshort	0x0000006d	

# Submitted on 2004-05-17 by Carl
0	string	\\x3C\\x00\\x3F\\x00\\x78\\x00\\x6D\\x00\\x6c\\x00	[fid=000000007-F3-0000XML;ext=xml;mime=text/xml;]Extensible Markup language (XML) file, UTF-16LE encoded

# Submitted on 2004-05-17 by Carl
0	string	\\xef\\xbb\\xbf<?xml	[fid=000000007-F3-0000XML;ext=xml;mime=text/xml;]Extensible Markup language (XML) file, UTF-8 encoded

# Submitted on 2004-05-17 by Carl
0	string	\\xfe\\xff\\x00\\x3C\\x00\\x3F\\x00\\x78\\x00\\x6D	[fid=000000007-F3-0000XML;ext=xml;mime=text/xml;]Extensible Markup language (XML) file, UTF-16BE encoded

# Submitted on 2004-05-17 by Carl
0	string	\\xff\\xfe\\x00\\x00\\x3C\\x00\\x00\\x00	[fid=000000007-F3-0000XML;ext=xml;mime=text/xml;]Extensible Markup language (XML) file, UTF-32LE encoded
&8	beshort	0x3F000000	
&12	beshort	0x78000000	

# Submitted on 2004-05-17 by Carl
0	string	\\xff\\xfe\\x3C\\x00\\x3F\\x00\\x78\\x00\\x6D\\x00	[fid=000000007-F3-0000XML;ext=xml;mime=text/xml;]Extensible Markup language (XML) file, UTF-16LE encoded

# Submitted on 2004-05-17 by Carl
0	string	<?xml	[fid=000000007-F3-0000XML;ext=xml;mime=text/xml;]Extensible Markup language (XML) file

# Submitted on 2004-04-20 by Carl
0	string	\\xd0\\xcf\\x11\\xe0\\xa1\\xb1\\x1a\\xe1	[fid=000001001-F4-0000OLE;ext=ole;mime=;]Microsoft OLE Compound file, big-endian
&0x1C	leshort	!0xFFFE	

# Submitted on 2004-04-20 by Carl
0	string	\\xd0\\xcf\\x11\\xe0\\xa1\\xb1\\x1a\\xe1	[fid=000001001-F4-0000OLE;ext=ole;mime=;]Microsoft OLE Compound file, little-endian
&0x1C	leshort	0xFFFE	
>0x1A	leshort	x	, version %d
>0x18	leshort	x	.%d

# Magic ID for Freepascal compiler files.
# Submitted on 2004-10-24 by Carl
0	string	PPU0	[fid=000100120-11-0000PPU;ext=ppu,ppl,ppo,ppw,ppa,ppt;mime=;]Freepascal unit file
>0x04	string	x	, version %.2s

# Magic ID for Smartcards files.
# Submitted on 2004-10-29 by Carl
0	belong	0x00FACADE	[fid=000001011-10-0000EXP;ext=exp;mime=;]Javacard API export file
>0x05	byte	x	, version %d
>4	byte	x	.%d

# Submitted on 2004-10-29 by Carl
0	string	-rom1fs-	[fid=000100121-0F-0000IMG;ext=img;mime=;]Simple ROM filesystem (ROMFS)
>16	string	x	[title=%s]

# Magic ID for Virtual PC files.
# Submitted on 2004-10-29 by Carl
0	string	conectix	[fid=000001001-0F-0000VHD;ext=vhd;mime=;]Virtual PC Hard drive

# Submitted on 2004-11-12 by Carl Eric Codere
0	string	%!PS-Adobe-	[fid=000001003-33-00000PS;ext=ps,eps;mime=application/postscript;]Postscript file
>11	string	x	, level %.1s
>13	string	x	.%.1s

# Submitted on 2004-11-12 by Carl Eric Codere
0	lelong	0x526f6d2e	[fid=000001338-0F-0000ROM;ext=rom,fs;mime=;]eCos ROM Filesystem image (ROMFS)
>16	string	x	[title=%.16s]

# Magic ID for PADGen files.
# Submitted on 2004-11-26 by Carl Eric Codere
0x29	string	<XML_DIZ_INFO>	[fid=000001339-A0-0000XML;ext=xml;mime=text/xml;]Portable application description file (XML)
&0	string	<?xml	

# Magic ID for PADGen files.
# Submitted on 2004-11-26 by Carl Eric Codere
0x28	string	<XML_DIZ_INFO>	[fid=000001339-A0-0000XML;ext=xml;mime=text/xml;]Portable application description file (XML)
&0	string	<?xml	

# Submitted on 2004-11-26 by Carl Eric Codere
0x29	string	<x:xmpmeta\\ 	[fid=000001003-A0-0000XMP;ext=xml,xmp;mime=text/xml;]Extensible metadata platform sidecar file (XML)
&0	string	<?xml	

# Submitted on 2004-11-26 by Carl Eric Codere
0x28	string	<x:xmpmeta\\ 	[fid=000001003-A0-0000XMP;ext=xml,xmp;mime=text/xml;]Extensible metadata platform sidecar file (XML)
&0	string	<?xml	

# Magic ID for Texinfo files.
# Submitted on 2004-11-26 by Carl Eric Codere
1	string	input texinfo	[fid=000001340-00-000TEXI;ext=texi;mime=;]Texinfo source file

# Magic ID for MS-DOS files.
# Submitted on 2004-11-26 by Carl Eric Codere
0	string	\\xFFFONT	[fid=000001001-70-0000CPI;ext=cpi;mime=;]MS-DOS code page raster font

# Magic ID for UNIX files.
# Submitted on 2004-11-26 by Carl Eric Codere
0	string	TZif	[fid=000000000-90-0000000;ext=;mime=;]Timezone information database file (compiled)

# Magic ID for Telix files.
# Submitted on 2005-03-04 by Carl Eric Codere
0	lelong	0x2e2b291a	[fid=000100126-B0-0000FON;ext=fon;mime=;]Telix phone book
&4	leshort	1	

# Magic ID for Microsoft Visual C++ files.
# Submitted on 2005-03-04 by Carl Eric Codere
0	string	VCPCH0\\x00\\x00	[fid=000001001-90-0000PCH;ext=pch;mime=;]Microsoft Visual C++ pre-compiled header(s)

# Magic ID for Microsoft Visual C++ files.
# Submitted on 2005-03-04 by Carl Eric Codere
0	string	Microsoft\\ C/C++\\ program\\ database	[fid=000001001-90-0000PDB;ext=pdb;mime=;]Microsoft Visual C++ debug information database
&0x25	string	\\x0D\\x0A\\x1A	
&0x28	string	JG\\x00	

# Magic ID for Microsoft Visual C++ files.
# Submitted on 2005-03-04 by Carl Eric Codere
0	string	Microsoft\\ Linker\\ Database\\x0A\\x07\\x1A	[fid=000001001-90-0000ILK;ext=ilk;mime=;]Microsoft Visual C++ linker database


# CRC32:8BC3BA46
'
);
-
/**
* Returns the test data for a given key
*
diff --git a/cake/tests/cases/libs/model/behavior.test.php b/cake/tests/cases/libs/model/behavior.test.php
index 628397fa3..9b3760259 100644
--- a/cake/tests/cases/libs/model/behavior.test.php
+++ b/cake/tests/cases/libs/model/behavior.test.php
@@ -1,7 +1,7 @@
assertIdentical($Apple->beforeTestResult, $expected);
}
-
/**
* Test attach and detaching
*
+ * @access public
* @return void
**/
function testBehaviorAttachAndDetach() {
@@ -954,19 +960,8 @@ class BehaviorTest extends CakeTestCase {
$Sample->Behaviors->init($Sample->alias, $Sample->actsAs);
$Sample->Behaviors->attach('Test2');
$Sample->Behaviors->detach('Test3');
-
+
$Sample->Behaviors->trigger($Sample, 'beforeTest');
}
-
-/**
- * tearDown method
- *
- * @access public
- * @return void
- */
- function tearDown() {
- ClassRegistry::flush();
- }
}
-
?>
\ No newline at end of file
diff --git a/cake/tests/cases/libs/model/behaviors/acl.test.php b/cake/tests/cases/libs/model/behaviors/acl.test.php
index 47ffc4a79..3ca1974e3 100644
--- a/cake/tests/cases/libs/model/behaviors/acl.test.php
+++ b/cake/tests/cases/libs/model/behaviors/acl.test.php
@@ -1,7 +1,7 @@
'mother_id'
)
);
-
/**
- * ParentNode
+ * parentNode method
*
* @return void
- **/
+ * @access public
+ */
function parentNode() {
if (!$this->id && empty($this->data)) {
return null;
@@ -99,13 +98,11 @@ class AclPerson extends CakeTestModel {
return array('AclPerson' => array('id' => $data['AclPerson']['mother_id']));
}
}
-
}
-
/**
-* Acl Test User
+* AclUser class
*
-* @package cake.tests
+* @package cake
* @subpackage cake.tests.cases.libs.model.behaviors
*/
class AclUser extends CakeTestModel {
@@ -139,11 +136,10 @@ class AclUser extends CakeTestModel {
return null;
}
}
-
/**
-* Acl Test User
+* AclPost class
*
-* @package cake.tests
+* @package cake
* @subpackage cake.tests.cases.libs.model.behaviors
*/
class AclPost extends CakeTestModel {
@@ -177,33 +173,62 @@ class AclPost extends CakeTestModel {
return null;
}
}
-
/**
-* ACL behavior test class
+* AclBehaviorTest class
*
-* @package cake.tests
+* @package cake
* @subpackage cake.tests.cases.libs.controller.components
*/
class AclBehaviorTestCase extends CakeTestCase {
+/**
+ * Aco property
+ *
+ * @var Aco
+ * @access public
+ */
+ var $Aco;
+/**
+ * Aro property
+ *
+ * @var Aro
+ * @access public
+ */
+ var $Aro;
+/**
+ * fixtures property
+ *
+ * @var array
+ * @access public
+ */
var $fixtures = array('core.person', 'core.user', 'core.post', 'core.aco', 'core.aro', 'core.aros_aco');
-
/**
* Set up the test
*
* @return void
- **/
+ * @access public
+ */
function startTest() {
Configure::write('Acl.database', 'test_suite');
$this->Aco =& new Aco();
$this->Aro =& new Aro();
}
-
+/**
+ * tearDown method
+ *
+ * @return void
+ * @access public
+ */
+ function tearDown() {
+ ClassRegistry::flush();
+ unset($this->Aro, $this->Aco);
+ }
/**
* Test Setup of AclBehavior
*
* @return void
- **/
+ * @access public
+ */
function testSetup() {
$User =& new AclUser();
$this->assertTrue(isset($User->Behaviors->Acl->settings['User']));
@@ -215,12 +240,12 @@ class AclBehaviorTestCase extends CakeTestCase {
$this->assertEqual($Post->Behaviors->Acl->settings['Post']['type'], 'controlled');
$this->assertTrue(is_object($Post->Aco));
}
-
/**
* test After Save
*
* @return void
- **/
+ * @access public
+ */
function testAfterSave() {
$Post =& new AclPost();
$data = array(
@@ -264,12 +289,12 @@ class AclBehaviorTestCase extends CakeTestCase {
$this->assertEqual($node[0]['Aro']['parent_id'], 5);
$this->assertEqual($node[1]['Aro']['parent_id'], null);
}
-
/**
* Test After Delete
*
* @return void
- **/
+ * @access public
+ */
function testAfterDelete() {
$aroData = array(
'Aro' => array(
@@ -317,12 +342,12 @@ class AclBehaviorTestCase extends CakeTestCase {
$this->assertTrue(empty($result));
}
-
/**
* Test Node()
*
* @return void
- **/
+ * @access public
+ */
function testNode() {
$Person =& new AclPerson();
$aroData = array(
@@ -339,16 +364,5 @@ class AclBehaviorTestCase extends CakeTestCase {
$this->assertTrue(is_array($result));
$this->assertEqual(sizeof($result), 1);
}
-
-/**
- * tear down test
- *
- * @return void
- **/
- function tearDown() {
- ClassRegistry::flush();
- unset($this->Aro, $this->Aco);
- }
-
}
?>
\ No newline at end of file
diff --git a/cake/tests/cases/libs/model/behaviors/containable.test.php b/cake/tests/cases/libs/model/behaviors/containable.test.php
index 9a7a2f4e1..b5f801df8 100644
--- a/cake/tests/cases/libs/model/behaviors/containable.test.php
+++ b/cake/tests/cases/libs/model/behaviors/containable.test.php
@@ -1,7 +1,7 @@
+?>
\ No newline at end of file
diff --git a/cake/tests/cases/libs/model/behaviors/translate.test.php b/cake/tests/cases/libs/model/behaviors/translate.test.php
index 4c0393df7..20eb3651c 100644
--- a/cake/tests/cases/libs/model/behaviors/translate.test.php
+++ b/cake/tests/cases/libs/model/behaviors/translate.test.php
@@ -1,7 +1,7 @@
simulated[count($this->simulated) - 1];
}
}
-
/**
- * Short description for class.
+ * AdodbTestModel
*
- * @package cake.tests
+ * @package cake
* @subpackage cake.tests.cases.libs.model.datasources
*/
class AdodbTestModel extends CakeTestModel {
@@ -152,7 +149,6 @@ class AdodbTestModel extends CakeTestModel {
);
}
}
-
if (!class_exists('Article')) {
/**
* Article class
@@ -171,11 +167,10 @@ if (!class_exists('Article')) {
}
}
-
/**
- * The test class for the DboAdobd
+ * DboAdodbTest class
*
- * @package cake.tests
+ * @package cake
* @subpackage cake.tests.cases.libs.model.datasources.dbo
*/
class DboAdodbTest extends CakeTestCase {
@@ -186,14 +181,13 @@ class DboAdodbTest extends CakeTestCase {
* @access public
*/
var $db = null;
-
/**
- * undocumented class variable
+ * fixtures property
*
* @var string
+ * @access public
**/
var $fixtures = array('core.article');
-
/**
* Skip if cannot connect to AdoDb
*
@@ -280,6 +274,5 @@ class DboAdodbTest extends CakeTestCase {
function testColumns() {
}
-
}
?>
\ No newline at end of file
diff --git a/cake/tests/cases/libs/model/datasources/dbo/dbo_mssql.test.php b/cake/tests/cases/libs/model/datasources/dbo/dbo_mssql.test.php
index cc8448a3e..ab5592200 100644
--- a/cake/tests/cases/libs/model/datasources/dbo/dbo_mssql.test.php
+++ b/cake/tests/cases/libs/model/datasources/dbo/dbo_mssql.test.php
@@ -1,7 +1,7 @@
connected = true;
return true;
}
- function lastError() {}
+/**
+ * lastError method
+ *
+ * @return void
+ * @access public
+ */
+ function lastError() {
+ }
/**
* simulated property
*
@@ -104,11 +121,10 @@ class DboMssqlTestDb extends DboMssql {
return $this->simulated[count($this->simulated) - 1];
}
}
-
/**
- * Short description for class.
+ * MssqlTestModel class
*
- * @package cake.tests
+ * @package cake
* @subpackage cake.tests.cases.libs.model.datasources
*/
class MssqlTestModel extends Model {
@@ -183,9 +199,9 @@ class MssqlTestModel extends Model {
}
}
/**
- * The test class for the DboMssql
+ * DboMssqlTest class
*
- * @package cake.tests
+ * @package cake
* @subpackage cake.tests.cases.libs.model.datasources.dbo
*/
class DboMssqlTest extends CakeTestCase {
@@ -215,6 +231,16 @@ class DboMssqlTest extends CakeTestCase {
$this->db = new DboMssqlTestDb($db->config);
$this->model = new MssqlTestModel();
}
+/**
+ * tearDown method
+ *
+ * @access public
+ * @return void
+ */
+ function tearDown() {
+ unset($this->model);
+ }
+
/**
* testQuoting method
*
@@ -314,7 +340,12 @@ class DboMssqlTest extends CakeTestCase {
);
$this->assertEqual($result, $expected);
}
-
+/**
+ * testUpdateAllSyntax method
+ *
+ * @return void
+ * @access public
+ */
function testUpdateAllSyntax() {
$model = ClassRegistry::init('MssqlTestModel');
$fields = array('MssqlTestModel.client_id' => '[MssqlTestModel].[client_id] + 1');
@@ -326,15 +357,5 @@ class DboMssqlTest extends CakeTestCase {
$this->assertPattern('/^UPDATE \[mssql_test_models\]/', $result);
$this->assertPattern('/SET \[client_id\] = \[client_id\] \+ 1/', $result);
}
-
-/**
- * tearDown method
- *
- * @access public
- * @return void
- */
- function tearDown() {
- unset($this->model);
- }
}
?>
\ No newline at end of file
diff --git a/cake/tests/cases/libs/model/datasources/dbo/dbo_mysql.test.php b/cake/tests/cases/libs/model/datasources/dbo/dbo_mysql.test.php
index dda8322cf..3d94dc6af 100644
--- a/cake/tests/cases/libs/model/datasources/dbo/dbo_mysql.test.php
+++ b/cake/tests/cases/libs/model/datasources/dbo/dbo_mysql.test.php
@@ -1,7 +1,7 @@
db->query($this->db->dropSchema($schema1));
}
}
-
?>
\ No newline at end of file
diff --git a/cake/tests/cases/libs/model/datasources/dbo/dbo_mysqli.test.php b/cake/tests/cases/libs/model/datasources/dbo/dbo_mysqli.test.php
index 38ab1b891..9031164dd 100644
--- a/cake/tests/cases/libs/model/datasources/dbo/dbo_mysqli.test.php
+++ b/cake/tests/cases/libs/model/datasources/dbo/dbo_mysqli.test.php
@@ -1,7 +1,7 @@
assertEqual($result, $expected);
}
}
-
?>
\ No newline at end of file
diff --git a/cake/tests/cases/libs/model/datasources/dbo/dbo_oracle.test.php b/cake/tests/cases/libs/model/datasources/dbo/dbo_oracle.test.php
index 0cacb783c..314fcfce8 100644
--- a/cake/tests/cases/libs/model/datasources/dbo/dbo_oracle.test.php
+++ b/cake/tests/cases/libs/model/datasources/dbo/dbo_oracle.test.php
@@ -1,7 +1,7 @@
db->config['password'] = $old_pw;
$this->db->connect();
}
-
/**
* testName method
*
@@ -131,10 +128,5 @@ class DboOracleTest extends CakeTestCase {
$this->assertEqual($e, $r);
}
-
-
-
-
}
-
?>
\ No newline at end of file
diff --git a/cake/tests/cases/libs/model/datasources/dbo/dbo_postgres.test.php b/cake/tests/cases/libs/model/datasources/dbo/dbo_postgres.test.php
index c6ff8a5f0..bae7ad584 100644
--- a/cake/tests/cases/libs/model/datasources/dbo/dbo_postgres.test.php
+++ b/cake/tests/cases/libs/model/datasources/dbo/dbo_postgres.test.php
@@ -1,7 +1,7 @@
assertEqual($this->db->buildColumn($result), $expected);
}
-
/**
* Tests that binary data is escaped/unescaped properly on reads and writes
*
@@ -409,7 +406,6 @@ class DboPostgresTest extends CakeTestCase {
$result = $model->find('first');
$this->assertEqual($result['BinaryTest']['data'], $data);
}
-
/**
* Tests the syntax of generated schema indexes
*
@@ -479,7 +475,6 @@ class DboPostgresTest extends CakeTestCase {
$db1->query('DROP TABLE ' . $db1->fullTableName('datatypes'));
}
-
/**
* Test index generation from table info.
*
diff --git a/cake/tests/cases/libs/model/datasources/dbo/dbo_sqlite.test.php b/cake/tests/cases/libs/model/datasources/dbo/dbo_sqlite.test.php
index a22cc7721..adfad9dbc 100644
--- a/cake/tests/cases/libs/model/datasources/dbo/dbo_sqlite.test.php
+++ b/cake/tests/cases/libs/model/datasources/dbo/dbo_sqlite.test.php
@@ -1,7 +1,7 @@
assertEqual($expected, $result);
$this->db->query('DROP TABLE ' . $name);
}
-
/**
* Tests that cached table descriptions are saved under the sanitized key name
*
@@ -207,5 +205,4 @@ class DboSqliteTest extends CakeTestCase {
Configure::write('Cache.disable', true);
}
}
-
?>
\ No newline at end of file
diff --git a/cake/tests/cases/libs/model/datasources/dbo_source.test.php b/cake/tests/cases/libs/model/datasources/dbo_source.test.php
index 54375cf7e..cb10ebc46 100644
--- a/cake/tests/cases/libs/model/datasources/dbo_source.test.php
+++ b/cake/tests/cases/libs/model/datasources/dbo_source.test.php
@@ -1,7 +1,7 @@
_schema;
}
}
+/**
+ * TestModel4TestModel7 class
+ *
+ * @package cake
+ * @subpackage cake.tests.cases.libs.model.datasources
+ */
class TestModel4TestModel7 extends CakeTestModel {
/**
* name property
@@ -271,9 +276,9 @@ class TestModel4TestModel7 extends CakeTestModel {
}
}
/**
- * Short description for class.
+ * TestModel5 class
*
- * @package cake.tests
+ * @package cake
* @subpackage cake.tests.cases.libs.model.datasources
*/
class TestModel5 extends CakeTestModel {
@@ -338,9 +343,9 @@ class TestModel5 extends CakeTestModel {
}
}
/**
- * Short description for class.
+ * TestModel6 class
*
- * @package cake.tests
+ * @package cake
* @subpackage cake.tests.cases.libs.model.datasources
*/
class TestModel6 extends CakeTestModel {
@@ -395,9 +400,9 @@ class TestModel6 extends CakeTestModel {
}
}
/**
- * Short description for class.
+ * TestModel7 class
*
- * @package cake.tests
+ * @package cake
* @subpackage cake.tests.cases.libs.model.datasources
*/
class TestModel7 extends CakeTestModel {
@@ -441,9 +446,9 @@ class TestModel7 extends CakeTestModel {
}
}
/**
- * Short description for class.
+ * TestModel8 class
*
- * @package cake.tests
+ * @package cake
* @subpackage cake.tests.cases.libs.model.datasources
*/
class TestModel8 extends CakeTestModel {
@@ -501,9 +506,9 @@ class TestModel8 extends CakeTestModel {
}
}
/**
- * Short description for class.
+ * TestModel9 class
*
- * @package cake.tests
+ * @package cake
* @subpackage cake.tests.cases.libs.model.datasources
*/
class TestModel9 extends CakeTestModel {
@@ -1136,11 +1141,10 @@ class ArticleFeatured2 extends CakeTestModel {
return $this->_schema;
}
}
-
/**
- * Short description for class.
+ * DboSourceTest class
*
- * @package cake.tests
+ * @package cake
* @subpackage cake.tests.cases.libs.model.datasources
*/
class DboSourceTest extends CakeTestCase {
@@ -3135,7 +3139,7 @@ class DboSourceTest extends CakeTestCase {
'fields' => null, 'order' => null, 'recursive' => null
));
$this->assertEqual($result, $expected);
-
+
$result = $this->testDb->query('findByFindBy', array('value'), $this->Model);
$expected = array('first', array(
'conditions' => array('TestModel.find_by' => 'value'),
@@ -3806,5 +3810,4 @@ class DboSourceTest extends CakeTestCase {
$this->assertNoPattern('/Took:/s', $contents);
}
}
-
?>
\ No newline at end of file
diff --git a/cake/tests/cases/libs/model/db_acl.test.php b/cake/tests/cases/libs/model/db_acl.test.php
index dc8fd24be..82d4d15ad 100644
--- a/cake/tests/cases/libs/model/db_acl.test.php
+++ b/cake/tests/cases/libs/model/db_acl.test.php
@@ -1,7 +1,7 @@
array('with' => 'DbPermissionTest'));
}
-
/**
-* Aco Test Wrapper
-*
-* @package cake.tests
-* @subpackage cake.tests.cases.libs.controller.components
-*/
+ * Aco Test Wrapper
+ *
+ * @package cake
+ * @subpackage cake.tests.cases.libs.controller.components
+ */
class DbAcoTest extends DbAclNodeTestBase {
/**
* name property
@@ -113,13 +109,12 @@ class DbAcoTest extends DbAclNodeTestBase {
*/
var $hasAndBelongsToMany = array('DbAroTest' => array('with' => 'DbPermissionTest'));
}
-
/**
-* Permission Test Wrapper
-*
-* @package cake.tests
-* @subpackage cake.tests.cases.libs.controller.components
-*/
+ * Permission Test Wrapper
+ *
+ * @package cake
+ * @subpackage cake.tests.cases.libs.controller.components
+ */
class DbPermissionTest extends CakeTestModel {
/**
* name property
@@ -151,11 +146,11 @@ class DbPermissionTest extends CakeTestModel {
var $belongsTo = array('DbAroTest' => array('foreignKey' => 'aro_id'), 'DbAcoTest' => array('foreignKey' => 'aco_id'));
}
/**
-* Short description for class.
-*
-* @package cake.tests
-* @subpackage cake.tests.cases.libs.controller.components
-*/
+ * DboActionTest class
+ *
+ * @package cake
+ * @subpackage cake.tests.cases.libs.controller.components
+ */
class DbAcoActionTest extends CakeTestModel {
/**
* name property
@@ -180,11 +175,11 @@ class DbAcoActionTest extends CakeTestModel {
var $belongsTo = array('DbAcoTest' => array('foreignKey' => 'aco_id'));
}
/**
-* Short description for class.
-*
-* @package cake.tests
-* @subpackage cake.tests.cases.libs.controller.components
-*/
+ * DbAroUserTest class
+ *
+ * @package cake
+ * @subpackage cake.tests.cases.libs.controller.components
+ */
class DbAroUserTest extends CakeTestModel {
/**
* name property
@@ -215,13 +210,12 @@ class DbAroUserTest extends CakeTestModel {
}
}
}
-
/**
-* Short description for class.
-*
-* @package cake.tests
-* @subpackage cake.tests.cases.libs.controller.components
-*/
+ * DbAclTest class
+ *
+ * @package cake
+ * @subpackage cake.tests.cases.libs.controller.components
+ */
class DbAclTest extends DbAcl {
/**
* construct method
@@ -237,9 +231,9 @@ class DbAclTest extends DbAcl {
}
}
/**
- * Short description for class.
+ * AclNodeTest class
*
- * @package cake.tests
+ * @package cake
* @subpackage cake.tests.cases.libs.controller.components.dbacl.models
*/
class AclNodeTest extends CakeTestCase {
diff --git a/cake/tests/cases/libs/model/model.test.php b/cake/tests/cases/libs/model/model.test.php
index 6c9760b81..a4845b77f 100644
--- a/cake/tests/cases/libs/model/model.test.php
+++ b/cake/tests/cases/libs/model/model.test.php
@@ -1,7 +1,7 @@
debug);
}
+/**
+ * endTest method
+ *
+ * @access public
+ * @return void
+ */
+ function endTest() {
+ ClassRegistry::flush();
+ }
/**
* testAutoConstructAssociations method
*
@@ -956,7 +963,6 @@ class ModelTest extends CakeTestCase {
$result = $Article->read(null, 2);
$this->assertEqual($result['Article']['title'], 'Staying alive');
}
-
/**
* testCreationOfEmptyRecord method
*
@@ -3182,7 +3188,6 @@ class ModelTest extends CakeTestCase {
Configure::write('Cache.check', $_back['check']);
Configure::write('Cache.disable', $_back['disable']);
}
-
/**
* testSaveAll method
*
@@ -3248,12 +3253,12 @@ class ModelTest extends CakeTestCase {
$expected = array('id' => '2', 'comment_id' => '7', 'attachment' => 'some_file.tgz', 'created' => $ts, 'updated' => $ts);
$this->assertEqual($result[6]['Attachment'], $expected);
}
-
/**
* Test SaveAll with Habtm relations
*
+ * @access public
* @return void
- **/
+ */
function testSaveAllHabtm() {
$this->loadFixtures('Article', 'Tag', 'Comment', 'User');
$data = array(
@@ -3279,7 +3284,12 @@ class ModelTest extends CakeTestCase {
$this->assertEqual(count($result['Comment']), 1);
$this->assertEqual(count($result['Comment'][0]['comment']['Article comment']), 1);
}
-
+/**
+ * Test SaveAll with Habtm relations and extra join table fields
+ *
+ * @access public
+ * @return void
+ */
function testSaveAllHabtmWithExtraJoinTableFields() {
$this->loadFixtures('Something', 'SomethingElse', 'JoinThing');
@@ -3753,7 +3763,6 @@ class ModelTest extends CakeTestCase {
);
$this->assertEqual($TestModel->validationErrors, $expected);
}
-
/**
* testSaveAllValidateFirst method
*
@@ -3929,7 +3938,6 @@ class ModelTest extends CakeTestCase {
$expected = array_fill(0, 1, 1);
$this->assertEqual($result, $expected);
}
-
/**
* testSaveWithCounterCacheScope method
*
@@ -4786,7 +4794,6 @@ class ModelTest extends CakeTestCase {
$expected = $TestModel->save($data);
$this->assertFalse($expected);
}
-
// function testBasicValidation() {
// $TestModel =& new ValidationTest();
// $TestModel->testing = true;
@@ -5537,7 +5544,6 @@ class ModelTest extends CakeTestCase {
$this->assertIdentical($result['DataTest']['count'], '0');
$this->assertIdentical($result['DataTest']['float'], '0');
}
-
/**
* testNonNumericHabtmJoinKey method
*
@@ -5827,7 +5833,6 @@ class ModelTest extends CakeTestCase {
$this->assertEqual($db2->fullTableName($TestModel, false), 'apples');
$this->assertEqual($db1->fullTableName($TestModel, false), 'apples');
}
-
/**
* testDynamicBehaviorAttachment method
*
@@ -5858,7 +5863,6 @@ class ModelTest extends CakeTestCase {
$this->assertEqual($TestModel->Behaviors->attached(), array());
$this->assertFalse(isset($TestModel->Behaviors->Tree));
}
-
/**
* Tests cross database joins. Requires $test and $test2 to both be set in DATABASE_CONFIG
* NOTE: When testing on MySQL, you must set 'persistent' => false on *both* database connections,
@@ -6477,7 +6481,12 @@ class ModelTest extends CakeTestCase {
$result = $Portfolio->ItemsPortfolio->find('all', array('conditions' => array('ItemsPortfolio.portfolio_id' => 1)));
$this->assertFalse($result);
}
-
+/**
+ * testDeleteArticleBLinks method
+ *
+ * @access public
+ * @return void
+ */
function testDeleteArticleBLinks() {
$this->loadFixtures('Article', 'ArticlesTag', 'Tag');
$TestModel =& new ArticleB();
@@ -6500,21 +6509,16 @@ class ModelTest extends CakeTestCase {
);
$this->assertEqual($result, $expected);
}
-
+/**
+ * testPkInHAbtmLinkModelArticleB
+ *
+ * @access public
+ * @return void
+ */
function testPkInHabtmLinkModelArticleB() {
$this->loadFixtures('Article', 'Tag');
$TestModel2 =& new ArticleB();
$this->assertEqual($TestModel2->ArticlesTag->primaryKey, 'article_id');
}
-/**
- * endTest method
- *
- * @access public
- * @return void
- */
- function endTest() {
- ClassRegistry::flush();
- }
}
-
-?>
+?>
\ No newline at end of file
diff --git a/cake/tests/cases/libs/model/models.php b/cake/tests/cases/libs/model/models.php
index 95170c748..8f1423e9c 100644
--- a/cake/tests/cases/libs/model/models.php
+++ b/cake/tests/cases/libs/model/models.php
@@ -1,7 +1,7 @@
Schema = new TestAppSchema();
}
+/**
+ * tearDown method
+ *
+ * @access public
+ * @return void
+ */
+ function tearDown() {
+ unset($this->Schema);
+ }
/**
* testSchemaName method
*
@@ -471,7 +479,7 @@ class CakeSchemaTest extends CakeTestCase {
function testSchemaCreateTable() {
$db =& ConnectionManager::getDataSource('test_suite');
$db->cacheSources = false;
-
+
$Schema =& new CakeSchema(array(
'connection' => 'test_suite',
'testdescribes' => array(
@@ -481,25 +489,16 @@ class CakeSchemaTest extends CakeTestCase {
),
));
$sql = $db->createSchema($Schema);
-
+
$col = $Schema->tables['testdescribes']['int_null'];
$col['name'] = 'int_null';
$column = $this->db->buildColumn($col);
$this->assertPattern('/' . preg_quote($column, '/') . '/', $sql);
-
+
$col = $Schema->tables['testdescribes']['int_not_null'];
$col['name'] = 'int_not_null';
$column = $this->db->buildColumn($col);
$this->assertPattern('/' . preg_quote($column, '/') . '/', $sql);
}
-/**
- * tearDown method
- *
- * @access public
- * @return void
- */
- function tearDown() {
- unset($this->Schema);
- }
}
?>
\ No newline at end of file
diff --git a/cake/tests/cases/libs/multibyte.test.php b/cake/tests/cases/libs/multibyte.test.php
index c97c40efc..68950cc78 100644
--- a/cake/tests/cases/libs/multibyte.test.php
+++ b/cake/tests/cases/libs/multibyte.test.php
@@ -1,7 +1,7 @@
methodCalls[] = array('methodWithOptionalParam' => array($param));
}
-
/**
* testPersist
*
@@ -250,24 +249,20 @@ class TestObject extends Object {
return $this->_persist($name, $return, $object, $type);
}
}
-
-
/**
- * ObjectTestModel
+ * ObjectTestModel class
*
- * @package cake.tests
+ * @package cake
* @subpackage cake.tests.cases.libs
*/
class ObjectTestModel extends CakeTestModel {
var $useTable = false;
var $name = 'ObjectTestModel';
}
-
-
/**
- * Object Test Class
+ * Object Test class
*
- * @package cake.tests
+ * @package cake
* @subpackage cake.tests.cases.libs
*/
class ObjectTest extends CakeTestCase {
@@ -286,6 +281,15 @@ class ObjectTest extends CakeTestCase {
function setUp() {
$this->object = new TestObject();
}
+/**
+ * tearDown method
+ *
+ * @access public
+ * @return void
+ */
+ function tearDown() {
+ unset($this->object);
+ }
/**
* testLog method
*
@@ -593,7 +597,6 @@ class ObjectTest extends CakeTestCase {
$_POST = $_tmp;
}
-
/**
* testCakeError
*
@@ -602,14 +605,5 @@ class ObjectTest extends CakeTestCase {
function testCakeError() {
}
-/**
- * tearDown method
- *
- * @access public
- * @return void
- */
- function tearDown() {
- unset($this->object);
- }
}
?>
\ No newline at end of file
diff --git a/cake/tests/cases/libs/overloadable.test.php b/cake/tests/cases/libs/overloadable.test.php
index 8e1d24b4f..5c0363ad5 100644
--- a/cake/tests/cases/libs/overloadable.test.php
+++ b/cake/tests/cases/libs/overloadable.test.php
@@ -1,7 +1,7 @@
skipif (true, 'OverloadableTest not implemented');
+ $this->skipif(true, 'OverloadableTest not implemented');
}
}
?>
\ No newline at end of file
diff --git a/cake/tests/cases/libs/router.test.php b/cake/tests/cases/libs/router.test.php
index 0af3648d9..7cbc98161 100644
--- a/cake/tests/cases/libs/router.test.php
+++ b/cake/tests/cases/libs/router.test.php
@@ -1,7 +1,7 @@
array(), 'named' => array(), 'plugin' => null, 'controller' => 'posts', 'action' => 'index');
$this->assertEqual($result, $expected);
}
-
/**
* Tests URL generation with flags and prefixes in and out of context
*
diff --git a/cake/tests/cases/libs/sanitize.test.php b/cake/tests/cases/libs/sanitize.test.php
index 31101445e..e564f9a92 100644
--- a/cake/tests/cases/libs/sanitize.test.php
+++ b/cake/tests/cases/libs/sanitize.test.php
@@ -1,7 +1,7 @@
assertEqual($result, $expected);
}
}
-
-?>
+?>
\ No newline at end of file
diff --git a/cake/tests/cases/libs/security.test.php b/cake/tests/cases/libs/security.test.php
index a04da4a44..4c2e97019 100644
--- a/cake/tests/cases/libs/security.test.php
+++ b/cake/tests/cases/libs/security.test.php
@@ -1,7 +1,7 @@
'hi');
$this->assertFalse(Set::check($set, 'a.b'));
}
-
/**
* Tests Set::flatten
*
@@ -2612,5 +2610,4 @@ class SetTest extends CakeTestCase {
$this->assertEqual($result, $expected);
}
}
-
?>
\ No newline at end of file
diff --git a/cake/tests/cases/libs/socket.test.php b/cake/tests/cases/libs/socket.test.php
index c409b1664..31ce57873 100644
--- a/cake/tests/cases/libs/socket.test.php
+++ b/cake/tests/cases/libs/socket.test.php
@@ -1,7 +1,7 @@
Socket = new CakeSocket();
}
+/**
+ * tearDown method
+ *
+ * @access public
+ * @return void
+ */
+ function tearDown() {
+ unset($this->Socket);
+ }
/**
* testConstruct method
*
@@ -165,14 +174,5 @@ class SocketTest extends CakeTestCase {
$anotherSocket->reset();
$this->assertEqual(array(), $anotherSocket->config);
}
-/**
- * tearDown method
- *
- * @access public
- * @return void
- */
- function tearDown() {
- unset($this->Socket);
- }
}
?>
\ No newline at end of file
diff --git a/cake/tests/cases/libs/string.test.php b/cake/tests/cases/libs/string.test.php
index eacdd181e..0bb0460ab 100644
--- a/cake/tests/cases/libs/string.test.php
+++ b/cake/tests/cases/libs/string.test.php
@@ -1,7 +1,7 @@
Reporter =& new CakeHtmlReporter();
}
/**
- * undocumented function
+ * testRunAllTests method
*
* @return void
* @access public
@@ -55,7 +61,7 @@ class TestManagerTest extends CakeTestCase {
$this->assertEqual(count($out), count($list));
}
/**
- * undocumented function
+ * testRunTestCase method
*
* @return void
* @access public
@@ -71,49 +77,44 @@ class TestManagerTest extends CakeTestCase {
$this->assertTrue($result);
}
/**
- * undocumented function
+ * testRunGroupTest method
*
* @return void
* @access public
*/
function testRunGroupTest() {
-
}
/**
- * undocumented function
+ * testAddTestCasesFromDirectory method
*
* @return void
* @access public
*/
function testAddTestCasesFromDirectory() {
-
}
/**
- * undocumented function
+ * testAddTestFile method
*
* @return void
* @access public
*/
function testAddTestFile() {
-
}
/**
- * undocumented function
+ * testGetTestCaseList method
*
* @return void
* @access public
*/
function testGetTestCaseList() {
-
}
/**
- * undocumented function
+ * testGetGroupTestList method
*
* @return void
* @access public
*/
function testGetGroupTestList() {
-
}
}
?>
\ No newline at end of file
diff --git a/cake/tests/cases/libs/validation.test.php b/cake/tests/cases/libs/validation.test.php
index 310b7a8ae..60b6a187b 100644
--- a/cake/tests/cases/libs/validation.test.php
+++ b/cake/tests/cases/libs/validation.test.php
@@ -1,7 +1,7 @@
Validation =& Validation::getInstance();
}
/**
@@ -1975,4 +1974,4 @@ class ValidationTestCase extends CakeTestCase {
// $this->assertTrue(Validation::file(TEST_CAKE_CORE_INCLUDE_PATH. 'VERSION.txt'));
// }
}
-?>
+?>
\ No newline at end of file
diff --git a/cake/tests/cases/libs/view/helper.test.php b/cake/tests/cases/libs/view/helper.test.php
index 7c3d7ea23..8cc1b811b 100644
--- a/cake/tests/cases/libs/view/helper.test.php
+++ b/cake/tests/cases/libs/view/helper.test.php
@@ -1,7 +1,7 @@
array('with' => 'HelperTestPostsTag'));
}
-
/**
* HelperTestComment class
*
@@ -156,11 +155,10 @@ class HelperTestPostsTag extends Model {
return $this->_schema;
}
}
-
/**
- * Short description for class.
+ * HelperTest class
*
- * @package cake.tests
+ * @package cake
* @subpackage cake.tests.cases.libs
*/
class HelperTest extends CakeTestCase {
@@ -180,6 +178,16 @@ class HelperTest extends CakeTestCase {
ClassRegistry::addObject('HelperTestComment', new HelperTestComment());
ClassRegistry::addObject('HelperTestTag', new HelperTestTag());
}
+/**
+ * tearDown method
+ *
+ * @access public
+ * @return void
+ */
+ function tearDown() {
+ unset($this->Helper, $this->View);
+ ClassRegistry::flush();
+ }
/**
* testFormFieldNameParsing method
*
@@ -355,22 +363,22 @@ class HelperTest extends CakeTestCase {
function testUrlConversion() {
$result = $this->Helper->url('/controller/action/1');
$this->assertEqual($result, '/controller/action/1');
-
+
$result = $this->Helper->url('/controller/action/1?one=1&two=2');
$this->assertEqual($result, '/controller/action/1?one=1&two=2');
-
+
$result = $this->Helper->url(array('controller' => 'posts', 'action' => 'index', 'page' => '1" onclick="alert(\'XSS\');"'));
$this->assertEqual($result, "/posts/index/page:1" onclick="alert('XSS');"");
-
+
$result = $this->Helper->url('/controller/action/1/param:this+one+more');
$this->assertEqual($result, '/controller/action/1/param:this+one+more');
-
+
$result = $this->Helper->url('/controller/action/1/param:this%20one%20more');
$this->assertEqual($result, '/controller/action/1/param:this%20one%20more');
-
+
$result = $this->Helper->url('/controller/action/1/param:%7Baround%20here%7D%5Bthings%5D%5Bare%5D%24%24');
$this->assertEqual($result, '/controller/action/1/param:%7Baround%20here%7D%5Bthings%5D%5Bare%5D%24%24');
-
+
$result = $this->Helper->url(array(
'controller' => 'posts', 'action' => 'index', 'param' => '%7Baround%20here%7D%5Bthings%5D%5Bare%5D%24%24'
));
@@ -518,15 +526,5 @@ class HelperTest extends CakeTestCase {
$result = $this->Helper->clean('<script>alert(document.cookie)</script>');
$this->assertEqual($result, '<script>alert(document.cookie)</script>');
}
-/**
- * tearDown method
- *
- * @access public
- * @return void
- */
- function tearDown() {
- unset($this->Helper, $this->View);
- ClassRegistry::flush();
- }
}
?>
\ No newline at end of file
diff --git a/cake/tests/cases/libs/view/helpers/ajax.test.php b/cake/tests/cases/libs/view/helpers/ajax.test.php
index 7b9073097..78060a7d8 100644
--- a/cake/tests/cases/libs/view/helpers/ajax.test.php
+++ b/cake/tests/cases/libs/view/helpers/ajax.test.php
@@ -1,7 +1,7 @@
codeBlocks[] = $parameter;
}
}
-
/**
- * Short description for class.
+ * AjaxTest class
*
- * @package cake.tests
+ * @package cake
* @subpackage cake.tests.cases.libs.view.helpers
*/
-class AjaxTest extends CakeTestCase {
+class AjaxHelperTest extends CakeTestCase {
/**
* Regexp for CDATA start block
*
@@ -168,6 +175,16 @@ class AjaxTest extends CakeTestCase {
ClassRegistry::addObject('view', $view);
ClassRegistry::addObject('PostAjaxTest', new PostAjaxTest());
}
+/**
+ * tearDown method
+ *
+ * @access public
+ * @return void
+ */
+ function tearDown() {
+ unset($this->Ajax);
+ ClassRegistry::flush();
+ }
/**
* testEvalScripts method
*
@@ -624,7 +641,6 @@ class AjaxTest extends CakeTestCase {
$this->assertPattern('/^';
$this->assertEqual($result, $expected);
From 377108f93092ef56e98375a73a4365d954e1b4aa Mon Sep 17 00:00:00 2001
From: mark_story
Date: Wed, 15 Apr 2009 02:29:50 +0000
Subject: [PATCH 46/67] Adding tests to show correct usage of form::create()
with querystring params. Closes #6278
git-svn-id: https://svn.cakephp.org/repo/branches/1.2.x.x@8144 3807eeeb-6ff5-0310-8944-8be069107fe0
---
cake/tests/cases/libs/view/helper.test.php | 6 +++++
.../cases/libs/view/helpers/form.test.php | 26 +++++++++++++++++++
2 files changed, 32 insertions(+)
diff --git a/cake/tests/cases/libs/view/helper.test.php b/cake/tests/cases/libs/view/helper.test.php
index 8cc1b811b..e380650b9 100644
--- a/cake/tests/cases/libs/view/helper.test.php
+++ b/cake/tests/cases/libs/view/helper.test.php
@@ -383,6 +383,12 @@ class HelperTest extends CakeTestCase {
'controller' => 'posts', 'action' => 'index', 'param' => '%7Baround%20here%7D%5Bthings%5D%5Bare%5D%24%24'
));
$this->assertEqual($result, "/posts/index/param:%7Baround%20here%7D%5Bthings%5D%5Bare%5D%24%24");
+
+ $result = $this->Helper->url(array(
+ 'controller' => 'posts', 'action' => 'index', 'page' => '1',
+ '?' => array('one' => 'value', 'two' => 'value', 'three' => 'purple')
+ ));
+ $this->assertEqual($result, "/posts/index/page:1?one=value&two=value&three=purple");
}
/**
* testFieldsWithSameName method
diff --git a/cake/tests/cases/libs/view/helpers/form.test.php b/cake/tests/cases/libs/view/helpers/form.test.php
index a310b1c57..cb486f694 100644
--- a/cake/tests/cases/libs/view/helpers/form.test.php
+++ b/cake/tests/cases/libs/view/helpers/form.test.php
@@ -4528,6 +4528,32 @@ class FormHelperTest extends CakeTestCase {
);
$this->assertTags($result, $expected);
}
+/**
+ * Test base form url when url param is passed with multiple parameters (&)
+ *
+ */
+ function testFormCreateQuerystringParams() {
+ $result = $this->Form->create('Contact', array(
+ 'type' => 'post',
+ 'escape' => false,
+ 'url' => array(
+ 'controller' => 'controller',
+ 'action' => 'action',
+ '?' => array('param1' => 'value1', 'param2' => 'value2')
+ )
+ ));
+ $expected = array(
+ 'form' => array(
+ 'id' => 'ContactAddForm',
+ 'method' => 'post',
+ 'action' => '/controller/action/?param1=value1¶m2=value2'
+ ),
+ 'fieldset' => array('style' => 'preg:/display\s*\:\s*none;\s*/'),
+ 'input' => array('type' => 'hidden', 'name' => '_method', 'value' => 'POST'),
+ '/fieldset'
+ );
+ $this->assertTags($result, $expected, true);
+ }
/**
* testGetFormCreate method
*
From 8db4fe682bf6f1e406943df9cd5a72582c36e919 Mon Sep 17 00:00:00 2001
From: mark_story
Date: Wed, 15 Apr 2009 17:18:01 +0000
Subject: [PATCH 47/67] Allowing name attribute to pass on to hidden field in
FormHelper::radio(). Fixes inconsistency with checkbox(). Test case added.
Fixes #6260
git-svn-id: https://svn.cakephp.org/repo/branches/1.2.x.x@8145 3807eeeb-6ff5-0310-8944-8be069107fe0
---
cake/libs/view/helpers/form.php | 2 +-
.../cases/libs/view/helpers/form.test.php | 20 +++++++++++++++++++
2 files changed, 21 insertions(+), 1 deletion(-)
diff --git a/cake/libs/view/helpers/form.php b/cake/libs/view/helpers/form.php
index 4ddf2e94c..2a4ff3420 100644
--- a/cake/libs/view/helpers/form.php
+++ b/cake/libs/view/helpers/form.php
@@ -934,7 +934,7 @@ class FormHelper extends AppHelper {
if (!isset($value) || $value === '') {
$hidden = $this->hidden($fieldName, array(
- 'id' => $attributes['id'] . '_', 'value' => ''
+ 'id' => $attributes['id'] . '_', 'value' => '', 'name' => $attributes['name']
));
}
$out = $hidden . join($inbetween, $out);
diff --git a/cake/tests/cases/libs/view/helpers/form.test.php b/cake/tests/cases/libs/view/helpers/form.test.php
index cb486f694..b06f2b7e9 100644
--- a/cake/tests/cases/libs/view/helpers/form.test.php
+++ b/cake/tests/cases/libs/view/helpers/form.test.php
@@ -2553,6 +2553,26 @@ class FormHelperTest extends CakeTestCase {
'/label'
);
$this->assertTags($result, $expected);
+
+
+ $result = $this->Form->radio('Model.field', array('option A', 'option B'), array('name' => 'data[Model][custom]'));
+ $expected = array(
+ 'fieldset' => array(),
+ 'legend' => array(),
+ 'Field',
+ '/legend',
+ 'input' => array('type' => 'hidden', 'name' => 'data[Model][custom]', 'value' => '', 'id' => 'ModelField_'),
+ array('input' => array('type' => 'radio', 'name' => 'data[Model][custom]', 'value' => '0', 'id' => 'ModelField0')),
+ array('label' => array('for' => 'ModelField0')),
+ 'option A',
+ '/label',
+ array('input' => array('type' => 'radio', 'name' => 'data[Model][custom]', 'value' => '1', 'id' => 'ModelField1')),
+ array('label' => array('for' => 'ModelField1')),
+ 'option B',
+ '/label',
+ '/fieldset'
+ );
+ $this->assertTags($result, $expected);
}
/**
* testSelect method
From bd7bd5d8917bc53aa06dae01dc09670f1c770121 Mon Sep 17 00:00:00 2001
From: "renan.saddam"
Date: Thu, 16 Apr 2009 18:12:01 +0000
Subject: [PATCH 48/67] Fixing issue when generating textarea with null value.
git-svn-id: https://svn.cakephp.org/repo/branches/1.2.x.x@8146 3807eeeb-6ff5-0310-8944-8be069107fe0
---
cake/libs/view/helper.php | 2 +-
cake/tests/cases/libs/view/helpers/form.test.php | 16 ++++++++++++----
2 files changed, 13 insertions(+), 5 deletions(-)
diff --git a/cake/libs/view/helper.php b/cake/libs/view/helper.php
index fc12c7ac2..076622c73 100644
--- a/cake/libs/view/helper.php
+++ b/cake/libs/view/helper.php
@@ -591,7 +591,7 @@ class Helper extends Overloadable {
if (is_array($result)) {
$view =& ClassRegistry::getObject('view');
- if (isset($result[$view->fieldSuffix])) {
+ if (array_key_exists($view->fieldSuffix, $result)) {
$result = $result[$view->fieldSuffix];
}
}
diff --git a/cake/tests/cases/libs/view/helpers/form.test.php b/cake/tests/cases/libs/view/helpers/form.test.php
index b06f2b7e9..9358df259 100644
--- a/cake/tests/cases/libs/view/helpers/form.test.php
+++ b/cake/tests/cases/libs/view/helpers/form.test.php
@@ -2553,8 +2553,8 @@ class FormHelperTest extends CakeTestCase {
'/label'
);
$this->assertTags($result, $expected);
-
-
+
+
$result = $this->Form->radio('Model.field', array('option A', 'option B'), array('name' => 'data[Model][custom]'));
$expected = array(
'fieldset' => array(),
@@ -4247,6 +4247,14 @@ class FormHelperTest extends CakeTestCase {
'/textarea',
);
$this->assertTags($result, $expected);
+
+ $this->Form->data['Model']['0']['OtherModel']['field'] = null;
+ $result = $this->Form->textarea('Model.0.OtherModel.field');
+ $expected = array(
+ 'textarea' => array('name' => 'data[Model][0][OtherModel][field]', 'id' => 'Model0OtherModelField'),
+ '/textarea'
+ );
+ $this->assertTags($result, $expected);
}
/**
* testTextAreaWithStupidCharacters method
@@ -4564,8 +4572,8 @@ class FormHelperTest extends CakeTestCase {
));
$expected = array(
'form' => array(
- 'id' => 'ContactAddForm',
- 'method' => 'post',
+ 'id' => 'ContactAddForm',
+ 'method' => 'post',
'action' => '/controller/action/?param1=value1¶m2=value2'
),
'fieldset' => array('style' => 'preg:/display\s*\:\s*none;\s*/'),
From bbfee7ba179a07e1f544d436ab8fa70d3fc599d1 Mon Sep 17 00:00:00 2001
From: davidpersson
Date: Fri, 17 Apr 2009 13:26:07 +0000
Subject: [PATCH 49/67] Updating Xml class to always use #document as the very
root node and to create a node below it if the root option is set. Adding
test. Fixes #6294
git-svn-id: https://svn.cakephp.org/repo/branches/1.2.x.x@8147 3807eeeb-6ff5-0310-8944-8be069107fe0
---
cake/libs/xml.php | 12 +++++++++---
cake/tests/cases/libs/xml.test.php | 20 ++++++++++++++++++++
2 files changed, 29 insertions(+), 3 deletions(-)
diff --git a/cake/libs/xml.php b/cake/libs/xml.php
index d7eab9f53..b4edf2fff 100644
--- a/cake/libs/xml.php
+++ b/cake/libs/xml.php
@@ -823,13 +823,19 @@ class Xml extends XmlNode {
$this->{$key} = $options[$key];
}
$this->__tags = $options['tags'];
- parent::__construct($options['root']);
+ parent::__construct('#document');
+
+ if ($options['root'] !== '#document') {
+ $Root = $this->createNode($options['root']);
+ } else {
+ $Root =& $this;
+ }
if (!empty($input)) {
if (is_string($input)) {
- $this->load($input);
+ $Root->load($input);
} elseif (is_array($input) || is_object($input)) {
- $this->append($input, $options);
+ $Root->append($input, $options);
}
}
// if (Configure::read('App.encoding') !== null) {
diff --git a/cake/tests/cases/libs/xml.test.php b/cake/tests/cases/libs/xml.test.php
index 4ee508a68..f452b54df 100644
--- a/cake/tests/cases/libs/xml.test.php
+++ b/cake/tests/cases/libs/xml.test.php
@@ -256,6 +256,26 @@ class XmlTest extends CakeTestCase {
$result = $xml->toString(array('header' => false, 'cdata' => false));
$this->assertEqual($expected, $result);
}
+/**
+ * Prove that serialization with a given root node works
+ * as expected.
+ *
+ * @access public
+ * @return void
+ * @link https://trac.cakephp.org/ticket/6294
+ */
+ function testArraySerializationWithRoot() {
+ $input = array(
+ array('Shirt' => array('id' => 1, 'color' => 'green')),
+ array('Shirt' => array('id' => 2, 'color' => 'blue')),
+ );
+ $expected = '';
+ $expected .= '';
+
+ $Xml = new Xml($input, array('root' => 'collection'));
+ $result = $Xml->toString(array('header' => false));
+ $this->assertEqual($expected, $result);
+ }
/**
* testCloneNode
*
From 6e91ee7ad4897cbcf1a2b65a1c5244953a3c4f8c Mon Sep 17 00:00:00 2001
From: mark_story
Date: Mon, 20 Apr 2009 07:36:26 +0000
Subject: [PATCH 50/67] Adding tests to disprove #6306
git-svn-id: https://svn.cakephp.org/repo/branches/1.2.x.x@8148 3807eeeb-6ff5-0310-8944-8be069107fe0
---
cake/tests/cases/libs/router.test.php | 11 ++++++++++-
1 file changed, 10 insertions(+), 1 deletion(-)
diff --git a/cake/tests/cases/libs/router.test.php b/cake/tests/cases/libs/router.test.php
index 7cbc98161..f0bfb1441 100644
--- a/cake/tests/cases/libs/router.test.php
+++ b/cake/tests/cases/libs/router.test.php
@@ -1316,9 +1316,18 @@ class RouterTest extends CakeTestCase {
$expected = '/others/edit/1';
$this->assertEqual($result, $expected);
- $result = Router::url(array('controller' => 'others', 'action' => 'edit', 1, 'protected' => true));;
+ $result = Router::url(array('controller' => 'others', 'action' => 'edit', 1, 'protected' => true));
$expected = '/protected/others/edit/1';
$this->assertEqual($result, $expected);
+
+ $result = Router::url(array('controller' => 'others', 'action' => 'edit', 1, 'protected' => true, 'page' => 1));
+ $expected = '/protected/others/edit/1/page:1';
+ $this->assertEqual($result, $expected);
+
+ Router::connectNamed(array('random'));
+ $result = Router::url(array('controller' => 'others', 'action' => 'edit', 1, 'protected' => true, 'random' => 'my-value'));
+ $expected = '/protected/others/edit/1/random:my-value';
+ $this->assertEqual($result, $expected);
}
/**
* testRemoveBase method
From 0cc3d5149f1e9f9442d46a2b37ea99dee9de422f Mon Sep 17 00:00:00 2001
From: gwoo
Date: Wed, 22 Apr 2009 16:05:13 +0000
Subject: [PATCH 51/67] fixes #6277, relaxing character length comparison for
UUID
git-svn-id: https://svn.cakephp.org/repo/branches/1.2.x.x@8149 3807eeeb-6ff5-0310-8944-8be069107fe0
---
cake/libs/model/model.php | 4 ++--
1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/cake/libs/model/model.php b/cake/libs/model/model.php
index 05b655975..0af80bafb 100644
--- a/cake/libs/model/model.php
+++ b/cake/libs/model/model.php
@@ -1210,7 +1210,7 @@ class Model extends Overloadable {
foreach ($this->_schema as $field => $properties) {
if ($this->primaryKey === $field) {
$fInfo = $this->_schema[$field];
- $isUUID = ($fInfo['length'] === 36 &&
+ $isUUID = ($fInfo['length'] == 36 &&
($fInfo['type'] === 'string' || $fInfo['type'] === 'binary')
);
if (empty($this->data[$this->alias][$this->primaryKey]) && $isUUID) {
@@ -1279,7 +1279,7 @@ class Model extends Overloadable {
));
$isUUID = !empty($this->{$join}->primaryKey) && (
- $this->{$join}->_schema[$this->{$join}->primaryKey]['length'] === 36 && (
+ $this->{$join}->_schema[$this->{$join}->primaryKey]['length'] == 36 && (
$this->{$join}->_schema[$this->{$join}->primaryKey]['type'] === 'string' ||
$this->{$join}->_schema[$this->{$join}->primaryKey]['type'] === 'binary'
)
From fd0c39fcc6f57551c6eec75895bb3af87f18af43 Mon Sep 17 00:00:00 2001
From: gwoo
Date: Wed, 22 Apr 2009 16:47:34 +0000
Subject: [PATCH 52/67] fixes #6293, Deleting non-existing record causes save()
to fail. Thanks to msadouni for the patch and test!
git-svn-id: https://svn.cakephp.org/repo/branches/1.2.x.x@8150 3807eeeb-6ff5-0310-8944-8be069107fe0
---
cake/libs/model/model.php | 2 +-
cake/tests/cases/libs/model/model.test.php | 42 ++++++++++++++++++----
2 files changed, 37 insertions(+), 7 deletions(-)
diff --git a/cake/libs/model/model.php b/cake/libs/model/model.php
index 0af80bafb..5238bb242 100644
--- a/cake/libs/model/model.php
+++ b/cake/libs/model/model.php
@@ -1853,7 +1853,7 @@ class Model extends Overloadable {
if ($this->getID() === false || $this->useTable === false) {
return false;
}
- if ($this->__exists !== null && $reset !== true) {
+ if (!empty($this->__exists) && $reset !== true) {
return $this->__exists;
}
$conditions = array($this->alias . '.' . $this->primaryKey => $this->getID());
diff --git a/cake/tests/cases/libs/model/model.test.php b/cake/tests/cases/libs/model/model.test.php
index 42170ae0c..595335172 100644
--- a/cake/tests/cases/libs/model/model.test.php
+++ b/cake/tests/cases/libs/model/model.test.php
@@ -63,10 +63,10 @@ class ModelTest extends CakeTestCase {
'core.dependency', 'core.story', 'core.stories_tag', 'core.cd', 'core.book', 'core.basket',
'core.overall_favorite', 'core.account', 'core.content', 'core.content_account',
'core.film_file', 'core.test_plugin_article', 'core.test_plugin_comment', 'core.uuiditem',
- 'core.counter_cache_user', 'core.counter_cache_post',
- 'core.counter_cache_user_nonstandard_primary_key',
- 'core.counter_cache_post_nonstandard_primary_key', 'core.uuidportfolio',
- 'core.uuiditems_uuidportfolio', 'core.uuiditems_uuidportfolio_numericid', 'core.fruit',
+ 'core.counter_cache_user', 'core.counter_cache_post',
+ 'core.counter_cache_user_nonstandard_primary_key',
+ 'core.counter_cache_post_nonstandard_primary_key', 'core.uuidportfolio',
+ 'core.uuiditems_uuidportfolio', 'core.uuiditems_uuidportfolio_numericid', 'core.fruit',
'core.fruits_uuid_tag', 'core.uuid_tag'
);
/**
@@ -3921,7 +3921,7 @@ class ModelTest extends CakeTestCase {
$this->assertEqual($users[1]['User']['post_count'], 2);
}
/**
- * Test counter cache with models that use a non-standard (i.e. not using 'id')
+ * Test counter cache with models that use a non-standard (i.e. not using 'id')
* as their primary key.
*
* @access public
@@ -3929,7 +3929,7 @@ class ModelTest extends CakeTestCase {
*/
function testCounterCacheWithNonstandardPrimaryKey() {
$this->loadFixtures(
- 'CounterCacheUserNonstandardPrimaryKey',
+ 'CounterCacheUserNonstandardPrimaryKey',
'CounterCachePostNonstandardPrimaryKey'
);
@@ -4027,6 +4027,36 @@ class ModelTest extends CakeTestCase {
array('Article' => array('id' => 1, 'title' => 'First Article' ))
);
$this->assertEqual($result, $expected);
+
+
+ // make sure deleting a non-existent record doesn't break save()
+ // ticket #6293
+ $this->loadFixtures('Uuid');
+ $Uuid =& new Uuid();
+ $data = array(
+ 'B607DAB9-88A2-46CF-B57C-842CA9E3B3B3',
+ '52C8865C-10EE-4302-AE6C-6E7D8E12E2C8',
+ '8208C7FE-E89C-47C5-B378-DED6C271F9B8');
+ foreach ($data as $id) {
+ $Uuid->save(array('id' => $id));
+ }
+ $Uuid->del('52C8865C-10EE-4302-AE6C-6E7D8E12E2C8');
+ $Uuid->del('52C8865C-10EE-4302-AE6C-6E7D8E12E2C8');
+ foreach ($data as $id) {
+ $Uuid->save(array('id' => $id));
+ }
+ $result = $Uuid->find('all', array(
+ 'conditions' => array('id' => $data),
+ 'fields' => array('id'),
+ 'order' => 'id'));
+ $expected = array(
+ array('Uuid' => array(
+ 'id' => '52C8865C-10EE-4302-AE6C-6E7D8E12E2C8')),
+ array('Uuid' => array(
+ 'id' => '8208C7FE-E89C-47C5-B378-DED6C271F9B8')),
+ array('Uuid' => array(
+ 'id' => 'B607DAB9-88A2-46CF-B57C-842CA9E3B3B3')));
+ $this->assertEqual($result, $expected);
}
/**
* testDeleteAll method
From 82cb895f505e3f50ef14473bc0d11310eadf0fc0 Mon Sep 17 00:00:00 2001
From: mark_story
Date: Thu, 23 Apr 2009 17:26:56 +0000
Subject: [PATCH 53/67] Correcting test case simulation. Closes #6211
git-svn-id: https://svn.cakephp.org/repo/branches/1.2.x.x@8151 3807eeeb-6ff5-0310-8944-8be069107fe0
---
.../cases/libs/controller/components/auth.test.php | 10 ++++++++--
1 file changed, 8 insertions(+), 2 deletions(-)
diff --git a/cake/tests/cases/libs/controller/components/auth.test.php b/cake/tests/cases/libs/controller/components/auth.test.php
index f10eae7a7..e65ec4c08 100644
--- a/cake/tests/cases/libs/controller/components/auth.test.php
+++ b/cake/tests/cases/libs/controller/components/auth.test.php
@@ -839,16 +839,22 @@ class AuthTest extends CakeTestCase {
$this->assertEqual($expected, $this->Controller->Session->read('Auth.redirect'));
// QueryString parameters
+ $_back = $_GET;
+ $_GET = array(
+ 'url' => '/posts/index/29?print=true&refer=menu',
+ 'print' => 'true',
+ 'refer' => 'menu'
+ );
$this->Controller->Session->del('Auth');
$url = '/posts/index/29?print=true&refer=menu';
- $this->Controller->params = Router::parse($url);
- $this->Controller->params['url']['url'] = Router::normalize($url);
+ $this->Controller->params = Dispatcher::parseParams($url);
$this->Controller->Auth->initialize($this->Controller);
$this->Controller->Auth->loginAction = array('controller' => 'AuthTest', 'action' => 'login');
$this->Controller->Auth->userModel = 'AuthUser';
$this->Controller->Auth->startup($this->Controller);
$expected = Router::normalize('posts/index/29?print=true&refer=menu');
$this->assertEqual($expected, $this->Controller->Session->read('Auth.redirect'));
+ $_GET = $_back;
//external authed action
$_SERVER['HTTP_REFERER'] = 'http://webmail.example.com/view/message';
From 650d1e7c789e6242add3872b6e9966838b6d2091 Mon Sep 17 00:00:00 2001
From: jperras
Date: Fri, 24 Apr 2009 18:20:51 +0000
Subject: [PATCH 54/67] Removing hard coded HELO hostname of 'cake' in
EmailComponent; better compliance with RFC-821 3.5. Test cases added. Fixes
#6264.
git-svn-id: https://svn.cakephp.org/repo/branches/1.2.x.x@8152 3807eeeb-6ff5-0310-8944-8be069107fe0
---
cake/libs/controller/components/email.php | 8 +-
.../libs/controller/components/email.test.php | 222 +++++++++++-------
2 files changed, 148 insertions(+), 82 deletions(-)
diff --git a/cake/libs/controller/components/email.php b/cake/libs/controller/components/email.php
index c8a368b3d..71b013a14 100644
--- a/cake/libs/controller/components/email.php
+++ b/cake/libs/controller/components/email.php
@@ -673,7 +673,13 @@ class EmailComponent extends Object{
return false;
}
- if (!$this->__smtpSend('HELO cake', '250')) {
+ if (isset($this->smtpOptions['host'])) {
+ $host = $this->smtpOptions['host'];
+ } else {
+ $host = env('HTTP_HOST');
+ }
+
+ if (!$this->__smtpSend("HELO {$host}", '250')) {
return false;
}
diff --git a/cake/tests/cases/libs/controller/components/email.test.php b/cake/tests/cases/libs/controller/components/email.test.php
index cfe806c06..4258c952c 100644
--- a/cake/tests/cases/libs/controller/components/email.test.php
+++ b/cake/tests/cases/libs/controller/components/email.test.php
@@ -25,6 +25,41 @@
* @license http://www.opensource.org/licenses/opengroup.php The Open Group Test Suite License
*/
App::import('Component', 'Email');
+/**
+ * EmailTestComponent class
+ *
+ * @package cake
+ * @subpackage cake.tests.cases.libs.controller.components
+ */
+class EmailTestComponent extends EmailComponent {
+/**
+ * smtpSend method override for testing
+ *
+ * @access public
+ * @return mixed
+ */
+ function smtpSend($data, $code = '250') {
+ return parent::__smtpSend($data, $code);
+ }
+/**
+ * Convenience setter method for testing.
+ *
+ * @access public
+ * @return void
+ */
+ function setConnectionSocket(&$socket) {
+ $this->__smtpConnection = $socket;
+ }
+/**
+ * Convenience getter method for testing.
+ *
+ * @access public
+ * @return mixed
+ */
+ function getConnectionSocket() {
+ return $this->__smtpConnection;
+ }
+}
/**
* EmailTestController class
*
@@ -52,7 +87,7 @@ class EmailTestController extends Controller {
* @var array
* @access public
*/
- var $components = array('Email');
+ var $components = array('EmailTest');
/**
* pageTitle property
*
@@ -98,7 +133,7 @@ class EmailComponentTest extends CakeTestCase {
@$this->Controller->Component->init($this->Controller);
set_error_handler('simpleTestErrorHandler');
- $this->Controller->Email->initialize($this->Controller, array());
+ $this->Controller->EmailTest->initialize($this->Controller, array());
ClassRegistry::addObject('view', new View($this->Controller));
$this->_viewPaths = Configure::read('viewPaths');
@@ -125,9 +160,9 @@ class EmailComponentTest extends CakeTestCase {
* @return void
*/
function testBadSmtpSend() {
- $this->Controller->Email->smtpOptions['host'] = 'blah';
- $this->Controller->Email->delivery = 'smtp';
- $this->assertFalse($this->Controller->Email->send('Should not work'));
+ $this->Controller->EmailTest->smtpOptions['host'] = 'blah';
+ $this->Controller->EmailTest->delivery = 'smtp';
+ $this->assertFalse($this->Controller->EmailTest->send('Should not work'));
}
/**
* testSmtpSend method
@@ -139,18 +174,18 @@ class EmailComponentTest extends CakeTestCase {
if (!$this->skipIf(!@fsockopen('localhost', 25), '%s No SMTP server running on localhost')) {
return;
}
- $this->Controller->Email->reset();
- $this->Controller->Email->to = 'postmaster@localhost';
- $this->Controller->Email->from = 'noreply@example.com';
- $this->Controller->Email->subject = 'Cake SMTP test';
- $this->Controller->Email->replyTo = 'noreply@example.com';
- $this->Controller->Email->template = null;
+ $this->Controller->EmailTest->reset();
+ $this->Controller->EmailTest->to = 'postmaster@localhost';
+ $this->Controller->EmailTest->from = 'noreply@example.com';
+ $this->Controller->EmailTest->subject = 'Cake SMTP test';
+ $this->Controller->EmailTest->replyTo = 'noreply@example.com';
+ $this->Controller->EmailTest->template = null;
- $this->Controller->Email->delivery = 'smtp';
- $this->assertTrue($this->Controller->Email->send('This is the body of the message'));
+ $this->Controller->EmailTest->delivery = 'smtp';
+ $this->assertTrue($this->Controller->EmailTest->send('This is the body of the message'));
- $this->Controller->Email->_debug = true;
- $this->Controller->Email->sendAs = 'text';
+ $this->Controller->EmailTest->_debug = true;
+ $this->Controller->EmailTest->sendAs = 'text';
$expect = <<Host: localhost
Port: 25
@@ -174,7 +209,7 @@ This is the body of the message
TEMPDOC;
- $this->assertTrue($this->Controller->Email->send('This is the body of the message'));
+ $this->assertTrue($this->Controller->EmailTest->send('This is the body of the message'));
$this->assertEqual($this->Controller->Session->read('Message.email.message'), $this->__osFix($expect));
}
/**
@@ -186,20 +221,22 @@ TEMPDOC;
function testAuthenticatedSmtpSend() {
$this->skipIf(!@fsockopen('localhost', 25), '%s No SMTP server running on localhost');
- $this->Controller->Email->reset();
- $this->Controller->Email->to = 'postmaster@localhost';
- $this->Controller->Email->from = 'noreply@example.com';
- $this->Controller->Email->subject = 'Cake SMTP test';
- $this->Controller->Email->replyTo = 'noreply@example.com';
- $this->Controller->Email->template = null;
- $this->Controller->Email->smtpOptions['username'] = 'test';
- $this->Controller->Email->smtpOptions['password'] = 'testing';
+ $this->Controller->EmailTest->reset();
+ $this->Controller->EmailTest->to = 'postmaster@localhost';
+ $this->Controller->EmailTest->from = 'noreply@example.com';
+ $this->Controller->EmailTest->subject = 'Cake SMTP test';
+ $this->Controller->EmailTest->replyTo = 'noreply@example.com';
+ $this->Controller->EmailTest->template = null;
+ $this->Controller->EmailTest->smtpOptions['username'] = 'test';
+ $this->Controller->EmailTest->smtpOptions['password'] = 'testing';
- $this->Controller->Email->delivery = 'smtp';
- $result = $this->Controller->Email->send('This is the body of the message');
- $code = substr($this->Controller->Email->smtpError, 0, 3);
+ $this->Controller->EmailTest->delivery = 'smtp';
+ $result = $this->Controller->EmailTest->send('This is the body of the message');
+ $code = substr($this->Controller->EmailTest->smtpError, 0, 3);
$this->skipIf(!$code, '%s Authentication not enabled on server');
- $this->assertTrue(!$result && $code == '535');
+
+ $this->assertFalse($result);
+ $this->assertEqual($code, '535');
}
/**
* testSendFormats method
@@ -208,13 +245,13 @@ TEMPDOC;
* @return void
*/
function testSendFormats() {
- $this->Controller->Email->reset();
- $this->Controller->Email->to = 'postmaster@localhost';
- $this->Controller->Email->from = 'noreply@example.com';
- $this->Controller->Email->subject = 'Cake SMTP test';
- $this->Controller->Email->replyTo = 'noreply@example.com';
- $this->Controller->Email->template = null;
- $this->Controller->Email->delivery = 'debug';
+ $this->Controller->EmailTest->reset();
+ $this->Controller->EmailTest->to = 'postmaster@localhost';
+ $this->Controller->EmailTest->from = 'noreply@example.com';
+ $this->Controller->EmailTest->subject = 'Cake SMTP test';
+ $this->Controller->EmailTest->replyTo = 'noreply@example.com';
+ $this->Controller->EmailTest->template = null;
+ $this->Controller->EmailTest->delivery = 'debug';
$message = <<To: postmaster@localhost
@@ -234,20 +271,20 @@ This is the body of the message
MSGBLOC;
- $this->Controller->Email->sendAs = 'text';
+ $this->Controller->EmailTest->sendAs = 'text';
$expect = str_replace('{CONTENTTYPE}', 'text/plain; charset=UTF-8', $message);
- $this->assertTrue($this->Controller->Email->send('This is the body of the message'));
+ $this->assertTrue($this->Controller->EmailTest->send('This is the body of the message'));
$this->assertEqual($this->Controller->Session->read('Message.email.message'), $this->__osFix($expect));
- $this->Controller->Email->sendAs = 'html';
+ $this->Controller->EmailTest->sendAs = 'html';
$expect = str_replace('{CONTENTTYPE}', 'text/html; charset=UTF-8', $message);
- $this->assertTrue($this->Controller->Email->send('This is the body of the message'));
+ $this->assertTrue($this->Controller->EmailTest->send('This is the body of the message'));
$this->assertEqual($this->Controller->Session->read('Message.email.message'), $this->__osFix($expect));
// TODO: better test for format of message sent?
- $this->Controller->Email->sendAs = 'both';
+ $this->Controller->EmailTest->sendAs = 'both';
$expect = str_replace('{CONTENTTYPE}', 'multipart/alternative; boundary="alt-"' . "\n", $message);
- $this->assertTrue($this->Controller->Email->send('This is the body of the message'));
+ $this->assertTrue($this->Controller->EmailTest->send('This is the body of the message'));
$this->assertEqual($this->Controller->Session->read('Message.email.message'), $this->__osFix($expect));
}
/**
@@ -257,13 +294,13 @@ MSGBLOC;
* @return void
*/
function testTemplates() {
- $this->Controller->Email->reset();
- $this->Controller->Email->to = 'postmaster@localhost';
- $this->Controller->Email->from = 'noreply@example.com';
- $this->Controller->Email->subject = 'Cake SMTP test';
- $this->Controller->Email->replyTo = 'noreply@example.com';
+ $this->Controller->EmailTest->reset();
+ $this->Controller->EmailTest->to = 'postmaster@localhost';
+ $this->Controller->EmailTest->from = 'noreply@example.com';
+ $this->Controller->EmailTest->subject = 'Cake SMTP test';
+ $this->Controller->EmailTest->replyTo = 'noreply@example.com';
- $this->Controller->Email->delivery = 'debug';
+ $this->Controller->EmailTest->delivery = 'debug';
$header = <<Controller->Email->layout = 'default';
- $this->Controller->Email->template = 'default';
+ $this->Controller->EmailTest->layout = 'default';
+ $this->Controller->EmailTest->template = 'default';
$text = <<Controller->Email->sendAs = 'text';
+ $this->Controller->EmailTest->sendAs = 'text';
$expect = '' . str_replace('{CONTENTTYPE}', 'text/plain; charset=UTF-8', $header) . $text . "\n" . '
';
- $this->assertTrue($this->Controller->Email->send('This is the body of the message'));
+ $this->assertTrue($this->Controller->EmailTest->send('This is the body of the message'));
$this->assertEqual($this->Controller->Session->read('Message.email.message'), $this->__osFix($expect));
- $this->Controller->Email->sendAs = 'html';
+ $this->Controller->EmailTest->sendAs = 'html';
$expect = '' . str_replace('{CONTENTTYPE}', 'text/html; charset=UTF-8', $header) . $html . "\n" . '
';
- $this->assertTrue($this->Controller->Email->send('This is the body of the message'));
+ $this->assertTrue($this->Controller->EmailTest->send('This is the body of the message'));
$this->assertEqual($this->Controller->Session->read('Message.email.message'), $this->__osFix($expect));
- $this->Controller->Email->sendAs = 'both';
+ $this->Controller->EmailTest->sendAs = 'both';
$expect = str_replace('{CONTENTTYPE}', 'multipart/alternative; boundary="alt-"' . "\n", $header);
$expect .= '--alt-' . "\n" . 'Content-Type: text/plain; charset=UTF-8' . "\n" . 'Content-Transfer-Encoding: 7bit' . "\n\n" . $text . "\n\n";
$expect .= '--alt-' . "\n" . 'Content-Type: text/html; charset=UTF-8' . "\n" . 'Content-Transfer-Encoding: 7bit' . "\n\n" . $html . "\n\n";
$expect = '' . $expect . '--alt---' . "\n\n" . '
';
- $this->assertTrue($this->Controller->Email->send('This is the body of the message'));
+ $this->assertTrue($this->Controller->EmailTest->send('This is the body of the message'));
$this->assertEqual($this->Controller->Session->read('Message.email.message'), $this->__osFix($expect));
$html = <<Controller->Email->sendAs = 'html';
+ $this->Controller->EmailTest->sendAs = 'html';
$expect = '' . str_replace('{CONTENTTYPE}', 'text/html; charset=UTF-8', $header) . $html . "\n" . '
';
- $this->assertTrue($this->Controller->Email->send('This is the body of the message', 'default', 'thin'));
+ $this->assertTrue($this->Controller->EmailTest->send('This is the body of the message', 'default', 'thin'));
$this->assertEqual($this->Controller->Session->read('Message.email.message'), $this->__osFix($expect));
return;
@@ -362,11 +399,34 @@ This email was sent using the CakePHP Framework, http://cakephp.org.
TEXTBLOC;
- $this->Controller->Email->sendAs = 'text';
+ $this->Controller->EmailTest->sendAs = 'text';
$expect = '' . str_replace('{CONTENTTYPE}', 'text/plain; charset=UTF-8', $header) . $text . "\n" . '
';
- $this->assertTrue($this->Controller->Email->send('This is the body of the message', 'wide', 'default'));
+ $this->assertTrue($this->Controller->EmailTest->send('This is the body of the message', 'wide', 'default'));
$this->assertEqual($this->Controller->Session->read('Message.email.message'), $this->__osFix($expect));
}
+/**
+ * testSmtpSendSocket method
+ *
+ * @access public
+ * @return void
+ */
+ function testSmtpSendSocket() {
+ $this->skipIf(!@fsockopen('localhost', 25), '%s No SMTP server running on localhost');
+
+ $this->Controller->EmailTest->reset();
+ $socket =& new CakeSocket(array_merge(array('protocol'=>'smtp'), $this->Controller->EmailTest->smtpOptions));
+ $this->Controller->EmailTest->setConnectionSocket($socket);
+
+ $this->assertTrue($this->Controller->EmailTest->getConnectionSocket());
+
+ $response = $this->Controller->EmailTest->smtpSend('HELO', '250');
+ $this->assertPattern('/501 Syntax: HELO hostname/', $this->Controller->EmailTest->smtpError);
+
+ $this->Controller->EmailTest->smtpError = null;
+ $response = $this->Controller->EmailTest->smtpSend('HELO somehostname', '250');
+ $this->assertNoPattern('/501 Syntax: HELO hostname/', $this->Controller->EmailTest->smtpError);
+
+ }
/**
* testSendDebug method
*
@@ -374,15 +434,15 @@ TEXTBLOC;
* @return void
*/
function testSendDebug() {
- $this->Controller->Email->reset();
- $this->Controller->Email->to = 'postmaster@localhost';
- $this->Controller->Email->from = 'noreply@example.com';
- $this->Controller->Email->subject = 'Cake SMTP test';
- $this->Controller->Email->replyTo = 'noreply@example.com';
- $this->Controller->Email->template = null;
+ $this->Controller->EmailTest->reset();
+ $this->Controller->EmailTest->to = 'postmaster@localhost';
+ $this->Controller->EmailTest->from = 'noreply@example.com';
+ $this->Controller->EmailTest->subject = 'Cake SMTP test';
+ $this->Controller->EmailTest->replyTo = 'noreply@example.com';
+ $this->Controller->EmailTest->template = null;
- $this->Controller->Email->delivery = 'debug';
- $this->assertTrue($this->Controller->Email->send('This is the body of the message'));
+ $this->Controller->EmailTest->delivery = 'debug';
+ $this->assertTrue($this->Controller->EmailTest->send('This is the body of the message'));
}
/**
* testContentStripping method
@@ -394,7 +454,7 @@ TEXTBLOC;
$content = "Previous content\n--alt-\nContent-TypeContent-Type:: text/html; charsetcharset==utf-8\nContent-Transfer-Encoding: 7bit";
$content .= "\n\nMy own html content
";
- $result = $this->Controller->Email->__strip($content, true);
+ $result = $this->Controller->EmailTest->__strip($content, true);
$expected = "Previous content\n--alt-\n text/html; utf-8\n 7bit\n\nMy own html content
";
$this->assertEqual($result, $expected);
}
@@ -405,28 +465,28 @@ TEXTBLOC;
* @return void
*/
function testMultibyte() {
- $this->Controller->Email->reset();
- $this->Controller->Email->to = 'postmaster@localhost';
- $this->Controller->Email->from = 'noreply@example.com';
- $this->Controller->Email->subject = 'هذه رسالة بعنوان طويل مرسل للمستلم';
- $this->Controller->Email->replyTo = 'noreply@example.com';
- $this->Controller->Email->template = null;
- $this->Controller->Email->delivery = 'debug';
+ $this->Controller->EmailTest->reset();
+ $this->Controller->EmailTest->to = 'postmaster@localhost';
+ $this->Controller->EmailTest->from = 'noreply@example.com';
+ $this->Controller->EmailTest->subject = 'هذه رسالة بعنوان طويل مرسل للمستلم';
+ $this->Controller->EmailTest->replyTo = 'noreply@example.com';
+ $this->Controller->EmailTest->template = null;
+ $this->Controller->EmailTest->delivery = 'debug';
$subject = '=?UTF-8?B?2YfYsNmHINix2LPYp9mE2Kkg2KjYudmG2YjYp9mGINi32YjZitmEINmF2LE=?=' . "\r\n" . ' =?UTF-8?B?2LPZhCDZhNmE2YXYs9iq2YTZhQ==?=';
- $this->Controller->Email->sendAs = 'text';
- $this->assertTrue($this->Controller->Email->send('This is the body of the message'));
+ $this->Controller->EmailTest->sendAs = 'text';
+ $this->assertTrue($this->Controller->EmailTest->send('This is the body of the message'));
preg_match('/Subject: (.*)Header:/s', $this->Controller->Session->read('Message.email.message'), $matches);
$this->assertEqual(trim($matches[1]), $subject);
- $this->Controller->Email->sendAs = 'html';
- $this->assertTrue($this->Controller->Email->send('This is the body of the message'));
+ $this->Controller->EmailTest->sendAs = 'html';
+ $this->assertTrue($this->Controller->EmailTest->send('This is the body of the message'));
preg_match('/Subject: (.*)Header:/s', $this->Controller->Session->read('Message.email.message'), $matches);
$this->assertEqual(trim($matches[1]), $subject);
- $this->Controller->Email->sendAs = 'both';
- $this->assertTrue($this->Controller->Email->send('This is the body of the message'));
+ $this->Controller->EmailTest->sendAs = 'both';
+ $this->assertTrue($this->Controller->EmailTest->send('This is the body of the message'));
preg_match('/Subject: (.*)Header:/s', $this->Controller->Session->read('Message.email.message'), $matches);
$this->assertEqual(trim($matches[1]), $subject);
}
From 97abf8477096fe5afae3319bab0ba5a916be217e Mon Sep 17 00:00:00 2001
From: jperras
Date: Sat, 25 Apr 2009 00:01:57 +0000
Subject: [PATCH 55/67] EmailComponent:: now is set to null after calling
EmailComponent::reset(). Test cases added; fixes #6314.
git-svn-id: https://svn.cakephp.org/repo/branches/1.2.x.x@8153 3807eeeb-6ff5-0310-8944-8be069107fe0
---
cake/libs/controller/components/email.php | 1 +
.../libs/controller/components/email.test.php | 82 +++++++++++++++++++
2 files changed, 83 insertions(+)
diff --git a/cake/libs/controller/components/email.php b/cake/libs/controller/components/email.php
index 71b013a14..90dc72055 100644
--- a/cake/libs/controller/components/email.php
+++ b/cake/libs/controller/components/email.php
@@ -345,6 +345,7 @@ class EmailComponent extends Object{
$this->bcc = array();
$this->subject = null;
$this->additionalParams = null;
+ $this->smtpError = null;
$this->__header = array();
$this->__boundary = null;
$this->__message = array();
diff --git a/cake/tests/cases/libs/controller/components/email.test.php b/cake/tests/cases/libs/controller/components/email.test.php
index 4258c952c..08f033aac 100644
--- a/cake/tests/cases/libs/controller/components/email.test.php
+++ b/cake/tests/cases/libs/controller/components/email.test.php
@@ -59,6 +59,51 @@ class EmailTestComponent extends EmailComponent {
function getConnectionSocket() {
return $this->__smtpConnection;
}
+/**
+ * Convenience setter for testing.
+ *
+ * @access public
+ * @return void
+ */
+ function setHeaders($headers) {
+ $this->__header += $headers;
+ }
+/**
+ * Convenience getter for testing.
+ *
+ * @access public
+ * @return array
+ */
+ function getHeaders() {
+ return $this->__header;
+ }
+/**
+ * Convenience setter for testing.
+ *
+ * @access public
+ * @return void
+ */
+ function setBoundary() {
+ $this->__createBoundary();
+ }
+/**
+ * Convenience getter for testing.
+ *
+ * @access public
+ * @return string
+ */
+ function getBoundary() {
+ return $this->__boundary;
+ }
+/**
+ * Convenience getter for testing.
+ *
+ * @access public
+ * @return string
+ */
+ function getMessage() {
+ return $this->__message;
+ }
}
/**
* EmailTestController class
@@ -490,6 +535,43 @@ TEXTBLOC;
preg_match('/Subject: (.*)Header:/s', $this->Controller->Session->read('Message.email.message'), $matches);
$this->assertEqual(trim($matches[1]), $subject);
}
+/**
+ * testReset method
+ *
+ * @access public
+ * @return void
+ */
+ function testReset() {
+ $this->Controller->EmailTest->template = 'test_template';
+ $this->Controller->EmailTest->to = 'test.recipient@example.com';
+ $this->Controller->EmailTest->from = 'test.sender@example.com';
+ $this->Controller->EmailTest->replyTo = 'test.replyto@example.com';
+ $this->Controller->EmailTest->return = 'test.return@example.com';
+ $this->Controller->EmailTest->cc = array('cc1@example.com', 'cc2@example.com');
+ $this->Controller->EmailTest->bcc = array('bcc1@example.com', 'bcc2@example.com');
+ $this->Controller->EmailTest->subject = 'Test subject';
+ $this->Controller->EmailTest->additionalParams = 'X-additional-header';
+ $this->Controller->EmailTest->delivery = 'smtp';
+ $this->Controller->EmailTest->smtpOptions['host'] = 'blah';
+
+ $this->assertFalse($this->Controller->EmailTest->send('Should not work'));
+
+ $this->Controller->EmailTest->reset();
+
+ $this->assertNull($this->Controller->EmailTest->template);
+ $this->assertNull($this->Controller->EmailTest->to);
+ $this->assertNull($this->Controller->EmailTest->from);
+ $this->assertNull($this->Controller->EmailTest->replyTo);
+ $this->assertNull($this->Controller->EmailTest->return);
+ $this->assertIdentical($this->Controller->EmailTest->cc, array());
+ $this->assertIdentical($this->Controller->EmailTest->bcc, array());
+ $this->assertNull($this->Controller->EmailTest->subject);
+ $this->assertNull($this->Controller->EmailTest->additionalParams);
+ $this->assertIdentical($this->Controller->EmailTest->getHeaders(), array());
+ $this->assertNull($this->Controller->EmailTest->getBoundary());
+ $this->assertIdentical($this->Controller->EmailTest->getMessage(), array());
+ $this->assertNull($this->Controller->EmailTest->smtpError);
+ }
/**
* osFix method
*
From 9ab6339392d8f08eed150db553d0faaf2f64dd99 Mon Sep 17 00:00:00 2001
From: gwoo
Date: Sat, 25 Apr 2009 01:06:46 +0000
Subject: [PATCH 56/67] fixes #6240, DboOracle: fix cache sources and php
version compatibility
git-svn-id: https://svn.cakephp.org/repo/branches/1.2.x.x@8154 3807eeeb-6ff5-0310-8944-8be069107fe0
---
cake/libs/model/datasources/dbo/dbo_oracle.php | 4 ++--
1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/cake/libs/model/datasources/dbo/dbo_oracle.php b/cake/libs/model/datasources/dbo/dbo_oracle.php
index d35b5900a..f7ec6f06e 100644
--- a/cake/libs/model/datasources/dbo/dbo_oracle.php
+++ b/cake/libs/model/datasources/dbo/dbo_oracle.php
@@ -454,6 +454,7 @@ class DboOracle extends DboSource {
while($r = $this->fetchRow()) {
$sources[] = strtolower($r[0]['name']);
}
+ parent::listSources($sources);
return $sources;
}
/**
@@ -834,8 +835,7 @@ class DboOracle extends DboSource {
switch($column) {
case 'date':
- $date = new DateTime($data);
- $data = $date->format('Y-m-d H:i:s');
+ $data = date('Y-m-d H:i:s', strtotime($data));
$data = "TO_DATE('$data', 'YYYY-MM-DD HH24:MI:SS')";
break;
case 'integer' :
From 8bb11e49d7fb1fb708caba36b3ede5c35e6f424a Mon Sep 17 00:00:00 2001
From: jperras
Date: Sat, 25 Apr 2009 01:17:21 +0000
Subject: [PATCH 57/67] Fixing counterCache behavior when updating an existing
record's counterScope value. Thanks for the patch, mattcurry. Fixes #6270.
git-svn-id: https://svn.cakephp.org/repo/branches/1.2.x.x@8155 3807eeeb-6ff5-0310-8944-8be069107fe0
---
cake/libs/model/model.php | 17 ++++++++---------
cake/tests/cases/libs/model/model.test.php | 4 ++++
2 files changed, 12 insertions(+), 9 deletions(-)
diff --git a/cake/libs/model/model.php b/cake/libs/model/model.php
index 5238bb242..1becede48 100644
--- a/cake/libs/model/model.php
+++ b/cake/libs/model/model.php
@@ -1374,16 +1374,15 @@ class Model extends Overloadable {
$conditions = ($recursive == 1) ? (array)$assoc['counterScope'] : array();
if (isset($keys['old'][$foreignKey])) {
- if ($keys['old'][$foreignKey] == $keys[$foreignKey]) {
- continue;
+ if ($keys['old'][$foreignKey] != $keys[$foreignKey]) {
+ $conditions[$fkQuoted] = $keys['old'][$foreignKey];
+ $count = intval($this->find('count', compact('conditions', 'recursive')));
+
+ $this->{$parent}->updateAll(
+ array($assoc['counterCache'] => $count),
+ array($this->{$parent}->escapeField() => $keys['old'][$foreignKey])
+ );
}
- $conditions[$fkQuoted] = $keys['old'][$foreignKey];
- $count = intval($this->find('count', compact('conditions', 'recursive')));
-
- $this->{$parent}->updateAll(
- array($assoc['counterCache'] => $count),
- array($this->{$parent}->escapeField() => $keys['old'][$foreignKey])
- );
}
$conditions[$fkQuoted] = $keys[$foreignKey];
diff --git a/cake/tests/cases/libs/model/model.test.php b/cake/tests/cases/libs/model/model.test.php
index 595335172..77149c1cc 100644
--- a/cake/tests/cases/libs/model/model.test.php
+++ b/cake/tests/cases/libs/model/model.test.php
@@ -3990,6 +3990,10 @@ class ModelTest extends CakeTestCase {
$TestModel2->saveField('published', true);
$result = $TestModel->findById(1);
$this->assertIdentical($result['Syfile']['item_count'], '2');
+
+ $TestModel2->save(array('id' => 1, 'syfile_id' => 1, 'published'=> false));
+ $result = $TestModel->findById(1);
+ $this->assertIdentical($result['Syfile']['item_count'], '1');
}
/**
* testDel method
From b68c78fc0f86f669027dc90cdc09dbde999ba4e3 Mon Sep 17 00:00:00 2001
From: mark_story
Date: Sat, 25 Apr 2009 02:16:05 +0000
Subject: [PATCH 58/67] Fixing lost querystring params when user request
without a session is performed. Test case updated. Fixes #6211
git-svn-id: https://svn.cakephp.org/repo/branches/1.2.x.x@8156 3807eeeb-6ff5-0310-8944-8be069107fe0
---
cake/libs/controller/components/auth.php | 5 +++++
cake/tests/cases/libs/controller/components/auth.test.php | 2 +-
2 files changed, 6 insertions(+), 1 deletion(-)
diff --git a/cake/libs/controller/components/auth.php b/cake/libs/controller/components/auth.php
index d2f2bede9..a8744ce25 100644
--- a/cake/libs/controller/components/auth.php
+++ b/cake/libs/controller/components/auth.php
@@ -337,6 +337,11 @@ class AuthComponent extends Object {
if (!$this->user()) {
if (!$this->RequestHandler->isAjax()) {
$this->Session->setFlash($this->authError, 'default', array(), 'auth');
+ if (!empty($controller->params['url']) && count($controller->params['url']) >= 2) {
+ $query = $controller->params['url'];
+ unset($query['url']);
+ $url .= Router::queryString($query, array());
+ }
$this->Session->write('Auth.redirect', $url);
$controller->redirect($loginAction);
return false;
diff --git a/cake/tests/cases/libs/controller/components/auth.test.php b/cake/tests/cases/libs/controller/components/auth.test.php
index e65ec4c08..3cdb25bb7 100644
--- a/cake/tests/cases/libs/controller/components/auth.test.php
+++ b/cake/tests/cases/libs/controller/components/auth.test.php
@@ -841,7 +841,7 @@ class AuthTest extends CakeTestCase {
// QueryString parameters
$_back = $_GET;
$_GET = array(
- 'url' => '/posts/index/29?print=true&refer=menu',
+ 'url' => '/posts/index/29',
'print' => 'true',
'refer' => 'menu'
);
From c8cf1a2c5bed17c6c24df5484a957abf354bde3a Mon Sep 17 00:00:00 2001
From: mark_story
Date: Tue, 28 Apr 2009 01:32:20 +0000
Subject: [PATCH 59/67] Updating __mergeVars to correctly merge parent and
child component configurations. Applied patch from 'neilcrookes'. Test case
added. Fixes #6325
git-svn-id: https://svn.cakephp.org/repo/branches/1.2.x.x@8157 3807eeeb-6ff5-0310-8944-8be069107fe0
---
cake/libs/controller/controller.php | 2 +-
.../cases/libs/controller/controller.test.php | 16 ++++++++++++++++
2 files changed, 17 insertions(+), 1 deletion(-)
diff --git a/cake/libs/controller/controller.php b/cake/libs/controller/controller.php
index 19a9aef76..5c33e1a49 100644
--- a/cake/libs/controller/controller.php
+++ b/cake/libs/controller/controller.php
@@ -393,7 +393,7 @@ class Controller extends Object {
if ($var === 'components') {
$normal = Set::normalize($this->{$var});
$app = Set::normalize($appVars[$var]);
- $this->{$var} = Set::merge($normal, $app);
+ $this->{$var} = Set::merge($app, $normal);
} else {
$this->{$var} = Set::merge($this->{$var}, array_diff($appVars[$var], $this->{$var}));
}
diff --git a/cake/tests/cases/libs/controller/controller.test.php b/cake/tests/cases/libs/controller/controller.test.php
index 53b1663ed..8c7b3204c 100644
--- a/cake/tests/cases/libs/controller/controller.test.php
+++ b/cake/tests/cases/libs/controller/controller.test.php
@@ -940,6 +940,22 @@ class ControllerTest extends CakeTestCase {
$this->assertTrue(isset($TestController->ControllerPost));
$this->assertTrue(isset($TestController->ControllerComment));
}
+/**
+ * test that options from child classes replace those in the parent classes.
+ *
+ * @access public
+ * @return void
+ **/
+ function testChildComponentOptionsSupercedeParents() {
+ if ($this->skipIf(defined('APP_CONTROLLER_EXISTS'), '%s Need a non-existent AppController')) {
+ return;
+ }
+ $TestController =& new TestController();
+ $expected = array('foo');
+ $TestController->components = array('Cookie' => $expected);
+ $TestController->constructClasses();
+ $this->assertEqual($TestController->components['Cookie'], $expected);
+ }
/**
* Ensure that __mergeVars is not being greedy and merging with
* AppController when you make an instance of Controller
From 9f15226e4605ba4b6c5ba918b64d7209ceb77540 Mon Sep 17 00:00:00 2001
From: nate
Date: Tue, 28 Apr 2009 13:23:37 +0000
Subject: [PATCH 60/67] Fixes #6318: Incorrect whitespace handling/parsing of
XML documents
git-svn-id: https://svn.cakephp.org/repo/branches/1.2.x.x@8158 3807eeeb-6ff5-0310-8944-8be069107fe0
---
cake/libs/xml.php | 3 ++-
cake/tests/cases/libs/xml.test.php | 24 ++++++++++++++++++++++++
2 files changed, 26 insertions(+), 1 deletion(-)
diff --git a/cake/libs/xml.php b/cake/libs/xml.php
index b4edf2fff..845068514 100644
--- a/cake/libs/xml.php
+++ b/cake/libs/xml.php
@@ -880,10 +880,11 @@ class Xml extends XmlNode {
*/
function parse() {
$this->__initParser();
+ $this->__rawData = trim($this->__rawData);
$this->__header = trim(str_replace(
a('<' . '?', '?' . '>'),
a('', ''),
- substr(trim($this->__rawData), 0, strpos($this->__rawData, "\n"))
+ substr($this->__rawData, 0, strpos($this->__rawData, '?' . '>'))
));
xml_parse_into_struct($this->__parser, $this->__rawData, $vals);
diff --git a/cake/tests/cases/libs/xml.test.php b/cake/tests/cases/libs/xml.test.php
index f452b54df..eec558641 100644
--- a/cake/tests/cases/libs/xml.test.php
+++ b/cake/tests/cases/libs/xml.test.php
@@ -389,6 +389,30 @@ class XmlTest extends CakeTestCase {
$result = $node->removeAttribute('missing');
$this->assertFalse($result);
}
+
+ /**
+ * Tests that XML documents with non-standard spacing (i.e. leading whitespace, whole document
+ * on one line) still parse properly.
+ *
+ * @return void
+ */
+ function testParsingWithNonStandardWhitespace() {
+ $raw = '1.0';
+ $array = array('Prices' => array('price' => 1.0));
+
+ $xml = new Xml($raw);
+ $this->assertEqual($xml->toArray(), $array);
+ $this->assertEqual($xml->__header, 'xml version="1.0" encoding="ISO-8859-1"');
+
+ $xml = new Xml(' ' . $raw);
+ $this->assertEqual($xml->toArray(), $array);
+ $this->assertEqual($xml->__header, 'xml version="1.0" encoding="ISO-8859-1"');
+
+ $xml = new Xml("\n" . $raw);
+ $this->assertEqual($xml->toArray(), $array);
+ $this->assertEqual($xml->__header, 'xml version="1.0" encoding="ISO-8859-1"');
+ }
+
/* Not implemented yet */
/* function testChildFilter() {
$input = array(
From 48386b791f61e1ce8f99e1198c09a36de3059635 Mon Sep 17 00:00:00 2001
From: "renan.saddam"
Date: Tue, 28 Apr 2009 22:20:04 +0000
Subject: [PATCH 61/67] Fixing cake_test_fixture and dbo_mssql tests. Refs
#6135.
git-svn-id: https://svn.cakephp.org/repo/branches/1.2.x.x@8159 3807eeeb-6ff5-0310-8944-8be069107fe0
---
.../cases/libs/cake_test_fixture.test.php | 4 +--
.../model/datasources/dbo/dbo_mssql.test.php | 29 +------------------
2 files changed, 3 insertions(+), 30 deletions(-)
diff --git a/cake/tests/cases/libs/cake_test_fixture.test.php b/cake/tests/cases/libs/cake_test_fixture.test.php
index 5e17ed25b..03a712a56 100644
--- a/cake/tests/cases/libs/cake_test_fixture.test.php
+++ b/cake/tests/cases/libs/cake_test_fixture.test.php
@@ -51,8 +51,8 @@ class CakeTestFixtureTestFixture extends CakeTestFixture {
*/
var $fields = array(
'id' => array('type' => 'integer', 'key' => 'primary'),
- 'name' => array('type' => 'text', 'length' => '255'),
- 'created' => array('type' => 'datetime'),
+ 'name' => array('type' => 'string', 'length' => '255'),
+ 'created' => array('type' => 'datetime')
);
/**
* Records property
diff --git a/cake/tests/cases/libs/model/datasources/dbo/dbo_mssql.test.php b/cake/tests/cases/libs/model/datasources/dbo/dbo_mssql.test.php
index d2c3411f7..319f2f134 100644
--- a/cake/tests/cases/libs/model/datasources/dbo/dbo_mssql.test.php
+++ b/cake/tests/cases/libs/model/datasources/dbo/dbo_mssql.test.php
@@ -36,32 +36,6 @@ require_once LIBS.'model'.DS.'datasources'.DS.'dbo'.DS.'dbo_mssql.php';
* @subpackage cake.tests.cases.libs.model.datasources.dbo
*/
class DboMssqlTestDb extends DboMssql {
-/**
- * Contructor
- *
- * @return void
- * @access public
- */
- function __construct() {
- }
-/**
- * connect method
- *
- * @return boolean
- * @access public
- */
- function connect() {
- $this->connected = true;
- return true;
- }
-/**
- * lastError method
- *
- * @return void
- * @access public
- */
- function lastError() {
- }
/**
* simulated property
*
@@ -346,10 +320,9 @@ class DboMssqlTest extends CakeTestCase {
* @access public
*/
function testUpdateAllSyntax() {
- $model = ClassRegistry::init('MssqlTestModel');
$fields = array('MssqlTestModel.client_id' => '[MssqlTestModel].[client_id] + 1');
$conditions = array('MssqlTestModel.updated <' => date('2009-01-01 00:00:00'));
- $this->db->update($model, $fields, null, $conditions);
+ $this->db->update($this->model, $fields, null, $conditions);
$result = $this->db->getLastQuery();
$this->assertNoPattern('/MssqlTestModel/', $result);
From 7eaf331213a13f6263d17e45d947dae6adad46e4 Mon Sep 17 00:00:00 2001
From: mark_story
Date: Wed, 29 Apr 2009 12:40:15 +0000
Subject: [PATCH 62/67] Updating doc block for FormHelper::input(). Fixes #6328
git-svn-id: https://svn.cakephp.org/repo/branches/1.2.x.x@8160 3807eeeb-6ff5-0310-8944-8be069107fe0
---
cake/libs/view/helpers/form.php | 3 ++-
1 file changed, 2 insertions(+), 1 deletion(-)
diff --git a/cake/libs/view/helpers/form.php b/cake/libs/view/helpers/form.php
index 2a4ff3420..5cff4816d 100644
--- a/cake/libs/view/helpers/form.php
+++ b/cake/libs/view/helpers/form.php
@@ -559,7 +559,8 @@ class FormHelper extends AppHelper {
/**
* Generates a form input element complete with label and wrapper div
*
- * Options - See each field type method for more information.
+ * Options - See each field type method for more information. Any options that are part of
+ * $attributes or $options for the different type methods can be included in $options for input().
*
* - 'type' - Force the type of widget you want. e.g. ```type => 'select'```
* - 'label' - control the label
From 975ddaa4be67da028ea9f34d774852ff2c98cb73 Mon Sep 17 00:00:00 2001
From: "renan.saddam"
Date: Wed, 29 Apr 2009 16:26:03 +0000
Subject: [PATCH 63/67] Fixes #6135: Primary Key detection and load record
fixtures on mssql. Tests added.
git-svn-id: https://svn.cakephp.org/repo/branches/1.2.x.x@8161 3807eeeb-6ff5-0310-8944-8be069107fe0
---
cake/libs/model/datasources/datasource.php | 9 ++-
cake/libs/model/datasources/dbo/dbo_mssql.php | 60 ++++++++++++--
.../model/datasources/dbo/dbo_mssql.test.php | 79 +++++++++++++------
3 files changed, 114 insertions(+), 34 deletions(-)
diff --git a/cake/libs/model/datasources/datasource.php b/cake/libs/model/datasources/datasource.php
index 6736f62a6..4fa8fba2e 100644
--- a/cake/libs/model/datasources/datasource.php
+++ b/cake/libs/model/datasources/datasource.php
@@ -241,13 +241,14 @@ class DataSource extends Object {
if ($this->cacheSources === false) {
return null;
}
- if (isset($this->__descriptions[$model->tablePrefix . $model->table])) {
- return $this->__descriptions[$model->tablePrefix . $model->table];
+ $table = $this->fullTableName($model, false);
+ if (isset($this->__descriptions[$table])) {
+ return $this->__descriptions[$table];
}
- $cache = $this->__cacheDescription($model->tablePrefix . $model->table);
+ $cache = $this->__cacheDescription($table);
if ($cache !== null) {
- $this->__descriptions[$model->tablePrefix . $model->table] =& $cache;
+ $this->__descriptions[$table] =& $cache;
return $cache;
}
return null;
diff --git a/cake/libs/model/datasources/dbo/dbo_mssql.php b/cake/libs/model/datasources/dbo/dbo_mssql.php
index 88938ba3b..c1bbd9e9c 100644
--- a/cake/libs/model/datasources/dbo/dbo_mssql.php
+++ b/cake/libs/model/datasources/dbo/dbo_mssql.php
@@ -221,7 +221,7 @@ class DboMssql extends DboSource {
'null' => (strtoupper($column[0]['Null']) == 'YES'),
'default' => preg_replace("/^[(]{1,2}'?([^')]*)?'?[)]{1,2}$/", "$1", $column[0]['Default']),
'length' => intval($column[0]['Length']),
- 'key' => ($column[0]['Key'] == '1')
+ 'key' => ($column[0]['Key'] == '1') ? 'primary' : false
);
if ($fields[$field]['default'] === 'null') {
$fields[$field]['default'] = null;
@@ -341,17 +341,18 @@ class DboMssql extends DboSource {
if (!empty($values)) {
$fields = array_combine($fields, $values);
}
+ $primaryKey = $this->_getPrimaryKey($model);
- if (array_key_exists($model->primaryKey, $fields)) {
- if (empty($fields[$model->primaryKey])) {
- unset($fields[$model->primaryKey]);
+ if (array_key_exists($primaryKey, $fields)) {
+ if (empty($fields[$primaryKey])) {
+ unset($fields[$primaryKey]);
} else {
- $this->_execute("SET IDENTITY_INSERT " . $this->fullTableName($model) . " ON");
+ $this->_execute('SET IDENTITY_INSERT ' . $this->fullTableName($model) . ' ON');
}
}
$result = parent::create($model, array_keys($fields), array_values($fields));
- if (array_key_exists($model->primaryKey, $fields) && !empty($fields[$model->primaryKey])) {
- $this->_execute("SET IDENTITY_INSERT " . $this->fullTableName($model) . " OFF");
+ if (array_key_exists($primaryKey, $fields) && !empty($fields[$primaryKey])) {
+ $this->_execute('SET IDENTITY_INSERT ' . $this->fullTableName($model) . ' OFF');
}
return $result;
}
@@ -631,6 +632,29 @@ class DboMssql extends DboSource {
return false;
}
}
+/**
+ * Inserts multiple values into a table
+ *
+ * @param string $table
+ * @param string $fields
+ * @param array $values
+ * @access protected
+ */
+ function insertMulti($table, $fields, $values) {
+ $primaryKey = $this->_getPrimaryKey($table);
+ $hasPrimaryKey = $primaryKey != null && (
+ (is_array($fields) && in_array($primaryKey, $fields)
+ || (is_string($fields) && strpos($fields, $this->startQuote . $primaryKey . $this->endQuote) !== false))
+ );
+
+ if ($hasPrimaryKey) {
+ $this->_execute('SET IDENTITY_INSERT ' . $this->fullTableName($table) . ' ON');
+ }
+ parent::insertMulti($table, $fields, $values);
+ if ($hasPrimaryKey) {
+ $this->_execute('SET IDENTITY_INSERT ' . $this->fullTableName($table) . ' OFF');
+ }
+ }
/**
* Generate a database-native column schema string
*
@@ -680,5 +704,27 @@ class DboMssql extends DboSource {
}
return $join;
}
+/**
+ * Makes sure it will return the primary key
+ *
+ * @param mixed $model
+ * @access protected
+ * @return string
+ */
+ function _getPrimaryKey($model) {
+ if (is_object($model)) {
+ $schema = $model->schema();
+ } else {
+ $schema = $this->describe($model);
+ }
+
+ foreach ($schema as $field => $props) {
+ if (isset($props['key']) && $props['key'] == 'primary') {
+ return $field;
+ }
+ }
+
+ return null;
+ }
}
?>
\ No newline at end of file
diff --git a/cake/tests/cases/libs/model/datasources/dbo/dbo_mssql.test.php b/cake/tests/cases/libs/model/datasources/dbo/dbo_mssql.test.php
index 319f2f134..c92a67e9d 100644
--- a/cake/tests/cases/libs/model/datasources/dbo/dbo_mssql.test.php
+++ b/cake/tests/cases/libs/model/datasources/dbo/dbo_mssql.test.php
@@ -94,6 +94,16 @@ class DboMssqlTestDb extends DboMssql {
function getLastQuery() {
return $this->simulated[count($this->simulated) - 1];
}
+/**
+ * getPrimaryKey method
+ *
+ * @param mixed $model
+ * @access public
+ * @return void
+ */
+ function getPrimaryKey($model) {
+ return parent::_getPrimaryKey($model);
+ }
}
/**
* MssqlTestModel class
@@ -116,6 +126,32 @@ class MssqlTestModel extends Model {
* @access public
*/
var $useTable = false;
+/**
+ * _schema property
+ *
+ * @var array
+ * @access protected
+ */
+ var $_schema = array(
+ 'id' => array('type' => 'integer', 'null' => '', 'default' => '', 'length' => '8', 'key' => 'primary'),
+ 'client_id' => array('type' => 'integer', 'null' => '', 'default' => '0', 'length' => '11'),
+ 'name' => array('type' => 'string', 'null' => '', 'default' => '', 'length' => '255'),
+ 'login' => array('type' => 'string', 'null' => '', 'default' => '', 'length' => '255'),
+ 'passwd' => array('type' => 'string', 'null' => '1', 'default' => '', 'length' => '255'),
+ 'addr_1' => array('type' => 'string', 'null' => '1', 'default' => '', 'length' => '255'),
+ 'addr_2' => array('type' => 'string', 'null' => '1', 'default' => '', 'length' => '25'),
+ 'zip_code' => array('type' => 'string', 'null' => '1', 'default' => '', 'length' => '155'),
+ 'city' => array('type' => 'string', 'null' => '1', 'default' => '', 'length' => '155'),
+ 'country' => array('type' => 'string', 'null' => '1', 'default' => '', 'length' => '155'),
+ 'phone' => array('type' => 'string', 'null' => '1', 'default' => '', 'length' => '155'),
+ 'fax' => array('type' => 'string', 'null' => '1', 'default' => '', 'length' => '155'),
+ 'url' => array('type' => 'string', 'null' => '1', 'default' => '', 'length' => '255'),
+ 'email' => array('type' => 'string', 'null' => '1', 'default' => '', 'length' => '155'),
+ 'comments' => array('type' => 'text', 'null' => '1', 'default' => '', 'length' => ''),
+ 'last_login'=> array('type' => 'datetime', 'null' => '1', 'default' => '', 'length' => ''),
+ 'created' => array('type' => 'date', 'null' => '1', 'default' => '', 'length' => ''),
+ 'updated' => array('type' => 'datetime', 'null' => '1', 'default' => '', 'length' => null)
+ );
/**
* find method
*
@@ -143,33 +179,14 @@ class MssqlTestModel extends Model {
return $conditions;
}
/**
- * schema method
+ * setSchema method
*
+ * @param array $schema
* @access public
* @return void
*/
- function schema() {
- $this->_schema = array(
- 'id' => array('type' => 'integer', 'null' => '', 'default' => '', 'length' => '8'),
- 'client_id' => array('type' => 'integer', 'null' => '', 'default' => '0', 'length' => '11'),
- 'name' => array('type' => 'string', 'null' => '', 'default' => '', 'length' => '255'),
- 'login' => array('type' => 'string', 'null' => '', 'default' => '', 'length' => '255'),
- 'passwd' => array('type' => 'string', 'null' => '1', 'default' => '', 'length' => '255'),
- 'addr_1' => array('type' => 'string', 'null' => '1', 'default' => '', 'length' => '255'),
- 'addr_2' => array('type' => 'string', 'null' => '1', 'default' => '', 'length' => '25'),
- 'zip_code' => array('type' => 'string', 'null' => '1', 'default' => '', 'length' => '155'),
- 'city' => array('type' => 'string', 'null' => '1', 'default' => '', 'length' => '155'),
- 'country' => array('type' => 'string', 'null' => '1', 'default' => '', 'length' => '155'),
- 'phone' => array('type' => 'string', 'null' => '1', 'default' => '', 'length' => '155'),
- 'fax' => array('type' => 'string', 'null' => '1', 'default' => '', 'length' => '155'),
- 'url' => array('type' => 'string', 'null' => '1', 'default' => '', 'length' => '255'),
- 'email' => array('type' => 'string', 'null' => '1', 'default' => '', 'length' => '155'),
- 'comments' => array('type' => 'text', 'null' => '1', 'default' => '', 'length' => ''),
- 'last_login'=> array('type' => 'datetime', 'null' => '1', 'default' => '', 'length' => ''),
- 'created' => array('type' => 'date', 'null' => '1', 'default' => '', 'length' => ''),
- 'updated' => array('type' => 'datetime', 'null' => '1', 'default' => '', 'length' => null)
- );
- return $this->_schema;
+ function setSchema($schema) {
+ $this->_schema = $schema;
}
}
/**
@@ -329,5 +346,21 @@ class DboMssqlTest extends CakeTestCase {
$this->assertPattern('/^UPDATE \[mssql_test_models\]/', $result);
$this->assertPattern('/SET \[client_id\] = \[client_id\] \+ 1/', $result);
}
+/**
+ * testGetPrimaryKey method
+ *
+ * @return void
+ * @access public
+ */
+ function testGetPrimaryKey() {
+ $result = $this->db->getPrimaryKey($this->model);
+ $this->assertEqual($result, 'id');
+
+ $schema = $this->model->schema();
+ unset($schema['id']['key']);
+ $this->model->setSchema($schema);
+ $result = $this->db->getPrimaryKey($this->model);
+ $this->assertNull($result);
+ }
}
?>
\ No newline at end of file
From f25cf632066cc840cabf6e915258e0e040285bef Mon Sep 17 00:00:00 2001
From: "renan.saddam"
Date: Wed, 29 Apr 2009 16:39:42 +0000
Subject: [PATCH 64/67] Adding missing test from last commit.
git-svn-id: https://svn.cakephp.org/repo/branches/1.2.x.x@8162 3807eeeb-6ff5-0310-8944-8be069107fe0
---
.../model/datasources/dbo/dbo_mssql.test.php | 31 +++++++++++++++++++
1 file changed, 31 insertions(+)
diff --git a/cake/tests/cases/libs/model/datasources/dbo/dbo_mssql.test.php b/cake/tests/cases/libs/model/datasources/dbo/dbo_mssql.test.php
index c92a67e9d..1cd3268fa 100644
--- a/cake/tests/cases/libs/model/datasources/dbo/dbo_mssql.test.php
+++ b/cake/tests/cases/libs/model/datasources/dbo/dbo_mssql.test.php
@@ -362,5 +362,36 @@ class DboMssqlTest extends CakeTestCase {
$result = $this->db->getPrimaryKey($this->model);
$this->assertNull($result);
}
+/**
+ * testInsertMulti
+ *
+ * @return void
+ * @access public
+ */
+ function testInsertMulti() {
+ $fields = array('id', 'name', 'login');
+ $values = array('(1, \'Larry\', \'PhpNut\')', '(2, \'Renan\', \'renan.saddam\')');
+ $this->db->simulated = array();
+ $this->db->insertMulti($this->model, $fields, $values);
+ $result = $this->db->simulated;
+ $expected = array(
+ 'SET IDENTITY_INSERT [mssql_test_models] ON',
+ 'INSERT INTO [mssql_test_models] ([id], [name], [login]) VALUES (1, \'Larry\', \'PhpNut\')',
+ 'INSERT INTO [mssql_test_models] ([id], [name], [login]) VALUES (2, \'Renan\', \'renan.saddam\')',
+ 'SET IDENTITY_INSERT [mssql_test_models] OFF'
+ );
+ $this->assertEqual($result, $expected);
+
+ $fields = array('name', 'login');
+ $values = array('(\'Larry\', \'PhpNut\')', '(\'Renan\', \'renan.saddam\')');
+ $this->db->simulated = array();
+ $this->db->insertMulti($this->model, $fields, $values);
+ $result = $this->db->simulated;
+ $expected = array(
+ 'INSERT INTO [mssql_test_models] ([name], [login]) VALUES (\'Larry\', \'PhpNut\')',
+ 'INSERT INTO [mssql_test_models] ([name], [login]) VALUES (\'Renan\', \'renan.saddam\')'
+ );
+ $this->assertEqual($result, $expected);
+ }
}
?>
\ No newline at end of file
From cf3f92c402a79baa04e831fa83a84871745f05d5 Mon Sep 17 00:00:00 2001
From: mark_story
Date: Thu, 30 Apr 2009 23:38:14 +0000
Subject: [PATCH 65/67] Updating testsuite console to search $pluginPaths for
plugins. Fixing readability of help in 80 col displays. Fixes #6329.
git-svn-id: https://svn.cakephp.org/repo/branches/1.2.x.x@8163 3807eeeb-6ff5-0310-8944-8be069107fe0
---
cake/console/libs/testsuite.php | 50 +++++++++++++++++++--------------
1 file changed, 29 insertions(+), 21 deletions(-)
diff --git a/cake/console/libs/testsuite.php b/cake/console/libs/testsuite.php
index 72cefbcc2..b11a7ea11 100644
--- a/cake/console/libs/testsuite.php
+++ b/cake/console/libs/testsuite.php
@@ -156,30 +156,30 @@ class TestSuiteShell extends Shell {
function help() {
$this->out('Usage: ');
$this->out("\tcake testsuite category test_type file");
- $this->out("\t\t - category - \"app\", \"core\" or name of a plugin");
- $this->out("\t\t - test_type - \"case\", \"group\" or \"all\"");
- $this->out("\t\t - test_file - file name with folder prefix and without the (test|group).php suffix");
+ $this->out("\t\t- category - \"app\", \"core\" or name of a plugin");
+ $this->out("\t\t- test_type - \"case\", \"group\" or \"all\"");
+ $this->out("\t\t- test_file - file name with folder prefix and without the (test|group).php suffix");
$this->out('');
$this->out('Examples: ');
- $this->out("\t\t cake testsuite app all");
- $this->out("\t\t cake testsuite core all");
+ $this->out("\t\tcake testsuite app all");
+ $this->out("\t\tcake testsuite core all");
$this->out('');
- $this->out("\t\t cake testsuite app case behaviors/debuggable");
- $this->out("\t\t cake testsuite app case models/my_model");
- $this->out("\t\t cake testsuite app case controllers/my_controller");
+ $this->out("\t\tcake testsuite app case behaviors/debuggable");
+ $this->out("\t\tcake testsuite app case models/my_model");
+ $this->out("\t\tcake testsuite app case controllers/my_controller");
$this->out('');
- $this->out("\t\t cake testsuite core case file");
- $this->out("\t\t cake testsuite core case router");
- $this->out("\t\t cake testsuite core case set");
+ $this->out("\t\tcake testsuite core case file");
+ $this->out("\t\tcake testsuite core case router");
+ $this->out("\t\tcake testsuite core case set");
$this->out('');
- $this->out("\t\t cake testsuite app group mygroup");
- $this->out("\t\t cake testsuite core group acl");
- $this->out("\t\t cake testsuite core group socket");
+ $this->out("\t\tcake testsuite app group mygroup");
+ $this->out("\t\tcake testsuite core group acl");
+ $this->out("\t\tcake testsuite core group socket");
$this->out('');
- $this->out("\t\t cake testsuite bugs case models/bug // for the plugin 'bugs' and its test case 'bug'");
- $this->out("\t\t cake testsuite bugs group bug // for the plugin bugs and its test group 'bug'");
- $this->out("\t\t cake testsuite bugs_me case models/bug // for the plugin 'bugs_me' and its test case 'bug'");
- $this->out("\t\t cake testsuite bugs_me group bug // for the plugin bugs_me and its test group 'bug'");
+ $this->out("\t\tcake testsuite bugs case models/bug");
+ $this->out("\t\t // for the plugin 'bugs' and its test case 'models/bug'");
+ $this->out("\t\tcake testsuite bugs group bug");
+ $this->out("\t\t // for the plugin bugs and its test group 'bug'");
$this->out('');
$this->out('Code Coverage Analysis: ');
$this->out("\n\nAppend 'cov' to any of the above in order to enable code coverage analysis");
@@ -312,11 +312,19 @@ class TestSuiteShell extends Shell {
);
if (array_key_exists($category, $paths)) {
- $folder = $paths[$category];
+ $folder = $paths[$category] . 'tests';
} else {
- $folder = APP.'plugins'.DS.Inflector::underscore($category).DS;
+ $scoredCategory = Inflector::underscore($category);
+ $folder = APP . 'plugins' . DS . $scoredCategory . DS;
+ $pluginPaths = Configure::read('pluginPaths');
+ foreach ($pluginPaths as $path) {
+ if (file_exists($path . $scoredCategory . DS . 'tests')) {
+ $folder = $path . $scoredCategory . DS . 'tests';
+ break;
+ }
+ }
}
- return $folder.'tests';
+ return $folder;
}
/**
* Sets some get vars needed for TestManager
From 38b7a34a8e74aeb7324febde4d10a9b87854bb83 Mon Sep 17 00:00:00 2001
From: gwoo
Date: Fri, 1 May 2009 08:24:24 -0700
Subject: [PATCH 66/67] adding gitignore with "vendors"
---
.gitignore | 1 +
1 file changed, 1 insertion(+)
create mode 100644 .gitignore
diff --git a/.gitignore b/.gitignore
new file mode 100644
index 000000000..1562dcf95
--- /dev/null
+++ b/.gitignore
@@ -0,0 +1 @@
+vendors
\ No newline at end of file
From 5cf96a077a6b0e85969d71ebbd19f9d1414e3eb5 Mon Sep 17 00:00:00 2001
From: gwoo
Date: Fri, 1 May 2009 10:52:14 -0700
Subject: [PATCH 67/67] adding app/tmp to gitignore
---
.gitignore | 1 +
1 file changed, 1 insertion(+)
diff --git a/.gitignore b/.gitignore
index 1562dcf95..cfc5c7a4b 100644
--- a/.gitignore
+++ b/.gitignore
@@ -1 +1,2 @@
+app/tmp
vendors
\ No newline at end of file