From e3dd893b9d18acb02e72b2ab64e4e37c8cb1f81f Mon Sep 17 00:00:00 2001 From: Steevan BARBOYON Date: Fri, 17 Jan 2020 16:12:10 +0100 Subject: [PATCH] Compatibility with benchmark kit 4.0.0-DEV --- .circleci/config.yml | 21 +++++ .gitignore | 2 +- .../AbstractComponentConfiguration.php | 92 ------------------- .phpbenchmarks/config.yml | 19 ++++ .phpbenchmarks/{ => nginx}/vhost.conf | 4 +- .../7.0/composer.lock} | 4 +- .phpbenchmarks/{ => php/7.0}/initBenchmark.sh | 0 .phpbenchmarks/php/7.0/php.ini | 0 .../7.0}/responseBody/responseBody.json | 0 README.md | 20 ++-- composer.json | 6 +- public/index.php | 4 +- .../JsonSerializableToSerialize.php | 2 +- .../JsonSerializableFactory.php | 4 +- 14 files changed, 61 insertions(+), 117 deletions(-) create mode 100644 .circleci/config.yml delete mode 100644 .phpbenchmarks/AbstractComponentConfiguration.php create mode 100644 .phpbenchmarks/config.yml rename .phpbenchmarks/{ => nginx}/vhost.conf (79%) rename .phpbenchmarks/{composer/composer.lock.php7.0 => php/7.0/composer.lock} (95%) rename .phpbenchmarks/{ => php/7.0}/initBenchmark.sh (100%) create mode 100644 .phpbenchmarks/php/7.0/php.ini rename .phpbenchmarks/{ => php/7.0}/responseBody/responseBody.json (100%) diff --git a/.circleci/config.yml b/.circleci/config.yml new file mode 100644 index 0000000..041b39b --- /dev/null +++ b/.circleci/config.yml @@ -0,0 +1,21 @@ +version: '2.1' + +jobs: + ValidateBenchmark: + docker: + - image: phpbenchmarks/benchmark-kit:4 + working_directory: /var/www/benchmark + steps: + - checkout + - run: + name: /var/entrypoint.sh + command: /var/entrypoint.sh --nginx-as-service + - run: + name: "benchmark:validate" + command: "/var/benchmark-kit/bin/console benchmark:validate:all" + +workflows: + version: '2.1' + BenchmarkKit: + jobs: + - ValidateBenchmark diff --git a/.gitignore b/.gitignore index 4fbb073..de4a392 100644 --- a/.gitignore +++ b/.gitignore @@ -1,2 +1,2 @@ -/vendor/ +/vendor /composer.lock diff --git a/.phpbenchmarks/AbstractComponentConfiguration.php b/.phpbenchmarks/AbstractComponentConfiguration.php deleted file mode 100644 index 12e25f3..0000000 --- a/.phpbenchmarks/AbstractComponentConfiguration.php +++ /dev/null @@ -1,92 +0,0 @@ - 'https://github.com/phpbenchmarks/php/blob/php_7.0_json-serialization-big-overload/public/index.php#L15', - 'integerSerialization' => 'https://github.com/phpbenchmarks/php/blob/php_7.0_json-serialization-big-overload/public/index.php#L15', - 'floatSerialization' => 'https://github.com/phpbenchmarks/php/blob/php_7.0_json-serialization-big-overload/public/index.php#L15', - 'stringSerialization' => 'https://github.com/phpbenchmarks/php/blob/php_7.0_json-serialization-big-overload/public/index.php#L15', - 'booleanSerialization' => 'https://github.com/phpbenchmarks/php/blob/php_7.0_json-serialization-big-overload/public/index.php#L15', - 'nullSerialization' => 'https://github.com/phpbenchmarks/php/blob/php_7.0_json-serialization-big-overload/public/index.php#L15', - 'arraySerialization' => 'https://github.com/phpbenchmarks/php/blob/php_7.0_json-serialization-big-overload/public/index.php#L15', - 'objectSerialization' => 'https://github.com/phpbenchmarks/php/blob/php_7.0_json-serialization-big-overload/public/index.php#L15' - ]; - } -} diff --git a/.phpbenchmarks/config.yml b/.phpbenchmarks/config.yml new file mode 100644 index 0000000..c991889 --- /dev/null +++ b/.phpbenchmarks/config.yml @@ -0,0 +1,19 @@ +component: + id: 1 +benchmark: + type: 8 + relativeUrl: / +sourceCode: + entryPoint: public/index.php + urls: + jsonSerialization: 'https://github.com/phpbenchmarks/php/tree/7.0.33_json-serialization-big-overload_0/public/index.php#L15' + integerSerialization: 'https://github.com/phpbenchmarks/php/tree/7.0.33_json-serialization-big-overload_0/public/index.php#L15' + floatSerialization: 'https://github.com/phpbenchmarks/php/tree/7.0.33_json-serialization-big-overload_0/public/index.php#L15' + stringSerialization: 'https://github.com/phpbenchmarks/php/tree/7.0.33_json-serialization-big-overload_0/public/index.php#L15' + booleanSerialization: 'https://github.com/phpbenchmarks/php/tree/7.0.33_json-serialization-big-overload_0/public/index.php#L15' + nullSerialization: 'https://github.com/phpbenchmarks/php/tree/7.0.33_json-serialization-big-overload_0/public/index.php#L15' + arraySerialization: 'https://github.com/phpbenchmarks/php/tree/7.0.33_json-serialization-big-overload_0/public/index.php#L15' + objectSerialization: 'https://github.com/phpbenchmarks/php/tree/7.0.33_json-serialization-big-overload_0/public/index.php#L15' +coreDependency: + name: php + version: 7.0.33 diff --git a/.phpbenchmarks/vhost.conf b/.phpbenchmarks/nginx/vhost.conf similarity index 79% rename from .phpbenchmarks/vhost.conf rename to .phpbenchmarks/nginx/vhost.conf index 2caa86c..d7dba5a 100644 --- a/.phpbenchmarks/vhost.conf +++ b/.phpbenchmarks/nginx/vhost.conf @@ -1,5 +1,5 @@ server { - listen 80; + listen ____PORT____; server_name ____HOST____; root ____INSTALLATION_PATH____/public; location / { @@ -12,6 +12,4 @@ server { fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name; fastcgi_param HTTPS off; } - error_log /var/log/nginx/benchmark_error.log; - access_log /var/log/nginx/benchmark_access.log; } diff --git a/.phpbenchmarks/composer/composer.lock.php7.0 b/.phpbenchmarks/php/7.0/composer.lock similarity index 95% rename from .phpbenchmarks/composer/composer.lock.php7.0 rename to .phpbenchmarks/php/7.0/composer.lock index 1000561..4058883 100644 --- a/.phpbenchmarks/composer/composer.lock.php7.0 +++ b/.phpbenchmarks/php/7.0/composer.lock @@ -4,7 +4,7 @@ "Read more about it at https://getcomposer.org/doc/01-basic-usage.md#installing-dependencies", "This file is @generated automatically" ], - "content-hash": "b1deeafe1a25c3fd2a5f7a580c99fe03", + "content-hash": "a4a91596334d29f7c9aceb523d784ed9", "packages": [ { "name": "phpbenchmarks/benchmark-json-serialization-big-overload", @@ -44,7 +44,7 @@ "prefer-stable": false, "prefer-lowest": false, "platform": { - "php": "7.0.*", + "php": "7.0.33", "ext-json": "*" }, "platform-dev": [] diff --git a/.phpbenchmarks/initBenchmark.sh b/.phpbenchmarks/php/7.0/initBenchmark.sh similarity index 100% rename from .phpbenchmarks/initBenchmark.sh rename to .phpbenchmarks/php/7.0/initBenchmark.sh diff --git a/.phpbenchmarks/php/7.0/php.ini b/.phpbenchmarks/php/7.0/php.ini new file mode 100644 index 0000000..e69de29 diff --git a/.phpbenchmarks/responseBody/responseBody.json b/.phpbenchmarks/php/7.0/responseBody/responseBody.json similarity index 100% rename from .phpbenchmarks/responseBody/responseBody.json rename to .phpbenchmarks/php/7.0/responseBody/responseBody.json diff --git a/README.md b/README.md index 85a8c51..62a9a21 100644 --- a/README.md +++ b/README.md @@ -6,7 +6,7 @@ ## What is www.phpbenchmarks.com? -You will find lot of benchmarks for PHP frameworks, template engines and JSON serializers on [phpbenchmarks.com](http://www.phpbenchmarks.com). +You will find a lot of benchmarks for PHP and PHP libraries on [phpbenchmarks.com](http://www.phpbenchmarks.com). Benchmarks results are available from PHP 5.6 to latest version. @@ -14,9 +14,7 @@ Our benchmarking protocol is available on [benchmarking protocol page](http://ww ## What is this repository? -It contains PHP installation `only`. -To reuse code between minor versions, features for benchmarks are not coded in this repository -but in [phpbenchmarks/php-common](https://github.com/phpbenchmarks/php-common) repository. +It contains PHP benchmark code. Switch branch to select version and benchmark you want to see. @@ -33,12 +31,14 @@ Go to [community page](http://www.phpbenchmarks.com/en/community) to see the Hal ## How version works? -We do not follow semantic version for this repository. Here is an explanation about our versioning system: +We do not follow semantic version for this repository. -`W` PHP major version. +Here is an explanation about our versioning system: -`X` PHP minor version. +`X.Y.Z_benchmark-slug_W` -`Y` PHP bugfix version. - -`Z` Benchmark type: `6` JSON serialization of Hello world, `7` Small JSON serialization, `8` Big JSON serialization. +* `X`: PHP major version. +* `Y`: PHP minor version. +* `Z`: PHP patch version. +* `benchmark-slug`: slug of the benchmark, list available on [documentation page](http://www.phpbenchmarks.com/en/documentation). +* `W`: benchmark version diff --git a/composer.json b/composer.json index 21541b7..0aa0025 100644 --- a/composer.json +++ b/composer.json @@ -3,13 +3,13 @@ "license": "proprietary", "type": "project", "require": { - "php": "7.0.*", + "php": "7.0.33", "ext-json": "*", "phpbenchmarks/benchmark-json-serialization-big-overload": "1.0.0" }, "autoload": { "psr-4": { - "Php73\\BenchmarkJsonSerializationBigOverload\\": "src/" + "App\\": "src/" } } -} +} \ No newline at end of file diff --git a/public/index.php b/public/index.php index 57c5925..4a9800d 100644 --- a/public/index.php +++ b/public/index.php @@ -2,7 +2,7 @@ declare(strict_types=1); -use Php73\BenchmarkJsonSerializationBigOverload\ObjectToSerializeFactory\JsonSerializableFactory; +use App\ObjectToSerializeFactory\JsonSerializableFactory; use PhpBenchmarks\BenchmarkJsonSerializationBigOverload\BenchmarkService; require __DIR__ . '/../vendor/autoload.php'; @@ -14,5 +14,3 @@ } else { json_encode($benchmarkService->getDataToSerialize()); } - -// require phpbenchmarks stats.php here when needed diff --git a/src/ObjectToSerialize/JsonSerializableToSerialize.php b/src/ObjectToSerialize/JsonSerializableToSerialize.php index 33e8923..e33c199 100644 --- a/src/ObjectToSerialize/JsonSerializableToSerialize.php +++ b/src/ObjectToSerialize/JsonSerializableToSerialize.php @@ -2,7 +2,7 @@ declare(strict_types=1); -namespace Php73\BenchmarkJsonSerializationBigOverload\ObjectToSerialize; +namespace App\ObjectToSerialize; use PhpBenchmarks\BenchmarkJsonSerializationBigOverload\ObjectToSerialize\ObjectToSerialize; diff --git a/src/ObjectToSerializeFactory/JsonSerializableFactory.php b/src/ObjectToSerializeFactory/JsonSerializableFactory.php index 56e9d71..4639f9e 100644 --- a/src/ObjectToSerializeFactory/JsonSerializableFactory.php +++ b/src/ObjectToSerializeFactory/JsonSerializableFactory.php @@ -2,9 +2,9 @@ declare(strict_types=1); -namespace Php73\BenchmarkJsonSerializationBigOverload\ObjectToSerializeFactory; +namespace App\ObjectToSerializeFactory; -use Php73\BenchmarkJsonSerializationBigOverload\ObjectToSerialize\JsonSerializableToSerialize; +use App\ObjectToSerialize\JsonSerializableToSerialize; use PhpBenchmarks\BenchmarkJsonSerializationBigOverload\{ ObjectToSerialize\ObjectToSerializeInterface, ObjectToSerializeFactory\ObjectToSerializeFactoryInterface