Skip to content

Commit 5608e1d

Browse files
committed
Merge bitcoin/bitcoin#27928: test: Add more tests for the BIP21 implementation
f1d807e Add more tests for the BIP21 implementation (Kiminuo) Pull request description: This PR is an attempt to make it clear how the current BIP21 implementation behaves in Bitcoin Core. Especially, I'm interested whether one can specify multiple `amount` (`message`, etc.) parameters. My primary end goal is to answer [this question of mine](https://bitcoin.stackexchange.com/questions/118654/how-to-interpret-bip21-uri-with-amount-specified-twice/) but I figured that maybe it's worth a PR. If not, I'll close the PR. ACKs for top commit: MarcoFalke: lgtm ACK f1d807e kevkevinpal: ACK [f1d807e](bitcoin/bitcoin@f1d807e) Tree-SHA512: d287809d47c5cfc667f850927bfd969bd345a996d3d53a4c26ef0ffd29eb75ef53358692a15f9a0493ec9e1c101123b6584572e25f87bcb98ff67f6b6c166de4
2 parents 4d828ef + f1d807e commit 5608e1d

File tree

1 file changed

+26
-0
lines changed

1 file changed

+26
-0
lines changed

src/qt/test/uritests.cpp

Lines changed: 26 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -58,9 +58,35 @@ void URITests::uriTests()
5858
uri.setUrl(QString("bitcoin:175tWpb8K1S7NmH4Zx6rewF9WQrcZv245W?req-message=Wikipedia Example Address"));
5959
QVERIFY(GUIUtil::parseBitcoinURI(uri, &rv));
6060

61+
// Commas in amounts are not allowed.
6162
uri.setUrl(QString("bitcoin:175tWpb8K1S7NmH4Zx6rewF9WQrcZv245W?amount=1,000&label=Wikipedia Example"));
6263
QVERIFY(!GUIUtil::parseBitcoinURI(uri, &rv));
6364

6465
uri.setUrl(QString("bitcoin:175tWpb8K1S7NmH4Zx6rewF9WQrcZv245W?amount=1,000.0&label=Wikipedia Example"));
6566
QVERIFY(!GUIUtil::parseBitcoinURI(uri, &rv));
67+
68+
// There are two amount specifications. The last value wins.
69+
uri.setUrl(QString("bitcoin:175tWpb8K1S7NmH4Zx6rewF9WQrcZv245W?amount=100&amount=200&label=Wikipedia Example"));
70+
QVERIFY(GUIUtil::parseBitcoinURI(uri, &rv));
71+
QVERIFY(rv.address == QString("175tWpb8K1S7NmH4Zx6rewF9WQrcZv245W"));
72+
QVERIFY(rv.amount == 20000000000LL);
73+
QVERIFY(rv.label == QString("Wikipedia Example"));
74+
75+
// The first amount value is correct. However, the second amount value is not valid. Hence, the URI is not valid.
76+
uri.setUrl(QString("bitcoin:175tWpb8K1S7NmH4Zx6rewF9WQrcZv245W?amount=100&amount=1,000&label=Wikipedia Example"));
77+
QVERIFY(!GUIUtil::parseBitcoinURI(uri, &rv));
78+
79+
// Test label containing a question mark ('?').
80+
uri.setUrl(QString("bitcoin:175tWpb8K1S7NmH4Zx6rewF9WQrcZv245W?amount=100&label=?"));
81+
QVERIFY(GUIUtil::parseBitcoinURI(uri, &rv));
82+
QVERIFY(rv.address == QString("175tWpb8K1S7NmH4Zx6rewF9WQrcZv245W"));
83+
QVERIFY(rv.amount == 10000000000LL);
84+
QVERIFY(rv.label == QString("?"));
85+
86+
// Escape sequences are not supported.
87+
uri.setUrl(QString("bitcoin:175tWpb8K1S7NmH4Zx6rewF9WQrcZv245W?amount=100&label=%3F"));
88+
QVERIFY(GUIUtil::parseBitcoinURI(uri, &rv));
89+
QVERIFY(rv.address == QString("175tWpb8K1S7NmH4Zx6rewF9WQrcZv245W"));
90+
QVERIFY(rv.amount == 10000000000LL);
91+
QVERIFY(rv.label == QString("%3F"));
6692
}

0 commit comments

Comments
 (0)