Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
Y
yii2
Project
Overview
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
PSDI Army
yii2
Commits
9a461edd
Commit
9a461edd
authored
May 11, 2013
by
Klimov Paul
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Check helper methods have been added to "YiiRequirementChecker".
parent
fa724fc0
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
193 additions
and
1 deletion
+193
-1
YiiRequirementCheckerTest.php
...unit/framework/requirements/YiiRequirementCheckerTest.php
+68
-0
YiiRequirementChecker.php
yii/requirements/YiiRequirementChecker.php
+125
-1
No files found.
tests/unit/framework/requirements/YiiRequirementCheckerTest.php
View file @
9a461edd
...
...
@@ -124,4 +124,72 @@ class YiiRequirementCheckerTest extends TestCase
$this
->
assertEquals
(
$mergedRequirement
[
'name'
],
$checkResult
[
'requirements'
][
$key
][
'name'
],
'Wrong requirements list!'
);
}
}
public
function
testCheckPhpExtensionVersion
()
{
$requirementsChecker
=
new
YiiRequirementChecker
();
$this
->
assertFalse
(
$requirementsChecker
->
checkPhpExtensionVersion
(
'some_unexisting_php_extension'
,
'0.1'
),
'No fail while checking unexisting extension!'
);
$this
->
assertTrue
(
$requirementsChecker
->
checkPhpExtensionVersion
(
'pdo'
,
'1.0'
),
'Unable to check PDO version!'
);
}
/**
* Data provider for {@link testGetByteSize()}.
* @return array
*/
public
function
dataProviderGetByteSize
()
{
return
array
(
array
(
'456'
,
456
),
array
(
'5K'
,
5
*
1024
),
array
(
'16KB'
,
16
*
1024
),
array
(
'4M'
,
4
*
1024
*
1024
),
array
(
'14MB'
,
14
*
1024
*
1024
),
array
(
'7G'
,
7
*
1024
*
1024
*
1024
),
array
(
'12GB'
,
12
*
1024
*
1024
*
1024
),
);
}
/**
* @dataProvider dataProviderGetByteSize
*
* @param string $verboseValue verbose value.
* @param integer $expectedByteSize expected byte size.
*/
public
function
testGetByteSize
(
$verboseValue
,
$expectedByteSize
)
{
$requirementsChecker
=
new
YiiRequirementChecker
();
$this
->
assertEquals
(
$expectedByteSize
,
$requirementsChecker
->
getByteSize
(
$verboseValue
),
"Wrong byte size for '
{
$verboseValue
}
'!"
);
}
/**
* Data provider for {@link testCompareByteSize()}
* @return array
*/
public
function
dataProviderCompareByteSize
()
{
return
array
(
array
(
'2M'
,
'2K'
,
'>'
,
true
),
array
(
'2M'
,
'2K'
,
'>='
,
true
),
array
(
'1K'
,
'1024'
,
'=='
,
true
),
array
(
'10M'
,
'11M'
,
'<'
,
true
),
array
(
'10M'
,
'11M'
,
'<='
,
true
),
);
}
/**
* @depends testGetByteSize
* @dataProvider dataProviderCompareByteSize
*
* @param string $a first value.
* @param string $b second value.
* @param string $compare comparison.
* @param boolean $expectedComparisonResult expected comparison result.
*/
public
function
testCompareByteSize
(
$a
,
$b
,
$compare
,
$expectedComparisonResult
)
{
$requirementsChecker
=
new
YiiRequirementChecker
();
$this
->
assertEquals
(
$expectedComparisonResult
,
$requirementsChecker
->
compareByteSize
(
$a
,
$b
,
$compare
),
"Wrong compare '
{
$a
}{
$compare
}{
$b
}
'"
);
}
}
yii/requirements/YiiRequirementChecker.php
View file @
9a461edd
...
...
@@ -27,7 +27,7 @@ class YiiRequirementChecker
if
(
!
is_array
(
$requirements
))
{
$this
->
usageError
(
"Requirements must be an array!"
);
}
if
(
!
isset
(
$this
->
result
))
{
if
(
!
isset
(
$this
->
result
)
||
!
is_array
(
$this
->
result
)
)
{
$this
->
result
=
array
(
'summary'
=>
array
(
'total'
=>
0
,
...
...
@@ -91,6 +91,130 @@ class YiiRequirementChecker
}
/**
* Checks if the given PHP extension is available and its version matches the given one.
* @param string $extensionName PHP extension name.
* @param string $version required PHP extension version.
* @param string $compare comparison operator, by default '>='
* @return boolean if PHP extension version matches.
*/
function
checkPhpExtensionVersion
(
$extensionName
,
$version
,
$compare
=
'>='
)
{
if
(
!
extension_loaded
(
$extensionName
))
{
return
false
;
}
$extensionVersion
=
phpversion
(
$extensionName
);
if
(
empty
(
$extensionVersion
))
{
return
false
;
}
return
version_compare
(
$extensionVersion
,
$version
,
$compare
);
}
/**
* Checks if PHP configuration option (from php.ini) is on.
* @param string $name configuration option name.
* @return boolean option is on.
*/
function
checkPhpIniOn
(
$name
)
{
$value
=
ini_get
(
$name
);
if
(
empty
(
$value
))
{
return
false
;
}
return
((
integer
)
$value
==
1
||
strtolower
(
$value
)
==
'on'
);
}
/**
* Checks if PHP configuration option (from php.ini) is off.
* @param string $name configuration option name.
* @return boolean option is off.
*/
function
checkPhpIniOff
(
$name
)
{
$value
=
ini_get
(
$name
);
if
(
empty
(
$value
))
{
return
true
;
}
return
(
strtolower
(
$value
)
==
'off'
);
}
/**
* Compare byte sizes of values given in the verbose representation,
* like '5M', '15K' etc.
* @param string $a first value.
* @param string $b second value.
* @param string $compare comparison operator, by default '>='.
* @return boolean comparison result.
*/
function
compareByteSize
(
$a
,
$b
,
$compare
=
'>='
)
{
$compareExpression
=
'('
.
$this
->
getByteSize
(
$a
)
.
$compare
.
$this
->
getByteSize
(
$b
)
.
')'
;
return
$this
->
evaluateExpression
(
$compareExpression
);
}
/**
* Gets the size in bytes from verbose size representation.
* For example: '5K' => 5*1024
* @param string $verboseSize verbose size representation.
* @return integer actual size in bytes.
*/
function
getByteSize
(
$verboseSize
)
{
if
(
empty
(
$verboseSize
))
{
return
0
;
}
if
(
is_numeric
(
$verboseSize
))
{
return
(
integer
)
$verboseSize
;
}
$sizeUnit
=
trim
(
$verboseSize
,
'0123456789'
);
$size
=
str_replace
(
$sizeUnit
,
''
,
$verboseSize
);
$size
=
trim
(
$size
);
if
(
!
is_numeric
(
$size
))
{
return
0
;
}
switch
(
strtolower
(
$sizeUnit
))
{
case
'kb'
:
case
'k'
:
{
return
$size
*
1024
;
}
case
'mb'
:
case
'm'
:
{
return
$size
*
1024
*
1024
;
}
case
'gb'
:
case
'g'
:
{
return
$size
*
1024
*
1024
*
1024
;
}
default
:
{
return
0
;
}
}
}
/**
* Checks if upload max file size matches the given range.
* @param string|null $min verbose file size minimum required value, pass null to skip minimum check.
* @param string|null $max verbose file size maximum required value, pass null to skip maximum check.
* @return boolean success.
*/
function
checkUploadMaxFileSize
(
$min
=
null
,
$max
=
null
)
{
$postMaxSize
=
ini_get
(
'post_max_size'
);
$uploadMaxFileSize
=
ini_get
(
'upload_max_filesize'
);
if
(
$min
!==
null
)
{
$minCheckResult
=
$this
->
compareByteSize
(
$postMaxSize
,
$min
,
'>='
)
&&
$this
->
compareByteSize
(
$uploadMaxFileSize
,
$min
,
'>='
);
}
else
{
$minCheckResult
=
true
;
}
if
(
$max
!==
null
)
{
var_dump
(
$postMaxSize
,
$uploadMaxFileSize
,
$max
);
$maxCheckResult
=
$this
->
compareByteSize
(
$postMaxSize
,
$max
,
'<='
)
&&
$this
->
compareByteSize
(
$uploadMaxFileSize
,
$max
,
'<='
);
}
else
{
$maxCheckResult
=
true
;
}
return
(
$minCheckResult
&&
$maxCheckResult
);
}
/**
* Renders a view file.
* This method includes the view file as a PHP script
* and captures the display result if required.
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment