diff options
Diffstat (limited to 'u8c-check/src')
-rw-r--r-- | u8c-check/src/test.cc | 118 | ||||
-rw-r--r-- | u8c-check/src/test0.inl | 49 | ||||
-rw-r--r-- | u8c-check/src/test1.inl | 24 |
3 files changed, 191 insertions, 0 deletions
diff --git a/u8c-check/src/test.cc b/u8c-check/src/test.cc new file mode 100644 index 0000000..3f72a1e --- /dev/null +++ b/u8c-check/src/test.cc @@ -0,0 +1,118 @@ +#if defined(NDEBUG) +#undef NDEBUG +#endif + +#include <chrono> /* std::chrono::duration, std::chrono::high_resolution_clock */ +#include <cstdlib> /* EXIT_FAILURE, EXIT_SUCCESS, std::exit */ +#include <cstring> /* std::strcmp */ +#include <iostream> /* std::cerr, std::cout, std::endl */ +#include <limits> /* std::numeric_limits */ +#include <u8c/u8c> + +# include "test0.inl" +# include "test1.inl" + +static_assert(u8c::abs(-0x1) == 0x1); +static_assert(u8c::abs(-0x1p0) == 0x1p0); +static_assert(u8c::abs(-0x100p0) == 0x100p0); + +static_assert(u8c::fma(0x10,0x10,0x100) == 0x200); + +static_assert(!u8c::isinf(0x0)); +static_assert(u8c::isinf(std::numeric_limits<float>::infinity())); + +static_assert(!u8c::isnan(0x0)); +static_assert(u8c::isnan(std::numeric_limits<float>::quiet_NaN())); + +static_assert(u8c::isprime(0x2u)); +static_assert(u8c::isprime(0x3u)); +static_assert(!u8c::isprime(0x4u)); +static_assert(u8c::isprime(0x5u)); +static_assert(!u8c::isprime(0x6u)); +static_assert(u8c::isprime(0x7u)); +static_assert(!u8c::isprime(0x8u)); +static_assert(!u8c::isprime(0x9u)); +static_assert(!u8c::isprime(0xAu)); +static_assert(u8c::isprime(0xBu)); +static_assert(!u8c::isprime(0xCu)); +static_assert(u8c::isprime(0xDu)); +static_assert(!u8c::isprime(0xEu)); +static_assert(!u8c::isprime(0xFu)); + +static_assert(u8c::pow(0x1,0x10000) == 0x1); +static_assert(u8c::pow(0x2,0x2) == 0x4); +static_assert(u8c::pow(0x2,0x4) == 0x10); +static_assert(u8c::pow(0x2,0x10) == 0x10000); +static_assert(u8c::pow(0x3,0x3) == 0x1B); + +static_assert(u8c::quota(0x1,0x3) < u8c::quota<>::inf()); +static_assert(u8c::quota(0x1,0x3) == u8c::quota(0x2,0x6)); +static_assert(u8c::quota<>::inf() == u8c::quota<>::inf()); +static_assert(u8c::quota<>::nan() != u8c::quota<>::nan()); + +static_assert(u8c::trunc(static_cast<u8c::ubyte>(std::numeric_limits<u8c::byte>::max()) + u8c_uint16c(0x1),u8c_bytec(0x0)) == std::numeric_limits<u8c::byte>::min()); + +static_assert(u8c::cstrlen("This is a string!") == 0x11uz); +static_assert(u8c::cstrlen("Das war ein Befehl!") == 0x13uz); + +static_assert(u8c::cstrcmp("Clang","Clang") == u8c_bytec(0x0)); +static_assert(u8c::cstrcmp("Clang","GCC") == u8c_bytec(0x1)); +static_assert(u8c::cstrcmp("GCC","Clang") == u8c_bytec(-0x1)); +static_assert(u8c::cstrcmp("GCC","GCC") == u8c_bytec(0x0)); + +auto main(int const argc,char const * const * const argv) -> int { + int constexpr maxtestn = 0x1; + auto gettestnm = [](int const _n) { + switch (_n) { + [[unlikely]] default: + return "N/A"; + case 0x0: + return "Array Stress-testing"; + case 0x1: + return "Strings"; + } + }; + auto helpscrn = [&](char const * const _prognm) { + std::cout << "u8c-test: Test u8c" << std::endl; + std::cout << "Usage: " << _prognm << " [test number]" << std::endl; + std::cout << std::endl; + std::cout << "Test numbers:" << std::endl; + for (int n = 0x0;n <= maxtestn;n += 0x1) { + std::cout << "\t " << n << " - \"" << gettestnm(n) << "\"" << std::endl; + } + std::cout << std::endl; + std::cout << "u8c version: " << u8c::ver << std::endl; + }; + auto test = [&](int const _n) { + auto const testnm = gettestnm(_n); + std::cout << ":: \u001B[95mTesting\u001B[0m test #" << _n << " \u001B[3m\"" << testnm << "\"\u001B[0m..." << std::endl << std::endl; + auto begin = std::chrono::high_resolution_clock::now(); + switch (_n) { + [[unlikely]] default: + std::exit(EXIT_FAILURE); + case 0x0: + ::test0(); + break; + case 0x1: + ::test1(); + break; + } + auto const end = std::chrono::high_resolution_clock::now(); + std::chrono::duration<double> const tmdiff = end - begin; + std::cout << std::endl << ":: \u001B[96mDone\u001B[0m testing test #" << _n << " \u001B[3m\"" << testnm << "\"\u001B[0m (took " << tmdiff.count() << " seconds)." << std::endl; + }; + if (argc > 0x1) { + if (!std::strcmp(argv[0x1uz],"--help")) { + helpscrn(argv[0x0uz]); + std::exit(EXIT_SUCCESS); + } + else { + std::cerr << "Invalid argument \"\u001B[3m" << argv[0x1uz] << "\"\u001B[0m." << std::endl; + std::exit(EXIT_FAILURE); + } + } + for (int n = 0x0;n <= maxtestn;n += 0x1) { + test(n); + } + std::exit(EXIT_SUCCESS); +} diff --git a/u8c-check/src/test0.inl b/u8c-check/src/test0.inl new file mode 100644 index 0000000..5b4db6c --- /dev/null +++ b/u8c-check/src/test0.inl @@ -0,0 +1,49 @@ +#include <iostream> /* std::cerr, std::endl */ +#include <limits> /* std::numeric_limits */ +#include <random> /* std::random_device, std::uniform_int_distribution */ +#include <u8c/arr> + +auto test0() -> void { + std::cerr << "Constructing array of 256 elements, each with a value of 15..."; + u8c::arr<int> arr(0x100uz,0xF); + u8c_assert(arr.sz() == 0x100uz); + u8c_assert(static_cast<u8c::size>(arr.end() - arr.begin()) == arr.sz()); + for (auto const elm : arr) { + u8c_assert(elm == 0xF); + } + std::cerr << " okay." << std::endl; + std::random_device rd; + { + std::uniform_int_distribution<int> distr(0x0,std::numeric_limits<int>::max()); + for (u8c::byte n = u8c_bytec(0x0);n <= u8c_bytec(0x10);n += u8c_ubytec(0x1)) { + auto const val = distr(rd); + std::cerr << "Filling array with the value of " << val << "..."; + arr.fill(val); + for (auto const elm : arr) { + u8c_assert(elm == val); + } + std::cerr << " okay." << std::endl; + } + } + { + std::uniform_int_distribution<u8c::size> distr(0x1,0xFFF); + for (u8c::byte n = u8c_bytec(0x0);n <= u8c_bytec(0x4);n += u8c_ubytec(0x1)) { + auto const sz = distr(rd); + std::cerr << "Allocating the array to the size of " << sz << "..."; + arr.alloc(sz); + u8c_assert(arr.sz() == sz); + std::cerr << " okay." << std::endl; + } + } + std::cerr << "Doing some additionel tests..."; + arr.alloc(0x2uz); + u8c_assert(arr.sz() == 0x2uz); + arr.fill(0xF); + u8c_assert(arr[0x0uz] == 0xF); + u8c_assert(arr[0x1uz] == 0xF); + arr.realloc(0x4uz); + u8c_assert(arr.sz() == 0x4uz); + u8c_assert(arr[0x0uz] == 0xF); + u8c_assert(arr[0x1uz] == 0xF); + std::cerr << " okay." << std::endl; +} diff --git a/u8c-check/src/test1.inl b/u8c-check/src/test1.inl new file mode 100644 index 0000000..4e2a18e --- /dev/null +++ b/u8c-check/src/test1.inl @@ -0,0 +1,24 @@ +#include <cstdint> /* u8c_uint32c, u8c_ubytec, std::int_fast8_t, u8c::uint32 */ +#include <iomanip> /* std::hex */ +#include <iostream> /* std::cout, std::endl */ +#include <random> /* std::random_device */ + +auto test1() -> void { + std::random_device rd; + std::uniform_int_distribution<char32_t> distr(u8c_uint32c(0x0),u8c_uint32c(0x100)); + for(std::int_fast8_t n = u8c_bytec(0x0);n <= u8c_bytec(0x4);n += u8c_ubytec(0x1)) { + auto const chr = distr(rd); + std::cout << "U+" << std::hex << static_cast<u8c::uint32>(chr) << " (\"" << u8c::uninm(chr) << "\" @ \"" << u8c::uniblk(chr) << "\")" << std::endl; + std::cout << "Is alphanumeric: " << u8c::isalnum(chr) << std::endl; + std::cout << "Is alphabetic: " << u8c::isalpha(chr) << std::endl; + std::cout << "Is control character: " << u8c::iscntrl(chr) << std::endl; + std::cout << "Is digit: " << u8c::isdigit(chr) << std::endl; + std::cout << "Is lowercase: " << u8c::islower(chr) << std::endl; + std::cout << "Is punctuation mark: " << u8c::ispunct(chr) << std::endl; + std::cout << "Is whitespace: " << u8c::isspace(chr) << std::endl; + std::cout << "Is surrogate point: " << u8c::issurro(chr) << std::endl; + std::cout << "Is uppercase: " << u8c::isupper(chr) << std::endl; + std::cout << "Is hexadecimal digit: " << u8c::isxdigit(chr) << std::endl; + std::cout << std::endl; + } +} |