From Fedora Project Wiki
No edit summary
(Add trackers)
 
(27 intermediate revisions by 3 users not shown)
Line 5: Line 5:
== Summary ==
== Summary ==
<!-- A sentence or two summarizing what this change is and what it will do. This information is used for the overall changeset summary page for each release. Note that motivation for the change should be in the Benefit to Fedora section below, and this part should answer the question "What?" rather than "Why?". -->
<!-- A sentence or two summarizing what this change is and what it will do. This information is used for the overall changeset summary page for each release. Note that motivation for the change should be in the Benefit to Fedora section below, and this part should answer the question "What?" rather than "Why?". -->
Update to a new upstream release of python-setuptools that is not completely compatible with previous releases. Since version 58+ upstream removed support for 2to3 during builds. This is breaking change and projects are encouraged to port to a unified codebase.  
Update to a new upstream release of python-setuptools that is not completely compatible with previous releases. Since version 58+ upstream removed support for 2to3 during builds. This is a breaking change and projects are encouraged to port to a unified codebase.


== Owner ==
== Owner ==
Line 21: Line 21:


== Current status ==
== Current status ==
[[Category:ChangePageIncomplete]]
[[Category:ChangeAcceptedF36]]
<!-- When your change proposal page is completed and ready for review and announcement -->
<!-- When your change proposal page is completed and ready for review and announcement -->
<!-- remove Category:ChangePageIncomplete and change it to Category:ChangeReadyForWrangler -->
<!-- remove Category:ChangePageIncomplete and change it to Category:ChangeReadyForWrangler -->
Line 39: Line 39:
ON_QA -> change is fully code complete
ON_QA -> change is fully code complete
-->
-->
* FESCo issue: <will be assigned by the Wrangler>
* FESCo issue: [https://pagure.io/fesco/issue/2676 #2676]
* Tracker bug: <will be assigned by the Wrangler>
* Tracker bug: [https://bugzilla.redhat.com/show_bug.cgi?id=2016051 #2016051]
* Release notes tracker: <will be assigned by the Wrangler>
* Release notes tracker: [https://pagure.io/fedora-docs/release-notes/issue/747 #747]


== Detailed Description ==
== Detailed Description ==
<!-- Expand on the summary, if appropriate.  A couple sentences suffices to explain the goal, but the more details you can provide the better. -->
<!-- Expand on the summary, if appropriate.  A couple sentences suffices to explain the goal, but the more details you can provide the better. -->
Setuptools is a package development process library designed to facilitate packaging Python projects by enhancing the Python standard library distutils (distribution utilities). It changes fast and it often introduces breaking changes such as the removal of support for 2to3 during the builds in version 58.0.0 which was [https://github.com/pypa/setuptools/blob/main/CHANGES.rst#v4620 deprecated] since version 46.2.0 present in Fedora 33. `use_2to3` used to help to translate Python 2.x programs to Python 3.x. But since Python 2 reached its end of life on 1st January 2020 and lib2to3 is deprecated in Python 3.10 and slated for removal in Python 3.12., developers are encouraged to drop support for Python 2 and migrate to Python 3. It is still possible to use command line `2to3` tool in Python 3.10, but it will be deprecated in 3.11 and removed in 3.13.


== Feedback ==
List of packages that will likely fail to build, because they use the removed use_2to3 option.
<!-- Summarize the feedback from the community and address why you chose not to accept proposed alternatives. This section is optional for all change proposals but is strongly suggested. Incorporating feedback here as it is raised gives FESCo a clearer view of your proposal and leaves a good record for the future. If you get no feedback, that is useful to note in this section as well. For innovative or possibly controversial ideas, consider collecting feedback before you file the change proposal. -->
 
Maintainers by package:
* fail2ban            atkac hobbes1069 jgu orion
* playitagainsam      churchyard
* pybluez              limb
* pyp2rpm              gordonmessmer kevin
* python-anyjson      fab mrunge sundaram
* python-behave        pschindl
* python-concurrentloghandler dcallagh
* python-deap          zbyszek
* python-demjson      lmacken thm
* python-flask-openid  frantisekz pjp sundaram
* python-funcparserlib dridi
* python-jsmin        ignatenkobrain
* python-libusb1      jonny
* python-mailer        fab
* python-marathon      apevec dmsimard
* python-nose-cover3  mrunge ngompa pingou
* python-parse_type    ignatenkobrain
* python-proteus      sharkcz
* python-pypng        kevin ralph
* python-pysam        davidsch
* python-relatorio    sharkcz
* python-rnc2rng      ignatenkobrain
* python-simpleeval    sharkcz
* python-speaklater    ondrejj
* python-sphinx-bootstrap-theme besser82 sic
* python-spyking-circus ankursinha
* python-suds          jortel swt2c
* python-tempita      jcapitao kylev
* python-vatnumber    sharkcz
* python-xunitparser  ignatenkobrain lbrabec tflink
* trytond              sharkcz
* trytond-account      sharkcz
* trytond-account-be  sharkcz
* trytond-account-de-skr03 sharkcz
* trytond-account-invoice sharkcz
* trytond-account-invoice-history sharkcz
* trytond-account-invoice-line-standalone sharkcz
* trytond-account-product sharkcz
* trytond-account-statement sharkcz
* trytond-account-stock-anglo-saxon sharkcz
* trytond-account-stock-continental sharkcz
* trytond-analytic-account sharkcz
* trytond-analytic-invoice sharkcz
* trytond-analytic-purchase sharkcz
* trytond-analytic-sale sharkcz
* trytond-company      sharkcz
* trytond-company-work-time sharkcz
* trytond-country      sharkcz
* trytond-currency    sharkcz
* trytond-dashboard    sharkcz
* trytond-google-maps  sharkcz
* trytond-ldap-authentication sharkcz
* trytond-party        sharkcz
* trytond-party-siret  sharkcz
* trytond-product      sharkcz
* trytond-product-cost-fifo sharkcz
* trytond-product-cost-history sharkcz
* trytond-product-price-list sharkcz
* trytond-project      sharkcz
* trytond-project-plan sharkcz
* trytond-project-revenue sharkcz
* trytond-purchase    sharkcz
* trytond-purchase-invoice-line-standalone sharkcz
* trytond-sale        sharkcz
* trytond-sale-opportunity sharkcz
* trytond-sale-price-list sharkcz
* trytond-stock        sharkcz
* trytond-stock-forecast sharkcz
* trytond-stock-inventory-location sharkcz
* trytond-stock-location-sequence sharkcz
* trytond-stock-product-location sharkcz
* trytond-stock-supply sharkcz
* trytond-stock-supply-day sharkcz
* trytond-timesheet    sharkcz
 
 
Packages by maintainer:
* ankursinha python-spyking-circus
* apevec    python-marathon
* atkac      fail2ban
* besser82  python-sphinx-bootstrap-theme
* churchyard playitagainsam
* davidsch  python-pysam
* dcallagh  python-concurrentloghandler
* dmsimard  python-marathon
* dridi      python-funcparserlib
* fab        python-anyjson python-mailer
* frantisekz python-flask-openid
* gordonmessmer pyp2rpm
* hobbes1069 fail2ban
* ignatenkobrain python-jsmin python-parse_type python-rnc2rng python-xunitparser
* jcapitao  python-tempita
* jgu        fail2ban
* jonny      python-libusb1
* jortel    python-suds
* kevin      pyp2rpm python-pypng
* kylev      python-tempita
* lbrabec    python-xunitparser
* limb      pybluez
* lmacken    python-demjson
* mrunge    python-anyjson python-nose-cover3
* ngompa    python-nose-cover3
* ondrejj    python-speaklater
* orion      fail2ban
* pingou    python-nose-cover3
* pjp        python-flask-openid
* pschindl  python-behave
* ralph      python-pypng
* sharkcz    python-proteus python-relatorio python-simpleeval python-vatnumber trytond trytond-account trytond-account-be trytond-account-de-skr03 trytond-account-invoice trytond-account-invoice-history trytond-account-invoice-line-standalone trytond-account-product trytond-account-statement trytond-account-stock-anglo-saxon trytond-account-stock-continental trytond-analytic-account trytond-analytic-invoice trytond-analytic-purchase trytond-analytic-sale trytond-company trytond-company-work-time trytond-country trytond-currency trytond-dashboard trytond-google-maps trytond-ldap-authentication trytond-party trytond-party-siret trytond-product trytond-product-cost-fifo trytond-product-cost-history trytond-product-price-list trytond-project trytond-project-plan trytond-project-revenue trytond-purchase trytond-purchase-invoice-line-standalone trytond-sale trytond-sale-opportunity trytond-sale-price-list trytond-stock trytond-stock-forecast trytond-stock-inventory-location trytond-stock-location-sequence trytond-stock-product-location trytond-stock-supply trytond-stock-supply-day trytond-timesheet
* sic        python-sphinx-bootstrap-theme
* sundaram  python-anyjson python-flask-openid
* swt2c      python-suds
* tflink    python-xunitparser
* thm        python-demjson
* zbyszek    python-deap


== Benefit to Fedora ==
== Benefit to Fedora ==
Line 77: Line 194:
     https://fedoraproject.org/wiki/Changes/perl5.26 (major upgrade to a popular software stack, visible to users of that stack)
     https://fedoraproject.org/wiki/Changes/perl5.26 (major upgrade to a popular software stack, visible to users of that stack)
-->
-->
Fedora offers cutting edge technologies for Python and Setuptools is one of the most important Python packages. By doing this update we bring users the latest features that Setuptools offers and also we enable Fedora 36 to receive future updates as well.


== Scope ==
== Scope ==
* Proposal owners:
* Proposal owners: update python-setuptools to 58.x.x, provide help
<!-- What work do the feature owners have to accomplish to complete the feature in time for release?  Is it a large change affecting many parts of the distribution or is it a very isolated change? What are those changes?-->
<!-- What work do the feature owners have to accomplish to complete the feature in time for release?  Is it a large change affecting many parts of the distribution or is it a very isolated change? What are those changes?-->


* Other developers: <!-- REQUIRED FOR SYSTEM WIDE CHANGES -->
* Other developers: report problems to the upstream and backport patch to the affected packages. The impact can be tested using [https://copr.fedorainfracloud.org/coprs/thrnciar/setuptools-impact-check/packages/ copr repository] where Setuptools 58.0.4 has been built.
<!-- REQUIRED FOR SYSTEM WIDE CHANGES -->
<!-- What work do other developers have to accomplish to complete the feature in time for release?  Is it a large change affecting many parts of the distribution or is it a very isolated change? What are those changes?-->
<!-- What work do other developers have to accomplish to complete the feature in time for release?  Is it a large change affecting many parts of the distribution or is it a very isolated change? What are those changes?-->


Line 99: Line 218:


== Upgrade/compatibility impact ==
== Upgrade/compatibility impact ==
There is a clean upgrade path from current version to python-setuptools 58.x.x. Fedora users using RPM-packaged Setuptools will use Setuptools 58.x.x by default.
<!-- What happens to systems that have had a previous versions of Fedora installed and are updated to the version containing this change? Will anything require manual configuration or data migration? Will any existing functionality be no longer supported? -->
<!-- What happens to systems that have had a previous versions of Fedora installed and are updated to the version containing this change? Will anything require manual configuration or data migration? Will any existing functionality be no longer supported? -->


Line 120: Line 240:


<!-- REQUIRED FOR SYSTEM WIDE CHANGES -->
<!-- REQUIRED FOR SYSTEM WIDE CHANGES -->
 
* Find the package you want to update in this [https://copr.fedorainfracloud.org/coprs/thrnciar/setuptools-impact-check/packages/ copr repository] and check the build logs to determine the fail cause.
* Work with the upstream to resolve the issue or drop the need for 2to3 during the build of the package.
* When updating the package, you can test it using the same copr repository where the latest version of Setuptools has been built.
* Let us know if something doesn't work as it should.


== User Experience ==
== User Experience ==
Line 133: Line 256:
  - Green has been scientifically proven to be the most relaxing color. The move to a default background color of green with green text will result in Fedora users being the most relaxed users of any operating system.
  - Green has been scientifically proven to be the most relaxing color. The move to a default background color of green with green text will result in Fedora users being the most relaxed users of any operating system.
-->
-->
 
Regular distro users shouldn't notice any change in Setuptools behaviour, except for packages that use 2to3 to transform Python 2.x source code into Python 3.x source code. Such packages will fail with `error in <package name> setup command: use_2to3 is invalid` and should be fixed by their maintainers.
== Dependencies ==
<!-- What other packages (RPMs) depend on this package?  Are there changes outside the developers' control on which completion of this change depends?  In other words, completion of another change owned by someone else and might cause you to not be able to finish on time or that you would need to coordinate?  Other upstream projects like the kernel (if this is not a kernel change)? -->
 
<!-- REQUIRED FOR SYSTEM WIDE CHANGES -->
 


== Contingency Plan ==
== Contingency Plan ==
Line 147: Line 265:
* Contingency deadline: N/A (not a System Wide Change)  <!-- REQUIRED FOR SYSTEM WIDE CHANGES -->
* Contingency deadline: N/A (not a System Wide Change)  <!-- REQUIRED FOR SYSTEM WIDE CHANGES -->
<!-- Does finishing this feature block the release, or can we ship with the feature in incomplete state? -->
<!-- Does finishing this feature block the release, or can we ship with the feature in incomplete state? -->
* Blocks release? N/A (not a System Wide Change), Yes/No <!-- REQUIRED FOR SYSTEM WIDE CHANGES -->
* Blocks release? N/A (not a System Wide Change) <!-- REQUIRED FOR SYSTEM WIDE CHANGES -->
 


== Documentation ==
== Documentation ==
<!-- Is there upstream documentation on this change, or notes you have written yourself?  Link to that material here so other interested developers can get involved. -->
<!-- Is there upstream documentation on this change, or notes you have written yourself?  Link to that material here so other interested developers can get involved. -->
[https://github.com/pypa/setuptools/blob/main/CHANGES.rst Setuptools changelog]


<!-- REQUIRED FOR SYSTEM WIDE CHANGES -->
<!-- REQUIRED FOR SYSTEM WIDE CHANGES -->
N/A (not a System Wide Change)
This page is the documentation.


== Release Notes ==
== Release Notes ==

Latest revision as of 19:03, 20 October 2021

Setuptools 58+

Summary

Update to a new upstream release of python-setuptools that is not completely compatible with previous releases. Since version 58+ upstream removed support for 2to3 during builds. This is a breaking change and projects are encouraged to port to a unified codebase.

Owner


Current status

Detailed Description

Setuptools is a package development process library designed to facilitate packaging Python projects by enhancing the Python standard library distutils (distribution utilities). It changes fast and it often introduces breaking changes such as the removal of support for 2to3 during the builds in version 58.0.0 which was deprecated since version 46.2.0 present in Fedora 33. use_2to3 used to help to translate Python 2.x programs to Python 3.x. But since Python 2 reached its end of life on 1st January 2020 and lib2to3 is deprecated in Python 3.10 and slated for removal in Python 3.12., developers are encouraged to drop support for Python 2 and migrate to Python 3. It is still possible to use command line 2to3 tool in Python 3.10, but it will be deprecated in 3.11 and removed in 3.13.

List of packages that will likely fail to build, because they use the removed use_2to3 option.

Maintainers by package:

  • fail2ban atkac hobbes1069 jgu orion
  • playitagainsam churchyard
  • pybluez limb
  • pyp2rpm gordonmessmer kevin
  • python-anyjson fab mrunge sundaram
  • python-behave pschindl
  • python-concurrentloghandler dcallagh
  • python-deap zbyszek
  • python-demjson lmacken thm
  • python-flask-openid frantisekz pjp sundaram
  • python-funcparserlib dridi
  • python-jsmin ignatenkobrain
  • python-libusb1 jonny
  • python-mailer fab
  • python-marathon apevec dmsimard
  • python-nose-cover3 mrunge ngompa pingou
  • python-parse_type ignatenkobrain
  • python-proteus sharkcz
  • python-pypng kevin ralph
  • python-pysam davidsch
  • python-relatorio sharkcz
  • python-rnc2rng ignatenkobrain
  • python-simpleeval sharkcz
  • python-speaklater ondrejj
  • python-sphinx-bootstrap-theme besser82 sic
  • python-spyking-circus ankursinha
  • python-suds jortel swt2c
  • python-tempita jcapitao kylev
  • python-vatnumber sharkcz
  • python-xunitparser ignatenkobrain lbrabec tflink
  • trytond sharkcz
  • trytond-account sharkcz
  • trytond-account-be sharkcz
  • trytond-account-de-skr03 sharkcz
  • trytond-account-invoice sharkcz
  • trytond-account-invoice-history sharkcz
  • trytond-account-invoice-line-standalone sharkcz
  • trytond-account-product sharkcz
  • trytond-account-statement sharkcz
  • trytond-account-stock-anglo-saxon sharkcz
  • trytond-account-stock-continental sharkcz
  • trytond-analytic-account sharkcz
  • trytond-analytic-invoice sharkcz
  • trytond-analytic-purchase sharkcz
  • trytond-analytic-sale sharkcz
  • trytond-company sharkcz
  • trytond-company-work-time sharkcz
  • trytond-country sharkcz
  • trytond-currency sharkcz
  • trytond-dashboard sharkcz
  • trytond-google-maps sharkcz
  • trytond-ldap-authentication sharkcz
  • trytond-party sharkcz
  • trytond-party-siret sharkcz
  • trytond-product sharkcz
  • trytond-product-cost-fifo sharkcz
  • trytond-product-cost-history sharkcz
  • trytond-product-price-list sharkcz
  • trytond-project sharkcz
  • trytond-project-plan sharkcz
  • trytond-project-revenue sharkcz
  • trytond-purchase sharkcz
  • trytond-purchase-invoice-line-standalone sharkcz
  • trytond-sale sharkcz
  • trytond-sale-opportunity sharkcz
  • trytond-sale-price-list sharkcz
  • trytond-stock sharkcz
  • trytond-stock-forecast sharkcz
  • trytond-stock-inventory-location sharkcz
  • trytond-stock-location-sequence sharkcz
  • trytond-stock-product-location sharkcz
  • trytond-stock-supply sharkcz
  • trytond-stock-supply-day sharkcz
  • trytond-timesheet sharkcz


Packages by maintainer:

  • ankursinha python-spyking-circus
  • apevec python-marathon
  • atkac fail2ban
  • besser82 python-sphinx-bootstrap-theme
  • churchyard playitagainsam
  • davidsch python-pysam
  • dcallagh python-concurrentloghandler
  • dmsimard python-marathon
  • dridi python-funcparserlib
  • fab python-anyjson python-mailer
  • frantisekz python-flask-openid
  • gordonmessmer pyp2rpm
  • hobbes1069 fail2ban
  • ignatenkobrain python-jsmin python-parse_type python-rnc2rng python-xunitparser
  • jcapitao python-tempita
  • jgu fail2ban
  • jonny python-libusb1
  • jortel python-suds
  • kevin pyp2rpm python-pypng
  • kylev python-tempita
  • lbrabec python-xunitparser
  • limb pybluez
  • lmacken python-demjson
  • mrunge python-anyjson python-nose-cover3
  • ngompa python-nose-cover3
  • ondrejj python-speaklater
  • orion fail2ban
  • pingou python-nose-cover3
  • pjp python-flask-openid
  • pschindl python-behave
  • ralph python-pypng
  • sharkcz python-proteus python-relatorio python-simpleeval python-vatnumber trytond trytond-account trytond-account-be trytond-account-de-skr03 trytond-account-invoice trytond-account-invoice-history trytond-account-invoice-line-standalone trytond-account-product trytond-account-statement trytond-account-stock-anglo-saxon trytond-account-stock-continental trytond-analytic-account trytond-analytic-invoice trytond-analytic-purchase trytond-analytic-sale trytond-company trytond-company-work-time trytond-country trytond-currency trytond-dashboard trytond-google-maps trytond-ldap-authentication trytond-party trytond-party-siret trytond-product trytond-product-cost-fifo trytond-product-cost-history trytond-product-price-list trytond-project trytond-project-plan trytond-project-revenue trytond-purchase trytond-purchase-invoice-line-standalone trytond-sale trytond-sale-opportunity trytond-sale-price-list trytond-stock trytond-stock-forecast trytond-stock-inventory-location trytond-stock-location-sequence trytond-stock-product-location trytond-stock-supply trytond-stock-supply-day trytond-timesheet
  • sic python-sphinx-bootstrap-theme
  • sundaram python-anyjson python-flask-openid
  • swt2c python-suds
  • tflink python-xunitparser
  • thm python-demjson
  • zbyszek python-deap

Benefit to Fedora

Fedora offers cutting edge technologies for Python and Setuptools is one of the most important Python packages. By doing this update we bring users the latest features that Setuptools offers and also we enable Fedora 36 to receive future updates as well.

Scope

  • Proposal owners: update python-setuptools to 58.x.x, provide help
  • Other developers: report problems to the upstream and backport patch to the affected packages. The impact can be tested using copr repository where Setuptools 58.0.4 has been built.
  • Policies and guidelines: N/A (not needed for this Change)
  • Trademark approval: N/A (not needed for this Change)
  • Alignment with Objectives:

Upgrade/compatibility impact

There is a clean upgrade path from current version to python-setuptools 58.x.x. Fedora users using RPM-packaged Setuptools will use Setuptools 58.x.x by default.


How To Test

  • Find the package you want to update in this copr repository and check the build logs to determine the fail cause.
  • Work with the upstream to resolve the issue or drop the need for 2to3 during the build of the package.
  • When updating the package, you can test it using the same copr repository where the latest version of Setuptools has been built.
  • Let us know if something doesn't work as it should.

User Experience

Regular distro users shouldn't notice any change in Setuptools behaviour, except for packages that use 2to3 to transform Python 2.x source code into Python 3.x source code. Such packages will fail with error in <package name> setup command: use_2to3 is invalid and should be fixed by their maintainers.

Contingency Plan

  • Contingency mechanism: (What to do? Who will do it?) N/A (not a System Wide Change)
  • Contingency deadline: N/A (not a System Wide Change)
  • Blocks release? N/A (not a System Wide Change)

Documentation

Setuptools changelog

This page is the documentation.

Release Notes