mirror of
https://github.com/aljazceru/python-teos.git
synced 2025-12-17 22:24:23 +01:00
user_pk/client_pk -> user_id and cli/client -> user (when it does not reffer to the software)
This commit is contained in:
@@ -28,17 +28,17 @@ def test_init(gatekeeper, run_bitcoind):
|
||||
def test_add_update_user(gatekeeper):
|
||||
# add_update_user adds DEFAULT_SLOTS to a given user as long as the identifier is {02, 03}| 32-byte hex str
|
||||
# it also add DEFAULT_SUBSCRIPTION_DURATION + current_block_height to the user
|
||||
user_pk = "02" + get_random_value_hex(32)
|
||||
user_id = "02" + get_random_value_hex(32)
|
||||
|
||||
for _ in range(10):
|
||||
user = gatekeeper.registered_users.get(user_pk)
|
||||
user = gatekeeper.registered_users.get(user_id)
|
||||
current_slots = user.available_slots if user is not None else 0
|
||||
|
||||
gatekeeper.add_update_user(user_pk)
|
||||
gatekeeper.add_update_user(user_id)
|
||||
|
||||
assert gatekeeper.registered_users.get(user_pk).available_slots == current_slots + config.get("DEFAULT_SLOTS")
|
||||
assert gatekeeper.registered_users.get(user_id).available_slots == current_slots + config.get("DEFAULT_SLOTS")
|
||||
assert gatekeeper.registered_users[
|
||||
user_pk
|
||||
user_id
|
||||
].subscription_expiry == gatekeeper.block_processor.get_block_count() + config.get(
|
||||
"DEFAULT_SUBSCRIPTION_DURATION"
|
||||
)
|
||||
@@ -46,31 +46,31 @@ def test_add_update_user(gatekeeper):
|
||||
# The same can be checked for multiple users
|
||||
for _ in range(10):
|
||||
# The user identifier is changed every call
|
||||
user_pk = "03" + get_random_value_hex(32)
|
||||
user_id = "03" + get_random_value_hex(32)
|
||||
|
||||
gatekeeper.add_update_user(user_pk)
|
||||
assert gatekeeper.registered_users.get(user_pk).available_slots == config.get("DEFAULT_SLOTS")
|
||||
gatekeeper.add_update_user(user_id)
|
||||
assert gatekeeper.registered_users.get(user_id).available_slots == config.get("DEFAULT_SLOTS")
|
||||
assert gatekeeper.registered_users[
|
||||
user_pk
|
||||
user_id
|
||||
].subscription_expiry == gatekeeper.block_processor.get_block_count() + config.get(
|
||||
"DEFAULT_SUBSCRIPTION_DURATION"
|
||||
)
|
||||
|
||||
|
||||
def test_add_update_user_wrong_pk(gatekeeper):
|
||||
def test_add_update_user_wrong_id(gatekeeper):
|
||||
# Passing a wrong pk defaults to the errors in check_user_pk. We can try with one.
|
||||
wrong_pk = get_random_value_hex(32)
|
||||
wrong_id = get_random_value_hex(32)
|
||||
|
||||
with pytest.raises(InvalidParameter):
|
||||
gatekeeper.add_update_user(wrong_pk)
|
||||
gatekeeper.add_update_user(wrong_id)
|
||||
|
||||
|
||||
def test_add_update_user_wrong_pk_prefix(gatekeeper):
|
||||
def test_add_update_user_wrong_id_prefix(gatekeeper):
|
||||
# Prefixes must be 02 or 03, anything else should fail
|
||||
wrong_pk = "04" + get_random_value_hex(32)
|
||||
wrong_id = "04" + get_random_value_hex(32)
|
||||
|
||||
with pytest.raises(InvalidParameter):
|
||||
gatekeeper.add_update_user(wrong_pk)
|
||||
gatekeeper.add_update_user(wrong_id)
|
||||
|
||||
|
||||
def test_identify_user(gatekeeper):
|
||||
@@ -79,13 +79,13 @@ def test_identify_user(gatekeeper):
|
||||
|
||||
# Let's first register a user
|
||||
sk, pk = generate_keypair()
|
||||
compressed_pk = Cryptographer.get_compressed_pk(pk)
|
||||
gatekeeper.add_update_user(compressed_pk)
|
||||
user_id = Cryptographer.get_compressed_pk(pk)
|
||||
gatekeeper.add_update_user(user_id)
|
||||
|
||||
message = "Hey, it's me"
|
||||
signature = Cryptographer.sign(message.encode(), sk)
|
||||
|
||||
assert gatekeeper.authenticate_user(message.encode(), signature) == compressed_pk
|
||||
assert gatekeeper.authenticate_user(message.encode(), signature) == user_id
|
||||
|
||||
|
||||
def test_identify_user_non_registered(gatekeeper):
|
||||
@@ -132,15 +132,15 @@ def test_update_available_slots(gatekeeper):
|
||||
# update_available_slots should decrease the slot count if a new appointment is added
|
||||
# let's add a new user
|
||||
sk, pk = generate_keypair()
|
||||
compressed_pk = Cryptographer.get_compressed_pk(pk)
|
||||
gatekeeper.add_update_user(compressed_pk)
|
||||
user_id = Cryptographer.get_compressed_pk(pk)
|
||||
gatekeeper.add_update_user(user_id)
|
||||
|
||||
# And now update the slots given an appointment
|
||||
appointment, _ = generate_dummy_appointment()
|
||||
gatekeeper.update_available_slots(compressed_pk, appointment.get_summary())
|
||||
gatekeeper.update_available_slots(user_id, appointment.get_summary())
|
||||
|
||||
# This is a standard size appointment, so it should have reduced the slots by one
|
||||
assert gatekeeper.registered_users[compressed_pk].available_slots == config.get("DEFAULT_SLOTS") - 1
|
||||
assert gatekeeper.registered_users[user_id].available_slots == config.get("DEFAULT_SLOTS") - 1
|
||||
|
||||
# Updates can leave the count as it, decrease it, or increase it, depending on the appointment size (modulo
|
||||
# ENCRYPTED_BLOB_MAX_SIZE_HEX)
|
||||
@@ -148,7 +148,7 @@ def test_update_available_slots(gatekeeper):
|
||||
# Appointments of the same size leave it as is
|
||||
appointment_same_size, _ = generate_dummy_appointment()
|
||||
remaining_slots = gatekeeper.update_available_slots(
|
||||
compressed_pk, appointment.get_summary(), appointment_same_size.get_summary()
|
||||
user_id, appointment.get_summary(), appointment_same_size.get_summary()
|
||||
)
|
||||
assert remaining_slots == config.get("DEFAULT_SLOTS") - 1
|
||||
|
||||
@@ -156,20 +156,20 @@ def test_update_available_slots(gatekeeper):
|
||||
appointment_x2_size = appointment_same_size
|
||||
appointment_x2_size.encrypted_blob = "A" * (ENCRYPTED_BLOB_MAX_SIZE_HEX + 1)
|
||||
remaining_slots = gatekeeper.update_available_slots(
|
||||
compressed_pk, appointment_x2_size.get_summary(), appointment.get_summary()
|
||||
user_id, appointment_x2_size.get_summary(), appointment.get_summary()
|
||||
)
|
||||
assert remaining_slots == config.get("DEFAULT_SLOTS") - 2
|
||||
|
||||
# Smaller appointments increase it (using the same data but flipped)
|
||||
remaining_slots = gatekeeper.update_available_slots(
|
||||
compressed_pk, appointment.get_summary(), appointment_x2_size.get_summary()
|
||||
user_id, appointment.get_summary(), appointment_x2_size.get_summary()
|
||||
)
|
||||
assert remaining_slots == config.get("DEFAULT_SLOTS") - 1
|
||||
|
||||
# If the appointment needs more slots than there's free, it should fail
|
||||
gatekeeper.registered_users[compressed_pk].available_slots = 1
|
||||
gatekeeper.registered_users[user_id].available_slots = 1
|
||||
with pytest.raises(NotEnoughSlots):
|
||||
gatekeeper.update_available_slots(compressed_pk, appointment_x2_size.get_summary())
|
||||
gatekeeper.update_available_slots(user_id, appointment_x2_size.get_summary())
|
||||
|
||||
|
||||
def test_get_expired_appointments(gatekeeper):
|
||||
|
||||
Reference in New Issue
Block a user