From Fedora Project Wiki
m (internal link cleaning)
 
(104 intermediate revisions by 5 users not shown)
Line 18: Line 18:
== Current status ==
== Current status ==
* Targeted release: [[Releases/14 | Fedora 14]]  
* Targeted release: [[Releases/14 | Fedora 14]]  
* Last updated: 2010-07-25
* Last updated: 2010-09-27
* Percentage of completion: 60%
* Percentage of completion: 100%


Packages built into [http://koji.fedoraproject.org/koji/buildtargetinfo?name=dist-f14-py27-rebuild dist-f14-py27-rebuild]; currently [http://dmalcolm.fedorapeople.org/python-packaging/failures-2010-07-25-01.html 170 failing rebuilds]
oget wrote [http://oget.fedorapeople.org/python27/py27check.py a script] to report on remaining problems.


=== Packages waiting on other packages ===
The results can be seen [http://oget.fedorapeople.org/python27/python-27-rebuild-errors-LATEST.html here]
<!-- please use * to indicate the hierarchy of build-time dependencies here -->
 
* kdebindings, pyactivemq need:
Tracker bug for packages that fail to rebuild:
** boost [http://koji.fedoraproject.org/koji/taskinfo?taskID=2348337 DONE] needed :
https://bugzilla.redhat.com/showdependencytree.cgi?id=619913&hide_resolved=1
*** openmpi [http://koji.fedoraproject.org/koji/taskinfo?taskID=2348272 DONE] (applied workaround for [https://bugzilla.redhat.com/show_bug.cgi?id=617766 bug 617766])
 
* python-execnet needs:
Fixes for broken packages should be built into both rawhide, and into dist-f14.
** protobuf needed:
 
*** subversion (see above)
Information on the new "dist-git" system can be seen [[Using_Fedora_GIT|here]].
* revelation needs gnome-python2-applet from:
 
** gnome-python2-desktop, which [https://bugzilla.redhat.com/show_bug.cgi?id=617717 fails to build against gtk-3.0, apparently due to a missing header]
Once it's been successfully rebuilt for F14, an [https://admin.fedoraproject.org/updates/new/ update needs to be filed ] to get the rebuild into F14.
* python-networkx needs:
 
** python-matplotlib
To make it easier to track things, dmalcolm has been filing bugs using [https://bugzilla.redhat.com/enter_bug.cgi?alias=&assigned_to=&attachurl=&blocked=619913&bug_file_loc=http%3A%2F%2F&bug_severity=medium&bug_status=NEW&cf_build_id=&cf_clone_of=&cf_cust_facing=---&cf_devel_whiteboard=&cf_environment=&cf_internal_whiteboard=&cf_issuetracker=&cf_qa_whiteboard=&cf_targetrelease=---&comment=The%20package%20needs%20to%20be%20rebuilt%20against%20python%202.7%20in%20both%20F14%20and%20devel.%0D%0A%0D%0AInformation%20on%20the%20new%20%22dist-git%22%20system%20can%20be%20seen%20here%3A%0D%0A%20%20http%3A%2F%2Ffedoraproject.org%2Fwiki%2FUsing_Fedora_GIT%0D%0A%0D%0AInformation%20on%20common%20difficulties%20with%20Python%202.7%20rebuilds%20can%20be%20seen%20here%3A%0D%0A%20%20https%3A%2F%2Ffedoraproject.org%2Fwiki%2FFeatures%2FPython_2.7%0D%0A%0D%0AOnce%20it%27s%20been%20successfully%20rebuilt%20for%20F14%2C%20an%20update%20needs%20to%20be%20filed%20to%20get%20the%20rebuild%20into%20F14%3A%0D%0A%20%20https%3A%2F%2Fadmin.fedoraproject.org%2Fupdates%2Fnew%2F%0D%0A%0D%0APlease%20add%20this%20bug%20to%20the%20update%2C%20to%20make%20it%20easy%20to%20track%20what%27s%20been%20done%2C%20and%20what%27s%20left%20to%20do.%0D%0A%0D%0AThanks!&contenttypeentry=&contenttypemethod=autodetect&contenttypeselection=text%2Fplain&data=&deadline=&defined_cf_partner=&dependson=&description=&estimated_time=0.0&external_bug_id=&external_id=0&flag_type-155=X&flag_type-16=X&flag_type-65=X&flag_type-66=X&flag_type-67=X&form_name=enter_bug&keywords=&maketemplate=Remember%20values%20as%20bookmarkable%20template&op_sys=Linux&priority=low&product=Fedora&qa_contact=&rep_platform=All&short_desc=needs%20to%20be%20rebuilt%20against%20python%202.7%20in%20F14%20and%20devel&status_whiteboard=&target_milestone=---&version=14 this template] against the broken packages. Please set the component and add the name of the component to the front of the subject of the bug. Once an update has been created, the bug should be flipped over to the MODIFIED status, to make it easy to see what works remain.
*** scipiy fails, looks like [http://projects.scipy.org/scipy/ticket/1180 this upstream bug]. May need  [http://projects.scipy.org/numpy/changeset/5614 this patch to numpy] (not sure yet)
 
* gget needs
 
** notify-python fails to build with [http://koji.fedoraproject.org/koji/getfile?taskID=2344863&name=build.log /usr/include/pygtk-2.0/pygtk/pygtk.h:8:21: fatal error: gtk/gtk.h: No such file or directory]
Tracker bug for issue arising in built packages: https://bugzilla.redhat.com/showdependencytree.cgi?id=620817&hide_resolved=1 (e.g. Python 2.7 incompatibilities)
* gnome-package-kit needs:
 
** PackageKit [https://bugzilla.redhat.com/show_bug.cgi?id=617782 fails to build in .gir gfeneration]
=== Packages with build errors ===
* sympy needed:
* '''IN BODHI''' [https://admin.fedoraproject.org/updates/cyphesis-0.5.24-1.fc14 cyphesis]: Presently built and in the testing repo but regression tests have been disabled and maintainer has not looked at it. See https://bugzilla.redhat.com/show_bug.cgi?id=620298
** python-mpmath DONE
* [http://koji.fedoraproject.org/koji/buildinfo?buildID=187814 antlr3] had a build dependency on a non-existing package, maven2-plugin-antlr. Now that the dependency has been packaged, antlr3 is built and submitted to [https://admin.fedoraproject.org/updates/antlr3-3.2-11.fc14,antlr-maven-plugin-2.1-3.20101012svn12849.fc14 testing].
* hamster-applet needs:
** many gnome-python2-* packages from gnome-python2-desktop. Specifically gnome-python2-bonobo which needs:
** pyorbit: DONE
* sugar-tamtam needs:
** csound
*** boost-python [http://koji.fedoraproject.org/koji/taskinfo?taskID=2348337 DONE]
*** build parameter changes
** gnome-python2-rsvg
* ipa needs
** TurboGears
** setools-libs-python from setools
*** setools fails with [http://koji.fedoraproject.org/koji/getfile?taskID=2345685&name=build.log Error: SWIG version >= 1.3.28 is required.  You have 2.0.0.  You should look at http://www.swig.org]
** python-paste-script
** python-ruledispatch
** python-turbojson needs:
*** python-peak-rules: fails in %check [http://koji.fedoraproject.org/koji/getfile?taskID=2345363&name=build.log apparently within peak-util-assembler (is this 2.7-compatible?)]
** python-ruledispatch (fails in %check, with [http://koji.fedoraproject.org/koji/getfile?taskID=2345441&name=build.log "KeyError: 320" in 4 tests, and "AssertionError: 42529136 == Pointer(<invalid at 0x0x288f170>)" in another])
** python-formencode
** python-cherrypy2
* conduit needs
** pygoocanvas
* [http://koji.fedoraproject.org/koji/getfile?taskID=2344329&name=root.log caribou] needs
** python-virtkey [http://koji.fedoraproject.org/koji/getfile?taskID=2345507&name=build.log fails with /usr/include/gtk-2.0/gdk/gdkpixbuf.h:37:35: fatal error: gdk-pixbuf/gdk-pixbuf.h: No such file or directory]
** pyclutter
* [http://koji.fedoraproject.org/koji/getfile?taskID=2345779&name=root.log telepathy-farsight] needs
** [http://koji.fedoraproject.org/koji/getfile?taskID=2344431&name=root.log farsight2] needs:
*** gupnp-igd-python
* lazygal fails with [http://koji.fedoraproject.org/koji/getfile?taskID=2344725&name=build.log  AttributeError: 'module' object has no attribute 'sysconfig' (distutils module)]
* [http://koji.fedoraproject.org/koji/getfile?taskID=2344964&name=root.log planner] needs:
** gnome-python2-gnomevfs
** gnome-python2-gnome
* [http://koji.fedoraproject.org/koji/taskinfo?taskID=2344797 orca] needs:
** gnome-python2-bonobo
** gnome-python2-gconf
** gnome-python2-libwnck
* [http://koji.fedoraproject.org/koji/taskinfo?taskID=2344865 pootle] needs:
** aeidon
** python-iniparse
** python-lxml [http://koji.fedoraproject.org/koji/getfile?taskID=2345313&name=build.log fails to build inside the 2to3 invocation in fix_itertools_imports.py]
** translate-toolkit
*** python-lxml (see above)
* hulahop needs
** xulrunner-python (dmalcolm is not in ACL for rpms/xulrunner/devel)
* onboard fails to build with [http://koji.fedoraproject.org/koji/getfile?taskID=2344895&name=build.log /usr/bin/python: can't open file 'setup.py': Errno 2 No such file or directory]


=== Common bugs ===
=== Common bugs ===
gobject-introspection's /usr/bin/g-ir-scanner appears to be [https://bugzilla.redhat.com/show_bug.cgi?id=617782 incompatible with python 2.7], this leads to anything building a .gir file failing.
==== FIXED: gobject-introspection ====
gobject-introspection's /usr/bin/g-ir-scanner was [https://bugzilla.redhat.com/show_bug.cgi?id=617782 incompatible with python 2.7], this led to anything building a .gir file failing.
 
This was blocking:
* [http://koji.fedoraproject.org/koji/getfile?taskID=2344639&name=build.log gtk-vnc] DONE
* [http://koji.fedoraproject.org/koji/getfile?taskID=2347398&name=build.log PackageKit] DONE
 
==== FIXED: SWIG ====
Various swig users fail to find the python libraries during "configure":
<pre>
checking for Python library path... find: `/usr/lib/python/config/': No such file or directory
find: `/usr/lib/python/': No such file or directory
/usr/lib
checking python extra libraries...
</pre>


This is currently  blocking:
Relevant part of "configure" seems to be
* [http://koji.fedoraproject.org/koji/getfile?taskID=2344639&name=build.log gtk-vnc]
<pre>
* [http://koji.fedoraproject.org/koji/getfile?taskID=2347398&name=build.log PackageKit]
        python_path=`echo $PYTHON | sed "s,/bin.*$,,"`
        for i in "$python_path/lib/python$PYTHON_VERSION/config/" "$python_path/lib/python$PYTHON_VERSION/" "$python_path/lib/python/config/" "$python_path/\
lib/python/" "$python_path/" ; do
</pre>
This sets $python_path to "/usr", and then looks for config within /usr/lib, which fails on 64-bit: the relevant files are in /usr/lib64 (why did this work before? is this a python change?)
 
Before this we see errors like this:
<pre>
checking for SWIG version... 2.0.0
configure: WARNING: SWIG version >= 1.3.17 is required.  You have 2.0.0.  You should look at http://www.swig.org
</pre>
The test in the configure seems to look for an exact match on major and minor, and >= on the patch level, and thus "2" -ne "1" seems to leave SWIG_LIB unset, and could be the actual problem here.
 
A workaround is to add this:
<pre>
# For now (workaround for SWIG major-version bump)
BuildRequires:  autoconf
 
%prep
(snip)
# Fixup expected version of SWIG:
sed -i -e "s|AC_PROG_SWIG(1.3.17)|AC_PROG_SWIG(2.0.0)|" configure.in
# and rebuild the configure script:
autoconf
</pre>
 
This was blocking:
* DONE: [http://koji.fedoraproject.org/koji/getfile?taskID=2344787&name=build.log libopensync]
* DONE: setools


== Detailed Description ==
== Detailed Description ==
Line 162: Line 160:
<!-- The release notes also help users know how to deal with platform changes such as ABIs/APIs, configuration or data file formats, or upgrade concerns.  If there are any such changes involved in this feature, indicate them here.  You can also link to upstream documentation if it satisfies this need.  This information forms the basis of the release notes edited by the documentation team and shipped with the release. -->
<!-- The release notes also help users know how to deal with platform changes such as ABIs/APIs, configuration or data file formats, or upgrade concerns.  If there are any such changes involved in this feature, indicate them here.  You can also link to upstream documentation if it satisfies this need.  This information forms the basis of the release notes edited by the documentation team and shipped with the release. -->
The system Python 2 stack has been upgraded to 2.7. For a list of changes see http://docs.python.org/dev/whatsnew/2.7.html
The system Python 2 stack has been upgraded to 2.7. For a list of changes see http://docs.python.org/dev/whatsnew/2.7.html
=== Caveat: PyCObject and warnings ===
Python provides various APIs for use by C extension modules.  One of these APIs, PyCObject, was deprecated in Python 2.7, but there are a [https://bugzilla.redhat.com/showdependencytree.cgi?id=620842&hide_resolved=1 number of key modules that have not yet been ported to its replacement].
By default, deprecation warnings are ignored, so this will not cause problems.
However, if the standard warnings settings are overridden, you may see problems with these modules.  In particular, if warnings have been set to "error", it is possible to make the Python interpreter abort or even segfault when importing these modules.
If you need to enable errors-for-warnings, please also add an override so that a PendingDeprecationWarning is merely logged, rather than raising an exception:
<pre>
>>> import warnings
>>> warnings.simplefilter('error')
>>> warnings.simplefilter('default', PendingDeprecationWarning)
</pre>


== Comments and Discussion ==
== Comments and Discussion ==
Line 172: Line 184:
<!-- After review, the feature wrangler will move your page to Category:FeatureReadyForFesco... if it still needs more work it will move back to Category:FeaturePageIncomplete-->
<!-- After review, the feature wrangler will move your page to Category:FeatureReadyForFesco... if it still needs more work it will move back to Category:FeaturePageIncomplete-->
<!-- A pretty picture of the page category usage is at: https://fedoraproject.org/wiki/Features/Policy/Process -->
<!-- A pretty picture of the page category usage is at: https://fedoraproject.org/wiki/Features/Policy/Process -->
[[Category:Python]]

Latest revision as of 14:04, 18 September 2016


Python 2.7

Summary

Update the system Python 2 stack in Fedora from 2.6 to 2.7

Owner

  • Email: <dmalcolm@redhat.com>

Current status

  • Targeted release: Fedora 14
  • Last updated: 2010-09-27
  • Percentage of completion: 100%

oget wrote a script to report on remaining problems.

The results can be seen here

Tracker bug for packages that fail to rebuild: https://bugzilla.redhat.com/showdependencytree.cgi?id=619913&hide_resolved=1

Fixes for broken packages should be built into both rawhide, and into dist-f14.

Information on the new "dist-git" system can be seen here.

Once it's been successfully rebuilt for F14, an update needs to be filed to get the rebuild into F14.

To make it easier to track things, dmalcolm has been filing bugs using this template against the broken packages. Please set the component and add the name of the component to the front of the subject of the bug. Once an update has been created, the bug should be flipped over to the MODIFIED status, to make it easy to see what works remain.


Tracker bug for issue arising in built packages: https://bugzilla.redhat.com/showdependencytree.cgi?id=620817&hide_resolved=1 (e.g. Python 2.7 incompatibilities)

Packages with build errors

Common bugs

FIXED: gobject-introspection

gobject-introspection's /usr/bin/g-ir-scanner was incompatible with python 2.7, this led to anything building a .gir file failing.

This was blocking:

FIXED: SWIG

Various swig users fail to find the python libraries during "configure":

checking for Python library path... find: `/usr/lib/python/config/': No such file or directory
find: `/usr/lib/python/': No such file or directory
/usr/lib
checking python extra libraries... 

Relevant part of "configure" seems to be

        python_path=`echo $PYTHON | sed "s,/bin.*$,,"`
        for i in "$python_path/lib/python$PYTHON_VERSION/config/" "$python_path/lib/python$PYTHON_VERSION/" "$python_path/lib/python/config/" "$python_path/\
lib/python/" "$python_path/" ; do

This sets $python_path to "/usr", and then looks for config within /usr/lib, which fails on 64-bit: the relevant files are in /usr/lib64 (why did this work before? is this a python change?)

Before this we see errors like this:

checking for SWIG version... 2.0.0
configure: WARNING: SWIG version >= 1.3.17 is required.  You have 2.0.0.  You should look at http://www.swig.org

The test in the configure seems to look for an exact match on major and minor, and >= on the patch level, and thus "2" -ne "1" seems to leave SWIG_LIB unset, and could be the actual problem here.

A workaround is to add this:

# For now (workaround for SWIG major-version bump)
BuildRequires:  autoconf

%prep
(snip)
# Fixup expected version of SWIG:
sed -i -e "s|AC_PROG_SWIG(1.3.17)|AC_PROG_SWIG(2.0.0)|" configure.in
# and rebuild the configure script:
autoconf

This was blocking:

Detailed Description

  • Python 2.7 was released on 2010-07-03

This will require a rebuild of everything with Requires: python(abi) = 2.6. See Mass_Rebuild_SOP for how we do a full rebuild of everything - hopefully we can adapt the scripts there to accomplish the rebuild needed for Python 2.7. See Features/Python_2.7/MassRebuild for notes on this specific rebuild.

Porting

Hopefully, little to no porting will be required.

Some notes on changes that may require porting are given on the upstream wiki here: http://docs.python.org/dev/whatsnew/2.7.html#porting-to-python-2-7

Benefit to Fedora

Fedora aims to showcase the latest in free and open source software - we should have the most recent release of Python.

Scope

Python is pervasive in Fedora. Everything from yum to system-config-* to anaconda to pungi is written in Python.

How To Test

Interested testers do not need special hardware. If you have a favorite Python script, module, or application, please test it with Python 2.7 and verify that it still works as you expect.

My own test plan:

  • Smoketest of the interpreter
  • Run the upstream regression test suite
  • Ensure that yum still works
  • Ensure that anaconda still works

User Experience

Users should not notice any difference, other than the availability of the 2.7 interpreter


Dependencies

The list is too large to include here.

repoquery --whatrequires --alldeps -s "python(abi) = 2.6" | sort -u

indicates approximately 1200 rpms

Contingency Plan

  • There is none. This is do-or-die.

Documentation

What’s New in Python 2.7

Release Notes

The system Python 2 stack has been upgraded to 2.7. For a list of changes see http://docs.python.org/dev/whatsnew/2.7.html

Caveat: PyCObject and warnings

Python provides various APIs for use by C extension modules. One of these APIs, PyCObject, was deprecated in Python 2.7, but there are a number of key modules that have not yet been ported to its replacement.

By default, deprecation warnings are ignored, so this will not cause problems.

However, if the standard warnings settings are overridden, you may see problems with these modules. In particular, if warnings have been set to "error", it is possible to make the Python interpreter abort or even segfault when importing these modules.

If you need to enable errors-for-warnings, please also add an override so that a PendingDeprecationWarning is merely logged, rather than raising an exception:

>>> import warnings
>>> warnings.simplefilter('error')
>>> warnings.simplefilter('default', PendingDeprecationWarning)

Comments and Discussion