summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--lib/private/App/AppStore/Version/VersionParser.php47
-rw-r--r--tests/lib/App/AppStore/Version/VersionParserTest.php7
2 files changed, 40 insertions, 14 deletions
diff --git a/lib/private/App/AppStore/Version/VersionParser.php b/lib/private/App/AppStore/Version/VersionParser.php
index 1058a8bc0fa..b548ef386d9 100644
--- a/lib/private/App/AppStore/Version/VersionParser.php
+++ b/lib/private/App/AppStore/Version/VersionParser.php
@@ -28,6 +28,14 @@ namespace OC\App\AppStore\Version;
*/
class VersionParser {
/**
+ * @param string $versionString
+ * @return bool
+ */
+ private function isValidVersionString($versionString) {
+ return (bool)preg_match('/^[0-9.]+$/', $versionString);
+ }
+
+ /**
* Returns the version for a version string
*
* @param string $versionSpec
@@ -42,23 +50,34 @@ class VersionParser {
// Count the amount of =, if it is one then it's either maximum or minimum
// version. If it is two then it is maximum and minimum.
- if (preg_match_all('/(?:>|<)(?:=|)[0-9.]+/', $versionSpec, $matches)) {
- switch(count($matches[0])) {
- case 1:
- if(substr($matches[0][0], 0, 1) === '>') {
- return new Version(substr($matches[0][0], 2), '');
- } else {
- return new Version('', substr($matches[0][0], 2));
- }
+ $versionElements = explode(' ', $versionSpec);
+ $firstVersion = isset($versionElements[0]) ? $versionElements[0] : '';
+ $firstVersionNumber = substr($firstVersion, 2);
+ $secondVersion = isset($versionElements[1]) ? $versionElements[1] : '';
+ $secondVersionNumber = substr($secondVersion, 2);
+
+ switch(count($versionElements)) {
+ case 1:
+ if(!$this->isValidVersionString($firstVersionNumber)) {
break;
- case 2:
- return new Version(substr($matches[0][0], 2), substr($matches[0][1], 2));
+ }
+ if(substr($firstVersion, 0, 1) === '>') {
+ return new Version($firstVersionNumber, '');
+ } else {
+ return new Version('', $firstVersionNumber);
+ }
+ case 2:
+ if(!$this->isValidVersionString($firstVersionNumber) || !$this->isValidVersionString($secondVersionNumber)) {
break;
- default:
- throw new \Exception('Version cannot be parsed');
- }
+ }
+ return new Version($firstVersionNumber, $secondVersionNumber);
}
- throw new \Exception('Version cannot be parsed');
+ throw new \Exception(
+ sprintf(
+ 'Version cannot be parsed: %s',
+ $versionSpec
+ )
+ );
}
}
diff --git a/tests/lib/App/AppStore/Version/VersionParserTest.php b/tests/lib/App/AppStore/Version/VersionParserTest.php
index ccf557eefbc..77c289e5474 100644
--- a/tests/lib/App/AppStore/Version/VersionParserTest.php
+++ b/tests/lib/App/AppStore/Version/VersionParserTest.php
@@ -81,4 +81,11 @@ class VersionParserTest extends TestCase {
$this->assertEquals($expected, $this->versionParser->getVersion($input));
}
+ /**
+ * @expectedException \Exception
+ * @expectedExceptionMessage Version cannot be parsed: BogusVersion
+ */
+ public function testGetVersionException() {
+ $this->versionParser->getVersion('BogusVersion');
+ }
}