Skip to content
Snippets Groups Projects
Select Git revision
  • fc42dee0b4c2337252c4c0c9ea2b6893a05e4fca
  • master default protected
  • dev
  • appimage
  • fix_gitlab
  • fixappveyor
  • gitlab
  • fix_ci
  • fix_dbus_error
  • fix_ci_osx
  • sakia020
  • fix_travis#1105
  • feature/backend
  • check_uniq_node_by_endpoints
  • qt5.7
  • feature/agent_architecture
  • translations
  • pyqt5.6
  • qtwebengine
  • pyinstaller
  • landscape
  • 0.53.2
  • 0.53.1
  • 0.53.0
  • 0.52.0
  • 0.51.1
  • 0.51.0
  • 0.50.5
  • 0.50.4
  • 0.50.3
  • 0.50.2
  • 0.50.1
  • 0.50.0
  • 0.33.0rc7
  • 0.33.0rc6
  • 0.33.0rc5
  • 0.33.0rc4
  • 0.33.0rc3
  • 0.33.0rc2
  • 0.33.0rc1
  • 0.32.10post1
41 results

test_signing.py

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)