upgraded dependencies
This commit is contained in:
1
vendor/phpunit/php-timer/.gitattributes
vendored
1
vendor/phpunit/php-timer/.gitattributes
vendored
@@ -1 +0,0 @@
|
||||
*.php diff=php
|
1
vendor/phpunit/php-timer/.github/FUNDING.yml
vendored
1
vendor/phpunit/php-timer/.github/FUNDING.yml
vendored
@@ -1 +0,0 @@
|
||||
patreon: s_bergmann
|
40
vendor/phpunit/php-timer/.github/stale.yml
vendored
40
vendor/phpunit/php-timer/.github/stale.yml
vendored
@@ -1,40 +0,0 @@
|
||||
# Configuration for probot-stale - https://github.com/probot/stale
|
||||
|
||||
# Number of days of inactivity before an Issue or Pull Request becomes stale
|
||||
daysUntilStale: 60
|
||||
|
||||
# Number of days of inactivity before a stale Issue or Pull Request is closed.
|
||||
# Set to false to disable. If disabled, issues still need to be closed manually, but will remain marked as stale.
|
||||
daysUntilClose: 7
|
||||
|
||||
# Issues or Pull Requests with these labels will never be considered stale. Set to `[]` to disable
|
||||
exemptLabels:
|
||||
- enhancement
|
||||
|
||||
# Set to true to ignore issues in a project (defaults to false)
|
||||
exemptProjects: false
|
||||
|
||||
# Set to true to ignore issues in a milestone (defaults to false)
|
||||
exemptMilestones: false
|
||||
|
||||
# Label to use when marking as stale
|
||||
staleLabel: stale
|
||||
|
||||
# Comment to post when marking as stale. Set to `false` to disable
|
||||
markComment: >
|
||||
This issue has been automatically marked as stale because it has not had activity within the last 60 days. It will be closed after 7 days if no further activity occurs. Thank you for your contributions.
|
||||
|
||||
# Comment to post when removing the stale label.
|
||||
# unmarkComment: >
|
||||
# Your comment here.
|
||||
|
||||
# Comment to post when closing a stale Issue or Pull Request.
|
||||
closeComment: >
|
||||
This issue has been automatically closed because it has not had activity since it was marked as stale. Thank you for your contributions.
|
||||
|
||||
# Limit the number of actions per hour, from 1-30. Default is 30
|
||||
limitPerRun: 30
|
||||
|
||||
# Limit to only `issues` or `pulls`
|
||||
only: issues
|
||||
|
5
vendor/phpunit/php-timer/.gitignore
vendored
5
vendor/phpunit/php-timer/.gitignore
vendored
@@ -1,5 +0,0 @@
|
||||
/.idea
|
||||
/.php_cs.cache
|
||||
/vendor
|
||||
/composer.lock
|
||||
|
197
vendor/phpunit/php-timer/.php_cs.dist
vendored
197
vendor/phpunit/php-timer/.php_cs.dist
vendored
@@ -1,197 +0,0 @@
|
||||
<?php declare(strict_types=1);
|
||||
$header = <<<'EOF'
|
||||
This file is part of phpunit/php-timer.
|
||||
|
||||
(c) Sebastian Bergmann <sebastian@phpunit.de>
|
||||
|
||||
For the full copyright and license information, please view the LICENSE
|
||||
file that was distributed with this source code.
|
||||
EOF;
|
||||
|
||||
return PhpCsFixer\Config::create()
|
||||
->setRiskyAllowed(true)
|
||||
->setRules(
|
||||
[
|
||||
'align_multiline_comment' => true,
|
||||
'array_indentation' => true,
|
||||
'array_syntax' => ['syntax' => 'short'],
|
||||
'binary_operator_spaces' => [
|
||||
'operators' => [
|
||||
'=' => 'align',
|
||||
'=>' => 'align',
|
||||
],
|
||||
],
|
||||
'blank_line_after_namespace' => true,
|
||||
'blank_line_before_statement' => [
|
||||
'statements' => [
|
||||
'break',
|
||||
'continue',
|
||||
'declare',
|
||||
'do',
|
||||
'for',
|
||||
'foreach',
|
||||
'if',
|
||||
'include',
|
||||
'include_once',
|
||||
'require',
|
||||
'require_once',
|
||||
'return',
|
||||
'switch',
|
||||
'throw',
|
||||
'try',
|
||||
'while',
|
||||
'yield',
|
||||
],
|
||||
],
|
||||
'braces' => true,
|
||||
'cast_spaces' => true,
|
||||
'class_attributes_separation' => ['elements' => ['const', 'method', 'property']],
|
||||
'combine_consecutive_issets' => true,
|
||||
'combine_consecutive_unsets' => true,
|
||||
'compact_nullable_typehint' => true,
|
||||
'concat_space' => ['spacing' => 'one'],
|
||||
'declare_equal_normalize' => ['space' => 'none'],
|
||||
'declare_strict_types' => true,
|
||||
'dir_constant' => true,
|
||||
'elseif' => true,
|
||||
'encoding' => true,
|
||||
'full_opening_tag' => true,
|
||||
'function_declaration' => true,
|
||||
'header_comment' => ['header' => $header, 'separate' => 'none'],
|
||||
'indentation_type' => true,
|
||||
'is_null' => true,
|
||||
'line_ending' => true,
|
||||
'list_syntax' => ['syntax' => 'short'],
|
||||
'logical_operators' => true,
|
||||
'lowercase_cast' => true,
|
||||
'lowercase_constants' => true,
|
||||
'lowercase_keywords' => true,
|
||||
'lowercase_static_reference' => true,
|
||||
'magic_constant_casing' => true,
|
||||
'method_argument_space' => ['ensure_fully_multiline' => true],
|
||||
'modernize_types_casting' => true,
|
||||
'multiline_comment_opening_closing' => true,
|
||||
'multiline_whitespace_before_semicolons' => true,
|
||||
'native_constant_invocation' => true,
|
||||
'native_function_casing' => true,
|
||||
'native_function_invocation' => true,
|
||||
'new_with_braces' => false,
|
||||
'no_alias_functions' => true,
|
||||
'no_alternative_syntax' => true,
|
||||
'no_blank_lines_after_class_opening' => true,
|
||||
'no_blank_lines_after_phpdoc' => true,
|
||||
'no_blank_lines_before_namespace' => true,
|
||||
'no_closing_tag' => true,
|
||||
'no_empty_comment' => true,
|
||||
'no_empty_phpdoc' => true,
|
||||
'no_empty_statement' => true,
|
||||
'no_extra_blank_lines' => true,
|
||||
'no_homoglyph_names' => true,
|
||||
'no_leading_import_slash' => true,
|
||||
'no_leading_namespace_whitespace' => true,
|
||||
'no_mixed_echo_print' => ['use' => 'print'],
|
||||
'no_multiline_whitespace_around_double_arrow' => true,
|
||||
'no_null_property_initialization' => true,
|
||||
'no_php4_constructor' => true,
|
||||
'no_short_bool_cast' => true,
|
||||
'no_short_echo_tag' => true,
|
||||
'no_singleline_whitespace_before_semicolons' => true,
|
||||
'no_spaces_after_function_name' => true,
|
||||
'no_spaces_inside_parenthesis' => true,
|
||||
'no_superfluous_elseif' => true,
|
||||
'no_superfluous_phpdoc_tags' => true,
|
||||
'no_trailing_comma_in_list_call' => true,
|
||||
'no_trailing_comma_in_singleline_array' => true,
|
||||
'no_trailing_whitespace' => true,
|
||||
'no_trailing_whitespace_in_comment' => true,
|
||||
'no_unneeded_control_parentheses' => true,
|
||||
'no_unneeded_curly_braces' => true,
|
||||
'no_unneeded_final_method' => true,
|
||||
'no_unreachable_default_argument_value' => true,
|
||||
'no_unset_on_property' => true,
|
||||
'no_unused_imports' => true,
|
||||
'no_useless_else' => true,
|
||||
'no_useless_return' => true,
|
||||
'no_whitespace_before_comma_in_array' => true,
|
||||
'no_whitespace_in_blank_line' => true,
|
||||
'non_printable_character' => true,
|
||||
'normalize_index_brace' => true,
|
||||
'object_operator_without_whitespace' => true,
|
||||
'ordered_class_elements' => [
|
||||
'order' => [
|
||||
'use_trait',
|
||||
'constant_public',
|
||||
'constant_protected',
|
||||
'constant_private',
|
||||
'property_public_static',
|
||||
'property_protected_static',
|
||||
'property_private_static',
|
||||
'property_public',
|
||||
'property_protected',
|
||||
'property_private',
|
||||
'method_public_static',
|
||||
'construct',
|
||||
'destruct',
|
||||
'magic',
|
||||
'phpunit',
|
||||
'method_public',
|
||||
'method_protected',
|
||||
'method_private',
|
||||
'method_protected_static',
|
||||
'method_private_static',
|
||||
],
|
||||
],
|
||||
'ordered_imports' => true,
|
||||
'phpdoc_add_missing_param_annotation' => true,
|
||||
'phpdoc_align' => true,
|
||||
'phpdoc_annotation_without_dot' => true,
|
||||
'phpdoc_indent' => true,
|
||||
'phpdoc_no_access' => true,
|
||||
'phpdoc_no_empty_return' => true,
|
||||
'phpdoc_no_package' => true,
|
||||
'phpdoc_order' => true,
|
||||
'phpdoc_return_self_reference' => true,
|
||||
'phpdoc_scalar' => true,
|
||||
'phpdoc_separation' => true,
|
||||
'phpdoc_single_line_var_spacing' => true,
|
||||
'phpdoc_to_comment' => true,
|
||||
'phpdoc_trim' => true,
|
||||
'phpdoc_trim_consecutive_blank_line_separation' => true,
|
||||
'phpdoc_types' => ['groups' => ['simple', 'meta']],
|
||||
'phpdoc_types_order' => true,
|
||||
'phpdoc_var_without_name' => true,
|
||||
'pow_to_exponentiation' => true,
|
||||
'protected_to_private' => true,
|
||||
'return_assignment' => true,
|
||||
'return_type_declaration' => ['space_before' => 'none'],
|
||||
'self_accessor' => true,
|
||||
'semicolon_after_instruction' => true,
|
||||
'set_type_to_cast' => true,
|
||||
'short_scalar_cast' => true,
|
||||
'simplified_null_return' => true,
|
||||
'single_blank_line_at_eof' => true,
|
||||
'single_import_per_statement' => true,
|
||||
'single_line_after_imports' => true,
|
||||
'single_quote' => true,
|
||||
'standardize_not_equals' => true,
|
||||
'ternary_to_null_coalescing' => true,
|
||||
'trailing_comma_in_multiline_array' => true,
|
||||
'trim_array_spaces' => true,
|
||||
'unary_operator_spaces' => true,
|
||||
'visibility_required' => [
|
||||
'elements' => [
|
||||
'const',
|
||||
'method',
|
||||
'property',
|
||||
],
|
||||
],
|
||||
'void_return' => true,
|
||||
'whitespace_after_comma_in_array' => true,
|
||||
]
|
||||
)
|
||||
->setFinder(
|
||||
PhpCsFixer\Finder::create()
|
||||
->files()
|
||||
->in(__DIR__ . '/src')
|
||||
->in(__DIR__ . '/tests')
|
||||
);
|
2
vendor/phpunit/php-timer/.psalm/baseline.xml
vendored
Normal file
2
vendor/phpunit/php-timer/.psalm/baseline.xml
vendored
Normal file
@@ -0,0 +1,2 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<files psalm-version="4.0.1@b1e2e30026936ef8d5bf6a354d1c3959b6231f44"/>
|
16
vendor/phpunit/php-timer/.psalm/config.xml
vendored
Normal file
16
vendor/phpunit/php-timer/.psalm/config.xml
vendored
Normal file
@@ -0,0 +1,16 @@
|
||||
<?xml version="1.0"?>
|
||||
<psalm
|
||||
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
|
||||
xmlns="https://getpsalm.org/schema/config"
|
||||
xsi:schemaLocation="https://getpsalm.org/schema/config vendor/vimeo/psalm/config.xsd"
|
||||
resolveFromConfigFile="false"
|
||||
totallyTyped="true"
|
||||
errorBaseline=".psalm/baseline.xml"
|
||||
>
|
||||
<projectFiles>
|
||||
<directory name="src" />
|
||||
<ignoreFiles>
|
||||
<directory name="vendor" />
|
||||
</ignoreFiles>
|
||||
</projectFiles>
|
||||
</psalm>
|
23
vendor/phpunit/php-timer/.travis.yml
vendored
23
vendor/phpunit/php-timer/.travis.yml
vendored
@@ -1,23 +0,0 @@
|
||||
language: php
|
||||
|
||||
php:
|
||||
- 7.1
|
||||
- 7.2
|
||||
- 7.3
|
||||
- 7.4snapshot
|
||||
|
||||
before_install:
|
||||
- composer self-update
|
||||
- composer clear-cache
|
||||
|
||||
install:
|
||||
- travis_retry composer update --no-interaction --no-ansi --no-progress --no-suggest
|
||||
|
||||
script:
|
||||
- ./vendor/bin/phpunit --coverage-clover=coverage.xml
|
||||
|
||||
after_success:
|
||||
- bash <(curl -s https://codecov.io/bash)
|
||||
|
||||
notifications:
|
||||
email: false
|
111
vendor/phpunit/php-timer/ChangeLog.md
vendored
111
vendor/phpunit/php-timer/ChangeLog.md
vendored
@@ -2,17 +2,102 @@
|
||||
|
||||
All notable changes are documented in this file using the [Keep a CHANGELOG](http://keepachangelog.com/) principles.
|
||||
|
||||
## [2.1.3] - 2020-11-30
|
||||
## [5.0.3] - 2020-10-26
|
||||
|
||||
### Fixed
|
||||
|
||||
* `SebastianBergmann\Timer\Exception` now correctly extends `\Throwable`
|
||||
|
||||
## [5.0.2] - 2020-09-28
|
||||
|
||||
### Changed
|
||||
|
||||
* Changed PHP version constraint in `composer.json` from `^7.1` to `>=7.1`
|
||||
* Changed PHP version constraint in `composer.json` from `^7.3 || ^8.0` to `>=7.3`
|
||||
|
||||
## [5.0.1] - 2020-06-26
|
||||
|
||||
### Added
|
||||
|
||||
* This component is now supported on PHP 8
|
||||
|
||||
## [5.0.0] - 2020-06-07
|
||||
|
||||
### Changed
|
||||
|
||||
* Parameter type for `SebastianBergmann\Timer\Duration::fromMicroseconds()` was changed from `int` to `float`
|
||||
* Parameter type for `SebastianBergmann\Timer\Duration::fromNanoseconds()` was changed from `int` to `float`
|
||||
* Return type for `SebastianBergmann\Timer\Duration::asNanoseconds()` was changed from `int` to `float`
|
||||
|
||||
### Fixed
|
||||
|
||||
* [#31](https://github.com/sebastianbergmann/php-timer/issues/31): Type Error on 32-bit systems (where `hrtime()` returns `float` instead of `int`)
|
||||
|
||||
## [4.0.0] - 2020-06-01
|
||||
|
||||
### Added
|
||||
|
||||
* Introduced `Duration` value object for encapsulating a duration with nanosecond granularity
|
||||
* Introduced `ResourceUsageFormatter` object for formatting resource usage with option to explicitly pass a duration (instead of looking at the unreliable `$_SERVER['REQUEST_TIME_FLOAT']` variable)
|
||||
|
||||
### Changed
|
||||
|
||||
* The methods of `Timer` are no longer static
|
||||
* `Timer::stop()` now returns a `Duration` value object
|
||||
|
||||
### Removed
|
||||
|
||||
* Functionality that is now implemented in `Duration` and `ResourceUsageFormatter` has been removed from `Timer`
|
||||
|
||||
## [3.1.4] - 2020-04-20
|
||||
|
||||
### Changed
|
||||
|
||||
* `Timer::timeSinceStartOfRequest()` no longer tries `$_SERVER['REQUEST_TIME']` when `$_SERVER['REQUEST_TIME_FLOAT']` is not available (`$_SERVER['REQUEST_TIME_FLOAT']` was added in PHP 5.4 and this library requires PHP 7.3)
|
||||
* Improved exception messages when `$_SERVER['REQUEST_TIME_FLOAT']` is not set or is not of type `float`
|
||||
|
||||
### Changed
|
||||
|
||||
## [3.1.3] - 2020-04-20
|
||||
|
||||
### Changed
|
||||
|
||||
* `Timer::timeSinceStartOfRequest()` now raises an exception if `$_SERVER['REQUEST_TIME_FLOAT']` does not contain a `float` (or `$_SERVER['REQUEST_TIME']` does not contain an `int`)
|
||||
|
||||
## [3.1.2] - 2020-04-17
|
||||
|
||||
### Changed
|
||||
|
||||
* Improved the fix for [#30](https://github.com/sebastianbergmann/php-timer/issues/30) and restored usage of `hrtime()`
|
||||
|
||||
## [3.1.1] - 2020-04-17
|
||||
|
||||
### Fixed
|
||||
|
||||
* [#30](https://github.com/sebastianbergmann/php-timer/issues/30): Resolution of time returned by `Timer::stop()` is different than before (this reverts using `hrtime()` instead of `microtime()`)
|
||||
|
||||
## [3.1.0] - 2020-04-17
|
||||
|
||||
### Added
|
||||
|
||||
* `Timer::secondsToShortTimeString()` as alternative to `Timer::secondsToTimeString()`
|
||||
|
||||
### Changed
|
||||
|
||||
* `Timer::start()` and `Timer::stop()` now use `hrtime()` (high resolution monotonic timer) instead of `microtime()`
|
||||
* `Timer::timeSinceStartOfRequest()` now uses `Timer::secondsToShortTimeString()` for time formatting
|
||||
* Improved formatting of `Timer::secondsToTimeString()` result
|
||||
|
||||
## [3.0.0] - 2020-02-07
|
||||
|
||||
### Removed
|
||||
|
||||
* This component is no longer supported on PHP 7.1 and PHP 7.2
|
||||
|
||||
## [2.1.2] - 2019-06-07
|
||||
|
||||
### Fixed
|
||||
|
||||
* Fixed [#21](https://github.com/sebastianbergmann/php-timer/pull/3352): Formatting of memory consumption does not work on 32bit systems
|
||||
* [#21](https://github.com/sebastianbergmann/php-timer/pull/21): Formatting of memory consumption does not work on 32bit systems
|
||||
|
||||
## [2.1.1] - 2019-02-20
|
||||
|
||||
@@ -36,8 +121,18 @@ All notable changes are documented in this file using the [Keep a CHANGELOG](htt
|
||||
|
||||
* This component is no longer supported on PHP 5.3, PHP 5.4, PHP 5.5, PHP 5.6, and PHP 7.0
|
||||
|
||||
[2.1.3]: https://github.com/sebastianbergmann/diff/compare/2.1.2...2.1.3
|
||||
[2.1.2]: https://github.com/sebastianbergmann/diff/compare/2.1.1...2.1.2
|
||||
[2.1.1]: https://github.com/sebastianbergmann/diff/compare/2.1.0...2.1.1
|
||||
[2.1.0]: https://github.com/sebastianbergmann/diff/compare/2.0.0...2.1.0
|
||||
[2.0.0]: https://github.com/sebastianbergmann/diff/compare/1.0.9...2.0.0
|
||||
[5.0.3]: https://github.com/sebastianbergmann/php-timer/compare/5.0.2...5.0.3
|
||||
[5.0.2]: https://github.com/sebastianbergmann/php-timer/compare/5.0.1...5.0.2
|
||||
[5.0.1]: https://github.com/sebastianbergmann/php-timer/compare/5.0.0...5.0.1
|
||||
[5.0.0]: https://github.com/sebastianbergmann/php-timer/compare/4.0.0...5.0.0
|
||||
[4.0.0]: https://github.com/sebastianbergmann/php-timer/compare/3.1.4...4.0.0
|
||||
[3.1.4]: https://github.com/sebastianbergmann/php-timer/compare/3.1.3...3.1.4
|
||||
[3.1.3]: https://github.com/sebastianbergmann/php-timer/compare/3.1.2...3.1.3
|
||||
[3.1.2]: https://github.com/sebastianbergmann/php-timer/compare/3.1.1...3.1.2
|
||||
[3.1.1]: https://github.com/sebastianbergmann/php-timer/compare/3.1.0...3.1.1
|
||||
[3.1.0]: https://github.com/sebastianbergmann/php-timer/compare/3.0.0...3.1.0
|
||||
[3.0.0]: https://github.com/sebastianbergmann/php-timer/compare/2.1.2...3.0.0
|
||||
[2.1.2]: https://github.com/sebastianbergmann/php-timer/compare/2.1.1...2.1.2
|
||||
[2.1.1]: https://github.com/sebastianbergmann/php-timer/compare/2.1.0...2.1.1
|
||||
[2.1.0]: https://github.com/sebastianbergmann/php-timer/compare/2.0.0...2.1.0
|
||||
[2.0.0]: https://github.com/sebastianbergmann/php-timer/compare/1.0.9...2.0.0
|
||||
|
2
vendor/phpunit/php-timer/LICENSE
vendored
2
vendor/phpunit/php-timer/LICENSE
vendored
@@ -1,6 +1,6 @@
|
||||
phpunit/php-timer
|
||||
|
||||
Copyright (c) 2010-2019, Sebastian Bergmann <sebastian@phpunit.de>.
|
||||
Copyright (c) 2010-2020, Sebastian Bergmann <sebastian@phpunit.de>.
|
||||
All rights reserved.
|
||||
|
||||
Redistribution and use in source and binary forms, with or without
|
||||
|
83
vendor/phpunit/php-timer/README.md
vendored
83
vendor/phpunit/php-timer/README.md
vendored
@@ -1,49 +1,104 @@
|
||||
[](https://travis-ci.org/sebastianbergmann/php-timer)
|
||||
|
||||
# phpunit/php-timer
|
||||
|
||||
[](https://github.com/sebastianbergmann/php-timer/actions)
|
||||
[](https://shepherd.dev/github/sebastianbergmann/php-timer)
|
||||
|
||||
Utility class for timing things, factored out of PHPUnit into a stand-alone component.
|
||||
|
||||
## Installation
|
||||
|
||||
You can add this library as a local, per-project dependency to your project using [Composer](https://getcomposer.org/):
|
||||
|
||||
composer require phpunit/php-timer
|
||||
```
|
||||
composer require phpunit/php-timer
|
||||
```
|
||||
|
||||
If you only need this library during development, for instance to run your project's test suite, then you should add it as a development-time dependency:
|
||||
|
||||
composer require --dev phpunit/php-timer
|
||||
```
|
||||
composer require --dev phpunit/php-timer
|
||||
```
|
||||
|
||||
## Usage
|
||||
|
||||
### Basic Timing
|
||||
|
||||
```php
|
||||
require __DIR__ . '/vendor/autoload.php';
|
||||
|
||||
use SebastianBergmann\Timer\Timer;
|
||||
|
||||
Timer::start();
|
||||
$timer = new Timer;
|
||||
|
||||
// ...
|
||||
$timer->start();
|
||||
|
||||
$time = Timer::stop();
|
||||
var_dump($time);
|
||||
foreach (\range(0, 100000) as $i) {
|
||||
// ...
|
||||
}
|
||||
|
||||
print Timer::secondsToTimeString($time);
|
||||
$duration = $timer->stop();
|
||||
|
||||
var_dump(get_class($duration));
|
||||
var_dump($duration->asString());
|
||||
var_dump($duration->asSeconds());
|
||||
var_dump($duration->asMilliseconds());
|
||||
var_dump($duration->asMicroseconds());
|
||||
var_dump($duration->asNanoseconds());
|
||||
```
|
||||
|
||||
The code above yields the output below:
|
||||
|
||||
double(1.0967254638672E-5)
|
||||
0 ms
|
||||
```
|
||||
string(32) "SebastianBergmann\Timer\Duration"
|
||||
string(9) "00:00.002"
|
||||
float(0.002851062)
|
||||
float(2.851062)
|
||||
float(2851.062)
|
||||
int(2851062)
|
||||
```
|
||||
|
||||
### Resource Consumption Since PHP Startup
|
||||
### Resource Consumption
|
||||
|
||||
#### Explicit duration
|
||||
|
||||
```php
|
||||
require __DIR__ . '/vendor/autoload.php';
|
||||
|
||||
use SebastianBergmann\Timer\ResourceUsageFormatter;
|
||||
use SebastianBergmann\Timer\Timer;
|
||||
|
||||
print Timer::resourceUsage();
|
||||
$timer = new Timer;
|
||||
$timer->start();
|
||||
|
||||
foreach (\range(0, 100000) as $i) {
|
||||
// ...
|
||||
}
|
||||
|
||||
print (new ResourceUsageFormatter)->resourceUsage($timer->stop());
|
||||
```
|
||||
|
||||
The code above yields the output below:
|
||||
|
||||
Time: 0 ms, Memory: 0.50MB
|
||||
```
|
||||
Time: 00:00.002, Memory: 6.00 MB
|
||||
```
|
||||
|
||||
#### Duration since PHP Startup (using unreliable `$_SERVER['REQUEST_TIME_FLOAT']`)
|
||||
|
||||
```php
|
||||
require __DIR__ . '/vendor/autoload.php';
|
||||
|
||||
use SebastianBergmann\Timer\ResourceUsageFormatter;
|
||||
|
||||
foreach (\range(0, 100000) as $i) {
|
||||
// ...
|
||||
}
|
||||
|
||||
print (new ResourceUsageFormatter)->resourceUsageSinceStartOfRequest();
|
||||
```
|
||||
|
||||
The code above yields the output below:
|
||||
|
||||
```
|
||||
Time: 00:00.002, Memory: 6.00 MB
|
||||
```
|
||||
|
20
vendor/phpunit/php-timer/build.xml
vendored
20
vendor/phpunit/php-timer/build.xml
vendored
@@ -1,20 +0,0 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project name="php-timer" default="setup">
|
||||
<target name="setup" depends="clean,composer"/>
|
||||
|
||||
<target name="clean" description="Cleanup build artifacts">
|
||||
<delete dir="${basedir}/vendor"/>
|
||||
<delete file="${basedir}/composer.lock"/>
|
||||
</target>
|
||||
|
||||
<target name="composer" depends="clean" description="Install dependencies with Composer">
|
||||
<exec executable="composer" taskname="composer">
|
||||
<arg value="update"/>
|
||||
<arg value="--no-interaction"/>
|
||||
<arg value="--no-progress"/>
|
||||
<arg value="--no-ansi"/>
|
||||
<arg value="--no-suggest"/>
|
||||
</exec>
|
||||
</target>
|
||||
</project>
|
||||
|
9
vendor/phpunit/php-timer/composer.json
vendored
9
vendor/phpunit/php-timer/composer.json
vendored
@@ -19,12 +19,15 @@
|
||||
},
|
||||
"prefer-stable": true,
|
||||
"require": {
|
||||
"php": ">=7.1"
|
||||
"php": ">=7.3"
|
||||
},
|
||||
"require-dev": {
|
||||
"phpunit/phpunit": "^8.5"
|
||||
"phpunit/phpunit": "^9.3"
|
||||
},
|
||||
"config": {
|
||||
"platform": {
|
||||
"php": "7.3.0"
|
||||
},
|
||||
"optimize-autoloader": true,
|
||||
"sort-packages": true
|
||||
},
|
||||
@@ -35,7 +38,7 @@
|
||||
},
|
||||
"extra": {
|
||||
"branch-alias": {
|
||||
"dev-master": "2.1-dev"
|
||||
"dev-master": "5.0-dev"
|
||||
}
|
||||
}
|
||||
}
|
||||
|
19
vendor/phpunit/php-timer/phpunit.xml
vendored
19
vendor/phpunit/php-timer/phpunit.xml
vendored
@@ -1,19 +0,0 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<phpunit xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
|
||||
xsi:noNamespaceSchemaLocation="https://schema.phpunit.de/7.0/phpunit.xsd"
|
||||
bootstrap="vendor/autoload.php"
|
||||
forceCoversAnnotation="true"
|
||||
beStrictAboutCoversAnnotation="true"
|
||||
beStrictAboutOutputDuringTests="true"
|
||||
beStrictAboutTodoAnnotatedTests="true"
|
||||
verbose="true">
|
||||
<testsuite name="default">
|
||||
<directory suffix="Test.php">tests</directory>
|
||||
</testsuite>
|
||||
|
||||
<filter>
|
||||
<whitelist processUncoveredFilesFromWhitelist="true">
|
||||
<directory suffix=".php">src</directory>
|
||||
</whitelist>
|
||||
</filter>
|
||||
</phpunit>
|
109
vendor/phpunit/php-timer/src/Duration.php
vendored
Normal file
109
vendor/phpunit/php-timer/src/Duration.php
vendored
Normal file
@@ -0,0 +1,109 @@
|
||||
<?php declare(strict_types=1);
|
||||
/*
|
||||
* This file is part of phpunit/php-timer.
|
||||
*
|
||||
* (c) Sebastian Bergmann <sebastian@phpunit.de>
|
||||
*
|
||||
* For the full copyright and license information, please view the LICENSE
|
||||
* file that was distributed with this source code.
|
||||
*/
|
||||
namespace SebastianBergmann\Timer;
|
||||
|
||||
use function floor;
|
||||
use function sprintf;
|
||||
|
||||
/**
|
||||
* @psalm-immutable
|
||||
*/
|
||||
final class Duration
|
||||
{
|
||||
/**
|
||||
* @var float
|
||||
*/
|
||||
private $nanoseconds;
|
||||
|
||||
/**
|
||||
* @var int
|
||||
*/
|
||||
private $hours;
|
||||
|
||||
/**
|
||||
* @var int
|
||||
*/
|
||||
private $minutes;
|
||||
|
||||
/**
|
||||
* @var int
|
||||
*/
|
||||
private $seconds;
|
||||
|
||||
/**
|
||||
* @var int
|
||||
*/
|
||||
private $milliseconds;
|
||||
|
||||
public static function fromMicroseconds(float $microseconds): self
|
||||
{
|
||||
return new self($microseconds * 1000);
|
||||
}
|
||||
|
||||
public static function fromNanoseconds(float $nanoseconds): self
|
||||
{
|
||||
return new self($nanoseconds);
|
||||
}
|
||||
|
||||
private function __construct(float $nanoseconds)
|
||||
{
|
||||
$this->nanoseconds = $nanoseconds;
|
||||
$timeInMilliseconds = $nanoseconds / 1000000;
|
||||
$hours = floor($timeInMilliseconds / 60 / 60 / 1000);
|
||||
$hoursInMilliseconds = $hours * 60 * 60 * 1000;
|
||||
$minutes = floor($timeInMilliseconds / 60 / 1000) % 60;
|
||||
$minutesInMilliseconds = $minutes * 60 * 1000;
|
||||
$seconds = floor(($timeInMilliseconds - $hoursInMilliseconds - $minutesInMilliseconds) / 1000);
|
||||
$secondsInMilliseconds = $seconds * 1000;
|
||||
$milliseconds = $timeInMilliseconds - $hoursInMilliseconds - $minutesInMilliseconds - $secondsInMilliseconds;
|
||||
$this->hours = (int) $hours;
|
||||
$this->minutes = $minutes;
|
||||
$this->seconds = (int) $seconds;
|
||||
$this->milliseconds = (int) $milliseconds;
|
||||
}
|
||||
|
||||
public function asNanoseconds(): float
|
||||
{
|
||||
return $this->nanoseconds;
|
||||
}
|
||||
|
||||
public function asMicroseconds(): float
|
||||
{
|
||||
return $this->nanoseconds / 1000;
|
||||
}
|
||||
|
||||
public function asMilliseconds(): float
|
||||
{
|
||||
return $this->nanoseconds / 1000000;
|
||||
}
|
||||
|
||||
public function asSeconds(): float
|
||||
{
|
||||
return $this->nanoseconds / 1000000000;
|
||||
}
|
||||
|
||||
public function asString(): string
|
||||
{
|
||||
$result = '';
|
||||
|
||||
if ($this->hours > 0) {
|
||||
$result = sprintf('%02d', $this->hours) . ':';
|
||||
}
|
||||
|
||||
$result .= sprintf('%02d', $this->minutes) . ':';
|
||||
$result .= sprintf('%02d', $this->seconds);
|
||||
|
||||
if ($this->milliseconds > 0) {
|
||||
$result .= '.' . sprintf('%03d', $this->milliseconds);
|
||||
}
|
||||
|
||||
return $result;
|
||||
}
|
||||
}
|
73
vendor/phpunit/php-timer/src/ResourceUsageFormatter.php
vendored
Normal file
73
vendor/phpunit/php-timer/src/ResourceUsageFormatter.php
vendored
Normal file
@@ -0,0 +1,73 @@
|
||||
<?php declare(strict_types=1);
|
||||
/*
|
||||
* This file is part of phpunit/php-timer.
|
||||
*
|
||||
* (c) Sebastian Bergmann <sebastian@phpunit.de>
|
||||
*
|
||||
* For the full copyright and license information, please view the LICENSE
|
||||
* file that was distributed with this source code.
|
||||
*/
|
||||
namespace SebastianBergmann\Timer;
|
||||
|
||||
use function is_float;
|
||||
use function memory_get_peak_usage;
|
||||
use function microtime;
|
||||
use function sprintf;
|
||||
|
||||
final class ResourceUsageFormatter
|
||||
{
|
||||
/**
|
||||
* @psalm-var array<string,int>
|
||||
*/
|
||||
private const SIZES = [
|
||||
'GB' => 1073741824,
|
||||
'MB' => 1048576,
|
||||
'KB' => 1024,
|
||||
];
|
||||
|
||||
public function resourceUsage(Duration $duration): string
|
||||
{
|
||||
return sprintf(
|
||||
'Time: %s, Memory: %s',
|
||||
$duration->asString(),
|
||||
$this->bytesToString(memory_get_peak_usage(true))
|
||||
);
|
||||
}
|
||||
|
||||
/**
|
||||
* @throws TimeSinceStartOfRequestNotAvailableException
|
||||
*/
|
||||
public function resourceUsageSinceStartOfRequest(): string
|
||||
{
|
||||
if (!isset($_SERVER['REQUEST_TIME_FLOAT'])) {
|
||||
throw new TimeSinceStartOfRequestNotAvailableException(
|
||||
'Cannot determine time at which the request started because $_SERVER[\'REQUEST_TIME_FLOAT\'] is not available'
|
||||
);
|
||||
}
|
||||
|
||||
if (!is_float($_SERVER['REQUEST_TIME_FLOAT'])) {
|
||||
throw new TimeSinceStartOfRequestNotAvailableException(
|
||||
'Cannot determine time at which the request started because $_SERVER[\'REQUEST_TIME_FLOAT\'] is not of type float'
|
||||
);
|
||||
}
|
||||
|
||||
return $this->resourceUsage(
|
||||
Duration::fromMicroseconds(
|
||||
(1000000 * (microtime(true) - $_SERVER['REQUEST_TIME_FLOAT']))
|
||||
)
|
||||
);
|
||||
}
|
||||
|
||||
private function bytesToString(int $bytes): string
|
||||
{
|
||||
foreach (self::SIZES as $unit => $value) {
|
||||
if ($bytes >= $value) {
|
||||
return sprintf('%.2f %s', $bytes >= 1024 ? $bytes / $value : $bytes, $unit);
|
||||
}
|
||||
}
|
||||
|
||||
// @codeCoverageIgnoreStart
|
||||
return $bytes . ' byte' . ($bytes !== 1 ? 's' : '');
|
||||
// @codeCoverageIgnoreEnd
|
||||
}
|
||||
}
|
92
vendor/phpunit/php-timer/src/Timer.php
vendored
92
vendor/phpunit/php-timer/src/Timer.php
vendored
@@ -9,92 +9,32 @@
|
||||
*/
|
||||
namespace SebastianBergmann\Timer;
|
||||
|
||||
use function array_pop;
|
||||
use function hrtime;
|
||||
|
||||
final class Timer
|
||||
{
|
||||
/**
|
||||
* @var int[]
|
||||
* @psalm-var list<float>
|
||||
*/
|
||||
private static $sizes = [
|
||||
'GB' => 1073741824,
|
||||
'MB' => 1048576,
|
||||
'KB' => 1024,
|
||||
];
|
||||
private $startTimes = [];
|
||||
|
||||
/**
|
||||
* @var int[]
|
||||
*/
|
||||
private static $times = [
|
||||
'hour' => 3600000,
|
||||
'minute' => 60000,
|
||||
'second' => 1000,
|
||||
];
|
||||
|
||||
/**
|
||||
* @var float[]
|
||||
*/
|
||||
private static $startTimes = [];
|
||||
|
||||
public static function start(): void
|
||||
public function start(): void
|
||||
{
|
||||
self::$startTimes[] = \microtime(true);
|
||||
$this->startTimes[] = (float) hrtime(true);
|
||||
}
|
||||
|
||||
public static function stop(): float
|
||||
/**
|
||||
* @throws NoActiveTimerException
|
||||
*/
|
||||
public function stop(): Duration
|
||||
{
|
||||
return \microtime(true) - \array_pop(self::$startTimes);
|
||||
}
|
||||
|
||||
public static function bytesToString(float $bytes): string
|
||||
{
|
||||
foreach (self::$sizes as $unit => $value) {
|
||||
if ($bytes >= $value) {
|
||||
return \sprintf('%.2f %s', $bytes >= 1024 ? $bytes / $value : $bytes, $unit);
|
||||
}
|
||||
if (empty($this->startTimes)) {
|
||||
throw new NoActiveTimerException(
|
||||
'Timer::start() has to be called before Timer::stop()'
|
||||
);
|
||||
}
|
||||
|
||||
return $bytes . ' byte' . ((int) $bytes !== 1 ? 's' : '');
|
||||
}
|
||||
|
||||
public static function secondsToTimeString(float $time): string
|
||||
{
|
||||
$ms = \round($time * 1000);
|
||||
|
||||
foreach (self::$times as $unit => $value) {
|
||||
if ($ms >= $value) {
|
||||
$time = \floor($ms / $value * 100.0) / 100.0;
|
||||
|
||||
return $time . ' ' . ($time == 1 ? $unit : $unit . 's');
|
||||
}
|
||||
}
|
||||
|
||||
return $ms . ' ms';
|
||||
}
|
||||
|
||||
/**
|
||||
* @throws RuntimeException
|
||||
*/
|
||||
public static function timeSinceStartOfRequest(): string
|
||||
{
|
||||
if (isset($_SERVER['REQUEST_TIME_FLOAT'])) {
|
||||
$startOfRequest = $_SERVER['REQUEST_TIME_FLOAT'];
|
||||
} elseif (isset($_SERVER['REQUEST_TIME'])) {
|
||||
$startOfRequest = $_SERVER['REQUEST_TIME'];
|
||||
} else {
|
||||
throw new RuntimeException('Cannot determine time at which the request started');
|
||||
}
|
||||
|
||||
return self::secondsToTimeString(\microtime(true) - $startOfRequest);
|
||||
}
|
||||
|
||||
/**
|
||||
* @throws RuntimeException
|
||||
*/
|
||||
public static function resourceUsage(): string
|
||||
{
|
||||
return \sprintf(
|
||||
'Time: %s, Memory: %s',
|
||||
self::timeSinceStartOfRequest(),
|
||||
self::bytesToString(\memory_get_peak_usage(true))
|
||||
);
|
||||
return Duration::fromNanoseconds((float) hrtime(true) - array_pop($this->startTimes));
|
||||
}
|
||||
}
|
||||
|
@@ -9,6 +9,8 @@
|
||||
*/
|
||||
namespace SebastianBergmann\Timer;
|
||||
|
||||
interface Exception
|
||||
use Throwable;
|
||||
|
||||
interface Exception extends Throwable
|
||||
{
|
||||
}
|
@@ -9,6 +9,8 @@
|
||||
*/
|
||||
namespace SebastianBergmann\Timer;
|
||||
|
||||
final class RuntimeException extends \RuntimeException implements Exception
|
||||
use LogicException;
|
||||
|
||||
final class NoActiveTimerException extends LogicException implements Exception
|
||||
{
|
||||
}
|
16
vendor/phpunit/php-timer/src/exceptions/TimeSinceStartOfRequestNotAvailableException.php
vendored
Normal file
16
vendor/phpunit/php-timer/src/exceptions/TimeSinceStartOfRequestNotAvailableException.php
vendored
Normal file
@@ -0,0 +1,16 @@
|
||||
<?php declare(strict_types=1);
|
||||
/*
|
||||
* This file is part of phpunit/php-timer.
|
||||
*
|
||||
* (c) Sebastian Bergmann <sebastian@phpunit.de>
|
||||
*
|
||||
* For the full copyright and license information, please view the LICENSE
|
||||
* file that was distributed with this source code.
|
||||
*/
|
||||
namespace SebastianBergmann\Timer;
|
||||
|
||||
use RuntimeException;
|
||||
|
||||
final class TimeSinceStartOfRequestNotAvailableException extends RuntimeException implements Exception
|
||||
{
|
||||
}
|
134
vendor/phpunit/php-timer/tests/TimerTest.php
vendored
134
vendor/phpunit/php-timer/tests/TimerTest.php
vendored
@@ -1,134 +0,0 @@
|
||||
<?php declare(strict_types=1);
|
||||
/*
|
||||
* This file is part of phpunit/php-timer.
|
||||
*
|
||||
* (c) Sebastian Bergmann <sebastian@phpunit.de>
|
||||
*
|
||||
* For the full copyright and license information, please view the LICENSE
|
||||
* file that was distributed with this source code.
|
||||
*/
|
||||
namespace SebastianBergmann\Timer;
|
||||
|
||||
use PHPUnit\Framework\TestCase;
|
||||
|
||||
/**
|
||||
* @covers \SebastianBergmann\Timer\Timer
|
||||
*/
|
||||
final class TimerTest extends TestCase
|
||||
{
|
||||
public function testCanBeStartedAndStopped(): void
|
||||
{
|
||||
$this->assertIsFloat(Timer::stop());
|
||||
}
|
||||
|
||||
public function testCanFormatTimeSinceStartOfRequest(): void
|
||||
{
|
||||
$this->assertStringMatchesFormat('%f %s', Timer::timeSinceStartOfRequest());
|
||||
}
|
||||
|
||||
/**
|
||||
* @backupGlobals enabled
|
||||
*/
|
||||
public function testCanFormatSinceStartOfRequestWhenRequestTimeIsNotAvailableAsFloat(): void
|
||||
{
|
||||
if (isset($_SERVER['REQUEST_TIME_FLOAT'])) {
|
||||
unset($_SERVER['REQUEST_TIME_FLOAT']);
|
||||
}
|
||||
|
||||
$this->assertStringMatchesFormat('%f %s', Timer::timeSinceStartOfRequest());
|
||||
}
|
||||
|
||||
/**
|
||||
* @backupGlobals enabled
|
||||
*/
|
||||
public function testCannotFormatTimeSinceStartOfRequestWhenRequestTimeIsNotAvailable(): void
|
||||
{
|
||||
if (isset($_SERVER['REQUEST_TIME_FLOAT'])) {
|
||||
unset($_SERVER['REQUEST_TIME_FLOAT']);
|
||||
}
|
||||
|
||||
if (isset($_SERVER['REQUEST_TIME'])) {
|
||||
unset($_SERVER['REQUEST_TIME']);
|
||||
}
|
||||
|
||||
$this->expectException(RuntimeException::class);
|
||||
|
||||
Timer::timeSinceStartOfRequest();
|
||||
}
|
||||
|
||||
public function testCanFormatResourceUsage(): void
|
||||
{
|
||||
$this->assertStringMatchesFormat('Time: %s, Memory: %f %s', Timer::resourceUsage());
|
||||
}
|
||||
|
||||
/**
|
||||
* @dataProvider secondsProvider
|
||||
*/
|
||||
public function testCanFormatSecondsAsString(string $string, float $seconds): void
|
||||
{
|
||||
$this->assertEquals($string, Timer::secondsToTimeString($seconds));
|
||||
}
|
||||
|
||||
public function secondsProvider(): array
|
||||
{
|
||||
return [
|
||||
['0 ms', 0],
|
||||
['1 ms', .001],
|
||||
['10 ms', .01],
|
||||
['100 ms', .1],
|
||||
['999 ms', .999],
|
||||
['1 second', .9999],
|
||||
['1 second', 1],
|
||||
['2 seconds', 2],
|
||||
['59.9 seconds', 59.9],
|
||||
['59.99 seconds', 59.99],
|
||||
['59.99 seconds', 59.999],
|
||||
['1 minute', 59.9999],
|
||||
['59 seconds', 59.001],
|
||||
['59.01 seconds', 59.01],
|
||||
['1 minute', 60],
|
||||
['1.01 minutes', 61],
|
||||
['2 minutes', 120],
|
||||
['2.01 minutes', 121],
|
||||
['59.99 minutes', 3599.9],
|
||||
['59.99 minutes', 3599.99],
|
||||
['59.99 minutes', 3599.999],
|
||||
['1 hour', 3599.9999],
|
||||
['59.98 minutes', 3599.001],
|
||||
['59.98 minutes', 3599.01],
|
||||
['1 hour', 3600],
|
||||
['1 hour', 3601],
|
||||
['1 hour', 3601.9],
|
||||
['1 hour', 3601.99],
|
||||
['1 hour', 3601.999],
|
||||
['1 hour', 3601.9999],
|
||||
['1.01 hours', 3659.9999],
|
||||
['1.01 hours', 3659.001],
|
||||
['1.01 hours', 3659.01],
|
||||
['2 hours', 7199.9999],
|
||||
];
|
||||
}
|
||||
|
||||
/**
|
||||
* @dataProvider bytesProvider
|
||||
*/
|
||||
public function testCanFormatBytesAsString(string $string, float $bytes): void
|
||||
{
|
||||
$this->assertEquals($string, Timer::bytesToString($bytes));
|
||||
}
|
||||
|
||||
public function bytesProvider(): array
|
||||
{
|
||||
return [
|
||||
['0 bytes', 0],
|
||||
['1 byte', 1],
|
||||
['1023 bytes', 1023],
|
||||
['1.00 KB', 1024],
|
||||
['1.50 KB', 1.5 * 1024],
|
||||
['2.00 MB', 2 * 1048576],
|
||||
['2.50 MB', 2.5 * 1048576],
|
||||
['3.00 GB', 3 * 1073741824],
|
||||
['3.50 GB', 3.5 * 1073741824],
|
||||
];
|
||||
}
|
||||
}
|
Reference in New Issue
Block a user