* * 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, see . * or see http://www.gnu.org/ */ /** * \file test/phpunit/FunctionsTest.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/date.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) /** * Class for PHPUnit tests * * @backupGlobals disabled * @backupStaticAttributes enabled * @remarks backupGlobals must be disabled to have db,conf,user and lang not erased. */ class FunctionsTest extends PHPUnit_Framework_TestCase { protected $savconf; protected $savuser; protected $savlangs; protected $savdb; /** * Constructor * We save global variables into local variables * * @return CoreTest */ function FunctionsTest() { //$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"; } /** * 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"; } /** */ public function testDolHtmlCleanLastBr() { $input="A string
"; $after=dol_htmlcleanlastbr($input); $this->assertEquals("A string",$after); $input="A string first
\nA string second
"; $after=dol_htmlcleanlastbr($input); $this->assertEquals("A string first
\nA string second",$after); $input="A string\n
\n"; $after=dol_htmlcleanlastbr($input); $this->assertEquals("A string",$after); $input="A string\n

\n\n"; $after=dol_htmlcleanlastbr($input); $this->assertEquals("A string",$after); return true; } /** */ public function testDolHtmlEntitiesBr() { $input="A string\nwith a é, &, < and >."; // Text not already HTML $after=dol_htmlentitiesbr($input,0); // Add
before \n $this->assertEquals("A string
\nwith a é, &, < and >.",$after); $input="A string\nwith a é, &, < and >."; // Text not already HTML $after=dol_htmlentitiesbr($input,1); // Replace \n with
$this->assertEquals("A string
with a é, &, < and >.",$after); $input="A string
\nwith a é, &, < and >."; // Text already HTML, so &,<,> should not be converted $after=dol_htmlentitiesbr($input); $this->assertEquals("A string
\nwith a é, &, < and >.",$after); $input="
  • \nA string with a é, &, < and >.
  • \nAnother string"; // Text already HTML, so &,<,> should not be converted $after=dol_htmlentitiesbr($input); $this->assertEquals("
  • \nA string with a é, &, < and >.
  • \nAnother string",$after); return true; } /** */ public function testDolTextIsHtml() { // True $input='xxx'; $after=dol_textishtml($input); $this->assertTrue($after); $input='xxx'; $after=dol_textishtml($input); $this->assertTrue($after); $input='xxx yyy zzz'; $after=dol_textishtml($input); $this->assertTrue($after); $input='xxx
    '; $after=dol_textishtml($input); $this->assertTrue($after); $input='text with
    some div
    '; $after=dol_textishtml($input); $this->assertTrue($after); $input='text with HTML   entities'; $after=dol_textishtml($input); $this->assertTrue($after); // False $input='xxx < br>'; $after=dol_textishtml($input); $this->assertFalse($after); } /** */ public function testDolTrunc() { // Default trunc (will add ... if truncation truncation or keep last char if only one char) $input="éeéeéeàa"; $after=dol_trunc($input,3); $this->assertEquals("éeé...",$after); $after=dol_trunc($input,2); $this->assertEquals("ée...",$after); $input="éeé"; $after=dol_trunc($input,3); $this->assertEquals("éeé",$after); $after=dol_trunc($input,2); $this->assertEquals("éeé",$after); $after=dol_trunc($input,1); $this->assertEquals("é...",$after); // Trunc with no ... $input="éeéeéeàa"; $after=dol_trunc($input,3,'right','UTF-8',1); $this->assertEquals("éeé",$after); $after=dol_trunc($input,2,'right','UTF-8',1); $this->assertEquals("ée",$after); $input="éeé"; $after=dol_trunc($input,3,'right','UTF-8',1); $this->assertEquals("éeé",$after); $after=dol_trunc($input,2,'right','UTF-8',1); $this->assertEquals("ée",$after); $after=dol_trunc($input,1,'right','UTF-8',1); $this->assertEquals("é",$after); $input="éeéeéeàa"; $after=dol_trunc($input,4,'middle'); $this->assertEquals("ée...àa",$after); return true; } /** * testDolMkTime * * @return void */ public function testDolMkTime() { $result=dol_mktime(25,0,0,1,1,1970,1,1); // Error (25 hours) print __METHOD__." result=".$result."\n"; $this->assertEquals('',$result); $result=dol_mktime(2,61,0,1,1,1970,1,1); // Error (61 minutes) print __METHOD__." result=".$result."\n"; $this->assertEquals('',$result); $result=dol_mktime(2,1,61,1,1,1970,1,1); // Error (61 seconds) print __METHOD__." result=".$result."\n"; $this->assertEquals('',$result); $result=dol_mktime(2,1,1,1,32,1970,1,1); // Error (day 32) print __METHOD__." result=".$result."\n"; $this->assertEquals('',$result); $result=dol_mktime(2,1,1,13,1,1970,1,1); // Error (month 13) print __METHOD__." result=".$result."\n"; $this->assertEquals('',$result); $result=dol_mktime(2,1,1,1,1,1970,1); // 1970-01-01 02:01:01 in GMT area -> 7261 print __METHOD__." result=".$result."\n"; $this->assertEquals(7261,$result); $tz=getCurrentTimeZoneInt(); $result=dol_mktime(2,0,0,1,1,1970,0); // 1970-01-01 02:00:00 in local area print __METHOD__." result=".$result."\n"; $this->assertEquals(7200-($tz*3600),$result); } } ?>