diff --git a/bookwyrm/tests/views/imports/test_import.py b/bookwyrm/tests/views/imports/test_import.py index 362cb199c..763c2a523 100644 --- a/bookwyrm/tests/views/imports/test_import.py +++ b/bookwyrm/tests/views/imports/test_import.py @@ -1,14 +1,13 @@ """ test for app action functionality """ import pathlib from unittest.mock import patch - from django.core.files.uploadedfile import SimpleUploadedFile from django.template.response import TemplateResponse from django.test import TestCase from django.test.client import RequestFactory +from bookwyrm.tests.validate_html import validate_html from bookwyrm import forms, models, views -from bookwyrm.tests.validate_html import validate_html class ImportViews(TestCase): @@ -45,29 +44,15 @@ class ImportViews(TestCase): import_job = models.ImportJob.objects.create(user=self.local_user, mappings={}) request = self.factory.get("") request.user = self.local_user - - result = view(request, import_job.id) - + with patch("bookwyrm.tasks.app.AsyncResult") as async_result: + async_result.return_value = [] + result = view(request, import_job.id) self.assertIsInstance(result, TemplateResponse) validate_html(result.render()) self.assertEqual(result.status_code, 200) - def test_import_status_reformat(self): - """there are so many views, this just makes sure it LOADS""" - view = views.ImportStatus.as_view() - import_job = models.ImportJob.objects.create(user=self.local_user, mappings={}) - request = self.factory.post("") - request.user = self.local_user - with patch( - "bookwyrm.importers.goodreads_import.GoodreadsImporter.update_legacy_job" - ) as mock: - result = view(request, import_job.id) - self.assertEqual(mock.call_args[0][0], import_job) - - self.assertEqual(result.status_code, 302) - def test_start_import(self): - """start a job""" + """retry failed items""" view = views.Import.as_view() form = forms.ImportForm() form.data["source"] = "Goodreads" @@ -89,20 +74,3 @@ class ImportViews(TestCase): job = models.ImportJob.objects.get() self.assertFalse(job.include_reviews) self.assertEqual(job.privacy, "public") - - def test_retry_item(self): - """try again on a single row""" - job = models.ImportJob.objects.create(user=self.local_user, mappings={}) - item = models.ImportItem.objects.create( - index=0, - job=job, - book_guess=self.book, - fail_reason="no match", - data={}, - normalized_data={}, - ) - request = self.factory.post("") - request.user = self.local_user - with patch("bookwyrm.importers.importer.import_item_task.delay") as mock: - views.retry_item(request, job.id, item.id) - self.assertEqual(mock.call_count, 1) diff --git a/bookwyrm/views/imports/import_data.py b/bookwyrm/views/imports/import_data.py index 80386b3de..7f6a4d13f 100644 --- a/bookwyrm/views/imports/import_data.py +++ b/bookwyrm/views/imports/import_data.py @@ -37,32 +37,33 @@ class Import(View): def post(self, request): """ingest a goodreads csv""" form = forms.ImportForm(request.POST, request.FILES) - if not form.is_valid(): - return HttpResponseBadRequest() + if form.is_valid(): + include_reviews = request.POST.get("include_reviews") == "on" + privacy = request.POST.get("privacy") + source = request.POST.get("source") - include_reviews = request.POST.get("include_reviews") == "on" - privacy = request.POST.get("privacy") - source = request.POST.get("source") + importer = None + if source == "LibraryThing": + importer = LibrarythingImporter() + elif source == "Storygraph": + importer = StorygraphImporter() + else: + # Default : Goodreads + importer = GoodreadsImporter() - importer = None - if source == "LibraryThing": - importer = LibrarythingImporter() - elif source == "Storygraph": - importer = StorygraphImporter() - else: - # Default : Goodreads - importer = GoodreadsImporter() + try: + job = importer.create_job( + request.user, + TextIOWrapper( + request.FILES["csv_file"], encoding=importer.encoding + ), + include_reviews, + privacy, + ) + except (UnicodeDecodeError, ValueError, KeyError): + return HttpResponseBadRequest(_("Not a valid csv file")) - try: - job = importer.create_job( - request.user, - TextIOWrapper(request.FILES["csv_file"], encoding=importer.encoding), - include_reviews, - privacy, - ) - except (UnicodeDecodeError, ValueError, KeyError): - return HttpResponseBadRequest(_("Not a valid csv file")) + importer.start_import(job) - importer.start_import(job) - - return redirect(f"/import/{job.id}") + return redirect(f"/import/{job.id}") + return HttpResponseBadRequest()