forked from thunderbird/addons-server
-
Notifications
You must be signed in to change notification settings - Fork 0
/
settings_test.py
160 lines (132 loc) · 5.27 KB
/
settings_test.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
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
# -*- coding: utf-8 -*-
from settings import * # noqa
# Make sure the app needed to test translations is present.
INSTALLED_APPS += (
'olympia.translations.tests.testapp',
)
# Make sure the debug toolbar isn't used during the tests.
INSTALLED_APPS = [app for app in INSTALLED_APPS if app != 'debug_toolbar']
# See settings.py for documentation:
IN_TEST_SUITE = True
# Don't call out to persona in tests.
AUTHENTICATION_BACKENDS = (
'olympia.users.backends.TestUserBackend',
)
CELERY_TASK_ALWAYS_EAGER = True
DEBUG = False
# We won't actually send an email.
SEND_REAL_EMAIL = True
PAYPAL_PERMISSIONS_URL = ''
SITE_URL = 'http://testserver'
# We don't want to share cache state between processes. Always use the local
# memcache backend for tests.
#
# Note: Per settings.py, this module can cause deadlocks when running as a web
# server. It's safe to use in tests, since we don't use threads, and there's
# no opportunity for contention, but it shouldn't be used in the base settings
# until we're sure the deadlock issues are fixed.
CACHES = {
'default': {
# `CacheStatTracker` is required for `assert_cache_requests` to work
# properly
'BACKEND': 'olympia.lib.cache.CacheStatTracker',
'LOCATION': 'olympia',
'OPTIONS': {
'ACTUAL_BACKEND': 'django.core.cache.backends.locmem.LocMemCache',
}
},
'filesystem': { # In real settings it's a filesystem cache, not here.
'BACKEND': 'django.core.cache.backends.locmem.LocMemCache',
'LOCATION': 'olympia-filesystem',
}
}
# Overrides whatever storage you might have put in local settings.
DEFAULT_FILE_STORAGE = 'olympia.amo.utils.LocalFileStorage'
TASK_USER_ID = 1337
# Make sure we have no replicas and only one shard to allow for impedent
# search scoring
ES_DEFAULT_NUM_REPLICAS = 0
ES_DEFAULT_NUM_SHARDS = 1
# Set to True if we're allowed to use X-SENDFILE.
XSENDFILE = True
# Don't enable the signing by default in tests, many would fail trying to sign
# empty or bad zip files, or try posting to the endpoints. We don't want that.
SIGNING_SERVER = ''
# Disable addon signing for unittests, too many would fail trying to sign
# corrupt/bad zip files. These will be enabled explicitly for unittests.
ENABLE_ADDON_SIGNING = False
# Limit logging in tests.
LOGGING['loggers'] = {
'': {
'handlers': ['null'],
'level': logging.DEBUG,
'propogate': False,
},
# Need to disable celery logging explicitly. Celery configures it's
# logging manually and we don't catch their logger in our default config.
'celery': {
'handlers': ['null'],
'level': logging.DEBUG,
'propagate': False
},
}
# To speed tests up, crushing uploaded images is disabled in tests except
# where we explicitly want to test pngcrush.
PNGCRUSH_BIN = '/bin/true'
BASKET_API_KEY = 'testkey'
###############################################################################
# Only if running on a CI server.
###############################################################################
if os.environ.get('RUNNING_IN_CI'):
import product_details
from datetime import datetime
class MockProductDetails:
"""Main information we need in tests.
We don't want to rely on the product_details that are automatically
downloaded in manage.py for the tests. Also, downloading all the
information is very long, and we don't want that for each test build on
travis for example.
So here's a Mock that can be used instead of the real product_details.
"""
last_update = datetime.now()
languages = dict((lang, {'native': lang}) for lang in AMO_LANGUAGES)
firefox_versions = {"LATEST_FIREFOX_VERSION": "33.1.1"}
thunderbird_versions = {"LATEST_THUNDERBIRD_VERSION": "31.2.0"}
firefox_history_major_releases = {'1.0': '2004-11-09'}
def __init__(self):
"""Some tests need specifics languages.
This is an excerpt of lib/product_json/languages.json.
"""
self.languages.update({
u'el': {
u'native': u'Ελληνικά',
u'English': u'Greek'},
u'hr': {
u'native': u'Hrvatski',
u'English': u'Croatian'},
u'sr': {
u'native': u'Dolnoserbšćina',
u'English': u'Serbian'},
u'en-US': {
u'native': u'English (US)',
u'English': u'English (US)'},
u'en-GB': {
u'native': u'English (GB)',
u'English': u'English (GB)'},
u'tr': {
u'native': u'Türkçe',
u'English': u'Turkish'},
u'cy': {
u'native': u'Cymraeg',
u'English': u'Welsh'},
u'sr-Latn': {
u'native': u'Srpski',
u'English': u'Serbian'},
u'es': {
u'native': u'Español',
u'English': u'Spanish'},
u'dbg': {
u'English': u'Debug Robot',
u'native': u'Ḓḗƀŭɠ Řǿƀǿŧ'}
})
product_details.product_details = MockProductDetails()