Set Shaarli's version only in shaarli_version.php file
This commit is contained in:
parent
bbc6b844c1
commit
b786c8836f
3 changed files with 62 additions and 13 deletions
|
@ -4,9 +4,13 @@
|
||||||
*/
|
*/
|
||||||
class ApplicationUtils
|
class ApplicationUtils
|
||||||
{
|
{
|
||||||
|
/**
|
||||||
|
* @var string File containing the current version
|
||||||
|
*/
|
||||||
|
public static $VERSION_FILE = 'shaarli_version.php';
|
||||||
|
|
||||||
private static $GIT_URL = 'https://raw.githubusercontent.com/shaarli/Shaarli';
|
private static $GIT_URL = 'https://raw.githubusercontent.com/shaarli/Shaarli';
|
||||||
private static $GIT_BRANCHES = array('latest', 'stable');
|
private static $GIT_BRANCHES = array('latest', 'stable');
|
||||||
private static $VERSION_FILE = 'shaarli_version.php';
|
|
||||||
private static $VERSION_START_TAG = '<?php /* ';
|
private static $VERSION_START_TAG = '<?php /* ';
|
||||||
private static $VERSION_END_TAG = ' */ ?>';
|
private static $VERSION_END_TAG = ' */ ?>';
|
||||||
|
|
||||||
|
@ -29,6 +33,30 @@ public static function getLatestGitVersionCode($url, $timeout=2)
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return $data;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Retrieve the version from a remote URL or a file.
|
||||||
|
*
|
||||||
|
* @param string $remote URL or file to fetch.
|
||||||
|
* @param int $timeout For URLs fetching.
|
||||||
|
*
|
||||||
|
* @return bool|string The version or false if it couldn't be retrieved.
|
||||||
|
*/
|
||||||
|
public static function getVersion($remote, $timeout = 2)
|
||||||
|
{
|
||||||
|
if (startsWith($remote, 'http')) {
|
||||||
|
if (($data = static::getLatestGitVersionCode($remote, $timeout)) === false) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
if (! is_file($remote)) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
$data = file_get_contents($remote);
|
||||||
|
}
|
||||||
|
|
||||||
return str_replace(
|
return str_replace(
|
||||||
array(self::$VERSION_START_TAG, self::$VERSION_END_TAG, PHP_EOL),
|
array(self::$VERSION_START_TAG, self::$VERSION_END_TAG, PHP_EOL),
|
||||||
array('', '', ''),
|
array('', '', ''),
|
||||||
|
@ -90,7 +118,7 @@ public static function checkUpdate($currentVersion,
|
||||||
|
|
||||||
// Late Static Binding allows overriding within tests
|
// Late Static Binding allows overriding within tests
|
||||||
// See http://php.net/manual/en/language.oop5.late-static-bindings.php
|
// See http://php.net/manual/en/language.oop5.late-static-bindings.php
|
||||||
$latestVersion = static::getLatestGitVersionCode(
|
$latestVersion = static::getVersion(
|
||||||
self::$GIT_URL . '/' . $branch . '/' . self::$VERSION_FILE
|
self::$GIT_URL . '/' . $branch . '/' . self::$VERSION_FILE
|
||||||
);
|
);
|
||||||
|
|
||||||
|
|
|
@ -1,8 +1,6 @@
|
||||||
<?php
|
<?php
|
||||||
/**
|
/**
|
||||||
* Shaarli dev - Shaare your links...
|
* Shaarli - The personal, minimalist, super-fast, database free, bookmarking service.
|
||||||
*
|
|
||||||
* The personal, minimalist, super-fast, database free, bookmarking service.
|
|
||||||
*
|
*
|
||||||
* Friendly fork by the Shaarli community:
|
* Friendly fork by the Shaarli community:
|
||||||
* - https://github.com/shaarli/Shaarli
|
* - https://github.com/shaarli/Shaarli
|
||||||
|
@ -25,7 +23,6 @@
|
||||||
/*
|
/*
|
||||||
* PHP configuration
|
* PHP configuration
|
||||||
*/
|
*/
|
||||||
define('shaarli_version', 'dev');
|
|
||||||
|
|
||||||
// http://server.com/x/shaarli --> /shaarli/
|
// http://server.com/x/shaarli --> /shaarli/
|
||||||
define('WEB_PATH', substr($_SERVER['REQUEST_URI'], 0, 1+strrpos($_SERVER['REQUEST_URI'], '/', 0)));
|
define('WEB_PATH', substr($_SERVER['REQUEST_URI'], 0, 1+strrpos($_SERVER['REQUEST_URI'], '/', 0)));
|
||||||
|
@ -90,6 +87,8 @@
|
||||||
exit;
|
exit;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
define('shaarli_version', ApplicationUtils::getVersion(__DIR__ .'/'. ApplicationUtils::$VERSION_FILE));
|
||||||
|
|
||||||
// Force cookie path (but do not change lifetime)
|
// Force cookie path (but do not change lifetime)
|
||||||
$cookie = session_get_cookie_params();
|
$cookie = session_get_cookie_params();
|
||||||
$cookiedir = '';
|
$cookiedir = '';
|
||||||
|
|
|
@ -17,7 +17,7 @@ class FakeApplicationUtils extends ApplicationUtils
|
||||||
/**
|
/**
|
||||||
* Toggle HTTP requests, allow overriding the version code
|
* Toggle HTTP requests, allow overriding the version code
|
||||||
*/
|
*/
|
||||||
public static function getLatestGitVersionCode($url, $timeout=0)
|
public static function getVersion($url, $timeout=0)
|
||||||
{
|
{
|
||||||
return self::$VERSION_CODE;
|
return self::$VERSION_CODE;
|
||||||
}
|
}
|
||||||
|
@ -44,18 +44,28 @@ public function setUp()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Remove test version file if it exists
|
||||||
|
*/
|
||||||
|
public function tearDown()
|
||||||
|
{
|
||||||
|
if (is_file('sandbox/version.php')) {
|
||||||
|
unlink('sandbox/version.php');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Retrieve the latest version code available on Git
|
* Retrieve the latest version code available on Git
|
||||||
*
|
*
|
||||||
* Expected format: Semantic Versioning - major.minor.patch
|
* Expected format: Semantic Versioning - major.minor.patch
|
||||||
*/
|
*/
|
||||||
public function testGetLatestGitVersionCode()
|
public function testGetVersionCode()
|
||||||
{
|
{
|
||||||
$testTimeout = 10;
|
$testTimeout = 10;
|
||||||
|
|
||||||
$this->assertEquals(
|
$this->assertEquals(
|
||||||
'0.5.4',
|
'0.5.4',
|
||||||
ApplicationUtils::getLatestGitVersionCode(
|
ApplicationUtils::getVersion(
|
||||||
'https://raw.githubusercontent.com/shaarli/Shaarli/'
|
'https://raw.githubusercontent.com/shaarli/Shaarli/'
|
||||||
.'v0.5.4/shaarli_version.php',
|
.'v0.5.4/shaarli_version.php',
|
||||||
$testTimeout
|
$testTimeout
|
||||||
|
@ -63,7 +73,7 @@ public function testGetLatestGitVersionCode()
|
||||||
);
|
);
|
||||||
$this->assertRegExp(
|
$this->assertRegExp(
|
||||||
self::$versionPattern,
|
self::$versionPattern,
|
||||||
ApplicationUtils::getLatestGitVersionCode(
|
ApplicationUtils::getVersion(
|
||||||
'https://raw.githubusercontent.com/shaarli/Shaarli/'
|
'https://raw.githubusercontent.com/shaarli/Shaarli/'
|
||||||
.'master/shaarli_version.php',
|
.'master/shaarli_version.php',
|
||||||
$testTimeout
|
$testTimeout
|
||||||
|
@ -72,14 +82,26 @@ public function testGetLatestGitVersionCode()
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Attempt to retrieve the latest version from an invalid URL
|
* Attempt to retrieve the latest version from an invalid File
|
||||||
*/
|
*/
|
||||||
public function testGetLatestGitVersionCodeInvalidUrl()
|
public function testGetVersionCodeFromFile()
|
||||||
|
{
|
||||||
|
file_put_contents('sandbox/version.php', '<?php /* 1.2.3 */ ?>'. PHP_EOL);
|
||||||
|
$this->assertEquals(
|
||||||
|
'1.2.3',
|
||||||
|
ApplicationUtils::getVersion('sandbox/version.php', 1)
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Attempt to retrieve the latest version from an invalid File
|
||||||
|
*/
|
||||||
|
public function testGetVersionCodeInvalidFile()
|
||||||
{
|
{
|
||||||
$oldlog = ini_get('error_log');
|
$oldlog = ini_get('error_log');
|
||||||
ini_set('error_log', '/dev/null');
|
ini_set('error_log', '/dev/null');
|
||||||
$this->assertFalse(
|
$this->assertFalse(
|
||||||
ApplicationUtils::getLatestGitVersionCode('htttp://null.io', 1)
|
ApplicationUtils::getVersion('idontexist', 1)
|
||||||
);
|
);
|
||||||
ini_set('error_log', $oldlog);
|
ini_set('error_log', $oldlog);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue