From f6e62d87fd9565efb21de1d375c9f74fb7202893 Mon Sep 17 00:00:00 2001 From: Philipp Weiler Date: Sat, 2 Dec 2023 11:48:46 +0100 Subject: [PATCH 1/3] Update `TestCleanup::test_cleanup_all` Replace hypothesis-based testing with Pytest's parametrize. Instead of loading randomly generated AnnData objects, versions of the pancreas and dentate gyrus are used. --- tests/core/test_anndata.py | 23 +++++++++++++++++++---- 1 file changed, 19 insertions(+), 4 deletions(-) diff --git a/tests/core/test_anndata.py b/tests/core/test_anndata.py index ebb5a6df..1f113fa2 100644 --- a/tests/core/test_anndata.py +++ b/tests/core/test_anndata.py @@ -112,8 +112,23 @@ def test_different_obs_id_length( class TestCleanup(TestBase): - @given(adata=get_adata(max_obs=5, max_vars=5), inplace=st.booleans()) - def test_cleanup_all(self, adata: AnnData, inplace: bool): + @pytest.mark.parametrize("dataset", ["pancreas", "dentategyrus"]) + @pytest.mark.parametrize("n_obs", [50, 100]) + @pytest.mark.parametrize("layer", [None, "unspliced", "spliced"]) + @pytest.mark.parametrize("dense", [True, False]) + @pytest.mark.parametrize("inplace", [True, False]) + def test_cleanup_all( + self, adata, dataset: str, n_obs: int, layer: bool, dense: bool, inplace: bool + ): + adata = adata(dataset=dataset, n_obs=n_obs, raw=False, preprocessed=True) + adata.layers["dummy_layer"] = csr_matrix(np.eye(adata.n_obs, adata.n_vars)) + adata.uns["dummy_entry"] = {"key": csr_matrix(np.eye(5, 7))} + + if dense: + if layer is None: + adata.X = adata.X.A + else: + adata.layers[layer] = adata.layers[layer].A returned_adata = cleanup(adata=adata, clean="all", inplace=inplace) if not inplace: @@ -122,8 +137,8 @@ def test_cleanup_all(self, adata: AnnData, inplace: bool): else: assert returned_adata is None - assert len(adata.layers) == 0 - assert len(adata.uns) == 0 + assert list(adata.layers.keys()) == ["Ms", "Mu", "spliced", "unspliced"] + assert list(adata.uns.keys()) == ["neighbors"] assert len(adata.obs.columns) == 0 assert len(adata.var.columns) == 0 From c9e321720afda52e33a5bacf6f909d10569fe205 Mon Sep 17 00:00:00 2001 From: Philipp Weiler Date: Sat, 2 Dec 2023 11:49:25 +0100 Subject: [PATCH 2/3] Update `test_datasets.py` Update Python version for which dataset download is tests. --- tests/datasets/test_datasets.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/tests/datasets/test_datasets.py b/tests/datasets/test_datasets.py index 06ed961a..f5bcd1f6 100644 --- a/tests/datasets/test_datasets.py +++ b/tests/datasets/test_datasets.py @@ -18,7 +18,7 @@ def dentategyrus_adata(tmpdir_factory): @pytest.mark.skipif( - sys.version_info[:2] != (3, 8) or sys.platform != "linux", + sys.version_info[:2] != (3, 10) or sys.platform != "linux", reason="Limit number of downloads to speed up testing.", ) class TestDataSets: From 5482f72730742267b847eab312f8b4d83d9b6d01 Mon Sep 17 00:00:00 2001 From: Philipp Weiler Date: Sat, 2 Dec 2023 12:06:33 +0100 Subject: [PATCH 3/3] Update `TestCleanup` Increase deadling for `test_cleanup_default_clean_w_random_adata`. --- tests/core/test_anndata.py | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/tests/core/test_anndata.py b/tests/core/test_anndata.py index 1f113fa2..5a0abd16 100644 --- a/tests/core/test_anndata.py +++ b/tests/core/test_anndata.py @@ -2,7 +2,7 @@ import hypothesis.strategies as st import pytest -from hypothesis import given +from hypothesis import given, settings import numpy as np import pandas as pd @@ -143,6 +143,7 @@ def test_cleanup_all( assert len(adata.var.columns) == 0 @given(adata=get_adata(max_obs=5, max_vars=5), inplace=st.booleans()) + @settings(max_examples=10, deadline=1000) def test_cleanup_default_clean_w_random_adata(self, adata: AnnData, inplace: bool): n_obs_cols = len(adata.obs.columns) n_var_cols = len(adata.var.columns)