MCPcopy Index your code
hub / github.com/petertodd/python-bitcoinlib / test

Method test

bitcoin/tests/test_wallet.py:285–335  ·  view source on GitHub ↗
(self)

Source from the content-addressed store, hash-verified

283
284class Test_RFC6979(unittest.TestCase):
285 def test(self):
286 if not is_libsec256k1_available():
287 return
288
289 use_libsecp256k1_for_signing(True)
290
291 # Test Vectors for RFC 6979 ECDSA, secp256k1, SHA-256
292 # (private key, message, expected k, expected signature)
293 test_vectors = [
294 (0x1, "Satoshi Nakamoto", 0x8F8A276C19F4149656B280621E358CCE24F5F52542772691EE69063B74F15D15, "934b1ea10a4b3c1757e2b0c017d0b6143ce3c9a7e6a4a49860d7a6ab210ee3d82442ce9d2b916064108014783e923ec36b49743e2ffa1c4496f01a512aafd9e5"),
295 (0x1, "All those moments will be lost in time, like tears in rain. Time to die...", 0x38AA22D72376B4DBC472E06C3BA403EE0A394DA63FC58D88686C611ABA98D6B3, "8600dbd41e348fe5c9465ab92d23e3db8b98b873beecd930736488696438cb6b547fe64427496db33bf66019dacbf0039c04199abb0122918601db38a72cfc21"),
296 (0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFEBAAEDCE6AF48A03BBFD25E8CD0364140, "Satoshi Nakamoto", 0x33A19B60E25FB6F4435AF53A3D42D493644827367E6453928554F43E49AA6F90, "fd567d121db66e382991534ada77a6bd3106f0a1098c231e47993447cd6af2d06b39cd0eb1bc8603e159ef5c20a5c8ad685a45b06ce9bebed3f153d10d93bed5"),
297 (0xf8b8af8ce3c7cca5e300d33939540c10d45ce001b8f252bfbc57ba0342904181, "Alan Turing", 0x525A82B70E67874398067543FD84C83D30C175FDC45FDEEE082FE13B1D7CFDF1, "7063ae83e7f62bbb171798131b4a0564b956930092b33b07b395615d9ec7e15c58dfcc1e00a35e1572f366ffe34ba0fc47db1e7189759b9fb233c5b05ab388ea"),
298 (0xe91671c46231f833a6406ccbea0e3e392c76c167bac1cb013f6f1013980455c2, "There is a computer disease that anybody who works with computers knows about. It's a very serious disease and it interferes completely with the work. The trouble with computers is that you 'play' with them!", 0x1F4B84C23A86A221D233F2521BE018D9318639D5B8BBD6374A8A59232D16AD3D, "b552edd27580141f3b2a5463048cb7cd3e047b97c9f98076c32dbdf85a68718b279fa72dd19bfae05577e06c7c0c1900c371fcd5893f7e1d56a37d30174671f6")
299 ]
300 for vector in test_vectors:
301 secret = CBitcoinSecret.from_secret_bytes(x('{:064x}'.format(vector[0])))
302 encoded_sig = secret.sign(hashlib.sha256(vector[1].encode('utf8')).digest())
303
304 assert(encoded_sig[0] == 0x30)
305 assert(encoded_sig[1] == len(encoded_sig)-2)
306 assert(encoded_sig[2] == 0x02)
307
308 rlen = encoded_sig[3]
309 rpos = 4
310 assert(rlen in (32, 33))
311
312 if rlen == 33:
313 assert(encoded_sig[rpos] == 0)
314 rpos += 1
315 rlen -= 1
316
317 rval = encoded_sig[rpos:rpos+rlen]
318 spos = rpos+rlen
319 assert(encoded_sig[spos] == 0x02)
320
321 spos += 1
322 slen = encoded_sig[spos]
323 assert(slen in (32, 33))
324
325 spos += 1
326 if slen == 33:
327 assert(encoded_sig[spos] == 0)
328 spos += 1
329 slen -= 1
330
331 sval = encoded_sig[spos:spos+slen]
332 sig = b2x(rval + sval)
333 assert(str(sig) == vector[3])
334
335 use_libsecp256k1_for_signing(False)

Callers

nothing calls this directly

Calls 6

is_libsec256k1_availableFunction · 0.90
xFunction · 0.90
b2xFunction · 0.90
from_secret_bytesMethod · 0.80
signMethod · 0.45

Tested by

no test coverage detected