nim-libp2p/tests/testbase58.nim

135 lines
4.6 KiB
Nim
Raw Normal View History

2018-11-24 00:06:06 +02:00
import unittest
import ../libp2p/base58
proc hexToBytes*(a: string, result: var openarray[byte]) =
doAssert(len(a) == 2 * len(result))
var i = 0
var k = 0
var r = 0
if len(a) > 0:
while i < len(a):
let c = a[i]
if i != 0 and i %% 2 == 0:
result[k] = r.byte
r = 0
inc(k)
else:
r = r shl 4
case c
of 'a'..'f':
r = r or (10 + ord(c) - ord('a'))
of 'A'..'F':
r = r or (10 + ord(c) - ord('A'))
of '0'..'9':
r = r or (ord(c) - ord('0'))
else:
doAssert(false)
inc(i)
result[k] = r.byte
proc fromHex*(a: string): seq[byte] =
doAssert(len(a) %% 2 == 0)
if len(a) == 0:
result = newSeq[byte]()
else:
result = newSeq[byte](len(a) div 2)
hexToBytes(a, result)
const TestVectors = [
["", ""],
["61", "2g"],
["626262", "a3gV"],
["636363", "aPEr"],
["73696d706c792061206c6f6e6720737472696e67", "2cFupjhnEsSn59qHXstmK2ffpLv2"],
["00eb15231dfceb60925886b67d065299925915aeb172c06647", "1NS17iag9jJgTHD1VXjvLCEnZuQ3rJDE9L"],
["516b6fcd0f", "ABnLTmg"],
["bf4f89001e670274dd", "3SEo3LWLoPntC"],
["572e4794", "3EFU7m"],
["ecac89cad93923c02321", "EJDM8drfXA6uyA"],
["10c8511e", "Rt5zm"],
["00000000000000000000", "1111111111"],
["000111d38e5fc9071ffcd20b4a763cc9ae4f252bb4e48fd66a835e252ada93ff480d6dd43dc62a641155a5", "123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"],
["000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f303132333435363738393a3b3c3d3e3f404142434445464748494a4b4c4d4e4f505152535455565758595a5b5c5d5e5f606162636465666768696a6b6c6d6e6f707172737475767778797a7b7c7d7e7f808182838485868788898a8b8c8d8e8f909192939495969798999a9b9c9d9e9fa0a1a2a3a4a5a6a7a8a9aaabacadaeafb0b1b2b3b4b5b6b7b8b9babbbcbdbebfc0c1c2c3c4c5c6c7c8c9cacbcccdcecfd0d1d2d3d4d5d6d7d8d9dadbdcdddedfe0e1e2e3e4e5e6e7e8e9eaebecedeeeff0f1f2f3f4f5f6f7f8f9fafbfcfdfeff", "1cWB5HCBdLjAuqGGReWE3R3CguuwSjw6RHn39s2yuDRTS5NsBgNiFpWgAnEx6VQi8csexkgYw3mdYrMHr8x9i7aEwP8kZ7vccXWqKDvGv3u1GxFKPuAkn8JCPPGDMf3vMMnbzm6Nh9zh1gcNsMvH3ZNLmP5fSG6DGbbi2tuwMWPthr4boWwCxf7ewSgNQeacyozhKDDQQ1qL5fQFUW52QKUZDZ5fw3KXNQJMcNTcaB723LchjeKun7MuGW5qyCBZYzA1KjofN1gYBV3NqyhQJ3Ns746GNuf9N2pQPmHz4xpnSrrfCvy6TVVz5d4PdrjeshsWQwpZsZGzvbdAdN8MKV5QsBDY"]
]
suite "BASE58 encoding test suite":
test "Empty seq/string test":
var a = Base58.encode([])
check:
2019-08-04 11:18:23 +03:00
a.isOk == true
len(a.value) == 0
var b = Base58.decode("")
2018-11-24 00:06:06 +02:00
check:
2019-08-04 11:18:23 +03:00
b.isOk == true
len(b.value) == 0
# test "Zero test":
# var s = newString(256)
# for i in 0..255:
# s[i] = '1'
# var buffer: array[256, byte]
# for i in 0..255:
# var a = Base58.encode(buffer.toOpenArray(0, i))
# check a == s[0..i]
# var b = Base58.decode(a)
# check b == buffer[0..i]
# test "Leading zero test":
# var buffer: array[256, byte]
# for i in 0..255:
# buffer[255] = byte(i)
# var a = Base58.encode(buffer)
# var b = Base58.decode(a)
# check:
# equalMem(addr buffer[0], addr b[0], 256) == true
# test "Small amount of bytes test":
# var buffer1: array[1, byte]
# var buffer2: array[2, byte]
# for i in 0..255:
# buffer1[0] = byte(i)
# var enc = Base58.encode(buffer1)
# var dec = Base58.decode(enc)
# check:
# len(dec) == 1
# dec[0] == buffer1[0]
# for i in 0..255:
# for k in 0..255:
# buffer2[0] = byte(i)
# buffer2[1] = byte(k)
# var enc = Base58.encode(buffer2)
# var dec = Base58.decode(enc)
# check:
# len(dec) == 2
# dec[0] == buffer2[0]
# dec[1] == buffer2[1]
# test "Test Vectors test":
# for item in TestVectors:
# var a = fromHex(item[0])
# var enc = Base58.encode(a)
# var dec = Base58.decode(item[1])
# check:
# enc == item[1]
# dec == a
# test "Buffer Overrun test":
# var encres = ""
# var encsize = 0
# var decres: seq[byte] = @[]
# var decsize = 0
# check:
# Base58.encode([0'u8], encres, encsize) == Base58Status.Overrun
# encsize == 1
# Base58.decode("1", decres, decsize) == Base58Status.Overrun
# decsize == 5
# test "Incorrect test":
# var decres = newSeq[byte](10)
# var decsize = 0
# check:
# Base58.decode("l", decres, decsize) == Base58Status.Incorrect
# decsize == 0
# Base58.decode("2l", decres, decsize) == Base58Status.Incorrect
# decsize == 0
# Base58.decode("O", decres, decsize) == Base58Status.Incorrect
# decsize == 0
# Base58.decode("2O", decres, decsize) == Base58Status.Incorrect
# decsize == 0
2018-11-24 00:06:06 +02:00