mirror of
https://gitlab.archlinux.org/archlinux/aurweb.git
synced 2025-02-03 10:43:03 +01:00
This change utilizes pytest-xdist to perform a multiproc test run and reworks aurweb.db's code. We no longer use a global engine, session or Session, but we now use a memo of engines and sessions as they are requested, based on the PYTEST_CURRENT_TEST environment variable, which is available during testing. Additionally, this change strips several SQLite components out of the Python code-base. SQLite is still compatible with PHP and sharness tests, but not with our FastAPI implementation. More changes: ------------ - Remove use of aurweb.db.session global in other code. - Use new aurweb.db.name() dynamic db name function in env.py. - Added 'addopts' to pytest.ini which utilizes multiprocessing. - Highly recommended to leave this be or modify `-n auto` to `-n {cpu_threads}` where cpu_threads is at least 2. Signed-off-by: Kevin Morris <kevr@0cost.org>
67 lines
1.8 KiB
Python
67 lines
1.8 KiB
Python
import hashlib
|
|
|
|
import pytest
|
|
|
|
from aurweb import captcha
|
|
|
|
|
|
@pytest.fixture(autouse=True)
|
|
def setup(db_test):
|
|
return
|
|
|
|
|
|
def test_captcha_salts():
|
|
""" Make sure we can get some captcha salts. """
|
|
salts = captcha.get_captcha_salts()
|
|
assert len(salts) == 6
|
|
|
|
|
|
def test_captcha_token():
|
|
""" Make sure getting a captcha salt's token matches up against
|
|
the first three digits of the md5 hash of the salt. """
|
|
salts = captcha.get_captcha_salts()
|
|
salt = salts[0]
|
|
|
|
token1 = captcha.get_captcha_token(salt)
|
|
token2 = hashlib.md5(salt.encode()).hexdigest()[:3]
|
|
|
|
assert token1 == token2
|
|
|
|
|
|
def test_captcha_challenge_answer():
|
|
""" Make sure that executing the captcha challenge via shell
|
|
produces the correct result by comparing it against a straight
|
|
up token conversion. """
|
|
salts = captcha.get_captcha_salts()
|
|
salt = salts[0]
|
|
|
|
challenge = captcha.get_captcha_challenge(salt)
|
|
|
|
token = captcha.get_captcha_token(salt)
|
|
challenge2 = f"LC_ALL=C pacman -V|sed -r 's#[0-9]+#{token}#g'|md5sum|cut -c1-6"
|
|
|
|
assert challenge == challenge2
|
|
|
|
|
|
def test_captcha_salt_filter():
|
|
""" Make sure captcha_salt_filter returns the first salt from
|
|
get_captcha_salts().
|
|
|
|
Example usage:
|
|
<input type="hidden" name="captcha_salt" value="{{ captcha_salt }}">
|
|
"""
|
|
salt = captcha.captcha_salt_filter(None)
|
|
assert salt == captcha.get_captcha_salts()[0]
|
|
|
|
|
|
def test_captcha_cmdline_filter():
|
|
""" Make sure that the captcha_cmdline filter gives us the
|
|
same challenge that get_captcha_challenge does.
|
|
|
|
Example usage:
|
|
<code>{{ captcha_salt | captcha_cmdline }}</code>
|
|
"""
|
|
salt = captcha.captcha_salt_filter(None)
|
|
display1 = captcha.captcha_cmdline_filter(None, salt)
|
|
display2 = captcha.get_captcha_challenge(salt)
|
|
assert display1 == display2
|