test: use json-rpc 2.0 in all functional tests by default

This commit is contained in:
Matthew Zipkin 2024-06-06 11:42:38 -04:00
parent 391843b029
commit b225295298
No known key found for this signature in database
GPG key ID: E7E2984B6289C93A

View file

@ -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):