mirror of
https://github.com/sissbruecker/linkding
synced 2024-11-29 14:50:20 +00:00
be789ea9e6
* Extract bookmark view contexts * Implement basic partial updates for bookmark list and tag cloud * Refactor confirm button JS into web component * Refactor bulk edit JS into web component * Refactor tag autocomplete JS into web component * Refactor bookmark page JS into web component * Refactor global shortcuts JS into web component * Update tests * Add E2E test for partial updates * Add partial updates for archived bookmarks * Add partial updates for shared bookmarks * Cleanup helpers * Improve naming in bulk edit * Refactor shared components into behaviors * Refactor bulk edit components into behaviors * Refactor bookmark list components into behaviors * Update tests * Combine all scripts into bundle * Fix E2E CI
44 lines
1.7 KiB
Python
44 lines
1.7 KiB
Python
from django.contrib.auth.models import User
|
|
from django.test import TransactionTestCase
|
|
from django.test.utils import CaptureQueriesContext
|
|
from django.urls import reverse
|
|
from django.db import connections
|
|
from django.db.utils import DEFAULT_DB_ALIAS
|
|
|
|
from bookmarks.tests.helpers import BookmarkFactoryMixin
|
|
|
|
|
|
class BookmarkSharedViewPerformanceTestCase(TransactionTestCase, BookmarkFactoryMixin):
|
|
|
|
def setUp(self) -> None:
|
|
user = self.get_or_create_test_user()
|
|
self.client.force_login(user)
|
|
|
|
def get_connection(self):
|
|
return connections[DEFAULT_DB_ALIAS]
|
|
|
|
def test_should_not_increase_number_of_queries_per_bookmark(self):
|
|
# create initial users and bookmarks
|
|
num_initial_bookmarks = 10
|
|
for index in range(num_initial_bookmarks):
|
|
user = self.setup_user(enable_sharing=True)
|
|
self.setup_bookmark(user=user, shared=True)
|
|
|
|
# capture number of queries
|
|
context = CaptureQueriesContext(self.get_connection())
|
|
with context:
|
|
response = self.client.get(reverse('bookmarks:shared'))
|
|
self.assertContains(response, '<li ld-bookmark-item>', num_initial_bookmarks)
|
|
|
|
number_of_queries = context.final_queries
|
|
|
|
# add more users and bookmarks
|
|
num_additional_bookmarks = 10
|
|
for index in range(num_additional_bookmarks):
|
|
user = self.setup_user(enable_sharing=True)
|
|
self.setup_bookmark(user=user, shared=True)
|
|
|
|
# assert num queries doesn't increase
|
|
with self.assertNumQueries(number_of_queries):
|
|
response = self.client.get(reverse('bookmarks:shared'))
|
|
self.assertContains(response, '<li ld-bookmark-item>', num_initial_bookmarks + num_additional_bookmarks)
|