diff --git a/shopelectro/tests/tests_views.py b/shopelectro/tests/tests_views.py index d5951e12..924a3654 100644 --- a/shopelectro/tests/tests_views.py +++ b/shopelectro/tests/tests_views.py @@ -543,6 +543,46 @@ def test_category_matrix_page(self): self.assertEqual(from_db.name, from_app.a.text) +@tag('fast', 'catalog') +class CategoriesMatrix(BaseCatalogTestCase): + + fixtures = ['dump.json'] + + def get_page(self): + return self.client.get( + path=reverse('custom_page', kwargs={'page': 'catalog'}) + ) + + def get_soup(self) -> BeautifulSoup: + return BeautifulSoup( + self.get_page().content.decode('utf-8'), + 'html.parser' + ) + + def test_roots_sorting(self): + soup = self.get_soup() + from_page = soup.find_all('h2') + from_db = ( + models.Category.objects.bind_fields().active() + .filter(level=0) + .order_by('page__position', 'name') + ).values_list('name', flat=True) + self.assertEqual([c.text for c in from_page], list(from_db)) + + def test_second_level_sorting(self): + soup = self.get_soup() + from_page = soup.select('.second-level-category > a') + from_db = ( + models.Category.objects.bind_fields().active() + .filter(level=1) + .order_by( + 'parent__page__position', 'parent__name', + 'page__position', 'name' + ) + ).values_list('name', flat=True) + self.assertEqual([c.text for c in from_page], list(from_db)) + + @tag('fast') class IndexPage(TestCase): diff --git a/shopelectro/views/catalog.py b/shopelectro/views/catalog.py index f862bfc5..fca46578 100644 --- a/shopelectro/views/catalog.py +++ b/shopelectro/views/catalog.py @@ -18,16 +18,11 @@ from shopelectro.exception import Http400 from shopelectro.views.helpers import set_csrf_cookie - # block numeric indexes to limit MATRIX_BLOCKS_TO_LIMIT = [3, 5] MATRIX_BLOCK_SIZE = 7 -# @todo #822:60m Create tests for the catalog matrix. -# This cases are would be good to test: -# - Matrix sorting by page position -# - Block items limiting def category_matrix(request, page: str): assert page == 'catalog' roots = (