From d3114746acf0d67c919640c14076b4621a834f1e Mon Sep 17 00:00:00 2001 From: Tim DiLauro Date: Wed, 18 Dec 2024 15:17:40 -0500 Subject: [PATCH] Fix a misleading test. (#2215) --- tests/manager/api/test_lanes.py | 31 ++++++++++++++++++++++++++----- 1 file changed, 26 insertions(+), 5 deletions(-) diff --git a/tests/manager/api/test_lanes.py b/tests/manager/api/test_lanes.py index 30ef2ed33..6ded28685 100644 --- a/tests/manager/api/test_lanes.py +++ b/tests/manager/api/test_lanes.py @@ -908,8 +908,29 @@ def test_overview_facets(self, lane_fixture: LaneFixture): class TestCrawlableFacets: - def test_default(self, db: DatabaseTransactionFixture): - facets = CrawlableFacets.default(db.default_library()) + @pytest.mark.parametrize( + "c1_distributor, c2_distributor, expected_distributor_count", + ( + pytest.param("distributor", "distributor", 1, id="same_distributor"), + pytest.param("distributor", "distributor2", 2, id="different_distributor"), + ), + ) + def test_default( + self, + db: DatabaseTransactionFixture, + c1_distributor: str, + c2_distributor: str, + expected_distributor_count: int, + ): + library = db.library() + c1 = db.collection( + library=library, settings=db.opds_settings(data_source=c1_distributor) + ) + c2 = db.collection( + library=library, settings=db.opds_settings(data_source=c2_distributor) + ) + + facets = CrawlableFacets.default(library) assert facets.availability == CrawlableFacets.AVAILABLE_ALL assert facets.order == CrawlableFacets.ORDER_LAST_UPDATE assert facets.order_ascending is False @@ -926,9 +947,9 @@ def test_default(self, db: DatabaseTransactionFixture): assert len(facet) == 1 # Except for distributor and collectionName, which have the default - # and data for each collection in the library. - for facet in [distributor, collectionName]: - assert len(facet) == 1 + len(db.default_library().associated_collections) + # along with their unique values among each collection in the library. + assert len(distributor) == 1 + expected_distributor_count + assert len(collectionName) == 1 + len(library.associated_collections) @pytest.mark.parametrize( "group_name, expected",