DateTimeTest.php 32 KB

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