blob: badde5518f302ec49891daf547c7815285972097 [file] [log] [blame]
Vadim Yanitskiy7d57edf2021-03-11 23:01:55 +01001#!/usr/bin/env python3
Daniel Laszlo Sitzer851e9c02018-12-04 19:40:08 +01002
3import unittest
Merlin Chlosta05ca36b2021-04-01 16:15:28 +02004from pySim import utils
5from pySim.ts_31_102 import EF_SUCI_Calc_Info
Daniel Laszlo Sitzer851e9c02018-12-04 19:40:08 +01006
7class DecTestCase(unittest.TestCase):
Merlin Chlosta05ca36b2021-04-01 16:15:28 +02008 # TS33.501 Annex C.4 test keys
9 hnet_pubkey_profile_b = "0272DA71976234CE833A6907425867B82E074D44EF907DFB4B3E21C1C2256EBCD1" # ID 27 in test file
10 hnet_pubkey_profile_a = "5A8D38864820197C3394B92613B20B91633CBD897119273BF8E4A6F4EEC0A650" # ID 30 in test file
11
12 # TS31.121 4.9.4 EF_SUCI_Calc_Info test file
13 testfile_suci_calc_info = "A006020101020000A14B80011B8121" +hnet_pubkey_profile_b +"80011E8120" +hnet_pubkey_profile_a
14
15 decoded_testfile_suci = {
16 'prot_scheme_id_list': [
17 {'priority': 0, 'identifier': 2, 'key_index': 1},
18 {'priority': 1, 'identifier': 1, 'key_index': 2},
19 {'priority': 2, 'identifier': 0, 'key_index': 0}],
20 'hnet_pubkey_list': [
21 {'hnet_pubkey_identifier': 27, 'hnet_pubkey': hnet_pubkey_profile_b.lower()}, # because h2b/b2h returns all lower-case
22 {'hnet_pubkey_identifier': 30, 'hnet_pubkey': hnet_pubkey_profile_a.lower()}]
23 }
Daniel Laszlo Sitzer851e9c02018-12-04 19:40:08 +010024
25 def testSplitHexStringToListOf5ByteEntries(self):
26 input_str = "ffffff0003ffffff0002ffffff0001"
27 expected = [
28 "ffffff0003",
29 "ffffff0002",
30 "ffffff0001",
31 ]
herlesupreeth45fa6042020-09-18 15:32:20 +020032 self.assertEqual(utils.hexstr_to_Nbytearr(input_str, 5), expected)
Daniel Laszlo Sitzer851e9c02018-12-04 19:40:08 +010033
34 def testDecMCCfromPLMN(self):
35 self.assertEqual(utils.dec_mcc_from_plmn("92f501"), 295)
36
37 def testDecMCCfromPLMN_unused(self):
38 self.assertEqual(utils.dec_mcc_from_plmn("ff0f00"), 4095)
39
40 def testDecMNCfromPLMN_twoDigitMNC(self):
41 self.assertEqual(utils.dec_mnc_from_plmn("92f501"), 10)
42
43 def testDecMNCfromPLMN_threeDigitMNC(self):
44 self.assertEqual(utils.dec_mnc_from_plmn("031263"), 361)
45
46 def testDecMNCfromPLMN_unused(self):
47 self.assertEqual(utils.dec_mnc_from_plmn("00f0ff"), 4095)
48
Vadim Yanitskiyc8458e22021-03-12 00:34:10 +010049 def test_enc_plmn(self):
50 with self.subTest("2-digit MCC"):
51 self.assertEqual(utils.enc_plmn("001", "01F"), "00F110")
52 self.assertEqual(utils.enc_plmn("001", "01"), "00F110")
53 self.assertEqual(utils.enc_plmn("295", "10"), "92F501")
54
55 with self.subTest("3-digit MCC"):
56 self.assertEqual(utils.enc_plmn("001", "001"), "001100")
57 self.assertEqual(utils.enc_plmn("302", "361"), "031263")
58
Daniel Laszlo Sitzer851e9c02018-12-04 19:40:08 +010059 def testDecAct_noneSet(self):
60 self.assertEqual(utils.dec_act("0000"), [])
61
62 def testDecAct_onlyUtran(self):
63 self.assertEqual(utils.dec_act("8000"), ["UTRAN"])
64
65 def testDecAct_onlyEUtran(self):
66 self.assertEqual(utils.dec_act("4000"), ["E-UTRAN"])
67
68 def testDecAct_onlyGsm(self):
69 self.assertEqual(utils.dec_act("0080"), ["GSM"])
70
71 def testDecAct_onlyGsmCompact(self):
72 self.assertEqual(utils.dec_act("0040"), ["GSM COMPACT"])
73
74 def testDecAct_onlyCdma2000HRPD(self):
75 self.assertEqual(utils.dec_act("0020"), ["cdma2000 HRPD"])
76
77 def testDecAct_onlyCdma20001xRTT(self):
78 self.assertEqual(utils.dec_act("0010"), ["cdma2000 1xRTT"])
79
80 def testDecAct_allSet(self):
81 self.assertEqual(utils.dec_act("ffff"), ["UTRAN", "E-UTRAN", "GSM", "GSM COMPACT", "cdma2000 HRPD", "cdma2000 1xRTT"])
82
83 def testDecxPlmn_w_act(self):
84 expected = {'mcc': 295, 'mnc': 10, 'act': ["UTRAN"]}
85 self.assertEqual(utils.dec_xplmn_w_act("92f5018000"), expected)
86
87 def testFormatxPlmn_w_act(self):
88 input_str = "92f501800092f5508000ffffff0000ffffff0000ffffff0000ffffff0000ffffff0000ffffff0000ffffff0000ffffff0000"
Vadim Yanitskiy46c49d52021-03-12 01:12:11 +010089 expected = "\t92f5018000 # MCC: 295 MNC: 010 AcT: UTRAN\n"
90 expected += "\t92f5508000 # MCC: 295 MNC: 005 AcT: UTRAN\n"
91 expected += "\tffffff0000 # unused\n"
92 expected += "\tffffff0000 # unused\n"
93 expected += "\tffffff0000 # unused\n"
94 expected += "\tffffff0000 # unused\n"
95 expected += "\tffffff0000 # unused\n"
96 expected += "\tffffff0000 # unused\n"
97 expected += "\tffffff0000 # unused\n"
98 expected += "\tffffff0000 # unused\n"
Daniel Laszlo Sitzer851e9c02018-12-04 19:40:08 +010099 self.assertEqual(utils.format_xplmn_w_act(input_str), expected)
100
Merlin Chlosta05ca36b2021-04-01 16:15:28 +0200101
102 def testDecodeSuciCalcInfo(self):
103 suci_calc_info = EF_SUCI_Calc_Info()
104 decoded = suci_calc_info._decode_hex(self.testfile_suci_calc_info)
105 self.assertDictEqual(self.decoded_testfile_suci, decoded)
106
107 def testEncodeSuciCalcInfo(self):
108 suci_calc_info = EF_SUCI_Calc_Info()
109 encoded = suci_calc_info._encode_hex(self.decoded_testfile_suci)
110 self.assertEqual(encoded.lower(), self.testfile_suci_calc_info.lower())
111
Daniel Laszlo Sitzer851e9c02018-12-04 19:40:08 +0100112if __name__ == "__main__":
113 unittest.main()