summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--composer.json31
-rw-r--r--php-di-symfony2-bridge.spec135
2 files changed, 129 insertions, 37 deletions
diff --git a/composer.json b/composer.json
index e91cb4b..8a05788 100644
--- a/composer.json
+++ b/composer.json
@@ -1,18 +1,31 @@
{
- "name": "php-di/symfony2-bridge",
+ "name": "php-di/symfony-bridge",
"type": "library",
- "description": "Integrates PHP-DI to Symfony 2",
- "homepage": "https://github.com/PHP-DI/Symfony2-Bridge/",
+ "description": "Integrates PHP-DI to Symfony",
+ "homepage": "http://php-di.org/doc/frameworks/symfony2.html",
"license": "MIT",
"autoload": {
- "psr-0": {
- "DI\\Bridge\\Symfony": "src/",
- "UnitTest\\DI\\Bridge\\Symfony": "tests/",
- "FunctionalTest\\DI\\Bridge\\Symfony": "tests/"
+ "psr-4": {
+ "DI\\Bridge\\Symfony\\": "src/"
+ }
+ },
+ "autoload-dev": {
+ "psr-4": {
+ "DI\\Bridge\\Symfony\\Test\\": "tests/"
}
},
"require": {
- "php-di/php-di": "~4.0 || ^5.0",
- "symfony/dependency-injection": "~2.0"
+ "php": "~7.0",
+ "php-di/php-di": "~6.0",
+ "symfony/dependency-injection": "~3.3||~4.0",
+ "symfony/http-kernel": "~3.3||~4.0",
+ "symfony/proxy-manager-bridge": "~3.3||~4.0",
+ "symfony/config": "~3.3||~4.0"
+ },
+ "require-dev": {
+ "phpunit/phpunit": "^4.8",
+ "symfony/filesystem": "^3.0",
+ "symfony/yaml": "^3.0",
+ "symfony/debug": "^3.0"
}
}
diff --git a/php-di-symfony2-bridge.spec b/php-di-symfony2-bridge.spec
index 9582606..59501e9 100644
--- a/php-di-symfony2-bridge.spec
+++ b/php-di-symfony2-bridge.spec
@@ -12,18 +12,23 @@
%global github_owner PHP-DI
%global github_name Symfony2-Bridge
-%global github_version 1.1.0
-%global github_commit e197ddc965e21c8b865a74d45dd73e334b674bd3
+%global github_version 3.0.0
+%global github_commit d536a47f168b2c06fd15a2f902ea6d59ff8dc55d
%global composer_vendor php-di
%global composer_project symfony2-bridge
-# "php-di/php-di": "~4.0 || ^5.0"
-%global di_min_ver 4.0
-%global di_max_ver 6.0
-# "symfony/dependency-injection": "~2.0"
-%global symfony_min_ver 2.0
-%global symfony_max_ver 3.0
+# "php": ">=7.0.0"
+%global php_min_ver 7.0.0
+# "php-di/php-di": "~6.0"
+%global di_min_ver 6.0
+%global di_max_ver 7
+# "symfony/dependency-injection": "~3.3||~4.0",
+# "symfony/http-kernel": "~3.3||~4.0",
+# "symfony/proxy-manager-bridge": "~3.3||~4.0",
+# "symfony/config": "~3.3||~4.0"
+%global symfony_min_ver 3.3
+%global symfony_max_ver 5
# Build using "--without tests" to disable tests
%global with_tests 0%{!?_without_tests:1}
@@ -32,8 +37,8 @@
Name: %{composer_vendor}-%{composer_project}
Version: %{github_version}
-Release: 9%{?github_release}%{?dist}
-Summary: PHP-DI integration with Symfony 2
+Release: 1%{?github_release}%{?dist}
+Summary: PHP-DI integration with Symfony
License: MIT
URL: http://php-di.org/doc/frameworks/symfony2.html
@@ -47,24 +52,61 @@ BuildArch: noarch
# Tests
%if %{with_tests}
## composer.json
+BuildRequires: php-composer(phpunit/phpunit)
+%if 0%{?fedora} >= 27 || 0%{?rhel} >= 8
+BuildRequires:(php-composer(php-di/php-di) >= %{di_min_ver} with php-composer(php-di/php-di) < %{di_max_ver})
+BuildRequires:(php-composer(symfony/dependency-injection) >= %{symfony_min_ver} with php-composer(symfony/dependency-injection) < %{symfony_max_ver})
+BuildRequires:(php-composer(symfony/http-kernel) >= %{symfony_min_ver} with php-composer(symfony/http-kernel) < %{symfony_max_ver})
+BuildRequires:(php-composer(symfony/proxy-manager-bridge) >= %{symfony_min_ver} with php-composer(symfony/proxy-manager-bridge) < %{symfony_max_ver})
+BuildRequires:(php-composer(symfony/config) >= %{symfony_min_ver} with php-composer(symfony/config) < %{symfony_max_ver})
+BuildRequires:(php-composer(symfony/filesystem) >= %{symfony_min_ver} with php-composer(symfony/filesystem) < %{symfony_max_ver})
+BuildRequires:(php-composer(symfony/yaml) >= %{symfony_min_ver} with php-composer(symfony/yaml) < %{symfony_max_ver})
+BuildRequires:(php-composer(symfony/debug) >= %{symfony_min_ver} with php-composer(symfony/debug) < %{symfony_max_ver})
+%else
BuildRequires: php-composer(php-di/php-di) < %{di_max_ver}
BuildRequires: php-composer(php-di/php-di) >= %{di_min_ver}
-BuildRequires: php-composer(phpunit/phpunit)
BuildRequires: php-composer(symfony/dependency-injection) < %{symfony_max_ver}
BuildRequires: php-composer(symfony/dependency-injection) >= %{symfony_min_ver}
-## phpcompatinfo (computed from version 1.1.0)
-BuildRequires: php(language) >= 5.3.0
+BuildRequires: php-composer(symfony/http-kernel) < %{symfony_max_ver}
+BuildRequires: php-composer(symfony/http-kernel) >= %{symfony_min_ver}
+BuildRequires: php-composer(symfony/proxy-manager-bridge) < %{symfony_max_ver}
+BuildRequires: php-composer(symfony/proxy-manager-bridge) >= %{symfony_min_ver}
+BuildRequires: php-composer(symfony/config) < %{symfony_max_ver}
+BuildRequires: php-composer(symfony/config) >= %{symfony_min_ver}
+BuildRequires: php-composer(symfony/filesystem) < %{symfony_max_ver}
+BuildRequires: php-composer(symfony/filesystem) >= %{symfony_min_ver}
+BuildRequires: php-composer(symfony/yaml) < %{symfony_max_ver}
+BuildRequires: php-composer(symfony/yaml) >= %{symfony_min_ver}
+BuildRequires: php-composer(symfony/debug) < %{symfony_max_ver}
+BuildRequires: php-composer(symfony/debug) >= %{symfony_min_ver}
+%endif
+## phpcompatinfo (computed from version 3.0.0)
+BuildRequires: php(language) >= %{php_min_ver}
## Autoloader
BuildRequires: php-composer(fedora/autoloader)
%endif
# composer.json
-Requires: php-composer(php-di/php-di) >= %{di_min_ver}
+%if 0%{?fedora} >= 27 || 0%{?rhel} >= 8
+Requires: (php-composer(php-di/php-di) >= %{di_min_ver} with php-composer(php-di/php-di) < %{di_max_ver})
+Requires: (php-composer(symfony/dependency-injection) >= %{symfony_min_ver} with php-composer(symfony/dependency-injection) < %{symfony_max_ver})
+Requires: (php-composer(symfony/http-kernel) >= %{symfony_min_ver} with php-composer(symfony/http-kernel) < %{symfony_max_ver})
+Requires: (php-composer(symfony/proxy-manager-bridge) >= %{symfony_min_ver} with php-composer(symfony/proxy-manager-bridge) < %{symfony_max_ver})
+Requires: (php-composer(symfony/config) >= %{symfony_min_ver} with php-composer(symfony/config) < %{symfony_max_ver})
+%else
Requires: php-composer(php-di/php-di) < %{di_max_ver}
-Requires: php-composer(symfony/dependency-injection) >= %{symfony_min_ver}
+Requires: php-composer(php-di/php-di) >= %{di_min_ver}
Requires: php-composer(symfony/dependency-injection) < %{symfony_max_ver}
-# phpcompatinfo (computed from version 1.1.0)
-Requires: php(language) >= 5.3.0
+Requires: php-composer(symfony/dependency-injection) >= %{symfony_min_ver}
+Requires: php-composer(symfony/http-kernel) < %{symfony_max_ver}
+Requires: php-composer(symfony/http-kernel) >= %{symfony_min_ver}
+Requires: php-composer(symfony/proxy-manager-bridge) < %{symfony_max_ver}
+Requires: php-composer(symfony/proxy-manager-bridge) >= %{symfony_min_ver}
+Requires: php-composer(symfony/config) < %{symfony_max_ver}
+Requires: php-composer(symfony/config) >= %{symfony_min_ver}
+%endif
+# phpcompatinfo (computed from version 3.0.0)
+Requires: php(language) >= %{php_min_ver}
# Autoloader
Requires: php-composer(fedora/autoloader)
@@ -83,7 +125,7 @@ Autoloader: %{phpdir}/DI/Bridge/Symfony/autoload.php
%setup -qn %{github_name}-%{github_commit}
: Create autoloader
-cat <<'AUTOLOAD' | tee src/DI/Bridge/Symfony/autoload.php
+cat <<'AUTOLOAD' | tee src/autoload.php
<?php
/**
* Autoloader for %{name} and its' dependencies
@@ -95,11 +137,22 @@ require_once '%{phpdir}/Fedora/Autoloader/autoload.php';
\Fedora\Autoloader\Autoload::addPsr4('DI\\Bridge\\Symfony\\', __DIR__);
-\Fedora\Autoloader\Dependencies::required(array(
+\Fedora\Autoloader\Dependencies::required([
'%{phpdir}/DI/autoload.php',
- '%{phpdir}/Symfony/Component/DependencyInjection/autoload.php',
-));
-
+ [
+ '%{phpdir}/Symfony4/Component/DependencyInjection/autoload.php',
+ '%{phpdir}/Symfony3/Component/DependencyInjection/autoload.php',
+ ], [
+ '%{phpdir}/Symfony4/Component/HttpKernel/autoload.php',
+ '%{phpdir}/Symfony3/Component/HttpKernel/autoload.php',
+ ], [
+ '%{phpdir}/Symfony4/Bridge/ProxyManager/autoload.php',
+ '%{phpdir}/Symfony3/Bridge/ProxyManager/autoload.php',
+ ], [
+ '%{phpdir}/Symfony4/Component/Config/autoload.php',
+ '%{phpdir}/Symfony3/Component/Config/autoload.php',
+ ],
+]);
AUTOLOAD
@@ -108,8 +161,8 @@ AUTOLOAD
%install
-mkdir -p %{buildroot}%{phpdir}
-cp -rp src/* %{buildroot}%{phpdir}/
+mkdir -p %{buildroot}%{phpdir}/DI/Bridge
+cp -rp src %{buildroot}%{phpdir}/DI/Bridge/Symfony
%check
@@ -118,16 +171,34 @@ cp -rp src/* %{buildroot}%{phpdir}/
cat <<'BOOTSTRAP' | tee bootstrap.php
<?php
require_once '%{buildroot}%{phpdir}/DI/Bridge/Symfony/autoload.php';
-\Fedora\Autoloader\Autoload::addPsr0('FunctionalTest\\DI\\Bridge\\Symfony\\', __DIR__.'/tests');
-\Fedora\Autoloader\Autoload::addPsr0('UnitTest\\DI\\Bridge\\Symfony\\', __DIR__.'/tests');
+\Fedora\Autoloader\Autoload::addPsr4('DI\\Bridge\\Symfony\\Test\\', __DIR__.'/tests');
+\Fedora\Autoloader\Dependencies::required([
+ [
+ '%{phpdir}/Symfony4/Component/Filesystem/autoload.php',
+ '%{phpdir}/Symfony3/Component/Filesystem/autoload.php',
+ ], [
+ '%{phpdir}/Symfony4/Component/Yaml/autoload.php',
+ '%{phpdir}/Symfony3/Component/Yaml/autoload.php',
+ ], [
+ '%{phpdir}/Symfony4/Component/Config/autoload.php',
+ '%{phpdir}/Symfony3/Component/Config/autoload.php',
+ ],
+]);
BOOTSTRAP
+# TODO investigate on symfonyGetInPHPDI failure
+
: Run tests
-for cmd in php php56 php70 php71 php72; do
+ret=0
+for cmd in php php71 php72 php73 php74; do
if which $cmd; then
- $cmd %{_bindir}/phpunit --verbose --bootstrap bootstrap.php
+ $cmd %{_bindir}/phpunit \
+ --filter '^((?!(symfonyGetInPHPDI)).)*$' \
+ --bootstrap bootstrap.php \
+ --verbose || ret=1
fi
done
+exit $ret
%else
: Tests skipped
%endif
@@ -143,6 +214,14 @@ done
%changelog
+* Mon Jun 17 2019 Remi Collet <remi@remirepo.net> - 3.0.0-1
+- update to 3.0.0
+- add dependency on symfony/http-kernel
+- add dependency on symfony/proxy-manager-bridge
+- add dependency on symfony/config
+- switch from Symfony 2 to Sypmfony 3 or 4
+- raise dependency on php-di 6.0
+
* Wed May 10 2017 Remi Collet <remi@remirepo.net> - 1.1.0-5
- add max version to build dependencies
- run test suite against PHP SCLs when available