Skip to content
Snippets Groups Projects
Select Git revision
  • e3b8c707fb5d3432fb0cc7239b7e62fb6e7756f2
  • dev default protected
  • vainamoinen197-transactiondocument-replace-vec-fields-by-smallvec-2
  • dvermd/200-keypairs-dewif
  • elois/wot
  • jawaka/155-dbex-add-dump-fork-tree-command
  • elois/195-bcdbwriteop
  • elois/deps-crypto
  • elois/gva-monetary-mass
  • elois/191-sled
  • elois/195
  • ji_emme/gva-humantimefield
  • 184-gva-rename-commontime-field-to-blockchaintime
  • ji_emme/182-gva-implement-block-meta-data
  • ji_emme/rml14
  • hugo/151-ws2pv2-sync
  • ji_emme/181-gva-implement-identity-request
  • ji_emme/89-implement-client-api-gva-graphql-verification-api
  • logo
  • test-juniper-from-schema
  • elois/exemple-gva-global-context
  • v0.2.0-a4 protected
  • v0.2.0-a2 protected
  • v0.2.0-a protected
  • v0.1.1-a1 protected
  • documents/v0.10.0-b1 protected
  • crypto/v0.4.0-b1 protected
  • crypto/v0.3.0-b3 protected
  • crypto/v0.3.0-b2 protected
  • crypto/v0.3.0-b1 protected
  • wot/v0.8.0-a0.9 protected
  • wot/v0.8.0-a0.8 protected
  • 0.1.0-a0.1 protected
  • v0.0.1-a0.12 protected
  • v0.0.1-a0.11 protected
  • v0.0.1-a0.10 protected
  • v0.0.1-a0.9 protected
  • v0.0.1-a0.8 protected
  • v0.0.1-a0.7 protected
  • v0.0.1-a0.6 protected
  • v0.0.1-a0.5 protected
41 results

lib.rs

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)