Added unit tests for relative_modified_date, changed method signature
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.
This commit is contained in:
parent
ed14541aea
commit
b0bb64c3ee
3 changed files with 204 additions and 10 deletions
|
@ -100,17 +100,20 @@ function strip_time($timestamp){
|
||||||
* @brief Formats timestamp relatively to the current time using
|
* @brief Formats timestamp relatively to the current time using
|
||||||
* a human-friendly format like "x minutes ago" or "yesterday"
|
* a human-friendly format like "x minutes ago" or "yesterday"
|
||||||
* @param int $timestamp timestamp to format
|
* @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
|
* @param bool $dateOnly whether to strip time information
|
||||||
* @return formatted timestamp
|
* @return formatted timestamp
|
||||||
*/
|
*/
|
||||||
function relative_modified_date($timestamp, $dateOnly = false) {
|
function relative_modified_date($timestamp, $fromTime, $dateOnly = false) {
|
||||||
$l=OC_L10N::get('lib');
|
$l=OC_L10N::get('lib');
|
||||||
$time = time();
|
if (!isset($fromTime)){
|
||||||
|
$fromTime = time();
|
||||||
|
}
|
||||||
if ($dateOnly){
|
if ($dateOnly){
|
||||||
$time = strip_time($time);
|
$fromTime = strip_time($fromTime);
|
||||||
$timestamp = strip_time($timestamp);
|
$timestamp = strip_time($timestamp);
|
||||||
}
|
}
|
||||||
$timediff = $time - $timestamp;
|
$timediff = $fromTime - $timestamp;
|
||||||
$diffminutes = round($timediff/60);
|
$diffminutes = round($timediff/60);
|
||||||
$diffhours = round($diffminutes/60);
|
$diffhours = round($diffminutes/60);
|
||||||
$diffdays = round($diffhours/24);
|
$diffdays = round($diffhours/24);
|
||||||
|
@ -119,11 +122,14 @@ function relative_modified_date($timestamp, $dateOnly = false) {
|
||||||
if(!$dateOnly && $timediff < 60) { return $l->t('seconds ago'); }
|
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 < 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(!$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', $fromTime)-$diffhours) >= 0) { return $l->t('today'); }
|
||||||
else if((date('G', $time)-$diffhours) >= -24) { return $l->t('yesterday'); }
|
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); }
|
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($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 if($timediff < 63113852) { return $l->t('last year'); }
|
||||||
else { return $l->t('years ago'); }
|
else { return $l->t('years ago'); }
|
||||||
}
|
}
|
||||||
|
|
|
@ -90,8 +90,8 @@ function human_file_size( $bytes ) {
|
||||||
* @param $timestamp unix timestamp
|
* @param $timestamp unix timestamp
|
||||||
* @returns human readable interpretation of the timestamp
|
* @returns human readable interpretation of the timestamp
|
||||||
*/
|
*/
|
||||||
function relative_modified_date($timestamp, $dateOnly = false) {
|
function relative_modified_date($timestamp, $fromTime, $dateOnly = false) {
|
||||||
return(\relative_modified_date($timestamp, $dateOnly));
|
return(\relative_modified_date($timestamp, $fromTime, $dateOnly));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -46,7 +46,6 @@ class Test_TemplateFunctions extends PHPUnit_Framework_TestCase {
|
||||||
$this->assertEquals("This is a good string!", $result);
|
$this->assertEquals("This is a good string!", $result);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
public function testPrintUnescaped() {
|
public function testPrintUnescaped() {
|
||||||
$htmlString = "<script>alert('xss');</script>";
|
$htmlString = "<script>alert('xss');</script>";
|
||||||
|
|
||||||
|
@ -66,5 +65,194 @@ class Test_TemplateFunctions extends PHPUnit_Framework_TestCase {
|
||||||
$this->assertEquals("This is a good string!", $result);
|
$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);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue