Summary: | lang/spidermonkey24: 'make configure' fails if devel/py-setuptools_scm is installed | ||
---|---|---|---|
Product: | Ports & Packages | Reporter: | John Hein <jcfyecrayz> |
Component: | Individual Port(s) | Assignee: | Koop Mast <kwm> |
Status: | Closed Overcome By Events | ||
Severity: | Affects Some People | CC: | kai, koobs, kwm, python, rene |
Priority: | --- | Keywords: | needs-qa |
Version: | Latest | Flags: | koobs:
maintainer-feedback?
(kwm) |
Hardware: | Any | ||
OS: | Any |
Description
John Hein
2019-05-15 12:51:56 UTC
Thanks for the report John The port really shouldn't be creating a Python environment/virtualenv or fetching things to do so, and should (only) be using the system Python environment and *_DEPEND'ing on the requisite python packages it needs (if any). To confirm again, this behaviour *does not* occur if setuptools_scm port is not installed? Is this a regression after a particular version, or did you just happen to notice it after something requiring setuptools_scm was installed? Is the issue contingent/dependent on an OPTION or other condition? (In reply to Kubilay Kocak from comment #1) I'm not sure about a regression. I just noticed it when trying to build spidermonkey24 after its PORTREVISION was bumped. Previous (successful) build of spidermonkey24 was 24.2.0_9 (built 20181220). At that time py-setuptools_scm was at 1.15.5, but I have not tried to determine if that particular combination (vs py-setuptools_scm 3.1.0 now) is relevant. It's possible there is a regression (dependent on py-setuptools_scm version). I suspect you're right that the spidermonkey24 port could / should be convinced to use the system install of python but that may not fix this problem. I don't know yet how to get the spidermonkey24 port to do that. Yes (re: "to confirm again"), I can build before py-setuptools_scm is installed, and not after. I used poudriere testport with -i to build successfully. Then while still in the jail (due to the -i), I remove spidermonkey24's work dir, do 'make -C /usr/ports/devel/py-setuptools_scm install', then 'make -C /usr/ports/lang/spidermonkey24 configure' (which now fails). I also don't know if the options combination is important (I suspect not), but for the record the options I have are set like so (which I think is the default + UTF8): OPTIONS_FILE_UNSET+=DEBUG OPTIONS_FILE_UNSET+=DTRACE OPTIONS_FILE_UNSET+=GCZEAL OPTIONS_FILE_UNSET+=JEMALLOC OPTIONS_FILE_SET+=METHODJIT OPTIONS_FILE_SET+=OPTIMIZE OPTIONS_FILE_SET+=READLINE OPTIONS_FILE_SET+=THREADSAFE OPTIONS_FILE_SET+=TRACEJIT OPTIONS_FILE_SET+=UTF8 (In reply to John Hein from comment #2) I just installed py-setuptools_scm PORTVERSION 1.17.0 in the poudriere jail (after deleting the installed 3.1.0), and 'make -C /usr/ports/lang/spidermonkey24 configure' succeeds. (In reply to Kubilay Kocak from comment #1) Also regarding whether to use virtualenv or not, I don't necessarily think it's bad for spidermonkey24 to use virtualenv, particularly if it only needs it for building (vs. a run-time dependency). Having a port isolate itself from the installed environment can be a reasonable strategy. Yes, pros / cons exist, and we don't need to get too deep into that here, I think. Ultimately, I could use someone with python expertise to help determine the root cause of this failure so we can figure out if we should fix spidermonkey24 or if there is something wrong with py-setuptools_scm (or something else). Clarification that may have already been obvious: the py-setuptools_scm flavor that interferes is @py27. Now that the default python is py36, this is important to mention if you are trying to reproduce. Of course, if only py-setuptools_scm@py36 is installed, then the python2.7 (that spidermonkey24 uses) won't see it, and thus you won't reproduce the failure. So the reproduction instructions in comment 2 should say 'make -C /usr/ports/devel/py-setuptools_scm install FLAVOR=py27' in case your ports tree is after the default python switched from py27 -> py36. I don't have a fix yet, but potential workarounds include: (1) 'pkg delete py27-setuptools_scm'. Leave deleted if you don't need it, or re-add after building & installing spidermonkey24. (2) mv -i /usr/local/lib/python2.7/site-packages/setuptools_scm-3.1.0-py2.7.egg-info /usr/local/lib/python2.7/site-packages/setuptools_scm-3.1.0-py2.7.egg-info.mv Then rename back after building & installing spidermonkey24. This is an old version of spidermonkey which is python27 only, please use a recent version. |