From Fedora Project Wiki

Revision as of 08:53, 4 February 2016 by Churchyard (talk | contribs) (Created page with "= System Python = == Summary == Separate several subpackages form the python3 packages - a system-python(-libs) that can be required by various tools that consider themselves...")
(diff) ← Older revision | Latest revision (diff) | Newer revision → (diff)

System Python

Summary

Separate several subpackages form the python3 packages - a system-python(-libs) that can be required by various tools that consider themselves "system tools".

Owner

  • Email: mhroncok@redhat.com
  • Release notes owner:

Current status

  • Targeted release: Fedora 24
  • Last updated: 2016-02-04
  • Tracker bug: <will be assigned by the Wrangler>

Detailed Description

python3 package to be split in several more subpackages:

  • system-python-libs - a subset of standard Python library considered essential to run "system tools" requiring Python
  • system-python - /usr/bin/system-python binary (interpreter) for the tools to be able to run, provides system-python(abi)
  • python3-libs brings in the remaining subset of standard Python library and will require system-python-libs, thus packages requiring it (directly or indirectly) will get the entire standard Python library
  • python3 still requires python3-libs and provides python(abi)

The term "system tool" in this context means any package where a maintainer wishes to require system-python package instead of python3 package.

Any package requiring "python(abi) = 3.x" (currently all Python modules and apps) will still bring in the entire standard library and thus will not be affected by this change in any way. Since this dependency is automatically generated, macros will be provided to remove it and depend on "system-python(abi) = 3.x" instead.

If a package maintainer wishes to depend on system-python instead of python3 it is their responsibility to cooperate with the maintainers of all the Python dependencies of their package and do the same thing there. For example consider package foo requiring python3-bar; if foo's maintainer wishes to require system-python instead of python3, they must be sure to make sure python3-bar does this as well, otherwise the depednency chain would bring in python3 package anyway.

Benefit to Fedora

system-python(-libs) will be smaller than python3(-libs) and thus it can reduce the size of images where size is critical, such as Fedora Cloud.

Once this change is complete, we can cooperate with maintainers of tools to require system-python instead of python3 and make sure python3 package is not dragged as a dependency on such installations.

Scope

  • Proposal owners:
    • determine what the essential subset of the standard library is (investigate packages that later might become "system tools")
    • split the subset into a subpackage system-python-libs
    • create system-python binary and package
    • invent macros to change the requirement of python-abi
    • test if present packages requiring python3 or python-abi = 3.x work


  • Other developers: N/A (not a System Wide Change)
  • Release engineering: N/A (not a System Wide Change)
  • Policies and guidelines:
    • introduce a change to Python packaging guidelines for package maintainers to be able to profit from this change (after the implementation is ready)


  • Trademark approval: N/A (not needed for this Change)

Upgrade/compatibility impact

N/A (not a System Wide Change)

How To Test

TBD

User Experience

They should not notice any change. Later, when packages depend on system-python, user can benefit form a smaller Cloud image and such.

Dependencies

As explained above, other packages can choose to depend on system-python instead of python3 once this change is done. But we do not require them to do so in order to finish this change.

Contingency Plan

  • Contingency mechanism:
    • Rollback the change in python3.spec
  • Contingency deadline: N/A (not a System Wide Change)
  • Blocks release? No

Documentation

Will be in the Python packaging guidelines.

Release Notes

TBD