Migrate all 92 Python files in qa/ from Python 2 to Python 3: - Update shebangs from python2 to python3 - Replace print statements with print() calls - Fix imports (http.client, urllib.parse, queue, io, functools) - Convert xrange→range, 0L→0, long→int, cmp→key functions - Fix except/as syntax, bytes/str handling, integer division - Use relative imports in test_framework/ package Add qa/run-tests.sh: multi-stage test runner (1183 lines) - Stage 1: Build/binary verification - Stage 2: Security hardening (PIE, NX, RELRO, canary, FORTIFY) - Stage 3-4: Boost/Google test binaries - Stage 5: Library tests (secp256k1, univalue) - Stage 6: RandomX validation (live chain mining + block checks) - Stage 7: RPC integration (skipped: regtest mining incompatible) - Stage 8: Source code invariant checks - Stage 8b: DragonX-specific source checks (11 tests) - Flags: --chain=dragonx, --live-dragonx, --save-release, --quick - Timestamped reports with release archiving to qa/release-reports/ Add qa/clean-test-reports.sh for housekeeping (--keep=N, --dry-run) Fix test build infrastructure: - src/Makefile.gtest.include: fix zcash_gtest→hush_gtest refs, remove 17 stale source files, add LIBZCASH/LIBHUSH/LIBRANDOMX - src/Makefile.test.include: remove stale sources, deduplicate LDADD/CXXFLAGS, add missing libraries - src/gtest/test_checkblock.cpp: add height param to ContextualCheckBlock - src/test/test_bitcoin.cpp: remove JoinSplitTestingSetup (dead code) Add qa/test-reports/ to .gitignore for transient output.
102 lines
4.5 KiB
Python
Executable File
102 lines
4.5 KiB
Python
Executable File
#!/usr/bin/env python3
|
|
# Copyright (c) 2016-2024 The Hush developers
|
|
# Copyright (c) 2014 The Bitcoin Core developers
|
|
# Distributed under the GPLv3 software license, see the accompanying
|
|
# file COPYING or https://www.gnu.org/licenses/gpl-3.0.en.html
|
|
|
|
# Test rpc http basics
|
|
|
|
from test_framework.test_framework import BitcoinTestFramework
|
|
from test_framework.util import assert_equal, start_nodes
|
|
|
|
import base64
|
|
|
|
try:
|
|
import http.client as httplib
|
|
except ImportError:
|
|
import http.client
|
|
try:
|
|
import urllib.parse as urlparse
|
|
except ImportError:
|
|
import urllib.parse
|
|
|
|
class HTTPBasicsTest (BitcoinTestFramework):
|
|
def setup_nodes(self):
|
|
return start_nodes(4, self.options.tmpdir)
|
|
|
|
def run_test(self):
|
|
|
|
#################################################
|
|
# lowlevel check for http persistent connection #
|
|
#################################################
|
|
url = urllib.parse.urlparse(self.nodes[0].url)
|
|
authpair = url.username + ':' + url.password
|
|
headers = {"Authorization": "Basic " + base64.b64encode(authpair)}
|
|
|
|
conn = http.client.HTTPConnection(url.hostname, url.port)
|
|
conn.connect()
|
|
conn.request('POST', '/', '{"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('POST', '/', '{"method": "getchaintips"}', headers)
|
|
out2 = conn.getresponse().read()
|
|
assert_equal('"error":null' in out2, 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 = http.client.HTTPConnection(url.hostname, url.port)
|
|
conn.connect()
|
|
conn.request('POST', '/', '{"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('POST', '/', '{"method": "getchaintips"}', headers)
|
|
out2 = conn.getresponse().read()
|
|
assert_equal('"error":null' in out2, 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 = http.client.HTTPConnection(url.hostname, url.port)
|
|
conn.connect()
|
|
conn.request('POST', '/', '{"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
|
|
|
|
# node1 (2nd node) is running with disabled keep-alive option
|
|
urlNode1 = urllib.parse.urlparse(self.nodes[1].url)
|
|
authpair = urlNode1.username + ':' + urlNode1.password
|
|
headers = {"Authorization": "Basic " + base64.b64encode(authpair)}
|
|
|
|
conn = http.client.HTTPConnection(urlNode1.hostname, urlNode1.port)
|
|
conn.connect()
|
|
conn.request('POST', '/', '{"method": "getbestblockhash"}', headers)
|
|
out1 = conn.getresponse().read()
|
|
assert_equal('"error":null' in out1, True)
|
|
|
|
# node2 (third node) is running with standard keep-alive parameters which means keep-alive is on
|
|
urlNode2 = urllib.parse.urlparse(self.nodes[2].url)
|
|
authpair = urlNode2.username + ':' + urlNode2.password
|
|
headers = {"Authorization": "Basic " + base64.b64encode(authpair)}
|
|
|
|
conn = http.client.HTTPConnection(urlNode2.hostname, urlNode2.port)
|
|
conn.connect()
|
|
conn.request('POST', '/', '{"method": "getbestblockhash"}', headers)
|
|
out1 = conn.getresponse().read()
|
|
assert_equal('"error":null' in out1, True)
|
|
assert_equal(conn.sock!=None, True) # connection must be closed because hushd should use keep-alive by default
|
|
|
|
if __name__ == '__main__':
|
|
HTTPBasicsTest().main()
|