Skip to content
Snippets Groups Projects
Select Git revision
  • 6fc41d0e937f34da97588a6e687733454c202de4
  • master default protected
  • network/gtest-1000 protected
  • upgradable-multisig
  • runtime/gtest-1000
  • network/gdev-800 protected
  • cgeek/issue-297-cpu
  • gdev-800-tests
  • update-docker-compose-rpc-squid-names
  • fix-252
  • 1000i100-test
  • hugo/tmp-0.9.1
  • network/gdev-803 protected
  • hugo/endpoint-gossip
  • network/gdev-802 protected
  • hugo/distance-precompute
  • network/gdev-900 protected
  • tuxmain/anonymous-tx
  • debug/podman
  • hugo/195-doc
  • hugo/195-graphql-schema
  • gtest-1000-0.11.0 protected
  • gtest-1000 protected
  • gdev-900-0.10.1 protected
  • gdev-900-0.10.0 protected
  • gdev-900-0.9.2 protected
  • gdev-800-0.8.0 protected
  • gdev-900-0.9.1 protected
  • gdev-900-0.9.0 protected
  • gdev-803 protected
  • gdev-802 protected
  • runtime-801 protected
  • gdev-800 protected
  • runtime-800-bis protected
  • runtime-800 protected
  • runtime-800-backup protected
  • runtime-701 protected
  • runtime-700 protected
  • runtime-600 protected
  • runtime-500 protected
  • v0.4.1 protected
41 results

weights-benchmarking.md

Blame
  • test_signing.py 2.84 KiB
    from __future__ import division
    
    import binascii
    import codecs
    import os
    
    import pytest
    
    import nacl
    import nacl.encoding
    import nacl.nacl
    
    
    def ed25519_known_answers():
        # Known answers taken from: http://ed25519.cr.yp.to/python/sign.input
        answers = []
    
        path = os.path.join(os.path.dirname(__file__), "data", "ed25519")
        with codecs.open(path, "r", encoding="utf-8") as fp:
            for line in fp:
                x = line.split(":")
                answers.append({
                    "seed": x[0][0:64].encode("ascii"),
                    "public_key": x[1].encode("ascii"),
                    "message": x[2].encode("ascii"),
                    "signed": x[3].encode("ascii"),
                    "signature": binascii.hexlify(binascii.unhexlify(x[3].encode("ascii"))[:64]),
                })
    
        return answers
    
    
    class TestSigningKey:
    
        def test_initialize_with_generate(self):
            nacl.signing.SigningKey.generate()
    
        @pytest.mark.parametrize("seed", [
            b"77076d0a7318a57d3c16c17251b26645df4c2f87ebc0992ab177fba51db92c2a",
        ])
        def test_initialization_with_seed(self, seed):
            nacl.signing.SigningKey(seed, encoder=nacl.encoding.HexEncoder)
    
        @pytest.mark.parametrize(("seed", "message", "signature", "expected"),
                [(x["seed"], x["message"], x["signature"], x["signed"])
                    for x in ed25519_known_answers()]
            )
        def test_message_signing(self, seed, message, signature, expected):
            signing_key = nacl.signing.SigningKey(seed, encoder=nacl.encoding.HexEncoder)
            signed = signing_key.sign(binascii.unhexlify(message), encoder=nacl.encoding.HexEncoder)
    
            assert signed == expected
            assert signed.message == message
            assert signed.signature == signature
    
    
    class TestVerifyKey:
    
        @pytest.mark.parametrize(("public_key", "signed", "message", "signature"),
            [(x["public_key"], x["signed"], x["message"], x["signature"]) for x in ed25519_known_answers()]
        )
        def test_valid_signed_message(self, public_key, signed, message, signature):
            key = nacl.signing.VerifyKey(public_key, encoder=nacl.encoding.HexEncoder)
    
            assert binascii.hexlify(key.verify(signed, encoder=nacl.encoding.HexEncoder)) == message
            assert binascii.hexlify(key.verify(message, signature, encoder=nacl.encoding.HexEncoder)) == message
    
        def test_invalid_signed_message(self):
            skey = nacl.signing.SigningKey.generate()
            smessage = skey.sign(b"A Test Message!")
            signature, message = smessage.signature, b"A Forged Test Message!"
    
            # Small sanity check
            assert skey.verify_key.verify(smessage)
    
            with pytest.raises(nacl.signing.BadSignatureError):
                skey.verify_key.verify(message, signature)
    
            with pytest.raises(nacl.signing.BadSignatureError):
                forged = nacl.signing.SignedMessage(signature + message)
                skey.verify_key.verify(forged)