mirror of
https://github.com/gryf/fs-uae-wrapper.git
synced 2025-12-20 12:58:01 +01:00
Fix unit tests
This commit is contained in:
@@ -297,6 +297,8 @@ class ArchiveBase(Base):
|
|||||||
logging.debug("_validate_options")
|
logging.debug("_validate_options")
|
||||||
|
|
||||||
validation_result = super(ArchiveBase, self)._validate_options()
|
validation_result = super(ArchiveBase, self)._validate_options()
|
||||||
|
if not validation_result:
|
||||||
|
return False
|
||||||
|
|
||||||
if 'wrapper_archive' not in self.all_options:
|
if 'wrapper_archive' not in self.all_options:
|
||||||
logging.warning("Configuration lacks of optional `wrapper_archive'"
|
logging.warning("Configuration lacks of optional `wrapper_archive'"
|
||||||
@@ -325,4 +327,3 @@ class ArchiveBase(Base):
|
|||||||
basename == os.path.splitext(fname)[0]):
|
basename == os.path.splitext(fname)[0]):
|
||||||
return fname
|
return fname
|
||||||
return None
|
return None
|
||||||
|
|
||||||
|
|||||||
@@ -3,19 +3,15 @@ Display message in separate process
|
|||||||
"""
|
"""
|
||||||
import multiprocessing as mp
|
import multiprocessing as mp
|
||||||
import sys
|
import sys
|
||||||
try:
|
import tkinter
|
||||||
import tkinter as tk
|
import tkinter.ttk
|
||||||
from tkinter import ttk
|
|
||||||
except ImportError:
|
|
||||||
import Tkinter as tk
|
|
||||||
import ttk
|
|
||||||
|
|
||||||
|
|
||||||
class MessageGui(tk.Tk):
|
class MessageGui(tkinter.Tk):
|
||||||
"""Simple gui for displaying a message"""
|
"""Simple gui for displaying a message"""
|
||||||
|
|
||||||
def __init__(self, parent=None, msg=""):
|
def __init__(self, parent=None, msg=""):
|
||||||
tk.Tk.__init__(self, parent)
|
tkinter.Tk.__init__(self, parent)
|
||||||
|
|
||||||
self.grid()
|
self.grid()
|
||||||
self.resizable(False, False)
|
self.resizable(False, False)
|
||||||
@@ -26,10 +22,11 @@ class MessageGui(tk.Tk):
|
|||||||
|
|
||||||
self.frame = ttk.Frame(self, padding=5, borderwidth=0)
|
self.frame = ttk.Frame(self, padding=5, borderwidth=0)
|
||||||
self.frame.grid()
|
self.frame.grid()
|
||||||
ttk.Label(self.frame, text=msg, relief="ridge", padding=10).grid()
|
tkinter.ttk.Label(self.frame, text=msg, relief="ridge",
|
||||||
|
padding=10).grid()
|
||||||
|
|
||||||
if 'linux' in sys.platform:
|
if 'linux' in sys.platform:
|
||||||
style = ttk.Style()
|
style = tkinter.ttk.Style()
|
||||||
style.theme_use('clam')
|
style.theme_use('clam')
|
||||||
|
|
||||||
def __call__(self):
|
def __call__(self):
|
||||||
|
|||||||
@@ -2,11 +2,7 @@ import os
|
|||||||
import shutil
|
import shutil
|
||||||
from tempfile import mkdtemp
|
from tempfile import mkdtemp
|
||||||
from unittest import TestCase
|
from unittest import TestCase
|
||||||
|
|
||||||
try:
|
|
||||||
from unittest import mock
|
from unittest import mock
|
||||||
except ImportError:
|
|
||||||
import mock
|
|
||||||
|
|
||||||
from fs_uae_wrapper import archive
|
from fs_uae_wrapper import archive
|
||||||
from fs_uae_wrapper import utils
|
from fs_uae_wrapper import utils
|
||||||
@@ -26,23 +22,26 @@ class TestArchive(TestCase):
|
|||||||
except OSError:
|
except OSError:
|
||||||
pass
|
pass
|
||||||
|
|
||||||
|
@mock.patch('fs_uae_wrapper.base.ArchiveBase._get_wrapper_archive_name')
|
||||||
@mock.patch('fs_uae_wrapper.path.which')
|
@mock.patch('fs_uae_wrapper.path.which')
|
||||||
def test_validate_options(self, which):
|
def test_validate_options(self, which, get_wrapper_arch_name):
|
||||||
which.return_value = 'unrar'
|
which.return_value = 'unrar'
|
||||||
|
|
||||||
arch = archive.Wrapper('Config.fs-uae', utils.CmdOption(), {})
|
arch = archive.Wrapper('Config.fs-uae', utils.CmdOption(), {})
|
||||||
self.assertFalse(arch._validate_options())
|
self.assertFalse(arch._validate_options())
|
||||||
arch.all_options = {'wrapper': 'archive'}
|
|
||||||
|
|
||||||
arch.all_options['wrapper'] = 'archive'
|
get_wrapper_arch_name.return_value = None
|
||||||
|
arch.all_options = {'wrapper': 'archive'}
|
||||||
self.assertFalse(arch._validate_options())
|
self.assertFalse(arch._validate_options())
|
||||||
|
|
||||||
|
get_wrapper_arch_name.return_value = 'fake_arch_filename'
|
||||||
arch.all_options['wrapper_archive'] = 'rar'
|
arch.all_options['wrapper_archive'] = 'rar'
|
||||||
self.assertTrue(arch._validate_options())
|
self.assertTrue(arch._validate_options())
|
||||||
|
|
||||||
@mock.patch('tempfile.mkdtemp')
|
@mock.patch('tempfile.mkdtemp')
|
||||||
@mock.patch('fs_uae_wrapper.path.which')
|
@mock.patch('fs_uae_wrapper.path.which')
|
||||||
@mock.patch('fs_uae_wrapper.archive.Wrapper._make_archive')
|
@mock.patch('fs_uae_wrapper.archive.Wrapper._make_archive')
|
||||||
|
@mock.patch('fs_uae_wrapper.base.ArchiveBase._get_wrapper_archive_name')
|
||||||
@mock.patch('fs_uae_wrapper.base.ArchiveBase._save_save')
|
@mock.patch('fs_uae_wrapper.base.ArchiveBase._save_save')
|
||||||
@mock.patch('fs_uae_wrapper.base.ArchiveBase._get_saves_dir')
|
@mock.patch('fs_uae_wrapper.base.ArchiveBase._get_saves_dir')
|
||||||
@mock.patch('fs_uae_wrapper.base.ArchiveBase._run_emulator')
|
@mock.patch('fs_uae_wrapper.base.ArchiveBase._run_emulator')
|
||||||
@@ -50,7 +49,8 @@ class TestArchive(TestCase):
|
|||||||
@mock.patch('fs_uae_wrapper.base.ArchiveBase._load_save')
|
@mock.patch('fs_uae_wrapper.base.ArchiveBase._load_save')
|
||||||
@mock.patch('fs_uae_wrapper.base.ArchiveBase._extract')
|
@mock.patch('fs_uae_wrapper.base.ArchiveBase._extract')
|
||||||
def test_run(self, extract, load_save, copy_conf, run_emulator,
|
def test_run(self, extract, load_save, copy_conf, run_emulator,
|
||||||
get_save_dir, save_state, make_arch, which, mkdtemp):
|
get_save_dir, save_state, get_wrapper_arch_name, make_arch,
|
||||||
|
which, mkdtemp):
|
||||||
|
|
||||||
extract.return_value = False
|
extract.return_value = False
|
||||||
load_save.return_value = False
|
load_save.return_value = False
|
||||||
@@ -58,6 +58,7 @@ class TestArchive(TestCase):
|
|||||||
run_emulator.return_value = False
|
run_emulator.return_value = False
|
||||||
get_save_dir.return_value = False
|
get_save_dir.return_value = False
|
||||||
save_state.return_value = False
|
save_state.return_value = False
|
||||||
|
get_wrapper_arch_name.return_value = "fake_arch_filename"
|
||||||
make_arch.return_value = False
|
make_arch.return_value = False
|
||||||
which.return_value = 'rar'
|
which.return_value = 'rar'
|
||||||
|
|
||||||
|
|||||||
@@ -3,11 +3,7 @@ import sys
|
|||||||
import shutil
|
import shutil
|
||||||
from tempfile import mkstemp, mkdtemp
|
from tempfile import mkstemp, mkdtemp
|
||||||
from unittest import TestCase
|
from unittest import TestCase
|
||||||
|
|
||||||
try:
|
|
||||||
from unittest import mock
|
from unittest import mock
|
||||||
except ImportError:
|
|
||||||
import mock
|
|
||||||
|
|
||||||
from fs_uae_wrapper import base
|
from fs_uae_wrapper import base
|
||||||
from fs_uae_wrapper import utils
|
from fs_uae_wrapper import utils
|
||||||
@@ -94,6 +90,11 @@ class TestBase(TestCase):
|
|||||||
bobj._normalize_options()
|
bobj._normalize_options()
|
||||||
self.assertDictEqual(bobj.fsuae_options, {})
|
self.assertDictEqual(bobj.fsuae_options, {})
|
||||||
|
|
||||||
|
get_config.return_value = {'random_item': 10}
|
||||||
|
bobj.fsuae_options = utils.CmdOption()
|
||||||
|
bobj._normalize_options()
|
||||||
|
self.assertDictEqual(bobj.fsuae_options, {})
|
||||||
|
|
||||||
@mock.patch('os.path.exists')
|
@mock.patch('os.path.exists')
|
||||||
@mock.patch('fs_uae_wrapper.utils.get_config')
|
@mock.patch('fs_uae_wrapper.utils.get_config')
|
||||||
def test_normalize_options_path_not_exists(self, get_config, os_exists):
|
def test_normalize_options_path_not_exists(self, get_config, os_exists):
|
||||||
@@ -390,16 +391,42 @@ class TestArchiveBase(TestCase):
|
|||||||
self.assertFalse(bobj._extract())
|
self.assertFalse(bobj._extract())
|
||||||
utils_extract.assert_called_once_with(self.fname, '')
|
utils_extract.assert_called_once_with(self.fname, '')
|
||||||
|
|
||||||
def test_validate_options(self):
|
@mock.patch('fs_uae_wrapper.base.ArchiveBase._get_wrapper_archive_name')
|
||||||
|
def test_validate_options(self, get_wrapper_arch_name):
|
||||||
|
|
||||||
bobj = base.ArchiveBase('Config.fs-uae', utils.CmdOption(), {})
|
bobj = base.ArchiveBase('Config.fs-uae', utils.CmdOption(), {})
|
||||||
bobj.all_options = {}
|
bobj.all_options = {}
|
||||||
|
|
||||||
self.assertFalse(bobj._validate_options())
|
self.assertFalse(bobj._validate_options())
|
||||||
|
|
||||||
|
get_wrapper_arch_name.return_value = None
|
||||||
bobj.all_options = {'wrapper': 'dummy'}
|
bobj.all_options = {'wrapper': 'dummy'}
|
||||||
self.assertFalse(bobj._validate_options())
|
self.assertFalse(bobj._validate_options())
|
||||||
|
|
||||||
bobj.all_options = {'wrapper': 'dummy',
|
bobj.all_options = {'wrapper': 'dummy',
|
||||||
'wrapper_archive': 'myarchive.7z'}
|
'wrapper_archive': 'myarchive.7z'}
|
||||||
self.assertTrue(bobj._validate_options())
|
self.assertTrue(bobj._validate_options())
|
||||||
|
|
||||||
|
@mock.patch('os.listdir')
|
||||||
|
def test_get_wrapper_archive_name(self, os_listdir):
|
||||||
|
os_listdir.return_value = 'no archive among other files'.split()
|
||||||
|
bobj = base.ArchiveBase('Config.fs-uae', utils.CmdOption(), {})
|
||||||
|
bobj.all_options = {'wrapper': 'dummy'}
|
||||||
|
self.assertIsNone(bobj._get_wrapper_archive_name())
|
||||||
|
|
||||||
|
os_listdir.return_value = 'no config.rar among other files'.split()
|
||||||
|
bobj = base.ArchiveBase('Config.fs-uae', utils.CmdOption(), {})
|
||||||
|
bobj.all_options = {'wrapper': 'dummy'}
|
||||||
|
self.assertIsNone(bobj._get_wrapper_archive_name())
|
||||||
|
|
||||||
|
os_listdir.return_value = 'file Config.TAR among other files'.split()
|
||||||
|
bobj = base.ArchiveBase('Config.fs-uae', utils.CmdOption(), {})
|
||||||
|
bobj.all_options = {'wrapper': 'dummy'}
|
||||||
|
self.assertEqual(bobj._get_wrapper_archive_name(), 'Config.TAR')
|
||||||
|
|
||||||
|
os_listdir.return_value = 'Config.lha FooBar_1.24b_20202.7z'.split()
|
||||||
|
bobj = base.ArchiveBase('FooBar_1.24b_20202.fs-uae',
|
||||||
|
utils.CmdOption(), {})
|
||||||
|
bobj.all_options = {'wrapper': 'dummy'}
|
||||||
|
self.assertEqual(bobj._get_wrapper_archive_name(),
|
||||||
|
'FooBar_1.24b_20202.7z')
|
||||||
|
|||||||
@@ -1,9 +1,5 @@
|
|||||||
from unittest import TestCase
|
from unittest import TestCase
|
||||||
|
|
||||||
try:
|
|
||||||
from unittest import mock
|
from unittest import mock
|
||||||
except ImportError:
|
|
||||||
import mock
|
|
||||||
|
|
||||||
from fs_uae_wrapper import cd32
|
from fs_uae_wrapper import cd32
|
||||||
from fs_uae_wrapper import utils
|
from fs_uae_wrapper import utils
|
||||||
@@ -13,6 +9,7 @@ class TestCD32(TestCase):
|
|||||||
|
|
||||||
@mock.patch('tempfile.mkdtemp')
|
@mock.patch('tempfile.mkdtemp')
|
||||||
@mock.patch('fs_uae_wrapper.path.which')
|
@mock.patch('fs_uae_wrapper.path.which')
|
||||||
|
@mock.patch('fs_uae_wrapper.base.ArchiveBase._get_wrapper_archive_name')
|
||||||
@mock.patch('fs_uae_wrapper.base.ArchiveBase._save_save')
|
@mock.patch('fs_uae_wrapper.base.ArchiveBase._save_save')
|
||||||
@mock.patch('fs_uae_wrapper.base.ArchiveBase._get_saves_dir')
|
@mock.patch('fs_uae_wrapper.base.ArchiveBase._get_saves_dir')
|
||||||
@mock.patch('fs_uae_wrapper.base.ArchiveBase._run_emulator')
|
@mock.patch('fs_uae_wrapper.base.ArchiveBase._run_emulator')
|
||||||
@@ -20,7 +17,8 @@ class TestCD32(TestCase):
|
|||||||
@mock.patch('fs_uae_wrapper.base.ArchiveBase._load_save')
|
@mock.patch('fs_uae_wrapper.base.ArchiveBase._load_save')
|
||||||
@mock.patch('fs_uae_wrapper.base.ArchiveBase._extract')
|
@mock.patch('fs_uae_wrapper.base.ArchiveBase._extract')
|
||||||
def test_run(self, extract, load_save, copy_conf, run_emulator,
|
def test_run(self, extract, load_save, copy_conf, run_emulator,
|
||||||
get_save_dir, save_state, which, mkdtemp):
|
get_save_dir, save_state, get_wrapper_arch_name, which,
|
||||||
|
mkdtemp):
|
||||||
|
|
||||||
extract.return_value = False
|
extract.return_value = False
|
||||||
copy_conf.return_value = False
|
copy_conf.return_value = False
|
||||||
@@ -28,6 +26,7 @@ class TestCD32(TestCase):
|
|||||||
run_emulator.return_value = False
|
run_emulator.return_value = False
|
||||||
get_save_dir.return_value = False
|
get_save_dir.return_value = False
|
||||||
save_state.return_value = False
|
save_state.return_value = False
|
||||||
|
get_wrapper_arch_name.return_value = "fake_arch_filename"
|
||||||
which.return_value = 'unrar'
|
which.return_value = 'unrar'
|
||||||
|
|
||||||
acd32 = cd32.Wrapper('Config.fs-uae', utils.CmdOption(), {})
|
acd32 = cd32.Wrapper('Config.fs-uae', utils.CmdOption(), {})
|
||||||
|
|||||||
@@ -2,11 +2,7 @@ import os
|
|||||||
import shutil
|
import shutil
|
||||||
from tempfile import mkdtemp
|
from tempfile import mkdtemp
|
||||||
from unittest import TestCase
|
from unittest import TestCase
|
||||||
|
|
||||||
try:
|
|
||||||
from unittest import mock
|
from unittest import mock
|
||||||
except ImportError:
|
|
||||||
import mock
|
|
||||||
|
|
||||||
from fs_uae_wrapper import file_archive
|
from fs_uae_wrapper import file_archive
|
||||||
|
|
||||||
|
|||||||
@@ -1,20 +1,12 @@
|
|||||||
from unittest import TestCase
|
from unittest import TestCase
|
||||||
import os
|
import os
|
||||||
|
|
||||||
try:
|
|
||||||
from unittest import mock
|
from unittest import mock
|
||||||
except ImportError:
|
|
||||||
import mock
|
|
||||||
|
|
||||||
from fs_uae_wrapper import message
|
from fs_uae_wrapper import message
|
||||||
|
|
||||||
if os.environ.get('DISPLAY'):
|
if os.environ.get('DISPLAY'):
|
||||||
try:
|
|
||||||
import tkinter as tk
|
import tkinter as tk
|
||||||
from tkinter import ttk
|
from tkinter import ttk
|
||||||
except ImportError:
|
|
||||||
import Tkinter as tk
|
|
||||||
import ttk
|
|
||||||
|
|
||||||
|
|
||||||
class TestMessage(TestCase):
|
class TestMessage(TestCase):
|
||||||
|
|||||||
@@ -1,9 +1,5 @@
|
|||||||
from unittest import TestCase
|
from unittest import TestCase
|
||||||
|
|
||||||
try:
|
|
||||||
from unittest import mock
|
from unittest import mock
|
||||||
except ImportError:
|
|
||||||
import mock
|
|
||||||
|
|
||||||
from fs_uae_wrapper import plain
|
from fs_uae_wrapper import plain
|
||||||
from fs_uae_wrapper import utils
|
from fs_uae_wrapper import utils
|
||||||
|
|||||||
@@ -2,11 +2,7 @@ import os
|
|||||||
import shutil
|
import shutil
|
||||||
from tempfile import mkdtemp
|
from tempfile import mkdtemp
|
||||||
from unittest import TestCase
|
from unittest import TestCase
|
||||||
|
|
||||||
try:
|
|
||||||
from unittest import mock
|
from unittest import mock
|
||||||
except ImportError:
|
|
||||||
import mock
|
|
||||||
|
|
||||||
from fs_uae_wrapper import savestate
|
from fs_uae_wrapper import savestate
|
||||||
from fs_uae_wrapper import utils
|
from fs_uae_wrapper import utils
|
||||||
|
|||||||
@@ -3,11 +3,7 @@ import sys
|
|||||||
from tempfile import mkstemp, mkdtemp
|
from tempfile import mkstemp, mkdtemp
|
||||||
from unittest import TestCase
|
from unittest import TestCase
|
||||||
import shutil
|
import shutil
|
||||||
|
|
||||||
try:
|
|
||||||
from unittest import mock
|
from unittest import mock
|
||||||
except ImportError:
|
|
||||||
import mock
|
|
||||||
|
|
||||||
from fs_uae_wrapper import utils
|
from fs_uae_wrapper import utils
|
||||||
|
|
||||||
|
|||||||
@@ -3,11 +3,7 @@ import sys
|
|||||||
from tempfile import mkstemp, mkdtemp
|
from tempfile import mkstemp, mkdtemp
|
||||||
from unittest import TestCase
|
from unittest import TestCase
|
||||||
import shutil
|
import shutil
|
||||||
|
|
||||||
try:
|
|
||||||
from unittest import mock
|
from unittest import mock
|
||||||
except ImportError:
|
|
||||||
import mock
|
|
||||||
|
|
||||||
from fs_uae_wrapper import wrapper
|
from fs_uae_wrapper import wrapper
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user