升级主要版本(例如4.4.0到5.0.0)

编辑本页

警告:您正在浏览的文档欧宝官网下载appob娱乐下载Symfony 5.3,现已不再维护。

本页的更新版本用于Syob娱乐下载mfony 6.2(当前稳定版本)。

升级主要版本(例如4.4.0到5.0.0)

每两年,Symfony会发布一个新ob娱乐下载的主要版本(第一个版本号会改变)。这些版本的升级是最棘手的,因为它们被允许破坏向后兼容性。然而,Symfonob娱乐下载y使这个升级过程尽可能顺利。

这意味着您可以在主要版本实际发布之前更新大部分代码。这叫做编写代码未来的兼容

升级主要版本有以下几个步骤:

  1. 让您的代码免于弃用
  2. 通过Composer更新到新的主版本
  3. 更新代码以使用新版本

1)让你的代码免于弃用

在主要版本的生命周期中,会添加新特性,改变方法签名和公共API使用。然而,小版本不应包含任何向后不兼容的更改。要做到这一点,“旧的”(例如函数,类等)代码仍然可以工作,但被标记为弃用,表示将来会删除/更改,并建议您停止使用。

当主要版本发布时(例如5.0.0),所有已弃用的特性和功能都将被删除。所以,只要你已经更新了你的代码,停止使用这些过时的功能在前一个版本的主要(例如。4.4 . *),你应该可以毫无问题地升级。这意味着你应该首先升级到最新的小版本(例如4.4)以便你能看到所有的用法。

为了帮助您找到已弃用的特性,每当您最终使用了已弃用的特性时,都会触发通知。中访问应用程序时开发环境在浏览器中,这些通知显示在web开发工具栏中:

最终,您应该致力于停止使用已弃用的功能。有时,警告可能会告诉您需要更改哪些内容。

但其他时候,警告可能不清楚:某个地方的设置可能会导致更深的类触发警告。在这种情况下,Symfonyob娱乐下载尽力给出一个明确的信息,但您可能需要进一步研究该警告。

有时,警告可能来自您正在使用的第三方库或包。如果这是真的,那么很有可能已经更新了那些已弃用的内容。在这种情况下,升级库来修复它们。

一旦所有弃用警告消失,您就可以更有信心地升级了。

PHPUnit中的弃用

当您使用PHPUnit运行测试时,不会显示弃用通知。为了帮助您,Symfony提供了PHob娱乐下载PUnit桥接。这个桥将在测试报告的末尾向您展示所有弃用通知的漂亮摘要。

你所需要做的就是安装PHPUnit桥接:

1
创建symfony/phpunit-bridgob娱乐下载e

现在,你可以开始修复通知:

12 3 4 5 6 7 8 9 10 11 12 13 14
执行"composer require——dev symfony/phpunit-bridge"命令后使用ob娱乐下载/ bin / phpunit)…OK(10个测试,20个断言)剩余的弃用通知(6)“请求”服务已弃用并将被删除3.0.添加一个类型提示ob娱乐下载Symfony\Component\HttpFoundation\请求到你的控制器参数来检索请求:6x 3xPageAdminTest::testPageShow from ob娱乐下载Symfony\Cmf\SimpleCmsBundle\Tests\WebTest\Admin 2x来自Symfony\Cmf\SimpleCmsBundle\Tesob娱乐下载ts\WebTest\Admin 1x的PageAdminTest: testPageList来自Symfony\Cmf\SimpleCmsBundle\Tesob娱乐下载ts\WebTest\Admin的PageAdminTest: testPageEdit

一旦你把它们都修好了,命令就以0(成功)你就完成了!

有时,你不能修复所有的弃用(例如,4.4中已经弃用了一些东西,而你仍然需要支持4.3)。在这些情况下,您仍然可以使用桥来修复尽可能多的弃用,然后允许更多的弃用使您的测试再次通过。方法可以做到这一点ob娱乐下载SYMFONY_DEPRECATIONS_HELPERenv变量:

1 2 3 4 5 6 7 8
<!——phpunit.xml.dist——><phpunit)><!——……--><php><env的名字“ob娱乐下载SYMFONY_DEPRECATIONS_HELPER”价值“马克斯(总)= 999999”/>php>phpunit)>

您还可以执行如下命令:

1
ob娱乐下载SYMFONY_DEPRECATIONS_HELPER=max[total]=999999 php ./bin/phpunit

2)通过Composer更新到新的主要版本

