* Copyright (C) 2023 Alexandre Janniaux * * 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 . * or see https://www.gnu.org/ */ /** * \file test/phpunit/CommonClassTest.php * \ingroup test * \brief PHPUnit test * \remarks Class that extends all PHPunit tests. To share similare code between each test. */ 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'; 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 CommonClassTest extends PHPUnit\Framework\TestCase { protected $savconf; protected $savuser; protected $savlangs; protected $savdb; /** * Constructor * We save global variables into local variables * * @param string $name Name */ public function __construct($name = '') { parent::__construct($name); //$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"; } /** * setUpBeforeClass * * @return void */ public static function setUpBeforeClass(): void { global $conf,$user,$langs,$db; $db->begin(); // This is to have all actions inside a transaction even if test launched without suite. if (!isModEnabled('agenda')) { print __METHOD__." module agenda must be enabled.\n"; die(1); } print __METHOD__."\n"; } /** * This method is called when a test fails * * @param Throwable $t Throwable object * @return void */ protected function onNotSuccessfulTest(Throwable $t): void { $logfile = DOL_DATA_ROOT.'/dolibarr.log'; $lines = file($logfile); $nbLinesToShow = 100; $totalLines = count($lines); $premiereLigne = max(0, $totalLines - $nbLinesToShow); // Obtient les dernières lignes du tableau $dernieresLignes = array_slice($lines, $premiereLigne, $nbLinesToShow); // Show log file print "\n----- Test fails. Show last ".$nbLinesToShow." lines of dolibarr.log file -----\n"; foreach ($dernieresLignes as $ligne) { print $ligne . "
"; } parent::onNotSuccessfulTest($t); } /** * Init phpunit tests * * @return void */ protected function setUp(): void { global $conf,$user,$langs,$db; $conf = $this->savconf; $user = $this->savuser; $langs = $this->savlangs; $db = $this->savdb; print __METHOD__."\n"; //print $db->getVersion()."\n"; } /** * End phpunit tests * * @return void */ protected function tearDown(): void { print __METHOD__."\n"; } /** * tearDownAfterClass * * @return void */ public static function tearDownAfterClass(): void { global $db; $db->rollback(); print __METHOD__."\n"; } }