diff options
author | Bharat Mediratta <bharat@menalto.com> | 2008-11-01 10:47:00 +0000 |
---|---|---|
committer | Bharat Mediratta <bharat@menalto.com> | 2008-11-01 10:47:00 +0000 |
commit | 60fbea6fd000569210641588888c010b50c9c8e6 (patch) | |
tree | ae81808b4cde116f69dbe3a47a71e6e408c7e5a6 | |
parent | 5a3731d0c6e846c926e233109359632afaacacdb (diff) |
Add first test; this verifies that we leave the ?> off at the end of PHP files.
-rw-r--r-- | core/tests/File_Structure_Test.php | 46 |
1 files changed, 46 insertions, 0 deletions
diff --git a/core/tests/File_Structure_Test.php b/core/tests/File_Structure_Test.php new file mode 100644 index 00000000..d0749062 --- /dev/null +++ b/core/tests/File_Structure_Test.php @@ -0,0 +1,46 @@ +<?php +/** + * Gallery - a web based photo album viewer and editor + * Copyright (C) 2000-2008 Bharat Mediratta + * + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation; either version 2 of the License, or (at + * your option) any later version. + * + * This program is distributed in the hope that it will be useful, but + * WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + * General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program; if not, write to the Free Software + * Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston, MA 02110-1301, USA. + */ + +class File_Structure_Test extends Unit_Test_Case { + public function no_trailing_closing_php_tag_test() { + $dir = new GalleryCodeFilterIterator( + new RecursiveIteratorIterator(new RecursiveDirectoryIterator(DOCROOT))); + foreach ($dir as $file) { + if (preg_match('/(\?\>\s*)$/', file_get_contents($file), $matches)) { + $this->assert_true(false, "$file ends in a trailing ?>"); + } + } + } +} + +class GalleryCodeFilterIterator extends FilterIterator { + public function accept() { + // Skip anything that we didn't write + $path_name = $this->getInnerIterator()->getPathName(); + return !(strstr($path_name, ".svn") || + substr($path_name, -1, 1) == "~" || + strstr($path_name, SYSPATH) !== false || + strstr($path_name, MODPATH . 'forge') !== false || + strstr($path_name, MODPATH . 'unit_test') !== false || + strstr($path_name, MODPATH . 'mptt') !== false || + strstr($path_name, DOCROOT . 'var') !== false || + strstr($path_name, DOCROOT . 'test') !== false); + } +} |