DateLibTest.php 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577
  1. <?php
  2. /* Copyright (C) 2010 Laurent Destailleur <eldy@users.sourceforge.net>
  3. * Copyright (C) 2023 Alexandre Janniaux <alexandre.janniaux@gmail.com>
  4. *
  5. * This program is free software; you can redistribute it and/or modify
  6. * it under the terms of the GNU General Public License as published by
  7. * the Free Software Foundation; either version 3 of the License, or
  8. * (at your option) any later version.
  9. *
  10. * This program is distributed in the hope that it will be useful,
  11. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  12. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  13. * GNU General Public License for more details.
  14. *
  15. * You should have received a copy of the GNU General Public License
  16. * along with this program. If not, see <https://www.gnu.org/licenses/>.
  17. * or see https://www.gnu.org/
  18. */
  19. /**
  20. * \file test/phpunit/DateLibTest.php
  21. * \ingroup test
  22. * \brief PHPUnit test
  23. * \remarks To run this script as CLI: phpunit filename.php
  24. */
  25. global $conf,$user,$langs,$db;
  26. //define('TEST_DB_FORCE_TYPE','mysql'); // This is to force using mysql driver
  27. //require_once 'PHPUnit/Autoload.php';
  28. require_once dirname(__FILE__).'/../../htdocs/master.inc.php';
  29. require_once dirname(__FILE__).'/../../htdocs/core/lib/date.lib.php';
  30. if (empty($user->id)) {
  31. print "Load permissions for admin user nb 1\n";
  32. $user->fetch(1);
  33. $user->getrights();
  34. }
  35. $conf->global->MAIN_DISABLE_ALL_MAILS=1;
  36. print "\n".$langs->trans("CurrentTimeZone").' : '.getServerTimeZoneString();
  37. print "\n".$langs->trans("CurrentHour").' : '.dol_print_date(dol_now('gmt'), 'dayhour', 'tzserver');
  38. print "\n";
  39. /**
  40. * Class for PHPUnit tests
  41. *
  42. * @backupGlobals disabled
  43. * @backupStaticAttributes enabled
  44. * @remarks backupGlobals must be disabled to have db,conf,user and lang not erased.
  45. */
  46. class DateLibTest extends PHPUnit\Framework\TestCase
  47. {
  48. protected $savconf;
  49. protected $savuser;
  50. protected $savlangs;
  51. protected $savdb;
  52. /**
  53. * Constructor
  54. * We save global variables into local variables
  55. *
  56. * @param string $name Name
  57. * @return DateLibTest
  58. */
  59. public function __construct($name = '')
  60. {
  61. parent::__construct($name);
  62. //$this->sharedFixture
  63. global $conf,$user,$langs,$db;
  64. $this->savconf=$conf;
  65. $this->savuser=$user;
  66. $this->savlangs=$langs;
  67. $this->savdb=$db;
  68. $langs->load("admin");
  69. print __METHOD__." db->type=".$db->type." user->id=".$user->id;
  70. //print " - db ".$db->db;
  71. print "\n";
  72. }
  73. /**
  74. * setUpBeforeClass
  75. *
  76. * @return void
  77. */
  78. public static function setUpBeforeClass(): void
  79. {
  80. global $conf,$user,$langs,$db;
  81. $db->begin(); // This is to have all actions inside a transaction even if test launched without suite.
  82. print __METHOD__."\n";
  83. }
  84. /**
  85. * tearDownAfterClass
  86. *
  87. * @return void
  88. */
  89. public static function tearDownAfterClass(): void
  90. {
  91. global $conf,$user,$langs,$db;
  92. $db->rollback();
  93. print __METHOD__."\n";
  94. }
  95. /**
  96. * Init phpunit tests
  97. *
  98. * @return void
  99. */
  100. protected function setUp(): void
  101. {
  102. global $conf,$user,$langs,$db;
  103. $conf=$this->savconf;
  104. $user=$this->savuser;
  105. $langs=$this->savlangs;
  106. $db=$this->savdb;
  107. print __METHOD__."\n";
  108. }
  109. /**
  110. * End phpunit tests
  111. *
  112. * @return void
  113. */
  114. protected function tearDown(): void
  115. {
  116. print __METHOD__."\n";
  117. }
  118. /**
  119. * testNumBetweenDay
  120. *
  121. * @return void
  122. */
  123. public function testNumBetweenDay()
  124. {
  125. global $conf,$user,$langs,$db;
  126. $conf=$this->savconf;
  127. $user=$this->savuser;
  128. $langs=$this->savlangs;
  129. $db=$this->savdb;
  130. // With same hours
  131. $date1=dol_mktime(0, 0, 0, 1, 1, 2012, 'gmt');
  132. $date2=dol_mktime(0, 0, 0, 1, 2, 2012, 'gmt');
  133. $result=num_between_day($date1, $date2, 1);
  134. print __METHOD__." result=".$result."\n";
  135. $this->assertEquals(2, $result);
  136. $result=num_between_day($date1, $date2, 0);
  137. print __METHOD__." result=".$result."\n";
  138. $this->assertEquals(1, $result);
  139. // With different hours
  140. $date1=dol_mktime(0, 0, 0, 1, 1, 2012, 'gmt');
  141. $date2=dol_mktime(12, 0, 0, 1, 2, 2012, 'gmt');
  142. $result=num_between_day($date1, $date2, 1);
  143. print __METHOD__." result=".$result."\n";
  144. $this->assertEquals(2, $result);
  145. $result=num_between_day($date1, $date2, 0);
  146. print __METHOD__." result=".$result."\n";
  147. $this->assertEquals(1, $result);
  148. // With different date before and after sunlight hour (day to change sunlight hour is 2014-03-30)
  149. $date1=dol_mktime(0, 0, 0, 3, 28, 2014, true);
  150. $date2=dol_mktime(0, 0, 0, 3, 31, 2014, true);
  151. $result=num_between_day($date1, $date2, 1);
  152. print __METHOD__." result=".$result."\n";
  153. $this->assertEquals(4, $result);
  154. $result=num_between_day($date1, $date2, 0);
  155. print __METHOD__." result=".$result."\n";
  156. $this->assertEquals(3, $result);
  157. return $result;
  158. }
  159. /**
  160. * testNumPublicHoliday
  161. *
  162. * @return void
  163. */
  164. public function testNumPublicHoliday()
  165. {
  166. global $conf,$user,$langs,$db;
  167. $conf=$this->savconf;
  168. $user=$this->savuser;
  169. $langs=$this->savlangs;
  170. $db=$this->savdb;
  171. // With same hours - Tuesday/Wednesday jan 2013
  172. $date1=dol_mktime(0, 0, 0, 1, 1, 2013, 'gmt');
  173. $date2=dol_mktime(0, 0, 0, 1, 2, 2013, 'gmt');
  174. $date3=dol_mktime(0, 0, 0, 1, 3, 2013, 'gmt');
  175. $result=num_public_holiday($date1, $date2, 'FR', 1);
  176. print __METHOD__." for Tuesday 1 - Wednesday 2 jan 2013 for FR result=".$result."\n";
  177. $this->assertEquals(1, $result, 'NumPublicHoliday for Tuesday 1 - Wednesday 2 jan 2013 for FR'); // 1 closed days (country france)
  178. $result=num_public_holiday($date1, $date2, 'XX', 1);
  179. print __METHOD__." for Tuesday 1 - Wednesday 2 jan 2013 for XX result=".$result."\n";
  180. $this->assertEquals(1, $result, 'NumPublicHoliday for Tuesday 1 - Wednesday 2 jan 2013 for XX'); // 1 closed days (country unknown)
  181. print '----'."\n";
  182. $result=num_public_holiday($date2, $date3, 'FR', 1);
  183. print __METHOD__." for Wednesday 2 - Thursday 3 jan 2013 for FR result=".$result."\n";
  184. $this->assertEquals(0, $result, 'NumPublicHoliday for Wednesday 2 - Thursday 3 jan 2013 for FR'); // no closed days
  185. // Check with easter monday
  186. $date1=dol_mktime(0, 0, 0, 4, 21, 2019, 'gmt');
  187. $date2=dol_mktime(0, 0, 0, 4, 23, 2019, 'gmt');
  188. $result=num_public_holiday($date1, $date2, 'XX', 1);
  189. print __METHOD__." result=".$result."\n";
  190. $this->assertEquals(1, $result, 'NumPublicHoliday including eastermonday for XX'); // 2 opened day, 1 closed days (sunday)
  191. $result=num_public_holiday($date1, $date2, 'FR', 1);
  192. print __METHOD__." result=".$result."\n";
  193. $this->assertEquals(2, $result, 'NumPublicHoliday including eastermonday for FR'); // 1 opened day, 2 closed days (sunday + easter monday)
  194. // Check for sunday/saturday - Friday 4 - Sunday 6 jan 2013
  195. $date1=dol_mktime(0, 0, 0, 1, 4, 2013, 'gmt');
  196. $date2=dol_mktime(0, 0, 0, 1, 6, 2013, 'gmt');
  197. $result=num_public_holiday($date1, $date2, 'FR', 1);
  198. print __METHOD__." result=".$result."\n";
  199. $this->assertEquals(2, $result, 'NumPublicHoliday for FR'); // 1 opened day, 2 closed days
  200. $result=num_public_holiday($date1, $date2, 'FR', 1, 1, 1);
  201. print __METHOD__." result=".$result."\n";
  202. $this->assertEquals(2, $result, 'NumPublicHoliday for FR'); // 1 opened day, 2 closed days
  203. $result=num_public_holiday($date1, $date2, 'FR', 1, 1, 0);
  204. print __METHOD__." result=".$result."\n";
  205. $this->assertEquals(1, $result, 'NumPublicHoliday for FR'); // 2 opened day, 1 closed days
  206. $result=num_public_holiday($date1, $date2, 'FR', 1, 0, 0);
  207. print __METHOD__." result=".$result."\n";
  208. $this->assertEquals(0, $result, 'NumPublicHoliday for FR'); // 3 opened day, 0 closed days
  209. $result=num_public_holiday($date1, $date2, 'XX', 1);
  210. print __METHOD__." result=".$result."\n";
  211. $this->assertEquals(2, $result, 'NumPublicHoliday for XX'); // 1 opened day, 2 closed days (even if country unknown)
  212. }
  213. /**
  214. * testNumOpenDay
  215. *
  216. * @return void
  217. */
  218. public function testNumOpenDay()
  219. {
  220. global $conf,$user,$langs,$db;
  221. $conf=$this->savconf;
  222. $user=$this->savuser;
  223. $langs=$this->savlangs;
  224. $db=$this->savdb;
  225. // With same hours - Tuesday/Wednesday jan 2013
  226. $date1=dol_mktime(0, 0, 0, 1, 1, 2013, 'gmt'); // tuesday
  227. $date2=dol_mktime(0, 0, 0, 1, 2, 2013, 'gmt'); // wednesday
  228. $date3=dol_mktime(0, 0, 0, 1, 3, 2013, 'gmt'); // thursday
  229. $result=num_open_day($date1, $date2, 0, 1, 0, 'FR');
  230. print __METHOD__." result=".$result."\n";
  231. $this->assertEquals(1, $result, 'NumOpenDay Tuesday 1 - Wednesday 2 jan 2013 for FR'); // 1 opened days (country france)
  232. $result=num_open_day($date1, $date2, 0, 1, 0, 'XX');
  233. print __METHOD__." result=".$result."\n";
  234. $this->assertEquals(1, $result, 'NumOpenDay Tuesday 1 - Wednesday 2 jan 2013 for XX'); // 1 opened days (country unknown)
  235. $result=num_open_day($date2, $date3, 0, 1, 0, 'FR');
  236. print __METHOD__." result=".$result."\n";
  237. $this->assertEquals(2, $result, 'NumOpenDay Wednesday 2 - Thursday 3 jan 2013 for FR'); // 2 opened days
  238. // With same hours - Friday/Sunday jan 2013
  239. $date1=dol_mktime(0, 0, 0, 1, 4, 2013, 'gmt'); // friday
  240. $date2=dol_mktime(0, 0, 0, 1, 6, 2013, 'gmt'); // sunday
  241. $result=num_open_day($date1, $date2, 0, 1, 0, 'FR');
  242. print __METHOD__." result=".$result."\n";
  243. $this->assertEquals(1, $result, 'NumOpenDay for FR'); // 1 opened day, 2 closed
  244. $result=num_open_day($date1, $date2, 'XX', 1);
  245. print __METHOD__." result=".$result."\n";
  246. $this->assertEquals(1, $result, 'NumOpenDay for XX'); // 1 opened day, 2 closes (even if country unknown)
  247. // Test option MAIN_NON_WORKING_DAYS_INCLUDE_SATURDAY and MAIN_NON_WORKING_DAYS_INCLUDE_SUNDAY
  248. $conf->global->MAIN_NON_WORKING_DAYS_INCLUDE_SATURDAY = 0;
  249. $result=num_open_day($date1, $date2, 0, 1, 0, 'FR');
  250. print __METHOD__." result=".$result."\n";
  251. $this->assertEquals(2, $result, 'NumOpenDay for FR when saturday is a working day'); //2 opened day, 1 closed
  252. $conf->global->MAIN_NON_WORKING_DAYS_INCLUDE_SUNDAY = 0;
  253. $result=num_open_day($date1, $date2, 'XX', 1);
  254. print __METHOD__." result=".$result."\n";
  255. $this->assertEquals(3, $result, 'NumOpenDay for XX when saturday + sunday are working days'); // 3 opened day, 0 closes (even if country unknown)
  256. }
  257. /**
  258. * testConvertTime2Seconds
  259. *
  260. * @return void
  261. */
  262. public function testConvertTime2Seconds()
  263. {
  264. global $conf,$user,$langs,$db;
  265. $conf=$this->savconf;
  266. $user=$this->savuser;
  267. $langs=$this->savlangs;
  268. $db=$this->savdb;
  269. $result=convertTime2Seconds(1, 1, 2);
  270. print __METHOD__." result=".$result."\n";
  271. $this->assertEquals(3662, $result);
  272. return $result;
  273. }
  274. /**
  275. * testConvertSecondToTime
  276. *
  277. * @return void
  278. */
  279. public function testConvertSecondToTime()
  280. {
  281. global $conf,$user,$langs,$db;
  282. $conf=$this->savconf;
  283. $user=$this->savuser;
  284. $langs=$this->savlangs;
  285. $db=$this->savdb;
  286. $result=convertSecondToTime(0, 'all', 86400);
  287. print __METHOD__." result=".$result."\n";
  288. $this->assertEquals('0', $result);
  289. $result=convertSecondToTime(86400, 'all', 86400);
  290. print __METHOD__." result=".$result."\n";
  291. $this->assertSame('1 '.$langs->trans("d"), $result);
  292. return $result;
  293. }
  294. /**
  295. * testDolPrintDate
  296. *
  297. * @return void
  298. */
  299. public function testDolPrintDate()
  300. {
  301. global $conf,$user,$langs,$db;
  302. $conf=$this->savconf;
  303. $user=$this->savuser;
  304. $langs=$this->savlangs;
  305. $db=$this->savdb;
  306. // Check %Y-%m-%d %H:%M:%S format
  307. $result=dol_print_date('1970-01-01', '%Y-%m-%d %H:%M:%S', true); // A case for compatibility check
  308. print __METHOD__." result=".$result."\n";
  309. $this->assertEquals('1970-01-01 00:00:00', $result);
  310. // Check %Y-%m-%d %H:%M:%S format
  311. $result=dol_print_date(0, '%Y-%m-%d %H:%M:%S', true);
  312. print __METHOD__." result=".$result."\n";
  313. $this->assertEquals('1970-01-01 00:00:00', $result);
  314. // Same with T and Z
  315. $result=dol_print_date(0, '%Y-%m-%dT%H:%M:%SZ', true);
  316. print __METHOD__." result=".$result."\n";
  317. $this->assertEquals('1970-01-01T00:00:00Z', $result);
  318. // Check %Y-%m-%d %H:%M:%S format
  319. $result=dol_print_date(16725225600, '%Y-%m-%d %H:%M:%S', true); // http://www.epochconverter.com/
  320. print __METHOD__." result=".$result."\n";
  321. $this->assertEquals('2500-01-01 00:00:00', $result);
  322. // Check %Y-%m-%d %H:%M:%S format
  323. $result=dol_print_date(-1830384000, '%Y-%m-%d %H:%M:%S', true); // http://www.epochconverter.com/
  324. print __METHOD__." result=".$result."\n";
  325. $this->assertEquals('1912-01-01 00:00:00', $result); // dol_print_date use TZ (good) but epoch converter does not use it.
  326. // Check %Y-%m-%d %H:%M:%S format
  327. $result=dol_print_date(-11676096000, '%Y-%m-%d %H:%M:%S', true); // http://www.epochconverter.com/
  328. print __METHOD__." result=".$result."\n";
  329. $this->assertEquals('1600-01-01 00:00:00', $result);
  330. // test with negative timezone
  331. $result=dol_print_date(-1, '%Y-%m-%d %H:%M:%S', true); // http://www.epochconverter.com/
  332. print __METHOD__." result=".$result."\n";
  333. $this->assertEquals('1969-12-31 23:59:59', $result);
  334. // Check dayhour format for fr_FR
  335. $outputlangs=new Translate('', $conf);
  336. $outputlangs->setDefaultLang('fr_FR');
  337. $outputlangs->load("main");
  338. $result=dol_print_date(0+24*3600, 'dayhour', true, $outputlangs);
  339. print __METHOD__." result=".$result."\n";
  340. $this->assertEquals('02/01/1970 00:00', $result);
  341. // Check %a and %b format for fr_FR
  342. $result=dol_print_date(0, '%a %b %B', true, $outputlangs);
  343. print __METHOD__." result=".$result."\n";
  344. $this->assertEquals('Jeu Jan. Janvier', $result);
  345. $result=dol_print_date(1619388000, '%Y-%m-%d %a', 'gmt', $outputlangs);
  346. print __METHOD__." result=".$result."\n";
  347. $this->assertEquals('2021-04-25 Dim', $result);
  348. /* This test is disabled because result depends on TZ of server
  349. $result=dol_print_date(1619388000, '%Y-%m-%d %a', 'tzserver', $outputlangs); // If TZ is +2, then result will be Lun for 1619388000
  350. print __METHOD__." result=".$result."\n";
  351. $this->assertEquals('2021-04-26 Lun', $result);
  352. */
  353. // Check day format for en_US
  354. $outputlangs=new Translate('', $conf);
  355. $outputlangs->setDefaultLang('en_US');
  356. $outputlangs->load("main");
  357. $result=dol_print_date(0+24*3600, 'day', true, $outputlangs);
  358. print __METHOD__." result=".$result."\n";
  359. $this->assertEquals('01/02/1970', $result);
  360. // Check %a and %b format for en_US
  361. $result=dol_print_date(0, '%a %b %B', true, $outputlangs);
  362. print __METHOD__." result=".$result."\n";
  363. $this->assertEquals('Thu Jan January', $result);
  364. return $result;
  365. }
  366. /**
  367. * testDolTimePlusDuree
  368. *
  369. * @return int
  370. */
  371. public function testDolTimePlusDuree()
  372. {
  373. global $conf,$user,$langs,$db;
  374. $conf=$this->savconf;
  375. $user=$this->savuser;
  376. $langs=$this->savlangs;
  377. $db=$this->savdb;
  378. // Check dayhour format for fr_FR
  379. $outputlangs=new Translate('', $conf);
  380. $outputlangs->setDefaultLang('fr_FR');
  381. $outputlangs->load("main");
  382. $result=dol_print_date(dol_time_plus_duree(dol_time_plus_duree(dol_time_plus_duree(0, 1, 'm'), 1, 'y'), 1, 'd'), 'dayhour', true, $outputlangs);
  383. print __METHOD__." result=".$result."\n";
  384. $this->assertEquals('02/02/1971 00:00', $result);
  385. return $result;
  386. }
  387. /**
  388. * testDolStringToTime
  389. *
  390. * @return int
  391. */
  392. public function testDolStringToTime()
  393. {
  394. global $conf,$user,$langs,$db;
  395. $conf=$this->savconf;
  396. $user=$this->savuser;
  397. $langs=$this->savlangs;
  398. $db=$this->savdb;
  399. $stime='19700102';
  400. $result=dol_stringtotime($stime);
  401. print __METHOD__." result=".$result."\n";
  402. $this->assertEquals(86400, $result);
  403. $stime='1970-01-01T02:00:00Z';
  404. $result=dol_stringtotime($stime);
  405. print __METHOD__." result=".$result."\n";
  406. $this->assertEquals(7200, $result);
  407. $stime='1970-01-01 02:00:00';
  408. $result=dol_stringtotime($stime);
  409. print __METHOD__." result=".$result."\n";
  410. $this->assertEquals(7200, $result);
  411. $stime='19700101T020000Z';
  412. $result=dol_stringtotime($stime);
  413. print __METHOD__." result=".$result."\n";
  414. $this->assertEquals(7200, $result);
  415. $stime='19700101020000';
  416. $result=dol_stringtotime($stime);
  417. print __METHOD__." result=".$result."\n";
  418. $this->assertEquals(7200, $result);
  419. return $result;
  420. }
  421. /**
  422. * testDolGetFirstDayWeek
  423. *
  424. * @return int
  425. */
  426. public function testDolGetFirstDayWeek()
  427. {
  428. global $conf;
  429. $day=3; $month=2; $year=2015;
  430. $conf->global->MAIN_START_WEEK = 1; // start on monday
  431. $prev = dol_get_first_day_week($day, $month, $year);
  432. $this->assertEquals(2, (int) $prev['first_day']); // monday for month 2, year 2014 is the 2
  433. $day=3; $month=2; $year=2015;
  434. $conf->global->MAIN_START_WEEK = 0; // start on sunday
  435. $prev = dol_get_first_day_week($day, $month, $year);
  436. $this->assertEquals(1, (int) $prev['first_day']); // sunday for month 2, year 2015 is the 1st
  437. return 1;
  438. }
  439. /**
  440. * testDolGetFirstHour
  441. *
  442. * @return int
  443. */
  444. public function testDolGetFirstHour()
  445. {
  446. global $conf;
  447. $now = 1800 + (24 * 3600 * 10); // The 11th of january 1970 at 0:30 in UTC
  448. $result = dol_get_first_hour($now, 'gmt');
  449. print __METHOD__." now = ".$now.", dol_print_date(now, 'dayhourrfc', 'gmt') = ".dol_print_date($now, 'dayhourrfc', 'gmt').", result = ".$result.", dol_print_date(result, 'dayhourrfc', 'gmt') = ".dol_print_date($result, 'dayhourrfc', 'gmt')."\n";
  450. $this->assertEquals('1970-01-11T00:00:00Z', dol_print_date($result, 'dayhourrfc', 'gmt')); // monday for month 2, year 2014 is the 2
  451. $now = 23.5 * 3600 + (24 * 3600 * 10); // The 11th of january 1970 at 23:30 in UTC
  452. $result = dol_get_first_hour($now, 'gmt');
  453. print __METHOD__." now = ".$now.", dol_print_date(now, 'dayhourrfc', 'gmt') = ".dol_print_date($now, 'dayhourrfc', 'gmt').", result = ".$result.", dol_print_date(result, 'dayhourrfc', 'gmt') = ".dol_print_date($result, 'dayhourrfc', 'gmt')."\n";
  454. $this->assertEquals('1970-01-11T00:00:00Z', dol_print_date($result, 'dayhourrfc', 'gmt')); // monday for month 2, year 2014 is the 2
  455. return 1;
  456. }
  457. /**
  458. * testDolSqlDateFilter
  459. *
  460. * @return int
  461. */
  462. public function testDolSqlDateFilter()
  463. {
  464. global $conf;
  465. $result = dolSqlDateFilter('field1', 0, 0, 1970, 0);
  466. print __METHOD__." result = ".$result."\n";
  467. $this->assertEquals(" AND field1 BETWEEN '1970-01-01 00:00:00' AND '1970-12-31 23:59:59'", $result, 'Test dolSqlDateFilter 1');
  468. /* If server/company is in TZ America/Bahia, and we need range with a date set in GMT
  469. $result = dolSqlDateFilter('field1', 0, 0, 1970, 0, 'gmt');
  470. print __METHOD__." result = ".$result."\n";
  471. $this->assertEquals(" AND field1 BETWEEN '1969-12-31 21:00:00' AND '1970-12-31 20:59:59'", $result, 'Test dolSqlDateFilter 2');
  472. */
  473. return 1;
  474. }
  475. }