eliminate pywin32 dependency #1274

Closed
opened 2010-11-30 20:58:52 +00:00 by daira · 34 comments

Anything that can be done using pywin32 can also be done, a little more klunkily, using ctypes. Currently we depend on pywin32 directly to get disk stats at source:src/allmydata/storage/server.py@4595#L177, and indirectly via Twisted. Twisted depends on it only for spawnProcess in http://twistedmatrix.com/trac/browser/trunk/twisted/internet/posixbase.py?rev=29163#L331. These dependencies could be easily eliminated, simplifying installation on Windows.

(We ended up not needing a change to Twisted.)

Anything that can be done using pywin32 can also be done, a little more klunkily, using ctypes. Currently we depend on pywin32 directly to get disk stats at source:src/allmydata/storage/server.py@4595#L177, and indirectly via Twisted. Twisted depends on it only for `spawnProcess` in <http://twistedmatrix.com/trac/browser/trunk/twisted/internet/posixbase.py?rev=29163#L331>. These dependencies could be easily eliminated, simplifying installation on Windows. (We ended up not needing a change to Twisted.)
daira added the
c/code-storage
p/major
t/defect
v/1.8.0
labels 2010-11-30 20:58:52 +00:00
daira added this to the 1.9.0 milestone 2010-11-30 20:58:52 +00:00
Author

This patch needs to be rebased due to the changes in #1195.

This patch needs to be rebased due to the changes in #1195.
daira self-assigned this 2010-12-31 21:07:25 +00:00
Author

Attachment no-pywin32.darcs.patch (12696 bytes) added

