Opened 13 years ago
Last modified 13 years ago
#37 closed defect (FIXED)
natty support
Reported by: | Will Kahn-Greene | Owned by: | Will Kahn-Greene |
---|---|---|---|
Priority: | major | Milestone: | 0.0.2 |
Component: | Keywords: | ||
Cc: | Parent Tickets: |
Description
Running python setup.py develop on Ubuntu Natty doesn't work. PIL doesn't get compiled with jpeg or png support. This happens with both the virtualenv and buildout instructions. Doing a Google search leads to the following interesting urls: - `http://ubuntuforums.org/showthread.php?t=1751455 <http://ubuntuforums.org/showthread.php?t=1751455>`_ - `http://www.isnull.com.ar/2011/05/solved-python-pil-ioerror-decoder-jpeg.html <http://www.isnull.com.ar/2011/05/solved-python-pil-ioerror-decoder-jpeg.html>`_ This is a big deal because it means people using Ubuntu Natty can't run GNU MediaGoblin.
Attachments (2)
Change History (13)
comment:2 by , 13 years ago
03:35 ok. so, options are probably something like this: 03:35 1. virtualenv with site packages and tell people to pip install datetime over the existing system one. (yuck) 03:36 2. roll our own pypi with all the stuff. (total yuck and a lot of work) 03:36 3. not use pil and instead use mogrify or something. 03:36 4. tell people not to use natty. 03:36 mmm... i can't think of any others. One more comment. You forgot about `#5 </issues/5>`_: Modify the sys.path0 serach path so that it finds a local dateutil before searching the system one. In buildout that was simply possible by editing the few lines in bin/parser. I know that one is being automatically created by buildout, but looking at the buildout stuff, it does check e.g. for existing PYTHONPATH etc. So, I am not sure it is not possible to convinve buildout to put this dist package before the system one.
comment:3 by , 13 years ago
BTW, I have been able to get it work on natty with the following buildout.cfg :: [buildout] develop = . parts = mediagoblin make_user_dev_dirs [mediagoblin] recipe=zc.recipe.egg interpreter=python dependent-scripts = true eggs= python-dateutil>=1.5.0,<2.0.0 mediagoblin entry-points = nosetests=nose:run_exit paster=paste.script.command:run [make_user_dev_dirs] recipe = mediagoblin:make_user_dev_dirs path = user_dev As a consequence, buildout created the followin sys.path0: :: sys.path[0:0] = [ '/home/spaetz/src/mediagoblin/eggs/python_dateutil-1.5-py2.7.egg', '/home/spaetz/src/mediagoblin', ... And the startup worked flawlessly even after re-"buildout"ing. It might seem a bit ugly to put a dependency there (I don't know buildout...), but it did work using buildout. Hope that helps getting this running on natty with less effort.
comment:4 by , 13 years ago
One more issue I had with "buildout" on natty: 14:14 BTW, current buildout did not like my system python-pymongo and failed with a mysterious "mongo master not found". When I removed system python-pymongo it used the egg and all was fine. So this might also be a candidate for sys.path0 fudging. I guess the same way as the dateutil thing above in buildout.cfg should work. I have a running mediagoblin in natty now, using buildout. I can submit things and see the images.
comment:5 by , 13 years ago
Sebastian Spaeth wrote: 03:35 ok. so, options are probably something like this: 03:35 1. virtualenv with site packages and tell people to pip install datetime over the existing system one. (yuck) 03:36 2. roll our own pypi with all the stuff. (total yuck and a lot of work) 03:36 3. not use pil and instead use mogrify or something. 03:36 4. tell people not to use natty. 03:36 mmm... i can't think of any others. I had purposefully not included these options because they're not very useful. That wasn't an oversight. One more comment. You forgot about `#5 </issues/5>`_: Modify the sys.path0 serach path so that it finds a local dateutil before searching the system one. In buildout that was simply possible by editing the few lines in bin/parser. I know that one is being automatically created by buildout, but looking at the buildout stuff, it does check e.g. for existing PYTHONPATH etc. So, I am not sure it is not possible to convinve buildout to put this dist package before the system one. I didn't forget about this--I didn't think it was worth talking about. It requires the dev to change bin/parser every time they run buildout and that sucks.
comment:6 by , 13 years ago
Sebastian Spaeth wrote: BTW, I have been able to get it work on natty with the following buildout.cfg [...] As a consequence, buildout created the followin sys.path0: [...] And the startup worked flawlessly even after re-"buildout"ing. It might seem a bit ugly to put a dependency there (I don't know buildout...), but it did work using buildout. Hope that helps getting this running on natty with less effort. Can you put this together in a patch and attach it?
comment:7 by , 13 years ago
Patch commit is here: `https://gitorious.org/mediagoblin/mediagoblin/merge\_requests/6 <https://gitorious.org/mediagoblin/mediagoblin/merge_requests/6>`_
by , 13 years ago
Attachment: | 0001-Enforce-using-local-dateutil-with-buildout.patch added |
---|
0001-Enforce-using-local-dateutil-with-buildout.patch
comment:8 by , 13 years ago
willkg told me we don't use the gitorious merge request machinery, so here is the patch
by , 13 years ago
Attachment: | 0001-Enforce-using-local-dateutil-with-buildout.patch.1 added |
---|
0001-Enforce-using-local-dateutil-with-buildout.patch
comment:9 by , 13 years ago
Identified another issue with system python-pymongo on Ubuntu Natty, which would always cause *AutoReconnect("could not find master/primary")* errors. Forcing using a local one here too.
comment:10 by , 13 years ago
Status: | In Progress → Closed |
---|
Thanks for the patch, pushed. I wonder if it does fix everyone's things? I'll assume it does for now. If that's not true please let me know otherwise.
comment:11 by , 13 years ago
The original url for this bug was http://bugs.foocorp.net/issues/308 .
Note:
See TracTickets
for help on using tickets.