CLI: Added logging to the ostinato modules for debugging; -d option to example.py skips user input and uses default values instead
This commit is contained in:
parent
2a83b1a61b
commit
3406d68697
@ -16,6 +16,7 @@
|
|||||||
# along with this program. If not, see <http://www.gnu.org/licenses/>
|
# along with this program. If not, see <http://www.gnu.org/licenses/>
|
||||||
|
|
||||||
import json
|
import json
|
||||||
|
import logging
|
||||||
from os.path import dirname
|
from os.path import dirname
|
||||||
|
|
||||||
with open(dirname(__file__) + '/pkg_info.json') as f:
|
with open(dirname(__file__) + '/pkg_info.json') as f:
|
||||||
@ -24,3 +25,4 @@ with open(dirname(__file__) + '/pkg_info.json') as f:
|
|||||||
__version__ = _info['version']
|
__version__ = _info['version']
|
||||||
__revision__ = _info['revision']
|
__revision__ = _info['revision']
|
||||||
|
|
||||||
|
__log__ = logging.getLogger('ostinato')
|
||||||
|
@ -6,23 +6,37 @@ import os
|
|||||||
import sys
|
import sys
|
||||||
import time
|
import time
|
||||||
|
|
||||||
# ostinato modules - prepend 'ostinato.' to the module names when using
|
# ostinato modules
|
||||||
# an installed package i.e ostinato.core and ostinato.protocols.xxx
|
# (user scripts using the installed package should prepend ostinato. i.e
|
||||||
|
# ostinato.core and ostinato.protocols)
|
||||||
from core import ost_pb, DroneProxy
|
from core import ost_pb, DroneProxy
|
||||||
from protocols.mac_pb2 import mac
|
from protocols.mac_pb2 import mac
|
||||||
from protocols.ip4_pb2 import ip4, Ip4
|
from protocols.ip4_pb2 import ip4, Ip4
|
||||||
|
|
||||||
# initialize defaults
|
# initialize defaults
|
||||||
|
use_defaults = False
|
||||||
host_name = '127.0.0.1'
|
host_name = '127.0.0.1'
|
||||||
tx_port_number = 0
|
tx_port_number = 0
|
||||||
rx_port_number = 0
|
rx_port_number = 0
|
||||||
|
|
||||||
# setup logging
|
# setup logging
|
||||||
log = logging.getLogger(__name__)
|
log = logging.getLogger(__name__)
|
||||||
logging.basicConfig(level=logging.DEBUG)
|
logging.basicConfig(level=logging.INFO)
|
||||||
|
|
||||||
s = raw_input('Drone\'s Hostname/IP [%s]: ' % (host_name))
|
# command-line option/arg processing
|
||||||
host_name = s or host_name
|
if len(sys.argv) > 1:
|
||||||
|
if sys.argv[1] in ('-d', '--use-defaults'):
|
||||||
|
use_defaults = True
|
||||||
|
if sys.argv[1] in ('-h', '--help'):
|
||||||
|
print '%s [OPTION]...' % (sys.argv[0])
|
||||||
|
print 'Options:'
|
||||||
|
print ' -d --use-defaults run using default values'
|
||||||
|
print ' -h --help show this help'
|
||||||
|
sys.exit(0)
|
||||||
|
|
||||||
|
if not use_defaults:
|
||||||
|
s = raw_input('Drone\'s Hostname/IP [%s]: ' % (host_name))
|
||||||
|
host_name = s or host_name
|
||||||
|
|
||||||
drone = DroneProxy(host_name)
|
drone = DroneProxy(host_name)
|
||||||
|
|
||||||
@ -50,13 +64,14 @@ try:
|
|||||||
tx_port_number = port.port_id.id
|
tx_port_number = port.port_id.id
|
||||||
rx_port_number = port.port_id.id
|
rx_port_number = port.port_id.id
|
||||||
|
|
||||||
p = raw_input('Tx Port Id [%d]: ' % (tx_port_number))
|
if not use_defaults:
|
||||||
if p:
|
p = raw_input('Tx Port Id [%d]: ' % (tx_port_number))
|
||||||
tx_port_number = int(p)
|
if p:
|
||||||
|
tx_port_number = int(p)
|
||||||
|
|
||||||
p = raw_input('Rx Port Id [%d]: ' % (rx_port_number))
|
p = raw_input('Rx Port Id [%d]: ' % (rx_port_number))
|
||||||
if p:
|
if p:
|
||||||
rx_port_number = int(p)
|
rx_port_number = int(p)
|
||||||
|
|
||||||
tx_port = ost_pb.PortIdList()
|
tx_port = ost_pb.PortIdList()
|
||||||
tx_port.port_id.add().id = tx_port_number;
|
tx_port.port_id.add().id = tx_port_number;
|
||||||
|
@ -18,6 +18,7 @@
|
|||||||
from google.protobuf.message import EncodeError, DecodeError
|
from google.protobuf.message import EncodeError, DecodeError
|
||||||
from google.protobuf.service import RpcChannel
|
from google.protobuf.service import RpcChannel
|
||||||
from google.protobuf.service import RpcController
|
from google.protobuf.service import RpcController
|
||||||
|
import logging
|
||||||
import socket
|
import socket
|
||||||
import struct
|
import struct
|
||||||
import sys
|
import sys
|
||||||
@ -49,10 +50,13 @@ class OstinatoRpcController(RpcController):
|
|||||||
|
|
||||||
class OstinatoRpcChannel(RpcChannel):
|
class OstinatoRpcChannel(RpcChannel):
|
||||||
def __init__(self):
|
def __init__(self):
|
||||||
|
self.log = logging.getLogger('ostinato.rpc')
|
||||||
|
self.log.debug('opening socket')
|
||||||
self.sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
|
self.sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
|
||||||
|
|
||||||
def connect(self, host, port):
|
def connect(self, host, port):
|
||||||
self.peer = '%s:%d' % (host, port)
|
self.peer = '%s:%d' % (host, port)
|
||||||
|
self.log.debug('connecting to %s', self.peer)
|
||||||
try:
|
try:
|
||||||
self.sock.connect((host, port))
|
self.sock.connect((host, port))
|
||||||
except socket.error, e:
|
except socket.error, e:
|
||||||
@ -62,31 +66,40 @@ class OstinatoRpcChannel(RpcChannel):
|
|||||||
raise
|
raise
|
||||||
|
|
||||||
def disconnect(self):
|
def disconnect(self):
|
||||||
|
self.log.debug('closing socket')
|
||||||
self.sock.close()
|
self.sock.close()
|
||||||
|
|
||||||
def CallMethod(self, method, controller, request, response_class, done):
|
def CallMethod(self, method, controller, request, response_class, done):
|
||||||
OST_PB_MSG_HDR_SIZE = 8
|
MSG_HDR_SIZE = 8
|
||||||
OST_PB_MSG_TYPE_REQUEST = 1
|
MSG_TYPE_REQUEST = 1
|
||||||
OST_PB_MSG_TYPE_RESPONSE = 2
|
MSG_TYPE_RESPONSE = 2
|
||||||
OST_PB_MSG_TYPE_BLOB = 3
|
MSG_TYPE_BLOB = 3
|
||||||
|
|
||||||
error = ''
|
error = ''
|
||||||
try:
|
try:
|
||||||
|
self.log.debug('invoking RPC %s(%s): %s', method.name,
|
||||||
|
type(request).__name__, response_class.__name__)
|
||||||
|
self.log.debug('serializing request arg %s', request)
|
||||||
req = request.SerializeToString()
|
req = request.SerializeToString()
|
||||||
self.sock.sendall(struct.pack('>HHI',
|
hdr = struct.pack('>HHI', MSG_TYPE_REQUEST, method.index, len(req))
|
||||||
OST_PB_MSG_TYPE_REQUEST, method.index, len(req)) + req)
|
self.log.debug('req.hdr = %r', hdr)
|
||||||
|
self.sock.sendall(hdr + req)
|
||||||
|
|
||||||
# receive and parse header
|
# receive and parse header
|
||||||
|
self.log.debug('receiving response hdr')
|
||||||
hdr = ''
|
hdr = ''
|
||||||
while len(hdr) < OST_PB_MSG_HDR_SIZE:
|
while len(hdr) < MSG_HDR_SIZE:
|
||||||
chunk = self.sock.recv(OST_PB_MSG_HDR_SIZE - len(hdr))
|
chunk = self.sock.recv(MSG_HDR_SIZE - len(hdr))
|
||||||
if chunk == '':
|
if chunk == '':
|
||||||
raise PeerClosedConnError('connection closed by peer')
|
raise PeerClosedConnError('connection closed by peer')
|
||||||
hdr = hdr + chunk
|
hdr = hdr + chunk
|
||||||
|
|
||||||
(msg_type, method_index, resp_len) = struct.unpack('>HHI', hdr)
|
(msg_type, method_index, resp_len) = struct.unpack('>HHI', hdr)
|
||||||
|
self.log.debug('resp hdr: type = %d, method = %d, len = %d',
|
||||||
|
msg_type, method_index, resp_len)
|
||||||
|
|
||||||
# receive and parse the actual response message
|
# receive and parse the actual response message
|
||||||
|
self.log.debug('receiving response data')
|
||||||
resp = ''
|
resp = ''
|
||||||
while len(resp) < resp_len:
|
while len(resp) < resp_len:
|
||||||
chunk = self.sock.recv(resp_len - len(resp))
|
chunk = self.sock.recv(resp_len - len(resp))
|
||||||
@ -99,10 +112,11 @@ class OstinatoRpcChannel(RpcChannel):
|
|||||||
raise RpcMismatchError('RPC mismatch',
|
raise RpcMismatchError('RPC mismatch',
|
||||||
expected = method.index, received = method_index)
|
expected = method.index, received = method_index)
|
||||||
|
|
||||||
if msg_type == OST_PB_MSG_TYPE_RESPONSE:
|
if msg_type == MSG_TYPE_RESPONSE:
|
||||||
response = response_class()
|
response = response_class()
|
||||||
response.ParseFromString(resp)
|
response.ParseFromString(resp)
|
||||||
elif msg_type == OST_PB_MSG_TYPE_BLOB:
|
self.log.debug('parsed response %s', response)
|
||||||
|
elif msg_type == MSG_TYPE_BLOB:
|
||||||
response = resp
|
response = resp
|
||||||
else:
|
else:
|
||||||
raise RpcError('unknown RPC msg type %d' % msg_type)
|
raise RpcError('unknown RPC msg type %d' % msg_type)
|
||||||
@ -112,29 +126,35 @@ class OstinatoRpcChannel(RpcChannel):
|
|||||||
except socket.error, e:
|
except socket.error, e:
|
||||||
error = 'ERROR: RPC %s() to Drone %s failed (%s)' % (
|
error = 'ERROR: RPC %s() to Drone %s failed (%s)' % (
|
||||||
method.name, self.peer, e)
|
method.name, self.peer, e)
|
||||||
|
self.log.exception(error+e)
|
||||||
raise
|
raise
|
||||||
except PeerClosedConnError, e:
|
except PeerClosedConnError, e:
|
||||||
error = 'ERROR: Drone %s closed connection receiving reply ' \
|
error = 'ERROR: Drone %s closed connection receiving reply ' \
|
||||||
'for RPC %s() (%s)' % (
|
'for RPC %s() (%s)' % (
|
||||||
self.peer, method.name, e)
|
self.peer, method.name, e)
|
||||||
|
self.log.exception(error)
|
||||||
raise
|
raise
|
||||||
except EncodeError, e:
|
except EncodeError, e:
|
||||||
error = 'ERROR: Failed to serialize %s arg for RPC %s() ' \
|
error = 'ERROR: Failed to serialize %s arg for RPC %s() ' \
|
||||||
'to Drone %s (%s)' % (
|
'to Drone %s (%s)' % (
|
||||||
type(request).__name__, method.name, self.peer, e)
|
type(request).__name__, method.name, self.peer, e)
|
||||||
|
self.log.exception(error)
|
||||||
raise
|
raise
|
||||||
except DecodeError, e:
|
except DecodeError, e:
|
||||||
error = 'ERROR: Failed to parse %s response for RPC %s() ' \
|
error = 'ERROR: Failed to parse %s response for RPC %s() ' \
|
||||||
'from Drone %s (%s)' % (
|
'from Drone %s (%s)' % (
|
||||||
type(response).__name__, method.name, self.peer, e)
|
type(response).__name__, method.name, self.peer, e)
|
||||||
|
self.log.exception(error)
|
||||||
raise
|
raise
|
||||||
except RpcMismatchError, e:
|
except RpcMismatchError, e:
|
||||||
error = 'ERROR: Rpc Mismatch for RPC %s() (%s)' % (
|
error = 'ERROR: Rpc Mismatch for RPC %s() (%s)' % (
|
||||||
method.name, e)
|
method.name, e)
|
||||||
|
self.log.exception(error)
|
||||||
raise
|
raise
|
||||||
except RpcError, e:
|
except RpcError, e:
|
||||||
error = 'ERROR: Unknown reply received for RPC %s() (%s) ' % (
|
error = 'ERROR: Unknown reply received for RPC %s() (%s) ' % (
|
||||||
method.name, e)
|
method.name, e)
|
||||||
|
self.log.exception(error)
|
||||||
raise
|
raise
|
||||||
finally:
|
finally:
|
||||||
if error:
|
if error:
|
||||||
|
@ -68,7 +68,6 @@ setup(name = 'ostinato',
|
|||||||
packages = ['ostinato', 'ostinato.protocols'],
|
packages = ['ostinato', 'ostinato.protocols'],
|
||||||
package_dir = {'ostinato': '.'},
|
package_dir = {'ostinato': '.'},
|
||||||
package_data = {'ostinato': ['pkg_info.json', 'LICENSE.txt']},
|
package_data = {'ostinato': ['pkg_info.json', 'LICENSE.txt']},
|
||||||
scripts = ['example.py'],
|
|
||||||
platforms = ['Any'],
|
platforms = ['Any'],
|
||||||
classifiers = [
|
classifiers = [
|
||||||
'Development Status :: 5 - Production/Stable',
|
'Development Status :: 5 - Production/Stable',
|
||||||
|
Loading…
Reference in New Issue
Block a user