DateTimeTest.php 31 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102
  1. <?php
  2. namespace Tools\Test\TestCase\Utility;
  3. use Cake\Core\Configure;
  4. use DateTime as CoreDateTime;
  5. use Shim\TestSuite\TestCase;
  6. use Tools\I18n\DateTime;
  7. class DateTimeTest extends TestCase {
  8. /**
  9. * @var \Tools\Utility\DateTime
  10. */
  11. protected DateTime $Time;
  12. /**
  13. * @return void
  14. */
  15. public function setUp(): void {
  16. $this->Time = new DateTime();
  17. parent::setUp();
  18. }
  19. /**
  20. * TimeTest::testObject()
  21. *
  22. * @return void
  23. */
  24. public function testObject() {
  25. $this->assertTrue(is_object($this->Time));
  26. $this->assertInstanceOf(DateTime::class, $this->Time);
  27. }
  28. /**
  29. * Currently only works with timezoned localized values, not with UTC!!!
  30. *
  31. * @return void
  32. */
  33. public function testIncrementDate() {
  34. $timezone = Configure::read('Config.timezone');
  35. //$timezone = Date$this->Time->timezone();
  36. Configure::write('Config.timezone', 'Europe/Berlin');
  37. $phpTimezone = date_default_timezone_get();
  38. date_default_timezone_set('Europe/Berlin');
  39. $from = '2012-12-31';
  40. $Date = $this->Time->incrementDate($from, 0, 0);
  41. $this->assertSame($from, $Date->format(FORMAT_DB_DATE));
  42. $from = '2012-12-31';
  43. $Date = $this->Time->incrementDate($from, 0, 1);
  44. $this->assertSame('2013-01-31', $Date->format(FORMAT_DB_DATE));
  45. $from = '2012-12-31';
  46. $Date = $this->Time->incrementDate($from, 0, 2);
  47. $this->assertSame('2013-02-28', $Date->format(FORMAT_DB_DATE));
  48. $from = '2012-12-31';
  49. $Date = $this->Time->incrementDate($from, 0, 4);
  50. $this->assertSame('2013-04-30', $Date->format(FORMAT_DB_DATE));
  51. $from = '2012-12-31';
  52. $Date = $this->Time->incrementDate($from, 1, 0);
  53. $this->assertSame('2013-12-31', $Date->format(FORMAT_DB_DATE));
  54. // from leap year
  55. $from = '2008-02-29';
  56. $Date = $this->Time->incrementDate($from, 1, 0);
  57. $this->assertSame('2009-02-28', $Date->format(FORMAT_DB_DATE));
  58. // into leap year
  59. $from = '2007-02-28';
  60. $Date = $this->Time->incrementDate($from, 1, 0);
  61. $this->assertSame('2008-02-29', $Date->format(FORMAT_DB_DATE));
  62. // other direction
  63. $from = '2012-12-31';
  64. $Date = $this->Time->incrementDate($from, 0, -1);
  65. $this->assertSame('2012-11-30', $Date->format(FORMAT_DB_DATE));
  66. $from = '2012-12-31';
  67. $Date = $this->Time->incrementDate($from, -1, -1);
  68. $this->assertSame('2011-11-30', $Date->format(FORMAT_DB_DATE));
  69. // including days
  70. $from = '2012-12-31';
  71. $Date = $this->Time->incrementDate($from, 0, 1, 1);
  72. $this->assertSame('2013-02-01', $Date->format(FORMAT_DB_DATE));
  73. // including days
  74. $from = '2012-12-31';
  75. $Date = $this->Time->incrementDate($from, 0, 1, 5);
  76. $this->assertSame('2013-02-05', $Date->format(FORMAT_DB_DATE));
  77. Configure::write('Config.timezone', $timezone);
  78. date_default_timezone_set($phpTimezone);
  79. }
  80. /**
  81. * @return void
  82. */
  83. public function testNiceDate() {
  84. $res = setlocale(LC_TIME, 'de_DE.UTF-8', 'deu_deu');
  85. //$this->assertTrue(!empty($res));
  86. $values = [
  87. ['2009-12-01 00:00:00', FORMAT_NICE_YMD, '01.12.2009'],
  88. ['2009-12-01 00:00:00', FORMAT_NICE_M_FULL, 'December'],
  89. ];
  90. foreach ($values as $v) {
  91. $result = $this->Time->niceDate($v[0], $v[1]);
  92. $this->assertEquals($v[2], $result);
  93. }
  94. $date = '2009-12-01 00:00:00';
  95. $format = FORMAT_NICE_YMD;
  96. $result = $this->Time->niceDate($date, $format, ['oclock' => true]);
  97. $expected = '01.12.2009';
  98. $this->assertEquals($expected, $result);
  99. $date = '2009-12-01 00:00:00';
  100. $format = FORMAT_NICE_YMDHM;
  101. $result = $this->Time->niceDate($date, $format, ['oclock' => true]);
  102. $expected = '01.12.2009, 00:00 ' . __d('tools', 'o\'clock');
  103. $this->assertEquals($expected, $result);
  104. $date = time();
  105. $format = FORMAT_NICE_YMDHM;
  106. $result = $this->Time->niceDate($date, $format, ['oclock' => true]);
  107. $this->assertNotEmpty($result);
  108. }
  109. /**
  110. * TimeTest::testNiceTime()
  111. *
  112. * @return void
  113. */
  114. public function testNiceTime() {
  115. $result = $this->Time->niceTime('22:11:18');
  116. $expected = '22:11';
  117. $this->assertEquals($expected, $result);
  118. $result = $this->Time->niceTime('2014-11-12 22:11:18');
  119. $this->assertEquals($expected, $result);
  120. }
  121. /**
  122. * Test that input as date only (YYYY-MM-DD) does not suddendly return a
  123. * different date on output due to timezone differences.
  124. * Here the timezone should not apply since we only input date and only output
  125. * date (time itself is irrelevant).
  126. *
  127. * @return void
  128. */
  129. public function testDateWithTimezone() {
  130. $res = setlocale(LC_TIME, 'de_DE.UTF-8', 'deu_deu');
  131. //$this->assertTrue(!empty($res));
  132. Configure::write('Config.timezone', 'America/Anchorage');
  133. $ret = $this->Time->niceDate('2009-12-01');
  134. $this->assertEquals('01.12.2009', $ret);
  135. }
  136. /**
  137. * @return void
  138. */
  139. public function testFormatLocalized() {
  140. $ret = $this->Time->formatLocalized(new DateTime('2009-12-01'), 'd.m.Y');
  141. $this->assertEquals('01.12.2009', $ret);
  142. }
  143. /**
  144. * TimeTest::testParseLocalizedDate()
  145. *
  146. * @return void
  147. */
  148. public function testParseLocalizedDate() {
  149. $ret = $this->Time->parseLocalizedDate('15-Feb-2009', 'j-M-Y', 'start');
  150. //$this->debug($ret);
  151. $this->assertEquals('2009-02-15 00:00:00', $ret);
  152. // problem when not passing months or days as well - no way of knowing how exact the date was
  153. $ret = $this->Time->parseLocalizedDate('2009', 'Y', 'start');
  154. //pr($ret);
  155. //$this->assertEquals($ret, '2009-01-01 00:00:00');
  156. $ret = $this->Time->parseLocalizedDate('Feb 2009', 'M Y', 'start');
  157. //pr($ret);
  158. //$this->assertEquals($ret, '2009-02-01 00:00:00');
  159. $values = [
  160. [__d('tools', 'Today'), [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')))]],
  161. ['2010', ['2010-01-01 00:00:00', '2010-12-31 23:59:59']],
  162. ['23.02.2011', ['2011-02-23 00:00:00', '2011-02-23 23:59:59']],
  163. ['22/02/2011', ['2011-02-22 00:00:00', '2011-02-22 23:59:59']],
  164. ['3/2/11', ['2011-02-03 00:00:00', '2011-02-03 23:59:59']],
  165. //array('2/12/9', array('2009-12-02 00:00:00', '2009-12-02 23:59:59')),
  166. //array('12/2009', array('2009-12-01 00:00:00', '2009-12-31 23:59:59')),
  167. ];
  168. foreach ($values as $v) {
  169. $ret = $this->Time->parseLocalizedDate($v[0], null, 'start');
  170. //pr($ret);
  171. $this->assertEquals($v[1][0], $ret);
  172. $ret = $this->Time->parseLocalizedDate($v[0], null, 'end');
  173. //pr($ret);
  174. $this->assertEquals($v[1][1], $ret);
  175. }
  176. }
  177. /**
  178. * @return void
  179. */
  180. public function testLocalDate() {
  181. $values = [
  182. ['2009-12-01 00:00:00', 'd.m.Y', '01.12.2009'],
  183. //['2009-12-01 00:00:00', 'M', 'Dez.'],
  184. ];
  185. foreach ($values as $v) {
  186. $ret = $this->Time->localDate($v[0], $v[1], ['language' => 'de']);
  187. $this->assertEquals($v[2], $ret);
  188. }
  189. $date = '2009-12-01 00:00:00';
  190. $format = 'd.m.Y';
  191. $result = $this->Time->localDate($date, $format, ['language' => 'de', 'oclock' => true]);
  192. $expected = '01.12.2009';
  193. $this->assertEquals($expected, $result);
  194. $date = '2009-12-01 00:00:00';
  195. $format = 'd.m.Y, H:i';
  196. $result = $this->Time->localDate($date, $format, ['language' => 'de', 'oclock' => true]);
  197. $expected = '01.12.2009, 00:00 ' . __d('tools', 'o\'clock');
  198. $this->assertEquals($expected, $result);
  199. }
  200. /**
  201. * TimeTest::testPeriod()
  202. *
  203. * @return void
  204. */
  205. public function testPeriod() {
  206. //$this->out($this->_header(__FUNCTION__), true);
  207. $values = [
  208. [__d('tools', 'Today'), [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')))]],
  209. ['2010', ['2010-01-01 00:00:00', '2010-12-31 23:59:59']],
  210. ['2011-02', ['2011-02-01 00:00:00', '2011-02-28 23:59:59']],
  211. ['2012-02', ['2012-02-01 00:00:00', '2012-02-29 23:59:59']],
  212. ['2010-02-23', ['2010-02-23 00:00:00', '2010-02-23 23:59:59']],
  213. ['2010-02-23 bis 2010-02-26', ['2010-02-23 00:00:00', '2010-02-26 23:59:59']],
  214. //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')),
  215. // localized
  216. ['23.02.2011', ['2011-02-23 00:00:00', '2011-02-23 23:59:59']],
  217. ['23.2.2010 bis 26.2.2011', ['2010-02-23 00:00:00', '2011-02-26 23:59:59']],
  218. ];
  219. foreach ($values as $v) {
  220. $ret = $this->Time->period($v[0]);
  221. //pr($ret);
  222. $this->assertEquals($v[1], $ret);
  223. }
  224. }
  225. /**
  226. * TimeTest::testPeriodAsSql()
  227. *
  228. * @return void
  229. */
  230. public function testPeriodAsSql() {
  231. //$this->out($this->_header(__FUNCTION__), true);
  232. $values = [
  233. [__d('tools', 'Today'), "(Model.field >= '" . date(FORMAT_DB_DATE) . " 00:00:00') AND (Model.field <= '" . date(FORMAT_DB_DATE) . " 23:59:59')"],
  234. [__d('tools', 'Yesterday') . ' ' . __d('tools', 'until') . ' ' . __d('tools', 'Today'), "(Model.field >= '" . date(FORMAT_DB_DATE, time() - DAY) . " 00:00:00') AND (Model.field <= '" . date(FORMAT_DB_DATE) . " 23:59:59')"],
  235. [__d('tools', 'Today') . ' ' . __d('tools', 'until') . ' ' . __d('tools', 'Tomorrow'), "(Model.field >= '" . date(FORMAT_DB_DATE, time()) . " 00:00:00') AND (Model.field <= '" . date(FORMAT_DB_DATE, time() + DAY) . " 23:59:59')"],
  236. [__d('tools', 'Yesterday') . ' ' . __d('tools', 'until') . ' ' . __d('tools', 'Tomorrow'), "(Model.field >= '" . date(FORMAT_DB_DATE, time() - DAY) . " 00:00:00') AND (Model.field <= '" . date(FORMAT_DB_DATE, time() + DAY) . " 23:59:59')"],
  237. ];
  238. foreach ($values as $v) {
  239. $ret = $this->Time->periodAsSql($v[0], 'Model.field');
  240. //pr($v[1]);
  241. //pr($ret);
  242. $this->assertSame($v[1], $ret);
  243. }
  244. }
  245. /**
  246. * TimeTest::testDifference()
  247. *
  248. * @return void
  249. */
  250. public function testDifference() {
  251. //$this->out($this->_header(__FUNCTION__), true);
  252. $values = [
  253. ['2010-02-23 11:11:11', '2010-02-23 11:12:01', 50],
  254. ['2010-02-23 11:11:11', '2010-02-24 11:12:01', DAY + 50],
  255. ];
  256. foreach ($values as $v) {
  257. $ret = $this->Time->difference($v[0], $v[1]);
  258. $this->assertEquals($v[2], $ret);
  259. }
  260. }
  261. /**
  262. * TimeTest::testIsLeapYear()
  263. *
  264. * @return void
  265. */
  266. public function testIsLeapYear() {
  267. $this->Time = new DateTime('2001-01-01');
  268. $is = $this->Time->isLeapYear();
  269. $this->assertFalse($is);
  270. $this->Time = new DateTime('2008-01-01');
  271. $is = $this->Time->isLeapYear();
  272. $this->assertTrue($is);
  273. $this->Time = new DateTime('2000-01-01');
  274. $is = $this->Time->isLeapYear();
  275. $this->assertTrue($is);
  276. }
  277. /**
  278. * TimeTest::testIsInRange()
  279. *
  280. * @return void
  281. */
  282. public function testIsInRange() {
  283. $is = $this->Time->isInRange(date(FORMAT_DB_DATETIME, time() + 22 * HOUR), DAY);
  284. $this->assertTrue($is);
  285. $is = $this->Time->isInRange(date(FORMAT_DB_DATETIME, time() + 26 * HOUR), DAY);
  286. $this->assertFalse($is);
  287. $day = date(FORMAT_DB_DATETIME, time() + 10 * DAY);
  288. $this->assertTrue($this->Time->isInRange($day, 11 * DAY));
  289. $this->assertTrue($this->Time->isInRange($day, 10 * DAY));
  290. $this->assertFalse($this->Time->isInRange($day, 9 * DAY));
  291. $day = date(FORMAT_DB_DATETIME, time() - 78 * DAY);
  292. $this->assertTrue($this->Time->isInRange($day, 79 * DAY));
  293. $this->assertTrue($this->Time->isInRange($day, 78 * DAY));
  294. $this->assertFalse($this->Time->isInRange($day, 77 * DAY));
  295. }
  296. /**
  297. * Test age
  298. *
  299. * @return void
  300. */
  301. public function testAge() {
  302. $this->assertEquals('0', $this->Time->age(null));
  303. [$year, $month, $day] = explode('-', date('Y-m-d'));
  304. $this->assertEquals('0', $this->Time->age($year . '-' . $month . '-' . $day, null));
  305. [$year, $month, $day] = explode('-', date('Y-m-d', strtotime('-10 years')));
  306. $this->assertEquals('10', $this->Time->age($year . '-' . $month . '-' . $day, null));
  307. [$year, $month, $day] = explode('-', date('Y-m-d', strtotime('-10 years +1 day')));
  308. $this->assertEquals('9', $this->Time->age($year . '-' . $month . '-' . $day, null));
  309. [$year, $month, $day] = explode('-', date('Y-m-d', strtotime('-10 years -1 day')));
  310. $this->assertEquals('10', $this->Time->age($year . '-' . $month . '-' . $day, null));
  311. // Crossing years
  312. $this->assertEquals('2', $this->Time->age('2005-12-01', '2008-02-29'));
  313. $this->assertEquals('6', $this->Time->age('2002-01-29', '2008-12-02'));
  314. // Leap year
  315. $this->assertEquals('2', $this->Time->age('2005-03-01', '2008-02-28'));
  316. $this->assertEquals('2', $this->Time->age('2005-03-01', '2008-02-29'));
  317. $this->assertEquals('3', $this->Time->age('2005-03-01', '2008-03-01'));
  318. $this->assertEquals('3', $this->Time->age('2005-02-29', '2008-03-01'));
  319. // Future
  320. [$yearE, $monthE, $dayE] = explode('-', date('Y-m-d', strtotime('+10 years -1 day')));
  321. $this->assertEquals('9', $this->Time->age(null, $yearE . '-' . $monthE . '-' . $dayE));
  322. [$yearE, $monthE, $dayE] = explode('-', date('Y-m-d', strtotime('+10 years +1 day')));
  323. $this->assertEquals('10', $this->Time->age(null, $yearE . '-' . $monthE . '-' . $dayE));
  324. $birthday = '2033-04-09';
  325. $this->assertEquals(-1, $this->Time->age($birthday));
  326. $birthday = '1985-04-08';
  327. $relativeDate = '2010-04-07';
  328. $this->assertEquals('24', $this->Time->age($birthday, $relativeDate));
  329. $relativeDate = '2010-04-08';
  330. $this->assertEquals('25', $this->Time->age($birthday, $relativeDate));
  331. $relativeDate = '2010-04-09';
  332. $this->assertEquals('25', $this->Time->age($birthday, $relativeDate));
  333. }
  334. /**
  335. * TimeTest::testAgeBounds()
  336. *
  337. * @return void
  338. */
  339. public function testAgeBounds() {
  340. //$this->out($this->_header(__FUNCTION__), true);
  341. $values = [
  342. [20, 20, ['min' => '1990-07-07', 'max' => '1991-07-06']],
  343. [10, 30, ['min' => '1980-07-07', 'max' => '2001-07-06']],
  344. [11, 12, ['min' => '1998-07-07', 'max' => '2000-07-06']],
  345. ];
  346. foreach ($values as $v) {
  347. //echo $v[0].'/'.$v[1];
  348. $ret = $this->Time->ageBounds($v[0], $v[1], true, '2011-07-06'); //TODO: relative time
  349. //pr($ret);
  350. if (isset($v[2])) {
  351. $this->assertSame($v[2], $ret);
  352. $this->assertEquals($v[0], $this->Time->age($v[2]['max'], '2011-07-06'));
  353. $this->assertEquals($v[1], $this->Time->age($v[2]['min'], '2011-07-06'));
  354. }
  355. }
  356. }
  357. /**
  358. * TimeTest::testAgeByYear()
  359. *
  360. * @return void
  361. */
  362. public function testAgeByYear() {
  363. //$this->out($this->_header(__FUNCTION__), true);
  364. // year only
  365. $is = $this->Time->ageByYear(2000);
  366. //$this->out($is);
  367. $this->assertEquals((date('Y') - 2001) . '/' . (date('Y') - 2000), $is);
  368. $is = $this->Time->ageByYear(1985);
  369. $this->assertEquals((date('Y') - 1986) . '/' . (date('Y') - 1985), $is);
  370. // with month
  371. $month = date('n') + 1;
  372. if ($month <= 12) {
  373. $is = $this->Time->ageByYear(2000, $month);
  374. //$this->out($is);
  375. //$this->assertEquals($is, (date('Y')-2001).'/'.(date('Y')-2000), null, '2000/'.$month);
  376. $expected = (string)(date('Y') - 2001);
  377. $this->assertSame($expected, $is);
  378. }
  379. $month = date('n') - 1;
  380. if ($month >= 1) {
  381. $is = $this->Time->ageByYear(2000, $month);
  382. //$this->out($is);
  383. //$this->assertEquals($is, (date('Y')-2001).'/'.(date('Y')-2000), null, '2000/'.$month);
  384. $expected = (string)(date('Y') - 2000);
  385. $this->assertSame($expected, $is); //null, '2000/'.$month)
  386. }
  387. }
  388. /**
  389. * TimeTest::testDaysInMonth()
  390. *
  391. * @return void
  392. */
  393. public function testDaysInMonth() {
  394. //$this->out($this->_header(__FUNCTION__), true);
  395. $ret = $this->Time->daysInMonth('2004', '3');
  396. $this->assertEquals(31, $ret);
  397. $ret = $this->Time->daysInMonth('2006', '4');
  398. $this->assertEquals(30, $ret);
  399. $ret = $this->Time->daysInMonth('2007', '2');
  400. $this->assertEquals(28, $ret);
  401. $ret = $this->Time->daysInMonth('2008', '2');
  402. $this->assertEquals(29, $ret);
  403. }
  404. /**
  405. * TimeTest::testDay()
  406. *
  407. * @return void
  408. */
  409. public function testDayName() {
  410. //$this->out($this->_header(__FUNCTION__), true);
  411. $ret = $this->Time->dayName('0');
  412. $this->assertEquals(__d('tools', 'Sunday'), $ret);
  413. $ret = $this->Time->dayName(2, true);
  414. $this->assertEquals(__d('tools', 'Tue'), $ret);
  415. $ret = $this->Time->dayName(6);
  416. $this->assertEquals(__d('tools', 'Saturday'), $ret);
  417. $ret = $this->Time->dayName(6, false, 1);
  418. $this->assertEquals(__d('tools', 'Sunday'), $ret);
  419. $ret = $this->Time->dayName(0, false, 2);
  420. $this->assertEquals(__d('tools', 'Tuesday'), $ret);
  421. $ret = $this->Time->dayName(1, false, 6);
  422. $this->assertEquals(__d('tools', 'Sunday'), $ret);
  423. }
  424. /**
  425. * TimeTest::testMonth()
  426. *
  427. * @return void
  428. */
  429. public function testMonthName() {
  430. //$this->out($this->_header(__FUNCTION__), true);
  431. $ret = $this->Time->monthName('11');
  432. $this->assertEquals(__d('tools', 'November'), $ret);
  433. $ret = $this->Time->monthName(1);
  434. $this->assertEquals(__d('tools', 'January'), $ret);
  435. $ret = $this->Time->monthName(2, true, ['appendDot' => true]);
  436. $this->assertEquals(__d('tools', 'Feb') . '.', $ret);
  437. $ret = $this->Time->monthName(5, true, ['appendDot' => true]);
  438. $this->assertEquals(__d('tools', 'May'), $ret);
  439. }
  440. /**
  441. * TimeTest::testDays()
  442. *
  443. * @return void
  444. */
  445. public function testDayNames() {
  446. //$this->out($this->_header(__FUNCTION__), true);
  447. $ret = $this->Time->dayNames();
  448. $this->assertTrue(count($ret) === 7);
  449. }
  450. /**
  451. * TimeTest::testMonths()
  452. *
  453. * @return void
  454. */
  455. public function testMonthNames() {
  456. //$this->out($this->_header(__FUNCTION__), true);
  457. $ret = $this->Time->monthNames();
  458. $this->assertTrue(count($ret) === 12);
  459. }
  460. /**
  461. * TimeTest::testRelLengthOfTime()
  462. *
  463. * @return void
  464. */
  465. public function testRelLengthOfTime() {
  466. $result = $this->Time->relLengthOfTime('1990-11-20');
  467. $this->assertTrue(!empty($result));
  468. $this->assertTrue(is_string($result));
  469. $result = $this->Time->relLengthOfTime('2012-11-20');
  470. $this->assertTrue(!empty($result));
  471. $this->assertTrue(is_string($result));
  472. $result = $this->Time->relLengthOfTime(date(FORMAT_DB_DATETIME, time() - 3600));
  473. $this->assertTrue(!empty($result));
  474. $this->assertTrue(is_string($result));
  475. $res = $this->Time->relLengthOfTime(date(FORMAT_DB_DATETIME, time() - 4 * DAY - 5 * HOUR), null, ['plural' => 'n']);
  476. //pr($res);
  477. //$this->assertEquals($res, 'Vor 4 Tagen, 5 '.__d('tools', 'Hours'));
  478. $this->assertEquals(__d('tools', '{0} ago', '4 ' . __d('tools', 'Days') . ', ' . '5 ' . __d('tools', 'Hours')), $res);
  479. $res = $this->Time->relLengthOfTime(date(FORMAT_DB_DATETIME, time() + 4 * DAY + 5 * HOUR), null, ['plural' => 'n']);
  480. //pr($res);
  481. $this->assertEquals(__d('tools', 'In {0}', '4 ' . __d('tools', 'Days') . ', ' . '5 ' . __d('tools', 'Hours')), $res);
  482. $res = $this->Time->relLengthOfTime(date(FORMAT_DB_DATETIME, time()), null, ['plural' => 'n']);
  483. //pr($res);
  484. $this->assertEquals($res, __d('tools', 'justNow'));
  485. }
  486. /**
  487. * Test cweek
  488. *
  489. * @return void
  490. */
  491. public function testCweek() {
  492. $year = 2008;
  493. $month = 12;
  494. $day = 29;
  495. $date = mktime(0, 0, 0, $month, $day, $year);
  496. $this->assertEquals('01/' . $year, $this->Time->cweek($year . '-' . $month . '-' . $day));
  497. $year = 2009;
  498. $month = 1;
  499. $day = 1;
  500. $date = mktime(0, 0, 0, $month, $day, $year);
  501. $this->assertEquals('01/' . $year, $this->Time->cweek($year . '-' . $month . '-' . $day));
  502. $year = 2009;
  503. $month = 1;
  504. $day = 9;
  505. $date = mktime(0, 0, 0, $month, $day, $year);
  506. $this->assertEquals('02/' . $year, $this->Time->cweek($year . '-' . $month . '-' . $day . ' 00:00:00'));
  507. $year = 2009;
  508. $month = 12;
  509. $day = 26;
  510. $date = mktime(0, 0, 0, $month, $day, $year);
  511. $this->assertEquals('52/' . $year, $this->Time->cweek($year . '-' . $month . '-' . $day));
  512. }
  513. /**
  514. * Test IsInTheFuture
  515. *
  516. * @return void
  517. */
  518. public function testIsInTheFuture() {
  519. $testDate = date(FORMAT_DB_DATE, time() + 2 * DAY);
  520. $is = $this->Time->isInTheFuture($testDate);
  521. $this->assertTrue($is);
  522. $testDate = date(FORMAT_DB_DATETIME, time() - 1 * MINUTE);
  523. $is = $this->Time->isInTheFuture($testDate);
  524. $this->assertFalse($is);
  525. }
  526. /**
  527. * Test IsNotTodayAndInTheFuture
  528. *
  529. * @return void
  530. */
  531. public function testIsNotTodayAndInTheFuture() {
  532. $testDate = date(FORMAT_DB_DATE, time());
  533. $is = $this->Time->isNotTodayAndInTheFuture($testDate);
  534. $this->assertFalse($is);
  535. $testDate = date(FORMAT_DB_DATETIME, time() + 1 * DAY);
  536. $is = $this->Time->isNotTodayAndInTheFuture($testDate);
  537. $this->assertTrue($is);
  538. }
  539. /**
  540. * Test IsDayAfterTomorrow
  541. *
  542. * @return void
  543. */
  544. public function testIsDayAfterTomorrow() {
  545. $testDate = new DateTime(time() + 2 * DAY);
  546. $is = $this->Time->isDayAfterTomorrow($testDate);
  547. $this->assertTrue($is);
  548. $testDate = new DateTime(time() - 1 * MINUTE);
  549. $is = $this->Time->isDayAfterTomorrow($testDate);
  550. $this->assertFalse($is);
  551. }
  552. /**
  553. * @return void
  554. */
  555. public function testLengthOfTime() {
  556. $ret = $this->Time->lengthOfTime(60, 'Hi');
  557. $this->assertEquals('1 Minutes', $ret);
  558. $ret = $this->Time->lengthOfTime(DAY);
  559. $this->assertEquals('1 Days, 0 Hours', $ret);
  560. // FIX ME! Doesn't work!
  561. $ret = $this->Time->lengthOfTime(-60);
  562. //$this->assertEquals('-60 Seconds', $ret);
  563. $this->assertEquals('6 ' . __d('tools', 'Minutes') . ', 40 ' . __d('tools', 'Seconds'), $this->Time->lengthOfTime(400));
  564. $res = $this->Time->lengthOfTime(400, 'i');
  565. $this->assertEquals('6 ' . __d('tools', 'Minutes'), $res);
  566. $res = $this->Time->lengthOfTime(6 * DAY);
  567. $this->assertEquals('6 ' . __d('tools', 'Days') . ', 0 ' . __d('tools', 'Hours'), $res);
  568. }
  569. /**
  570. * @return void
  571. */
  572. public function testFuzzyFromOffset() {
  573. $ret = $this->Time->fuzzyFromOffset(MONTH);
  574. $this->assertSame('about a month', $ret);
  575. $ret = $this->Time->fuzzyFromOffset(120);
  576. $this->assertSame('a few minutes', $ret);
  577. $ret = $this->Time->fuzzyFromOffset(DAY);
  578. $this->assertSame('about a day', $ret);
  579. $ret = $this->Time->fuzzyFromOffset(DAY + 2 * MINUTE);
  580. $this->assertSame('about a day', $ret);
  581. // FIX ME! Doesn't work!
  582. $ret = $this->Time->fuzzyFromOffset(-DAY);
  583. //dd($ret);
  584. }
  585. /**
  586. * @return void
  587. */
  588. public function testCweekMod() {
  589. $result = $this->Time->cWeekMod(0);
  590. $this->assertEquals(0, $result);
  591. $result = $this->Time->cWeekMod(1);
  592. $this->assertEquals(1, $result);
  593. $result = $this->Time->cWeekMod(6);
  594. $this->assertEquals(0, $result);
  595. }
  596. /**
  597. * @return void
  598. */
  599. public function testCweeks() {
  600. //$this->out($this->_header(__FUNCTION__), true);
  601. $ret = $this->Time->cweeks('2004');
  602. $this->assertEquals(53, $ret);
  603. $ret = $this->Time->cweeks('2010');
  604. $this->assertEquals(52, $ret);
  605. $ret = $this->Time->cweeks('2006');
  606. $this->assertEquals(52, $ret);
  607. $ret = $this->Time->cweeks('2007');
  608. $this->assertEquals(52, $ret);
  609. /*
  610. for ($i = 1990; $i < 2020; $i++) {
  611. //$this->out($this->Time->cweeks($i).BR;
  612. }
  613. */
  614. }
  615. /**
  616. * @return void
  617. */
  618. public function testCweekBeginning() {
  619. //$this->out($this->_header(__FUNCTION__), true);
  620. $values = [
  621. '2001' => 978303600, # Mon 01.01.2001, 00:00
  622. '2006' => 1136156400, # Mon 02.01.2006, 00:00
  623. '2010' => 1262559600, # Mon 04.01.2010, 00:00
  624. '2013' => 1356908400, # Mon 31.12.2012, 00:00
  625. ];
  626. foreach ($values as $year => $expected) {
  627. $ret = $this->Time->cweekBeginning($year);
  628. //$this->out($ret);
  629. //$this->out($this->Time->niceDate($ret, 'D') . ' ' . $this->Time->niceDate($ret, FORMAT_NICE_YMDHMS));
  630. //$this->assertEquals($ret, $expected, null, $year);
  631. $this->assertTrue($ret <= $expected + HOUR && $ret >= $expected);
  632. }
  633. $values = [
  634. ['2001', '1', 978303600], # Mon 01.01.2001, 00:00:00
  635. ['2001', '2', 978908400], # Mon 08.01.2001, 00:00:00
  636. ['2001', '5', 980722800], # Mon 29.01.2001, 00:00:00
  637. ['2001', '52', 1009148400], # Mon 24.12.2001, 00:00:00
  638. ['2013', '11', 1362956400], # Mon 11.03.2013, 00:00:00
  639. ['2006', '3', 1137366000], # Mon 16.01.2006, 00:00:00
  640. ];
  641. foreach ($values as $v) {
  642. $ret = $this->Time->cweekBeginning($v[0], $v[1]);
  643. //$this->out($ret);
  644. //$this->out($this->Time->niceDate($ret, 'D') . ' ' . $this->Time->niceDate($ret, FORMAT_NICE_YMDHMS));
  645. //$this->assertSame($v[2], $ret, null, $v[1].'/'.$v[0]);
  646. $this->assertTrue($ret <= $v[2] + HOUR && $ret >= $v[2]);
  647. }
  648. }
  649. /**
  650. * @return void
  651. */
  652. public function testCweekEnding() {
  653. //$this->out($this->_header(__FUNCTION__), true);
  654. $values = [
  655. '2001' => 1009753199, # Sun 30.12.2001, 23:59:59
  656. '2006' => 1167605999, # Sun 31.12.2006, 23:59:59
  657. '2010' => 1294009199, # Sun 02.01.2011, 23:59:59
  658. '2013' => 1388357999, # Sun 29.12.2013, 23:59:59
  659. ];
  660. foreach ($values as $year => $expected) {
  661. $ret = $this->Time->cweekEnding($year);
  662. //$this->out($ret);
  663. //$this->out($this->Time->niceDate($ret, 'D') . ' ' . $this->Time->niceDate($ret, FORMAT_NICE_YMDHMS));
  664. //$this->assertSame($expected, $ret);
  665. $this->assertTrue($ret <= $expected + HOUR && $ret >= $expected);
  666. }
  667. $values = [
  668. ['2001', '1', 978908399], # Sun 07.01.2001, 23:59:59
  669. ['2001', '2', 979513199], # Sun 14.01.2001, 23:59:59
  670. ['2001', '5', 981327599], # Sun 04.02.2001, 23:59:59
  671. ['2001', '52', 1009753199], # Sun 30.12.2001, 23:59:59
  672. ['2013', '11', 1363561199], # Sun 17.03.2013, 23:59:59
  673. ['2006', '3', 1137970799], # Sun 22.01.2006, 23:59:59
  674. ];
  675. foreach ($values as $v) {
  676. $ret = $this->Time->cweekEnding($v[0], $v[1]);
  677. //$this->out($ret);
  678. //$this->out($this->Time->niceDate($ret, 'D') . ' ' . $this->Time->niceDate($ret, FORMAT_NICE_YMDHMS));
  679. //$this->assertSame($v[2], $ret, null, $v[1].'/'.$v[0]);
  680. $this->assertTrue($ret <= $v[2] + HOUR && $ret >= $v[2]);
  681. }
  682. }
  683. /**
  684. * TimeTest::testAgeRange()
  685. *
  686. * @return void
  687. */
  688. public function testAgeRange() {
  689. $is = $this->Time->ageRange(2000);
  690. $this->assertEquals(date('Y') - 2000 - 1, $is);
  691. $is = $this->Time->ageRange(date('Y') - 11, null, null, 5);
  692. $this->assertEquals([6, 10], $is);
  693. $is = $this->Time->ageRange(date('Y') - 13, null, null, 5);
  694. $this->assertEquals([11, 15], $is);
  695. $is = $this->Time->ageRange(1985, 23, 11);
  696. $this->assertEquals(date('Y') - 1985 - 1, $is);
  697. $is = $this->Time->ageRange(date('Y') - 29, null, null, 6);
  698. $this->assertEquals([25, 30], $is);
  699. $is = $this->Time->ageRange(date('Y') - 29, 21, 11, 7);
  700. $this->assertEquals([22, 28], $is);
  701. }
  702. /**
  703. * TimeTest::testParseDate()
  704. *
  705. * @return void
  706. */
  707. public function testParseLocalDate() {
  708. //echo $this->_header(__FUNCTION__);
  709. $tests = [
  710. '2010-12-11' => 1292022000,
  711. '2010-01-02' => 1262386800,
  712. '10-01-02' => 1262386800,
  713. '2.1.2010' => 1262386800,
  714. '2.1.10' => 1262386800,
  715. '02.01.10' => 1262386800,
  716. '02.01.2010' => 1262386800,
  717. '02.01.2010 22:11' => 1262386800,
  718. '2010-01-02 22:11' => 1262386800,
  719. ];
  720. foreach ($tests as $was => $expected) {
  721. $is = $this->Time->parseLocalDate($was);
  722. $this->assertTrue($is <= $expected + HOUR && $is >= $expected);
  723. }
  724. }
  725. /**
  726. * TimeTest::testParseTime()
  727. *
  728. * @return void
  729. */
  730. public function testParseLocalTime() {
  731. //echo $this->_header(__FUNCTION__);
  732. $tests = [
  733. '2:4' => 7440,
  734. '2:04' => 7440,
  735. '2' => 7200,
  736. '1,5' => 3600 + 1800,
  737. '1.5' => 3600 + 1800,
  738. '1.50' => 3600 + 1800,
  739. '1.01' => 3660,
  740. ':4' => 240,
  741. ':04' => 240,
  742. ':40' => 40 * MINUTE,
  743. '1:2:4' => 1 * HOUR + 2 * MINUTE + 4 * SECOND,
  744. '01:2:04' => 1 * HOUR + 2 * MINUTE + 4 * SECOND,
  745. '0:2:04' => 2 * MINUTE + 4 * SECOND,
  746. '::4' => 4 * SECOND,
  747. '::04' => 4 * SECOND,
  748. '::40' => 40 * SECOND,
  749. '2011-11-12 10:10:10' => 10 * HOUR + 10 * MINUTE + 10 * SECOND,
  750. ];
  751. // positive
  752. foreach ($tests as $was => $expected) {
  753. $is = $this->Time->parseLocalTime($was);
  754. //pr($is);
  755. $this->assertEquals($expected, $is);
  756. }
  757. unset($tests['2011-11-12 10:10:10']);
  758. // negative
  759. foreach ($tests as $was => $expected) {
  760. $is = $this->Time->parseLocalTime('-' . $was);
  761. //pr($is);
  762. $this->assertEquals(-$expected, $is);
  763. }
  764. }
  765. /**
  766. * TimeTest::testBuildTime()
  767. *
  768. * @return void
  769. */
  770. public function testDuration() {
  771. $tests = [
  772. 7440 => '2:04:00',
  773. 7220 => '2:00:20',
  774. 5400 => '1:30:00',
  775. 3660 => '1:01:00',
  776. ];
  777. // positive
  778. foreach ($tests as $was => $expected) {
  779. $is = $this->Time->duration($was);
  780. //pr($is);
  781. $this->assertEquals($expected, $is);
  782. }
  783. // M:SS
  784. $tests = [
  785. 7440 => '124:00',
  786. ];
  787. foreach ($tests as $was => $expected) {
  788. $is = $this->Time->duration($was, '%i:%S');
  789. //pr($is);
  790. $this->assertEquals($expected, $is);
  791. }
  792. }
  793. /**
  794. * TimeTest::testBuildTime()
  795. *
  796. * @return void
  797. */
  798. public function testBuildTime() {
  799. //echo $this->_header(__FUNCTION__);
  800. $tests = [
  801. 7440 => '2:04:00',
  802. 7220 => '2:00:20',
  803. 5400 => '1:30:00',
  804. 3660 => '1:01:00',
  805. 43202 => '12:00:02',
  806. ];
  807. // positive
  808. foreach ($tests as $was => $expected) {
  809. $is = $this->Time->buildTime($was);
  810. //pr($is);
  811. $this->assertEquals($expected, $is);
  812. }
  813. // negative
  814. foreach ($tests as $was => $expected) {
  815. $is = $this->Time->buildTime(-$was);
  816. //pr($is);
  817. $this->assertEquals('-' . $expected, $is);
  818. }
  819. $tests = [
  820. 7220 => '2:00', # 02:00:20 => rounded to 2:00:00
  821. 7441 => '2:04',
  822. 43202 => '12:00',
  823. ];
  824. // positive
  825. foreach ($tests as $was => $expected) {
  826. $is = $this->Time->buildTime($was, 'H:MM');
  827. //pr($is);
  828. $this->assertEquals($expected, $is);
  829. }
  830. // using DateTime interval
  831. $datetime1 = new DateTime('2009-10-11 13:13:13');
  832. $datetime2 = new DateTime('2009-10-12 13:13:15');
  833. $interval = $datetime1->diff($datetime2);
  834. $result = $this->Time->buildTime($interval, 'H:MM:SS');
  835. $this->assertEquals('24:00:02', $result);
  836. // using Time/Carbon
  837. $start = new DateTime();
  838. $end = (new DateTime())->addMinutes(3);
  839. $diff = $end->diffInSeconds($start);
  840. $result = $this->Time->buildTime($diff, 'H:MM:SS');
  841. $this->assertEquals('0:03:00', $result);
  842. $result = $this->Time->buildTime($diff, 'M:SS');
  843. $this->assertEquals('3:00', $result);
  844. }
  845. /**
  846. * TimeTest::testBuildDefaultTime()
  847. *
  848. * @return void
  849. */
  850. public function testBuildDefaultTime() {
  851. //echo $this->_header(__FUNCTION__);
  852. $tests = [
  853. 7440 => '02:04:00',
  854. 7220 => '02:00:20',
  855. 5400 => '01:30:00',
  856. 3660 => '01:01:00',
  857. 1 * HOUR + 2 * MINUTE + 4 * SECOND => '01:02:04',
  858. ];
  859. foreach ($tests as $was => $expected) {
  860. $is = $this->Time->buildDefaultTime($was);
  861. //pr($is);
  862. $this->assertEquals($expected, $is);
  863. }
  864. }
  865. /**
  866. * 9.30 => 9.50
  867. *
  868. * @return void
  869. */
  870. public function testStandardDecimal() {
  871. //echo $this->_header(__FUNCTION__);
  872. $value = '9.30';
  873. $is = $this->Time->standardToDecimalTime($value);
  874. $this->assertEquals('9.50', round($is, 2));
  875. $value = '9.3';
  876. $is = $this->Time->standardToDecimalTime($value);
  877. $this->assertEquals('9.50', round($is, 2));
  878. }
  879. /**
  880. * 9.50 => 9.30
  881. *
  882. * @return void
  883. */
  884. public function testDecimalStandard() {
  885. //echo $this->_header(__FUNCTION__);
  886. $value = '9.50';
  887. $is = $this->Time->decimalToStandardTime($value);
  888. $this->assertEquals('9.3', round($is, 2));
  889. $value = '9.5';
  890. $is = $this->Time->decimalToStandardTime($value);
  891. //pr($is);
  892. $this->assertEquals('9.3', $is);
  893. $is = $this->Time->decimalToStandardTime($value, 2);
  894. //pr($is);
  895. $this->assertEquals('9.30', $is);
  896. $is = $this->Time->decimalToStandardTime($value, 2, ':');
  897. //pr($is);
  898. $this->assertEquals('9:30', $is);
  899. }
  900. /**
  901. * TimeTest::testHasDaylightSavingTime()
  902. *
  903. * @return void
  904. */
  905. public function testHasDaylightSavingTime() {
  906. $timezone = 'Europe/Berlin';
  907. $x = $this->Time->hasDaylightSavingTime($timezone);
  908. $this->assertTrue($x);
  909. $timezone = 'Asia/Baghdad';
  910. $x = $this->Time->hasDaylightSavingTime($timezone);
  911. $this->assertFalse($x);
  912. }
  913. /**
  914. * TimeTest::testTimezone()
  915. *
  916. * @return void
  917. */
  918. public function testGetTimezone() {
  919. $timezone = $this->Time->getTimezone();
  920. // usually UTC
  921. $name = $timezone->getName();
  922. //$this->debug($name);
  923. $this->assertTrue(!empty($name));
  924. $location = $timezone->getLocation();
  925. //$this->debug($location);
  926. $this->assertTrue(!empty($location['country_code']));
  927. $this->assertTrue(isset($location['latitude']));
  928. $this->assertTrue(isset($location['longitude']));
  929. $offset = $timezone->getOffset(new CoreDateTime('@' . mktime(0, 0, 0, 1, 1, date('Y'))));
  930. //$this->debug($offset);
  931. $phpTimezone = date_default_timezone_get();
  932. $this->assertEquals($name, $phpTimezone);
  933. }
  934. }