2017-12-16 20:08:01 +00:00
|
|
|
import unittest
|
|
|
|
import os
|
|
|
|
|
2019-01-03 18:17:59 +00:00
|
|
|
from ogn.model import AircraftBeacon, ReceiverBeacon, Device, Receiver
|
|
|
|
from ogn.collect.database import add_missing_devices, add_missing_receivers
|
2017-12-16 20:08:01 +00:00
|
|
|
|
|
|
|
|
|
|
|
class TestDB(unittest.TestCase):
|
|
|
|
session = None
|
|
|
|
engine = None
|
|
|
|
app = None
|
|
|
|
|
|
|
|
def setUp(self):
|
|
|
|
os.environ['OGN_CONFIG_MODULE'] = 'config.test'
|
|
|
|
from ogn.commands.dbutils import engine, session
|
|
|
|
self.session = session
|
|
|
|
self.engine = engine
|
|
|
|
|
|
|
|
from ogn.commands.database import init
|
|
|
|
init()
|
|
|
|
|
|
|
|
def tearDown(self):
|
|
|
|
session = self.session
|
2018-01-11 07:35:07 +00:00
|
|
|
session.execute("DELETE FROM device_infos")
|
|
|
|
session.execute("DELETE FROM devices")
|
|
|
|
session.execute("DELETE FROM receivers")
|
|
|
|
session.execute("DELETE FROM aircraft_beacons")
|
|
|
|
session.execute("DELETE FROM receiver_beacons")
|
2017-12-16 20:08:01 +00:00
|
|
|
session.commit()
|
|
|
|
|
|
|
|
def test_update_devices(self):
|
|
|
|
session = self.session
|
|
|
|
|
2019-01-01 19:13:08 +00:00
|
|
|
ab01 = AircraftBeacon(name='FLRDD4711', receiver_name='Koenigsdf', address='DD4711', timestamp='2017-12-10 10:00:00')
|
|
|
|
rb01 = ReceiverBeacon(name='Bene', receiver_name='GLIDERN1', timestamp='2017-12-10 09:59:50')
|
2018-01-19 18:14:57 +00:00
|
|
|
d01 = Device(address='DD4711')
|
|
|
|
r01 = Receiver(name='Koenigsdf')
|
|
|
|
session.bulk_save_objects([ab01, rb01, d01, r01])
|
2017-12-16 20:08:01 +00:00
|
|
|
|
2018-11-28 06:37:35 +00:00
|
|
|
add_missing_devices(session)
|
|
|
|
add_missing_receivers(session)
|
2017-12-16 20:40:12 +00:00
|
|
|
|
2018-01-19 18:14:57 +00:00
|
|
|
aircraft_beacons = session.query(AircraftBeacon).all()
|
|
|
|
self.assertEqual(len(aircraft_beacons), 1)
|
|
|
|
aircraft_beacon = aircraft_beacons[0]
|
|
|
|
self.assertEqual(aircraft_beacon.device.address, 'DD4711')
|
|
|
|
self.assertEqual(aircraft_beacon.receiver.name, 'Koenigsdf')
|
|
|
|
|
|
|
|
receiver_beacons = session.query(ReceiverBeacon).all()
|
|
|
|
self.assertEqual(len(receiver_beacons), 1)
|
|
|
|
receiver_beacon = receiver_beacons[0]
|
|
|
|
self.assertEqual(receiver_beacon.receiver.name, 'Bene')
|
2017-12-16 20:08:01 +00:00
|
|
|
|
|
|
|
|
|
|
|
if __name__ == '__main__':
|
|
|
|
unittest.main()
|