mirror of
https://github.com/paperless-ngx/paperless-ngx.git
synced 2025-04-02 13:45:10 -05:00
Fix for #131: delete files on document.delete
This commit is contained in:
parent
58a299b671
commit
f5daded930
@ -1,4 +1,5 @@
|
|||||||
from django.apps import AppConfig
|
from django.apps import AppConfig
|
||||||
|
from django.db.models.signals import post_delete
|
||||||
|
|
||||||
|
|
||||||
class DocumentsConfig(AppConfig):
|
class DocumentsConfig(AppConfig):
|
||||||
@ -10,8 +11,12 @@ class DocumentsConfig(AppConfig):
|
|||||||
from .signals import document_consumption_started
|
from .signals import document_consumption_started
|
||||||
from .signals import document_consumption_finished
|
from .signals import document_consumption_finished
|
||||||
from .signals.handlers import (
|
from .signals.handlers import (
|
||||||
set_correspondent, set_tags, run_pre_consume_script,
|
set_correspondent,
|
||||||
run_post_consume_script)
|
set_tags,
|
||||||
|
run_pre_consume_script,
|
||||||
|
run_post_consume_script,
|
||||||
|
cleanup_document_deletion
|
||||||
|
)
|
||||||
|
|
||||||
document_consumption_started.connect(run_pre_consume_script)
|
document_consumption_started.connect(run_pre_consume_script)
|
||||||
|
|
||||||
@ -19,4 +24,6 @@ class DocumentsConfig(AppConfig):
|
|||||||
document_consumption_finished.connect(set_correspondent)
|
document_consumption_finished.connect(set_correspondent)
|
||||||
document_consumption_finished.connect(run_post_consume_script)
|
document_consumption_finished.connect(run_post_consume_script)
|
||||||
|
|
||||||
|
post_delete.connect(cleanup_document_deletion)
|
||||||
|
|
||||||
AppConfig.ready(self)
|
AppConfig.ready(self)
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
import logging
|
import logging
|
||||||
|
import os
|
||||||
|
|
||||||
from subprocess import Popen
|
from subprocess import Popen
|
||||||
|
|
||||||
@ -62,10 +63,7 @@ def run_pre_consume_script(sender, filename, **kwargs):
|
|||||||
if not settings.PRE_CONSUME_SCRIPT:
|
if not settings.PRE_CONSUME_SCRIPT:
|
||||||
return
|
return
|
||||||
|
|
||||||
Popen((
|
Popen((settings.PRE_CONSUME_SCRIPT, filename)).wait()
|
||||||
settings.PRE_CONSUME_SCRIPT,
|
|
||||||
filename
|
|
||||||
)).wait()
|
|
||||||
|
|
||||||
|
|
||||||
def run_post_consume_script(sender, document, **kwargs):
|
def run_post_consume_script(sender, document, **kwargs):
|
||||||
@ -84,3 +82,10 @@ def run_post_consume_script(sender, document, **kwargs):
|
|||||||
str(document.correspondent),
|
str(document.correspondent),
|
||||||
str(",".join(document.tags.all().values_list("slug", flat=True)))
|
str(",".join(document.tags.all().values_list("slug", flat=True)))
|
||||||
)).wait()
|
)).wait()
|
||||||
|
|
||||||
|
|
||||||
|
def cleanup_document_deletion(sender, instance, using, **kwargs):
|
||||||
|
try:
|
||||||
|
os.unlink(instance.source_path)
|
||||||
|
except FileNotFoundError:
|
||||||
|
pass # The file's already gone, so we're cool with it.
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
from django.test import TestCase
|
from django.test import TestCase
|
||||||
|
|
||||||
from ..models import Document, FileInfo
|
from ..models import FileInfo
|
||||||
|
|
||||||
|
|
||||||
class TestAttachment(TestCase):
|
class TestAttachment(TestCase):
|
||||||
|
20
src/documents/tests/test_document_model.py
Normal file
20
src/documents/tests/test_document_model.py
Normal file
@ -0,0 +1,20 @@
|
|||||||
|
from unittest import mock
|
||||||
|
|
||||||
|
from django.test import TestCase
|
||||||
|
|
||||||
|
from ..models import Document, Correspondent
|
||||||
|
|
||||||
|
|
||||||
|
class TestDocument(TestCase):
|
||||||
|
|
||||||
|
def test_file_deletion(self):
|
||||||
|
document = Document.objects.create(
|
||||||
|
correspondent=Correspondent.objects.create(name="Test0"),
|
||||||
|
title="Title",
|
||||||
|
content="content",
|
||||||
|
checksum="checksum",
|
||||||
|
)
|
||||||
|
file_path = document.source_path
|
||||||
|
with mock.patch("documents.signals.handlers.os.unlink") as mock_unlink:
|
||||||
|
document.delete()
|
||||||
|
mock_unlink.assert_called_with(file_path)
|
Loading…
x
Reference in New Issue
Block a user