|
|
|
@ -4,7 +4,7 @@
|
|
|
|
|
# file COPYING or http://www.opensource.org/licenses/mit-license.php.
|
|
|
|
|
"""Test share/rpcauth/rpcauth.py
|
|
|
|
|
"""
|
|
|
|
|
import base64
|
|
|
|
|
import re
|
|
|
|
|
import configparser
|
|
|
|
|
import hmac
|
|
|
|
|
import importlib
|
|
|
|
@ -28,18 +28,17 @@ class TestRPCAuth(unittest.TestCase):
|
|
|
|
|
self.assertEqual(len(self.rpcauth.generate_salt(i)), i * 2)
|
|
|
|
|
|
|
|
|
|
def test_generate_password(self):
|
|
|
|
|
"""Test that generated passwords only consist of urlsafe characters."""
|
|
|
|
|
r = re.compile(r"[0-9a-zA-Z_-]*")
|
|
|
|
|
password = self.rpcauth.generate_password()
|
|
|
|
|
expected_password = base64.urlsafe_b64encode(
|
|
|
|
|
base64.urlsafe_b64decode(password)).decode('utf-8')
|
|
|
|
|
self.assertEqual(expected_password, password)
|
|
|
|
|
self.assertTrue(r.fullmatch(password))
|
|
|
|
|
|
|
|
|
|
def test_check_password_hmac(self):
|
|
|
|
|
salt = self.rpcauth.generate_salt(16)
|
|
|
|
|
password = self.rpcauth.generate_password()
|
|
|
|
|
password_hmac = self.rpcauth.password_to_hmac(salt, password)
|
|
|
|
|
|
|
|
|
|
m = hmac.new(bytearray(salt, 'utf-8'),
|
|
|
|
|
bytearray(password, 'utf-8'), 'SHA256')
|
|
|
|
|
m = hmac.new(salt.encode('utf-8'), password.encode('utf-8'), 'SHA256')
|
|
|
|
|
expected_password_hmac = m.hexdigest()
|
|
|
|
|
|
|
|
|
|
self.assertEqual(expected_password_hmac, password_hmac)
|
|
|
|
|