Browse Source
11d7a7d
[RPC] add rpc-test for http keep-alive (persistent connections) (Jonas Schnelli)
0.10
Wladimir J. van der Laan
10 years ago
2 changed files with 77 additions and 0 deletions
@ -0,0 +1,76 @@
@@ -0,0 +1,76 @@
|
||||
#!/usr/bin/env python2 |
||||
# Copyright (c) 2014 The Bitcoin Core developers |
||||
# Distributed under the MIT software license, see the accompanying |
||||
# file COPYING or http://www.opensource.org/licenses/mit-license.php. |
||||
|
||||
# |
||||
# Test REST interface |
||||
# |
||||
|
||||
from test_framework import BitcoinTestFramework |
||||
from util import * |
||||
import base64 |
||||
|
||||
try: |
||||
import http.client as httplib |
||||
except ImportError: |
||||
import httplib |
||||
try: |
||||
import urllib.parse as urlparse |
||||
except ImportError: |
||||
import urlparse |
||||
|
||||
class RESTTest (BitcoinTestFramework): |
||||
def run_test(self): |
||||
|
||||
################################################# |
||||
# lowlevel check for http persistent connection # |
||||
################################################# |
||||
url = urlparse.urlparse(self.nodes[0].url) |
||||
authpair = url.username + ':' + url.password |
||||
headers = {"Authorization": "Basic " + base64.b64encode(authpair)} |
||||
|
||||
conn = httplib.HTTPConnection(url.hostname, url.port) |
||||
conn.connect() |
||||
conn.request('GET', '/', '{"method": "getbestblockhash"}', headers) |
||||
out1 = conn.getresponse().read(); |
||||
assert_equal('"error":null' in out1, True) |
||||
assert_equal(conn.sock!=None, True) #according to http/1.1 connection must still be open! |
||||
|
||||
#send 2nd request without closing connection |
||||
conn.request('GET', '/', '{"method": "getchaintips"}', headers) |
||||
out2 = conn.getresponse().read(); |
||||
assert_equal('"error":null' in out1, True) #must also response with a correct json-rpc message |
||||
assert_equal(conn.sock!=None, True) #according to http/1.1 connection must still be open! |
||||
conn.close() |
||||
|
||||
#same should be if we add keep-alive because this should be the std. behaviour |
||||
headers = {"Authorization": "Basic " + base64.b64encode(authpair), "Connection": "keep-alive"} |
||||
|
||||
conn = httplib.HTTPConnection(url.hostname, url.port) |
||||
conn.connect() |
||||
conn.request('GET', '/', '{"method": "getbestblockhash"}', headers) |
||||
out1 = conn.getresponse().read(); |
||||
assert_equal('"error":null' in out1, True) |
||||
assert_equal(conn.sock!=None, True) #according to http/1.1 connection must still be open! |
||||
|
||||
#send 2nd request without closing connection |
||||
conn.request('GET', '/', '{"method": "getchaintips"}', headers) |
||||
out2 = conn.getresponse().read(); |
||||
assert_equal('"error":null' in out1, True) #must also response with a correct json-rpc message |
||||
assert_equal(conn.sock!=None, True) #according to http/1.1 connection must still be open! |
||||
conn.close() |
||||
|
||||
#now do the same with "Connection: close" |
||||
headers = {"Authorization": "Basic " + base64.b64encode(authpair), "Connection":"close"} |
||||
|
||||
conn = httplib.HTTPConnection(url.hostname, url.port) |
||||
conn.connect() |
||||
conn.request('GET', '/', '{"method": "getbestblockhash"}', headers) |
||||
out1 = conn.getresponse().read(); |
||||
assert_equal('"error":null' in out1, True) |
||||
assert_equal(conn.sock!=None, False) #now the connection must be closed after the response |
||||
|
||||
|
||||
if __name__ == '__main__': |
||||
RESTTest ().main () |
Loading…
Reference in new issue