mirror of
https://git.selfprivacy.org/SelfPrivacy/selfprivacy-rest-api.git
synced 2025-01-11 18:39:30 +00:00
test(auth): token tests clearer about timezone assumptions
This commit is contained in:
parent
dd6f37a17d
commit
1bbb804919
|
@ -22,7 +22,7 @@ class NewDeviceKey(BaseModel):
|
||||||
|
|
||||||
def is_valid(self) -> bool:
|
def is_valid(self) -> bool:
|
||||||
"""
|
"""
|
||||||
Check if the recovery key is valid.
|
Check if key is valid.
|
||||||
"""
|
"""
|
||||||
if is_past(self.expires_at):
|
if is_past(self.expires_at):
|
||||||
return False
|
return False
|
||||||
|
@ -30,7 +30,7 @@ class NewDeviceKey(BaseModel):
|
||||||
|
|
||||||
def as_mnemonic(self) -> str:
|
def as_mnemonic(self) -> str:
|
||||||
"""
|
"""
|
||||||
Get the recovery key as a mnemonic.
|
Get the key as a mnemonic.
|
||||||
"""
|
"""
|
||||||
return Mnemonic(language="english").to_mnemonic(bytes.fromhex(self.key))
|
return Mnemonic(language="english").to_mnemonic(bytes.fromhex(self.key))
|
||||||
|
|
||||||
|
|
|
@ -47,6 +47,7 @@ class RecoveryKey(BaseModel):
|
||||||
) -> "RecoveryKey":
|
) -> "RecoveryKey":
|
||||||
"""
|
"""
|
||||||
Factory to generate a random token.
|
Factory to generate a random token.
|
||||||
|
If passed naive time as expiration, assumes utc
|
||||||
"""
|
"""
|
||||||
creation_date = datetime.now(timezone.utc)
|
creation_date = datetime.now(timezone.utc)
|
||||||
if expiration is not None:
|
if expiration is not None:
|
||||||
|
|
|
@ -1,18 +1,25 @@
|
||||||
import pytest
|
import pytest
|
||||||
from datetime import datetime, timedelta
|
from datetime import datetime, timedelta, timezone
|
||||||
|
|
||||||
from selfprivacy_api.models.tokens.recovery_key import RecoveryKey
|
from selfprivacy_api.models.tokens.recovery_key import RecoveryKey
|
||||||
from selfprivacy_api.models.tokens.new_device_key import NewDeviceKey
|
from selfprivacy_api.models.tokens.new_device_key import NewDeviceKey
|
||||||
|
|
||||||
|
|
||||||
def test_recovery_key_expired():
|
def test_recovery_key_expired_utcnaive():
|
||||||
expiration = datetime.now() - timedelta(minutes=5)
|
expiration = datetime.utcnow() - timedelta(minutes=5)
|
||||||
|
key = RecoveryKey.generate(expiration=expiration, uses_left=2)
|
||||||
|
assert not key.is_valid()
|
||||||
|
|
||||||
|
|
||||||
|
def test_recovery_key_expired_tzaware():
|
||||||
|
expiration = datetime.now(timezone.utc) - timedelta(minutes=5)
|
||||||
key = RecoveryKey.generate(expiration=expiration, uses_left=2)
|
key = RecoveryKey.generate(expiration=expiration, uses_left=2)
|
||||||
assert not key.is_valid()
|
assert not key.is_valid()
|
||||||
|
|
||||||
|
|
||||||
def test_new_device_key_expired():
|
def test_new_device_key_expired():
|
||||||
expiration = datetime.now() - timedelta(minutes=5)
|
# key is supposed to be tzaware
|
||||||
|
expiration = datetime.now(timezone.utc) - timedelta(minutes=5)
|
||||||
key = NewDeviceKey.generate()
|
key = NewDeviceKey.generate()
|
||||||
key.expires_at = expiration
|
key.expires_at = expiration
|
||||||
assert not key.is_valid()
|
assert not key.is_valid()
|
||||||
|
|
Loading…
Reference in a new issue