TimeTest.php 33 KB

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