You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 

223 lines
8.4 KiB

#!/usr/bin/python3 -OO
# Copyright 2007-2021 The SABnzbd-Team <team@sabnzbd.org>
#
# This program is free software; you can redistribute it and/or
# modify it under the terms of the GNU General Public License
# as published by the Free Software Foundation; either version 2
# of the License, or (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program; if not, write to the Free Software
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
"""
tests.test_functional_misc - Functional tests of various functions
"""
import shutil
import subprocess
import sys
import sabnzbd.encoding
from sabnzbd import save_compressed
from sabnzbd.constants import JOB_ADMIN
from tests.testhelper import *
class TestShowLogging(SABnzbdBaseTest):
def test_showlog(self):
"""Test the output of the filtered-log button"""
# Basic URL-fetching, easier than Selenium file download
log_result = get_url_result("status/showlog")
# Make sure it has basic log stuff
assert "The log" in log_result
assert "Full executable path" in log_result
# Make sure sabnzbd.ini was appended
assert "__encoding__ = utf-8" in log_result
assert "[misc]" in log_result
class TestQueueRepair(SABnzbdBaseTest):
def test_queue_repair(self):
"""Test full queue repair by manually adding an orphaned job"""
nzb_data = create_and_read_nzb("basic_rar5")
test_job_name = "testfile_%s" % time.time()
# Create folder and save compressed NZB like SABnzbd would do
admin_path = os.path.join(SAB_INCOMPLETE_DIR, test_job_name, JOB_ADMIN)
os.makedirs(admin_path)
save_compressed(admin_path, test_job_name, nzb_data)
assert os.path.exists(os.path.join(admin_path, test_job_name + ".nzb.gz"))
# Pause the queue do we don't download stuff
assert get_api_result("pause") == {"status": True}
# Request queue repair
assert get_api_result("restart_repair") == {"status": True}
# Let's check the queue, this can take long on GitHub Actions
for _ in range(60):
queue_result_slots = {}
try:
# Can give timeout if still restarting
queue_result_slots = get_api_result("queue", extra_arguments={"limit": 10000})["queue"]["slots"]
except requests.exceptions.RequestException:
pass
# Check if the repaired job was added to the queue
if queue_result_slots:
break
time.sleep(1)
else:
# The loop never stopped, so we fail
pytest.fail("Did not find the repaired job in the queue")
return
# Verify filename
assert test_job_name in [slot["filename"] for slot in queue_result_slots]
# Let's remove this thing
get_api_result("queue", extra_arguments={"name": "delete", "value": "all"})
assert len(get_api_result("queue")["queue"]["slots"]) == 0
# Unpause
assert get_api_result("resume") == {"status": True}
class TestSamplePostProc:
def test_sample_post_proc(self):
"""Make sure we don't break things"""
# Set parameters
script_params = [
"somedir222",
"nzbname",
"frènch_german_demö",
"Index12",
"Cat88",
"MyGroup",
"PP0",
"https://example.com/",
]
script_call = [sys.executable, "scripts/Sample-PostProc.py", "server"]
script_call.extend(script_params)
# Set parameters via env
env = os.environ.copy()
env["SAB_VERSION"] = "frènch_german_demö_version"
# Run script and check output
script_call = subprocess.Popen(script_call, stdout=subprocess.PIPE, env=env)
script_output, errs = script_call.communicate(timeout=15)
# This is a bit bad, since we use our own function
# But in a way it is also a test if the function does its job!
script_output = sabnzbd.encoding.platform_btou(script_output)
# Check if all parameters are there
for param in script_params:
assert param in script_output
assert env["SAB_VERSION"] in script_output
class TestExtractPot:
def test_extract_pot(self):
"""Simple test if translation extraction still works"""
script_call = [sys.executable, "tools/extract_pot.py"]
# Run script and check output
script_call = subprocess.Popen(script_call, stdout=subprocess.PIPE)
script_output, errs = script_call.communicate(timeout=15)
script_output = sabnzbd.encoding.platform_btou(script_output)
# Success message?
assert "Creating POT file" in script_output
assert "Finished creating POT file" in script_output
assert "Post-process POT file" in script_output
assert "Finished post-process POT file" in script_output
assert "Creating email POT file" in script_output
assert "Finished creating email POT file" in script_output
# Check if the file was modified less than 30 seconds ago
cur_time = time.time()
assert (cur_time - os.path.getmtime("po/main/SABnzbd.pot")) < 30
assert (cur_time - os.path.getmtime("po/email/SABemail.pot")) < 30
# Reset the translation updates
try:
lang_command = "git checkout @ -- %s/../po/main/SABnzbd.pot" % SAB_BASE_DIR
subprocess.Popen(lang_command.split()).communicate(timeout=30)
lang_command = "git checkout @ -- %s/../po/email/SABemail.pot" % SAB_BASE_DIR
subprocess.Popen(lang_command.split()).communicate(timeout=30)
except:
pass
@pytest.mark.skipif(sys.platform.startswith("win"), reason="Skipping on Windows")
@pytest.mark.skipif(sys.platform.startswith("darwin"), reason="Fails for now due to PyObjC problem")
class TestDaemonizing(SABnzbdBaseTest):
def test_daemonizing(self):
"""Simple test to see if daemon-mode still works.
Also test removal of large "sabnzbd.error.log"
We inherit from SABnzbdBaseTest so we can use it's clean-up logic!
"""
daemon_host = "localhost"
daemon_port = 23456
ini_location = os.path.join(SAB_CACHE_DIR, "daemon_test")
# Create large output-file
error_log_path = os.path.join(ini_location, sabnzbd.cfg.log_dir(), sabnzbd.constants.DEF_LOG_ERRFILE)
os.makedirs(os.path.dirname(error_log_path), exist_ok=True)
with open(error_log_path, "wb") as large_log:
large_log.seek(6 * 1024 * 1024)
large_log.write(b"\1")
# We need the basic-config to set the API-key
# Otherwise we can't shut it down at the end
shutil.copyfile(os.path.join(SAB_DATA_DIR, "sabnzbd.basic.ini"), os.path.join(ini_location, "sabnzbd.ini"))
# Combine it all into the script call
script_call = [
sys.executable,
"SABnzbd.py",
"-d",
"-s",
"%s:%s" % (daemon_host, daemon_port),
"-f",
ini_location,
"--pid",
ini_location,
]
# Run script and check output
script_call = subprocess.Popen(script_call, stdout=subprocess.PIPE)
script_output, errs = script_call.communicate(timeout=15)
# No error or output should be thrown by main process
assert not script_output
assert not errs
# It should be online after 3 seconds
time.sleep(3.0)
assert "version" in get_api_result("version", daemon_host, daemon_port)
# Did it create the PID file
pid_file = os.path.join(ini_location, "sabnzbd-%d.pid" % daemon_port)
assert os.path.exists(pid_file)
# Did it remove the bad log file?
assert os.path.exists(error_log_path)
assert os.path.getsize(error_log_path) < 1024
try:
# Let's shut it down and give it some time to do so
get_url_result("shutdown", daemon_host, daemon_port)
time.sleep(3.0)
except requests.exceptions.RequestException:
# Shutdown can be faster than the request
pass