一旦代码不再弃用,您就可以通过Composer通过修改您的代码来更新Symfony库ob娱乐下载composer.json文件和更改所有库开始ob娱乐下载symfony /到新的主版本:

12 3 4 5 6 7 8 9 10 11 12 13 14 16 17 18 19 20
{"…": "…","require": {- "ob娱乐下载symfony/cache": "4.4.*",+ "ob娱乐下载symfony/cache": "5.0.*",- "ob娱乐下载symfony/config": "4.4.*",+“sob娱乐下载ymfony/config”:“5.0.*”,-“sob娱乐下载ymfony/console”:“4.4.*”,+“sob娱乐下载ymfony/console”:“5.0.*”,"...:“…”,“…”:“一些库从symfony开始/遵循他们自己的版本控制方案。ob娱乐下载你不需要更新这些版本:你可以在任何你想要的时候独立升级它们","symfony/ monoo -bundle": "^3.5",}, "…"ob娱乐下载: "…",}

在你的底部composer.json文件,在额外的block中可以找到Symfony版本的数据设置。ob娱乐下载一定要升级这个。例如,将其更新为5.0 . *升级到Symfony 5.0ob娱乐下载:

1 2 3 4 5 6 7
"extra": {"sob娱乐下载ymfony": {"allow-contrib": false,"require": "4.4.*"+ "require": "5.0.*"}}

接下来,使用Composer下载新版本的库:

1
作曲家更新“ob娱乐下载symfony / *”

依赖错误

如果您得到一个依赖项错误,这可能意味着您还需要升级作为Symfony库依赖项的其他库。ob娱乐下载要允许这样做,请通过——with-all-dependencies国旗:

1
作曲家更新“ob娱乐下载symfony / *”——with-all-dependencies

这个更新ob娱乐下载symfony / *而且所有这些包所依赖的包。通过使用严格的版本约束composer.json,您可以控制每个库升级到什么版本。

如果还是不行,你的composer.json文件可能会为不兼容新Symfony版本的库指定一个版本。ob娱乐下载在这种情况下,将该库更新到中较新的版本composer.json也许能解决问题。

或者,您可能会遇到更深层次的问题,即不同的库依赖于其他库的冲突版本。检查要调试的错误消息。

另一个可能发生的问题是,项目依赖项可以安装在本地计算机上,但不能安装在远程服务器上。这通常发生在每台机器上的PHP版本不同的情况下。解决方案是添加平台配置选项到您的“composer”。json文件来定义依赖关系所允许的最高PHP版本(设置为服务器的PHP版本)。

升级其他软件包

您可能还想升级其余的库。如果你做得很好版本约束composer.json,你可以通过运行:

1
作曲家更新

谨慎

小心,如果你有一些不具体的版本约束在你的composer.json(如。dev-master),这可能会将一些非symfony库升级到包含破坏向后兼容性更ob娱乐下载改的新版本。

3)更新食谱

的更新版本随着时间的推移-特别是当您升级到一个库的新版本时配方可能有空。这些更新通常是次要的——例如在配置文件中添加新的注释——但是让您的文件与recipes保持同步是个好主意。

ob娱乐下载Symfony Flex提供了几个命令来帮助您升级食谱。在开始之前,请确保提交您正在进行的任何不相关的更改:

1.18

食谱:更新命令在Symfony Flex 1.18中引入。ob娱乐下载

1 2 3 4 5 6 7 8 9 10 11
#选择一个过时的食谱来更新作曲家食谱:更新#更新一个特定的食谱编写器配方:更新symfony/frameworob娱乐下载k-bundle#查看所有已安装的食谱列表,其中有可用的更新作曲家的食谱#查看有关特定食谱的详细信息Composer recipes ob娱乐下载symfony/framework-bundle

食谱:更新Command很聪明:它会查看安装时的配方与最新版本之间的差异。然后它会创建一个补丁并应用到你的应用程序中。如果有任何冲突,你可以像正常一样解决它们git像往常一样冲突和承诺。

4)更新你的代码以适应新版本

在一些罕见的情况下,下一个主要版本五月包含向后兼容性中断。确保你读了UPGRADE-X.0.md(其中X是新的主版本)包含在Symfony存储库中,用于您需要注意的任何BC中断。ob娱乐下载

此工作,包括代码示例,是根据创作共用BY-SA 3.0许可证。
ob娱乐下载Symfony 5.3支持通过JoliCode