Skip to content

Commit

Permalink
Issue NASA-AMMOS#200 - Move SLE class vars to instance vars
Browse files Browse the repository at this point in the history
When running more than one class that inherits from SLE, _state, _handlers,
_data_queue, and _invoke_id become shared. The most common issue this
creates is if data is being inserted into the data queue that is being
shared. Data will be given to any of the children even if the PDU
does not match what the child knows about.

By making these instance level attributes data is kept confined
to the individual member and is not shared.

Additionally, if a socket is closed abruptly, the _state should
be reset to "unbound" because the only way to reset it would be
to destroy the object.

patch_all is not required as the only thing being monkey patched
for gevents is time. By running patch_all, issues arise when running
non-gevent queues in calling applications.

_telem_sock should only be created when connecting, not on class instantiation

Fixes NASA-AMMOS#200
  • Loading branch information
christianmkuss committed Dec 7, 2022
1 parent 654bc55 commit 57b903c
Show file tree
Hide file tree
Showing 2 changed files with 9 additions and 7 deletions.
14 changes: 8 additions & 6 deletions ait/dsn/sle/common.py
Original file line number Diff line number Diff line change
Expand Up @@ -58,7 +58,7 @@
import gevent.queue
import gevent.socket
import gevent.select
import gevent.monkey; gevent.monkey.patch_all()
import gevent.monkey; gevent.monkey.patch_time()

import pyasn1.error
from pyasn1.codec.ber.encoder import encode
Expand Down Expand Up @@ -92,13 +92,13 @@ class SLE(object):
for interfacing with SLE.
'''
_state = 'unbound'
_handlers = defaultdict(list)
_data_queue = gevent.queue.Queue()
_invoke_id = 0

def __init__(self, *args, **kwargs):
''''''
self._state = 'unbound'
self._handlers = defaultdict(list)
self._data_queue = gevent.queue.Queue()
self._invoke_id = 0
self._downlink_frame_type = ait.config.get('dsn.sle.downlink_frame_type',
kwargs.get('downlink_frame_type', 'TMTransFrame'))
self._heartbeat = ait.config.get('dsn.sle.heartbeat',
Expand All @@ -117,7 +117,6 @@ def __init__(self, *args, **kwargs):
kwargs.get('peer_password', None))
self._responder_port = ait.config.get('dsn.sle.responder_port',
kwargs.get('responder_port', 'default'))
self._telem_sock = socket.socket(socket.AF_INET, socket.SOCK_DGRAM)
self._auth_level = ait.config.get('dsn.sle.auth_level',
kwargs.get('auth_level', 'none'))

Expand Down Expand Up @@ -166,6 +165,7 @@ def send(self, data):
for i in writeable:
i.sendall(data)
except socket.error as e:
self._state = 'unbound'
if e.errno == errno.ECONNRESET:
ait.core.log.error('Socket connection lost to DSN')
self._socket.close()
Expand Down Expand Up @@ -306,6 +306,8 @@ def connect(self):
ait.core.log.error('Connection failure with DSN. Aborting ...')
raise Exception('Unable to connect to DSN through any provided hostnames.')

self._telem_sock = socket.socket(socket.AF_INET, socket.SOCK_DGRAM)
ait.core.log.info("Starting conn monitor for %s", type(self))
self._conn_monitor = gevent.spawn(conn_handler, self)
self._data_processor = gevent.spawn(data_processor, self)

Expand Down
2 changes: 1 addition & 1 deletion setup.py
Original file line number Diff line number Diff line change
Expand Up @@ -26,7 +26,7 @@

setup(
name = 'ait-dsn',
version = '2.0.1-rc1',
version = '2.0.2',
description = description,
long_description = long_description,
long_description_content_type = 'text/x-rst',
Expand Down

0 comments on commit 57b903c

Please sign in to comment.