mirror of
https://github.com/Combodo/iTop.git
synced 2026-04-23 02:28:44 +02:00
🐛 Fix version methods throwing exceptions with version 3.0.0
This commit is contained in:
@@ -2081,33 +2081,38 @@ class utils
|
|||||||
*/
|
*/
|
||||||
public static function GetCacheBusterTimestamp()
|
public static function GetCacheBusterTimestamp()
|
||||||
{
|
{
|
||||||
if(!defined('COMPILATION_TIMESTAMP'))
|
if (!defined('COMPILATION_TIMESTAMP')) {
|
||||||
{
|
|
||||||
return ITOP_VERSION;
|
return ITOP_VERSION;
|
||||||
}
|
}
|
||||||
|
|
||||||
return COMPILATION_TIMESTAMP;
|
return COMPILATION_TIMESTAMP;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @return string eg : '2_7_0' ITOP_VERSION is '2.7.1-dev'
|
* @return string eg : '2_7_0' ITOP_VERSION is '2.7.1-dev'
|
||||||
*/
|
*/
|
||||||
public static function GetItopVersionWikiSyntax()
|
public static function GetItopVersionWikiSyntax() {
|
||||||
{
|
|
||||||
$sMinorVersion = self::GetItopMinorVersion();
|
$sMinorVersion = self::GetItopMinorVersion();
|
||||||
|
|
||||||
return str_replace('.', '_', $sMinorVersion).'_0';
|
return str_replace('.', '_', $sMinorVersion).'_0';
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
* @param string $sPatchVersion if non provided, will call GetItopPatchVersion
|
||||||
|
*
|
||||||
* @return string eg 2.7 if ITOP_VERSION is '2.7.0-dev'
|
* @return string eg 2.7 if ITOP_VERSION is '2.7.0-dev'
|
||||||
* @throws \Exception
|
* @throws \Exception
|
||||||
*/
|
*/
|
||||||
public static function GetItopMinorVersion()
|
public static function GetItopMinorVersion($sPatchVersion = null) {
|
||||||
{
|
if (is_null($sPatchVersion)) {
|
||||||
$sPatchVersion = self::GetItopPatchVersion();
|
$sPatchVersion = self::GetItopPatchVersion();
|
||||||
|
}
|
||||||
$aExplodedVersion = explode('.', $sPatchVersion);
|
$aExplodedVersion = explode('.', $sPatchVersion);
|
||||||
|
|
||||||
if (empty($aExplodedVersion[0]) || empty($aExplodedVersion[1]))
|
if (count($aExplodedVersion) < 2) {
|
||||||
{
|
throw new Exception('iTop version is wrongfully configured!');
|
||||||
|
}
|
||||||
|
if (($aExplodedVersion[0] == '') || ($aExplodedVersion[1] == '')) {
|
||||||
throw new Exception('iTop version is wrongfully configured!');
|
throw new Exception('iTop version is wrongfully configured!');
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -2117,9 +2122,9 @@ class utils
|
|||||||
/**
|
/**
|
||||||
* @return string eg '2.7.0' if ITOP_VERSION is '2.7.0-dev'
|
* @return string eg '2.7.0' if ITOP_VERSION is '2.7.0-dev'
|
||||||
*/
|
*/
|
||||||
public static function GetItopPatchVersion()
|
public static function GetItopPatchVersion() {
|
||||||
{
|
|
||||||
$aExplodedVersion = explode('-', ITOP_VERSION);
|
$aExplodedVersion = explode('-', ITOP_VERSION);
|
||||||
|
|
||||||
return $aExplodedVersion[0];
|
return $aExplodedVersion[0];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -46,7 +46,6 @@ class ItopTestCase extends TestCase
|
|||||||
@include_once '../../../../../../../../approot.inc.php';
|
@include_once '../../../../../../../../approot.inc.php';
|
||||||
|
|
||||||
$this->debug("\n----------\n---------- ".$this->getName()."\n----------\n");
|
$this->debug("\n----------\n---------- ".$this->getName()."\n----------\n");
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
protected function debug($sMsg)
|
protected function debug($sMsg)
|
||||||
|
|||||||
@@ -16,7 +16,6 @@
|
|||||||
namespace Combodo\iTop\Test\UnitTest\Integration;
|
namespace Combodo\iTop\Test\UnitTest\Integration;
|
||||||
|
|
||||||
use Combodo\iTop\Test\UnitTest\ItopTestCase;
|
use Combodo\iTop\Test\UnitTest\ItopTestCase;
|
||||||
use DOMDocument;
|
|
||||||
use iTopDesignFormat;
|
use iTopDesignFormat;
|
||||||
|
|
||||||
|
|
||||||
@@ -30,9 +29,30 @@ use iTopDesignFormat;
|
|||||||
*
|
*
|
||||||
* @package Combodo\iTop\Test\UnitTest\Setup
|
* @package Combodo\iTop\Test\UnitTest\Setup
|
||||||
*/
|
*/
|
||||||
class iTopModulesPhpVersionIntegrationTest extends ItopTestCase
|
class iTopModulesPhpVersionIntegrationTest extends ItopTestCase {
|
||||||
{
|
/**
|
||||||
|
* We had a problem when version was switched from 2.8.0 to 3.0.0, so this test aims to detect such problems
|
||||||
|
*
|
||||||
|
* @param string $sVersion
|
||||||
|
* @param string $sExpectedMinVersion if null the test will expects an exception to occur
|
||||||
|
*
|
||||||
|
* @throws \Exception
|
||||||
|
* @since 3.0.0
|
||||||
|
* @dataProvider GetItopMinorVersionProvider
|
||||||
|
*/
|
||||||
|
public function testGetItopMinorVersion($sVersion, $sExpectedMinVersion) {
|
||||||
|
if (is_null($sExpectedMinVersion)) {
|
||||||
|
$this->expectException(\Exception::class);
|
||||||
|
}
|
||||||
|
$sActualMinVersion = \utils::GetItopMinorVersion($sVersion);
|
||||||
|
if (!is_null($sExpectedMinVersion)) {
|
||||||
|
$this->assertEquals($sExpectedMinVersion, $sActualMinVersion);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public function GetItopMinorVersionProvider() {
|
||||||
|
return [['2.8.0', '2.8'], ['3.0.0', '3.0'], ['3.', null], ['3', null]];
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Verify if the datamodel.*.xml files refer to the current itop version
|
* Verify if the datamodel.*.xml files refer to the current itop version
|
||||||
@@ -44,6 +64,7 @@ class iTopModulesPhpVersionIntegrationTest extends ItopTestCase
|
|||||||
*/
|
*/
|
||||||
public function testiTopModulesPhpVersion($sExpectedVersion, $sPhpFile)
|
public function testiTopModulesPhpVersion($sExpectedVersion, $sPhpFile)
|
||||||
{
|
{
|
||||||
|
$this->assertNotNull($sExpectedVersion, 'Expected version is null, something went wrong in the dataprovider !');
|
||||||
|
|
||||||
$sModulePath = realpath($sPhpFile);
|
$sModulePath = realpath($sPhpFile);
|
||||||
$sModuleFileName = basename($sModulePath);
|
$sModuleFileName = basename($sModulePath);
|
||||||
@@ -57,38 +78,43 @@ class iTopModulesPhpVersionIntegrationTest extends ItopTestCase
|
|||||||
$matches
|
$matches
|
||||||
);
|
);
|
||||||
|
|
||||||
$this->assertRegExp("#$sExpectedVersion#", $matches[1], " $sPhpFile:2 file refer does not refer to current itop version ($sModuleName/$matches[1] does not match regexp $sModuleName/$sExpectedVersion)");
|
$this->assertRegExp("#$sExpectedVersion#", $matches[1],
|
||||||
|
" $sPhpFile:2 file refer does not refer to current itop version ($sModuleName/$matches[1] does not match regexp $sModuleName/$sExpectedVersion)");
|
||||||
}
|
}
|
||||||
|
|
||||||
public function iTopModulesPhpVersionProvider()
|
/**
|
||||||
{
|
* @return array
|
||||||
|
* @throws \Exception
|
||||||
|
* @uses utils::GetItopMinorVersion()
|
||||||
|
*/
|
||||||
|
public function iTopModulesPhpVersionProvider() {
|
||||||
parent::setUp();
|
parent::setUp();
|
||||||
|
|
||||||
require_once APPROOT.'core/config.class.inc.php';
|
require_once APPROOT.'core/config.class.inc.php';
|
||||||
require_once APPROOT.'application/utils.inc.php';
|
require_once APPROOT.'application/utils.inc.php';
|
||||||
|
|
||||||
if (is_dir(APPROOT.'datamodels/2.x'))
|
if (is_dir(APPROOT.'datamodels/2.x')) {
|
||||||
{
|
|
||||||
$DatamodelsPath = APPROOT.'datamodels/2.x';
|
$DatamodelsPath = APPROOT.'datamodels/2.x';
|
||||||
}
|
}
|
||||||
elseif (is_dir(APPROOT.'datamodels/1.x'))
|
elseif (is_dir(APPROOT.'datamodels/1.x'))
|
||||||
{
|
{
|
||||||
$DatamodelsPath = APPROOT.'datamodels/1.x';
|
$DatamodelsPath = APPROOT.'datamodels/1.x';
|
||||||
}
|
} else {
|
||||||
else
|
|
||||||
{
|
|
||||||
throw new \Exception('Cannot local the datamodels directory');
|
throw new \Exception('Cannot local the datamodels directory');
|
||||||
}
|
}
|
||||||
|
|
||||||
$sPath = $DatamodelsPath.'/*/module.*.php';
|
$sPath = $DatamodelsPath.'/*/module.*.php';
|
||||||
$aPhpFiles = glob($sPath);
|
$aPhpFiles = glob($sPath);
|
||||||
|
|
||||||
$sExpectedVersion = \utils::GetItopMinorVersion().'\.\d+'; // ie: 2.7\.\d+ (and yes, the 1st dot should be escaped, but, hey, it is good enough as it, ans less complex to read)
|
try {
|
||||||
|
$sExpectedVersion = \utils::GetItopMinorVersion().'\.\d+';// ie: 2.7\.\d+ (and yes, the 1st dot should be escaped, but, hey, it is good enough as it, ans less complex to read)
|
||||||
|
}
|
||||||
|
catch (\Exception $e) {
|
||||||
|
$sExpectedVersion = null;
|
||||||
|
}
|
||||||
|
|
||||||
$aTestCases = array();
|
$aTestCases = array();
|
||||||
foreach ($aPhpFiles as $sPhpFile)
|
foreach ($aPhpFiles as $sPhpFile) {
|
||||||
{
|
|
||||||
$aTestCases[$sPhpFile] = array(
|
$aTestCases[$sPhpFile] = array(
|
||||||
'sExpectedVersion' => $sExpectedVersion,
|
'sExpectedVersion' => $sExpectedVersion,
|
||||||
'sPhpFile' => $sPhpFile,
|
'sPhpFile' => $sPhpFile,
|
||||||
@@ -97,5 +123,4 @@ class iTopModulesPhpVersionIntegrationTest extends ItopTestCase
|
|||||||
|
|
||||||
return $aTestCases;
|
return $aTestCases;
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user