PyCIRCLean/tests/test_kittengroomer.py

262 lines
9.4 KiB
Python
Raw Normal View History

2016-12-05 17:19:39 +01:00
#!/usr/bin/env python
# -*- coding: utf-8 -*-
2016-12-09 02:12:08 +01:00
import os
2016-12-05 17:19:39 +01:00
import pytest
from kittengroomer import FileBase, KittenGroomerBase, GroomerLogger
2016-12-09 22:13:54 +01:00
from kittengroomer.helpers import ImplementationRequired
2016-12-05 17:19:39 +01:00
2016-12-09 02:12:08 +01:00
skip = pytest.mark.skip
xfail = pytest.mark.xfail
fixture = pytest.fixture
2016-12-05 17:19:39 +01:00
2016-12-09 22:13:54 +01:00
# FileBase
2016-12-05 17:19:39 +01:00
2016-12-09 02:12:08 +01:00
class TestFileBase:
2016-12-05 17:19:39 +01:00
2016-12-09 02:12:08 +01:00
@fixture
def source_file(self):
return 'tests/src_valid/blah.conf'
2016-12-09 02:12:08 +01:00
@fixture
def dest_file(self):
return 'tests/dst/blah.conf'
@fixture
def generic_conf_file(self, source_file, dest_file):
return FileBase(source_file, dest_file)
@fixture
def symlink_file(self, tmpdir):
2016-12-09 02:12:08 +01:00
file_path = tmpdir.join('test.txt')
file_path.write('testing')
file_path = file_path.strpath
symlink_path = tmpdir.join('symlinked.txt')
symlink_path = symlink_path.strpath
2016-12-09 22:13:54 +01:00
os.symlink(file_path, symlink_path)
2016-12-09 02:12:08 +01:00
return FileBase(symlink_path, symlink_path)
@fixture
def temp_file(self, tmpdir):
file_path = tmpdir.join('test.txt')
file_path.write('testing')
file_path = file_path.strpath
return FileBase(file_path, file_path)
@fixture
def temp_file_no_ext(self, tmpdir):
file_path = tmpdir.join('test')
file_path.write('testing')
file_path = file_path.strpath
return FileBase(file_path, file_path)
@fixture
def file_marked_dangerous(self, generic_conf_file):
generic_conf_file.make_dangerous()
2016-12-09 22:13:54 +01:00
return generic_conf_file
2016-12-09 02:12:08 +01:00
@fixture
def file_marked_unknown(self, generic_conf_file):
generic_conf_file.make_unknown()
2016-12-09 22:13:54 +01:00
return generic_conf_file
2016-12-09 02:12:08 +01:00
@fixture
def file_marked_binary(self, generic_conf_file):
generic_conf_file.make_binary()
2016-12-09 22:13:54 +01:00
return generic_conf_file
2016-12-09 02:12:08 +01:00
@fixture(params=[
FileBase.make_dangerous,
FileBase.make_unknown,
FileBase.make_binary
])
def file_marked_all_parameterized(self, request, generic_conf_file):
request.param(generic_conf_file)
return generic_conf_file
# What are the various things that can go wrong with file paths? We should have fixtures for them
2016-12-09 22:13:54 +01:00
# What should FileBase do if it's given a path that isn't a file (doesn't exist or is a dir)? Currently magic throws an exception
# We should probably catch everytime that happens and tell the user explicitly happened (and maybe put it in the log)
2016-12-09 02:12:08 +01:00
def test_create_broken(self, tmpdir):
with pytest.raises(TypeError):
FileBase()
2017-01-19 23:06:34 +01:00
with pytest.raises(FileNotFoundError):
FileBase('', '')
2017-01-19 23:06:34 +01:00
with pytest.raises(IsADirectoryError):
FileBase(tmpdir.strpath, tmpdir.strpath)
# TODO: are there other cases here? path to a file that doesn't exist? permissions?
2016-12-09 02:12:08 +01:00
def test_init(self, generic_conf_file):
generic_conf_file
2016-12-09 02:12:08 +01:00
def test_extension_uppercase(self, tmpdir):
file_path = tmpdir.join('TEST.TXT')
file_path.write('testing')
file_path = file_path.strpath
file = FileBase(file_path, file_path)
assert file.extension == '.txt'
2016-12-09 02:12:08 +01:00
def test_mimetypes(self, generic_conf_file):
assert generic_conf_file.mimetype == 'text/plain'
assert generic_conf_file.main_type == 'text'
assert generic_conf_file.sub_type == 'plain'
2017-03-10 19:13:38 +01:00
assert generic_conf_file.has_mimetype
2016-12-09 22:13:54 +01:00
# Need to test something without a mimetype
# Need to test something that's a directory
# Need to test something that causes the unicode exception
def test_has_mimetype_no_main_type(self, generic_conf_file):
generic_conf_file.main_type = ''
2017-03-10 19:13:38 +01:00
assert generic_conf_file.has_mimetype is False
2016-12-09 22:13:54 +01:00
def test_has_mimetype_no_sub_type(self, generic_conf_file):
generic_conf_file.sub_type = ''
2017-03-10 19:13:38 +01:00
assert generic_conf_file.has_mimetype is False
2016-12-09 02:12:08 +01:00
def test_has_extension(self, temp_file, temp_file_no_ext):
2017-03-10 19:13:38 +01:00
assert temp_file.has_extension is True
print(temp_file_no_ext.extension)
2017-03-10 19:13:38 +01:00
assert temp_file_no_ext.has_extension is False
2016-12-09 22:13:54 +01:00
def test_set_property(self, generic_conf_file):
generic_conf_file.set_property('test', True)
assert generic_conf_file.get_property('test') is True
assert generic_conf_file.get_property('wrong') is None
2016-12-09 02:12:08 +01:00
def test_marked_dangerous(self, file_marked_all_parameterized):
file_marked_all_parameterized.make_dangerous()
2017-03-10 19:13:38 +01:00
assert file_marked_all_parameterized.is_dangerous is True
2016-12-05 17:19:39 +01:00
# Should work regardless of weird paths??
2016-12-09 02:12:08 +01:00
# Should check file path alteration behavior as well
def test_generic_dangerous(self, generic_conf_file):
2017-03-10 19:13:38 +01:00
assert generic_conf_file.is_dangerous is False
2016-12-09 02:12:08 +01:00
generic_conf_file.make_dangerous()
2017-03-10 19:13:38 +01:00
assert generic_conf_file.is_dangerous is True
2016-12-09 02:12:08 +01:00
def test_has_symlink(self, tmpdir):
file_path = tmpdir.join('test.txt')
file_path.write('testing')
file_path = file_path.strpath
symlink_path = tmpdir.join('symlinked.txt')
symlink_path = symlink_path.strpath
os.symlink(file_path, symlink_path)
2016-12-09 02:12:08 +01:00
file = FileBase(file_path, file_path)
symlink = FileBase(symlink_path, symlink_path)
2017-03-10 19:13:38 +01:00
assert file.is_symlink is False
assert symlink.is_symlink is True
2016-12-09 02:12:08 +01:00
def test_has_symlink_fixture(self, symlink_file):
2017-03-10 19:13:38 +01:00
assert symlink_file.is_symlink is True
2016-12-09 02:12:08 +01:00
def test_generic_make_unknown(self, generic_conf_file):
2017-03-10 19:13:38 +01:00
assert generic_conf_file.is_unknown is False
2016-12-09 02:12:08 +01:00
generic_conf_file.make_unknown()
2017-03-10 19:13:38 +01:00
assert generic_conf_file.is_unknown
2016-12-05 17:19:39 +01:00
# given a FileBase object with no marking, should do the right things
2016-12-09 02:12:08 +01:00
def test_marked_make_unknown(self, file_marked_all_parameterized):
file = file_marked_all_parameterized
2017-03-10 19:13:38 +01:00
if file.is_unknown:
2016-12-09 02:12:08 +01:00
file.make_unknown()
2017-03-10 19:13:38 +01:00
assert file.is_unknown
2016-12-09 02:12:08 +01:00
else:
2017-03-10 19:13:38 +01:00
assert file.is_unknown is False
2016-12-09 02:12:08 +01:00
file.make_unknown()
2017-03-10 19:13:38 +01:00
assert file.is_unknown is False
2016-12-09 02:12:08 +01:00
# given a FileBase object with an unrecognized marking, should ???
2016-12-05 17:19:39 +01:00
2016-12-09 02:12:08 +01:00
def test_generic_make_binary(self, generic_conf_file):
2017-03-10 19:13:38 +01:00
assert generic_conf_file.is_binary is False
2016-12-09 02:12:08 +01:00
generic_conf_file.make_binary()
2017-03-10 19:13:38 +01:00
assert generic_conf_file.is_binary
2016-12-09 02:12:08 +01:00
def test_marked_make_binary(self, file_marked_all_parameterized):
file = file_marked_all_parameterized
2017-03-10 19:13:38 +01:00
if file.is_dangerous:
2016-12-09 02:12:08 +01:00
file.make_binary()
2017-03-10 19:13:38 +01:00
assert file.is_binary is False
2016-12-09 02:12:08 +01:00
else:
file.make_binary()
2017-03-10 19:13:38 +01:00
assert file.is_binary
2016-12-09 02:12:08 +01:00
def test_force_ext_change(self, generic_conf_file):
2017-03-10 19:13:38 +01:00
assert generic_conf_file.has_extension
assert generic_conf_file.get_property('extension') == '.conf'
2016-12-09 02:12:08 +01:00
assert os.path.splitext(generic_conf_file.dst_path)[1] == '.conf'
generic_conf_file.force_ext('.txt')
assert os.path.splitext(generic_conf_file.dst_path)[1] == '.txt'
assert generic_conf_file.get_property('force_ext') is True
assert generic_conf_file.get_property('extension') == '.txt'
2016-12-09 02:12:08 +01:00
# should be able to handle weird paths
def test_force_ext_correct(self, generic_conf_file):
2017-03-10 19:13:38 +01:00
assert generic_conf_file.has_extension
assert generic_conf_file.get_property('extension') == '.conf'
2016-12-09 02:12:08 +01:00
generic_conf_file.force_ext('.conf')
assert os.path.splitext(generic_conf_file.dst_path)[1] == '.conf'
assert generic_conf_file.get_property('force_ext') is None
2016-12-05 17:19:39 +01:00
# shouldn't change a file's extension if it already is right
2017-02-16 23:27:00 +01:00
def test_create_metadata_file(self, temp_file):
# Try making a metadata file
metadata_file_path = temp_file.create_metadata_file('.metadata.txt')
with open(metadata_file_path, 'w+') as metadata_file:
metadata_file.write('Have some metadata!')
# Shouldn't be able to make a metadata file with no extension
assert temp_file.create_metadata_file('') is False
# if metadata file already exists
# if there is no metadata to write should this work?
2017-03-10 19:13:38 +01:00
def test_safe_copy(self, generic_conf_file):
generic_conf_file.safe_copy()
# check that safe copy can handle weird file path inputs
2016-12-05 17:19:39 +01:00
class TestLogger:
@fixture
def generic_logger(self, tmpdir):
return GroomerLogger(tmpdir.strpath)
def test_tree(self, generic_logger):
generic_logger.tree(generic_logger.root_dir)
2016-12-05 17:19:39 +01:00
class TestKittenGroomerBase:
2016-12-09 02:12:08 +01:00
2016-12-09 22:13:54 +01:00
@fixture
def source_directory(self):
return 'tests/src_invalid'
2016-12-05 17:19:39 +01:00
2016-12-09 22:13:54 +01:00
@fixture
def dest_directory(self):
return 'tests/dst'
2016-12-05 17:19:39 +01:00
2016-12-09 22:13:54 +01:00
@fixture
def generic_groomer(self, source_directory, dest_directory):
return KittenGroomerBase(source_directory, dest_directory)
2016-12-05 17:19:39 +01:00
2016-12-09 22:13:54 +01:00
def test_create(self, generic_groomer):
assert generic_groomer
2016-12-05 17:19:39 +01:00
2016-12-09 22:13:54 +01:00
def test_instantiation(self, source_directory, dest_directory):
groomer = KittenGroomerBase(source_directory, dest_directory)
debug_groomer = KittenGroomerBase(source_directory,
dest_directory,
debug=True)
def test_list_all_files(self, tmpdir):
file = tmpdir.join('test.txt')
file.write('testing')
testdir = tmpdir.join('testdir')
os.mkdir(testdir.strpath)
simple_groomer = KittenGroomerBase(tmpdir.strpath, tmpdir.strpath)
2017-02-24 16:43:42 +01:00
files = simple_groomer.list_all_files(simple_groomer.src_root_dir)
2016-12-09 22:13:54 +01:00
assert file.strpath in files
assert testdir.strpath not in files