Skip to content
Snippets Groups Projects
Select Git revision
  • 88fc7dbc3e7596a19b38fa93d0630665fae18b4c
  • 3.9 default
  • develop
  • 6.0
  • 5.0
  • 4.0
  • scrutinizer-patch-4
  • scrutinizer-patch-3
  • scrutinizer-patch-2
  • scrutinizer-patch-1
  • 3.7
  • 3.8
  • 3.6
  • 3.9_backported
  • 3.8_backported
  • 3.7_backported
  • 3.5
  • 3.6_backported
  • 3.5_backported
  • 3.4
  • 3.3_backported
  • 6.0.4
  • 6.0.3
  • 5.0.7
  • 6.0.2
  • 6.0.1
  • 5.0.6
  • 6.0.0
  • 5.0.5
  • 6.0.0-rc
  • 5.0.4
  • 6.0.0-beta
  • 5.0.3
  • 4.0.6
  • 5.0.2
  • 5.0.1
  • 4.0.5
  • 5.0.0
  • 4.0.4
  • 5.0.0-rc2
  • 5.0.0-rc1
41 results

CodingPhpTest.php

Blame
  • user avatar
    Laurent Destailleur authored
    88fc7dbc
    History
    CodingPhpTest.php 5.59 KiB
    <?php
    /* Copyright (C) 2013 Laurent Destailleur  <eldy@users.sourceforge.net>
     *
     * 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 3 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, see <http://www.gnu.org/licenses/>.
     * or see http://www.gnu.org/
     */
    
    /**
     *      \file       test/phpunit/SqlTest.php
     *      \ingroup    test
     *      \brief      PHPUnit test
     *      \remarks    To run this script as CLI:  phpunit filename.php
     */
    
    global $conf,$user,$langs,$db;
    //define('TEST_DB_FORCE_TYPE','mysql');	// This is to force using mysql driver
    //require_once 'PHPUnit/Autoload.php';
    require_once dirname(__FILE__).'/../../htdocs/master.inc.php';
    require_once dirname(__FILE__).'/../../htdocs/core/lib/security.lib.php';
    require_once dirname(__FILE__).'/../../htdocs/core/lib/security2.lib.php';
    
    if (! defined('NOREQUIREUSER'))  define('NOREQUIREUSER','1');
    if (! defined('NOREQUIREDB'))    define('NOREQUIREDB','1');
    if (! defined('NOREQUIRESOC'))   define('NOREQUIRESOC','1');
    if (! defined('NOREQUIRETRAN'))  define('NOREQUIRETRAN','1');
    if (! defined('NOCSRFCHECK'))    define('NOCSRFCHECK','1');
    if (! defined('NOTOKENRENEWAL')) define('NOTOKENRENEWAL','1');
    if (! defined('NOREQUIREMENU'))  define('NOREQUIREMENU','1'); // If there is no menu to show
    if (! defined('NOREQUIREHTML'))  define('NOREQUIREHTML','1'); // If we don't need to load the html.form.class.php
    if (! defined('NOREQUIREAJAX'))  define('NOREQUIREAJAX','1');
    if (! defined("NOLOGIN"))        define("NOLOGIN",'1');       // If this page is public (can be called outside logged session)
    
    if (empty($user->id))
    {
        print "Load permissions for admin user nb 1\n";
        $user->fetch(1);
        $user->getrights();
    }
    $conf->global->MAIN_DISABLE_ALL_MAILS=1;
    
    
    /**
     * Class for PHPUnit tests
     *
     * @backupGlobals disabled
     * @backupStaticAttributes enabled
     * @remarks	backupGlobals must be disabled to have db,conf,user and lang not erased.
     */
    class CodingPhpTest extends PHPUnit_Framework_TestCase
    {
        protected $savconf;
        protected $savuser;
        protected $savlangs;
        protected $savdb;
    
        /**
         * Constructor
         * We save global variables into local variables
         *
         * @return SecurityTest
         */
        function __construct()
        {
            //$this->sharedFixture
            global $conf,$user,$langs,$db;
            $this->savconf=$conf;
            $this->savuser=$user;
            $this->savlangs=$langs;
            $this->savdb=$db;
    
            print __METHOD__." db->type=".$db->type." user->id=".$user->id;
            //print " - db ".$db->db;
            print "\n";
        }
    
        // Static methods
        public static function setUpBeforeClass()
        {
            global $conf,$user,$langs,$db;
            $db->begin(); // This is to have all actions inside a transaction even if test launched without suite.
    
            print __METHOD__."\n";
        }
    
        // tear down after class
        public static function tearDownAfterClass()
        {
            global $conf,$user,$langs,$db;
            $db->rollback();
    
            print __METHOD__."\n";
        }
    
        /**
         * Init phpunit tests
         *
         * @return  void
         */
        protected function setUp()
        {
            global $conf,$user,$langs,$db;
            $conf=$this->savconf;
            $user=$this->savuser;
            $langs=$this->savlangs;
            $db=$this->savdb;
    
            print __METHOD__."\n";
        }
    
        /**
         * End phpunit tests
         *
         * @return  void
         */
        protected function tearDown()
        {
            print __METHOD__."\n";
        }
    
        /**
         * testSql
         *
         * @return string
         */
        public function testPHP()
        {
            global $conf,$user,$langs,$db;
            $conf=$this->savconf;
            $user=$this->savuser;
            $langs=$this->savlangs;
            $db=$this->savdb;
    
            include_once DOL_DOCUMENT_ROOT.'/core/lib/files.lib.php';
            $filesarray = dol_dir_list(DOL_DOCUMENT_ROOT, 'files', 1, '\.php', null, 'fullname');
    
            foreach($filesarray as $key => $file) 
            {
                if (preg_match('/\/htdocs\/includes\//', $file['fullname'])) continue;
                if (preg_match('/\/htdocs\/custom\//', $file['fullname'])) continue;
                if (preg_match('/\/htdocs\/dolimed/', $file['fullname'])) continue;
                if (preg_match('/\/htdocs\/nltechno/', $file['fullname'])) continue;
                if (preg_match('/\/htdocs\/teclib/', $file['fullname'])) continue;
                
                print 'Check php file '.$file['fullname']."\n";
                $filecontent=file_get_contents($file['fullname']);
                
                $ok=true;
                $matches=array();
                preg_match_all('/=\s*\'"\s*\.\s*\$this->(....)/', $filecontent, $matches, PREG_SET_ORDER);
                foreach($matches as $key => $val)
                {
                    if ($val[1] != 'db->' && $val[1] != 'esca') 
                    {
                        $ok=false;
                        break;
                    }
                    //if ($reg[0] != 'db') $ok=false;
                }
                //print __METHOD__." Result for checking we don't have non escaped string in sql requests for file ".$file."\n";
                $this->assertTrue($ok, 'Found non escaped string in building of a sql request '.$file['fullname'].' ('.$val[0].'). Bad.');
                //exit;
            }
    
            return;
        }
    
    }