mirror of
				https://github.com/paperless-ngx/paperless-ngx.git
				synced 2025-10-26 16:22:35 -04:00 
			
		
		
		
	Merge pull request #247 from danielquinn/issue/235
Allow correspondents to be deleted without deleting their documents
This commit is contained in:
		
						commit
						e293f70a91
					
				| @ -2,6 +2,11 @@ Changelog | |||||||
| ######### | ######### | ||||||
| 
 | 
 | ||||||
| * 0.7.0 | * 0.7.0 | ||||||
|  |   * **Potentially breaking change**: As per `#235`_, Paperless will no longer | ||||||
|  |     automatically delete documents attached to correspondents when those | ||||||
|  |     correspondents are themselves deleted.  This was Django's default | ||||||
|  |     behaviour, but didn't make much sense in Paperless' case.  Thanks to | ||||||
|  |     `Thomas Brueggemann`_ and `David Martin`_ for their input on this one. | ||||||
|   * Fix for `#232`_ wherein Paperless wasn't recognising ``.tif`` files |   * Fix for `#232`_ wherein Paperless wasn't recognising ``.tif`` files | ||||||
|     properly.  Thanks to `ayounggun`_ for reporting this one and to |     properly.  Thanks to `ayounggun`_ for reporting this one and to | ||||||
|     `Kusti Skytén`_ for posting the correct solution in the Github issue. |     `Kusti Skytén`_ for posting the correct solution in the Github issue. | ||||||
| @ -264,5 +269,5 @@ Changelog | |||||||
| .. _#229: https://github.com/danielquinn/paperless/pull/229 | .. _#229: https://github.com/danielquinn/paperless/pull/229 | ||||||
| .. _#230: https://github.com/danielquinn/paperless/pull/230 | .. _#230: https://github.com/danielquinn/paperless/pull/230 | ||||||
| .. _#232: https://github.com/danielquinn/paperless/issues/232 | .. _#232: https://github.com/danielquinn/paperless/issues/232 | ||||||
|  | .. _#235: https://github.com/danielquinn/paperless/issues/235 | ||||||
| .. _#236: https://github.com/danielquinn/paperless/issues/236 | .. _#236: https://github.com/danielquinn/paperless/issues/236 | ||||||
| 
 |  | ||||||
|  | |||||||
| @ -16,6 +16,7 @@ pytz>=2016.10 | |||||||
| gunicorn==19.6.0 | gunicorn==19.6.0 | ||||||
| 
 | 
 | ||||||
| # For the tests | # For the tests | ||||||
|  | factory-boy | ||||||
| pytest | pytest | ||||||
| pytest-django | pytest-django | ||||||
| pytest-sugar | pytest-sugar | ||||||
|  | |||||||
							
								
								
									
										21
									
								
								src/documents/migrations/0018_auto_20170715_1712.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										21
									
								
								src/documents/migrations/0018_auto_20170715_1712.py
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,21 @@ | |||||||
|  | # -*- coding: utf-8 -*- | ||||||
|  | # Generated by Django 1.10.5 on 2017-07-15 17:12 | ||||||
|  | from __future__ import unicode_literals | ||||||
|  | 
 | ||||||
|  | from django.db import migrations, models | ||||||
|  | import django.db.models.deletion | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | class Migration(migrations.Migration): | ||||||
|  | 
 | ||||||
|  |     dependencies = [ | ||||||
|  |         ('documents', '0017_auto_20170512_0507'), | ||||||
|  |     ] | ||||||
|  | 
 | ||||||
|  |     operations = [ | ||||||
|  |         migrations.AlterField( | ||||||
|  |             model_name='document', | ||||||
|  |             name='correspondent', | ||||||
|  |             field=models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.SET_NULL, related_name='documents', to='documents.Correspondent'), | ||||||
|  |         ), | ||||||
|  |     ] | ||||||
| @ -172,7 +172,12 @@ class Document(models.Model): | |||||||
|     TYPES = (TYPE_PDF, TYPE_PNG, TYPE_JPG, TYPE_GIF, TYPE_TIF,) |     TYPES = (TYPE_PDF, TYPE_PNG, TYPE_JPG, TYPE_GIF, TYPE_TIF,) | ||||||
| 
 | 
 | ||||||
|     correspondent = models.ForeignKey( |     correspondent = models.ForeignKey( | ||||||
|         Correspondent, blank=True, null=True, related_name="documents") |         Correspondent, | ||||||
|  |         blank=True, | ||||||
|  |         null=True, | ||||||
|  |         related_name="documents", | ||||||
|  |         on_delete=models.SET_NULL | ||||||
|  |     ) | ||||||
| 
 | 
 | ||||||
|     title = models.CharField(max_length=128, blank=True, db_index=True) |     title = models.CharField(max_length=128, blank=True, db_index=True) | ||||||
| 
 | 
 | ||||||
|  | |||||||
							
								
								
									
										17
									
								
								src/documents/tests/factories.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										17
									
								
								src/documents/tests/factories.py
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,17 @@ | |||||||
|  | import factory | ||||||
|  | 
 | ||||||
|  | from ..models import Document, Correspondent | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | class CorrespondentFactory(factory.DjangoModelFactory): | ||||||
|  | 
 | ||||||
|  |     class Meta: | ||||||
|  |         model = Correspondent | ||||||
|  | 
 | ||||||
|  |     name = factory.Faker("name") | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | class DocumentFactory(factory.DjangoModelFactory): | ||||||
|  | 
 | ||||||
|  |     class Meta: | ||||||
|  |         model = Document | ||||||
							
								
								
									
										31
									
								
								src/documents/tests/test_models.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										31
									
								
								src/documents/tests/test_models.py
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,31 @@ | |||||||
|  | from django.test import TestCase | ||||||
|  | 
 | ||||||
|  | from ..models import Document, Correspondent | ||||||
|  | from .factories import DocumentFactory, CorrespondentFactory | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | class CorrespondentTestCase(TestCase): | ||||||
|  | 
 | ||||||
|  |     def test___str__(self): | ||||||
|  |         for s in ("test", "οχι", "test with fun_charÅc'\"terß"): | ||||||
|  |             correspondent = CorrespondentFactory.create(name=s) | ||||||
|  |             self.assertEqual(str(correspondent), s) | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | class DocumentTestCase(TestCase): | ||||||
|  | 
 | ||||||
|  |     def test_correspondent_deletion_does_not_cascade(self): | ||||||
|  | 
 | ||||||
|  |         self.assertEqual(Correspondent.objects.all().count(), 0) | ||||||
|  |         correspondent = CorrespondentFactory.create() | ||||||
|  |         self.assertEqual(Correspondent.objects.all().count(), 1) | ||||||
|  | 
 | ||||||
|  |         self.assertEqual(Document.objects.all().count(), 0) | ||||||
|  |         DocumentFactory.create(correspondent=correspondent) | ||||||
|  |         self.assertEqual(Document.objects.all().count(), 1) | ||||||
|  |         self.assertIsNotNone(Document.objects.all().first().correspondent) | ||||||
|  | 
 | ||||||
|  |         correspondent.delete() | ||||||
|  |         self.assertEqual(Correspondent.objects.all().count(), 0) | ||||||
|  |         self.assertEqual(Document.objects.all().count(), 1) | ||||||
|  |         self.assertIsNone(Document.objects.all().first().correspondent) | ||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user