TimeTest.php 31 KB

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