forked from openedx/course-discovery
-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathconftest.py
110 lines (79 loc) · 3.47 KB
/
conftest.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
import logging
import pytest
from django.conf import settings
from django.contrib.sites.models import Site
from django.core.cache import cache, caches
from django.core.management import call_command
from django.test.client import Client
from django_elasticsearch_dsl.registries import registry
from elasticsearch_dsl.connections import get_connection
from pytest_django.lazy_django import skip_if_no_django
from course_discovery.apps.core.tests.factories import PartnerFactory, SiteFactory
logger = logging.getLogger(__name__)
TEST_DOMAIN = 'testserver.fake'
@pytest.fixture(scope='session', autouse=True)
def django_cache_add_xdist_key_prefix(request):
skip_if_no_django()
xdist_prefix = getattr(request.config, 'workerinput', {}).get('workerid')
if xdist_prefix:
# Put a prefix like gw0_, gw1_ etc on xdist processes
for existing_cache in caches.all():
existing_cache.key_prefix = xdist_prefix + '_' + existing_cache.key_prefix
existing_cache.clear()
logger.info('Set existing cache key prefix to [%s]', existing_cache.key_prefix)
for name, cache_settings in settings.CACHES.items():
cache_settings['KEY_PREFIX'] = xdist_prefix + '_' + cache_settings.get('KEY_PREFIX', '')
logger.info('Set cache key prefix for [%s] cache to [%s]', name, cache_settings['KEY_PREFIX'])
@pytest.fixture
def django_cache(django_cache_add_xdist_key_prefix): # pylint: disable=redefined-outer-name,unused-argument
skip_if_no_django()
yield cache
@pytest.fixture(scope='session', autouse=True)
def elasticsearch_dsl_add_xdist_suffix_to_index_name(request):
skip_if_no_django()
xdist_suffix = getattr(request.config, 'workerinput', {}).get('workerid')
if xdist_suffix:
# Put a prefix like _gw0, _gw1 etc on xdist processes
# pylint: disable=protected-access
for index, document in registry._indices.items():
name = f'{index._name}_{xdist_suffix}'
index._name = name
logger.info('Set index name for elastic connection [%s]', name)
# Update setting indexes names
index_names_orig = settings.ELASTICSEARCH_INDEX_NAMES
index_names = index_names_orig.copy()
for document, name in index_names.items():
name = f'{name}_{xdist_suffix}'
index_names_orig[document] = name
@pytest.fixture
def elasticsearch_dsl_default_connection(
elasticsearch_dsl_add_xdist_suffix_to_index_name
): # pylint: disable=redefined-outer-name,unused-argument
skip_if_no_django()
esdsl_conn = get_connection()
call_command('search_index', '--delete', '-f')
call_command('search_index', '--create')
yield esdsl_conn
@pytest.fixture
def site(db): # pylint: disable=unused-argument
skip_if_no_django()
Site.objects.all().delete()
return SiteFactory(id=settings.SITE_ID, domain=TEST_DOMAIN)
@pytest.fixture
def partner(db, site): # pylint: disable=redefined-outer-name,unused-argument
skip_if_no_django()
return PartnerFactory(site=site)
@pytest.fixture
def client():
skip_if_no_django()
return Client(SERVER_NAME=TEST_DOMAIN)
@pytest.fixture(autouse=True)
def clear_caches(request):
for existing_cache in caches.all():
existing_cache.clear()
@pytest.fixture(scope='session', autouse=True)
def clear_es_indexes():
yield None
conn = get_connection()
for index_name in settings.ELASTICSEARCH_INDEX_NAMES.values():
conn.indices.delete(index=index_name + '_*')