0stderr:
1Traceback (most recent call last):
2 File "/home/travis/build/bitcoin/bitcoin/build/bitcoin-x86_64-unknown-linux-gnu/test/functional/test_framework/authproxy.py", line 107, in _request
3 return self._get_response()
4 File "/home/travis/build/bitcoin/bitcoin/build/bitcoin-x86_64-unknown-linux-gnu/test/functional/test_framework/authproxy.py", line 153, in _get_response
5 http_response = self.__conn.getresponse()
6 File "/usr/lib/python3.4/http/client.py", line 1208, in getresponse
7 response.begin()
8 File "/usr/lib/python3.4/http/client.py", line 380, in begin
9 version, status, reason = self._read_status()
10 File "/usr/lib/python3.4/http/client.py", line 350, in _read_status
11 raise BadStatusLine(line)
12http.client.BadStatusLine: ''
13During handling of the above exception, another exception occurred:
14Traceback (most recent call last):
15 File "/home/travis/build/bitcoin/bitcoin/build/bitcoin-x86_64-unknown-linux-gnu/test/functional/importprunedfunds.py", line 114, in <module>
16 ImportPrunedFundsTest().main()
17 File "/home/travis/build/bitcoin/bitcoin/build/bitcoin-x86_64-unknown-linux-gnu/test/functional/test_framework/test_framework.py", line 141, in main
18 self.stop_nodes()
19 File "/home/travis/build/bitcoin/bitcoin/build/bitcoin-x86_64-unknown-linux-gnu/test/functional/test_framework/test_framework.py", line 258, in stop_nodes
20 node.stop_node()
21 File "/home/travis/build/bitcoin/bitcoin/build/bitcoin-x86_64-unknown-linux-gnu/test/functional/test_framework/test_node.py", line 124, in stop_node
22 self.stop()
23 File "/home/travis/build/bitcoin/bitcoin/build/bitcoin-x86_64-unknown-linux-gnu/test/functional/test_framework/coverage.py", line 47, in __call__
24 return_val = self.auth_service_proxy_instance.__call__(*args, **kwargs)
25 File "/home/travis/build/bitcoin/bitcoin/build/bitcoin-x86_64-unknown-linux-gnu/test/functional/test_framework/authproxy.py", line 136, in __call__
26 response = self._request('POST', self.__url.path, postdata.encode('utf-8'))
27 File "/home/travis/build/bitcoin/bitcoin/build/bitcoin-x86_64-unknown-linux-gnu/test/functional/test_framework/authproxy.py", line 111, in _request
28 self.__conn.request(method, path, postdata, headers)
29 File "/usr/lib/python3.4/http/client.py", line 1125, in request
30 self._send_request(method, url, body, headers)
31 File "/usr/lib/python3.4/http/client.py", line 1163, in _send_request
32 self.endheaders(body)
33 File "/usr/lib/python3.4/http/client.py", line 1121, in endheaders
34 self._send_output(message_body)
35 File "/usr/lib/python3.4/http/client.py", line 951, in _send_output
36 self.send(msg)
37 File "/usr/lib/python3.4/http/client.py", line 886, in send
38 self.connect()
39 File "/usr/lib/python3.4/http/client.py", line 863, in connect
40 self.timeout, self.source_address)
41 File "/usr/lib/python3.4/socket.py", line 512, in create_connection
42 raise err
43 File "/usr/lib/python3.4/socket.py", line 503, in create_connection
44 sock.connect(sa)
45ConnectionRefusedError: [Errno 111] Connection refused
achow101
commented at 0:45 am on January 12, 2018:
member
I’m also seeing this on my BIP 174 test here: https://travis-ci.org/bitcoin/bitcoin/jobs/327867319. It appears to be happening consistently though, so I’m not sure if that’s a test problem or a Travis problem.
TheBlueMatt
commented at 4:12 pm on January 14, 2018:
member
This is a bug in the python-bitcoinrpc library - I get it all the time locally, something to do with the underlying HTTP request getting closed and not automatically reopened. In my own scripts I generally wrap every call and retry if it falls.
I’m also seeing this on my BIP 174 test here:
https://travis-ci.org/bitcoin/bitcoin/jobs/327867319. It appears to be
happening consistently though, so I’m not sure if that’s a test problem
or a Travis problem.
All the other examples are when the stop RPC is called. authproxy.py has handling for if the RPC call raises a http.client.BadStatusLine because the connection was closed:
It tries to reconnect and send the RPC again. I guess if the stop RPC is successful but causes the connection to be closed before the response is received, then authproxy won’t be able to reconnect and we’ll get the subsequent ConnectionRefusedError.
Shutdown processing was changed here: #11006. I wonder if that’s made this worse. I guess we see it on travis because it’s a timing thing.
@TheBlueMatt - you’re able to reproduce this locally. Can you check whether reverting #11006 improves this for you?
We could fix this by special casing calls to stop, and wrapping them in a try-except (which would check that the process had indeed stopped and then continue).
MarcoFalke
commented at 9:43 pm on January 15, 2018:
member
We could fix this by special casing calls to stop, and wrapping them in a try-except (which would check that the process had indeed stopped and then continue).
Imo, we should properly send the response before cutting the connection and going silent.
TheBlueMatt
commented at 11:38 pm on January 15, 2018:
member
Err, no, I’ve never seen the issue when running our test suite, only when using python-bitcoinrpc locally against a local bitcoind for other stuff.
All the other examples are when the stop RPC is called.
authproxy.py has handling for if the RPC call raises a
http.client.BadStatusLine because the connection was closed:
It tries to reconnect and send the RPC again. I guess if the stop RPC
is successful but causes the connection to be closed before the
response is received, then authproxy won’t be able to reconnect and
we’ll get the subsequent ConnectionRefusedError.
@TheBlueMatt - you’re able to reproduce this locally. Can you check
whether reverting #11006 improves this for you?
We could fix this by special casing calls to stop, and wrapping them
in a try-except (which would check that the process had indeed stopped
and then continue).
In case my assumption is wrong, do you see this exception also for rpcs other than stop?
MarcoFalke
commented at 4:29 pm on January 16, 2018:
member
So I tried running with the depends build (i.e. libevent 2.1.8-stable) and python:3.4.3 from trusty. So all of that should be identical to what travis is running, but I couldn’t reproduce the issue.
Since we print the consolidated logs on failure on travis, someone should copy-paste them here before wiping the travis log. I suspect they might help debug further.
jnewbery
commented at 2:49 pm on May 21, 2018:
member
0test 2018-05-16T22:34:40.352000Z TestFramework (DEBUG): Stop-start node0 with -persistmempool=0. Verify that it doesn't load its mempool.dat file. 1 test 2018-05-16T22:34:40.352000Z TestFramework.node0 (DEBUG): Stopping node
2 node0 2018-05-16T22:34:40.352576Z Received a POST request for/ from 127.0.0.1:32826 3 node0 2018-05-16T22:34:40.352707Z ThreadRPCServer method=stop user=__cookie__
4 node0 2018-05-16T22:34:40.352776Z Interrupting HTTP server
5 node0 2018-05-16T22:34:40.352818Z Interrupting HTTP RPC server
6 node0 2018-05-16T22:34:40.352828Z Interrupting RPC
7 node0 2018-05-16T22:34:40.352845Z Shutdown: In progress... 8 node0 2018-05-16T22:34:40.352861Z opencon thread exit
9 node0 2018-05-16T22:34:40.352867Z Stopping HTTP RPC server
10 node0 2018-05-16T22:34:40.352880Z Unregistering HTTP handler for/ (exactmatch 1)
11 node0 2018-05-16T22:34:40.352894Z addcon thread exit
12 node0 2018-05-16T22:34:40.352903Z Unregistering HTTP handler for/wallet/ (exactmatch 0)
13 node0 2018-05-16T22:34:40.352917Z Stopping RPC
14 test 2018-05-16T22:34:40.353000Z TestFramework (ERROR): Unexpected exception caught during testing
15Traceback (most recent call last):
16File"/home/travis/build/bitcoin/bitcoin/build/bitcoin-x86_64-unknown-linux-gnu/test/functional/test_framework/authproxy.py", line 107, in _request
17return self._get_response()
18File"/home/travis/build/bitcoin/bitcoin/build/bitcoin-x86_64-unknown-linux-gnu/test/functional/test_framework/authproxy.py", line 153, in _get_response
19 http_response = self.__conn.getresponse()
20File"/usr/lib/python3.4/http/client.py", line 1208, in getresponse
21 response.begin()
22File"/usr/lib/python3.4/http/client.py", line 380, in begin
23 version, status, reason = self._read_status()
24File"/usr/lib/python3.4/http/client.py", line 350, in _read_status
25 raise BadStatusLine(line)
26http.client.BadStatusLine: ''27During handling of the above exception, another exception occurred:
28Traceback (most recent call last):
29File"/home/travis/build/bitcoin/bitcoin/build/bitcoin-x86_64-unknown-linux-gnu/test/functional/test_framework/test_framework.py", line 152, in main
30 self.run_test()
31File"/home/travis/build/bitcoin/bitcoin/build/bitcoin-x86_64-unknown-linux-gnu/test/functional/mempool_persist.py", line 85, in run_test
32 self.stop_nodes()
33File"/home/travis/build/bitcoin/bitcoin/build/bitcoin-x86_64-unknown-linux-gnu/test/functional/test_framework/test_framework.py", line 301, in stop_nodes
34 node.stop_node()
35File"/home/travis/build/bitcoin/bitcoin/build/bitcoin-x86_64-unknown-linux-gnu/test/functional/test_framework/test_node.py", line 196, in stop_node
36 self.stop()
37File"/home/travis/build/bitcoin/bitcoin/build/bitcoin-x86_64-unknown-linux-gnu/test/functional/test_framework/coverage.py", line 47, in __call__
38 return_val = self.auth_service_proxy_instance.__call__(*args, **kwargs)
39File"/home/travis/build/bitcoin/bitcoin/build/bitcoin-x86_64-unknown-linux-gnu/test/functional/test_framework/authproxy.py", line 136, in __call__
40 response = self._request('POST', self.__url.path, postdata.encode('utf-8'))
41File"/home/travis/build/bitcoin/bitcoin/build/bitcoin-x86_64-unknown-linux-gnu/test/functional/test_framework/authproxy.py", line 111, in _request
42 self.__conn.request(method, path, postdata, headers)
43File"/usr/lib/python3.4/http/client.py", line 1125, in request
44 self._send_request(method, url, body, headers)
45File"/usr/lib/python3.4/http/client.py", line 1163, in _send_request
46 self.endheaders(body)
47File"/usr/lib/python3.4/http/client.py", line 1121, in endheaders
48 self._send_output(message_body)
49File"/usr/lib/python3.4/http/client.py", line 951, in _send_output
50 self.send(msg)
51File"/usr/lib/python3.4/http/client.py", line 886, in send
52 self.connect()
53File"/usr/lib/python3.4/http/client.py", line 863, in connect
54 self.timeout, self.source_address)
55File"/usr/lib/python3.4/socket.py", line 512, in create_connection
56 raise err
57File"/usr/lib/python3.4/socket.py", line 503, in create_connection
58 sock.connect(sa)
59ConnectionRefusedError: [Errno 111] Connection refused
60 node0 2018-05-16T22:34:40.353006Z RPC stopped.61 node0 2018-05-16T22:34:40.353022Z Stopping HTTP server
62 node0 2018-05-16T22:34:40.353078Z Waiting for HTTP worker threads to exit
63 node0 2018-05-16T22:34:40.353136Z msghand thread exit
64 node0 2018-05-16T22:34:40.353169Z Waiting for HTTP event thread to exit
65 node0 2018-05-16T22:34:40.353213Z Exited http event loop
66 node0 2018-05-16T22:34:40.353323Z Stopped HTTP server
67 node0 2018-05-16T22:34:40.353351Z BerkeleyEnvironment::Flush: Flush(false)
68 node0 2018-05-16T22:34:40.353368Z BerkeleyEnvironment::Flush: Flushing wallet.dat (refcount =0)...69 node0 2018-05-16T22:34:40.353469Z BerkeleyEnvironment::Flush: wallet.dat checkpoint
70 node0 2018-05-16T22:34:40.353714Z net thread exit
71 node0 2018-05-16T22:34:40.354198Z BerkeleyEnvironment::Flush: wallet.dat detach
72 node0 2018-05-16T22:34:40.355314Z BerkeleyEnvironment::Flush: wallet.dat closed
73 node0 2018-05-16T22:34:40.355334Z BerkeleyEnvironment::Flush: Flush(false) took 2ms
74 node0 2018-05-16T22:34:40.358379Z Flushed 0 addresses to peers.dat 3ms
75 node0 2018-05-16T22:34:40.358545Z scheduler thread interrupt
76 node0 2018-05-16T22:34:40.361186Z Dumped mempool: 1.8e-05s to copy, 0.002403s to dump
77 node0 2018-05-16T22:34:40.361215Z Recorded 5 unconfirmed txs from mempool in1.5e-05s
78 test 2018-05-16T22:34:40.362000Z TestFramework (INFO): Stopping nodes
79 test 2018-05-16T22:34:40.362000Z TestFramework.node0 (DEBUG): Stopping node
80 test 2018-05-16T22:34:40.363000Z TestFramework.node0 (ERROR): Unable to stop node.81Traceback (most recent call last):
82File"/home/travis/build/bitcoin/bitcoin/build/bitcoin-x86_64-unknown-linux-gnu/test/functional/test_framework/test_node.py", line 196, in stop_node
83 self.stop()
84File"/home/travis/build/bitcoin/bitcoin/build/bitcoin-x86_64-unknown-linux-gnu/test/functional/test_framework/coverage.py", line 47, in __call__
85 return_val = self.auth_service_proxy_instance.__call__(*args, **kwargs)
86File"/home/travis/build/bitcoin/bitcoin/build/bitcoin-x86_64-unknown-linux-gnu/test/functional/test_framework/authproxy.py", line 136, in __call__
87 response = self._request('POST', self.__url.path, postdata.encode('utf-8'))
88File"/home/travis/build/bitcoin/bitcoin/build/bitcoin-x86_64-unknown-linux-gnu/test/functional/test_framework/authproxy.py", line 106, in _request
89 self.__conn.request(method, path, postdata, headers)
90File"/usr/lib/python3.4/http/client.py", line 1125, in request
91 self._send_request(method, url, body, headers)
92File"/usr/lib/python3.4/http/client.py", line 1153, in _send_request
93 self.putrequest(method, url, **skips)
94File"/usr/lib/python3.4/http/client.py", line 993, in putrequest
95 raise CannotSendRequest(self.__state)
96http.client.CannotSendRequest: Request-sent
97 test 2018-05-16T22:34:40.363000Z TestFramework.node1 (DEBUG): Stopping node
98 test 2018-05-16T22:34:40.364000Z TestFramework.node2 (DEBUG): Stopping node
MarcoFalke
commented at 3:08 pm on May 21, 2018:
member
@jnewbery I’d suggest to revisit this issue report after #13215, which runs the functional tests through docker exec on a bionic container.
Bionic uses python3.6 and tests still failing with this error would rule out a bug that is only present in python3.4
MarcoFalke
commented at 5:55 pm on June 3, 2018:
member
I believe the exception on python 3.6 is http.client.RemoteDisconnected: Remote end closed connection without response. So this is likely not an issue with travis or python 3.4.
MarcoFalke renamed this:
[qa] Tests on travis occasionally raise http.client.BadStatusLine: ''
[qa] Tests occasionally raise http.client.RemoteDisconnected or BadStatusLine
on Jun 3, 2018
laanwj
commented at 1:59 pm on June 4, 2018:
member
I think this is caused by a race during shutdown of the http server, causing it to not succesfully return the JSON response to stop to the caller.
See also #13211, which more reliably reproduces the issue.
ken2812221
commented at 2:35 pm on June 4, 2018:
contributor
@laanwj So the expected action is waiting for RPC client to get response from RPC server? Even if the client does tend to not get any response. I think the server should close ASAP even when the client does not want to get response.
MarcoFalke
commented at 3:45 pm on June 4, 2018:
member
RPC client to get response from RPC server
Yes, all responses should be sent out unless you sent the corresponding request after the stop
jnewbery
commented at 3:59 pm on June 4, 2018:
member
Do people consider it a bug that bitcoind won’t always respond to a stop call (and presumably an encryptwallet call) before shutting down?
If so, we should fix that bug in bitcoind.
If not, we can fix the test failures by adding special casing for calls to stop and encryptwallet so that the test framework handles not receiving a response.
laanwj
commented at 5:40 pm on June 4, 2018:
member
Do people consider it a bug that bitcoind won’t always respond to a stop call (and presumably an encryptwallet call) before shutting down?
It was always considered a bug, at least.
So not regarding it as a bug is a change of behavior.
I’m also not sure how bitcoin-cli copes with this.
MarcoFalke
commented at 6:11 pm on June 4, 2018:
member
If this is not a bug, the documentation on help stop should clearly state that the remote might disconnect without sending a reply.
laanwj closed this
on Dec 6, 2018
laanwj referenced this in commit
a88bd3186d
on Dec 6, 2018
codablock referenced this in commit
835636d9b0
on Oct 14, 2019
codablock referenced this in commit
fefe07003b
on Oct 14, 2019
barrystyle referenced this in commit
32ea3cc4ef
on Jan 22, 2020
TheArbitrator referenced this in commit
7df7b4f53c
on Jun 23, 2021
TheArbitrator referenced this in commit
47b8deeda8
on Jun 25, 2021
Munkybooty referenced this in commit
aa25265942
on Aug 2, 2021
Munkybooty referenced this in commit
2e1fb3f3e8
on Aug 3, 2021
Munkybooty referenced this in commit
21d93c1aea
on Aug 5, 2021
Munkybooty referenced this in commit
36b2f4e0f0
on Aug 5, 2021
Munkybooty referenced this in commit
6db39063f8
on Aug 8, 2021
Munkybooty referenced this in commit
9740c21531
on Aug 11, 2021
Munkybooty referenced this in commit
09963a6af0
on Aug 11, 2021
This is a metadata mirror of the GitHub repository
bitcoin/bitcoin.
This site is not affiliated with GitHub.
Content is generated from a GitHub metadata backup.
generated: 2025-01-23 18:12 UTC
This site is hosted by @0xB10C More mirrored repositories can be found on mirror.b10c.me