TimeLibTest.php 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571
  1. <?php
  2. App::uses('TimeLib', 'Tools.Utility');
  3. App::uses('MyCakeTestCase', 'Tools.TestSuite');
  4. class TimeLibTest extends MyCakeTestCase {
  5. public $Time = null;
  6. public function testObject() {
  7. $this->Time = new TimeLib();
  8. $this->assertTrue(is_object($this->Time));
  9. $this->assertTrue(is_a($this->Time, 'TimeLib'));
  10. }
  11. public function testNiceDate() {
  12. $res = setlocale(LC_TIME, 'de_DE.UTF-8', 'deu_deu');
  13. debug($res);
  14. $values = array(
  15. array('2009-12-01 00:00:00', FORMAT_NICE_YMD, '01.12.2009'),
  16. array('2009-12-01 00:00:00', FORMAT_NICE_M_FULL, 'December'),
  17. );
  18. foreach ($values as $v) {
  19. $ret = TimeLib::niceDate($v[0], $v[1]);
  20. pr($ret); ob_flush();
  21. $this->assertEquals($ret, $v[2]);
  22. }
  23. }
  24. public function testLocalDate() {
  25. $res = setlocale(LC_TIME, array('de_DE.UTF-8', 'deu_deu'));
  26. debug($res);
  27. $values = array(
  28. array('2009-12-01 00:00:00', FORMAT_LOCAL_YMD, '01.12.2009'),
  29. array('2009-12-01 00:00:00', FORMAT_LOCAL_M_FULL, 'Dezember'),
  30. );
  31. foreach ($values as $v) {
  32. $ret = TimeLib::localDate($v[0], $v[1]);
  33. pr($ret); ob_flush();
  34. $this->assertEquals($ret, $v[2]);
  35. }
  36. }
  37. public function testParseLocalizedDate() {
  38. $this->out($this->_header(__FUNCTION__));
  39. $ret = TimeLib::parseLocalizedDate('15-Feb-2009', 'j-M-Y', 'start');
  40. pr($ret);
  41. $this->assertEquals($ret, '2009-02-15 00:00:00');
  42. # problem when not passing months or days as well - no way of knowing how exact the date was
  43. $ret = TimeLib::parseLocalizedDate('2009', 'Y', 'start');
  44. pr($ret);
  45. //$this->assertEquals($ret, '2009-01-01 00:00:00');
  46. $ret = TimeLib::parseLocalizedDate('Feb 2009', 'M Y', 'start');
  47. pr($ret);
  48. //$this->assertEquals($ret, '2009-02-01 00:00:00');
  49. $values = array(
  50. array(__('Today'), array(date(FORMAT_DB_DATETIME, mktime(0, 0, 0, date('m'), date('d'), date('Y'))), date(FORMAT_DB_DATETIME, mktime(23, 59, 59, date('m'), date('d'), date('Y'))))),
  51. array('2010', array('2010-01-01 00:00:00', '2010-12-31 23:59:59')),
  52. array('23.02.2011', array('2011-02-23 00:00:00', '2011-02-23 23:59:59')),
  53. array('22/02/2011', array('2011-02-22 00:00:00', '2011-02-22 23:59:59')),
  54. array('3/2/11', array('2011-02-03 00:00:00', '2011-02-03 23:59:59')),
  55. array('2/12/9', array('2009-12-02 00:00:00', '2009-12-02 23:59:59')),
  56. array('12/2009', array('2009-12-01 00:00:00', '2009-12-31 23:59:59')),
  57. );
  58. foreach ($values as $v) {
  59. $ret = TimeLib::parseLocalizedDate($v[0], null, 'start');
  60. pr($ret);
  61. $this->assertEquals($ret, $v[1][0]);
  62. $ret = TimeLib::parseLocalizedDate($v[0], null, 'end');
  63. pr($ret);
  64. $this->assertEquals($ret, $v[1][1]);
  65. }
  66. }
  67. public function testPeriod() {
  68. $this->out($this->_header(__FUNCTION__));
  69. $values = array(
  70. array(__('Today'), array(date(FORMAT_DB_DATETIME, mktime(0, 0, 0, date('m'), date('d'), date('Y'))), date(FORMAT_DB_DATETIME, mktime(23, 59, 59, date('m'), date('d'), date('Y'))))),
  71. array('2010', array('2010-01-01 00:00:00', '2010-12-31 23:59:59')),
  72. array('2011-02', array('2011-02-01 00:00:00', '2011-02-28 23:59:59')),
  73. array('2012-02', array('2012-02-01 00:00:00', '2012-02-29 23:59:59')),
  74. array('2010-02-23', array('2010-02-23 00:00:00', '2010-02-23 23:59:59')),
  75. array('2010-02-23 bis 2010-02-26', array('2010-02-23 00:00:00', '2010-02-26 23:59:59')),
  76. //array('2010-02-23 11:11:11 bis 2010-02-23 11:12:01', array('2010-02-23 11:11:11', '2010-02-23 11:12:01')),
  77. # localized
  78. array('23.02.2011', array('2011-02-23 00:00:00', '2011-02-23 23:59:59')),
  79. array('23.2.2010 bis 26.2.2011', array('2010-02-23 00:00:00', '2011-02-26 23:59:59')),
  80. );
  81. foreach ($values as $v) {
  82. $ret = TimeLib::period($v[0]);
  83. pr($ret);
  84. $this->assertEquals($ret, $v[1]);
  85. }
  86. }
  87. public function testPeriodAsSql() {
  88. $this->out($this->_header(__FUNCTION__));
  89. $values = array(
  90. array(__('Today'), "(Model.field >= '".date(FORMAT_DB_DATE)." 00:00:00') AND (Model.field <= '".date(FORMAT_DB_DATE)." 23:59:59')"),
  91. array(__('Yesterday').' '.__('until').' '.__('Today'), "(Model.field >= '".date(FORMAT_DB_DATE, time()-DAY)." 00:00:00') AND (Model.field <= '".date(FORMAT_DB_DATE)." 23:59:59')"),
  92. array(__('Today').' '.__('until').' '.__('Tomorrow'), "(Model.field >= '".date(FORMAT_DB_DATE, time())." 00:00:00') AND (Model.field <= '".date(FORMAT_DB_DATE, time()+DAY)." 23:59:59')"),
  93. array(__('Yesterday').' '.__('until').' '.__('Tomorrow'), "(Model.field >= '".date(FORMAT_DB_DATE, time()-DAY)." 00:00:00') AND (Model.field <= '".date(FORMAT_DB_DATE, time()+DAY)." 23:59:59')"),
  94. );
  95. foreach ($values as $v) {
  96. $ret = TimeLib::periodAsSql($v[0], 'Model.field');
  97. pr($v[1]);
  98. pr($ret); ob_flush();
  99. $this->assertSame($v[1], $ret);
  100. }
  101. }
  102. public function testDifference() {
  103. $this->out($this->_header(__FUNCTION__));
  104. $values = array(
  105. array('2010-02-23 11:11:11', '2010-02-23 11:12:01', 50),
  106. array('2010-02-23 11:11:11', '2010-02-24 11:12:01', DAY+50)
  107. );
  108. foreach ($values as $v) {
  109. $ret = TimeLib::difference($v[0], $v[1]);
  110. $this->assertEquals($v[2], $ret);
  111. }
  112. }
  113. public function testAgeBounds() {
  114. $this->out($this->_header(__FUNCTION__));
  115. $values = array(
  116. array(20, 20, array('min'=>'1990-07-07', 'max'=>'1991-07-06')),
  117. array(10, 30, array('min'=>'1980-07-07', 'max'=>'2001-07-06')),
  118. array(11, 12, array('min'=>'1998-07-07', 'max'=>'2000-07-06'))
  119. );
  120. foreach ($values as $v) {
  121. echo $v[0].'/'.$v[1];
  122. $ret = TimeLib::ageBounds($v[0], $v[1], true, '2011-07-06'); //TODO: relative time
  123. pr($ret);
  124. if (isset($v[2])) {
  125. $this->assertSame($v[2], $ret);
  126. pr(TimeLib::age($v[2]['min']));
  127. pr(TimeLib::age($v[2]['max']));
  128. $this->assertEquals($v[0], TimeLib::age($v[2]['max']));
  129. $this->assertEquals($v[1], TimeLib::age($v[2]['min']));
  130. }
  131. }
  132. }
  133. public function testAgeByYear() {
  134. $this->out($this->_header(__FUNCTION__));
  135. # year only
  136. $is = TimeLib::ageByYear(2000);
  137. $this->out($is);
  138. $this->assertEquals($is, (date('Y')-2001).'/'.(date('Y')-2000));
  139. $is = TimeLib::ageByYear(1985);
  140. $this->assertEquals($is, (date('Y')-1986).'/'.(date('Y')-1985));
  141. # with month
  142. if (($month = date('n')+1) <= 12) {
  143. $is = TimeLib::ageByYear(2000, $month);
  144. $this->out($is);
  145. //$this->assertEquals($is, (date('Y')-2001).'/'.(date('Y')-2000), null, '2000/'.$month);
  146. $this->assertSame($is, (date('Y')-2001), null, '2000/'.$month);
  147. }
  148. if (($month = date('n')-1) >= 1) {
  149. $is = TimeLib::ageByYear(2000, $month);
  150. $this->out($is);
  151. //$this->assertEquals($is, (date('Y')-2001).'/'.(date('Y')-2000), null, '2000/'.$month);
  152. $this->assertSame($is, (date('Y')-2000), null, '2000/'.$month);
  153. }
  154. }
  155. public function testDaysInMonth() {
  156. $this->out($this->_header(__FUNCTION__));
  157. $ret = TimeLib::daysInMonth('2004', '3');
  158. $this->assertEquals($ret, 31);
  159. $ret = TimeLib::daysInMonth('2006', '4');
  160. $this->assertEquals($ret, 30);
  161. $ret = TimeLib::daysInMonth('2007', '2');
  162. $this->assertEquals($ret, 28);
  163. $ret = TimeLib::daysInMonth('2008', '2');
  164. $this->assertEquals($ret, 29);
  165. }
  166. public function testDay() {
  167. $this->out($this->_header(__FUNCTION__));
  168. $ret = TimeLib::day('0');
  169. $this->assertEquals(__('Sunday'), $ret);
  170. $ret = TimeLib::day(2, true);
  171. $this->assertEquals(__('Tue'), $ret);
  172. $ret = TimeLib::day(6);
  173. $this->assertEquals(__('Saturday'), $ret);
  174. $ret = TimeLib::day(6, false, 1);
  175. $this->assertEquals(__('Sunday'), $ret);
  176. $ret = TimeLib::day(0, false, 2);
  177. $this->assertEquals(__('Tuesday'), $ret);
  178. $ret = TimeLib::day(1, false, 6);
  179. $this->assertEquals(__('Sunday'), $ret);
  180. }
  181. public function testMonth() {
  182. $this->out($this->_header(__FUNCTION__));
  183. $ret = TimeLib::month('11');
  184. $this->assertEquals(__('November'), $ret);
  185. $ret = TimeLib::month(1);
  186. $this->assertEquals(__('January'), $ret);
  187. $ret = TimeLib::month(2, true, array('appendDot'=>true));
  188. $this->assertEquals(__('Feb').'.', $ret);
  189. $ret = TimeLib::month(5, true, array('appendDot'=>true));
  190. $this->assertEquals(__('May'), $ret);
  191. }
  192. public function testDays() {
  193. $this->out($this->_header(__FUNCTION__));
  194. $ret = TimeLib::days();
  195. $this->assertTrue(count($ret) === 7);
  196. }
  197. public function testMonths() {
  198. $this->out($this->_header(__FUNCTION__));
  199. $ret = TimeLib::months();
  200. $this->assertTrue(count($ret) === 12);
  201. }
  202. public function testRelLengthOfTime() {
  203. $this->out($this->_header(__FUNCTION__));
  204. $ret = TimeLib::relLengthOfTime('1990-11-20');
  205. pr($ret);
  206. $ret = TimeLib::relLengthOfTime('2012-11-20');
  207. pr($ret);
  208. }
  209. public function testLengthOfTime() {
  210. $this->out($this->_header(__FUNCTION__));
  211. $ret = TimeLib::lengthOfTime(60);
  212. pr($ret);
  213. # FIX ME! Doesn't work!
  214. $ret = TimeLib::lengthOfTime(-60);
  215. pr($ret);
  216. $ret = TimeLib::lengthOfTime(-121);
  217. pr($ret);
  218. }
  219. public function testFuzzyFromOffset() {
  220. $this->out($this->_header(__FUNCTION__));
  221. $ret = TimeLib::fuzzyFromOffset(MONTH);
  222. pr($ret);
  223. $ret = TimeLib::fuzzyFromOffset(120);
  224. pr($ret);
  225. $ret = TimeLib::fuzzyFromOffset(DAY);
  226. pr($ret);
  227. $ret = TimeLib::fuzzyFromOffset(DAY+2*MINUTE);
  228. pr($ret);
  229. # FIX ME! Doesn't work!
  230. $ret = TimeLib::fuzzyFromOffset(-DAY);
  231. pr($ret);
  232. }
  233. public function testCweekMod() {
  234. }
  235. public function testCweekDay() {
  236. $this->out($this->_header(__FUNCTION__));
  237. # wednesday
  238. $ret = TimeLib::cweekDay(51, 2011, 2);
  239. $this->out('51, 2011, 2');
  240. $this->out(date(FORMAT_DB_DATETIME, $ret));
  241. $this->assertEquals(1324422000, $ret);
  242. }
  243. public function testCweeks() {
  244. $this->out($this->_header(__FUNCTION__));
  245. $ret = TimeLib::cweeks('2004');
  246. $this->assertEquals($ret, 53);
  247. $ret = TimeLib::cweeks('2010');
  248. $this->assertEquals($ret, 52);
  249. $ret = TimeLib::cweeks('2006');
  250. $this->assertEquals($ret, 52);
  251. $ret = TimeLib::cweeks('2007');
  252. $this->assertEquals($ret, 52);
  253. /*
  254. for ($i = 1990; $i < 2020; $i++) {
  255. $this->out(TimeLib::cweeks($i).BR;
  256. }
  257. */
  258. }
  259. public function testCweekBeginning() {
  260. $this->out($this->_header(__FUNCTION__));
  261. $values = array(
  262. '2001' => 978303600, # Mon 01.01.2001, 00:00
  263. '2006' => 1136156400, # Mon 02.01.2006, 00:00
  264. '2010' => 1262559600, # Mon 04.01.2010, 00:00
  265. '2013' => 1356908400, # Mon 31.12.2012, 00:00
  266. );
  267. foreach ($values as $year => $expected) {
  268. $ret = TimeLib::cweekBeginning($year);
  269. $this->out($ret);
  270. $this->out(TimeLib::niceDate($ret, 'D').' '.TimeLib::niceDate($ret, FORMAT_NICE_YMDHMS));
  271. $this->assertEquals($ret, $expected, null, $year);
  272. }
  273. $values = array(
  274. array('2001', '1', 978303600), # Mon 01.01.2001, 00:00:00
  275. array('2001', '2', 978908400), # Mon 08.01.2001, 00:00:00
  276. array('2001', '5', 980722800), # Mon 29.01.2001, 00:00:00
  277. array('2001', '52', 1009148400), # Mon 24.12.2001, 00:00:00
  278. array('2013', '11', 1362956400), # Mon 11.03.2013, 00:00:00
  279. array('2006', '3', 1137366000), # Mon 16.01.2006, 00:00:00
  280. );
  281. foreach ($values as $v) {
  282. $ret = TimeLib::cweekBeginning($v[0], $v[1]);
  283. $this->out($ret);
  284. $this->out(TimeLib::niceDate($ret, 'D').' '.TimeLib::niceDate($ret, FORMAT_NICE_YMDHMS));
  285. $this->assertSame($v[2], $ret, null, $v[1].'/'.$v[0]);
  286. }
  287. }
  288. public function testCweekEnding() {
  289. $this->out($this->_header(__FUNCTION__));
  290. $values = array(
  291. '2001' => 1009753199, # Sun 30.12.2001, 23:59:59
  292. '2006' => 1167605999, # Sun 31.12.2006, 23:59:59
  293. '2010' => 1294009199, # Sun 02.01.2011, 23:59:59
  294. '2013' => 1388357999, # Sun 29.12.2013, 23:59:59
  295. );
  296. foreach ($values as $year => $expected) {
  297. $ret = TimeLib::cweekEnding($year);
  298. $this->out($ret);
  299. $this->out(TimeLib::niceDate($ret, 'D').' '.TimeLib::niceDate($ret, FORMAT_NICE_YMDHMS));
  300. $this->assertSame($ret, $expected);
  301. }
  302. $values = array(
  303. array('2001', '1', 978908399), # Sun 07.01.2001, 23:59:59
  304. array('2001', '2', 979513199), # Sun 14.01.2001, 23:59:59
  305. array('2001', '5', 981327599), # Sun 04.02.2001, 23:59:59
  306. array('2001', '52', 1009753199), # Sun 30.12.2001, 23:59:59
  307. array('2013', '11', 1363561199), # Sun 17.03.2013, 23:59:59
  308. array('2006', '3', 1137970799), # Sun 22.01.2006, 23:59:59
  309. );
  310. foreach ($values as $v) {
  311. $ret = TimeLib::cweekEnding($v[0], $v[1]);
  312. $this->out($ret);
  313. $this->out(TimeLib::niceDate($ret, 'D').' '.TimeLib::niceDate($ret, FORMAT_NICE_YMDHMS));
  314. $this->assertSame($v[2], $ret, null, $v[1].'/'.$v[0]);
  315. }
  316. }
  317. public function testAgeByHoroscop() {
  318. App::uses('ZodiacLib', 'Tools.Misc');
  319. $zodiac = new ZodiacLib();
  320. $is = TimeLib::ageByHoroscope(2000, ZodiacLib::SIGN_VIRGO);
  321. pr($is);
  322. $this->assertEquals($is, 11);
  323. $is = TimeLib::ageByHoroscope(1991, ZodiacLib::SIGN_LIBRA);
  324. pr($is);
  325. $this->assertEquals($is, 20);
  326. $is = TimeLib::ageByHoroscope(1986, ZodiacLib::SIGN_CAPRICORN);
  327. pr($is);
  328. $this->assertEquals($is, array(24, 25));
  329. $is = TimeLib::ageByHoroscope(2000, ZodiacLib::SIGN_SCORPIO);
  330. pr($is);
  331. $this->assertEquals($is, array(10, 11));
  332. }
  333. public function testAgeRange() {
  334. $is = TimeLib::ageRange(2000);
  335. pr($is);
  336. $this->assertEquals($is, 10);
  337. $is = TimeLib::ageRange(2002, null, null, 5);
  338. pr($is);
  339. $this->assertEquals($is, array(6, 10));
  340. $is = TimeLib::ageRange(2000, null, null, 5);
  341. pr($is);
  342. $this->assertEquals($is, array(6, 10));
  343. $is = TimeLib::ageRange(1985, 23, 11);
  344. pr($is);
  345. $this->assertEquals($is, 25);
  346. $is = TimeLib::ageRange(1985, null, null, 6);
  347. pr($is);
  348. $this->assertEquals($is, array(25, 30));
  349. $is = TimeLib::ageRange(1985, 21, 11, 7);
  350. pr($is);
  351. $this->assertEquals($is, array(22, 28));
  352. }
  353. public function testParseDate() {
  354. echo $this->_header(__FUNCTION__);
  355. $tests = array(
  356. '2010-12-11' => 1292022000,
  357. '2010-01-02' => 1262386800,
  358. '10-01-02' => 1262386800,
  359. '2.1.2010' => 1262386800,
  360. '2.1.10' => 1262386800,
  361. '02.01.10' => 1262386800,
  362. '02.01.2010' => 1262386800,
  363. '02.01.2010 22:11' => 1262386800,
  364. '2010-01-02 22:11' => 1262386800,
  365. );
  366. foreach ($tests as $was => $expected) {
  367. $is = TimeLib::parseDate($was);
  368. //pr($is);
  369. pr(date(FORMAT_NICE_YMDHMS, $is));
  370. $this->assertSame($expected, $is); //, null, $was
  371. }
  372. }
  373. public function testParseTime() {
  374. echo $this->_header(__FUNCTION__);
  375. $tests = array(
  376. '2:4' => 7440,
  377. '2:04' => 7440,
  378. '2' => 7200,
  379. '1,5' => 3600+1800,
  380. '1.5' => 3600+1800,
  381. '1.50' => 3600+1800,
  382. '1.01' => 3660,
  383. ':4' => 240,
  384. ':04' => 240,
  385. ':40' => 40*MINUTE,
  386. '1:2:4' => 1*HOUR+2*MINUTE+4*SECOND,
  387. '01:2:04' => 1*HOUR+2*MINUTE+4*SECOND,
  388. '0:2:04' => 2*MINUTE+4*SECOND,
  389. '::4' => 4*SECOND,
  390. '::04' => 4*SECOND,
  391. '::40' => 40*SECOND,
  392. '2011-11-12 10:10:10' => 10*HOUR+10*MINUTE+10*SECOND,
  393. );
  394. # positive
  395. foreach ($tests as $was => $expected) {
  396. $is = TimeLib::parseTime($was);
  397. //pr($is);
  398. $this->assertEquals($expected, $is); //null, $was
  399. }
  400. unset($tests['2011-11-12 10:10:10']);
  401. # negative
  402. foreach ($tests as $was => $expected) {
  403. $is = TimeLib::parseTime('-'.$was);
  404. //pr($is);
  405. $this->assertEquals($is, -$expected); //, null, '-'.$was.' ['.$is.' => '.(-$expected).']'
  406. }
  407. }
  408. public function testBuildTime() {
  409. echo $this->_header(__FUNCTION__);
  410. $tests = array(
  411. 7440 => '2:04',
  412. 7220 => '2:00', # 02:00:20 => rounded to 2:00:00
  413. 5400 => '1:30',
  414. 3660 => '1:01',
  415. );
  416. # positive
  417. foreach ($tests as $was => $expected) {
  418. $is = TimeLib::buildTime($was);
  419. pr($is);
  420. $this->assertEquals($expected, $is);
  421. }
  422. # negative
  423. foreach ($tests as $was => $expected) {
  424. $is = TimeLib::buildTime(-$was);
  425. pr($is);
  426. $this->assertEquals($is, '-'.$expected);
  427. }
  428. }
  429. public function testBuildDefaultTime() {
  430. echo $this->_header(__FUNCTION__);
  431. $tests = array(
  432. 7440 => '02:04:00',
  433. 7220 => '02:00:20',
  434. 5400 => '01:30:00',
  435. 3660 => '01:01:00',
  436. 1*HOUR+2*MINUTE+4*SECOND => '01:02:04',
  437. );
  438. foreach ($tests as $was => $expected) {
  439. $is = TimeLib::buildDefaultTime($was);
  440. pr($is);
  441. $this->assertEquals($expected, $is);
  442. }
  443. }
  444. /**
  445. * 9.30 => 9.50
  446. */
  447. public function testStandardDecimal() {
  448. echo $this->_header(__FUNCTION__);
  449. $value = '9.30';
  450. $is = TimeLib::standardToDecimalTime($value);
  451. $this->assertEquals(round($is, 2), '9.50');
  452. $value = '9.3';
  453. $is = TimeLib::standardToDecimalTime($value);
  454. $this->assertEquals(round($is, 2), '9.50');
  455. }
  456. /**
  457. * 9.50 => 9.30
  458. */
  459. public function testDecimalStandard() {
  460. echo $this->_header(__FUNCTION__);
  461. $value = '9.50';
  462. $is = TimeLib::decimalToStandardTime($value);
  463. $this->assertEquals(round($is, 2), '9.3');
  464. $value = '9.5';
  465. $is = TimeLib::decimalToStandardTime($value);
  466. pr($is);
  467. $this->assertEquals($is, '9.3');
  468. $is = TimeLib::decimalToStandardTime($value, 2);
  469. pr($is);
  470. $this->assertEquals($is, '9.30');
  471. $is = TimeLib::decimalToStandardTime($value, 2, ':');
  472. pr($is);
  473. $this->assertEquals($is, '9:30');
  474. }
  475. }