[server]: Add additional fields to fetch_transient_data
This commit is contained in:
@ -46,6 +46,10 @@ def fetch_trains():
|
|||||||
train_status = train["TrainStatus"]
|
train_status = train["TrainStatus"]
|
||||||
public_message = train["PublicMessage"]
|
public_message = train["PublicMessage"]
|
||||||
|
|
||||||
|
split_message = public_message.split("\\n")
|
||||||
|
trainDetails = split_message[1].split("(")[0]
|
||||||
|
trainUpdate = split_message[2]
|
||||||
|
|
||||||
# Regex to extract punctuality: Matches positive/negative number followed by "mins late"
|
# Regex to extract punctuality: Matches positive/negative number followed by "mins late"
|
||||||
match = re.search(r"(-?\d+)\s+mins\s+late", public_message)
|
match = re.search(r"(-?\d+)\s+mins\s+late", public_message)
|
||||||
punctuality = int(match.group(1)) if match else 0 # Default to 0 if no match
|
punctuality = int(match.group(1)) if match else 0 # Default to 0 if no match
|
||||||
@ -88,7 +92,9 @@ def fetch_trains():
|
|||||||
"trainDirection": train["Direction"],
|
"trainDirection": train["Direction"],
|
||||||
"trainPunctuality": punctuality,
|
"trainPunctuality": punctuality,
|
||||||
"trainPunctualityStatus": punctuality_status,
|
"trainPunctualityStatus": punctuality_status,
|
||||||
"latenessMessage": lateness_message
|
"latenessMessage": lateness_message,
|
||||||
|
"trainDetails": trainDetails,
|
||||||
|
"trainUpdate": trainUpdate
|
||||||
})
|
})
|
||||||
|
|
||||||
return trains
|
return trains
|
||||||
|
@ -59,7 +59,7 @@ class TestTransientData(unittest.TestCase):
|
|||||||
<TrainLongitude>-6.0</TrainLongitude>
|
<TrainLongitude>-6.0</TrainLongitude>
|
||||||
<TrainStatus>R</TrainStatus>
|
<TrainStatus>R</TrainStatus>
|
||||||
<TrainDate>2025-03-09</TrainDate>
|
<TrainDate>2025-03-09</TrainDate>
|
||||||
<PublicMessage>5 mins late</PublicMessage>
|
<PublicMessage>P322\\n17:10 - M3 Parkway to Docklands (1 mins late)\\nArrived Castleknock next stop Navan Road Parkway</PublicMessage>
|
||||||
<Direction>Northbound</Direction>
|
<Direction>Northbound</Direction>
|
||||||
</objTrainPositions>
|
</objTrainPositions>
|
||||||
</ArrayOfObjTrainPositions>
|
</ArrayOfObjTrainPositions>
|
||||||
@ -77,7 +77,7 @@ class TestTransientData(unittest.TestCase):
|
|||||||
"TrainLongitude": "-6.0",
|
"TrainLongitude": "-6.0",
|
||||||
"TrainStatus": "R",
|
"TrainStatus": "R",
|
||||||
"TrainDate": "2025-03-09",
|
"TrainDate": "2025-03-09",
|
||||||
"PublicMessage": "5 mins late",
|
"PublicMessage": "P322\\n17:10 - M3 Parkway to Docklands (1 mins late)\\nArrived Castleknock next stop Navan Road Parkway",
|
||||||
"Direction": "Northbound"
|
"Direction": "Northbound"
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
@ -89,9 +89,9 @@ class TestTransientData(unittest.TestCase):
|
|||||||
self.assertEqual(result[0]['trainCode'], 'A123')
|
self.assertEqual(result[0]['trainCode'], 'A123')
|
||||||
self.assertEqual(result[0]['trainStatus'], 'R')
|
self.assertEqual(result[0]['trainStatus'], 'R')
|
||||||
self.assertEqual(result[0]['trainStatusFull'], 'Running')
|
self.assertEqual(result[0]['trainStatusFull'], 'Running')
|
||||||
self.assertEqual(result[0]['trainPunctuality'], 5)
|
self.assertEqual(result[0]['trainPunctuality'], 1)
|
||||||
self.assertEqual(result[0]['trainPunctualityStatus'], 'late')
|
self.assertEqual(result[0]['trainPunctualityStatus'], 'late')
|
||||||
self.assertEqual(result[0]['latenessMessage'], '5 minutes late')
|
self.assertEqual(result[0]['latenessMessage'], '1 minute late')
|
||||||
|
|
||||||
if __name__ == "__main__":
|
if __name__ == "__main__":
|
||||||
unittest.main()
|
unittest.main()
|
||||||
|
Reference in New Issue
Block a user