mirror of
https://github.com/onionshare/onionshare.git
synced 2025-01-17 18:27:34 -05:00
221 lines
5.6 KiB
Python
221 lines
5.6 KiB
Python
import sys
|
|
import os
|
|
import shutil
|
|
import tempfile
|
|
from datetime import datetime, timedelta
|
|
|
|
import pytest
|
|
from PySide2 import QtTest
|
|
|
|
from onionshare_cli import common, web, settings
|
|
|
|
|
|
# Force tests to look for resources in the source code tree
|
|
sys.onionshare_dev_mode = True
|
|
|
|
# Let OnionShare know the tests are running, to avoid colliding with settings files
|
|
sys.onionshare_test_mode = True
|
|
|
|
|
|
@staticmethod
|
|
def qWait(t, qtapp):
|
|
end = datetime.now() + timedelta(milliseconds=t)
|
|
while datetime.now() < end:
|
|
qtapp.processEvents()
|
|
|
|
|
|
# Monkeypatch qWait, because PySide2 doesn't have it
|
|
# https://stackoverflow.com/questions/17960159/qwait-analogue-in-pyside
|
|
QtTest.QTest.qWait = qWait
|
|
|
|
# Allow importing onionshare_cli from the source tree
|
|
sys.path.insert(
|
|
0,
|
|
os.path.join(
|
|
os.path.dirname(os.path.dirname(os.path.dirname(os.path.abspath(__file__)))),
|
|
"cli",
|
|
),
|
|
)
|
|
|
|
# The temporary directory for CLI tests
|
|
test_temp_dir = None
|
|
|
|
|
|
def pytest_addoption(parser):
|
|
parser.addoption(
|
|
"--runtor", action="store_true", default=False, help="run tor tests"
|
|
)
|
|
|
|
|
|
def pytest_collection_modifyitems(config, items):
|
|
if not config.getoption("--runtor"):
|
|
# --runtor given in cli: do not skip tor tests
|
|
skip_tor = pytest.mark.skip(reason="need --runtor option to run")
|
|
for item in items:
|
|
if "tor" in item.keywords:
|
|
item.add_marker(skip_tor)
|
|
|
|
|
|
@pytest.fixture
|
|
def temp_dir():
|
|
"""Creates a persistent temporary directory for the CLI tests to use"""
|
|
global test_temp_dir
|
|
if not test_temp_dir:
|
|
test_temp_dir = tempfile.mkdtemp()
|
|
return test_temp_dir
|
|
|
|
|
|
@pytest.fixture
|
|
def temp_dir_1024(temp_dir):
|
|
"""Create a temporary directory that has a single file of a
|
|
particular size (1024 bytes).
|
|
"""
|
|
|
|
new_temp_dir = tempfile.mkdtemp(dir=temp_dir)
|
|
tmp_file, tmp_file_path = tempfile.mkstemp(dir=new_temp_dir)
|
|
with open(tmp_file, "wb") as f:
|
|
f.write(b"*" * 1024)
|
|
return new_temp_dir
|
|
|
|
|
|
# pytest > 2.9 only needs @pytest.fixture
|
|
@pytest.yield_fixture
|
|
def temp_dir_1024_delete(temp_dir):
|
|
"""Create a temporary directory that has a single file of a
|
|
particular size (1024 bytes). The temporary directory (including
|
|
the file inside) will be deleted after fixture usage.
|
|
"""
|
|
|
|
with tempfile.TemporaryDirectory(dir=temp_dir) as new_temp_dir:
|
|
tmp_file, tmp_file_path = tempfile.mkstemp(dir=new_temp_dir)
|
|
with open(tmp_file, "wb") as f:
|
|
f.write(b"*" * 1024)
|
|
yield new_temp_dir
|
|
|
|
|
|
@pytest.fixture
|
|
def temp_file_1024(temp_dir):
|
|
"""Create a temporary file of a particular size (1024 bytes)."""
|
|
|
|
with tempfile.NamedTemporaryFile(delete=False, dir=temp_dir) as tmp_file:
|
|
tmp_file.write(b"*" * 1024)
|
|
return tmp_file.name
|
|
|
|
|
|
# pytest > 2.9 only needs @pytest.fixture
|
|
@pytest.yield_fixture
|
|
def temp_file_1024_delete(temp_dir):
|
|
"""
|
|
Create a temporary file of a particular size (1024 bytes).
|
|
The temporary file will be deleted after fixture usage.
|
|
"""
|
|
|
|
with tempfile.NamedTemporaryFile(dir=temp_dir, delete=False) as tmp_file:
|
|
tmp_file.write(b"*" * 1024)
|
|
tmp_file.flush()
|
|
tmp_file.close()
|
|
yield tmp_file.name
|
|
|
|
|
|
# pytest > 2.9 only needs @pytest.fixture
|
|
@pytest.yield_fixture(scope="session")
|
|
def custom_zw():
|
|
zw = web.share_mode.ZipWriter(
|
|
common.Common(),
|
|
zip_filename=common.Common.random_string(4, 6),
|
|
processed_size_callback=lambda _: "custom_callback",
|
|
)
|
|
yield zw
|
|
zw.close()
|
|
os.remove(zw.zip_filename)
|
|
|
|
|
|
# pytest > 2.9 only needs @pytest.fixture
|
|
@pytest.yield_fixture(scope="session")
|
|
def default_zw():
|
|
zw = web.share_mode.ZipWriter(common.Common())
|
|
yield zw
|
|
zw.close()
|
|
tmp_dir = os.path.dirname(zw.zip_filename)
|
|
try:
|
|
shutil.rmtree(tmp_dir, ignore_errors=True)
|
|
except Exception:
|
|
pass
|
|
|
|
|
|
@pytest.fixture
|
|
def locale_en(monkeypatch):
|
|
monkeypatch.setattr("locale.getdefaultlocale", lambda: ("en_US", "UTF-8"))
|
|
|
|
|
|
@pytest.fixture
|
|
def locale_fr(monkeypatch):
|
|
monkeypatch.setattr("locale.getdefaultlocale", lambda: ("fr_FR", "UTF-8"))
|
|
|
|
|
|
@pytest.fixture
|
|
def locale_invalid(monkeypatch):
|
|
monkeypatch.setattr("locale.getdefaultlocale", lambda: ("xx_XX", "UTF-8"))
|
|
|
|
|
|
@pytest.fixture
|
|
def locale_ru(monkeypatch):
|
|
monkeypatch.setattr("locale.getdefaultlocale", lambda: ("ru_RU", "UTF-8"))
|
|
|
|
|
|
@pytest.fixture
|
|
def platform_darwin(monkeypatch):
|
|
monkeypatch.setattr("platform.system", lambda: "Darwin")
|
|
|
|
|
|
@pytest.fixture # (scope="session")
|
|
def platform_linux(monkeypatch):
|
|
monkeypatch.setattr("platform.system", lambda: "Linux")
|
|
|
|
|
|
@pytest.fixture
|
|
def platform_windows(monkeypatch):
|
|
monkeypatch.setattr("platform.system", lambda: "Windows")
|
|
|
|
|
|
@pytest.fixture
|
|
def sys_argv_sys_prefix(monkeypatch):
|
|
monkeypatch.setattr("sys.argv", [sys.prefix])
|
|
|
|
|
|
@pytest.fixture
|
|
def sys_frozen(monkeypatch):
|
|
monkeypatch.setattr("sys.frozen", True, raising=False)
|
|
|
|
|
|
@pytest.fixture
|
|
def sys_meipass(monkeypatch):
|
|
monkeypatch.setattr("sys._MEIPASS", os.path.expanduser("~"), raising=False)
|
|
|
|
|
|
@pytest.fixture # (scope="session")
|
|
def sys_onionshare_dev_mode(monkeypatch):
|
|
monkeypatch.setattr("sys.onionshare_dev_mode", True, raising=False)
|
|
|
|
|
|
@pytest.fixture
|
|
def time_time_100(monkeypatch):
|
|
monkeypatch.setattr("time.time", lambda: 100)
|
|
|
|
|
|
@pytest.fixture
|
|
def time_strftime(monkeypatch):
|
|
monkeypatch.setattr("time.strftime", lambda _: "Jun 06 2013 11:05:00")
|
|
|
|
|
|
@pytest.fixture
|
|
def common_obj():
|
|
return common.Common()
|
|
|
|
|
|
@pytest.fixture
|
|
def settings_obj(sys_onionshare_dev_mode, platform_linux):
|
|
_common = common.Common()
|
|
_common.version = "DUMMY_VERSION_1.2.3"
|
|
return settings.Settings(_common)
|