summaryrefslogtreecommitdiff
path: root/archaeological_finds/tests.py
diff options
context:
space:
mode:
Diffstat (limited to 'archaeological_finds/tests.py')
-rw-r--r--archaeological_finds/tests.py36
1 files changed, 36 insertions, 0 deletions
diff --git a/archaeological_finds/tests.py b/archaeological_finds/tests.py
index 2cf184561..c36327bae 100644
--- a/archaeological_finds/tests.py
+++ b/archaeological_finds/tests.py
@@ -18,6 +18,7 @@
# See the file COPYING for details.
from copy import deepcopy
import csv
+from io import StringIO
import json
import os
import shutil
@@ -1004,6 +1005,41 @@ class ImportFindTest(BaseImportFindTest):
self.assertEqual(len(impt.errors), 0)
+class ExportTest(FindInit, TestCase):
+ fixtures = FIND_TOWNS_FIXTURES
+
+ def setUp(self):
+ super().setUp()
+ self.username, self.password, self.user = create_superuser()
+
+ def test_ishtar_export_find(self):
+ self.create_finds(data={"label": "1234"})
+ self.create_finds(data={"label": "567"})
+ MCC = ImporterType.objects.get(name="MCC - Mobilier")
+ c = Client()
+ url = reverse(
+ "get-by-importer", kwargs={"slug": MCC.slug, "type": "csv"}
+ )
+ response = c.get(url)
+ # no result when no authentication
+ self.assertTrue(not response.content)
+ c.login(username=self.username, password=self.password)
+ response = c.get(url)
+ ENCODING = settings.ENCODING or "utf-8"
+ rows = list(csv.reader(StringIO(response.content.decode(ENCODING))))
+ # one header + two find
+ self.assertEqual(len(rows), 3)
+ row_cr = rows[1]
+ for row in rows[1:]:
+ self.assertEqual(row[0], "1")
+ self.assertEqual(row[1], "12345")
+ self.assertEqual(row[2], "A1")
+ self.assertEqual(row[3], "Context record")
+ self.assertEqual(row[4], "Base find")
+ self.assertEqual(rows[1][11], "1234")
+ self.assertEqual(rows[2][11], "567")
+
+
class ImportFindLiveServerTest(LiveServerTestCase, BaseImportFindTest):
def setUp(self):