diff --git a/src/smartcard/guid.py b/src/smartcard/guid.py index 294b46f8..0b7b8c3f 100644 --- a/src/smartcard/guid.py +++ b/src/smartcard/guid.py @@ -25,40 +25,21 @@ """ import uuid -# guid is ulong+ushort+ushort+uchar[8] - -def strToGUID(s): +def strToGUID(s: str) -> list[int]: """Converts a GUID string into a list of bytes. >>> strToGUID('{AD4F1667-EA75-4124-84D4-641B3B197C65}') [103, 22, 79, 173, 117, 234, 36, 65, 132, 212, 100, 27, 59, 25, 124, 101] """ - dat = uuid.UUID(hex=s) - dat = list(dat.bytes_le) - return dat + return list(uuid.UUID(s).bytes_le) -def GUIDToStr(g): +def GUIDToStr(g: list[int]) -> str: """Converts a GUID sequence of bytes into a string. >>> GUIDToStr([103,22,79,173, 117,234, 36,65, ... 132, 212, 100, 27, 59, 25, 124, 101]) '{AD4F1667-EA75-4124-84D4-641B3B197C65}' """ - dat = uuid.UUID(bytes_le=bytes(g)) - return '{' + str(dat).upper() + '}' - - -if __name__ == "__main__": - """Small sample illustrating the use of guid.py.""" - guid_in = '{AD4F1667-EA75-4124-84D4-641B3B197C65}' - print(guid_in) - dummycardguid1 = strToGUID(guid_in) - print(dummycardguid1) - guid_out = GUIDToStr(dummycardguid1) - print(guid_out) - if guid_in != guid_out: - print("Failure") - else: - print("Success") + return f"{{{uuid.UUID(bytes_le=bytes(g))}}}".upper() diff --git a/test/test_guid.py b/test/test_guid.py new file mode 100644 index 00000000..aba8e2a1 --- /dev/null +++ b/test/test_guid.py @@ -0,0 +1,13 @@ +from smartcard.guid import GUIDToStr, strToGUID + + +def test_roundtrip_string(): + string = '{AD4F1667-EA75-4124-84D4-641B3B197C65}' + assert GUIDToStr(strToGUID(string)) == string + + +def test_roundtrip_list_of_ints(): + list_of_ints = [ + 103, 22, 79, 173, 117, 234, 36, 65, 132, 212, 100, 27, 59, 25, 124, 101 + ] + assert strToGUID(GUIDToStr(list_of_ints)) == list_of_ints