mirror of
https://github.com/wpilibsuite/allwpilib
synced 2026-06-19 00:41:43 +00:00
Prepare wpiutil for merge into allwpilib.
This commit is contained in:
105
wpiutil/src/test/native/cpp/Base64Test.cpp
Normal file
105
wpiutil/src/test/native/cpp/Base64Test.cpp
Normal file
@@ -0,0 +1,105 @@
|
||||
/*----------------------------------------------------------------------------*/
|
||||
/* Copyright (c) 2015-2018 FIRST. All Rights Reserved. */
|
||||
/* Open Source Software - may be modified and shared by FRC teams. The code */
|
||||
/* must be accompanied by the FIRST BSD license file in the root directory of */
|
||||
/* the project. */
|
||||
/*----------------------------------------------------------------------------*/
|
||||
|
||||
#include "gtest/gtest.h"
|
||||
#include "llvm/SmallString.h"
|
||||
#include "support/Base64.h"
|
||||
|
||||
namespace wpi {
|
||||
|
||||
struct Base64TestParam {
|
||||
int plain_len;
|
||||
const char* plain;
|
||||
const char* encoded;
|
||||
};
|
||||
|
||||
std::ostream& operator<<(std::ostream& os, const Base64TestParam& param) {
|
||||
os << "Base64TestParam(Len: " << param.plain_len << ", "
|
||||
<< "Plain: \"" << param.plain << "\", "
|
||||
<< "Encoded: \"" << param.encoded << "\")";
|
||||
return os;
|
||||
}
|
||||
|
||||
class Base64Test : public ::testing::TestWithParam<Base64TestParam> {
|
||||
protected:
|
||||
llvm::StringRef GetPlain() {
|
||||
if (GetParam().plain_len < 0)
|
||||
return llvm::StringRef(GetParam().plain);
|
||||
else
|
||||
return llvm::StringRef(GetParam().plain, GetParam().plain_len);
|
||||
}
|
||||
};
|
||||
|
||||
TEST_P(Base64Test, EncodeStdString) {
|
||||
std::string s;
|
||||
Base64Encode(GetPlain(), &s);
|
||||
ASSERT_EQ(GetParam().encoded, s);
|
||||
|
||||
// text already in s
|
||||
Base64Encode(GetPlain(), &s);
|
||||
ASSERT_EQ(GetParam().encoded, s);
|
||||
}
|
||||
|
||||
TEST_P(Base64Test, EncodeSmallString) {
|
||||
llvm::SmallString<128> buf;
|
||||
ASSERT_EQ(GetParam().encoded, Base64Encode(GetPlain(), buf));
|
||||
// reuse buf
|
||||
ASSERT_EQ(GetParam().encoded, Base64Encode(GetPlain(), buf));
|
||||
}
|
||||
|
||||
TEST_P(Base64Test, DecodeStdString) {
|
||||
std::string s;
|
||||
llvm::StringRef encoded = GetParam().encoded;
|
||||
EXPECT_EQ(encoded.size(), Base64Decode(encoded, &s));
|
||||
ASSERT_EQ(GetPlain(), s);
|
||||
|
||||
// text already in s
|
||||
Base64Decode(encoded, &s);
|
||||
ASSERT_EQ(GetPlain(), s);
|
||||
}
|
||||
|
||||
TEST_P(Base64Test, DecodeSmallString) {
|
||||
llvm::SmallString<128> buf;
|
||||
llvm::StringRef encoded = GetParam().encoded;
|
||||
size_t len;
|
||||
llvm::StringRef plain = Base64Decode(encoded, &len, buf);
|
||||
EXPECT_EQ(encoded.size(), len);
|
||||
ASSERT_EQ(GetPlain(), plain);
|
||||
|
||||
// reuse buf
|
||||
plain = Base64Decode(encoded, &len, buf);
|
||||
ASSERT_EQ(GetPlain(), plain);
|
||||
}
|
||||
|
||||
static Base64TestParam sample[] = {
|
||||
{-1, "Send reinforcements", "U2VuZCByZWluZm9yY2VtZW50cw=="},
|
||||
{-1, "Now is the time for all good coders\n to learn C++",
|
||||
"Tm93IGlzIHRoZSB0aW1lIGZvciBhbGwgZ29vZCBjb2RlcnMKIHRvIGxlYXJuIEMrKw=="},
|
||||
{-1,
|
||||
"This is line one\nThis is line two\nThis is line three\nAnd so on...\n",
|
||||
"VGhpcyBpcyBsaW5lIG9uZQpUaGlzIGlzIGxpbmUgdHdvClRoaXMgaXMgbGluZSB0aHJlZQpBb"
|
||||
"mQgc28gb24uLi4K"},
|
||||
};
|
||||
|
||||
INSTANTIATE_TEST_CASE_P(Base64Sample, Base64Test,
|
||||
::testing::ValuesIn(sample), );
|
||||
|
||||
static Base64TestParam standard[] = {
|
||||
{0, "", ""},
|
||||
{1, "\0", "AA=="},
|
||||
{2, "\0\0", "AAA="},
|
||||
{3, "\0\0\0", "AAAA"},
|
||||
{1, "\377", "/w=="},
|
||||
{2, "\377\377", "//8="},
|
||||
{3, "\377\377\377", "////"},
|
||||
{2, "\xff\xef", "/+8="},
|
||||
};
|
||||
|
||||
INSTANTIATE_TEST_CASE_P(Base64Standard, Base64Test,
|
||||
::testing::ValuesIn(standard), );
|
||||
|
||||
} // namespace wpi
|
||||
Reference in New Issue
Block a user