Use puremagic to deobfuscate file extensions (#1914)
* correct_extension: basics, including unittest
* correct_extension: basics, including unittest
* correct_extension: puremagic into requirements.txt
* correct_extension: introduce a main for testing from CLI
* correct_extension: parse all parameters on CLI as files
* correct_extension: parse all parameters on CLI as files
* correct_extension: CLI parameter "-p" for privacy output
* correct_extension: has_common_extension() and most_likely_extension()
* correct_extension: has_common_extension() and most_likely_extension()
* correct_extension: add extension if file has no commonly used extension
* correct_extension: Black happy ... hopefully
* correct_extension: Black happy ... hopefully
* correct_extension: process feedback, mainly the extenions lists ^H^H^H^ tuples
* correct_extension: process feedback, mainly the extenions lists ^H^H^H^ tuples
* correct_extension: process feedback, mainly the extenions lists ^H^H^H^ tuples
* correct_extension: process feedback, mainly the extenions lists ^H^H^H^ tuples
* correct_extension: cleaned up
* correct_extension: cleaned up ... github-black now happy?
* correct_extension: cleaned up ... github-black now happy?
* correct_extension: cleaned up ... github-black now happy?
* correct_extension: cleaned up ... github-black now happy?
* correct_extension: cleaned up ... github-black now happy?
* correct_extension: easier if-then-logic, check if new_extension_to_add is filled.
* correct_extension: if puremagic does recoging txt or nzb, check ourselves
* correct_extension: if puremagic does recoging txt or nzb, check ourselves
* correct_extension: only files!
* correct_extension: only files!
* correct_extension: rNN files not common extension, plus easier testing
* correct_extension: clean-up ... no more boolean extension_too
* correct_extension: requirements.txt, solved a TODO, and use get_ext()
* correct_extension: a comment added
* correct_extension: correct typing, correct txt and nzb extension
* correct_extension: extensions always with dots, bug fix in what_is_most_likely_extension()
* correct_extension: back on track?
* correct_extension: back on track?
* correct_extension: better comments
4 years ago
|
|
|
#!/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.
|
|
|
|
|
|
|
|
"""
|
|
|
|
Testing SABnzbd correct extension functionality module
|
|
|
|
"""
|
|
|
|
|
|
|
|
import os
|
|
|
|
from tests.testhelper import *
|
|
|
|
import sabnzbd.utils.file_extension as file_extension
|
|
|
|
|
|
|
|
|
|
|
|
class Test_File_Extension:
|
|
|
|
def test_has_popular_extension(self):
|
|
|
|
assert file_extension.has_popular_extension("blabla/blabla.mkv")
|
|
|
|
assert file_extension.has_popular_extension("blabla/blabla.srt")
|
|
|
|
assert file_extension.has_popular_extension("djjddj/aaaaa.epub")
|
|
|
|
assert file_extension.has_popular_extension("test/testing.r01")
|
|
|
|
assert file_extension.has_popular_extension("test/testing.s91")
|
|
|
|
assert not file_extension.has_popular_extension("test/testing")
|
|
|
|
assert not file_extension.has_popular_extension("test/testing.rar01")
|
Use puremagic to deobfuscate file extensions (#1914)
* correct_extension: basics, including unittest
* correct_extension: basics, including unittest
* correct_extension: puremagic into requirements.txt
* correct_extension: introduce a main for testing from CLI
* correct_extension: parse all parameters on CLI as files
* correct_extension: parse all parameters on CLI as files
* correct_extension: CLI parameter "-p" for privacy output
* correct_extension: has_common_extension() and most_likely_extension()
* correct_extension: has_common_extension() and most_likely_extension()
* correct_extension: add extension if file has no commonly used extension
* correct_extension: Black happy ... hopefully
* correct_extension: Black happy ... hopefully
* correct_extension: process feedback, mainly the extenions lists ^H^H^H^ tuples
* correct_extension: process feedback, mainly the extenions lists ^H^H^H^ tuples
* correct_extension: process feedback, mainly the extenions lists ^H^H^H^ tuples
* correct_extension: process feedback, mainly the extenions lists ^H^H^H^ tuples
* correct_extension: cleaned up
* correct_extension: cleaned up ... github-black now happy?
* correct_extension: cleaned up ... github-black now happy?
* correct_extension: cleaned up ... github-black now happy?
* correct_extension: cleaned up ... github-black now happy?
* correct_extension: cleaned up ... github-black now happy?
* correct_extension: easier if-then-logic, check if new_extension_to_add is filled.
* correct_extension: if puremagic does recoging txt or nzb, check ourselves
* correct_extension: if puremagic does recoging txt or nzb, check ourselves
* correct_extension: only files!
* correct_extension: only files!
* correct_extension: rNN files not common extension, plus easier testing
* correct_extension: clean-up ... no more boolean extension_too
* correct_extension: requirements.txt, solved a TODO, and use get_ext()
* correct_extension: a comment added
* correct_extension: correct typing, correct txt and nzb extension
* correct_extension: extensions always with dots, bug fix in what_is_most_likely_extension()
* correct_extension: back on track?
* correct_extension: back on track?
* correct_extension: better comments
4 years ago
|
|
|
assert not file_extension.has_popular_extension("98ads098f098fa.a0ds98f098asdf")
|
|
|
|
|
|
|
|
def test_what_is_most_likely_extension(self):
|
|
|
|
# These are real-content files, where the contents determine the extension
|
|
|
|
filename = "tests/data/test_file_extension/apeeengeee" # A PNG
|
|
|
|
assert os.path.isfile(filename)
|
|
|
|
assert file_extension.what_is_most_likely_extension(filename) == ".png"
|
|
|
|
|
|
|
|
filename = "tests/data/test_file_extension/somepeedeef" # Some PDF
|
|
|
|
assert os.path.isfile(filename)
|
|
|
|
assert file_extension.what_is_most_likely_extension(filename) == ".pdf"
|
|
|
|
|
|
|
|
filename = "tests/data/test_file_extension/my_matroska" # my Matroska MKV
|
|
|
|
assert os.path.isfile(filename)
|
|
|
|
assert file_extension.what_is_most_likely_extension(filename) == ".mkv"
|
|
|
|
|
|
|
|
filename = "tests/data/test_file_extension/sometxtfile" # a txt file
|
|
|
|
assert os.path.isfile(filename)
|
|
|
|
assert file_extension.what_is_most_likely_extension(filename) == ".txt"
|
|
|
|
|
|
|
|
filename = "tests/data/test_file_extension/some_nzb_file" # a NZB file
|
|
|
|
assert os.path.isfile(filename)
|
|
|
|
assert file_extension.what_is_most_likely_extension(filename) == ".nzb"
|