Skip to content
Snippets Groups Projects
Select Git revision
  • e2f9864f423a1977014c6e1268ea62f3f8bce4e7
  • 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

FactureTest.php

Blame
  • user avatar
    Regis Houssin authored
    Fix: avoid errors with PHPUnit/Autoload.php
    e2f9864f
    History
    FactureTest.php 6.75 KiB
    <?php
    /* Copyright (C) 2010 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 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
     */
    
    /**
     *      \file       test/phpunit/FactureTest.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/compta/facture/class/facture.class.php';
    
    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;
    
    
    /**
     *
     * @xcovers DoliDb
     * @xcovers User
     * @xcovers Translate
     * @xcovers Conf
     * @xcovers Interfaces
     * @xcovers CommonObject
     * @xcovers Facture
     * @xcovers FactureLigne
     * @xcovers ModeleNumRefFactures
     * @xcovers InterfaceLogevents
     * @xcovers InterfaceActionsAuto
     * @xcovers InterfaceLdapsynchro
     * @xcovers InterfaceNotification
     * @xcovers InterfacePhenixsynchro
     * @xcovers InterfacePropalWorkflow
     * @xcovers InterfaceWebcalsynchro
     *
     * @backupGlobals disabled
     * @backupStaticAttributes enabled
     * @remarks	backupGlobals must be disabled to have db,conf,user and lang not erased.
     */
    class FactureTest extends PHPUnit_Framework_TestCase
    {
    	protected $savconf;
    	protected $savuser;
    	protected $savlangs;
    	protected $savdb;
    
    	/**
    	 * Constructor
    	 * We save global variables into local variables
    	 *
    	 * @return FactureTest
    	 */
    	function FactureTest()
    	{
    		//$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";
        }
        public static function tearDownAfterClass()
        {
        	global $conf,$user,$langs,$db;
    		$db->rollback();
    
    		print __METHOD__."\n";
        }
    
    	/**
    	 */
        protected function setUp()
        {
        	global $conf,$user,$langs,$db;
    		$conf=$this->savconf;
    		$user=$this->savuser;
    		$langs=$this->savlangs;
    		$db=$this->savdb;
    
    		print __METHOD__."\n";
        }
    	/**
    	 */
        protected function tearDown()
        {
        	print __METHOD__."\n";
        }
    
        /**
         */
        public function testFactureCreate()
        {
        	global $conf,$user,$langs,$db;
    		$conf=$this->savconf;
    		$user=$this->savuser;
    		$langs=$this->savlangs;
    		$db=$this->savdb;
    
    		$localobject=new Facture($this->savdb);
        	$localobject->initAsSpecimen();
        	$result=$localobject->create($user);
    
        	$this->assertLessThan($result, 0);
        	print __METHOD__." result=".$result."\n";
        	return $result;
        }
    
        /**
         * @depends	testFactureCreate
         * The depends says test is run only if previous is ok
         */
        public function testFactureFetch($id)
        {
        	global $conf,$user,$langs,$db;
    		$conf=$this->savconf;
    		$user=$this->savuser;
    		$langs=$this->savlangs;
    		$db=$this->savdb;
    
    		$localobject=new Facture($this->savdb);
        	$result=$localobject->fetch($id);
    
        	$this->assertLessThan($result, 0);
        	print __METHOD__." id=".$id." result=".$result."\n";
        	return $localobject;
        }
    
        /**
         * @depends	testFactureFetch
         * The depends says test is run only if previous is ok
         */
        public function testFactureUpdate($localobject)
        {
        	global $conf,$user,$langs,$db;
    		$conf=$this->savconf;
    		$user=$this->savuser;
    		$langs=$this->savlangs;
    		$db=$this->savdb;
    
    		$localobject->note='New note after update';
        	$result=$localobject->update($user);
    
        	print __METHOD__." id=".$localobject->id." result=".$result."\n";
        	$this->assertLessThan($result, 0);
        	return $localobject;
        }
    
        /**
         * @depends	testFactureUpdate
         * The depends says test is run only if previous is ok
         */
        public function testFactureValid($localobject)
        {
        	global $conf,$user,$langs,$db;
    		$conf=$this->savconf;
    		$user=$this->savuser;
    		$langs=$this->savlangs;
    		$db=$this->savdb;
    
        	$result=$localobject->validate($user);
        	print __METHOD__." id=".$localobject->id." result=".$result."\n";
    
        	$this->assertLessThan($result, 0);
        	return $localobject;
        }
    
       /**
         * @depends testFactureValid
         * The depends says test is run only if previous is ok
         */
        public function testFactureOther($localobject)
        {
            global $conf,$user,$langs,$db;
            $conf=$this->savconf;
            $user=$this->savuser;
            $langs=$this->savlangs;
            $db=$this->savdb;
    
            /*$result=$localobject->setstatus(0);
            print __METHOD__." id=".$localobject->id." result=".$result."\n";
            $this->assertLessThan($result, 0);
            */
    
            $localobject->info($localobject->id);
            print __METHOD__." localobject->date_creation=".$localobject->date_creation."\n";
            $this->assertNotEquals($localobject->date_creation, '');
    
            return $localobject->id;
        }
    
        /**
         * @depends	testFactureOther
         * The depends says test is run only if previous is ok
         */
        public function testFactureDelete($id)
        {
        	global $conf,$user,$langs,$db;
    		$conf=$this->savconf;
    		$user=$this->savuser;
    		$langs=$this->savlangs;
    		$db=$this->savdb;
    
    		$localobject=new Facture($this->savdb);
        	$result=$localobject->fetch($id);
    		$result=$localobject->delete($id);
    
    		print __METHOD__." id=".$id." result=".$result."\n";
        	$this->assertLessThan($result, 0);
        	return $result;
        }
    
        /**
         *
         */
        /*public function testVerifyNumRef()
        {
        	global $conf,$user,$langs,$db;
    		$conf=$this->savconf;
    		$user=$this->savuser;
    		$langs=$this->savlangs;
    		$db=$this->savdb;
    
    		$localobject=new Facture($this->savdb);
        	$result=$localobject->ref='refthatdoesnotexists';
    		$result=$localobject->VerifyNumRef();
    
    		print __METHOD__." result=".$result."\n";
        	$this->assertEquals($result, 0);
        	return $result;
        }*/
    }
    ?>