ut_dep.py 2.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990
  1. #!/usr/bin/env python3
  2. """
  3. test.unit_tests_d.ut_dep: dependency unit tests for the MMGen suite
  4. Test whether dependencies are installed and functional.
  5. No data verification is performed.
  6. """
  7. from mmgen.common import *
  8. class unit_tests:
  9. altcoin_deps = ('pysha3','py_ecc')
  10. win_skip = ('aiohttp','pysha3')
  11. def pysha3(self,name,ut): # ETH,XMR
  12. from sha3 import keccak_256
  13. return True
  14. def py_ecc(self,name,ut): # ETH
  15. from py_ecc.secp256k1 import privtopub
  16. return True
  17. def pysocks(self,name,ut):
  18. import requests,urllib3
  19. urllib3.disable_warnings()
  20. session = requests.Session()
  21. session.proxies.update({'https':'socks5h://127.243.172.8:20677'})
  22. try:
  23. session.get('https://127.188.29.17')
  24. except Exception as e:
  25. if type(e).__name__ == 'ConnectionError':
  26. return True
  27. else:
  28. print(e)
  29. return False
  30. def secp256k1(self,name,ut):
  31. from mmgen.secp256k1 import priv2pub
  32. priv2pub(bytes.fromhex('deadbeef'*8),1)
  33. return True
  34. def cryptography(self,name,ut):
  35. from cryptography.hazmat.primitives.ciphers import Cipher,algorithms,modes
  36. from cryptography.hazmat.backends import default_backend
  37. c = Cipher(algorithms.AES(b'deadbeef'*4),modes.CTR(b'deadbeef'*2),backend=default_backend())
  38. encryptor = c.encryptor()
  39. enc_data = encryptor.update(b'foo') + encryptor.finalize()
  40. return True
  41. def ecdsa(self,name,ut):
  42. import ecdsa
  43. pko = ecdsa.SigningKey.from_secret_exponent(12345678901234,curve=ecdsa.SECP256k1)
  44. pubkey = pko.get_verifying_key().to_string().hex()
  45. return True
  46. def gmpy(self,name,ut):
  47. from gmpy2 import context,set_context,sqrt,cbrt
  48. # context() parameters are platform-dependent!
  49. set_context(context(precision=75,round=1)) # OK for gmp 6.1.2 / gmpy 2.1.0
  50. return True
  51. def aiohttp(self,name,ut):
  52. import asyncio,aiohttp
  53. async def do():
  54. async with aiohttp.ClientSession(
  55. headers = { 'Content-Type': 'application/json' },
  56. connector = aiohttp.TCPConnector(),
  57. ) as session:
  58. pass
  59. asyncio.run(do())
  60. return True
  61. def pexpect(self,name,ut):
  62. import pexpect
  63. from pexpect.popen_spawn import PopenSpawn
  64. return True
  65. def scrypt(self,name,ut):
  66. passwd,salt = b'foo',b'bar'
  67. N,r,p = 4,8,16
  68. buflen = 64
  69. import scrypt
  70. scrypt.hash(passwd, salt, N=2**N, r=r, p=p, buflen=buflen)
  71. from hashlib import scrypt # max N == 14!!
  72. scrypt(password=passwd,salt=salt,n=2**N,r=r,p=p,maxmem=0,dklen=buflen)
  73. return True