a portable and fast pairing-based cryptography library
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 
mcl/test/conversion_test.cpp

96 lines
3.2 KiB

#include <cybozu/test.hpp>
#include <mcl/conversion.hpp>
CYBOZU_TEST_AUTO(arrayToDec)
{
const struct {
uint32_t x[5];
size_t xn;
const char *s;
} tbl[] = {
{ { 0, 0, 0, 0, 0 }, 1, "0" },
{ { 9, 0, 0, 0, 0 }, 1, "9" },
{ { 123456789, 0, 0, 0, 0 }, 1, "123456789" },
{ { 2147483647, 0, 0, 0, 0 }, 1, "2147483647" },
{ { 0xffffffff, 0, 0, 0, 0 }, 1, "4294967295" },
{ { 0x540be400, 0x2, 0, 0, 0 }, 2, "10000000000" },
{ { 0xffffffff, 0xffffffff, 0, 0, 0 }, 2, "18446744073709551615" },
{ { 0x89e80001, 0x8ac72304, 0, 0, 0 }, 2, "10000000000000000001" },
{ { 0xc582ca00, 0x8ac72304, 0, 0, 0 }, 2, "10000000001000000000" },
{ { 0, 0, 1, 0, 0 }, 3, "18446744073709551616" },
{ { 0xffffffff, 0xffffffff, 0xffffffff, 0xffffffff, 0 }, 4, "340282366920938463463374607431768211455" },
{ { 0xffffffff, 0xffffffff, 0xffffffff, 0xffffffff, 0xffffffff }, 5, "1461501637330902918203684832716283019655932542975" },
{ { 0x3b9aca00, 0x5e3f3700, 0x1cbfa532, 0x04f6433a, 0xd83ff078 }, 5, "1234567901234560000000000000000000000001000000000" },
};
for (size_t i = 0; i < CYBOZU_NUM_OF_ARRAY(tbl); i++) {
const size_t bufSize = 128;
char buf[bufSize] = {};
const char *str = tbl[i].s;
const uint32_t *x = tbl[i].x;
const size_t strLen = strlen(str);
size_t n = mcl::fp::arrayToDec(buf, bufSize, x, tbl[i].xn);
CYBOZU_TEST_EQUAL(n, strLen);
CYBOZU_TEST_EQUAL_ARRAY(buf + bufSize - n, str, n);
const size_t maxN = 32;
uint32_t xx[maxN] = {};
size_t xn = mcl::fp::decToArray(xx, maxN, str, strLen);
CYBOZU_TEST_EQUAL(xn, tbl[i].xn);
CYBOZU_TEST_EQUAL_ARRAY(xx, x, xn);
}
for (size_t i = 0; i < CYBOZU_NUM_OF_ARRAY(tbl); i++) {
const size_t bufSize = 128;
char buf[bufSize] = {};
const char *str = tbl[i].s;
const size_t strLen = strlen(str);
uint64_t x[8] = {};
size_t xn = (tbl[i].xn + 1) / 2;
memcpy(x, tbl[i].x, tbl[i].xn * sizeof(uint32_t));
size_t n = mcl::fp::arrayToDec(buf, bufSize, x, xn);
CYBOZU_TEST_EQUAL(n, strLen);
CYBOZU_TEST_EQUAL_ARRAY(buf + bufSize - n, str, n);
const size_t maxN = 32;
uint64_t xx[maxN] = {};
size_t xxn = mcl::fp::decToArray(xx, maxN, str, strLen);
CYBOZU_TEST_EQUAL(xxn, xn);
CYBOZU_TEST_EQUAL_ARRAY(xx, x, xn);
}
}
CYBOZU_TEST_AUTO(writeHexStr)
{
const char *hex1tbl = "0123456789abcdef";
const char *hex2tbl = "0123456789ABCDEF";
for (size_t i = 0; i < 16; i++) {
uint8_t v = 0xff;
CYBOZU_TEST_ASSERT(mcl::fp::local::hexCharToUint8(&v, hex1tbl[i]));
CYBOZU_TEST_EQUAL(v, i);
CYBOZU_TEST_ASSERT(mcl::fp::local::hexCharToUint8(&v, hex2tbl[i]));
CYBOZU_TEST_EQUAL(v, i);
}
const struct Tbl {
const char *bin;
size_t n;
const char *hex;
} tbl[] = {
{ "", 0, "" },
{ "\x12\x34\xab", 3, "1234ab" },
{ "\xff\xfc\x00\x12", 4, "fffc0012" },
};
for (size_t i = 0; i < CYBOZU_NUM_OF_ARRAY(tbl); i++) {
char buf[32];
cybozu::MemoryOutputStream os(buf, sizeof(buf));
const char *bin = tbl[i].bin;
const char *hex = tbl[i].hex;
size_t n = tbl[i].n;
bool b;
mcl::fp::writeHexStr(&b, os, bin, n);
CYBOZU_TEST_ASSERT(b);
CYBOZU_TEST_EQUAL(os.getPos(), n * 2);
CYBOZU_TEST_EQUAL_ARRAY(buf, hex, n * 2);
cybozu::MemoryInputStream is(hex, n * 2);
size_t w = mcl::fp::readHexStr(buf, n, is);
CYBOZU_TEST_EQUAL(w, n);
CYBOZU_TEST_EQUAL_ARRAY(buf, bin, n);
}
}