]> source.dussan.org Git - nextcloud-server.git/commitdiff
Added unit tests for relative_modified_date, changed method signature
authorVincent Petry <pvince81@owncloud.com>
Wed, 2 Oct 2013 18:16:35 +0000 (20:16 +0200)
committerVincent Petry <pvince81@owncloud.com>
Thu, 3 Oct 2013 11:55:05 +0000 (13:55 +0200)
Changed method signature of relative_modified_date template method to
make it possible to add a fromTime to compare with, mostly to make it
possible to test it.

Added unit test for date and time cases.

lib/private/template/functions.php
lib/public/template.php
tests/lib/template.php

index 6002113bdd998a3a1bd5feec41b2738d52501099..858134dd8c6043532588fc4478dc90796e02d4fc 100644 (file)
@@ -100,17 +100,20 @@ function strip_time($timestamp){
  * @brief Formats timestamp relatively to the current time using
  * a human-friendly format like "x minutes ago" or "yesterday"
  * @param int $timestamp timestamp to format
+ * @param int $fromTime timestamp to compare from, defaults to current time
  * @param bool $dateOnly whether to strip time information
  * @return formatted timestamp
  */
-function relative_modified_date($timestamp, $dateOnly = false) {
+function relative_modified_date($timestamp, $fromTime, $dateOnly = false) {
        $l=OC_L10N::get('lib');
-       $time = time();
+       if (!isset($fromTime)){
+               $fromTime = time();
+       }
        if ($dateOnly){
-               $time = strip_time($time);
+               $fromTime = strip_time($fromTime);
                $timestamp = strip_time($timestamp);
        }
-       $timediff = $time - $timestamp;
+       $timediff = $fromTime - $timestamp;
        $diffminutes = round($timediff/60);
        $diffhours = round($diffminutes/60);
        $diffdays = round($diffhours/24);
@@ -119,11 +122,14 @@ function relative_modified_date($timestamp, $dateOnly = false) {
        if(!$dateOnly && $timediff < 60) { return $l->t('seconds ago'); }
        else if(!$dateOnly && $timediff < 3600) { return $l->n('%n minute ago', '%n minutes ago', $diffminutes); }
        else if(!$dateOnly && $timediff < 86400) { return $l->n('%n hour ago', '%n hours ago', $diffhours); }
-       else if((date('G', $time)-$diffhours) >= 0) { return $l->t('today'); }
-       else if((date('G', $time)-$diffhours) >= -24) { return $l->t('yesterday'); }
+       else if((date('G', $fromTime)-$diffhours) >= 0) { return $l->t('today'); }
+       else if((date('G', $fromTime)-$diffhours) >= -24) { return $l->t('yesterday'); }
+       // 86400 * 31 days = 2678400
        else if($timediff < 2678400) { return $l->n('%n day go', '%n days ago', $diffdays); }
+       // 86400 * 60 days = 518400
        else if($timediff < 5184000) { return $l->t('last month'); }
-       else if((date('n', $time)-$diffmonths) > 0) { return $l->n('%n month ago', '%n months ago', $diffmonths); }
+       else if((date('n', $fromTime)-$diffmonths) > 0) { return $l->n('%n month ago', '%n months ago', $diffmonths); }
+       // 86400 * 365.25 days * 2 = 63113852
        else if($timediff < 63113852) { return $l->t('last year'); }
        else { return $l->t('years ago'); }
 }
index b3bffaf1af9b8edc4f7318dabe292a7b2baa094b..6349501272fb93e6323d2e91c3aadcc0d5c0bf88 100644 (file)
@@ -90,8 +90,8 @@ function human_file_size( $bytes ) {
  * @param $timestamp unix timestamp
  * @returns human readable interpretation of the timestamp
  */
-function relative_modified_date($timestamp, $dateOnly = false) {
-       return(\relative_modified_date($timestamp, $dateOnly));
+function relative_modified_date($timestamp, $fromTime, $dateOnly = false) {
+       return(\relative_modified_date($timestamp, $fromTime, $dateOnly));
 }
 
 
index fd12119da580aa5ed241a0784cdd4de389c27ae6..b4f1a4c40533f9b8cf1d587763ae83de7fe49388 100644 (file)
@@ -46,7 +46,6 @@ class Test_TemplateFunctions extends PHPUnit_Framework_TestCase {
                $this->assertEquals("This is a good string!", $result);
        }
 
-
        public function testPrintUnescaped() {
                $htmlString = "<script>alert('xss');</script>";
 
@@ -66,5 +65,194 @@ class Test_TemplateFunctions extends PHPUnit_Framework_TestCase {
                $this->assertEquals("This is a good string!", $result);
        }
 
+       // ---------------------------------------------------------------------------
+       // Test relative_modified_date with dates only
+       // ---------------------------------------------------------------------------
+       public function testRelativeDateToday(){
+               $currentTime = 1380703592;
+               $elementTime = $currentTime;
+               $result = (string)relative_modified_date($elementTime, $currentTime, true);
+
+               $this->assertEquals('today', $result);
+
+               // 2 hours ago is still today
+               $elementTime = $currentTime - 2 * 3600;
+               $result = (string)relative_modified_date($elementTime, $currentTime, true);
+
+               $this->assertEquals('today', $result);
+       }
+
+       public function testRelativeDateYesterday(){
+               $currentTime = 1380703592;
+               $elementTime = $currentTime - 24 * 3600;
+               $result = (string)relative_modified_date($elementTime, $currentTime, true);
+
+               $this->assertEquals('yesterday', $result);
+
+               // yesterday - 2 hours is still yesterday
+               $elementTime = $currentTime - 26 * 3600;
+               $result = (string)relative_modified_date($elementTime, $currentTime, true);
+
+               $this->assertEquals('yesterday', $result);
+       }
+
+       public function testRelativeDate2DaysAgo(){
+               $currentTime = 1380703592;
+               $elementTime = $currentTime - 48 * 3600;
+               $result = (string)relative_modified_date($elementTime, $currentTime, true);
+
+               $this->assertEquals('2 days ago', $result);
+
+               // 2 days ago minus 4 hours is still 2 days ago
+               $elementTime = $currentTime - 52 * 3600;
+               $result = (string)relative_modified_date($elementTime, $currentTime, true);
+
+               $this->assertEquals('2 days ago', $result);
+       }
+
+       public function testRelativeDateLastMonth(){
+               $currentTime = 1380703592;
+               $elementTime = $currentTime - 86400 * 31;
+               $result = (string)relative_modified_date($elementTime, $currentTime, true);
+
+               $this->assertEquals('last month', $result);
+
+               $elementTime = $currentTime - 86400 * 35;
+               $result = (string)relative_modified_date($elementTime, $currentTime, true);
+
+               $this->assertEquals('last month', $result);
+       }
+
+       public function testRelativeDateMonthsAgo(){
+               $currentTime = 1380703592;
+               $elementTime = $currentTime - 86400 * 60;
+               $result = (string)relative_modified_date($elementTime, $currentTime, true);
+
+               $this->assertEquals('2 months ago', $result);
+
+               $elementTime = $currentTime - 86400 * 65;
+               $result = (string)relative_modified_date($elementTime, $currentTime, true);
+
+               $this->assertEquals('2 months ago', $result);
+       }
+
+       public function testRelativeDateLastYear(){
+               $currentTime = 1380703592;
+               $elementTime = $currentTime - 86400 * 365;
+               $result = (string)relative_modified_date($elementTime, $currentTime, true);
+
+               $this->assertEquals('last year', $result);
+
+               $elementTime = $currentTime - 86400 * 450;
+               $result = (string)relative_modified_date($elementTime, $currentTime, true);
+
+               $this->assertEquals('last year', $result);
+       }
+
+       public function testRelativeDateYearsAgo(){
+               $currentTime = 1380703592;
+               $elementTime = $currentTime - 86400 * 365.25 * 2;
+               $result = (string)relative_modified_date($elementTime, $currentTime, true);
+
+               $this->assertEquals('years ago', $result);
+
+               $elementTime = $currentTime - 86400 * 365.25 * 3;
+               $result = (string)relative_modified_date($elementTime, $currentTime, true);
+
+               $this->assertEquals('years ago', $result);
+       }
 
+       // ---------------------------------------------------------------------------
+       // Test relative_modified_date with timestamps only (date + time value)
+       // ---------------------------------------------------------------------------
+
+       public function testRelativeTimeSecondsAgo(){
+               $currentTime = 1380703592;
+               $elementTime = $currentTime - 5;
+               $result = (string)relative_modified_date($elementTime, $currentTime, false);
+
+               $this->assertEquals('seconds ago', $result);
+       }
+
+       public function testRelativeTimeMinutesAgo(){
+               $currentTime = 1380703592;
+               $elementTime = $currentTime - 190;
+               $result = (string)relative_modified_date($elementTime, $currentTime, false);
+
+               $this->assertEquals('3 minutes ago', $result);
+       }
+
+       public function testRelativeTimeHoursAgo(){
+               $currentTime = 1380703592;
+               $elementTime = $currentTime - 7500;
+               $result = (string)relative_modified_date($elementTime, $currentTime, false);
+
+               $this->assertEquals('2 hours ago', $result);
+       }
+
+       public function testRelativeTime2DaysAgo(){
+               $currentTime = 1380703592;
+               $elementTime = $currentTime - 48 * 3600;
+               $result = (string)relative_modified_date($elementTime, $currentTime, false);
+
+               $this->assertEquals('2 days ago', $result);
+
+               // 2 days ago minus 4 hours is still 2 days ago
+               $elementTime = $currentTime - 52 * 3600;
+               $result = (string)relative_modified_date($elementTime, $currentTime, false);
+
+               $this->assertEquals('2 days ago', $result);
+       }
+
+       public function testRelativeTimeLastMonth(){
+               $currentTime = 1380703592;
+               $elementTime = $currentTime - 86400 * 31;
+               $result = (string)relative_modified_date($elementTime, $currentTime, false);
+
+               $this->assertEquals('last month', $result);
+
+               $elementTime = $currentTime - 86400 * 35;
+               $result = (string)relative_modified_date($elementTime, $currentTime, false);
+
+               $this->assertEquals('last month', $result);
+       }
+
+       public function testRelativeTimeMonthsAgo(){
+               $currentTime = 1380703592;
+               $elementTime = $currentTime - 86400 * 60;
+               $result = (string)relative_modified_date($elementTime, $currentTime, false);
+
+               $this->assertEquals('2 months ago', $result);
+
+               $elementTime = $currentTime - 86400 * 65;
+               $result = (string)relative_modified_date($elementTime, $currentTime, false);
+
+               $this->assertEquals('2 months ago', $result);
+       }
+
+       public function testRelativeTimeLastYear(){
+               $currentTime = 1380703592;
+               $elementTime = $currentTime - 86400 * 365;
+               $result = (string)relative_modified_date($elementTime, $currentTime, false);
+
+               $this->assertEquals('last year', $result);
+
+               $elementTime = $currentTime - 86400 * 450;
+               $result = (string)relative_modified_date($elementTime, $currentTime, false);
+
+               $this->assertEquals('last year', $result);
+       }
+
+       public function testRelativeTimeYearsAgo(){
+               $currentTime = 1380703592;
+               $elementTime = $currentTime - 86400 * 365.25 * 2;
+               $result = (string)relative_modified_date($elementTime, $currentTime, false);
+
+               $this->assertEquals('years ago', $result);
+
+               $elementTime = $currentTime - 86400 * 365.25 * 3;
+               $result = (string)relative_modified_date($elementTime, $currentTime, false);
+
+               $this->assertEquals('years ago', $result);
+       }
 }