Eliminate direct dependencies of Tahoe-LAFS on pywin32 (updated to trunk post-#1195). refs #1274

**Attachment** no-pywin32.darcs.patch (12696 bytes) added Eliminate direct dependencies of Tahoe-LAFS on pywin32 (updated to trunk post-#1195). refs #1274
daira removed their assignment 2010-12-31 22:19:42 +00:00
daira modified the milestone from 1.9.0 to 1.8.2 2011-01-06 02:03:06 +00:00
Author

(The 1.8.2 milestone is for eliminating the direct dependency.)

(The 1.8.2 milestone is for eliminating the direct dependency.)
Author

In [4941/ticket1306]:

Eliminate direct dependencies of Tahoe-LAFS on pywin32 (updated to trunk post-#1195). refs #1274
In [4941/ticket1306]: ``` Eliminate direct dependencies of Tahoe-LAFS on pywin32 (updated to trunk post-#1195). refs #1274 ```

I could try to review this. Release Master Brian Warner says he'll accept it based on the strength of manual testing by David-Sarah and hopefully other Windows users during the imminent release-candidate phase.

I could try to review this. Release Master Brian Warner says he'll accept it based on the strength of manual testing by David-Sarah and hopefully other Windows users during the imminent release-candidate phase.
zooko self-assigned this 2011-01-18 08:24:19 +00:00
wadey commented 2011-01-19 04:53:46 +00:00
Owner

I just reviewed this patch and it looks good to me. +1

I just reviewed this patch and it looks good to me. +1
zooko removed their assignment 2011-01-19 04:59:09 +00:00
daira was assigned by zooko 2011-01-19 04:59:09 +00:00
Author

In changeset:d21f4071c3229e18:

Eliminate direct dependencies of Tahoe-LAFS on pywin32 (rebased to trunk). refs #1274
In changeset:d21f4071c3229e18: ``` Eliminate direct dependencies of Tahoe-LAFS on pywin32 (rebased to trunk). refs #1274 ```

We can now update quickstart.html to no longer mention pywin32! Hooray! :-)

(Also wiki/AdvancedInstall, but I do not take any responsibility for that page so if it is going to get updated to reflect this change it will have to be updated by someone else.)

We can now update [quickstart.html](http://tahoe-lafs.org/source/tahoe-lafs/trunk/docs/quickstart.html) to no longer mention `pywin32`! Hooray! :-) (Also [wiki/AdvancedInstall](wiki/AdvancedInstall), but I do not take any responsibility for that page so if it is going to get updated to reflect this change it will have to be updated by someone else.)
Author

Replying to zooko:

We can now update quickstart.html to no longer mention pywin32! Hooray! :-)

Not so fast! Tahoe itself no longer directly depends on pywin32, but Twisted does. Specifically, in source:src/allmydata/test/test_runner.py, Tahoe uses twisted.internet.utils.getProcessOutputAndValue, which indirectly uses _dumbwin32proc.py and _pollingfile.py from Twisted.
Tahoe also has one call to getProcessOutput in source:src/allmydata/util/iputil.py.

There are two options for getting rid of this indirect dependency:

  • change the Twisted code to use ctypes. The two files I mentioned use 12 Win32 API functions (WaitForSingleObject, GetExitCodeProcess, CreatePipe, SetNamedPipeHandleState, GetCurrentProcess, DuplicateHandle, CloseHandle, CreateProcess, TerminateProcess, PeekNamedPipe, ReadFile, WriteFile), and two structures (SECURITY_ATTRIBUTES, STARTUPINFO). This is probably a few hours work to translate to ctypes.
  • change test_runner.py and iputil.py to use the subprocess module.

I was originally thinking of the first of these options, but the second seems easier, and maybe even feasible for 1.8.2. I'll try it after I'm done pushing the 1.8.2 patches that have already been reviewed.

Replying to [zooko](/tahoe-lafs/trac/issues/1274#issuecomment-382466): > We can now update [quickstart.html](http://tahoe-lafs.org/source/tahoe-lafs/trunk/docs/quickstart.html) to no longer mention `pywin32`! Hooray! :-) Not so fast! Tahoe itself no longer directly depends on pywin32, but Twisted does. Specifically, in source:src/allmydata/test/test_runner.py, Tahoe uses [twisted.internet.utils.getProcessOutputAndValue](http://twistedmatrix.com/trac/browser/trunk/twisted/internet/utils.py?rev=24810#L161), which indirectly uses [_dumbwin32proc.py](http://twistedmatrix.com/trac/browser/trunk/twisted/internet/_dumbwin32proc.py) and [_pollingfile.py](http://twistedmatrix.com/trac/browser/trunk/twisted/internet/_pollingfile.py) from Twisted. Tahoe also has one call to `getProcessOutput` in source:src/allmydata/util/iputil.py. There are two options for getting rid of this indirect dependency: * change the Twisted code to use ctypes. The two files I mentioned use 12 Win32 API functions (WaitForSingleObject, GetExitCodeProcess, CreatePipe, SetNamedPipeHandleState, GetCurrentProcess, DuplicateHandle, CloseHandle, CreateProcess, TerminateProcess, PeekNamedPipe, ReadFile, WriteFile), and two structures (SECURITY_ATTRIBUTES, STARTUPINFO). This is probably a few hours work to translate to ctypes. * change `test_runner.py` and `iputil.py` to use the `subprocess` module. I was originally thinking of the first of these options, but the second seems easier, and maybe even feasible for 1.8.2. I'll try it after I'm done pushing the 1.8.2 patches that have already been reviewed.
Author

Attachment eliminate-pywin32-completely.darcs.patch (46007 bytes) added

Eliminate dependencies on pywin32, even via Twisted. refs #1274

**Attachment** eliminate-pywin32-completely.darcs.patch (46007 bytes) added Eliminate dependencies on pywin32, even via Twisted. refs #1274
daira removed their assignment 2011-01-20 05:15:18 +00:00
I reviewed [attachment:eliminate-pywin32-completely.darcs.patch](/tahoe-lafs/trac/attachments/000078ac-bf5c-e6bc-a183-21d1e11b5028) and it looks good!
Author

In changeset:6dd8b6f47126fdc0:

Eliminate dependencies on pywin32, even via Twisted. refs #1274
In changeset:6dd8b6f47126fdc0: ``` Eliminate dependencies on pywin32, even via Twisted. refs #1274 ```
Author

Attachment eliminate-pywin32-news-and-doc.darcs.patch (24134 bytes) added

NEWS, docs/quickstart.html: pywin32 is no longer required on Windows. Update the download section of quickstart.html to include the release candidate. Apply to trunk just before release. refs #1306, #1274

**Attachment** eliminate-pywin32-news-and-doc.darcs.patch (24134 bytes) added NEWS, docs/quickstart.html: pywin32 is no longer required on Windows. Update the download section of quickstart.html to include the release candidate. Apply to trunk just before release. refs #1306, #1274
Author

In changeset:d5138b3237d27d0a:

src/allmydata/util/iputil.py: loosen regexps and ensure that 'LANG=en_US.UTF-8' is set in the environment, to minimize problems with localized output of IP-address-finding tools. refs #1274
In changeset:d5138b3237d27d0a: ``` src/allmydata/util/iputil.py: loosen regexps and ensure that 'LANG=en_US.UTF-8' is set in the environment, to minimize problems with localized output of IP-address-finding tools. refs #1274 ```

Nothing left but docs-needed and news-needed. Assigning to Brian.

Nothing left but `docs-needed` and `news-needed`. Assigning to Brian.
warner was assigned by zooko 2011-01-20 09:34:47 +00:00

Replying to davidsarah:

  • change test_runner.py and iputil.py to use the
    subprocess module.

The usual problem with using subprocess is SIGCHLD: Twisted's
reactor and subprocess.py fight over who gets to register a handler.
The reactor isn't strictly running during a trial unit test context. It
sort of is, but reactor.run() isn't called, and I've had problems using
reactor.spawnProcess or utils.getProcessOutputAndValue from tests
(the "potential zombie child" warning), which I've addressed by explicitly
invoking the twisted call that installs its SIGCHLD handler.

But it almost certainly is running when iputil.py gets used. So if
subprocess.py takes over the SIGCHLD handler, we need to look carefully
and make sure that Twisted gets it back again afterwards. I don't know if we
use getProcessOutputAndValue anywhere outside of iputil.py, so a
problem there may not bite us until we add a call like that later (like maybe
a call to du -s to measure storage usage), and I'd like to avoid that
uncertainty.

So maybe a quick manual test which does a reactor.spawnProcess in
response to a WUI button press is in order.

Replying to [davidsarah](/tahoe-lafs/trac/issues/1274#issuecomment-382467): > > * change `test_runner.py` and `iputil.py` to use the > `subprocess` module. The usual problem with using `subprocess` is `SIGCHLD`: Twisted's reactor and `subprocess.py` fight over who gets to register a handler. The reactor isn't strictly running during a `trial` unit test context. It sort of is, but `reactor.run()` isn't called, and I've had problems using `reactor.spawnProcess` or `utils.getProcessOutputAndValue` from tests (the "potential zombie child" warning), which I've addressed by explicitly invoking the twisted call that installs its SIGCHLD handler. But it almost certainly is running when `iputil.py` gets used. So if `subprocess.py` takes over the SIGCHLD handler, we need to look carefully and make sure that Twisted gets it back again afterwards. I don't know if we use `getProcessOutputAndValue` anywhere outside of `iputil.py`, so a problem there may not bite us until we add a call like that later (like maybe a call to `du -s` to measure storage usage), and I'd like to avoid that uncertainty. So maybe a quick manual test which does a `reactor.spawnProcess` in response to a WUI button press is in order.
Author

Replying to [warner]comment:20:

Replying to davidsarah:

  • change test_runner.py and iputil.py to use the
    subprocess module.

The usual problem with using subprocess is SIGCHLD: Twisted's
reactor and subprocess.py fight over who gets to register a handler.
The reactor isn't strictly running during a trial unit test context. It
sort of is, but reactor.run() isn't called, and I've had problems using
reactor.spawnProcess or utils.getProcessOutputAndValue from tests
(the "potential zombie child" warning), which I've addressed by explicitly
invoking the twisted call that installs its SIGCHLD handler.

But it almost certainly is running when iputil.py gets used. So if
subprocess.py takes over the SIGCHLD handler, we need to look carefully
and make sure that Twisted gets it back again afterwards. I don't know if we
use getProcessOutputAndValue anywhere outside of iputil.py, so a
problem there may not bite us until we add a call like that later (like maybe
a call to du -s to measure storage usage), and I'd like to avoid that
uncertainty.

With this patch, we no longer use anything that calls reactor.spawnProcess (either in test or non-test code). Does that resolve the problem?

iputil.py is the only place [in non-test code] where we previously used getProcessOutput and now use subprocess.Popen. Note that it is done in a deferToThread (I'm not sure whether that helps, since the SIGCHLD handler is process-global).

Replying to [warner]comment:20: > Replying to [davidsarah](/tahoe-lafs/trac/issues/1274#issuecomment-382467): > > > > * change `test_runner.py` and `iputil.py` to use the > > `subprocess` module. > > The usual problem with using `subprocess` is `SIGCHLD`: Twisted's > reactor and `subprocess.py` fight over who gets to register a handler. > The reactor isn't strictly running during a `trial` unit test context. It > sort of is, but `reactor.run()` isn't called, and I've had problems using > `reactor.spawnProcess` or `utils.getProcessOutputAndValue` from tests > (the "potential zombie child" warning), which I've addressed by explicitly > invoking the twisted call that installs its SIGCHLD handler. > > But it almost certainly is running when `iputil.py` gets used. So if > `subprocess.py` takes over the SIGCHLD handler, we need to look carefully > and make sure that Twisted gets it back again afterwards. I don't know if we > use `getProcessOutputAndValue` anywhere outside of `iputil.py`, so a > problem there may not bite us until we add a call like that later (like maybe > a call to `du -s` to measure storage usage), and I'd like to avoid that > uncertainty. With this patch, we no longer use anything that calls `reactor.spawnProcess` (either in test or non-test code). Does that resolve the problem? `iputil.py` is the only place [in non-test code] where we previously used `getProcessOutput` and now use `subprocess.Popen`. Note that it is done in a `deferToThread` (I'm not sure whether that helps, since the SIGCHLD handler is process-global).
Author

In changeset:b6c2c9591d61a680:

src/allmydata/util/iputil.py: correct an error in the address-matching regexps introduced by the previous patch to iputil. refs #1274
In changeset:b6c2c9591d61a680: ``` src/allmydata/util/iputil.py: correct an error in the address-matching regexps introduced by the previous patch to iputil. refs #1274 ```

Replying to [davidsarah]comment:21:

With this patch, we no longer use anything that calls
reactor.spawnProcess (either in test or non-test code). Does
that resolve the problem?

iputil.py is the only place [non-test code]in where we
previously used getProcessOutput and now use
subprocess.Popen. Note that it is done in a deferToThread
(I'm not sure whether that helps, since the SIGCHLD handler is
process-global).

I don't think that resolves the problem (although I need to stare at the
code and test it to be sure). The issue was using subprocess.Popen
in a twisted program, regardless of whether or not that same program is
using any reactor.spawnProcess calls. subprocess is
blocking, of course (when you use p.wait or I think
communicate), so using it for iputil.py at startup is
somewhat excusable but using it anywhere later would be bad.

But it may be the case that we won't see any damage from this right now.
When/if we start using spawned children at runtime (again, du -s
is the best I can imagine right now), we may have to undo this, or live
without that feature.

I'll try to run some tests this week to see what happens.

Replying to [davidsarah]comment:21: > With this patch, we no longer use anything that calls > `reactor.spawnProcess` (either in test or non-test code). Does > that resolve the problem? > > `iputil.py` is the only place [non-test code]in where we > previously used `getProcessOutput` and now use > `subprocess.Popen`. Note that it is done in a `deferToThread` > (I'm not sure whether that helps, since the SIGCHLD handler is > process-global). I don't think that resolves the problem (although I need to stare at the code and test it to be sure). The issue was using `subprocess.Popen` in a twisted program, regardless of whether or not that same program is using any `reactor.spawnProcess` calls. `subprocess` is blocking, of course (when you use `p.wait` or I think `communicate`), so using it for `iputil.py` at startup is somewhat excusable but using it anywhere later would be bad. But it may be the case that we won't see any damage from this right now. When/if we start using spawned children at runtime (again, `du -s` is the best I can imagine right now), we may have to undo this, or live without that feature. I'll try to run some tests this week to see what happens.

Oh, and is changeset:b6c2c9591d61a680 the last code patch for this ticket, modulo the SIGCHLD issue?

Oh, and is changeset:b6c2c9591d61a680 the last code patch for this ticket, modulo the SIGCHLD issue?
Author

Replying to [warner]comment:23:

Replying to [davidsarah]comment:21:

With this patch, we no longer use anything that calls
reactor.spawnProcess (either in test or non-test code). Does
that resolve the problem?

iputil.py is the only place [non-test code]in where we
previously used getProcessOutput and now use
subprocess.Popen. Note that it is done in a deferToThread
(I'm not sure whether that helps, since the SIGCHLD handler is
process-global).

I don't think that resolves the problem (although I need to stare at the
code and test it to be sure). The issue was using subprocess.Popen
in a twisted program, regardless of whether or not that same program is
using any reactor.spawnProcess calls. subprocess is
blocking, of course (when you use p.wait or I think
communicate), so using it for iputil.py at startup is
somewhat excusable but using it anywhere later would be bad.

Yes, that's why iputil now uses deferToThread.

But it may be the case that we won't see any damage from this right now.
When/if we start using spawned children at runtime (again, du -s
is the best I can imagine right now), we may have to undo this, or live
without that feature.

We would have to use subprocess for those in any case, to avoid reintroducing the dependency on pywin32 on Windows (besides the SIGCHLD issue).

This ticket is done, I've tested it on win32 (including starting a gateway node and using the WUI to the pubgrid), and Dcoder ran the testsuite successfully on win64. Unfortunately, it seems that buildbot depends on pywin32, so we can't set up the Windows buildbots without it installed. I'll open another ticket for that. (#1334)

Replying to [warner]comment:23: > Replying to [davidsarah]comment:21: > > > With this patch, we no longer use anything that calls > > `reactor.spawnProcess` (either in test or non-test code). Does > > that resolve the problem? > > > > `iputil.py` is the only place [non-test code]in where we > > previously used `getProcessOutput` and now use > > `subprocess.Popen`. Note that it is done in a `deferToThread` > > (I'm not sure whether that helps, since the SIGCHLD handler is > > process-global). > > I don't think that resolves the problem (although I need to stare at the > code and test it to be sure). The issue was using `subprocess.Popen` > in a twisted program, regardless of whether or not that same program is > using any `reactor.spawnProcess` calls. `subprocess` is > blocking, of course (when you use `p.wait` or I think > `communicate`), so using it for `iputil.py` at startup is > somewhat excusable but using it anywhere later would be bad. Yes, that's why iputil now uses `deferToThread`. > But it may be the case that we won't see any damage from this right now. > When/if we start using spawned children at runtime (again, `du -s` > is the best I can imagine right now), we may have to undo this, or live > without that feature. We would have to use `subprocess` for those in any case, to avoid reintroducing the dependency on pywin32 on Windows (besides the SIGCHLD issue). This ticket is done, I've tested it on win32 (including starting a gateway node and using the WUI to the pubgrid), and Dcoder ran the testsuite successfully on win64. Unfortunately, it seems that buildbot depends on pywin32, so we can't set up the Windows buildbots without it installed. I'll open another ticket for that. (#1334)
daira added the
r/fixed
label 2011-01-21 22:32:50 +00:00
daira closed this issue 2011-01-21 22:32:50 +00:00

Sigh, so it sounds like the new rule is that we aren't allowed to use reactor.spawnProcess or related functions in tahoe; instead we must use reactor.deferToThread and a blocking subprocess call, because of windows. Oh well.

Sigh, so it sounds like the new rule is that we aren't allowed to use `reactor.spawnProcess` or related functions in tahoe; instead we must use `reactor.deferToThread` and a blocking `subprocess` call, because of windows. Oh well.
Author

In changeset:3eadc8a05375656f:

NEWS, docs/quickstart.html: pywin32 is no longer required on Windows. refs #1274
In changeset:3eadc8a05375656f: ``` NEWS, docs/quickstart.html: pywin32 is no longer required on Windows. refs #1274 ```
Author

It appears that Twisted 8.2.0 depends on pywin32 when importing twisted.internet.defer (which we need, and nevow also needs). See this tahoe-dev thread: http://tahoe-lafs.org/pipermail/tahoe-dev/2011-June/006428.html

It appears that Twisted 8.2.0 depends on pywin32 when importing `twisted.internet.defer` (which we need, and nevow also needs). See this tahoe-dev thread: <http://tahoe-lafs.org/pipermail/tahoe-dev/2011-June/006428.html>
daira removed the
r/fixed
label 2011-06-09 18:51:01 +00:00
daira reopened this issue 2011-06-09 18:51:01 +00:00
Author

That dependency (actually in twisted.python.lockfile, which twisted.internet.defer imports), seems to have been removed in this changeset: http://twistedmatrix.com/trac/changeset/26634#file1 , which would have been released in Twisted 9.0.

Perhaps we should bump the Twisted version requirement to >= 9.0, either only on Windows, or on all platforms. That version was released on 2009-11-24.

That dependency (actually in `twisted.python.lockfile`, which `twisted.internet.defer` imports), seems to have been removed in this changeset: <http://twistedmatrix.com/trac/changeset/26634#file1> , which would have been released in Twisted 9.0. Perhaps we should bump the Twisted version requirement to >= 9.0, either only on Windows, or on all platforms. That version was released on 2009-11-24.
Author

Attachment raise-twisted-version-dep.darcs.patch (13235 bytes) added

Raise Twisted version requirement to >= 9.0.0, in order to avoid an indirect dependency on pywin32 for Windows. refs #1274

**Attachment** raise-twisted-version-dep.darcs.patch (13235 bytes) added Raise Twisted version requirement to >= 9.0.0, in order to avoid an indirect dependency on pywin32 for Windows. refs #1274
Author

Attachment raise-twisted-version-dep-2.darcs.patch (13733 bytes) added

Raise Twisted version requirement to >= 9.0.0 (at both setup- and install-time), in order to avoid an indirect dependency on pywin32 for Windows. refs #1274

**Attachment** raise-twisted-version-dep-2.darcs.patch (13733 bytes) added Raise Twisted version requirement to >= 9.0.0 (at both setup- and install-time), in order to avoid an indirect dependency on pywin32 for Windows. refs #1274

I looked at the patch itself and saw no bug in it. I wonder about raising the required version of Twisted, though. It is a shame to prevent someone using Debian Lenny, or Ubuntu Hardy from installing Tahoe-LAFS v1.9.0 using their pre-packaged version of Twisted:

http://packages.debian.org/search?keywords=twisted&searchon=names&suite=all&section=all

http://packages.ubuntu.com/search?keywords=twisted&searchon=names&suite=all&section=all

I'd like to know what Brian thinks.

Making it conditional on the platform might not be a good idea--although that works when Tahoe-LAFS is being built by having its source:setup.py file executed, there is no way to encode it into the resulting src/allmydata_tahoe.egg-info/requires.txt file, so if someone were to build a Tahoe-LAFS egg, that egg would come with metadata indicating a Twisted version requirement depending on what platform the egg was built on, although the egg itself would be platform-independent. This sort of thing could lead to confusion in the future, and we have enough confusion with regard to packaging as it is. (We already do a similar dependency version conditioned on platform for pycryptopp: http://tahoe-lafs.org/trac/tahoe-lafs/browser/trunk/src/allmydata/_auto_deps.py?annotate=blame&rev=4976#L64 . I suppose that too is potentially a source of confusion.)

$ cat src/allmydata_tahoe.egg-info/requires.txt 
setuptools >= 0.6c6
zfec >= 1.1.0
simplejson >= 1.4
zope.interface
Twisted >= 2.4.0
foolscap[secure_connections] >= 0.6.1
Nevow >= 0.6.0
pycrypto == 2.0.1, == 2.1.0, >= 2.3
pyasn1 >= 0.0.8a
mock
pycryptopp >= 0.5.20
I looked at the patch itself and saw no bug in it. I wonder about raising the required version of Twisted, though. It is a shame to prevent someone using Debian Lenny, or Ubuntu Hardy from installing Tahoe-LAFS v1.9.0 using their pre-packaged version of Twisted: <http://packages.debian.org/search?keywords=twisted&searchon=names&suite=all&section=all> <http://packages.ubuntu.com/search?keywords=twisted&searchon=names&suite=all&section=all> I'd like to know what Brian thinks. Making it conditional on the platform might not be a good idea--although that works when Tahoe-LAFS is being built by having its source:setup.py file executed, there is no way to encode it into the resulting `src/allmydata_tahoe.egg-info/requires.txt` file, so if someone were to build a Tahoe-LAFS egg, that egg would come with metadata indicating a Twisted version requirement depending on what platform the egg was built on, although the egg itself would be platform-independent. This sort of thing could lead to confusion in the future, and we have enough confusion with regard to packaging as it is. (We already do a similar dependency version conditioned on platform for pycryptopp: <http://tahoe-lafs.org/trac/tahoe-lafs/browser/trunk/src/allmydata/_auto_deps.py?annotate=blame&rev=4976#L64> . I suppose that too is potentially a source of confusion.) ``` $ cat src/allmydata_tahoe.egg-info/requires.txt setuptools >= 0.6c6 zfec >= 1.1.0 simplejson >= 1.4 zope.interface Twisted >= 2.4.0 foolscap[secure_connections] >= 0.6.1 Nevow >= 0.6.0 pycrypto == 2.0.1, == 2.1.0, >= 2.3 pyasn1 >= 0.0.8a mock pycryptopp >= 0.5.20 ```
Author

Replying to zooko:

I looked at the patch itself and saw no bug in it. I wonder about raising the required version of Twisted, though. It is a shame to prevent someone using Debian Lenny, or Ubuntu Hardy from installing Tahoe-LAFS v1.9.0 using their pre-packaged version of Twisted:

http://packages.debian.org/search?keywords=twisted&searchon=names&suite=all&section=all

http://packages.ubuntu.com/search?keywords=twisted&searchon=names&suite=all&section=all

I have to say, I don't really understand what the problem is with having a Tahoe instance built by 'python setup.py build' use a local instance of Twisted, when the installed instance is < 9.0.0.

I can see that someone might want to use their OS packagement tools to make sure that all instances of libraries are up-to-date (in order to promptly patch security bugs etc.), but that argument doesn't really hold water when the result would be to use a library version that is ~2 years old.

Making it conditional on the platform might not be a good idea--although that works when Tahoe-LAFS is being built by having its source:setup.py file executed, there is no way to encode it into the resulting src/allmydata_tahoe.egg-info/requires.txt file, so if someone were to build a Tahoe-LAFS egg, that egg would come with metadata indicating a Twisted version requirement depending on what platform the egg was built on, although the egg itself would be platform-independent.

A bit off-topic, but distutils2's approach fixes that problem; in setup.cfg you can use environment markers like this:

Requires-Dist: Twisted (>=9.0.0); sys.platform == 'win32'
Requires-Dist: Twisted (>=2.4.0); sys.platform != 'win32'
Replying to [zooko](/tahoe-lafs/trac/issues/1274#issuecomment-382488): > I looked at the patch itself and saw no bug in it. I wonder about raising the required version of Twisted, though. It is a shame to prevent someone using Debian Lenny, or Ubuntu Hardy from installing Tahoe-LAFS v1.9.0 using their pre-packaged version of Twisted: > > <http://packages.debian.org/search?keywords=twisted&searchon=names&suite=all&section=all> > > <http://packages.ubuntu.com/search?keywords=twisted&searchon=names&suite=all&section=all> I have to say, I don't really understand what the problem is with having a Tahoe instance built by '`python setup.py build`' use a local instance of Twisted, when the installed instance is < 9.0.0. I can see that someone might want to use their OS packagement tools to make sure that all instances of libraries are up-to-date (in order to promptly patch security bugs etc.), but that argument doesn't really hold water when the result would be to use a library version that is ~2 years old. > Making it conditional on the platform might not be a good idea--although that works when Tahoe-LAFS is being built by having its source:setup.py file executed, there is no way to encode it into the resulting `src/allmydata_tahoe.egg-info/requires.txt` file, so if someone were to build a Tahoe-LAFS egg, that egg would come with metadata indicating a Twisted version requirement depending on what platform the egg was built on, although the egg itself would be platform-independent. A bit off-topic, but distutils2's approach fixes that problem; in `setup.cfg` you can use [environment markers](http://www.python.org/dev/peps/pep-0345/#environment-markers) like this: ``` Requires-Dist: Twisted (>=9.0.0); sys.platform == 'win32' Requires-Dist: Twisted (>=2.4.0); sys.platform != 'win32' ```
daira modified the milestone from 1.8.2 to 1.9.0 2011-06-13 00:45:39 +00:00

Replying to [davidsarah]comment:32:

I have to say, I don't really understand what the problem is with having a Tahoe instance built by 'python setup.py build' use a local instance of Twisted, when the installed instance is < 9.0.0.

Yeah, I guess the cost really isn't that bad. Also, while I feel a sort of vague warm happiness about our longstanding compatibility with Twisted 2.4.0, it isn't really tested. A glance at our buildbot waterfall shows the following versions of Twisted: 8.1.0, 10.1.0, 11.0.0, and 10.0.0. So claiming that Tahoe-LAFS works correctly with Twisted 2.4.0 is best understood as "good intentions".

(Aside: I'm glad Brian hasn't yet gotten around to removing some of the tool versions information from the waterfall, so that I was able to gather that information by scanning a single page.)

The two Twisted 8.1.0 buildslaves are both Debian 5 "Lenny". As you say, if we raise this requirement then the Tahoe-LAFS build on those buildslaves should just use a local copy of a newer version of Twisted. Shall we try it?

I'd still like to hear from Brian on this ticket!

Replying to [davidsarah]comment:32: > > I have to say, I don't really understand what the problem is with having a Tahoe instance built by '`python setup.py build`' use a local instance of Twisted, when the installed instance is < 9.0.0. Yeah, I guess the cost really isn't that bad. Also, while I feel a sort of vague warm happiness about our longstanding compatibility with `Twisted 2.4.0`, it isn't really tested. A glance at [our buildbot waterfall](http://tahoe-lafs.org/buildbot/waterfall) shows the following versions of Twisted: `8.1.0`, `10.1.0`, `11.0.0`, and `10.0.0`. So claiming that Tahoe-LAFS works correctly with `Twisted 2.4.0` is best understood as "good intentions". (Aside: I'm glad Brian hasn't yet gotten around to removing some of the tool versions information from the waterfall, so that I was able to gather that information by scanning a single page.) The two `Twisted 8.1.0` buildslaves are both Debian 5 "Lenny". As you say, if we raise this requirement then the Tahoe-LAFS build on those buildslaves should just use a local copy of a newer version of Twisted. Shall we try it? I'd still like to hear from Brian on this ticket!
Author

Note that the new drop-upload feature (#1429) requires Twisted 10.1 on Linux. That could be an optional or platform-specific dependency, but it might be simpler for it not to be. Raising the dependency to >= 10.1 unconditionally would fix this ticket as well.

Note that the new drop-upload feature (#1429) requires Twisted 10.1 on Linux. That could be an optional or platform-specific dependency, but it might be simpler for it not to be. Raising the dependency to >= 10.1 unconditionally would fix this ticket as well.
Owner

FWIW, pkgsrc (and hence NetBSD) has had 10.1.0 since 2010-11-04. Given 10.1.0's release announcement on 2010-07-04, it seems systems without 10.1 are now out of date.

FWIW, pkgsrc (and hence NetBSD) has had 10.1.0 since 2010-11-04. Given 10.1.0's release announcement on 2010-07-04, it seems systems without 10.1 are now out of date.
Author
(http://tahoe-lafs.org/trac/tahoe-lafs/attachment/ticket/1435/dependency-updates.darcs.patch) replaces [attachment:raise-twisted-version-dep-2.darcs.patch](/tahoe-lafs/trac/attachments/000078ac-bf5c-e6bc-a183-016746507ac0).
Author

In changeset:8b4082677477daf1:

Update the dependency on Twisted to >= 10.1. This allows us to simplify some documentation: it's no longer necessary to install pywin32 on Windows, or apply a patch to Twisted in order to use the FTP frontend. fixes #1274, #1438. refs #1429
In changeset:8b4082677477daf1: ``` Update the dependency on Twisted to >= 10.1. This allows us to simplify some documentation: it's no longer necessary to install pywin32 on Windows, or apply a patch to Twisted in order to use the FTP frontend. fixes #1274, #1438. refs #1429 ```
daira added the
r/fixed
label 2011-07-22 05:26:54 +00:00
daira closed this issue 2011-07-22 05:26:54 +00:00
Sign in to join this conversation.
No labels
c/code
c/code-dirnodes
c/code-encoding
c/code-frontend
c/code-frontend-cli
c/code-frontend-ftp-sftp
c/code-frontend-magic-folder
c/code-frontend-web
c/code-mutable
c/code-network
c/code-nodeadmin
c/code-peerselection
c/code-storage
c/contrib
c/dev-infrastructure
c/docs
c/operational
c/packaging
c/unknown
c/website
kw:2pc
kw:410
kw:9p
kw:ActivePerl
kw:AttributeError
kw:DataUnavailable
kw:DeadReferenceError
kw:DoS
kw:FileZilla
kw:GetLastError
kw:IFinishableConsumer
kw:K
kw:LeastAuthority
kw:Makefile
kw:RIStorageServer
kw:StringIO
kw:UncoordinatedWriteError
kw:about
kw:access
kw:access-control
kw:accessibility
kw:accounting
kw:accounting-crawler
kw:add-only
kw:aes
kw:aesthetics
kw:alias
kw:aliases
kw:aliens
kw:allmydata
kw:amazon
kw:ambient
kw:annotations
kw:anonymity
kw:anonymous
kw:anti-censorship
kw:api_auth_token
kw:appearance
kw:appname
kw:apport
kw:archive
kw:archlinux
kw:argparse
kw:arm
kw:assertion
kw:attachment
kw:auth
kw:authentication
kw:automation
kw:avahi
kw:availability
kw:aws
kw:azure
kw:backend
kw:backoff
kw:backup
kw:backupdb
kw:backward-compatibility
kw:bandwidth
kw:basedir
kw:bayes
kw:bbfreeze
kw:beta
kw:binaries
kw:binutils
kw:bitcoin
kw:bitrot
kw:blacklist
kw:blocker
kw:blocks-cloud-deployment
kw:blocks-cloud-merge
kw:blocks-magic-folder-merge
kw:blocks-merge
kw:blocks-raic
kw:blocks-release
kw:blog
kw:bom
kw:bonjour
kw:branch
kw:branding
kw:breadcrumbs
kw:brians-opinion-needed
kw:browser
kw:bsd
kw:build
kw:build-helpers
kw:buildbot
kw:builders
kw:buildslave
kw:buildslaves
kw:cache
kw:cap
kw:capleak
kw:captcha
kw:cast
kw:centos
kw:cffi
kw:chacha
kw:charset
kw:check
kw:checker
kw:chroot
kw:ci
kw:clean
kw:cleanup
kw:cli
kw:cloud
kw:cloud-backend
kw:cmdline
kw:code
kw:code-checks
kw:coding-standards
kw:coding-tools
kw:coding_tools
kw:collection
kw:compatibility
kw:completion
kw:compression
kw:confidentiality
kw:config
kw:configuration
kw:configuration.txt
kw:conflict
kw:connection
kw:connectivity
kw:consistency
kw:content
kw:control
kw:control.furl
kw:convergence
kw:coordination
kw:copyright
kw:corruption
kw:cors
kw:cost
kw:coverage
kw:coveralls
kw:coveralls.io
kw:cpu-watcher
kw:cpyext
kw:crash
kw:crawler
kw:crawlers
kw:create-container
kw:cruft
kw:crypto
kw:cryptography
kw:cryptography-lib
kw:cryptopp
kw:csp
kw:curl
kw:cutoff-date
kw:cycle
kw:cygwin
kw:d3
kw:daemon
kw:darcs
kw:darcsver
kw:database
kw:dataloss
kw:db
kw:dead-code
kw:deb
kw:debian
kw:debug
kw:deep-check
kw:defaults
kw:deferred
kw:delete
kw:deletion
kw:denial-of-service
kw:dependency
kw:deployment
kw:deprecation
kw:desert-island
kw:desert-island-build
kw:design
kw:design-review-needed
kw:detection
kw:dev-infrastructure
kw:devpay
kw:directory
kw:directory-page
kw:dirnode
kw:dirnodes
kw:disconnect
kw:discovery
kw:disk
kw:disk-backend
kw:distribute
kw:distutils
kw:dns
kw:do_http
kw:doc-needed
kw:docker
kw:docs
kw:docs-needed
kw:dokan
kw:dos
kw:download
kw:downloader
kw:dragonfly
kw:drop-upload
kw:duplicity
kw:dusty
kw:earth-dragon
kw:easy
kw:ec2
kw:ecdsa
kw:ed25519
kw:egg-needed
kw:eggs
kw:eliot
kw:email
kw:empty
kw:encoding
kw:endpoint
kw:enterprise
kw:enum34
kw:environment
kw:erasure
kw:erasure-coding
kw:error
kw:escaping
kw:etag
kw:etch
kw:evangelism
kw:eventual
kw:example
kw:excess-authority
kw:exec
kw:exocet
kw:expiration
kw:extensibility
kw:extension
kw:failure
kw:fedora
kw:ffp
kw:fhs
kw:figleaf
kw:file
kw:file-descriptor
kw:filename
kw:filesystem
kw:fileutil
kw:fips
kw:firewall
kw:first
kw:floatingpoint
kw:flog
kw:foolscap
kw:forward-compatibility
kw:forward-secrecy
kw:forwarding
kw:free
kw:freebsd
kw:frontend
kw:fsevents
kw:ftp
kw:ftpd
kw:full
kw:furl
kw:fuse
kw:garbage
kw:garbage-collection
kw:gateway
kw:gatherer
kw:gc
kw:gcc
kw:gentoo
kw:get
kw:git
kw:git-annex
kw:github
kw:glacier
kw:globalcaps
kw:glossary
kw:google-cloud-storage
kw:google-drive-backend
kw:gossip
kw:governance
kw:grid
kw:grid-manager
kw:gridid
kw:gridsync
kw:grsec
kw:gsoc
kw:gvfs
kw:hackfest
kw:hacktahoe
kw:hang
kw:hardlink
kw:heartbleed
kw:heisenbug
kw:help
kw:helper
kw:hint
kw:hooks
kw:how
kw:how-to
kw:howto
kw:hp
kw:hp-cloud
kw:html
kw:http
kw:https
kw:i18n
kw:i2p
kw:i2p-collab
kw:illustration
kw:image
kw:immutable
kw:impressions
kw:incentives
kw:incident
kw:init
kw:inlineCallbacks
kw:inotify
kw:install
kw:installer
kw:integration
kw:integration-test
kw:integrity
kw:interactive
kw:interface
kw:interfaces
kw:interoperability
kw:interstellar-exploration
kw:introducer
kw:introduction
kw:iphone
kw:ipkg
kw:iputil
kw:ipv6
kw:irc
kw:jail
kw:javascript
kw:joke
kw:jquery
kw:json
kw:jsui
kw:junk
kw:key-value-store
kw:kfreebsd
kw:known-issue
kw:konqueror
kw:kpreid
kw:kvm
kw:l10n
kw:lae
kw:large
kw:latency
kw:leak
kw:leasedb
kw:leases
kw:libgmp
kw:license
kw:licenss
kw:linecount
kw:link
kw:linux
kw:lit
kw:localhost
kw:location
kw:locking
kw:logging
kw:logo
kw:loopback
kw:lucid
kw:mac
kw:macintosh
kw:magic-folder
kw:manhole
kw:manifest
kw:manual-test-needed
kw:map
kw:mapupdate
kw:max_space
kw:mdmf
kw:memcheck
kw:memory
kw:memory-leak
kw:mesh
kw:metadata
kw:meter
kw:migration
kw:mime
kw:mingw
kw:minimal
kw:misc
kw:miscapture
kw:mlp
kw:mock
kw:more-info-needed
kw:mountain-lion
kw:move
kw:multi-users
kw:multiple
kw:multiuser-gateway
kw:munin
kw:music
kw:mutability
kw:mutable
kw:mystery
kw:names
kw:naming
kw:nas
kw:navigation
kw:needs-review
kw:needs-spawn
kw:netbsd
kw:network
kw:nevow
kw:new-user
kw:newcaps
kw:news
kw:news-done
kw:news-needed
kw:newsletter
kw:newurls
kw:nfc
kw:nginx
kw:nixos
kw:no-clobber
kw:node
kw:node-url
kw:notification
kw:notifyOnDisconnect
kw:nsa310
kw:nsa320
kw:nsa325
kw:numpy
kw:objects
kw:old
kw:openbsd
kw:openitp-packaging
kw:openssl
kw:openstack
kw:opensuse
kw:operation-helpers
kw:operational
kw:operations
kw:ophandle
kw:ophandles
kw:ops
kw:optimization
kw:optional
kw:options
kw:organization
kw:os
kw:os.abort
kw:ostrom
kw:osx
kw:osxfuse
kw:otf-magic-folder-objective1
kw:otf-magic-folder-objective2
kw:otf-magic-folder-objective3
kw:otf-magic-folder-objective4
kw:otf-magic-folder-objective5
kw:otf-magic-folder-objective6
kw:p2p
kw:packaging
kw:partial
kw:password
kw:path
kw:paths
kw:pause
kw:peer-selection
kw:performance
kw:permalink
kw:permissions
kw:persistence
kw:phone
kw:pickle
kw:pip
kw:pipermail
kw:pkg_resources
kw:placement
kw:planning
kw:policy
kw:port
kw:portability
kw:portal
kw:posthook
kw:pratchett
kw:preformance
kw:preservation
kw:privacy
kw:process
kw:profile
kw:profiling
kw:progress
kw:proxy
kw:publish
kw:pyOpenSSL
kw:pyasn1
kw:pycparser
kw:pycrypto
kw:pycrypto-lib
kw:pycryptopp
kw:pyfilesystem
kw:pyflakes
kw:pylint
kw:pypi
kw:pypy
kw:pysqlite
kw:python
kw:python3
kw:pythonpath
kw:pyutil
kw:pywin32
kw:quickstart
kw:quiet
kw:quotas
kw:quoting
kw:raic
kw:rainhill
kw:random
kw:random-access
kw:range
kw:raspberry-pi
kw:reactor
kw:readonly
kw:rebalancing
kw:recovery
kw:recursive
kw:redhat
kw:redirect
kw:redressing
kw:refactor
kw:referer
kw:referrer
kw:regression
kw:rekey
kw:relay
kw:release
kw:release-blocker
kw:reliability
kw:relnotes
kw:remote
kw:removable
kw:removable-disk
kw:rename
kw:renew
kw:repair
kw:replace
kw:report
kw:repository
kw:research
kw:reserved_space
kw:response-needed
kw:response-time
kw:restore
kw:retrieve
kw:retry
kw:review
kw:review-needed
kw:reviewed
kw:revocation
kw:roadmap
kw:rollback
kw:rpm
kw:rsa
kw:rss
kw:rst
kw:rsync
kw:rusty
kw:s3
kw:s3-backend
kw:s3-frontend
kw:s4
kw:same-origin
kw:sandbox
kw:scalability
kw:scaling
kw:scheduling
kw:schema
kw:scheme
kw:scp
kw:scripts
kw:sdist
kw:sdmf
kw:security
kw:self-contained
kw:server
kw:servermap
kw:servers-of-happiness
kw:service
kw:setup
kw:setup.py
kw:setup_requires
kw:setuptools
kw:setuptools_darcs
kw:sftp
kw:shared
kw:shareset
kw:shell
kw:signals
kw:simultaneous
kw:six
kw:size
kw:slackware
kw:slashes
kw:smb
kw:sneakernet
kw:snowleopard
kw:socket
kw:solaris
kw:space
kw:space-efficiency
kw:spam
kw:spec
kw:speed
kw:sqlite
kw:ssh
kw:ssh-keygen
kw:sshfs
kw:ssl
kw:stability
kw:standards
kw:start
kw:startup
kw:static
kw:static-analysis
kw:statistics
kw:stats
kw:stats_gatherer
kw:status
kw:stdeb
kw:storage
kw:streaming
kw:strports
kw:style
kw:stylesheet
kw:subprocess
kw:sumo
kw:survey
kw:svg
kw:symlink
kw:synchronous
kw:tac
kw:tahoe-*
kw:tahoe-add-alias
kw:tahoe-admin
kw:tahoe-archive
kw:tahoe-backup
kw:tahoe-check
kw:tahoe-cp
kw:tahoe-create-alias
kw:tahoe-create-introducer
kw:tahoe-debug
kw:tahoe-deep-check
kw:tahoe-deepcheck
kw:tahoe-lafs-trac-stream
kw:tahoe-list-aliases
kw:tahoe-ls
kw:tahoe-magic-folder
kw:tahoe-manifest
kw:tahoe-mkdir
kw:tahoe-mount
kw:tahoe-mv
kw:tahoe-put
kw:tahoe-restart
kw:tahoe-rm
kw:tahoe-run
kw:tahoe-start
kw:tahoe-stats
kw:tahoe-unlink
kw:tahoe-webopen
kw:tahoe.css
kw:tahoe_files
kw:tahoewapi
kw:tarball
kw:tarballs
kw:tempfile
kw:templates
kw:terminology
kw:test
kw:test-and-set
kw:test-from-egg
kw:test-needed
kw:testgrid
kw:testing
kw:tests
kw:throttling
kw:ticket999-s3-backend
kw:tiddly
kw:time
kw:timeout
kw:timing
kw:to
kw:to-be-closed-on-2011-08-01
kw:tor
kw:tor-protocol
kw:torsocks
kw:tox
kw:trac
kw:transparency
kw:travis
kw:travis-ci
kw:trial
kw:trickle
kw:trivial
kw:truckee
kw:tub
kw:tub.location
kw:twine
kw:twistd
kw:twistd.log
kw:twisted
kw:twisted-14
kw:twisted-trial
kw:twitter
kw:twn
kw:txaws
kw:type
kw:typeerror
kw:ubuntu
kw:ucwe
kw:ueb
kw:ui
kw:unclean
kw:uncoordinated-writes
kw:undeletable
kw:unfinished-business
kw:unhandled-error
kw:unhappy
kw:unicode
kw:unit
kw:unix
kw:unlink
kw:update
kw:upgrade
kw:upload
kw:upload-helper
kw:uri
kw:url
kw:usability
kw:use-case
kw:utf-8
kw:util
kw:uwsgi
kw:ux
kw:validation
kw:variables
kw:vdrive
kw:verify
kw:verlib
kw:version
kw:versioning
kw:versions
kw:video
kw:virtualbox
kw:virtualenv
kw:vista
kw:visualization
kw:visualizer
kw:vm
kw:volunteergrid2
kw:volunteers
kw:vpn
kw:wapi
kw:warners-opinion-needed
kw:warning
kw:weapi
kw:web
kw:web.port
kw:webapi
kw:webdav
kw:webdrive
kw:webport
kw:websec
kw:website
kw:websocket
kw:welcome
kw:welcome-page
kw:welcomepage
kw:wiki
kw:win32
kw:win64
kw:windows
kw:windows-related
kw:winscp
kw:workaround
kw:world-domination
kw:wrapper
kw:write-enabler
kw:wui
kw:x86
kw:x86-64
kw:xhtml
kw:xml
kw:xss
kw:zbase32
kw:zetuptoolz
kw:zfec
kw:zookos-opinion-needed
kw:zope
kw:zope.interface
p/blocker
p/critical
p/major
p/minor
p/normal
p/supercritical
p/trivial
r/cannot reproduce
r/duplicate
r/fixed
r/invalid
r/somebody else's problem
r/was already fixed
r/wontfix
r/worksforme
t/defect
t/enhancement
t/task
v/0.2.0
v/0.3.0
v/0.4.0
v/0.5.0
v/0.5.1
v/0.6.0
v/0.6.1
v/0.7.0
v/0.8.0
v/0.9.0
v/1.0.0
v/1.1.0
v/1.10.0
v/1.10.1
v/1.10.2
v/1.10a2
v/1.11.0
v/1.12.0
v/1.12.1
v/1.13.0
v/1.14.0
v/1.15.0
v/1.15.1
v/1.2.0
v/1.3.0
v/1.4.1
v/1.5.0
v/1.6.0
v/1.6.1
v/1.7.0
v/1.7.1
v/1.7β
v/1.8.0
v/1.8.1
v/1.8.2
v/1.8.3
v/1.8β
v/1.9.0
v/1.9.0-s3branch
v/1.9.0a1
v/1.9.0a2
v/1.9.0b1
v/1.9.1
v/1.9.2
v/1.9.2a1
v/cloud-branch
v/unknown
No milestone
No project
No assignees
4 participants
Notifications
Due date
The due date is invalid or out of range. Please use the format "yyyy-mm-dd".

No due date set.

Dependencies

No dependencies set.

Reference: tahoe-lafs/trac#1274
No description provided.