FrozenTimeTest.php 31 KB

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