diff --git a/app/routes.py b/app/routes.py index cca008c..7c813fe 100644 --- a/app/routes.py +++ b/app/routes.py @@ -110,7 +110,7 @@ class ResponseType(StrEnum): ) sort_tables_form = Form( - default=False, + default='default', title='Sort worksheets', description=('Sort the worksheets into alphabetical order ' 'or leave in the order found in the AGS file. ' @@ -240,7 +240,7 @@ def prepare_validation_response(request, data): " sort worksheets in .xlsx file in alphabetical order.")) async def convert(background_tasks: BackgroundTasks, files: List[UploadFile] = conversion_file, - sort_tables: bool = sort_tables_form, + sort_tables: str = sort_tables_form, request: Request = None): """ Convert files between .ags and .xlsx format. Option to sort worksheets in .xlsx file in alphabetical order. @@ -258,12 +258,11 @@ async def convert(background_tasks: BackgroundTasks, :raises Exception: If the conversion fails or an unexpected error occurs. """ + if sort_tables == 'default': + sort_tables = None if not files[0].filename: raise InvalidPayloadError(request) RESULTS = 'results' - sorting_strategy = None - if sort_tables: - sorting_strategy = 'alphabetical' tmp_dir = Path(tempfile.mkdtemp()) results_dir = tmp_dir / RESULTS results_dir.mkdir() @@ -274,7 +273,7 @@ async def convert(background_tasks: BackgroundTasks, contents = await file.read() local_file = tmp_dir / file.filename local_file.write_bytes(contents) - converted, result = conversion.convert(local_file, results_dir, sorting_strategy=sorting_strategy) + converted, result = conversion.convert(local_file, results_dir, sorting_strategy=sort_tables) log = validation.to_plain_text(result) f.write(log) f.write('\n' + '=' * 80 + '\n') diff --git a/test/integration/test_api.py b/test/integration/test_api.py index 589e0d0..6111d50 100644 --- a/test/integration/test_api.py +++ b/test/integration/test_api.py @@ -225,7 +225,7 @@ async def test_convert_good_files(async_client, tmp_path): @pytest.mark.asyncio -@pytest.mark.parametrize('sort_tables', [True, False, None]) +@pytest.mark.parametrize('sort_tables', ['alphabetical', 'default']) async def test_convert_sort_tables(async_client, tmp_path, sort_tables): # Arrange fields = [] @@ -257,7 +257,7 @@ async def test_convert_sort_tables(async_client, tmp_path, sort_tables): assert (zipfile.Path(ags_zip) / 'example_ags.xlsx').is_file() with ags_zip.open('example_ags.xlsx') as xl_file: xl = pd.ExcelFile(xl_file) - if sort_tables: + if sort_tables == 'alphabetical': assert xl.sheet_names == sorted(groups) else: assert xl.sheet_names == groups