1
0
mirror of https://github.com/arsenetar/dupeguru.git synced 2024-11-16 20:29:02 +00:00
dupeguru/core/tests/base.py

189 lines
5.7 KiB
Python
Raw Normal View History

2016-05-29 19:02:39 +00:00
# Copyright 2016 Hardcoded Software (http://www.hardcoded.net)
#
# This software is licensed under the "GPLv3" License as described in the "LICENSE" file,
# which should be included with this package. The terms are also available at
# http://www.gnu.org/licenses/gpl-3.0.html
from hscommon.testutil import TestApp as TestAppBase, CallLogger, eq_, with_app # noqa
from pathlib import Path
from hscommon.util import get_file_ext, format_size
2011-11-27 21:49:12 +00:00
from hscommon.gui.column import Column
from hscommon.jobprogress.job import nulljob, JobCancelled
2022-05-09 06:40:08 +00:00
from core import engine, prioritize
from core.engine import getwords
from core.app import DupeGuru as DupeGuruBase
from core.gui.result_table import ResultTable as ResultTableBase
from core.gui.prioritize_dialog import PrioritizeDialog
2011-09-21 13:17:22 +00:00
class DupeGuruView:
JOB = nulljob
def __init__(self):
self.messages = []
2011-09-21 13:17:22 +00:00
def start_job(self, jobid, func, args=()):
try:
func(self.JOB, *args)
except JobCancelled:
return
2011-09-21 13:17:22 +00:00
def get_default(self, key_name):
return None
2011-09-21 13:17:22 +00:00
def set_default(self, key_name, value):
pass
def show_message(self, msg):
self.messages.append(msg)
def ask_yes_no(self, prompt):
return True # always answer yes
def create_results_window(self):
pass
2011-09-21 13:17:22 +00:00
2011-11-27 21:49:12 +00:00
class ResultTable(ResultTableBase):
COLUMNS = [
Column("marked", ""),
Column("name", "Filename"),
Column("folder_path", "Directory"),
Column("size", "Size (KB)"),
Column("extension", "Kind"),
]
DELTA_COLUMNS = {
"size",
}
2011-11-27 21:49:12 +00:00
class DupeGuru(DupeGuruBase):
NAME = "dupeGuru"
METADATA_TO_READ = ["size"]
2011-09-21 13:17:22 +00:00
def __init__(self):
2013-11-08 21:45:14 +00:00
DupeGuruBase.__init__(self, DupeGuruView())
self.appdata = "/tmp"
2016-06-08 01:32:30 +00:00
self._recreate_result_table()
def _prioritization_categories(self):
return prioritize.all_categories()
2016-06-08 01:32:30 +00:00
def _recreate_result_table(self):
if self.result_table is not None:
self.result_table.disconnect()
self.result_table = ResultTable(self)
self.result_table.view = CallLogger()
self.result_table.connect()
class NamedObject:
def __init__(self, name="foobar", with_words=False, size=1, folder=None):
self.name = name
if folder is None:
folder = "basepath"
self._folder = Path(folder)
self.size = size
self.digest_partial = name
self.digest = name
self.digest_samples = name
if with_words:
self.words = getwords(name)
self.is_ref = False
def __bool__(self):
return False # Make sure that operations are made correctly when the bool value of files is false.
def get_display_info(self, group, delta):
size = self.size
m = group.get_match_of(self)
if m and delta:
r = group.ref
size -= r.size
return {
"name": self.name,
"folder_path": str(self.folder_path),
"size": format_size(size, 0, 1, False),
"extension": self.extension if hasattr(self, "extension") else "---",
}
@property
def path(self):
return self._folder.joinpath(self.name)
@property
def folder_path(self):
return self.path.parent
@property
def extension(self):
return get_file_ext(self.name)
# Returns a group set that looks like that:
# "foo bar" (1)
# "bar bleh" (1024)
# "foo bleh" (1)
# "ibabtu" (1)
# "ibabtu" (1)
def GetTestGroups():
2016-05-29 19:02:39 +00:00
objects = [
NamedObject("foo bar"),
NamedObject("bar bleh"),
NamedObject("foo bleh"),
NamedObject("ibabtu"),
NamedObject("ibabtu"),
2016-05-29 19:02:39 +00:00
]
objects[1].size = 1024
matches = engine.getmatches(objects) # we should have 5 matches
groups = engine.get_groups(matches) # We should have 2 groups
for g in groups:
g.prioritize(lambda x: objects.index(x)) # We want the dupes to be in the same order as the list is
groups.sort(key=len, reverse=True) # We want the group with 3 members to be first.
2016-05-29 19:02:39 +00:00
return (objects, matches, groups)
class TestApp(TestAppBase):
__test__ = False
def __init__(self):
2011-11-27 21:49:12 +00:00
def link_gui(gui):
gui.view = self.make_logger()
if hasattr(gui, "_columns"): # tables
gui._columns.view = self.make_logger()
2011-11-27 21:49:12 +00:00
return gui
2011-11-27 21:49:12 +00:00
TestAppBase.__init__(self)
self.app = DupeGuru()
2011-11-27 21:49:12 +00:00
self.default_parent = self.app
2012-01-23 20:09:13 +00:00
self.dtree = link_gui(self.app.directory_tree)
self.dpanel = link_gui(self.app.details_panel)
self.slabel = link_gui(self.app.stats_label)
2012-01-23 20:09:13 +00:00
self.pdialog = PrioritizeDialog(self.app)
link_gui(self.pdialog.category_list)
link_gui(self.pdialog.criteria_list)
link_gui(self.pdialog.prioritization_list)
2012-03-14 16:47:21 +00:00
link_gui(self.app.ignore_list_dialog)
link_gui(self.app.ignore_list_dialog.ignore_list_table)
2013-08-04 13:26:18 +00:00
link_gui(self.app.progress_window)
link_gui(self.app.progress_window.jobdesc_textfield)
link_gui(self.app.progress_window.progressdesc_textfield)
@property
def rtable(self):
# rtable is a property because its instance can be replaced during execution
return self.app.result_table
# --- Helpers
def select_pri_criterion(self, name):
# Select a main prioritize criterion by name instead of by index. Makes tests more
# maintainable.
index = self.pdialog.category_list.index(name)
self.pdialog.category_list.select(index)
def add_pri_criterion(self, name, index):
self.select_pri_criterion(name)
self.pdialog.criteria_list.select([index])
self.pdialog.add_selected()