mirror of
https://github.com/craigerl/aprsd.git
synced 2026-01-15 18:15:33 -05:00
152 lines
6.4 KiB
Python
152 lines
6.4 KiB
Python
import json
|
|
import unittest
|
|
|
|
import aprslib
|
|
|
|
from aprsd import packets
|
|
from tests import fake
|
|
|
|
|
|
class TestWeatherPacket(unittest.TestCase):
|
|
"""Test WeatherPacket JSON serialization."""
|
|
|
|
def test_weather_packet_to_json(self):
|
|
"""Test WeatherPacket.to_json() method."""
|
|
packet = packets.WeatherPacket(
|
|
from_call=fake.FAKE_FROM_CALLSIGN,
|
|
to_call=fake.FAKE_TO_CALLSIGN,
|
|
latitude=37.7749,
|
|
longitude=-122.4194,
|
|
symbol='_',
|
|
symbol_table='/',
|
|
wind_speed=10.5,
|
|
wind_direction=180,
|
|
wind_gust=15.0,
|
|
temperature=72.5,
|
|
rain_1h=0.1,
|
|
rain_24h=0.5,
|
|
rain_since_midnight=0.3,
|
|
humidity=65,
|
|
pressure=1013.25,
|
|
comment='Test weather comment',
|
|
)
|
|
json_str = packet.to_json()
|
|
self.assertIsInstance(json_str, str)
|
|
json_dict = json.loads(json_str)
|
|
self.assertEqual(json_dict['_type'], 'WeatherPacket')
|
|
self.assertEqual(json_dict['from_call'], fake.FAKE_FROM_CALLSIGN)
|
|
self.assertEqual(json_dict['to_call'], fake.FAKE_TO_CALLSIGN)
|
|
self.assertEqual(json_dict['latitude'], 37.7749)
|
|
self.assertEqual(json_dict['longitude'], -122.4194)
|
|
self.assertEqual(json_dict['symbol'], '_')
|
|
self.assertEqual(json_dict['wind_speed'], 10.5)
|
|
self.assertEqual(json_dict['wind_direction'], 180)
|
|
self.assertEqual(json_dict['wind_gust'], 15.0)
|
|
self.assertEqual(json_dict['temperature'], 72.5)
|
|
self.assertEqual(json_dict['rain_1h'], 0.1)
|
|
self.assertEqual(json_dict['rain_24h'], 0.5)
|
|
self.assertEqual(json_dict['rain_since_midnight'], 0.3)
|
|
self.assertEqual(json_dict['humidity'], 65)
|
|
self.assertEqual(json_dict['pressure'], 1013.25)
|
|
self.assertEqual(json_dict['comment'], 'Test weather comment')
|
|
|
|
def test_weather_packet_from_dict(self):
|
|
"""Test WeatherPacket.from_dict() method."""
|
|
packet_dict = {
|
|
'_type': 'WeatherPacket',
|
|
'from_call': fake.FAKE_FROM_CALLSIGN,
|
|
'to_call': fake.FAKE_TO_CALLSIGN,
|
|
'latitude': 37.7749,
|
|
'longitude': -122.4194,
|
|
'symbol': '_',
|
|
'symbol_table': '/',
|
|
'wind_speed': 10.5,
|
|
'wind_direction': 180,
|
|
'wind_gust': 15.0,
|
|
'temperature': 72.5,
|
|
'rain_1h': 0.1,
|
|
'rain_24h': 0.5,
|
|
'rain_since_midnight': 0.3,
|
|
'humidity': 65,
|
|
'pressure': 1013.25,
|
|
'comment': 'Test weather comment',
|
|
}
|
|
packet = packets.WeatherPacket.from_dict(packet_dict)
|
|
self.assertIsInstance(packet, packets.WeatherPacket)
|
|
self.assertEqual(packet.from_call, fake.FAKE_FROM_CALLSIGN)
|
|
self.assertEqual(packet.to_call, fake.FAKE_TO_CALLSIGN)
|
|
self.assertEqual(packet.latitude, 37.7749)
|
|
self.assertEqual(packet.longitude, -122.4194)
|
|
self.assertEqual(packet.symbol, '_')
|
|
self.assertEqual(packet.wind_speed, 10.5)
|
|
self.assertEqual(packet.wind_direction, 180)
|
|
self.assertEqual(packet.wind_gust, 15.0)
|
|
self.assertEqual(packet.temperature, 72.5)
|
|
self.assertEqual(packet.rain_1h, 0.1)
|
|
self.assertEqual(packet.rain_24h, 0.5)
|
|
self.assertEqual(packet.rain_since_midnight, 0.3)
|
|
self.assertEqual(packet.humidity, 65)
|
|
self.assertEqual(packet.pressure, 1013.25)
|
|
self.assertEqual(packet.comment, 'Test weather comment')
|
|
|
|
def test_weather_packet_round_trip(self):
|
|
"""Test WeatherPacket round-trip: to_json -> from_dict."""
|
|
original = packets.WeatherPacket(
|
|
from_call=fake.FAKE_FROM_CALLSIGN,
|
|
to_call=fake.FAKE_TO_CALLSIGN,
|
|
latitude=37.7749,
|
|
longitude=-122.4194,
|
|
symbol='_',
|
|
symbol_table='/',
|
|
wind_speed=10.5,
|
|
wind_direction=180,
|
|
wind_gust=15.0,
|
|
temperature=72.5,
|
|
rain_1h=0.1,
|
|
rain_24h=0.5,
|
|
rain_since_midnight=0.3,
|
|
humidity=65,
|
|
pressure=1013.25,
|
|
comment='Test weather comment',
|
|
)
|
|
json_str = original.to_json()
|
|
packet_dict = json.loads(json_str)
|
|
restored = packets.WeatherPacket.from_dict(packet_dict)
|
|
self.assertEqual(restored.from_call, original.from_call)
|
|
self.assertEqual(restored.to_call, original.to_call)
|
|
self.assertEqual(restored.latitude, original.latitude)
|
|
self.assertEqual(restored.longitude, original.longitude)
|
|
self.assertEqual(restored.symbol, original.symbol)
|
|
self.assertEqual(restored.wind_speed, original.wind_speed)
|
|
self.assertEqual(restored.wind_direction, original.wind_direction)
|
|
self.assertEqual(restored.wind_gust, original.wind_gust)
|
|
self.assertEqual(restored.temperature, original.temperature)
|
|
self.assertEqual(restored.rain_1h, original.rain_1h)
|
|
self.assertEqual(restored.rain_24h, original.rain_24h)
|
|
self.assertEqual(restored.rain_since_midnight, original.rain_since_midnight)
|
|
self.assertEqual(restored.humidity, original.humidity)
|
|
self.assertEqual(restored.pressure, original.pressure)
|
|
self.assertEqual(restored.comment, original.comment)
|
|
self.assertEqual(restored._type, original._type)
|
|
|
|
def test_weather_packet_from_raw_string(self):
|
|
"""Test WeatherPacket creation from raw APRS string."""
|
|
packet_raw = 'FW9222>APRS,TCPXX*,qAX,CWOP-6:@122025z2953.94N/08423.77W_232/003g006t084r000p032P000h80b10157L745.DsWLL'
|
|
packet_dict = aprslib.parse(packet_raw)
|
|
packet = packets.factory(packet_dict)
|
|
self.assertIsInstance(packet, packets.WeatherPacket)
|
|
# Test to_json
|
|
json_str = packet.to_json()
|
|
self.assertIsInstance(json_str, str)
|
|
json_dict = json.loads(json_str)
|
|
self.assertEqual(json_dict['_type'], 'WeatherPacket')
|
|
# Test from_dict round trip
|
|
restored = packets.factory(json_dict)
|
|
self.assertIsInstance(restored, packets.WeatherPacket)
|
|
self.assertEqual(restored.from_call, packet.from_call)
|
|
self.assertEqual(restored.temperature, packet.temperature)
|
|
self.assertEqual(restored.humidity, packet.humidity)
|
|
self.assertEqual(restored.pressure, packet.pressure)
|
|
self.assertEqual(restored.wind_speed, packet.wind_speed)
|
|
self.assertEqual(restored.wind_direction, packet.wind_direction)
|