Add stoffu fixes to rename

release-v0.2.1.0
jwinterm 6 years ago
parent be6320b1a2
commit 3c4e299b34

@ -10167,13 +10167,13 @@ std::string wallet2::make_uri(const std::string &address, const std::string &pay
//---------------------------------------------------------------------------------------------------- //----------------------------------------------------------------------------------------------------
bool wallet2::parse_uri(const std::string &uri, std::string &address, std::string &payment_id, uint64_t &amount, std::string &tx_description, std::string &recipient_name, std::vector<std::string> &unknown_parameters, std::string &error) bool wallet2::parse_uri(const std::string &uri, std::string &address, std::string &payment_id, uint64_t &amount, std::string &tx_description, std::string &recipient_name, std::vector<std::string> &unknown_parameters, std::string &error)
{ {
if (uri.substr(0, 7) != "wownero:") if (uri.substr(0, 8) != "wownero:")
{ {
error = std::string("URI has wrong scheme (expected \"wownero:\"): ") + uri; error = std::string("URI has wrong scheme (expected \"wownero:\"): ") + uri;
return false; return false;
} }
std::string remainder = uri.substr(7); std::string remainder = uri.substr(8);
const char *ptr = strchr(remainder.c_str(), '?'); const char *ptr = strchr(remainder.c_str(), '?');
address = ptr ? remainder.substr(0, ptr-remainder.c_str()) : remainder; address = ptr ? remainder.substr(0, ptr-remainder.c_str()) : remainder;

@ -48,7 +48,7 @@ TEST(uri, empty_string)
TEST(uri, no_scheme) TEST(uri, no_scheme)
{ {
PARSE_URI("monero", false); PARSE_URI("wownero", false);
} }
TEST(uri, bad_scheme) TEST(uri, bad_scheme)
@ -58,75 +58,75 @@ TEST(uri, bad_scheme)
TEST(uri, scheme_not_first) TEST(uri, scheme_not_first)
{ {
PARSE_URI(" monero:", false); PARSE_URI(" wownero:", false);
} }
TEST(uri, no_body) TEST(uri, no_body)
{ {
PARSE_URI("monero:", false); PARSE_URI("wownero:", false);
} }
TEST(uri, no_address) TEST(uri, no_address)
{ {
PARSE_URI("monero:?", false); PARSE_URI("wownero:?", false);
} }
TEST(uri, bad_address) TEST(uri, bad_address)
{ {
PARSE_URI("monero:44444", false); PARSE_URI("wownero:44444", false);
} }
TEST(uri, good_address) TEST(uri, good_address)
{ {
PARSE_URI("monero:" TEST_ADDRESS, true); PARSE_URI("wownero:" TEST_ADDRESS, true);
ASSERT_EQ(address, TEST_ADDRESS); ASSERT_EQ(address, TEST_ADDRESS);
} }
TEST(uri, good_integrated_address) TEST(uri, good_integrated_address)
{ {
PARSE_URI("monero:" TEST_INTEGRATED_ADDRESS, true); PARSE_URI("wownero:" TEST_INTEGRATED_ADDRESS, true);
} }
TEST(uri, parameter_without_inter) TEST(uri, parameter_without_inter)
{ {
PARSE_URI("monero:" TEST_ADDRESS"&amount=1", false); PARSE_URI("wownero:" TEST_ADDRESS"&amount=1", false);
} }
TEST(uri, parameter_without_equals) TEST(uri, parameter_without_equals)
{ {
PARSE_URI("monero:" TEST_ADDRESS"?amount", false); PARSE_URI("wownero:" TEST_ADDRESS"?amount", false);
} }
TEST(uri, parameter_without_value) TEST(uri, parameter_without_value)
{ {
PARSE_URI("monero:" TEST_ADDRESS"?tx_amount=", false); PARSE_URI("wownero:" TEST_ADDRESS"?tx_amount=", false);
} }
TEST(uri, negative_amount) TEST(uri, negative_amount)
{ {
PARSE_URI("monero:" TEST_ADDRESS"?tx_amount=-1", false); PARSE_URI("wownero:" TEST_ADDRESS"?tx_amount=-1", false);
} }
TEST(uri, bad_amount) TEST(uri, bad_amount)
{ {
PARSE_URI("monero:" TEST_ADDRESS"?tx_amount=alphanumeric", false); PARSE_URI("wownero:" TEST_ADDRESS"?tx_amount=alphanumeric", false);
} }
TEST(uri, duplicate_parameter) TEST(uri, duplicate_parameter)
{ {
PARSE_URI("monero:" TEST_ADDRESS"?tx_amount=1&tx_amount=1", false); PARSE_URI("wownero:" TEST_ADDRESS"?tx_amount=1&tx_amount=1", false);
} }
TEST(uri, unknown_parameter) TEST(uri, unknown_parameter)
{ {
PARSE_URI("monero:" TEST_ADDRESS"?unknown=1", true); PARSE_URI("wownero:" TEST_ADDRESS"?unknown=1", true);
ASSERT_EQ(unknown_parameters.size(), 1); ASSERT_EQ(unknown_parameters.size(), 1);
ASSERT_EQ(unknown_parameters[0], "unknown=1"); ASSERT_EQ(unknown_parameters[0], "unknown=1");
} }
TEST(uri, unknown_parameters) TEST(uri, unknown_parameters)
{ {
PARSE_URI("monero:" TEST_ADDRESS"?tx_amount=1&unknown=1&tx_description=desc&foo=bar", true); PARSE_URI("wownero:" TEST_ADDRESS"?tx_amount=1&unknown=1&tx_description=desc&foo=bar", true);
ASSERT_EQ(unknown_parameters.size(), 2); ASSERT_EQ(unknown_parameters.size(), 2);
ASSERT_EQ(unknown_parameters[0], "unknown=1"); ASSERT_EQ(unknown_parameters[0], "unknown=1");
ASSERT_EQ(unknown_parameters[1], "foo=bar"); ASSERT_EQ(unknown_parameters[1], "foo=bar");
@ -134,84 +134,84 @@ TEST(uri, unknown_parameters)
TEST(uri, empty_payment_id) TEST(uri, empty_payment_id)
{ {
PARSE_URI("monero:" TEST_ADDRESS"?tx_payment_id=", false); PARSE_URI("wownero:" TEST_ADDRESS"?tx_payment_id=", false);
} }
TEST(uri, bad_payment_id) TEST(uri, bad_payment_id)
{ {
PARSE_URI("monero:" TEST_ADDRESS"?tx_payment_id=1234567890", false); PARSE_URI("wownero:" TEST_ADDRESS"?tx_payment_id=1234567890", false);
} }
TEST(uri, short_payment_id) TEST(uri, short_payment_id)
{ {
PARSE_URI("monero:" TEST_ADDRESS"?tx_payment_id=1234567890123456", true); PARSE_URI("wownero:" TEST_ADDRESS"?tx_payment_id=1234567890123456", true);
ASSERT_EQ(address, TEST_ADDRESS); ASSERT_EQ(address, TEST_ADDRESS);
ASSERT_EQ(payment_id, "1234567890123456"); ASSERT_EQ(payment_id, "1234567890123456");
} }
TEST(uri, long_payment_id) TEST(uri, long_payment_id)
{ {
PARSE_URI("monero:" TEST_ADDRESS"?tx_payment_id=1234567890123456789012345678901234567890123456789012345678901234", true); PARSE_URI("wownero:" TEST_ADDRESS"?tx_payment_id=1234567890123456789012345678901234567890123456789012345678901234", true);
ASSERT_EQ(address, TEST_ADDRESS); ASSERT_EQ(address, TEST_ADDRESS);
ASSERT_EQ(payment_id, "1234567890123456789012345678901234567890123456789012345678901234"); ASSERT_EQ(payment_id, "1234567890123456789012345678901234567890123456789012345678901234");
} }
TEST(uri, payment_id_with_integrated_address) TEST(uri, payment_id_with_integrated_address)
{ {
PARSE_URI("monero:" TEST_INTEGRATED_ADDRESS"?tx_payment_id=1234567890123456", false); PARSE_URI("wownero:" TEST_INTEGRATED_ADDRESS"?tx_payment_id=1234567890123456", false);
} }
TEST(uri, empty_description) TEST(uri, empty_description)
{ {
PARSE_URI("monero:" TEST_ADDRESS"?tx_description=", true); PARSE_URI("wownero:" TEST_ADDRESS"?tx_description=", true);
ASSERT_EQ(description, ""); ASSERT_EQ(description, "");
} }
TEST(uri, empty_recipient_name) TEST(uri, empty_recipient_name)
{ {
PARSE_URI("monero:" TEST_ADDRESS"?recipient_name=", true); PARSE_URI("wownero:" TEST_ADDRESS"?recipient_name=", true);
ASSERT_EQ(recipient_name, ""); ASSERT_EQ(recipient_name, "");
} }
TEST(uri, non_empty_description) TEST(uri, non_empty_description)
{ {
PARSE_URI("monero:" TEST_ADDRESS"?tx_description=foo", true); PARSE_URI("wownero:" TEST_ADDRESS"?tx_description=foo", true);
ASSERT_EQ(description, "foo"); ASSERT_EQ(description, "foo");
} }
TEST(uri, non_empty_recipient_name) TEST(uri, non_empty_recipient_name)
{ {
PARSE_URI("monero:" TEST_ADDRESS"?recipient_name=foo", true); PARSE_URI("wownero:" TEST_ADDRESS"?recipient_name=foo", true);
ASSERT_EQ(recipient_name, "foo"); ASSERT_EQ(recipient_name, "foo");
} }
TEST(uri, url_encoding) TEST(uri, url_encoding)
{ {
PARSE_URI("monero:" TEST_ADDRESS"?tx_description=foo%20bar", true); PARSE_URI("wownero:" TEST_ADDRESS"?tx_description=foo%20bar", true);
ASSERT_EQ(description, "foo bar"); ASSERT_EQ(description, "foo bar");
} }
TEST(uri, non_alphanumeric_url_encoding) TEST(uri, non_alphanumeric_url_encoding)
{ {
PARSE_URI("monero:" TEST_ADDRESS"?tx_description=foo%2x", true); PARSE_URI("wownero:" TEST_ADDRESS"?tx_description=foo%2x", true);
ASSERT_EQ(description, "foo%2x"); ASSERT_EQ(description, "foo%2x");
} }
TEST(uri, truncated_url_encoding) TEST(uri, truncated_url_encoding)
{ {
PARSE_URI("monero:" TEST_ADDRESS"?tx_description=foo%2", true); PARSE_URI("wownero:" TEST_ADDRESS"?tx_description=foo%2", true);
ASSERT_EQ(description, "foo%2"); ASSERT_EQ(description, "foo%2");
} }
TEST(uri, percent_without_url_encoding) TEST(uri, percent_without_url_encoding)
{ {
PARSE_URI("monero:" TEST_ADDRESS"?tx_description=foo%", true); PARSE_URI("wownero:" TEST_ADDRESS"?tx_description=foo%", true);
ASSERT_EQ(description, "foo%"); ASSERT_EQ(description, "foo%");
} }
TEST(uri, url_encoded_once) TEST(uri, url_encoded_once)
{ {
PARSE_URI("monero:" TEST_ADDRESS"?tx_description=foo%2020", true); PARSE_URI("wownero:" TEST_ADDRESS"?tx_description=foo%2020", true);
ASSERT_EQ(description, "foo 20"); ASSERT_EQ(description, "foo 20");
} }

Loading…
Cancel
Save