DateLibTest.php 18 KB

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