getPathname())) { $this->assert_false( preg_match('/\?\>\s*$/', file_get_contents($file)), "{$file->getPathname()} ends in ?>"); } } } public function view_files_correct_suffix_test() { $dir = new GalleryCodeFilterIterator( new RecursiveIteratorIterator(new RecursiveDirectoryIterator(DOCROOT))); foreach ($dir as $file) { if ($file->getFilename() == 'kohana_unit_test.php') { // Exception: this file must be named accordingly for the test framework continue; } if (strpos($file, "views")) { $this->assert_true( preg_match("#/views/.*?(\.html|mrss)\.php$#", $file->getPathname()), "{$file->getPathname()} should end in .html.php or mrss.php"); } } } public function no_windows_line_endings_test() { $dir = new GalleryCodeFilterIterator( new RecursiveIteratorIterator(new RecursiveDirectoryIterator(DOCROOT))); foreach ($dir as $file) { if (preg_match("/\.(php|css|html|js)$/", $file)) { foreach (file($file) as $line) { $this->assert_true(substr($line, -2) != "\r\n", "$file has windows style line endings"); } } } } public function code_files_start_with_gallery_preamble_test() { $dir = new GalleryCodeFilterIterator( new RecursiveIteratorIterator(new RecursiveDirectoryIterator(DOCROOT))); $expected = $this->_get_preamble(__FILE__); foreach ($dir as $file) { if (preg_match("/views/", $file->getPathname())) { // The preamble for views is a single line that prevents direct script access $lines = file($file->getPathname()); $this->assert_equal( "\n", $lines[0], "in file: {$file->getPathname()}"); } else if (preg_match("|\.php$|", $file->getPathname())) { $actual = $this->_get_preamble($file->getPathname()); if ($file->getPathName() == DOCROOT . "index.php") { // index.php allows direct access, so modify our expectations for the first line $index_expected = $expected; $index_expected[0] = "assert_equal($index_expected, $actual, "in file: {$file->getPathname()}"); } else { // We expect the full preamble in regular PHP files $actual = $this->_get_preamble($file->getPathname()); $this->assert_equal($expected, $actual, "in file: {$file->getPathname()}"); } } } } public function no_tabs_in_our_code_test() { $dir = new GalleryCodeFilterIterator( new RecursiveIteratorIterator(new RecursiveDirectoryIterator(DOCROOT))); $incorrect = array(); foreach ($dir as $file) { if (substr($file->getFilename(), -4) == ".php") { $this->assert_false( preg_match('/\t/', file_get_contents($file)), "{$file->getPathname()} has tabs in it"); } } } private function _get_preamble($file) { $lines = file($file); $copy = array(); for ($i = 0; $i < count($lines); $i++) { $copy[] = rtrim($lines[$i]); if (!strncmp($lines[$i], ' */', 3)) { return $copy; } } return $copy; } } class GalleryCodeFilterIterator extends FilterIterator { public function accept() { // Skip anything that we didn't write $path_name = $this->getInnerIterator()->getPathName(); return !(strpos($path_name, ".svn") || substr($path_name, -1, 1) == "~" || strpos($path_name, SYSPATH) !== false || strpos($path_name, MODPATH . 'forge') !== false || strpos($path_name, MODPATH . 'unit_test') !== false || strpos($path_name, MODPATH . 'mptt') !== false || strpos($path_name, MODPATH . 'kodoc') !== false || strpos($path_name, MODPATH . 'user/libraries/PasswordHash') !== false || strpos($path_name, DOCROOT . 'var') !== false || strpos($path_name, DOCROOT . 'test') !== false); } }