Merge pull request #271 from virtualtam/php53
PHP: ensure 5.3 compatibility
This commit is contained in:
commit
874f858b8f
10 changed files with 288 additions and 102 deletions
|
@ -3,6 +3,7 @@ php:
|
||||||
- 5.6
|
- 5.6
|
||||||
- 5.5
|
- 5.5
|
||||||
- 5.4
|
- 5.4
|
||||||
|
- 5.3
|
||||||
install:
|
install:
|
||||||
- composer self-update
|
- composer self-update
|
||||||
- composer install
|
- composer install
|
||||||
|
|
|
@ -57,7 +57,7 @@ Password: `demo`
|
||||||
|
|
||||||
## Installing
|
## Installing
|
||||||
|
|
||||||
Shaarli requires php 5.4. `php-gd` is optional and provides thumbnail resizing.
|
Shaarli requires PHP 5.3. `php-gd` is optional and provides thumbnail resizing.
|
||||||
|
|
||||||
* Download the latest stable release from https://github.com/shaarli/Shaarli/releases
|
* Download the latest stable release from https://github.com/shaarli/Shaarli/releases
|
||||||
* Unpack the archive in a directory on your web server
|
* Unpack the archive in a directory on your web server
|
||||||
|
|
|
@ -19,10 +19,10 @@
|
||||||
function writeConfig($config, $isLoggedIn)
|
function writeConfig($config, $isLoggedIn)
|
||||||
{
|
{
|
||||||
// These fields are required in configuration.
|
// These fields are required in configuration.
|
||||||
$MANDATORY_FIELDS = [
|
$MANDATORY_FIELDS = array(
|
||||||
'login', 'hash', 'salt', 'timezone', 'title', 'titleLink',
|
'login', 'hash', 'salt', 'timezone', 'title', 'titleLink',
|
||||||
'redirector', 'disablesessionprotection', 'privateLinkByDefault'
|
'redirector', 'disablesessionprotection', 'privateLinkByDefault'
|
||||||
];
|
);
|
||||||
|
|
||||||
if (!isset($config['config']['CONFIG_FILE'])) {
|
if (!isset($config['config']['CONFIG_FILE'])) {
|
||||||
throw new MissingFieldConfigException('CONFIG_FILE');
|
throw new MissingFieldConfigException('CONFIG_FILE');
|
||||||
|
|
110
application/TimeZone.php
Normal file
110
application/TimeZone.php
Normal file
|
@ -0,0 +1,110 @@
|
||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* Generates the timezone selection form and JavaScript.
|
||||||
|
*
|
||||||
|
* Note: 'UTC/UTC' is mapped to 'UTC' to form a valid option
|
||||||
|
*
|
||||||
|
* Example: preselect Europe/Paris
|
||||||
|
* list($htmlform, $js) = templateTZform('Europe/Paris');
|
||||||
|
*
|
||||||
|
* @param string $preselected_timezone preselected timezone (optional)
|
||||||
|
*
|
||||||
|
* @return an array containing the generated HTML form and Javascript code
|
||||||
|
**/
|
||||||
|
function generateTimeZoneForm($preselected_timezone='')
|
||||||
|
{
|
||||||
|
// Select the first available timezone if no preselected value is passed
|
||||||
|
if ($preselected_timezone == '') {
|
||||||
|
$l = timezone_identifiers_list();
|
||||||
|
$preselected_timezone = $l[0];
|
||||||
|
}
|
||||||
|
|
||||||
|
// Try to split the provided timezone
|
||||||
|
$spos = strpos($preselected_timezone, '/');
|
||||||
|
$pcontinent = substr($preselected_timezone, 0, $spos);
|
||||||
|
$pcity = substr($preselected_timezone, $spos+1);
|
||||||
|
|
||||||
|
// Display config form:
|
||||||
|
$timezone_form = '';
|
||||||
|
$timezone_js = '';
|
||||||
|
|
||||||
|
// The list is in the form 'Europe/Paris', 'America/Argentina/Buenos_Aires'...
|
||||||
|
// We split the list in continents/cities.
|
||||||
|
$continents = array();
|
||||||
|
$cities = array();
|
||||||
|
|
||||||
|
// TODO: use a template to generate the HTML/Javascript form
|
||||||
|
|
||||||
|
foreach (timezone_identifiers_list() as $tz) {
|
||||||
|
if ($tz == 'UTC') {
|
||||||
|
$tz = 'UTC/UTC';
|
||||||
|
}
|
||||||
|
$spos = strpos($tz, '/');
|
||||||
|
|
||||||
|
if ($spos !== false) {
|
||||||
|
$continent = substr($tz, 0, $spos);
|
||||||
|
$city = substr($tz, $spos+1);
|
||||||
|
$continents[$continent] = 1;
|
||||||
|
|
||||||
|
if (!isset($cities[$continent])) {
|
||||||
|
$cities[$continent] = '';
|
||||||
|
}
|
||||||
|
$cities[$continent] .= '<option value="'.$city.'"';
|
||||||
|
if ($pcity == $city) {
|
||||||
|
$cities[$continent] .= ' selected="selected"';
|
||||||
|
}
|
||||||
|
$cities[$continent] .= '>'.$city.'</option>';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
$continents_html = '';
|
||||||
|
$continents = array_keys($continents);
|
||||||
|
|
||||||
|
foreach ($continents as $continent) {
|
||||||
|
$continents_html .= '<option value="'.$continent.'"';
|
||||||
|
if ($pcontinent == $continent) {
|
||||||
|
$continents_html .= ' selected="selected"';
|
||||||
|
}
|
||||||
|
$continents_html .= '>'.$continent.'</option>';
|
||||||
|
}
|
||||||
|
|
||||||
|
// Timezone selection form
|
||||||
|
$timezone_form = 'Continent:';
|
||||||
|
$timezone_form .= '<select name="continent" id="continent" onChange="onChangecontinent();">';
|
||||||
|
$timezone_form .= $continents_html.'</select>';
|
||||||
|
$timezone_form .= ' City:';
|
||||||
|
$timezone_form .= '<select name="city" id="city">'.$cities[$pcontinent].'</select><br />';
|
||||||
|
|
||||||
|
// Javascript handler - updates the city list when the user selects a continent
|
||||||
|
$timezone_js = '<script>';
|
||||||
|
$timezone_js .= 'function onChangecontinent() {';
|
||||||
|
$timezone_js .= 'document.getElementById("city").innerHTML =';
|
||||||
|
$timezone_js .= ' citiescontinent[document.getElementById("continent").value]; }';
|
||||||
|
$timezone_js .= 'var citiescontinent = '.json_encode($cities).';';
|
||||||
|
$timezone_js .= '</script>';
|
||||||
|
|
||||||
|
return array($timezone_form, $timezone_js);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Tells if a continent/city pair form a valid timezone
|
||||||
|
*
|
||||||
|
* Note: 'UTC/UTC' is mapped to 'UTC'
|
||||||
|
*
|
||||||
|
* @param string $continent the timezone continent
|
||||||
|
* @param string $city the timezone city
|
||||||
|
*
|
||||||
|
* @return whether continent/city is a valid timezone
|
||||||
|
*/
|
||||||
|
function isTimeZoneValid($continent, $city)
|
||||||
|
{
|
||||||
|
if ($continent == 'UTC' && $city == 'UTC') {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
return in_array(
|
||||||
|
$continent.'/'.$city,
|
||||||
|
timezone_identifiers_list()
|
||||||
|
);
|
||||||
|
}
|
||||||
|
?>
|
|
@ -117,3 +117,24 @@ function generateLocation($referer, $host, $loopTerms = array())
|
||||||
|
|
||||||
return $final_referer;
|
return $final_referer;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Checks the PHP version to ensure Shaarli can run
|
||||||
|
*
|
||||||
|
* @param string $minVersion minimum PHP required version
|
||||||
|
* @param string $curVersion current PHP version (use PHP_VERSION)
|
||||||
|
*
|
||||||
|
* @throws Exception the PHP version is not supported
|
||||||
|
*/
|
||||||
|
function checkPHPVersion($minVersion, $curVersion)
|
||||||
|
{
|
||||||
|
if (version_compare($curVersion, $minVersion) < 0) {
|
||||||
|
throw new Exception(
|
||||||
|
'Your PHP version is obsolete!'
|
||||||
|
.' Shaarli requires at least PHP '.$minVersion.', and thus cannot run.'
|
||||||
|
.' Your PHP version has known security vulnerabilities and should be'
|
||||||
|
.' updated as soon as possible.'
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
?>
|
||||||
|
|
109
index.php
109
index.php
|
@ -3,7 +3,7 @@
|
||||||
// The personal, minimalist, super-fast, no-database Delicious clone. By sebsauvage.net
|
// The personal, minimalist, super-fast, no-database Delicious clone. By sebsauvage.net
|
||||||
// http://sebsauvage.net/wiki/doku.php?id=php:shaarli
|
// http://sebsauvage.net/wiki/doku.php?id=php:shaarli
|
||||||
// Licence: http://www.opensource.org/licenses/zlib-license.php
|
// Licence: http://www.opensource.org/licenses/zlib-license.php
|
||||||
// Requires: PHP 5.1.x (but autocomplete fields will only work if you have PHP 5.2.x)
|
// Requires: PHP 5.3.x
|
||||||
// -----------------------------------------------------------------------------------------------
|
// -----------------------------------------------------------------------------------------------
|
||||||
// NEVER TRUST IN PHP.INI
|
// NEVER TRUST IN PHP.INI
|
||||||
// Some hosts do not define a default timezone in php.ini,
|
// Some hosts do not define a default timezone in php.ini,
|
||||||
|
@ -59,7 +59,6 @@
|
||||||
ini_set('memory_limit', '128M'); // Try to set max upload file size and read (May not work on some hosts).
|
ini_set('memory_limit', '128M'); // Try to set max upload file size and read (May not work on some hosts).
|
||||||
ini_set('post_max_size', '16M');
|
ini_set('post_max_size', '16M');
|
||||||
ini_set('upload_max_filesize', '16M');
|
ini_set('upload_max_filesize', '16M');
|
||||||
checkphpversion();
|
|
||||||
error_reporting(E_ALL^E_WARNING); // See all error except warnings.
|
error_reporting(E_ALL^E_WARNING); // See all error except warnings.
|
||||||
//error_reporting(-1); // See all errors (for debugging only)
|
//error_reporting(-1); // See all errors (for debugging only)
|
||||||
|
|
||||||
|
@ -70,9 +69,19 @@
|
||||||
|
|
||||||
// Shaarli library
|
// Shaarli library
|
||||||
require_once 'application/LinkDB.php';
|
require_once 'application/LinkDB.php';
|
||||||
|
require_once 'application/TimeZone.php';
|
||||||
require_once 'application/Utils.php';
|
require_once 'application/Utils.php';
|
||||||
require_once 'application/Config.php';
|
require_once 'application/Config.php';
|
||||||
|
|
||||||
|
// Ensure the PHP version is supported
|
||||||
|
try {
|
||||||
|
checkPHPVersion('5.3', PHP_VERSION);
|
||||||
|
} catch(Exception $e) {
|
||||||
|
header('Content-Type: text/plain; charset=utf-8');
|
||||||
|
echo $e->getMessage();
|
||||||
|
exit;
|
||||||
|
}
|
||||||
|
|
||||||
include "inc/rain.tpl.class.php"; //include Rain TPL
|
include "inc/rain.tpl.class.php"; //include Rain TPL
|
||||||
raintpl::$tpl_dir = $GLOBALS['config']['RAINTPL_TPL']; // template directory
|
raintpl::$tpl_dir = $GLOBALS['config']['RAINTPL_TPL']; // template directory
|
||||||
raintpl::$cache_dir = $GLOBALS['config']['RAINTPL_TMP']; // cache directory
|
raintpl::$cache_dir = $GLOBALS['config']['RAINTPL_TMP']; // cache directory
|
||||||
|
@ -164,21 +173,7 @@ function setup_login_state() {
|
||||||
|
|
||||||
return $userIsLoggedIn;
|
return $userIsLoggedIn;
|
||||||
}
|
}
|
||||||
//==================================================================================================
|
|
||||||
$userIsLoggedIn = setup_login_state();
|
$userIsLoggedIn = setup_login_state();
|
||||||
//==================================================================================================
|
|
||||||
//==================================================================================================
|
|
||||||
|
|
||||||
// Check PHP version
|
|
||||||
function checkphpversion()
|
|
||||||
{
|
|
||||||
if (version_compare(PHP_VERSION, '5.1.0') < 0)
|
|
||||||
{
|
|
||||||
header('Content-Type: text/plain; charset=utf-8');
|
|
||||||
echo 'Your PHP version is obsolete! Shaarli requires at least php 5.1.0, and thus cannot run. Sorry. Your PHP version has known security vulnerabilities and should be updated as soon as possible.';
|
|
||||||
exit;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Checks if an update is available for Shaarli.
|
// Checks if an update is available for Shaarli.
|
||||||
// (at most once a day, and only for registered user.)
|
// (at most once a day, and only for registered user.)
|
||||||
|
@ -982,7 +977,7 @@ function showDaily()
|
||||||
$linksToDisplay = $LINKSDB->filterDay($day);
|
$linksToDisplay = $LINKSDB->filterDay($day);
|
||||||
} catch (Exception $exc) {
|
} catch (Exception $exc) {
|
||||||
error_log($exc);
|
error_log($exc);
|
||||||
$linksToDisplay = [];
|
$linksToDisplay = array();
|
||||||
}
|
}
|
||||||
|
|
||||||
// We pre-format some fields for proper output.
|
// We pre-format some fields for proper output.
|
||||||
|
@ -1288,7 +1283,7 @@ function renderPage()
|
||||||
if (!tokenOk($_POST['token'])) die('Wrong token.'); // Go away!
|
if (!tokenOk($_POST['token'])) die('Wrong token.'); // Go away!
|
||||||
$tz = 'UTC';
|
$tz = 'UTC';
|
||||||
if (!empty($_POST['continent']) && !empty($_POST['city']))
|
if (!empty($_POST['continent']) && !empty($_POST['city']))
|
||||||
if (isTZvalid($_POST['continent'],$_POST['city']))
|
if (isTimeZoneValid($_POST['continent'],$_POST['city']))
|
||||||
$tz = $_POST['continent'].'/'.$_POST['city'];
|
$tz = $_POST['continent'].'/'.$_POST['city'];
|
||||||
$GLOBALS['timezone'] = $tz;
|
$GLOBALS['timezone'] = $tz;
|
||||||
$GLOBALS['title']=$_POST['title'];
|
$GLOBALS['title']=$_POST['title'];
|
||||||
|
@ -1322,8 +1317,8 @@ function renderPage()
|
||||||
$PAGE->assign('token',getToken());
|
$PAGE->assign('token',getToken());
|
||||||
$PAGE->assign('title', empty($GLOBALS['title']) ? '' : $GLOBALS['title'] );
|
$PAGE->assign('title', empty($GLOBALS['title']) ? '' : $GLOBALS['title'] );
|
||||||
$PAGE->assign('redirector', empty($GLOBALS['redirector']) ? '' : $GLOBALS['redirector'] );
|
$PAGE->assign('redirector', empty($GLOBALS['redirector']) ? '' : $GLOBALS['redirector'] );
|
||||||
list($timezone_form,$timezone_js) = templateTZform($GLOBALS['timezone']);
|
list($timezone_form, $timezone_js) = generateTimeZoneForm($GLOBALS['timezone']);
|
||||||
$PAGE->assign('timezone_form',$timezone_form); // FIXME: Put entire tz form generation in template?
|
$PAGE->assign('timezone_form', $timezone_form);
|
||||||
$PAGE->assign('timezone_js',$timezone_js);
|
$PAGE->assign('timezone_js',$timezone_js);
|
||||||
$PAGE->renderPage('configure');
|
$PAGE->renderPage('configure');
|
||||||
exit;
|
exit;
|
||||||
|
@ -2059,9 +2054,11 @@ function install()
|
||||||
if (!empty($_POST['setlogin']) && !empty($_POST['setpassword']))
|
if (!empty($_POST['setlogin']) && !empty($_POST['setpassword']))
|
||||||
{
|
{
|
||||||
$tz = 'UTC';
|
$tz = 'UTC';
|
||||||
if (!empty($_POST['continent']) && !empty($_POST['city']))
|
if (!empty($_POST['continent']) && !empty($_POST['city'])) {
|
||||||
if (isTZvalid($_POST['continent'],$_POST['city']))
|
if (isTimeZoneValid($_POST['continent'], $_POST['city'])) {
|
||||||
$tz = $_POST['continent'].'/'.$_POST['city'];
|
$tz = $_POST['continent'].'/'.$_POST['city'];
|
||||||
|
}
|
||||||
|
}
|
||||||
$GLOBALS['timezone'] = $tz;
|
$GLOBALS['timezone'] = $tz;
|
||||||
// Everything is ok, let's create config file.
|
// Everything is ok, let's create config file.
|
||||||
$GLOBALS['login'] = $_POST['setlogin'];
|
$GLOBALS['login'] = $_POST['setlogin'];
|
||||||
|
@ -2087,8 +2084,11 @@ function install()
|
||||||
}
|
}
|
||||||
|
|
||||||
// Display config form:
|
// Display config form:
|
||||||
list($timezone_form,$timezone_js) = templateTZform();
|
list($timezone_form, $timezone_js) = generateTimeZoneForm();
|
||||||
$timezone_html=''; if ($timezone_form!='') $timezone_html='<tr><td><b>Timezone:</b></td><td>'.$timezone_form.'</td></tr>';
|
$timezone_html = '';
|
||||||
|
if ($timezone_form != '') {
|
||||||
|
$timezone_html = '<tr><td><b>Timezone:</b></td><td>'.$timezone_form.'</td></tr>';
|
||||||
|
}
|
||||||
|
|
||||||
$PAGE = new pageBuilder;
|
$PAGE = new pageBuilder;
|
||||||
$PAGE->assign('timezone_html',$timezone_html);
|
$PAGE->assign('timezone_html',$timezone_html);
|
||||||
|
@ -2097,67 +2097,6 @@ function install()
|
||||||
exit;
|
exit;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Generates the timezone selection form and JavaScript.
|
|
||||||
// Input: (optional) current timezone (can be 'UTC/UTC'). It will be pre-selected.
|
|
||||||
// Output: array(html,js)
|
|
||||||
// Example: list($htmlform,$js) = templateTZform('Europe/Paris'); // Europe/Paris pre-selected.
|
|
||||||
// Returns array('','') if server does not support timezones list. (e.g. PHP 5.1 on free.fr)
|
|
||||||
function templateTZform($ptz=false)
|
|
||||||
{
|
|
||||||
if (function_exists('timezone_identifiers_list')) // because of old PHP version (5.1) which can be found on free.fr
|
|
||||||
{
|
|
||||||
// Try to split the provided timezone.
|
|
||||||
if ($ptz==false) { $l=timezone_identifiers_list(); $ptz=$l[0]; }
|
|
||||||
$spos=strpos($ptz,'/'); $pcontinent=substr($ptz,0,$spos); $pcity=substr($ptz,$spos+1);
|
|
||||||
|
|
||||||
// Display config form:
|
|
||||||
$timezone_form = '';
|
|
||||||
$timezone_js = '';
|
|
||||||
// The list is in the form "Europe/Paris", "America/Argentina/Buenos_Aires"...
|
|
||||||
// We split the list in continents/cities.
|
|
||||||
$continents = array();
|
|
||||||
$cities = array();
|
|
||||||
foreach(timezone_identifiers_list() as $tz)
|
|
||||||
{
|
|
||||||
if ($tz=='UTC') $tz='UTC/UTC';
|
|
||||||
$spos = strpos($tz,'/');
|
|
||||||
if ($spos!==false)
|
|
||||||
{
|
|
||||||
$continent=substr($tz,0,$spos); $city=substr($tz,$spos+1);
|
|
||||||
$continents[$continent]=1;
|
|
||||||
if (!isset($cities[$continent])) $cities[$continent]='';
|
|
||||||
$cities[$continent].='<option value="'.$city.'"'.($pcity==$city?' selected':'').'>'.$city.'</option>';
|
|
||||||
}
|
|
||||||
}
|
|
||||||
$continents_html = '';
|
|
||||||
$continents = array_keys($continents);
|
|
||||||
foreach($continents as $continent)
|
|
||||||
$continents_html.='<option value="'.$continent.'"'.($pcontinent==$continent?' selected':'').'>'.$continent.'</option>';
|
|
||||||
$cities_html = $cities[$pcontinent];
|
|
||||||
$timezone_form = "Continent: <select name=\"continent\" id=\"continent\" onChange=\"onChangecontinent();\">${continents_html}</select>";
|
|
||||||
$timezone_form .= " City: <select name=\"city\" id=\"city\">${cities[$pcontinent]}</select><br />";
|
|
||||||
$timezone_js = "<script>";
|
|
||||||
$timezone_js .= "function onChangecontinent(){document.getElementById(\"city\").innerHTML = citiescontinent[document.getElementById(\"continent\").value];}";
|
|
||||||
$timezone_js .= "var citiescontinent = ".json_encode($cities).";" ;
|
|
||||||
$timezone_js .= "</script>" ;
|
|
||||||
return array($timezone_form,$timezone_js);
|
|
||||||
}
|
|
||||||
return array('','');
|
|
||||||
}
|
|
||||||
|
|
||||||
// Tells if a timezone is valid or not.
|
|
||||||
// If not valid, returns false.
|
|
||||||
// If system does not support timezone list, returns false.
|
|
||||||
function isTZvalid($continent,$city)
|
|
||||||
{
|
|
||||||
$tz = $continent.'/'.$city;
|
|
||||||
if (function_exists('timezone_identifiers_list')) // because of old PHP version (5.1) which can be found on free.fr
|
|
||||||
{
|
|
||||||
if (in_array($tz, timezone_identifiers_list())) // it's a valid timezone?
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
if (!function_exists('json_encode')) {
|
if (!function_exists('json_encode')) {
|
||||||
function json_encode($data) {
|
function json_encode($data) {
|
||||||
switch ($type = gettype($data)) {
|
switch ($type = gettype($data)) {
|
||||||
|
|
|
@ -18,7 +18,7 @@ class ConfigTest extends PHPUnit_Framework_TestCase
|
||||||
*/
|
*/
|
||||||
public function setUp()
|
public function setUp()
|
||||||
{
|
{
|
||||||
self::$_configFields = [
|
self::$_configFields = array(
|
||||||
'login' => 'login',
|
'login' => 'login',
|
||||||
'hash' => 'hash',
|
'hash' => 'hash',
|
||||||
'salt' => 'salt',
|
'salt' => 'salt',
|
||||||
|
@ -28,13 +28,13 @@ public function setUp()
|
||||||
'redirector' => '',
|
'redirector' => '',
|
||||||
'disablesessionprotection' => false,
|
'disablesessionprotection' => false,
|
||||||
'privateLinkByDefault' => false,
|
'privateLinkByDefault' => false,
|
||||||
'config' => [
|
'config' => array(
|
||||||
'CONFIG_FILE' => 'tests/config.php',
|
'CONFIG_FILE' => 'tests/config.php',
|
||||||
'DATADIR' => 'tests',
|
'DATADIR' => 'tests',
|
||||||
'config1' => 'config1data',
|
'config1' => 'config1data',
|
||||||
'config2' => 'config2data',
|
'config2' => 'config2data',
|
||||||
]
|
)
|
||||||
];
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -228,12 +228,12 @@ public function testCountHiddenPublic()
|
||||||
public function testDays()
|
public function testDays()
|
||||||
{
|
{
|
||||||
$this->assertEquals(
|
$this->assertEquals(
|
||||||
['20121206', '20130614', '20150310'],
|
array('20121206', '20130614', '20150310'),
|
||||||
self::$publicLinkDB->days()
|
self::$publicLinkDB->days()
|
||||||
);
|
);
|
||||||
|
|
||||||
$this->assertEquals(
|
$this->assertEquals(
|
||||||
['20121206', '20130614', '20141125', '20150310'],
|
array('20121206', '20130614', '20141125', '20150310'),
|
||||||
self::$privateLinkDB->days()
|
self::$privateLinkDB->days()
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
@ -269,7 +269,7 @@ public function testGetUnknownLinkFromURL()
|
||||||
public function testAllTags()
|
public function testAllTags()
|
||||||
{
|
{
|
||||||
$this->assertEquals(
|
$this->assertEquals(
|
||||||
[
|
array(
|
||||||
'web' => 3,
|
'web' => 3,
|
||||||
'cartoon' => 2,
|
'cartoon' => 2,
|
||||||
'gnu' => 2,
|
'gnu' => 2,
|
||||||
|
@ -279,12 +279,12 @@ public function testAllTags()
|
||||||
'software' => 1,
|
'software' => 1,
|
||||||
'stallman' => 1,
|
'stallman' => 1,
|
||||||
'free' => 1
|
'free' => 1
|
||||||
],
|
),
|
||||||
self::$publicLinkDB->allTags()
|
self::$publicLinkDB->allTags()
|
||||||
);
|
);
|
||||||
|
|
||||||
$this->assertEquals(
|
$this->assertEquals(
|
||||||
[
|
array(
|
||||||
'web' => 4,
|
'web' => 4,
|
||||||
'cartoon' => 3,
|
'cartoon' => 3,
|
||||||
'gnu' => 2,
|
'gnu' => 2,
|
||||||
|
@ -298,7 +298,7 @@ public function testAllTags()
|
||||||
'w3c' => 1,
|
'w3c' => 1,
|
||||||
'css' => 1,
|
'css' => 1,
|
||||||
'Mercurial' => 1
|
'Mercurial' => 1
|
||||||
],
|
),
|
||||||
self::$privateLinkDB->allTags()
|
self::$privateLinkDB->allTags()
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
83
tests/TimeZoneTest.php
Normal file
83
tests/TimeZoneTest.php
Normal file
|
@ -0,0 +1,83 @@
|
||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* TimeZone's tests
|
||||||
|
*/
|
||||||
|
|
||||||
|
require_once 'application/TimeZone.php';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Unitary tests for timezone utilities
|
||||||
|
*/
|
||||||
|
class TimeZoneTest extends PHPUnit_Framework_TestCase
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* Generate a timezone selection form
|
||||||
|
*/
|
||||||
|
public function testGenerateTimeZoneForm()
|
||||||
|
{
|
||||||
|
$generated = generateTimeZoneForm();
|
||||||
|
|
||||||
|
// HTML form
|
||||||
|
$this->assertStringStartsWith('Continent:<select', $generated[0]);
|
||||||
|
$this->assertContains('selected="selected"', $generated[0]);
|
||||||
|
$this->assertStringEndsWith('</select><br />', $generated[0]);
|
||||||
|
|
||||||
|
// Javascript handler
|
||||||
|
$this->assertStringStartsWith('<script>', $generated[1]);
|
||||||
|
$this->assertContains(
|
||||||
|
'<option value=\"Bermuda\">Bermuda<\/option>',
|
||||||
|
$generated[1]
|
||||||
|
);
|
||||||
|
$this->assertStringEndsWith('</script>', $generated[1]);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Generate a timezone selection form, with a preselected timezone
|
||||||
|
*/
|
||||||
|
public function testGenerateTimeZoneFormPreselected()
|
||||||
|
{
|
||||||
|
$generated = generateTimeZoneForm('Antarctica/Syowa');
|
||||||
|
|
||||||
|
// HTML form
|
||||||
|
$this->assertStringStartsWith('Continent:<select', $generated[0]);
|
||||||
|
$this->assertContains(
|
||||||
|
'value="Antarctica" selected="selected"',
|
||||||
|
$generated[0]
|
||||||
|
);
|
||||||
|
$this->assertContains(
|
||||||
|
'value="Syowa" selected="selected"',
|
||||||
|
$generated[0]
|
||||||
|
);
|
||||||
|
$this->assertStringEndsWith('</select><br />', $generated[0]);
|
||||||
|
|
||||||
|
|
||||||
|
// Javascript handler
|
||||||
|
$this->assertStringStartsWith('<script>', $generated[1]);
|
||||||
|
$this->assertContains(
|
||||||
|
'<option value=\"Bermuda\">Bermuda<\/option>',
|
||||||
|
$generated[1]
|
||||||
|
);
|
||||||
|
$this->assertStringEndsWith('</script>', $generated[1]);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Check valid timezones
|
||||||
|
*/
|
||||||
|
public function testValidTimeZone()
|
||||||
|
{
|
||||||
|
$this->assertTrue(isTimeZoneValid('America', 'Argentina/Ushuaia'));
|
||||||
|
$this->assertTrue(isTimeZoneValid('Europe', 'Oslo'));
|
||||||
|
$this->assertTrue(isTimeZoneValid('UTC', 'UTC'));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Check invalid timezones
|
||||||
|
*/
|
||||||
|
public function testInvalidTimeZone()
|
||||||
|
{
|
||||||
|
$this->assertFalse(isTimeZoneValid('CEST', 'CEST'));
|
||||||
|
$this->assertFalse(isTimeZoneValid('Europe', 'Atlantis'));
|
||||||
|
$this->assertFalse(isTimeZoneValid('Middle_Earth', 'Moria'));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
?>
|
|
@ -109,7 +109,7 @@ public function testGenerateLocation() {
|
||||||
*/
|
*/
|
||||||
public function testGenerateLocationLoop() {
|
public function testGenerateLocationLoop() {
|
||||||
$ref = 'http://localhost/?test';
|
$ref = 'http://localhost/?test';
|
||||||
$this->assertEquals('?', generateLocation($ref, 'localhost', ['test']));
|
$this->assertEquals('?', generateLocation($ref, 'localhost', array('test')));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -119,4 +119,36 @@ public function testGenerateLocationOut() {
|
||||||
$ref = 'http://somewebsite.com/?test';
|
$ref = 'http://somewebsite.com/?test';
|
||||||
$this->assertEquals('?', generateLocation($ref, 'localhost'));
|
$this->assertEquals('?', generateLocation($ref, 'localhost'));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Check supported PHP versions
|
||||||
|
*/
|
||||||
|
public function testCheckSupportedPHPVersion()
|
||||||
|
{
|
||||||
|
$minVersion = '5.3';
|
||||||
|
checkPHPVersion($minVersion, '5.4.32');
|
||||||
|
checkPHPVersion($minVersion, '5.5');
|
||||||
|
checkPHPVersion($minVersion, '5.6.10');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Check a unsupported PHP version
|
||||||
|
* @expectedException Exception
|
||||||
|
* @expectedExceptionMessageRegExp /Your PHP version is obsolete/
|
||||||
|
*/
|
||||||
|
public function testCheckSupportedPHPVersion51()
|
||||||
|
{
|
||||||
|
checkPHPVersion('5.3', '5.1.0');
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Check another unsupported PHP version
|
||||||
|
* @expectedException Exception
|
||||||
|
* @expectedExceptionMessageRegExp /Your PHP version is obsolete/
|
||||||
|
*/
|
||||||
|
public function testCheckSupportedPHPVersion52()
|
||||||
|
{
|
||||||
|
checkPHPVersion('5.3', '5.2');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
?>
|
||||||
|
|
Loading…
Reference in a new issue