#3368 closed defect (fixed)

(apparently) get_version called via Foolscap now fails with a Violation

Reported by: exarkun Owned by: GitHub <noreply@…>
Priority: normal Milestone: Support Python 3
Component: code Version: n/a
Keywords: Cc:
Launchpad Bug:

Description

If I create a client node and point it at an introducer node and then I create a storage node and point it at the same introducer node, the storage node logs this to stdout:

2020-08-04T15:05:05-0400 [twisted.internet.defer#critical] Unhandled error in Deferred:
2020-08-04T15:05:05-0400 [twisted.internet.defer#critical]
        Traceback (most recent call last):
          File "/home/exarkun/VirtualEnvs/tahoe-lafs/lib/python2.7/site-packages/foolscap/slicers/root.py", line 107, in send                                                                
            d.callback(None)
          File "/home/exarkun/VirtualEnvs/tahoe-lafs/lib/python2.7/site-packages/twisted/internet/defer.py", line 460, in callback                                                           
            self._startRunCallbacks(result)
          File "/home/exarkun/VirtualEnvs/tahoe-lafs/lib/python2.7/site-packages/twisted/internet/defer.py", line 568, in _startRunCallbacks                                                 
            self._runCallbacks()
          File "/home/exarkun/VirtualEnvs/tahoe-lafs/lib/python2.7/site-packages/twisted/internet/defer.py", line 654, in _runCallbacks                                                      
            current.result = callback(current.result, *args, **kw)
        --- <exception caught here> ---
          File "/home/exarkun/VirtualEnvs/tahoe-lafs/lib/python2.7/site-packages/foolscap/banana.py", line 215, in produce                                                                   
            slicer = self.newSlicerFor(obj)
          File "/home/exarkun/VirtualEnvs/tahoe-lafs/lib/python2.7/site-packages/foolscap/banana.py", line 314, in newSlicerFor                                                              
            return topSlicer.slicerForObject(obj)
          File "/home/exarkun/VirtualEnvs/tahoe-lafs/lib/python2.7/site-packages/foolscap/slicer.py", line 48, in slicerForObject                                                            
            return self.parent.slicerForObject(obj)
          File "/home/exarkun/VirtualEnvs/tahoe-lafs/lib/python2.7/site-packages/foolscap/slicer.py", line 48, in slicerForObject                                                            
            return self.parent.slicerForObject(obj)
          File "/home/exarkun/VirtualEnvs/tahoe-lafs/lib/python2.7/site-packages/foolscap/slicer.py", line 126, in slicerForObject                                                           
            return self.parent.slicerForObject(obj)
          File "/home/exarkun/VirtualEnvs/tahoe-lafs/lib/python2.7/site-packages/foolscap/slicers/root.py", line 66, in slicerForObject                                                      
            raise Violation("cannot serialize %s (%s)" % (obj, name))
        foolscap.tokens.Violation: Violation (<RootSlicer>.<answer-2-to-get_version>.??.??): ("cannot serialize 208234104320 (<class 'future.types.newint.newint'>)",)                       

208234104320 is somewhat close to the amount of available space on my local disk so perhaps it is the value for available-space in the get_version response.

Also, in the flog:

15:05:05.754 L23 []#96 an outbound callRemote (that we [yn5r] sent to someone else [iyyl]) failed on the far end                                                                              
15:05:05.754 L10 []#97  reqID=2, rref=<RemoteReference at 0x7fdd4a603d50 [pb://iyylzcj72xlihtzgte2wc6kwe7ly5dyy@tcp:127.1:42961/cgakoaryq3lhkzvv3wmwpi64i4aokv4e]>, methname=RIStorageServer.t
ahoe.allmydata.com.get_version             
15:05:05.754 L10 []#98  the REMOTE failure was:                                                                                                                                              
 FAILURE:                                                                                                                                                                                     
 [CopiedFailure instance: Traceback from remote host -- Traceback (most recent call last):
   File "/home/exarkun/VirtualEnvs/tahoe-lafs/lib/python2.7/site-packages/twisted/protocols/tls.py", line 295, in _flushReceiveBIO
     ProtocolWrapper.dataReceived(self, bytes)                   
   File "/home/exarkun/VirtualEnvs/tahoe-lafs/lib/python2.7/site-packages/twisted/protocols/policies.py", line 120, in dataReceived
     self.wrappedProtocol.dataReceived(data)                                                                                                                                                 
   File "/home/exarkun/VirtualEnvs/tahoe-lafs/lib/python2.7/site-packages/twisted/internet/endpoints.py", line 132, in dataReceived                                                           
     return self._wrappedProtocol.dataReceived(data)                                                                                                                                         
   File "/home/exarkun/VirtualEnvs/tahoe-lafs/lib/python2.7/site-packages/foolscap/banana.py", line 639, in dataReceived                                                                     
     self.handleData(chunk)                                                                                                                                                                  
 --- <exception caught here> ---                                                                                                                                                             
   File "/home/exarkun/VirtualEnvs/tahoe-lafs/lib/python2.7/site-packages/foolscap/banana.py", line 892, in handleData                                                                       
     raise Violation("ABORT received")                                                                                                                                                       
 foolscap.tokens.Violation: Violation (<RootUnslicer>.Answer(req=2).{}[http://allmydata.org/tahoe/protocols/storage/v1].{}[available-space]): ('ABORT received',)                            
 ]                                                                                                                                                                                            

which seems to support available-space as the issue.

Change History (4)

comment:1 Changed at 2020-08-04T19:48:33Z by exarkun

newint creeps in when parse_abbreviated_size is used to get an integer value from the configuration string.

Maybe parse_abbreviated_size shouldn't let newint escape, it should smash the value down to an int?

comment:2 Changed at 2020-08-05T15:55:00Z by itamarst

  • Keywords review added

comment:3 Changed at 2020-08-06T14:10:17Z by exarkun

  • Keywords review removed

comment:4 Changed at 2020-08-06T21:02:07Z by GitHub <noreply@…>

  • Owner set to GitHub <noreply@…>
  • Resolution set to fixed
  • Status changed from new to closed

In 596cf09/trunk:

Merge pull request #763 from tahoe-lafs/3368.leaky-newints

Fixes ticket:3368

Get rid of leaky newints.

Note: See TracTickets for help on using tickets.