2021-03-11 22:01:55 +00:00
|
|
|
#!/usr/bin/env python3
|
2018-12-04 18:40:08 +00:00
|
|
|
|
|
|
|
import unittest
|
2021-04-01 14:15:28 +00:00
|
|
|
from pySim import utils
|
|
|
|
from pySim.ts_31_102 import EF_SUCI_Calc_Info
|
2018-12-04 18:40:08 +00:00
|
|
|
|
|
|
|
class DecTestCase(unittest.TestCase):
|
2021-04-01 14:15:28 +00:00
|
|
|
# TS33.501 Annex C.4 test keys
|
|
|
|
hnet_pubkey_profile_b = "0272DA71976234CE833A6907425867B82E074D44EF907DFB4B3E21C1C2256EBCD1" # ID 27 in test file
|
|
|
|
hnet_pubkey_profile_a = "5A8D38864820197C3394B92613B20B91633CBD897119273BF8E4A6F4EEC0A650" # ID 30 in test file
|
|
|
|
|
|
|
|
# TS31.121 4.9.4 EF_SUCI_Calc_Info test file
|
|
|
|
testfile_suci_calc_info = "A006020101020000A14B80011B8121" +hnet_pubkey_profile_b +"80011E8120" +hnet_pubkey_profile_a
|
|
|
|
|
|
|
|
decoded_testfile_suci = {
|
|
|
|
'prot_scheme_id_list': [
|
|
|
|
{'priority': 0, 'identifier': 2, 'key_index': 1},
|
|
|
|
{'priority': 1, 'identifier': 1, 'key_index': 2},
|
|
|
|
{'priority': 2, 'identifier': 0, 'key_index': 0}],
|
|
|
|
'hnet_pubkey_list': [
|
|
|
|
{'hnet_pubkey_identifier': 27, 'hnet_pubkey': hnet_pubkey_profile_b.lower()}, # because h2b/b2h returns all lower-case
|
|
|
|
{'hnet_pubkey_identifier': 30, 'hnet_pubkey': hnet_pubkey_profile_a.lower()}]
|
|
|
|
}
|
2018-12-04 18:40:08 +00:00
|
|
|
|
|
|
|
def testSplitHexStringToListOf5ByteEntries(self):
|
|
|
|
input_str = "ffffff0003ffffff0002ffffff0001"
|
|
|
|
expected = [
|
|
|
|
"ffffff0003",
|
|
|
|
"ffffff0002",
|
|
|
|
"ffffff0001",
|
|
|
|
]
|
2020-09-18 13:32:20 +00:00
|
|
|
self.assertEqual(utils.hexstr_to_Nbytearr(input_str, 5), expected)
|
2018-12-04 18:40:08 +00:00
|
|
|
|
|
|
|
def testDecMCCfromPLMN(self):
|
|
|
|
self.assertEqual(utils.dec_mcc_from_plmn("92f501"), 295)
|
|
|
|
|
|
|
|
def testDecMCCfromPLMN_unused(self):
|
|
|
|
self.assertEqual(utils.dec_mcc_from_plmn("ff0f00"), 4095)
|
|
|
|
|
|
|
|
def testDecMNCfromPLMN_twoDigitMNC(self):
|
|
|
|
self.assertEqual(utils.dec_mnc_from_plmn("92f501"), 10)
|
|
|
|
|
|
|
|
def testDecMNCfromPLMN_threeDigitMNC(self):
|
|
|
|
self.assertEqual(utils.dec_mnc_from_plmn("031263"), 361)
|
|
|
|
|
|
|
|
def testDecMNCfromPLMN_unused(self):
|
|
|
|
self.assertEqual(utils.dec_mnc_from_plmn("00f0ff"), 4095)
|
|
|
|
|
2021-03-11 23:34:10 +00:00
|
|
|
def test_enc_plmn(self):
|
|
|
|
with self.subTest("2-digit MCC"):
|
|
|
|
self.assertEqual(utils.enc_plmn("001", "01F"), "00F110")
|
|
|
|
self.assertEqual(utils.enc_plmn("001", "01"), "00F110")
|
|
|
|
self.assertEqual(utils.enc_plmn("295", "10"), "92F501")
|
|
|
|
|
|
|
|
with self.subTest("3-digit MCC"):
|
|
|
|
self.assertEqual(utils.enc_plmn("001", "001"), "001100")
|
|
|
|
self.assertEqual(utils.enc_plmn("302", "361"), "031263")
|
|
|
|
|
2018-12-04 18:40:08 +00:00
|
|
|
def testDecAct_noneSet(self):
|
|
|
|
self.assertEqual(utils.dec_act("0000"), [])
|
|
|
|
|
|
|
|
def testDecAct_onlyUtran(self):
|
|
|
|
self.assertEqual(utils.dec_act("8000"), ["UTRAN"])
|
|
|
|
|
|
|
|
def testDecAct_onlyEUtran(self):
|
|
|
|
self.assertEqual(utils.dec_act("4000"), ["E-UTRAN"])
|
|
|
|
|
|
|
|
def testDecAct_onlyGsm(self):
|
|
|
|
self.assertEqual(utils.dec_act("0080"), ["GSM"])
|
|
|
|
|
|
|
|
def testDecAct_onlyGsmCompact(self):
|
|
|
|
self.assertEqual(utils.dec_act("0040"), ["GSM COMPACT"])
|
|
|
|
|
|
|
|
def testDecAct_onlyCdma2000HRPD(self):
|
|
|
|
self.assertEqual(utils.dec_act("0020"), ["cdma2000 HRPD"])
|
|
|
|
|
|
|
|
def testDecAct_onlyCdma20001xRTT(self):
|
|
|
|
self.assertEqual(utils.dec_act("0010"), ["cdma2000 1xRTT"])
|
|
|
|
|
|
|
|
def testDecAct_allSet(self):
|
|
|
|
self.assertEqual(utils.dec_act("ffff"), ["UTRAN", "E-UTRAN", "GSM", "GSM COMPACT", "cdma2000 HRPD", "cdma2000 1xRTT"])
|
|
|
|
|
|
|
|
def testDecxPlmn_w_act(self):
|
|
|
|
expected = {'mcc': 295, 'mnc': 10, 'act': ["UTRAN"]}
|
|
|
|
self.assertEqual(utils.dec_xplmn_w_act("92f5018000"), expected)
|
|
|
|
|
|
|
|
def testFormatxPlmn_w_act(self):
|
|
|
|
input_str = "92f501800092f5508000ffffff0000ffffff0000ffffff0000ffffff0000ffffff0000ffffff0000ffffff0000ffffff0000"
|
2021-03-12 00:12:11 +00:00
|
|
|
expected = "\t92f5018000 # MCC: 295 MNC: 010 AcT: UTRAN\n"
|
|
|
|
expected += "\t92f5508000 # MCC: 295 MNC: 005 AcT: UTRAN\n"
|
|
|
|
expected += "\tffffff0000 # unused\n"
|
|
|
|
expected += "\tffffff0000 # unused\n"
|
|
|
|
expected += "\tffffff0000 # unused\n"
|
|
|
|
expected += "\tffffff0000 # unused\n"
|
|
|
|
expected += "\tffffff0000 # unused\n"
|
|
|
|
expected += "\tffffff0000 # unused\n"
|
|
|
|
expected += "\tffffff0000 # unused\n"
|
|
|
|
expected += "\tffffff0000 # unused\n"
|
2018-12-04 18:40:08 +00:00
|
|
|
self.assertEqual(utils.format_xplmn_w_act(input_str), expected)
|
|
|
|
|
2021-04-01 14:15:28 +00:00
|
|
|
|
|
|
|
def testDecodeSuciCalcInfo(self):
|
|
|
|
suci_calc_info = EF_SUCI_Calc_Info()
|
|
|
|
decoded = suci_calc_info._decode_hex(self.testfile_suci_calc_info)
|
|
|
|
self.assertDictEqual(self.decoded_testfile_suci, decoded)
|
|
|
|
|
|
|
|
def testEncodeSuciCalcInfo(self):
|
|
|
|
suci_calc_info = EF_SUCI_Calc_Info()
|
|
|
|
encoded = suci_calc_info._encode_hex(self.decoded_testfile_suci)
|
|
|
|
self.assertEqual(encoded.lower(), self.testfile_suci_calc_info.lower())
|
|
|
|
|
2021-04-20 20:38:21 +00:00
|
|
|
def testEnc_msisdn(self):
|
|
|
|
msisdn_encoded = utils.enc_msisdn("+4916012345678", npi=0x01, ton=0x03)
|
|
|
|
self.assertEqual(msisdn_encoded, "0891946110325476f8ffffffffff")
|
|
|
|
msisdn_encoded = utils.enc_msisdn("123456", npi=0x01, ton=0x03)
|
|
|
|
self.assertEqual(msisdn_encoded, "04b1214365ffffffffffffffffff")
|
|
|
|
msisdn_encoded = utils.enc_msisdn("12345678901234567890", npi=0x01, ton=0x03)
|
|
|
|
self.assertEqual(msisdn_encoded, "0bb121436587092143658709ffff")
|
|
|
|
msisdn_encoded = utils.enc_msisdn("+12345678901234567890", npi=0x01, ton=0x03)
|
|
|
|
self.assertEqual(msisdn_encoded, "0b9121436587092143658709ffff")
|
|
|
|
msisdn_encoded = utils.enc_msisdn("", npi=0x01, ton=0x03)
|
|
|
|
self.assertEqual(msisdn_encoded, "ffffffffffffffffffffffffffff")
|
|
|
|
msisdn_encoded = utils.enc_msisdn("+", npi=0x01, ton=0x03)
|
|
|
|
self.assertEqual(msisdn_encoded, "ffffffffffffffffffffffffffff")
|
|
|
|
|
|
|
|
def testDec_msisdn(self):
|
|
|
|
msisdn_decoded = utils.dec_msisdn("0891946110325476f8ffffffffff")
|
|
|
|
self.assertEqual(msisdn_decoded, (1, 1, "+4916012345678"))
|
|
|
|
msisdn_decoded = utils.dec_msisdn("04b1214365ffffffffffffffffff")
|
|
|
|
self.assertEqual(msisdn_decoded, (1, 3, "123456"))
|
|
|
|
msisdn_decoded = utils.dec_msisdn("0bb121436587092143658709ffff")
|
|
|
|
self.assertEqual(msisdn_decoded, (1, 3, "12345678901234567890"))
|
|
|
|
msisdn_decoded = utils.dec_msisdn("ffffffffffffffffffffffffffff")
|
|
|
|
self.assertEqual(msisdn_decoded, None)
|
|
|
|
msisdn_decoded = utils.dec_msisdn("00112233445566778899AABBCCDDEEFF001122330bb121436587092143658709ffff")
|
|
|
|
self.assertEqual(msisdn_decoded, (1, 3, "12345678901234567890"))
|
|
|
|
msisdn_decoded = utils.dec_msisdn("ffffffffffffffffffffffffffffffffffffffff0bb121436587092143658709ffff")
|
|
|
|
self.assertEqual(msisdn_decoded, (1, 3, "12345678901234567890"))
|
|
|
|
|
2018-12-04 18:40:08 +00:00
|
|
|
if __name__ == "__main__":
|
|
|
|
unittest.main()
|