mirror of
https://github.com/bitcoin/bitcoin.git
synced 2025-01-25 02:33:24 -03:00
test: use json-rpc 2.0 in all functional tests by default
This commit is contained in:
parent
391843b029
commit
b225295298
1 changed files with 24 additions and 11 deletions
|
@ -26,7 +26,7 @@ ServiceProxy class:
|
||||||
|
|
||||||
- HTTP connections persist for the life of the AuthServiceProxy object
|
- HTTP connections persist for the life of the AuthServiceProxy object
|
||||||
(if server supports HTTP/1.1)
|
(if server supports HTTP/1.1)
|
||||||
- sends protocol 'version', per JSON-RPC 1.1
|
- sends "jsonrpc":"2.0", per JSON-RPC 2.0
|
||||||
- sends proper, incrementing 'id'
|
- sends proper, incrementing 'id'
|
||||||
- sends Basic HTTP authentication headers
|
- sends Basic HTTP authentication headers
|
||||||
- parses all JSON numbers that look like floats as Decimal
|
- parses all JSON numbers that look like floats as Decimal
|
||||||
|
@ -117,7 +117,7 @@ class AuthServiceProxy():
|
||||||
params = dict(args=args, **argsn)
|
params = dict(args=args, **argsn)
|
||||||
else:
|
else:
|
||||||
params = args or argsn
|
params = args or argsn
|
||||||
return {'version': '1.1',
|
return {'jsonrpc': '2.0',
|
||||||
'method': self._service_name,
|
'method': self._service_name,
|
||||||
'params': params,
|
'params': params,
|
||||||
'id': AuthServiceProxy.__id_count}
|
'id': AuthServiceProxy.__id_count}
|
||||||
|
@ -125,15 +125,28 @@ class AuthServiceProxy():
|
||||||
def __call__(self, *args, **argsn):
|
def __call__(self, *args, **argsn):
|
||||||
postdata = json.dumps(self.get_request(*args, **argsn), default=serialization_fallback, ensure_ascii=self.ensure_ascii)
|
postdata = json.dumps(self.get_request(*args, **argsn), default=serialization_fallback, ensure_ascii=self.ensure_ascii)
|
||||||
response, status = self._request('POST', self.__url.path, postdata.encode('utf-8'))
|
response, status = self._request('POST', self.__url.path, postdata.encode('utf-8'))
|
||||||
if response['error'] is not None:
|
# For backwards compatibility tests, accept JSON RPC 1.1 responses
|
||||||
raise JSONRPCException(response['error'], status)
|
if 'jsonrpc' not in response:
|
||||||
elif 'result' not in response:
|
if response['error'] is not None:
|
||||||
raise JSONRPCException({
|
raise JSONRPCException(response['error'], status)
|
||||||
'code': -343, 'message': 'missing JSON-RPC result'}, status)
|
elif 'result' not in response:
|
||||||
elif status != HTTPStatus.OK:
|
raise JSONRPCException({
|
||||||
raise JSONRPCException({
|
'code': -343, 'message': 'missing JSON-RPC result'}, status)
|
||||||
'code': -342, 'message': 'non-200 HTTP status code but no JSON-RPC error'}, status)
|
elif status != HTTPStatus.OK:
|
||||||
|
raise JSONRPCException({
|
||||||
|
'code': -342, 'message': 'non-200 HTTP status code but no JSON-RPC error'}, status)
|
||||||
|
else:
|
||||||
|
return response['result']
|
||||||
else:
|
else:
|
||||||
|
assert response['jsonrpc'] == '2.0'
|
||||||
|
if status != HTTPStatus.OK:
|
||||||
|
raise JSONRPCException({
|
||||||
|
'code': -342, 'message': 'non-200 HTTP status code'}, status)
|
||||||
|
if 'error' in response:
|
||||||
|
raise JSONRPCException(response['error'], status)
|
||||||
|
elif 'result' not in response:
|
||||||
|
raise JSONRPCException({
|
||||||
|
'code': -343, 'message': 'missing JSON-RPC 2.0 result and error'}, status)
|
||||||
return response['result']
|
return response['result']
|
||||||
|
|
||||||
def batch(self, rpc_call_list):
|
def batch(self, rpc_call_list):
|
||||||
|
@ -142,7 +155,7 @@ class AuthServiceProxy():
|
||||||
response, status = self._request('POST', self.__url.path, postdata.encode('utf-8'))
|
response, status = self._request('POST', self.__url.path, postdata.encode('utf-8'))
|
||||||
if status != HTTPStatus.OK:
|
if status != HTTPStatus.OK:
|
||||||
raise JSONRPCException({
|
raise JSONRPCException({
|
||||||
'code': -342, 'message': 'non-200 HTTP status code but no JSON-RPC error'}, status)
|
'code': -342, 'message': 'non-200 HTTP status code'}, status)
|
||||||
return response
|
return response
|
||||||
|
|
||||||
def _get_response(self):
|
def _get_response(self):
|
||||||
|
|
Loading…
Add table
Reference in a new issue