TimeTest.php 33 KB

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