def test_v021(self): receiver_beacon = ReceiverBeacon() receiver_beacon.parse("v0.2.1 CPU:0.8 RAM:25.6/458.9MB NTP:0.0ms/+0.0ppm +51.9C RF:+26-1.4ppm/-0.25dB") self.assertEqual(receiver_beacon.rec_crystal_correction, 26) self.assertEqual(receiver_beacon.rec_crystal_correction_fine, -1.4) self.assertEqual(receiver_beacon.rec_input_noise, -0.25)
def test_v022(self): receiver_beacon = ReceiverBeacon() receiver_beacon.parse("v0.2.2.x86 CPU:0.5 RAM:669.9/887.7MB NTP:1.0ms/+6.2ppm +52.0C RF:+0.06dB") self.assertEqual(receiver_beacon.version, '0.2.2') self.assertEqual(receiver_beacon.platform, 'x86') self.assertEqual(receiver_beacon.cpu_load, 0.5) self.assertEqual(receiver_beacon.cpu_temp, 52.0) self.assertEqual(receiver_beacon.free_ram, 669.9) self.assertEqual(receiver_beacon.total_ram, 887.7) self.assertEqual(receiver_beacon.ntp_error, 1.0) self.assertEqual(receiver_beacon.rec_crystal_correction, 0.0) self.assertEqual(receiver_beacon.rec_crystal_correction_fine, 0.0) self.assertEqual(receiver_beacon.rec_input_noise, 0.06)
def process_beacon(raw_message): if raw_message[0] == '#': return try: message = parse_aprs(raw_message) # symboltable / symbolcodes used by OGN: # I&: used as receiver # /X: helicopter_rotorcraft # /': glider_or_motorglider # \^: powered_aircraft # /g: para_glider # /O: ? # /^: ? # \n: ? # /z: ? # /o: ? if message['symboltable'] == "I" and message['symbolcode'] == '&': # ... we have a receiver_beacon message.update(parse_ogn_receiver_beacon(message['comment'])) message = replace_lonlat_with_wkt(message) beacon = ReceiverBeacon(**message) # connect beacon with receiver receiver = session.query(Receiver.id) \ .filter(Receiver.name == beacon.name) \ .first() if receiver is None: receiver = Receiver() receiver.name = beacon.name session.add(receiver) beacon.receiver_id = receiver.id else: # ... we have a aircraft_beacon message.update(parse_ogn_aircraft_beacon(message['comment'])) message = replace_lonlat_with_wkt(message) beacon = AircraftBeacon(**message) # connect beacon with device device = session.query(Device) \ .filter(Device.address == beacon.address) \ .first() if device is None: device = Device() device.address = beacon.address session.add(device) beacon.device_id = device.id # update device device.aircraft_type = beacon.aircraft_type device.stealth = beacon.stealth if beacon.hardware_version is not None: device.hardware_version = beacon.hardware_version if beacon.software_version is not None: device.software_version = beacon.software_version if beacon.real_address is not None: device.real_address = beacon.real_address # connect beacon with receiver receiver = session.query(Receiver.id) \ .filter(Receiver.name == beacon.receiver_name) \ .first() if receiver is None: receiver = Receiver() receiver.name = beacon.receiver_name session.add(receiver) beacon.receiver_id = receiver.id session.add(beacon) session.commit() logger.debug('Received message: {}'.format(raw_message)) except ParseError as e: logger.error('Received message: {}'.format(raw_message)) logger.error('Drop packet, {}'.format(e.message)) except TypeError as e: logger.error('TypeError: {}'.format(raw_message))
def test_fail_validation(self): receiver_beacon = ReceiverBeacon() with self.assertRaises(OgnParseError): receiver_beacon.parse("notAValidToken")
def process_beacon(raw_message, reference_date=None, reference_time=None): if raw_message[0] == '#': return try: message = parse_aprs(raw_message, reference_date, reference_time) # symboltable / symbolcodes used by OGN: # I&: used as receiver # /X: helicopter_rotorcraft # /': glider_or_motorglider # \^: powered_aircraft # /g: para_glider # /O: ? # /^: ? # \n: ? # /z: ? # /o: ? if 'symboltable' not in message and 'symbolcode' not in message: # we have a receiver_beacon (status message) message.update(parse_ogn_receiver_beacon(message['comment'])) beacon = ReceiverBeacon(**message) # connect beacon with receiver receiver = session.query(Receiver.id) \ .filter(Receiver.name == beacon.name) \ .first() if receiver is None: receiver = Receiver() receiver.name = beacon.name session.add(receiver) beacon.receiver_id = receiver.id elif message['symboltable'] == "I" and message['symbolcode'] == '&': # ... we have a receiver_beacon message.update(parse_ogn_receiver_beacon(message['comment'])) message = replace_lonlat_with_wkt(message) beacon = ReceiverBeacon(**message) # connect beacon with receiver receiver = session.query(Receiver.id) \ .filter(Receiver.name == beacon.name) \ .first() if receiver is None: receiver = Receiver() receiver.name = beacon.name session.add(receiver) beacon.receiver_id = receiver.id else: # ... we have a aircraft_beacon message.update(parse_ogn_aircraft_beacon(message['comment'])) message = replace_lonlat_with_wkt(message) beacon = AircraftBeacon(**message) # connect beacon with device device = session.query(Device) \ .filter(Device.address == beacon.address) \ .first() if device is None: device = Device() device.address = beacon.address session.add(device) beacon.device_id = device.id # update device device.aircraft_type = beacon.aircraft_type device.stealth = beacon.stealth if beacon.hardware_version is not None: device.hardware_version = beacon.hardware_version if beacon.software_version is not None: device.software_version = beacon.software_version if beacon.real_address is not None: device.real_address = beacon.real_address # connect beacon with receiver receiver = session.query(Receiver.id) \ .filter(Receiver.name == beacon.receiver_name) \ .first() if receiver is None: receiver = Receiver() receiver.name = beacon.receiver_name session.add(receiver) beacon.receiver_id = receiver.id session.add(beacon) session.commit() logger.debug('Received message: {}'.format(raw_message)) except ParseError as e: logger.error('Received message: {}'.format(raw_message)) logger.error('Drop packet, {}'.format(e.message)) except TypeError as e: logger.error('TypeError: {}'.format(raw_message))