WRITING A SCIENTIFIC REPORT

3.6

Write an abstract

The abstract is one paragraph that summarizes the research question, hypothesis, design, methods, and results in an easy to read way. This chapter briefly outlines the basics of good abstracts.

Short summary of everything
The abstract is a written summary of a research. It is around 150 to maximally 250 words of length. When you write an abstract, take your time to be informative but brief and concise at the same time, rather than writing a long and verbose text. Also, write your abstract for readers from other fields or who have never heard of your specific methods or research topic. The audience of an abstract is a psychologist who is not necessarily working in your field and does not know your area of expertise.

How is the abstract structured?
The text of the abstract of an empirical paper has a standard structure. It starts with one to two sentence that clearly state the problem or research question and goals of your research (for instance, “This paper investigates the role of … in …”). The next one to two sentences must explicitly state all the tested hypotheses, even if exploratory (for instance, “We hypothesized, based on prospect theory, that highly loss-averse individuals should … compared to people that are less loss-averse …”). Next, briefly write about the experimental design and methods that were used, including the sample size (for instance, ”To investigate this question, we conducted one online experiment (N = 89), which asked participants to … followed by … and …”), this usually takes one or two sentences. Afterwards, the next one or two sentences describe the main results, usually in plain text using words rather than in numbers (for instance, ”The results from a ANOVA show that … increases ….”). This is followed by a very brief sentence that relates the result back to the hypotheses (for instance, ”These findings fail to support prospect theory”). This is followed by the last sentence of the abstract which always is a conclusion from the empirical findings that mentions implications (for instance ”Taken together, our work shows that prospect theory is not …”). Implications are what the research findings mean for the practice or theory or future research.

How is the abstract formatted?
Following the APA format, the abstract has a section heading called Abstract in bold and centered. The abstract text is always formatted as one single paragraph, which means abstract texts contain no line breaks and no paragraph breaks. The line spacing is double-spaced (as usual in APA). Abstracts appear on the first page after the title page of psychological papers, and the abstract starts at the top of the page.

DJDT

Versionen

Paket Name Version
Django 4.2.17
Python 3.11.11
allauth Allauth 65.3.1.final.0
cachalot Cachalot 2.6.3
crispy_bootstrap5 Crispy_Bootstrap5 2024.10
crispy_forms Crispy_Forms 2.3
debug_toolbar Debug Toolbar 4.4.6
django_extensions Django Extensions 3.2.3
django_q Django Q 1.7.6
imagekit Imagekit 5.0.0
impersonate Impersonate 1.9.4
markdownx Markdownx 4.0.7
mozilla_django_oidc Mozilla_Django_Oidc 4.0.1
notifications Notifications 1.8.3
rosetta Rosetta 0.10.1
rules Rules 3.5.0.final.1
simple_history Simple_History 3.7.0
storages Storages 1.14.4
tos Terms Of Service 1.1.0
waffle django-waffle 4.1.0

Zeit

Ressourcenverwendung

Ressource Wert
CPU-Zeit Benutzer 332.427 ms
CPU-Zeit System 17.295 ms
CPU-Zeit gesamt 349.722 ms
Verstrichene Zeit 369.882 ms
Kontextwechsel 173 freiwillig, 14 unfreiwillig

Browserzeit

Timing-Attribut Verlauf Millisekunden seit Seitenaufruf (plus Dauer)
domainLookup13 (+225)
connect238 (+221)
request459 (+1540)
response1125 (+874)
domLoading1172 (+-1736871783710)
domInteractive2494
domContentLoadedEvent2494 (+104)
loadEvent-1736871782538 (+0)

Einstellungen von config.settings.staging

Einstellung Wert
ABSOLUTE_URL_OVERRIDES {}
ACCOUNT_ADAPTER 'lms_base.adapter.AccountAdapter'
ADMINS (('admin', 'notifications-nmc@unibas.ch'),)
ADMIN_URL 'admin/'
ALLOWED_HOSTS ['*']
APPEND_SLASH True
AUTHENTICATION_BACKENDS ('rules.permissions.ObjectPermissionBackend', 'lms_base.authentication.EDUIDAuthenticationBackend', 'django.contrib.auth.backends.ModelBackend')
AUTH_PASSWORD_VALIDATORS '********************'
AUTH_USER_MODEL 'users.User'
BASE_DIR '/app/project/config/../'
CACHALOT_ENABLED True
CACHES {'default': {'BACKEND': 'django_redis.cache.RedisCache', 'LOCATION': 'redis://tales-redis:6379/1', 'OPTIONS': {'CLIENT_CLASS': 'django_redis.client.DefaultClient', 'IGNORE_EXCEPTIONS': True}}}
CACHE_MIDDLEWARE_ALIAS 'default'
CACHE_MIDDLEWARE_KEY_PREFIX '********************'
CACHE_MIDDLEWARE_SECONDS 600
CI_COMMIT_SHORT_SHA '484e3ae2'
CI_COMMIT_TAG ''
CRISPY_ALLOWED_TEMPLATE_PACKS 'bootstrap5'
CRISPY_TEMPLATE_PACK 'bootstrap5'
CSRF_COOKIE_AGE 31449600
CSRF_COOKIE_DOMAIN None
CSRF_COOKIE_HTTPONLY False
CSRF_COOKIE_MASKED False
CSRF_COOKIE_NAME 'csrftoken'
CSRF_COOKIE_PATH '/'
CSRF_COOKIE_SAMESITE None
CSRF_COOKIE_SECURE False
CSRF_FAILURE_VIEW 'django.views.csrf.csrf_failure'
CSRF_HEADER_NAME 'HTTP_X_CSRFTOKEN'
CSRF_TRUSTED_ORIGINS []
CSRF_USE_SESSIONS False
DATABASES {'default': {'ATOMIC_REQUESTS': False, 'AUTOCOMMIT': True, 'CONN_HEALTH_CHECKS': False, 'CONN_MAX_AGE': 0, 'ENGINE': 'django.db.backends.postgresql', 'HOST': 'tales-postgres', 'NAME': 'tptt', 'OPTIONS': {}, 'PASSWORD': '********************', 'PORT': '5432', 'TEST': {'CHARSET': None, 'COLLATION': None, 'MIGRATE': True, 'MIRROR': None, 'NAME': None}, 'TIME_ZONE': None, 'USER': 'tales_db_user'}}
DATABASE_ROUTERS []
DATA_UPLOAD_MAX_MEMORY_SIZE 2621440
DATA_UPLOAD_MAX_NUMBER_FIELDS 1000
DATA_UPLOAD_MAX_NUMBER_FILES 100
DATETIME_FORMAT 'N j, Y, P'
DATETIME_INPUT_FORMATS ['%Y-%m-%d %H:%M:%S', '%Y-%m-%d %H:%M:%S.%f', '%Y-%m-%d %H:%M', '%m/%d/%Y %H:%M:%S', '%m/%d/%Y %H:%M:%S.%f', '%m/%d/%Y %H:%M', '%m/%d/%y %H:%M:%S', '%m/%d/%y %H:%M:%S.%f', '%m/%d/%y %H:%M']
DATE_FORMAT 'N j, Y'
DATE_INPUT_FORMATS ['%Y-%m-%d', '%m/%d/%Y', '%m/%d/%y', '%b %d %Y', '%b %d, %Y', '%d %b %Y', '%d %b, %Y', '%B %d %Y', '%B %d, %Y', '%d %B %Y', '%d %B, %Y']
DEBUG True
DEBUG_PROPAGATE_EXCEPTIONS False
DEBUG_TOOLBAR_CONFIG {'SHOW_TOOLBAR_CALLBACK': <function show_toolbar at 0x7910e57c16c0>}
DEBUG_TOOLBAR_PANELS ['debug_toolbar.panels.history.HistoryPanel', 'debug_toolbar.panels.versions.VersionsPanel', 'debug_toolbar.panels.timer.TimerPanel', 'debug_toolbar.panels.settings.SettingsPanel', 'debug_toolbar.panels.headers.HeadersPanel', 'debug_toolbar.panels.request.RequestPanel', 'debug_toolbar.panels.sql.SQLPanel', 'debug_toolbar.panels.staticfiles.StaticFilesPanel', 'debug_toolbar.panels.templates.TemplatesPanel', 'debug_toolbar.panels.cache.CachePanel', 'cachalot.panels.CachalotPanel', 'debug_toolbar.panels.signals.SignalsPanel', 'debug_toolbar.panels.logging.LoggingPanel', 'debug_toolbar.panels.redirects.RedirectsPanel', 'debug_toolbar.panels.profiling.ProfilingPanel']
DECIMAL_SEPARATOR '.'
DEFAULT_AUTO_FIELD 'django.db.models.AutoField'
DEFAULT_CHARSET 'utf-8'
DEFAULT_EXCEPTION_REPORTER 'django.views.debug.ExceptionReporter'
DEFAULT_EXCEPTION_REPORTER_FILTER 'django.views.debug.SafeExceptionReporterFilter'
DEFAULT_FILE_STORAGE 'django.core.files.storage.FileSystemStorage'
DEFAULT_FROM_EMAIL 'contact-nmc@unibas.ch'
DEFAULT_INDEX_TABLESPACE ''
DEFAULT_TABLESPACE ''
DEPLOY_ENV 'staging'
DISALLOWED_USER_AGENTS []
DJANGO_APPS ('django.contrib.auth', 'django.contrib.contenttypes', 'django.contrib.sessions', 'django.contrib.messages', 'django.contrib.staticfiles', 'django.forms', 'django.contrib.sites', 'django.contrib.flatpages', 'modeltranslation', 'django.contrib.admin', 'django.contrib.redirects', 'django.contrib.sitemaps', 'django.contrib.humanize')
DJANGO_NOTIFICATIONS_CONFIG {'USE_JSONFIELD': True}
EMAIL_BACKEND 'django.core.mail.backends.smtp.EmailBackend'
EMAIL_HOST 'smtp.unibas.ch'
EMAIL_HOST_PASSWORD '********************'
EMAIL_HOST_USER ''
EMAIL_PORT 25
EMAIL_SSL_CERTFILE None
EMAIL_SSL_KEYFILE '********************'
EMAIL_SUBJECT_PREFIX '[Django] '
EMAIL_TIMEOUT None
EMAIL_USE_LOCALTIME False
EMAIL_USE_SSL False
EMAIL_USE_TLS False
FILE_UPLOAD_DIRECTORY_PERMISSIONS None
FILE_UPLOAD_HANDLERS ['django.core.files.uploadhandler.MemoryFileUploadHandler', 'django.core.files.uploadhandler.TemporaryFileUploadHandler']
FILE_UPLOAD_MAX_MEMORY_SIZE 2621440
FILE_UPLOAD_PERMISSIONS 420
FILE_UPLOAD_TEMP_DIR None
FIRST_DAY_OF_WEEK 0
FIXTURE_DIRS []
FORCE_SCRIPT_NAME None
FORMAT_MODULE_PATH None
FORM_RENDERER 'django.forms.renderers.TemplatesSetting'
IGNORABLE_404_URLS []
IMAGEKIT_CACHEFILE_DIR 'CACHE/images'
IMAGEKIT_CACHEFILE_NAMER 'imagekit.cachefiles.namers.hash'
IMAGEKIT_CACHE_BACKEND 'default'
IMAGEKIT_CACHE_PREFIX 'imagekit:'
IMAGEKIT_CACHE_TIMEOUT 300
IMAGEKIT_DEFAULT_CACHEFILE_BACKEND 'imagekit.cachefiles.backends.Simple'
IMAGEKIT_DEFAULT_CACHEFILE_STRATEGY 'imagekit.cachefiles.strategies.JustInTime'
IMAGEKIT_DEFAULT_FILE_STORAGE 'default'
IMAGEKIT_SPEC_CACHEFILE_NAMER 'imagekit.cachefiles.namers.source_name_as_path'
IMAGEKIT_USE_MEMCACHED_SAFE_CACHE_KEY '********************'
INSTALLED_APPS ('django.contrib.auth', 'django.contrib.contenttypes', 'django.contrib.sessions', 'django.contrib.messages', 'django.contrib.staticfiles', 'django.forms', 'django.contrib.sites', 'django.contrib.flatpages', 'modeltranslation', 'django.contrib.admin', 'django.contrib.redirects', 'django.contrib.sitemaps', 'django.contrib.humanize', 'simple_history', 'crispy_forms', 'crispy_bootstrap5', 'allauth', 'allauth.account', 'allauth.socialaccount', 'mozilla_django_oidc', 'django_extensions', 'markdownx', 'rules.apps.AutodiscoverRulesConfig', 'imagekit', 'waffle', 'django_htmx', 'cachalot', 'corsheaders', 'tos', 'tos_i18n', 'impersonate', 'rosetta', 'django_q', 'notifications', 'link_check', 'users.apps.UsersConfig', 'lms_base', 'lms_tales.apps.LMSTalesConfig', 'lms_comments.apps.LMSCommentsConfig', 'lms_static_texts.apps.LMSStaticTextsConfig', 'tags.apps.TagsConfig', 'startpage.apps.StartpageConfig', 'search.apps.SearchConfig', 'utils.apps.UtilsConfig', 'dashboard.apps.DashboardConfig', 'reporting.apps.ReportingConfig', 'lms_notifications.apps.LMSNotificationsConfig', 'lms_roles.apps.LMSRolesConfig', 'storages', 'debug_toolbar')
INTERNAL_IPS ['127.0.0.1']
LANGUAGES (('de', 'Deutsch'), ('en', 'Englisch'), ('fr', 'Franzoesisch'))
LANGUAGES_BIDI ['he', 'ar', 'ar-dz', 'ckb', 'fa', 'ur']
LANGUAGE_CODE 'de'
LANGUAGE_COOKIE_AGE None
LANGUAGE_COOKIE_DOMAIN None
LANGUAGE_COOKIE_HTTPONLY False
LANGUAGE_COOKIE_NAME 'django_language'
LANGUAGE_COOKIE_PATH '/'
LANGUAGE_COOKIE_SAMESITE None
LANGUAGE_COOKIE_SECURE False
LOCALE_PATHS ['/app/project/config/../locale']
LOCAL_APPS ('users.apps.UsersConfig', 'lms_base', 'lms_tales.apps.LMSTalesConfig', 'lms_comments.apps.LMSCommentsConfig', 'lms_static_texts.apps.LMSStaticTextsConfig', 'tags.apps.TagsConfig', 'startpage.apps.StartpageConfig', 'search.apps.SearchConfig', 'utils.apps.UtilsConfig', 'dashboard.apps.DashboardConfig', 'reporting.apps.ReportingConfig', 'lms_notifications.apps.LMSNotificationsConfig', 'lms_roles.apps.LMSRolesConfig')
LOGGING {'disable_existing_loggers': False, 'formatters': {'verbose': {'format': '{asctime} {levelname} {name} {module} ' '{message}', 'style': '{'}}, 'handlers': {'console': {'class': 'logging.StreamHandler', 'formatter': 'verbose'}, 'mail_admins': {'class': 'django.utils.log.AdminEmailHandler', 'include_html': True, 'level': 'ERROR'}}, 'loggers': {'django': {'handlers': ['console', 'mail_admins'], 'level': 'WARNING', 'propagate': True}, 'django.request': {'handlers': ['console', 'mail_admins'], 'level': 'ERROR', 'propagate': False}, 'django.security': {'handlers': ['console', 'mail_admins'], 'level': 'ERROR', 'propagate': False}, 'fontTools': {'handlers': ['console'], 'level': 'ERROR'}, 'tales': {'handlers': ['console'], 'level': 'INFO'}, 'weasyprint': {'handlers': ['console'], 'level': 'ERROR'}}, 'root': {'handlers': ['console'], 'level': 'WARNING'}, 'version': 1}
LOGGING_CONFIG 'logging.config.dictConfig'
LOGIN_REDIRECT_URL '/'
LOGIN_URL 'account_login'
LOGOUT_REDIRECT_URL '/'
MANAGERS []
MARKDOWNX_EDITOR_RESIZABLE True
MARKDOWNX_IMAGE_MAX_SIZE {'quality': 90, 'size': (1920, 5600)}
MARKDOWNX_MARKDOWNIFY_FUNCTION 'lms_base.utils.markdownify'
MARKDOWNX_MARKDOWN_EXTENSIONS ['markdown.extensions.extra', 'markdown.extensions.smarty', 'markdown.extensions.codehilite', 'markdown.extensions.fenced_code', 'markdown.extensions.attr_list', 'markdown.extensions.toc', 'utils.markdown_extensions', 'python_markdown_oembed_extension']
MARKDOWNX_MEDIA_PATH 'markdownx/'
MARKDOWNX_UPLOAD_URLS_PATH '/markdownx/upload/'
MARKDOWNX_URLS_PATH '/markdownx/markdownify/'
MEDIA_ROOT '/app/project/media'
MEDIA_URL '/media/'
MESSAGE_REAPPEAR_TIME 600
MESSAGE_STORAGE 'django.contrib.messages.storage.fallback.FallbackStorage'
MIDDLEWARE ['corsheaders.middleware.CorsMiddleware', 'django.middleware.security.SecurityMiddleware', 'django.contrib.sessions.middleware.SessionMiddleware', 'django.middleware.csrf.CsrfViewMiddleware', 'django.contrib.auth.middleware.AuthenticationMiddleware', 'lms_tales.middleware.SetLocaleFoundInUserSettings', 'django.middleware.locale.LocaleMiddleware', 'django.middleware.common.CommonMiddleware', 'allauth.account.middleware.AccountMiddleware', 'impersonate.middleware.ImpersonateMiddleware', 'django.contrib.messages.middleware.MessageMiddleware', 'django.middleware.clickjacking.XFrameOptionsMiddleware', 'simple_history.middleware.HistoryRequestMiddleware', 'django.contrib.redirects.middleware.RedirectFallbackMiddleware', 'waffle.middleware.WaffleMiddleware', 'django_htmx.middleware.HtmxMiddleware', 'lms_tales.middleware.TalesUserAgreementMiddleware', 'lms_tales.middleware.ScheduledMessagesMiddleware', 'debug_toolbar.middleware.DebugToolbarMiddleware']
MIGRATION_MODULES {'tos': 'lms_tales.migrate.tos'}
MODELTRANSLATION_CUSTOM_FIELDS ('JSONField',)
MODELTRANSLATION_DEFAULT_LANGUAGE 'de'
MODELTRANSLATION_FALLBACK_LANGUAGES ('de', 'en', 'fr')
MONTH_DAY_FORMAT 'F j'
NOTIFICATIONS_NOTIFICATION_MODEL 'notifications.Notification'
NUMBER_GROUPING 0
OIDC_OP_AUTHORIZATION_ENDPOINT 'https://login.test.eduid.ch/idp/profile/oidc/authorize'
OIDC_OP_JWKS_ENDPOINT 'https://login.test.eduid.ch/idp/profile/oidc/keyset'
OIDC_OP_TOKEN_ENDPOINT '********************'
OIDC_OP_USER_ENDPOINT 'https://login.test.eduid.ch/idp/profile/oidc/userinfo'
OIDC_RP_CLIENT_ID 'unibas-tales'
OIDC_RP_CLIENT_SECRET '********************'
OIDC_RP_SCOPES 'openid email profile https://login.eduid.ch/authz/User.Read'
OIDC_RP_SIGN_ALGO 'RS256'
OIDC_TOKEN_USE_BASIC_AUTH '********************'
PASSWORD_HASHERS '********************'
PASSWORD_RESET_TIMEOUT '********************'
PREPEND_WWW False
PROJECT_DIR '/app/project/config/../'
Q_CLUSTER {'catch_up': False, 'django_redis': 'default', 'name': 'QCluster', 'retry': 600, 'timeout': 500, 'workers': 4}
RELEASE_NAME ''
REQUIRE_SUPERUSER True
ROOT_URLCONF 'config.urls'
ROSETTA_MESSAGES_SOURCE_LANGUAGE_CODE 'de'
ROSETTA_MESSAGES_SOURCE_LANGUAGE_NAME 'Deutsch'
ROSETTA_SHOW_AT_ADMIN_PANEL 'True'
SECRET_KEY '********************'
SECRET_KEY_FALLBACKS '********************'
SECURE_CONTENT_TYPE_NOSNIFF True
SECURE_CROSS_ORIGIN_OPENER_POLICY 'same-origin'
SECURE_HSTS_INCLUDE_SUBDOMAINS False
SECURE_HSTS_PRELOAD False
SECURE_HSTS_SECONDS 0
SECURE_PROXY_SSL_HEADER ('HTTP_X_FORWARDED_PROTO', 'https')
SECURE_REDIRECT_EXEMPT []
SECURE_REFERRER_POLICY 'same-origin'
SECURE_SSL_HOST None
SECURE_SSL_REDIRECT False
SERVER_EMAIL 'root@localhost'
SESSION_CACHE_ALIAS 'default'
SESSION_COOKIE_AGE 1209600
SESSION_COOKIE_DOMAIN None
SESSION_COOKIE_HTTPONLY True
SESSION_COOKIE_NAME 'sessionid'
SESSION_COOKIE_PATH '/'
SESSION_COOKIE_SAMESITE None
SESSION_COOKIE_SECURE False
SESSION_ENGINE 'django.contrib.sessions.backends.cache'
SESSION_EXPIRE_AT_BROWSER_CLOSE False
SESSION_FILE_PATH None
SESSION_SAVE_EVERY_REQUEST False
SESSION_SERIALIZER 'django.contrib.sessions.serializers.JSONSerializer'
SETTINGS_MODULE 'config.settings.staging'
SHORT_DATETIME_FORMAT 'm/d/Y P'
SHORT_DATE_FORMAT 'm/d/Y'
SIGNING_BACKEND 'django.core.signing.TimestampSigner'
SILENCED_SYSTEM_CHECKS []
SITE_DOMAIN 'https://nmc-tales-staging.nmc.unibas.ch/'
SITE_ID 1
SLACK_WEBHOOK 'https://hooks.slack.com/services/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'
STAGING_EMAIL_RECIPIENTS ['notifications-nmc@unibas.ch']
STATICFILES_DIRS ['/app/project/config/../static']
STATICFILES_FINDERS ('django.contrib.staticfiles.finders.FileSystemFinder', 'django.contrib.staticfiles.finders.AppDirectoriesFinder')
STATICFILES_STORAGE 'django.contrib.staticfiles.storage.StaticFilesStorage'
STATIC_ROOT '/app/project/config/../../staticfiles'
STATIC_URL '/static/'
STORAGES {'default': {'BACKEND': 'django.core.files.storage.FileSystemStorage'}, 'staticfiles': {'BACKEND': 'django.contrib.staticfiles.storage.StaticFilesStorage'}}
TALES_BASE_URL 'https://tales.nmc.unibas.ch'
TALES_VERSION 'dev'
TEMPLATES [{'BACKEND': 'django.template.backends.django.DjangoTemplates', 'DIRS': ['/app/project/config/../templates', '/usr/local/lib/python3.11/site-packages/django/forms/templates'], 'OPTIONS': {'builtins': ['django.templatetags.i18n', 'django.templatetags.static'], 'context_processors': ['django.template.context_processors.debug', 'django.template.context_processors.request', 'django.contrib.auth.context_processors.auth', 'django.template.context_processors.i18n', 'django.template.context_processors.media', 'django.template.context_processors.static', 'django.template.context_processors.tz', 'django.contrib.messages.context_processors.messages', 'utils.context_processors.ci_info'], 'debug': False, 'loaders': ['django.template.loaders.filesystem.Loader', 'django.template.loaders.app_directories.Loader']}}]
TEST_NON_SERIALIZED_APPS []
TEST_RUNNER 'django.test.runner.DiscoverRunner'
THIRD_PARTY_APPS ('debug_toolbar',)
THOUSAND_SEPARATOR ','
TIME_FORMAT 'P'
TIME_INPUT_FORMATS ['%H:%M:%S', '%H:%M:%S.%f', '%H:%M']
TIME_ZONE 'Europe/Zurich'
USER_DEACTIVATION_AFTER_DAYS 730
USER_DELETION_AFTER_DAYS 912
USE_DEPRECATED_PYTZ False
USE_I18N True
USE_L10N True
USE_THOUSAND_SEPARATOR False
USE_TZ True
USE_X_FORWARDED_HOST True
USE_X_FORWARDED_PORT False
VIEW_CACHE_TTL 600
WAFFLE_LOG_MISSING_FLAGS 30
WAFFLE_LOG_MISSING_SAMPLES 30
WAFFLE_LOG_MISSING_SWITCHES 30
WSGI_APPLICATION 'config.wsgi.application'
X_FRAME_OPTIONS 'DENY'
YEAR_MONTH_FORMAT 'F Y'

Header

Anfrage-Header

Schlüssel Wert
Accept text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.7
Accept-Encoding gzip, deflate, br, zstd
Cache-Control no-cache
Host nmc-tales-staging.nmc.unibas.ch
Pragma no-cache
Priority u=0, i
Sec-Ch-Ua "HeadlessChrome";v="129", "Not=A?Brand";v="8", "Chromium";v="129"
Sec-Ch-Ua-Mobile ?0
Sec-Ch-Ua-Platform "Windows"
Sec-Fetch-Dest document
Sec-Fetch-Mode navigate
Sec-Fetch-Site none
Sec-Fetch-User ?1
Upgrade-Insecure-Requests 1
User-Agent Mozilla/5.0 AppleWebKit/537.36 (KHTML, like Gecko; compatible; ClaudeBot/1.0; +claudebot@anthropic.com)
X-Forwarded-For 18.118.141.153
X-Forwarded-Host nmc-tales-staging.nmc.unibas.ch
X-Forwarded-Proto https

Antwort-Header

Schlüssel Wert
Content-Type text/html; charset=utf-8

WSGI-Umgebung

Da sich die WSGI-Umgebung von der Umgebung des Servers ableitet, wird nur eine notwendige Teilmenge dargestellt.

Schlüssel Wert
PATH_INFO /de/conducting-psychological-research-6/writing-a-scientific-report-21/write-an-abstract-1029
QUERY_STRING
REMOTE_ADDR 18.118.141.153
REMOTE_HOST 18.118.141.153
REQUEST_METHOD GET
SCRIPT_NAME
SERVER_NAME 172.19.0.7
SERVER_PORT 8000

Anfrage

View-Informationen

View-Funktion Argumente Schlüsselwort-Argumente URL-Name
utils.decorators.cache_per_user.<locals>.decorator.<locals>.apply_cache () {'chapter_pk': 21, 'chapter_slug': 'writing-a-scientific-report', 'course_pk': 6, 'course_slug': 'conducting-psychological-research', 'pk': 1029, 'slug': 'write-an-abstract'} tales:step

Keine Cookies

Keine Sitzungsdaten

Keine GET-Daten

Keine POST-Daten

SQL-Abfragen von 1 Verbindung

  • default 21,54 ms (21 Abfragen inklusive 10 ähnlich )
Abfrage Verlauf Zeit (ms) Aktion
SELECT "lms_tales_talesstep"."id",
       "lms_tales_talesstep"."created",
       "lms_tales_talesstep"."modified",
       "lms_tales_talesstep"."status_changed",
       "lms_tales_talesstep"."is_removed",
       "lms_tales_talesstep"."title",
       "lms_tales_talesstep"."title_de",
       "lms_tales_talesstep"."title_en",
       "lms_tales_talesstep"."title_fr",
       "lms_tales_talesstep"."subtitle",
       "lms_tales_talesstep"."subtitle_de",
       "lms_tales_talesstep"."subtitle_en",
       "lms_tales_talesstep"."subtitle_fr",
       "lms_tales_talesstep"."short_description",
       "lms_tales_talesstep"."short_description_de",
       "lms_tales_talesstep"."short_description_en",
       "lms_tales_talesstep"."short_description_fr",
       "lms_tales_talesstep"."title_image",
       "lms_tales_talesstep"."slug",
       "lms_tales_talesstep"."content",
       "lms_tales_talesstep"."content_de",
       "lms_tales_talesstep"."content_en",
       "lms_tales_talesstep"."content_fr",
       "lms_tales_talesstep"."content_html",
       "lms_tales_talesstep"."content_html_de",
       "lms_tales_talesstep"."content_html_en",
       "lms_tales_talesstep"."content_html_fr",
       "lms_tales_talesstep"."content_json",
       "lms_tales_talesstep"."content_json_de",
       "lms_tales_talesstep"."content_json_en",
       "lms_tales_talesstep"."content_json_fr",
       "lms_tales_talesstep"."copyright",
       "lms_tales_talesstep"."copyright_de",
       "lms_tales_talesstep"."copyright_en",
       "lms_tales_talesstep"."copyright_fr",
       "lms_tales_talesstep"."step_type",
       "lms_tales_talesstep"."duration",
       "lms_tales_talesstep"."order",
       "lms_tales_talesstep"."status",
       "lms_tales_talesstep"."allow_comments",
       "lms_tales_talesstep"."call_to_action",
       "lms_tales_talesstep"."call_to_action_de",
       "lms_tales_talesstep"."call_to_action_en",
       "lms_tales_talesstep"."call_to_action_fr",
       "lms_tales_talesstep"."chapter_id"
  FROM "lms_tales_talesstep"
 WHERE "lms_tales_talesstep"."id" = 1029
 LIMIT 21
SELECT ••• FROM "lms_tales_talesstep" WHERE "lms_tales_talesstep"."id" = 1029 LIMIT 21
2,62

Verbindung: default

Transaktionsstatus: Wartet

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in run(101)
  return _run_old_run_func()

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in _run_old_run_func(94)
  return old_run_func(self, *a, **kw)

/usr/local/lib/python3.11/concurrent/futures/thread.py in _worker(83)
  work_item.run()

/usr/local/lib/python3.11/concurrent/futures/thread.py in run(58)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/corsheaders/middleware.py in __call__(56)
  result = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in middleware(32)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/allauth/account/middleware.py in middleware(36)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/simple_history/middleware.py in middleware(41)
  return get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/django_htmx/middleware.py in __call__(43)
  return self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in __call__(168)
  response = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/panels.py in process_request(41)
  return super(CachalotPanel, self).process_request(request)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in __call__(244)
  current_executor.run_until_future(call_result)

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run_until_future(81)
  work_item.run()

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run(40)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_wrapped_callback(90)
  return callback(request, *args, **kwargs)

/app/project/utils/decorators.py in apply_cache(64)
  response = function(request, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/django/views/generic/base.py in view(104)
  return self.dispatch(request, *args, **kwargs)

/app/project/lms_tales/views/mixins.py in dispatch(20)
  self.object = self.get_object()

/usr/local/lib/python3.11/site-packages/django/views/generic/detail.py in get_object(53)
  obj = queryset.get()

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(37)
  return original(compiler, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(96)
  return _get_result_or_execute_query(

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in _get_result_or_execute_query(64)
  result = execute_query_func()

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in <lambda>(80)
  execute_query_func = lambda: original(compiler, *args, **kwargs)

SELECT "lms_tales_talesstepfilenew"."id",
       "lms_tales_talesstepfilenew"."created",
       "lms_tales_talesstepfilenew"."modified",
       "lms_tales_talesstepfilenew"."step_id",
       "lms_tales_talesstepfilenew"."file_id",
       "lms_tales_talesstepfilenew"."language"
  FROM "lms_tales_talesstepfilenew"
 WHERE ("lms_tales_talesstepfilenew"."language" = 'de' AND "lms_tales_talesstepfilenew"."step_id" = 1029)
SELECT ••• FROM "lms_tales_talesstepfilenew" WHERE ("lms_tales_talesstepfilenew"."language" = 'de' AND "lms_tales_talesstepfilenew"."step_id" = 1029)
3 ähnliche Abfragen.
1,20

Verbindung: default

Transaktionsstatus: Wartet

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in run(101)
  return _run_old_run_func()

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in _run_old_run_func(94)
  return old_run_func(self, *a, **kw)

/usr/local/lib/python3.11/concurrent/futures/thread.py in _worker(83)
  work_item.run()

/usr/local/lib/python3.11/concurrent/futures/thread.py in run(58)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/corsheaders/middleware.py in __call__(56)
  result = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in middleware(32)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/allauth/account/middleware.py in middleware(36)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/simple_history/middleware.py in middleware(41)
  return get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/django_htmx/middleware.py in __call__(43)
  return self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in __call__(168)
  response = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/panels.py in process_request(41)
  return super(CachalotPanel, self).process_request(request)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in __call__(244)
  current_executor.run_until_future(call_result)

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run_until_future(81)
  work_item.run()

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run(40)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_wrapped_callback(90)
  return callback(request, *args, **kwargs)

/app/project/utils/decorators.py in apply_cache(64)
  response = function(request, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/django/views/generic/base.py in view(104)
  return self.dispatch(request, *args, **kwargs)

/app/project/lms_tales/views/mixins.py in dispatch(31)
  return super().dispatch(request, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/django/views/generic/base.py in dispatch(143)
  return handler(request, *args, **kwargs)

/app/project/lms_tales/views/step_views.py in get(36)
  response = super().get(request, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/django/views/generic/detail.py in get(109)
  context = self.get_context_data(object=self.object)

/app/project/lms_tales/views/step_views.py in get_context_data(63)
  if len(step_files_new) == 0:

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(37)
  return original(compiler, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(96)
  return _get_result_or_execute_query(

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in _get_result_or_execute_query(64)
  result = execute_query_func()

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in <lambda>(80)
  execute_query_func = lambda: original(compiler, *args, **kwargs)

SELECT "lms_tales_talesstepfilenew"."id",
       "lms_tales_talesstepfilenew"."created",
       "lms_tales_talesstepfilenew"."modified",
       "lms_tales_talesstepfilenew"."step_id",
       "lms_tales_talesstepfilenew"."file_id",
       "lms_tales_talesstepfilenew"."language"
  FROM "lms_tales_talesstepfilenew"
 WHERE ("lms_tales_talesstepfilenew"."language" = 'en' AND "lms_tales_talesstepfilenew"."step_id" = 1029)
SELECT ••• FROM "lms_tales_talesstepfilenew" WHERE ("lms_tales_talesstepfilenew"."language" = 'en' AND "lms_tales_talesstepfilenew"."step_id" = 1029)
3 ähnliche Abfragen.
0,62

Verbindung: default

Transaktionsstatus: Wartet

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in run(101)
  return _run_old_run_func()

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in _run_old_run_func(94)
  return old_run_func(self, *a, **kw)

/usr/local/lib/python3.11/concurrent/futures/thread.py in _worker(83)
  work_item.run()

/usr/local/lib/python3.11/concurrent/futures/thread.py in run(58)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/corsheaders/middleware.py in __call__(56)
  result = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in middleware(32)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/allauth/account/middleware.py in middleware(36)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/simple_history/middleware.py in middleware(41)
  return get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/django_htmx/middleware.py in __call__(43)
  return self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in __call__(168)
  response = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/panels.py in process_request(41)
  return super(CachalotPanel, self).process_request(request)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in __call__(244)
  current_executor.run_until_future(call_result)

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run_until_future(81)
  work_item.run()

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run(40)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_wrapped_callback(90)
  return callback(request, *args, **kwargs)

/app/project/utils/decorators.py in apply_cache(64)
  response = function(request, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/django/views/generic/base.py in view(104)
  return self.dispatch(request, *args, **kwargs)

/app/project/lms_tales/views/mixins.py in dispatch(31)
  return super().dispatch(request, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/django/views/generic/base.py in dispatch(143)
  return handler(request, *args, **kwargs)

/app/project/lms_tales/views/step_views.py in get(36)
  response = super().get(request, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/django/views/generic/detail.py in get(109)
  context = self.get_context_data(object=self.object)

/app/project/lms_tales/views/step_views.py in get_context_data(69)
  if len(step_files_new) > 0:

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(37)
  return original(compiler, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(96)
  return _get_result_or_execute_query(

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in _get_result_or_execute_query(64)
  result = execute_query_func()

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in <lambda>(80)
  execute_query_func = lambda: original(compiler, *args, **kwargs)

SELECT "lms_tales_talesstepfilenew"."id",
       "lms_tales_talesstepfilenew"."created",
       "lms_tales_talesstepfilenew"."modified",
       "lms_tales_talesstepfilenew"."step_id",
       "lms_tales_talesstepfilenew"."file_id",
       "lms_tales_talesstepfilenew"."language"
  FROM "lms_tales_talesstepfilenew"
 WHERE ("lms_tales_talesstepfilenew"."language" = 'fr' AND "lms_tales_talesstepfilenew"."step_id" = 1029)
SELECT ••• FROM "lms_tales_talesstepfilenew" WHERE ("lms_tales_talesstepfilenew"."language" = 'fr' AND "lms_tales_talesstepfilenew"."step_id" = 1029)
3 ähnliche Abfragen.
0,66

Verbindung: default

Transaktionsstatus: Wartet

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in run(101)
  return _run_old_run_func()

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in _run_old_run_func(94)
  return old_run_func(self, *a, **kw)

/usr/local/lib/python3.11/concurrent/futures/thread.py in _worker(83)
  work_item.run()

/usr/local/lib/python3.11/concurrent/futures/thread.py in run(58)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/corsheaders/middleware.py in __call__(56)
  result = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in middleware(32)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/allauth/account/middleware.py in middleware(36)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/simple_history/middleware.py in middleware(41)
  return get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/django_htmx/middleware.py in __call__(43)
  return self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in __call__(168)
  response = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/panels.py in process_request(41)
  return super(CachalotPanel, self).process_request(request)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in __call__(244)
  current_executor.run_until_future(call_result)

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run_until_future(81)
  work_item.run()

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run(40)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_wrapped_callback(90)
  return callback(request, *args, **kwargs)

/app/project/utils/decorators.py in apply_cache(64)
  response = function(request, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/django/views/generic/base.py in view(104)
  return self.dispatch(request, *args, **kwargs)

/app/project/lms_tales/views/mixins.py in dispatch(31)
  return super().dispatch(request, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/django/views/generic/base.py in dispatch(143)
  return handler(request, *args, **kwargs)

/app/project/lms_tales/views/step_views.py in get(36)
  response = super().get(request, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/django/views/generic/detail.py in get(109)
  context = self.get_context_data(object=self.object)

/app/project/lms_tales/views/step_views.py in get_context_data(69)
  if len(step_files_new) > 0:

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(37)
  return original(compiler, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(96)
  return _get_result_or_execute_query(

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in _get_result_or_execute_query(64)
  result = execute_query_func()

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in <lambda>(80)
  execute_query_func = lambda: original(compiler, *args, **kwargs)

SELECT "lms_tales_talesauthor"."id",
       "lms_tales_talesauthor"."created",
       "lms_tales_talesauthor"."modified",
       "lms_tales_talesauthor"."name",
       "lms_tales_talesauthor"."name_de",
       "lms_tales_talesauthor"."name_en",
       "lms_tales_talesauthor"."name_fr",
       "lms_tales_talesauthor"."image",
       "lms_tales_talesauthor"."order",
       "lms_tales_talesauthor"."course_id"
  FROM "lms_tales_talesauthor"
 WHERE "lms_tales_talesauthor"."course_id" = 6
SELECT ••• FROM "lms_tales_talesauthor" WHERE "lms_tales_talesauthor"."course_id" = 6
0,86

Verbindung: default

Transaktionsstatus: Wartet

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in run(101)
  return _run_old_run_func()

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in _run_old_run_func(94)
  return old_run_func(self, *a, **kw)

/usr/local/lib/python3.11/concurrent/futures/thread.py in _worker(83)
  work_item.run()

/usr/local/lib/python3.11/concurrent/futures/thread.py in run(58)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/corsheaders/middleware.py in __call__(56)
  result = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in middleware(32)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/allauth/account/middleware.py in middleware(36)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/simple_history/middleware.py in middleware(41)
  return get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/django_htmx/middleware.py in __call__(43)
  return self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in __call__(168)
  response = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/panels.py in process_request(41)
  return super(CachalotPanel, self).process_request(request)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in __call__(244)
  current_executor.run_until_future(call_result)

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run_until_future(81)
  work_item.run()

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run(40)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_wrapped_callback(90)
  return callback(request, *args, **kwargs)

/app/project/utils/decorators.py in apply_cache(72)
  cache.set(CACHE_KEY, response.render(), ttl)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_patched_render(41)
  return old_render(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in render(114)
  self.content = self.rendered_content

/usr/local/lib/python3.11/site-packages/sentry_sdk/utils.py in runner(1788)
  return sentry_patched_function(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/templates.py in rendered_content(77)
  return real_rendered_content.fget(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in rendered_content(92)
  return template.render(context, self._request)

/usr/local/lib/python3.11/site-packages/django/template/backends/django.py in render(61)
  return self.template.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(175)
  return self._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py in render(314)
  match = condition.eval(context)

/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py in eval(877)
  return self.value.resolve(context, ignore_failures=True)

/usr/local/lib/python3.11/site-packages/django/template/base.py in resolve(715)
  obj = self.var.resolve(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in resolve(847)
  value = self._resolve_lookup(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in _resolve_lookup(890)
  current = getattr(current, bit)

/app/project/lms_tales/models.py in meta(83)
  + ", ".join([author.name for author in self.get_course().authors.all()]),

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(37)
  return original(compiler, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(96)
  return _get_result_or_execute_query(

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in _get_result_or_execute_query(64)
  result = execute_query_func()

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in <lambda>(80)
  execute_query_func = lambda: original(compiler, *args, **kwargs)

SELECT "waffle_flag"."id",
       "waffle_flag"."name",
       "waffle_flag"."everyone",
       "waffle_flag"."percent",
       "waffle_flag"."testing",
       "waffle_flag"."superusers",
       "waffle_flag"."staff",
       "waffle_flag"."authenticated",
       "waffle_flag"."languages",
       "waffle_flag"."rollout",
       "waffle_flag"."note",
       "waffle_flag"."created",
       "waffle_flag"."modified"
  FROM "waffle_flag"
 WHERE "waffle_flag"."name" = 'show_login_button'
 LIMIT 21
SELECT ••• FROM "waffle_flag" WHERE "waffle_flag"."name" = 'show_login_button' LIMIT 21
3 ähnliche Abfragen.
1,07

Verbindung: default

Transaktionsstatus: Wartet

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in run(101)
  return _run_old_run_func()

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in _run_old_run_func(94)
  return old_run_func(self, *a, **kw)

/usr/local/lib/python3.11/concurrent/futures/thread.py in _worker(83)
  work_item.run()

/usr/local/lib/python3.11/concurrent/futures/thread.py in run(58)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/corsheaders/middleware.py in __call__(56)
  result = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in middleware(32)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/allauth/account/middleware.py in middleware(36)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/simple_history/middleware.py in middleware(41)
  return get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/django_htmx/middleware.py in __call__(43)
  return self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in __call__(168)
  response = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/panels.py in process_request(41)
  return super(CachalotPanel, self).process_request(request)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in __call__(244)
  current_executor.run_until_future(call_result)

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run_until_future(81)
  work_item.run()

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run(40)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_wrapped_callback(90)
  return callback(request, *args, **kwargs)

/app/project/utils/decorators.py in apply_cache(72)
  cache.set(CACHE_KEY, response.render(), ttl)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_patched_render(41)
  return old_render(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in render(114)
  self.content = self.rendered_content

/usr/local/lib/python3.11/site-packages/sentry_sdk/utils.py in runner(1788)
  return sentry_patched_function(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/templates.py in rendered_content(77)
  return real_rendered_content.fget(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in rendered_content(92)
  return template.render(context, self._request)

/usr/local/lib/python3.11/site-packages/django/template/backends/django.py in render(61)
  return self.template.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(175)
  return self._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(208)
  return template.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(177)
  return self._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py in render(321)
  return nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/waffle/templatetags/waffle_tags.py in render(36)
  if self.condition(context.get('request', None), name):

/usr/local/lib/python3.11/site-packages/waffle/__init__.py in flag_is_active(19)
  flag = get_waffle_flag_model().get(flag_name)

/usr/local/lib/python3.11/site-packages/waffle/models.py in get(59)
  obj = cls.get_from_db(name)

/usr/local/lib/python3.11/site-packages/waffle/models.py in get_from_db(72)
  return objects.get(name=name)

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(37)
  return original(compiler, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(94)
  return execute_query_func()

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in <lambda>(80)
  execute_query_func = lambda: original(compiler, *args, **kwargs)

SELECT "lms_tales_taleschapter"."id",
       "lms_tales_taleschapter"."created",
       "lms_tales_taleschapter"."modified",
       "lms_tales_taleschapter"."status_changed",
       "lms_tales_taleschapter"."is_removed",
       "lms_tales_taleschapter"."title",
       "lms_tales_taleschapter"."title_de",
       "lms_tales_taleschapter"."title_en",
       "lms_tales_taleschapter"."title_fr",
       "lms_tales_taleschapter"."slug",
       "lms_tales_taleschapter"."order",
       "lms_tales_taleschapter"."status",
       "lms_tales_taleschapter"."course_id"
  FROM "lms_tales_taleschapter"
 WHERE ("lms_tales_taleschapter"."course_id" = 6 AND NOT "lms_tales_taleschapter"."is_removed" AND "lms_tales_taleschapter"."status" = 'published')
 ORDER BY "lms_tales_taleschapter"."course_id" ASC,
          "lms_tales_taleschapter"."order" ASC
SELECT ••• FROM "lms_tales_taleschapter" WHERE ("lms_tales_taleschapter"."course_id" = 6 AND NOT "lms_tales_taleschapter"."is_removed" AND "lms_tales_taleschapter"."status" = 'published') ORDER BY "lms_tales_taleschapter"."course_id" ASC, "lms_tales_taleschapter"."order" ASC
1,03

Verbindung: default

Transaktionsstatus: Wartet

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in run(101)
  return _run_old_run_func()

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in _run_old_run_func(94)
  return old_run_func(self, *a, **kw)

/usr/local/lib/python3.11/concurrent/futures/thread.py in _worker(83)
  work_item.run()

/usr/local/lib/python3.11/concurrent/futures/thread.py in run(58)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/corsheaders/middleware.py in __call__(56)
  result = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in middleware(32)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/allauth/account/middleware.py in middleware(36)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/simple_history/middleware.py in middleware(41)
  return get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/django_htmx/middleware.py in __call__(43)
  return self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in __call__(168)
  response = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/panels.py in process_request(41)
  return super(CachalotPanel, self).process_request(request)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in __call__(244)
  current_executor.run_until_future(call_result)

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run_until_future(81)
  work_item.run()

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run(40)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_wrapped_callback(90)
  return callback(request, *args, **kwargs)

/app/project/utils/decorators.py in apply_cache(72)
  cache.set(CACHE_KEY, response.render(), ttl)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_patched_render(41)
  return old_render(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in render(114)
  self.content = self.rendered_content

/usr/local/lib/python3.11/site-packages/sentry_sdk/utils.py in runner(1788)
  return sentry_patched_function(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/templates.py in rendered_content(77)
  return real_rendered_content.fget(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in rendered_content(92)
  return template.render(context, self._request)

/usr/local/lib/python3.11/site-packages/django/template/backends/django.py in render(61)
  return self.template.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(175)
  return self._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(208)
  return template.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(177)
  return self._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py in render(321)
  return nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py in render(194)
  len_values = len(values)

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(37)
  return original(compiler, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(96)
  return _get_result_or_execute_query(

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in _get_result_or_execute_query(64)
  result = execute_query_func()

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in <lambda>(80)
  execute_query_func = lambda: original(compiler, *args, **kwargs)

SELECT "lms_tales_talesstep"."id",
       "lms_tales_talesstep"."created",
       "lms_tales_talesstep"."modified",
       "lms_tales_talesstep"."status_changed",
       "lms_tales_talesstep"."is_removed",
       "lms_tales_talesstep"."title",
       "lms_tales_talesstep"."title_de",
       "lms_tales_talesstep"."title_en",
       "lms_tales_talesstep"."title_fr",
       "lms_tales_talesstep"."subtitle",
       "lms_tales_talesstep"."subtitle_de",
       "lms_tales_talesstep"."subtitle_en",
       "lms_tales_talesstep"."subtitle_fr",
       "lms_tales_talesstep"."short_description",
       "lms_tales_talesstep"."short_description_de",
       "lms_tales_talesstep"."short_description_en",
       "lms_tales_talesstep"."short_description_fr",
       "lms_tales_talesstep"."title_image",
       "lms_tales_talesstep"."slug",
       "lms_tales_talesstep"."content",
       "lms_tales_talesstep"."content_de",
       "lms_tales_talesstep"."content_en",
       "lms_tales_talesstep"."content_fr",
       "lms_tales_talesstep"."content_html",
       "lms_tales_talesstep"."content_html_de",
       "lms_tales_talesstep"."content_html_en",
       "lms_tales_talesstep"."content_html_fr",
       "lms_tales_talesstep"."content_json",
       "lms_tales_talesstep"."content_json_de",
       "lms_tales_talesstep"."content_json_en",
       "lms_tales_talesstep"."content_json_fr",
       "lms_tales_talesstep"."copyright",
       "lms_tales_talesstep"."copyright_de",
       "lms_tales_talesstep"."copyright_en",
       "lms_tales_talesstep"."copyright_fr",
       "lms_tales_talesstep"."step_type",
       "lms_tales_talesstep"."duration",
       "lms_tales_talesstep"."order",
       "lms_tales_talesstep"."status",
       "lms_tales_talesstep"."allow_comments",
       "lms_tales_talesstep"."call_to_action",
       "lms_tales_talesstep"."call_to_action_de",
       "lms_tales_talesstep"."call_to_action_en",
       "lms_tales_talesstep"."call_to_action_fr",
       "lms_tales_talesstep"."chapter_id"
  FROM "lms_tales_talesstep"
 INNER JOIN "lms_tales_taleschapter"
    ON ("lms_tales_talesstep"."chapter_id" = "lms_tales_taleschapter"."id")
 WHERE ("lms_tales_talesstep"."chapter_id" = 20 AND NOT "lms_tales_talesstep"."is_removed" AND "lms_tales_talesstep"."status" = 'published')
 ORDER BY "lms_tales_taleschapter"."course_id" ASC,
          "lms_tales_taleschapter"."order" ASC,
          "lms_tales_talesstep"."order" ASC
SELECT ••• FROM "lms_tales_talesstep" INNER JOIN "lms_tales_taleschapter" ON ("lms_tales_talesstep"."chapter_id" = "lms_tales_taleschapter"."id") WHERE ("lms_tales_talesstep"."chapter_id" = 20 AND NOT "lms_tales_talesstep"."is_removed" AND "lms_tales_talesstep"."status" = 'published') ORDER BY "lms_tales_taleschapter"."course_id" ASC, "lms_tales_taleschapter"."order" ASC, "lms_tales_talesstep"."order" ASC
4 ähnliche Abfragen.
2,02

Verbindung: default

Transaktionsstatus: Wartet

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in run(101)
  return _run_old_run_func()

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in _run_old_run_func(94)
  return old_run_func(self, *a, **kw)

/usr/local/lib/python3.11/concurrent/futures/thread.py in _worker(83)
  work_item.run()

/usr/local/lib/python3.11/concurrent/futures/thread.py in run(58)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/corsheaders/middleware.py in __call__(56)
  result = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in middleware(32)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/allauth/account/middleware.py in middleware(36)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/simple_history/middleware.py in middleware(41)
  return get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/django_htmx/middleware.py in __call__(43)
  return self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in __call__(168)
  response = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/panels.py in process_request(41)
  return super(CachalotPanel, self).process_request(request)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in __call__(244)
  current_executor.run_until_future(call_result)

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run_until_future(81)
  work_item.run()

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run(40)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_wrapped_callback(90)
  return callback(request, *args, **kwargs)

/app/project/utils/decorators.py in apply_cache(72)
  cache.set(CACHE_KEY, response.render(), ttl)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_patched_render(41)
  return old_render(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in render(114)
  self.content = self.rendered_content

/usr/local/lib/python3.11/site-packages/sentry_sdk/utils.py in runner(1788)
  return sentry_patched_function(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/templates.py in rendered_content(77)
  return real_rendered_content.fget(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in rendered_content(92)
  return template.render(context, self._request)

/usr/local/lib/python3.11/site-packages/django/template/backends/django.py in render(61)
  return self.template.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(175)
  return self._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(208)
  return template.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(177)
  return self._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py in render(321)
  return nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py in render(238)
  nodelist.append(node.render_annotated(context))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py in render(194)
  len_values = len(values)

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(37)
  return original(compiler, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(96)
  return _get_result_or_execute_query(

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in _get_result_or_execute_query(64)
  result = execute_query_func()

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in <lambda>(80)
  execute_query_func = lambda: original(compiler, *args, **kwargs)

SELECT "lms_tales_talesstep"."id",
       "lms_tales_talesstep"."created",
       "lms_tales_talesstep"."modified",
       "lms_tales_talesstep"."status_changed",
       "lms_tales_talesstep"."is_removed",
       "lms_tales_talesstep"."title",
       "lms_tales_talesstep"."title_de",
       "lms_tales_talesstep"."title_en",
       "lms_tales_talesstep"."title_fr",
       "lms_tales_talesstep"."subtitle",
       "lms_tales_talesstep"."subtitle_de",
       "lms_tales_talesstep"."subtitle_en",
       "lms_tales_talesstep"."subtitle_fr",
       "lms_tales_talesstep"."short_description",
       "lms_tales_talesstep"."short_description_de",
       "lms_tales_talesstep"."short_description_en",
       "lms_tales_talesstep"."short_description_fr",
       "lms_tales_talesstep"."title_image",
       "lms_tales_talesstep"."slug",
       "lms_tales_talesstep"."content",
       "lms_tales_talesstep"."content_de",
       "lms_tales_talesstep"."content_en",
       "lms_tales_talesstep"."content_fr",
       "lms_tales_talesstep"."content_html",
       "lms_tales_talesstep"."content_html_de",
       "lms_tales_talesstep"."content_html_en",
       "lms_tales_talesstep"."content_html_fr",
       "lms_tales_talesstep"."content_json",
       "lms_tales_talesstep"."content_json_de",
       "lms_tales_talesstep"."content_json_en",
       "lms_tales_talesstep"."content_json_fr",
       "lms_tales_talesstep"."copyright",
       "lms_tales_talesstep"."copyright_de",
       "lms_tales_talesstep"."copyright_en",
       "lms_tales_talesstep"."copyright_fr",
       "lms_tales_talesstep"."step_type",
       "lms_tales_talesstep"."duration",
       "lms_tales_talesstep"."order",
       "lms_tales_talesstep"."status",
       "lms_tales_talesstep"."allow_comments",
       "lms_tales_talesstep"."call_to_action",
       "lms_tales_talesstep"."call_to_action_de",
       "lms_tales_talesstep"."call_to_action_en",
       "lms_tales_talesstep"."call_to_action_fr",
       "lms_tales_talesstep"."chapter_id"
  FROM "lms_tales_talesstep"
 INNER JOIN "lms_tales_taleschapter"
    ON ("lms_tales_talesstep"."chapter_id" = "lms_tales_taleschapter"."id")
 WHERE ("lms_tales_talesstep"."chapter_id" = 19 AND NOT "lms_tales_talesstep"."is_removed" AND "lms_tales_talesstep"."status" = 'published')
 ORDER BY "lms_tales_taleschapter"."course_id" ASC,
          "lms_tales_taleschapter"."order" ASC,
          "lms_tales_talesstep"."order" ASC
SELECT ••• FROM "lms_tales_talesstep" INNER JOIN "lms_tales_taleschapter" ON ("lms_tales_talesstep"."chapter_id" = "lms_tales_taleschapter"."id") WHERE ("lms_tales_talesstep"."chapter_id" = 19 AND NOT "lms_tales_talesstep"."is_removed" AND "lms_tales_talesstep"."status" = 'published') ORDER BY "lms_tales_taleschapter"."course_id" ASC, "lms_tales_taleschapter"."order" ASC, "lms_tales_talesstep"."order" ASC
4 ähnliche Abfragen.
1,25

Verbindung: default

Transaktionsstatus: Wartet

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in run(101)
  return _run_old_run_func()

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in _run_old_run_func(94)
  return old_run_func(self, *a, **kw)

/usr/local/lib/python3.11/concurrent/futures/thread.py in _worker(83)
  work_item.run()

/usr/local/lib/python3.11/concurrent/futures/thread.py in run(58)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/corsheaders/middleware.py in __call__(56)
  result = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in middleware(32)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/allauth/account/middleware.py in middleware(36)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/simple_history/middleware.py in middleware(41)
  return get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/django_htmx/middleware.py in __call__(43)
  return self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in __call__(168)
  response = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/panels.py in process_request(41)
  return super(CachalotPanel, self).process_request(request)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in __call__(244)
  current_executor.run_until_future(call_result)

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run_until_future(81)
  work_item.run()

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run(40)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_wrapped_callback(90)
  return callback(request, *args, **kwargs)

/app/project/utils/decorators.py in apply_cache(72)
  cache.set(CACHE_KEY, response.render(), ttl)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_patched_render(41)
  return old_render(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in render(114)
  self.content = self.rendered_content

/usr/local/lib/python3.11/site-packages/sentry_sdk/utils.py in runner(1788)
  return sentry_patched_function(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/templates.py in rendered_content(77)
  return real_rendered_content.fget(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in rendered_content(92)
  return template.render(context, self._request)

/usr/local/lib/python3.11/site-packages/django/template/backends/django.py in render(61)
  return self.template.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(175)
  return self._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(208)
  return template.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(177)
  return self._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py in render(321)
  return nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py in render(238)
  nodelist.append(node.render_annotated(context))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py in render(194)
  len_values = len(values)

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(37)
  return original(compiler, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(96)
  return _get_result_or_execute_query(

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in _get_result_or_execute_query(64)
  result = execute_query_func()

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in <lambda>(80)
  execute_query_func = lambda: original(compiler, *args, **kwargs)

SELECT "lms_tales_talesstep"."id",
       "lms_tales_talesstep"."created",
       "lms_tales_talesstep"."modified",
       "lms_tales_talesstep"."status_changed",
       "lms_tales_talesstep"."is_removed",
       "lms_tales_talesstep"."title",
       "lms_tales_talesstep"."title_de",
       "lms_tales_talesstep"."title_en",
       "lms_tales_talesstep"."title_fr",
       "lms_tales_talesstep"."subtitle",
       "lms_tales_talesstep"."subtitle_de",
       "lms_tales_talesstep"."subtitle_en",
       "lms_tales_talesstep"."subtitle_fr",
       "lms_tales_talesstep"."short_description",
       "lms_tales_talesstep"."short_description_de",
       "lms_tales_talesstep"."short_description_en",
       "lms_tales_talesstep"."short_description_fr",
       "lms_tales_talesstep"."title_image",
       "lms_tales_talesstep"."slug",
       "lms_tales_talesstep"."content",
       "lms_tales_talesstep"."content_de",
       "lms_tales_talesstep"."content_en",
       "lms_tales_talesstep"."content_fr",
       "lms_tales_talesstep"."content_html",
       "lms_tales_talesstep"."content_html_de",
       "lms_tales_talesstep"."content_html_en",
       "lms_tales_talesstep"."content_html_fr",
       "lms_tales_talesstep"."content_json",
       "lms_tales_talesstep"."content_json_de",
       "lms_tales_talesstep"."content_json_en",
       "lms_tales_talesstep"."content_json_fr",
       "lms_tales_talesstep"."copyright",
       "lms_tales_talesstep"."copyright_de",
       "lms_tales_talesstep"."copyright_en",
       "lms_tales_talesstep"."copyright_fr",
       "lms_tales_talesstep"."step_type",
       "lms_tales_talesstep"."duration",
       "lms_tales_talesstep"."order",
       "lms_tales_talesstep"."status",
       "lms_tales_talesstep"."allow_comments",
       "lms_tales_talesstep"."call_to_action",
       "lms_tales_talesstep"."call_to_action_de",
       "lms_tales_talesstep"."call_to_action_en",
       "lms_tales_talesstep"."call_to_action_fr",
       "lms_tales_talesstep"."chapter_id"
  FROM "lms_tales_talesstep"
 INNER JOIN "lms_tales_taleschapter"
    ON ("lms_tales_talesstep"."chapter_id" = "lms_tales_taleschapter"."id")
 WHERE ("lms_tales_talesstep"."chapter_id" = 21 AND NOT "lms_tales_talesstep"."is_removed" AND "lms_tales_talesstep"."status" = 'published')
 ORDER BY "lms_tales_taleschapter"."course_id" ASC,
          "lms_tales_taleschapter"."order" ASC,
          "lms_tales_talesstep"."order" ASC
SELECT ••• FROM "lms_tales_talesstep" INNER JOIN "lms_tales_taleschapter" ON ("lms_tales_talesstep"."chapter_id" = "lms_tales_taleschapter"."id") WHERE ("lms_tales_talesstep"."chapter_id" = 21 AND NOT "lms_tales_talesstep"."is_removed" AND "lms_tales_talesstep"."status" = 'published') ORDER BY "lms_tales_taleschapter"."course_id" ASC, "lms_tales_taleschapter"."order" ASC, "lms_tales_talesstep"."order" ASC
4 ähnliche Abfragen.
1,76

Verbindung: default

Transaktionsstatus: Wartet

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in run(101)
  return _run_old_run_func()

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in _run_old_run_func(94)
  return old_run_func(self, *a, **kw)

/usr/local/lib/python3.11/concurrent/futures/thread.py in _worker(83)
  work_item.run()

/usr/local/lib/python3.11/concurrent/futures/thread.py in run(58)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/corsheaders/middleware.py in __call__(56)
  result = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in middleware(32)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/allauth/account/middleware.py in middleware(36)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/simple_history/middleware.py in middleware(41)
  return get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/django_htmx/middleware.py in __call__(43)
  return self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in __call__(168)
  response = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/panels.py in process_request(41)
  return super(CachalotPanel, self).process_request(request)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in __call__(244)
  current_executor.run_until_future(call_result)

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run_until_future(81)
  work_item.run()

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run(40)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_wrapped_callback(90)
  return callback(request, *args, **kwargs)

/app/project/utils/decorators.py in apply_cache(72)
  cache.set(CACHE_KEY, response.render(), ttl)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_patched_render(41)
  return old_render(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in render(114)
  self.content = self.rendered_content

/usr/local/lib/python3.11/site-packages/sentry_sdk/utils.py in runner(1788)
  return sentry_patched_function(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/templates.py in rendered_content(77)
  return real_rendered_content.fget(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in rendered_content(92)
  return template.render(context, self._request)

/usr/local/lib/python3.11/site-packages/django/template/backends/django.py in render(61)
  return self.template.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(175)
  return self._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(208)
  return template.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(177)
  return self._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py in render(321)
  return nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py in render(238)
  nodelist.append(node.render_annotated(context))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py in render(194)
  len_values = len(values)

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(37)
  return original(compiler, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(96)
  return _get_result_or_execute_query(

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in _get_result_or_execute_query(64)
  result = execute_query_func()

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in <lambda>(80)
  execute_query_func = lambda: original(compiler, *args, **kwargs)

SELECT "lms_tales_talesstep"."id",
       "lms_tales_talesstep"."created",
       "lms_tales_talesstep"."modified",
       "lms_tales_talesstep"."status_changed",
       "lms_tales_talesstep"."is_removed",
       "lms_tales_talesstep"."title",
       "lms_tales_talesstep"."title_de",
       "lms_tales_talesstep"."title_en",
       "lms_tales_talesstep"."title_fr",
       "lms_tales_talesstep"."subtitle",
       "lms_tales_talesstep"."subtitle_de",
       "lms_tales_talesstep"."subtitle_en",
       "lms_tales_talesstep"."subtitle_fr",
       "lms_tales_talesstep"."short_description",
       "lms_tales_talesstep"."short_description_de",
       "lms_tales_talesstep"."short_description_en",
       "lms_tales_talesstep"."short_description_fr",
       "lms_tales_talesstep"."title_image",
       "lms_tales_talesstep"."slug",
       "lms_tales_talesstep"."content",
       "lms_tales_talesstep"."content_de",
       "lms_tales_talesstep"."content_en",
       "lms_tales_talesstep"."content_fr",
       "lms_tales_talesstep"."content_html",
       "lms_tales_talesstep"."content_html_de",
       "lms_tales_talesstep"."content_html_en",
       "lms_tales_talesstep"."content_html_fr",
       "lms_tales_talesstep"."content_json",
       "lms_tales_talesstep"."content_json_de",
       "lms_tales_talesstep"."content_json_en",
       "lms_tales_talesstep"."content_json_fr",
       "lms_tales_talesstep"."copyright",
       "lms_tales_talesstep"."copyright_de",
       "lms_tales_talesstep"."copyright_en",
       "lms_tales_talesstep"."copyright_fr",
       "lms_tales_talesstep"."step_type",
       "lms_tales_talesstep"."duration",
       "lms_tales_talesstep"."order",
       "lms_tales_talesstep"."status",
       "lms_tales_talesstep"."allow_comments",
       "lms_tales_talesstep"."call_to_action",
       "lms_tales_talesstep"."call_to_action_de",
       "lms_tales_talesstep"."call_to_action_en",
       "lms_tales_talesstep"."call_to_action_fr",
       "lms_tales_talesstep"."chapter_id"
  FROM "lms_tales_talesstep"
 INNER JOIN "lms_tales_taleschapter"
    ON ("lms_tales_talesstep"."chapter_id" = "lms_tales_taleschapter"."id")
 WHERE ("lms_tales_talesstep"."chapter_id" = 22 AND NOT "lms_tales_talesstep"."is_removed" AND "lms_tales_talesstep"."status" = 'published')
 ORDER BY "lms_tales_taleschapter"."course_id" ASC,
          "lms_tales_taleschapter"."order" ASC,
          "lms_tales_talesstep"."order" ASC
SELECT ••• FROM "lms_tales_talesstep" INNER JOIN "lms_tales_taleschapter" ON ("lms_tales_talesstep"."chapter_id" = "lms_tales_taleschapter"."id") WHERE ("lms_tales_talesstep"."chapter_id" = 22 AND NOT "lms_tales_talesstep"."is_removed" AND "lms_tales_talesstep"."status" = 'published') ORDER BY "lms_tales_taleschapter"."course_id" ASC, "lms_tales_taleschapter"."order" ASC, "lms_tales_talesstep"."order" ASC
4 ähnliche Abfragen.
1,90

Verbindung: default

Transaktionsstatus: Wartet

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in run(101)
  return _run_old_run_func()

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in _run_old_run_func(94)
  return old_run_func(self, *a, **kw)

/usr/local/lib/python3.11/concurrent/futures/thread.py in _worker(83)
  work_item.run()

/usr/local/lib/python3.11/concurrent/futures/thread.py in run(58)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/corsheaders/middleware.py in __call__(56)
  result = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in middleware(32)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/allauth/account/middleware.py in middleware(36)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/simple_history/middleware.py in middleware(41)
  return get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/django_htmx/middleware.py in __call__(43)
  return self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in __call__(168)
  response = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/panels.py in process_request(41)
  return super(CachalotPanel, self).process_request(request)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in __call__(244)
  current_executor.run_until_future(call_result)

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run_until_future(81)
  work_item.run()

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run(40)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_wrapped_callback(90)
  return callback(request, *args, **kwargs)

/app/project/utils/decorators.py in apply_cache(72)
  cache.set(CACHE_KEY, response.render(), ttl)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_patched_render(41)
  return old_render(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in render(114)
  self.content = self.rendered_content

/usr/local/lib/python3.11/site-packages/sentry_sdk/utils.py in runner(1788)
  return sentry_patched_function(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/templates.py in rendered_content(77)
  return real_rendered_content.fget(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in rendered_content(92)
  return template.render(context, self._request)

/usr/local/lib/python3.11/site-packages/django/template/backends/django.py in render(61)
  return self.template.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(175)
  return self._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(208)
  return template.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(177)
  return self._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py in render(321)
  return nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py in render(238)
  nodelist.append(node.render_annotated(context))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py in render(194)
  len_values = len(values)

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(37)
  return original(compiler, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(96)
  return _get_result_or_execute_query(

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in _get_result_or_execute_query(64)
  result = execute_query_func()

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in <lambda>(80)
  execute_query_func = lambda: original(compiler, *args, **kwargs)

SELECT "lms_tales_talesstep"."id",
       "lms_tales_talesstep"."created",
       "lms_tales_talesstep"."modified",
       "lms_tales_talesstep"."status_changed",
       "lms_tales_talesstep"."is_removed",
       "lms_tales_talesstep"."title",
       "lms_tales_talesstep"."title_de",
       "lms_tales_talesstep"."title_en",
       "lms_tales_talesstep"."title_fr",
       "lms_tales_talesstep"."subtitle",
       "lms_tales_talesstep"."subtitle_de",
       "lms_tales_talesstep"."subtitle_en",
       "lms_tales_talesstep"."subtitle_fr",
       "lms_tales_talesstep"."short_description",
       "lms_tales_talesstep"."short_description_de",
       "lms_tales_talesstep"."short_description_en",
       "lms_tales_talesstep"."short_description_fr",
       "lms_tales_talesstep"."title_image",
       "lms_tales_talesstep"."slug",
       "lms_tales_talesstep"."content",
       "lms_tales_talesstep"."content_de",
       "lms_tales_talesstep"."content_en",
       "lms_tales_talesstep"."content_fr",
       "lms_tales_talesstep"."content_html",
       "lms_tales_talesstep"."content_html_de",
       "lms_tales_talesstep"."content_html_en",
       "lms_tales_talesstep"."content_html_fr",
       "lms_tales_talesstep"."content_json",
       "lms_tales_talesstep"."content_json_de",
       "lms_tales_talesstep"."content_json_en",
       "lms_tales_talesstep"."content_json_fr",
       "lms_tales_talesstep"."copyright",
       "lms_tales_talesstep"."copyright_de",
       "lms_tales_talesstep"."copyright_en",
       "lms_tales_talesstep"."copyright_fr",
       "lms_tales_talesstep"."step_type",
       "lms_tales_talesstep"."duration",
       "lms_tales_talesstep"."order",
       "lms_tales_talesstep"."status",
       "lms_tales_talesstep"."allow_comments",
       "lms_tales_talesstep"."call_to_action",
       "lms_tales_talesstep"."call_to_action_de",
       "lms_tales_talesstep"."call_to_action_en",
       "lms_tales_talesstep"."call_to_action_fr",
       "lms_tales_talesstep"."chapter_id"
  FROM "lms_tales_talesstep"
 INNER JOIN "lms_tales_taleschapter"
    ON ("lms_tales_talesstep"."chapter_id" = "lms_tales_taleschapter"."id")
 WHERE ("lms_tales_talesstep"."chapter_id" = 21 AND NOT "lms_tales_talesstep"."is_removed" AND "lms_tales_talesstep"."status" = 'published' AND "lms_tales_talesstep"."order" > 5)
 ORDER BY "lms_tales_taleschapter"."course_id" ASC,
          "lms_tales_taleschapter"."order" ASC,
          "lms_tales_talesstep"."order" ASC
 LIMIT 1
SELECT ••• FROM "lms_tales_talesstep" INNER JOIN "lms_tales_taleschapter" ON ("lms_tales_talesstep"."chapter_id" = "lms_tales_taleschapter"."id") WHERE ("lms_tales_talesstep"."chapter_id" = 21 AND NOT "lms_tales_talesstep"."is_removed" AND "lms_tales_talesstep"."status" = 'published' AND "lms_tales_talesstep"."order" > 5) ORDER BY "lms_tales_taleschapter"."course_id" ASC, "lms_tales_taleschapter"."order" ASC, "lms_tales_talesstep"."order" ASC LIMIT 1
0,76

Verbindung: default

Transaktionsstatus: Wartet

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in run(101)
  return _run_old_run_func()

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in _run_old_run_func(94)
  return old_run_func(self, *a, **kw)

/usr/local/lib/python3.11/concurrent/futures/thread.py in _worker(83)
  work_item.run()

/usr/local/lib/python3.11/concurrent/futures/thread.py in run(58)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/corsheaders/middleware.py in __call__(56)
  result = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in middleware(32)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/allauth/account/middleware.py in middleware(36)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/simple_history/middleware.py in middleware(41)
  return get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/django_htmx/middleware.py in __call__(43)
  return self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in __call__(168)
  response = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/panels.py in process_request(41)
  return super(CachalotPanel, self).process_request(request)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in __call__(244)
  current_executor.run_until_future(call_result)

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run_until_future(81)
  work_item.run()

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run(40)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_wrapped_callback(90)
  return callback(request, *args, **kwargs)

/app/project/utils/decorators.py in apply_cache(72)
  cache.set(CACHE_KEY, response.render(), ttl)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_patched_render(41)
  return old_render(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in render(114)
  self.content = self.rendered_content

/usr/local/lib/python3.11/site-packages/sentry_sdk/utils.py in runner(1788)
  return sentry_patched_function(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/templates.py in rendered_content(77)
  return real_rendered_content.fget(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in rendered_content(92)
  return template.render(context, self._request)

/usr/local/lib/python3.11/site-packages/django/template/backends/django.py in render(61)
  return self.template.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(175)
  return self._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py in render(541)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/library.py in render(237)
  output = self.func(*resolved_args, **resolved_kwargs)

/app/project/lms_base/templatetags/utils.py in get_next_step(128)
  return step.get_next(published_only=True)

/app/project/lms_base/models.py in get_next(249)
  return self._get_neighbour_step(is_next=True, published_only=published_only)

/app/project/lms_base/models.py in _get_neighbour_step(201)
  step = self.__class__.next_previous_manager.get_next_previous(

/app/project/lms_base/models.py in get_next_previous(71)
  return qs.first()

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(37)
  return original(compiler, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(96)
  return _get_result_or_execute_query(

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in _get_result_or_execute_query(64)
  result = execute_query_func()

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in <lambda>(80)
  execute_query_func = lambda: original(compiler, *args, **kwargs)

SELECT "lms_tales_taleschapter"."id",
       "lms_tales_taleschapter"."created",
       "lms_tales_taleschapter"."modified",
       "lms_tales_taleschapter"."status_changed",
       "lms_tales_taleschapter"."is_removed",
       "lms_tales_taleschapter"."title",
       "lms_tales_taleschapter"."title_de",
       "lms_tales_taleschapter"."title_en",
       "lms_tales_taleschapter"."title_fr",
       "lms_tales_taleschapter"."slug",
       "lms_tales_taleschapter"."order",
       "lms_tales_taleschapter"."status",
       "lms_tales_taleschapter"."course_id"
  FROM "lms_tales_taleschapter"
 WHERE ("lms_tales_taleschapter"."course_id" = 6 AND NOT "lms_tales_taleschapter"."is_removed" AND "lms_tales_taleschapter"."status" = 'published' AND "lms_tales_taleschapter"."order" > 2)
 ORDER BY "lms_tales_taleschapter"."course_id" ASC,
          "lms_tales_taleschapter"."order" ASC
 LIMIT 1
SELECT ••• FROM "lms_tales_taleschapter" WHERE ("lms_tales_taleschapter"."course_id" = 6 AND NOT "lms_tales_taleschapter"."is_removed" AND "lms_tales_taleschapter"."status" = 'published' AND "lms_tales_taleschapter"."order" > 2) ORDER BY "lms_tales_taleschapter"."course_id" ASC, "lms_tales_taleschapter"."order" ASC LIMIT 1
0,49

Verbindung: default

Transaktionsstatus: Wartet

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in run(101)
  return _run_old_run_func()

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in _run_old_run_func(94)
  return old_run_func(self, *a, **kw)

/usr/local/lib/python3.11/concurrent/futures/thread.py in _worker(83)
  work_item.run()

/usr/local/lib/python3.11/concurrent/futures/thread.py in run(58)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/corsheaders/middleware.py in __call__(56)
  result = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in middleware(32)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/allauth/account/middleware.py in middleware(36)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/simple_history/middleware.py in middleware(41)
  return get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/django_htmx/middleware.py in __call__(43)
  return self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in __call__(168)
  response = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/panels.py in process_request(41)
  return super(CachalotPanel, self).process_request(request)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in __call__(244)
  current_executor.run_until_future(call_result)

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run_until_future(81)
  work_item.run()

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run(40)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_wrapped_callback(90)
  return callback(request, *args, **kwargs)

/app/project/utils/decorators.py in apply_cache(72)
  cache.set(CACHE_KEY, response.render(), ttl)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_patched_render(41)
  return old_render(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in render(114)
  self.content = self.rendered_content

/usr/local/lib/python3.11/site-packages/sentry_sdk/utils.py in runner(1788)
  return sentry_patched_function(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/templates.py in rendered_content(77)
  return real_rendered_content.fget(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in rendered_content(92)
  return template.render(context, self._request)

/usr/local/lib/python3.11/site-packages/django/template/backends/django.py in render(61)
  return self.template.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(175)
  return self._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py in render(541)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/library.py in render(237)
  output = self.func(*resolved_args, **resolved_kwargs)

/app/project/lms_base/templatetags/utils.py in get_next_step(128)
  return step.get_next(published_only=True)

/app/project/lms_base/models.py in get_next(249)
  return self._get_neighbour_step(is_next=True, published_only=published_only)

/app/project/lms_base/models.py in _get_neighbour_step(216)
  chapter = chapter.get_next(published_only=True)

/app/project/lms_base/models.py in get_next(314)
  return self.__class__.next_previous_manager.get_next_previous(

/app/project/lms_base/models.py in get_next_previous(71)
  return qs.first()

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(37)
  return original(compiler, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(96)
  return _get_result_or_execute_query(

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in _get_result_or_execute_query(64)
  result = execute_query_func()

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in <lambda>(80)
  execute_query_func = lambda: original(compiler, *args, **kwargs)

SELECT COUNT(*) AS "__count"
  FROM "lms_tales_talesstep"
 WHERE ("lms_tales_talesstep"."chapter_id" = 22 AND NOT "lms_tales_talesstep"."is_removed" AND "lms_tales_talesstep"."status" = 'published')
SELECT COUNT(*) AS "__count" FROM "lms_tales_talesstep" WHERE ("lms_tales_talesstep"."chapter_id" = 22 AND NOT "lms_tales_talesstep"."is_removed" AND "lms_tales_talesstep"."status" = 'published')
0,59

Verbindung: default

Transaktionsstatus: Wartet

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in run(101)
  return _run_old_run_func()

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in _run_old_run_func(94)
  return old_run_func(self, *a, **kw)

/usr/local/lib/python3.11/concurrent/futures/thread.py in _worker(83)
  work_item.run()

/usr/local/lib/python3.11/concurrent/futures/thread.py in run(58)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/corsheaders/middleware.py in __call__(56)
  result = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in middleware(32)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/allauth/account/middleware.py in middleware(36)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/simple_history/middleware.py in middleware(41)
  return get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/django_htmx/middleware.py in __call__(43)
  return self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in __call__(168)
  response = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/panels.py in process_request(41)
  return super(CachalotPanel, self).process_request(request)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in __call__(244)
  current_executor.run_until_future(call_result)

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run_until_future(81)
  work_item.run()

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run(40)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_wrapped_callback(90)
  return callback(request, *args, **kwargs)

/app/project/utils/decorators.py in apply_cache(72)
  cache.set(CACHE_KEY, response.render(), ttl)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_patched_render(41)
  return old_render(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in render(114)
  self.content = self.rendered_content

/usr/local/lib/python3.11/site-packages/sentry_sdk/utils.py in runner(1788)
  return sentry_patched_function(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/templates.py in rendered_content(77)
  return real_rendered_content.fget(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in rendered_content(92)
  return template.render(context, self._request)

/usr/local/lib/python3.11/site-packages/django/template/backends/django.py in render(61)
  return self.template.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(175)
  return self._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py in render(541)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/library.py in render(237)
  output = self.func(*resolved_args, **resolved_kwargs)

/app/project/lms_base/templatetags/utils.py in get_next_step(128)
  return step.get_next(published_only=True)

/app/project/lms_base/models.py in get_next(249)
  return self._get_neighbour_step(is_next=True, published_only=published_only)

/app/project/lms_base/models.py in _get_neighbour_step(232)
  if qs.count() == 0:

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(37)
  return original(compiler, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(96)
  return _get_result_or_execute_query(

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in _get_result_or_execute_query(64)
  result = execute_query_func()

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in <lambda>(80)
  execute_query_func = lambda: original(compiler, *args, **kwargs)

SELECT "lms_tales_talesstep"."id",
       "lms_tales_talesstep"."created",
       "lms_tales_talesstep"."modified",
       "lms_tales_talesstep"."status_changed",
       "lms_tales_talesstep"."is_removed",
       "lms_tales_talesstep"."title",
       "lms_tales_talesstep"."title_de",
       "lms_tales_talesstep"."title_en",
       "lms_tales_talesstep"."title_fr",
       "lms_tales_talesstep"."subtitle",
       "lms_tales_talesstep"."subtitle_de",
       "lms_tales_talesstep"."subtitle_en",
       "lms_tales_talesstep"."subtitle_fr",
       "lms_tales_talesstep"."short_description",
       "lms_tales_talesstep"."short_description_de",
       "lms_tales_talesstep"."short_description_en",
       "lms_tales_talesstep"."short_description_fr",
       "lms_tales_talesstep"."title_image",
       "lms_tales_talesstep"."slug",
       "lms_tales_talesstep"."content",
       "lms_tales_talesstep"."content_de",
       "lms_tales_talesstep"."content_en",
       "lms_tales_talesstep"."content_fr",
       "lms_tales_talesstep"."content_html",
       "lms_tales_talesstep"."content_html_de",
       "lms_tales_talesstep"."content_html_en",
       "lms_tales_talesstep"."content_html_fr",
       "lms_tales_talesstep"."content_json",
       "lms_tales_talesstep"."content_json_de",
       "lms_tales_talesstep"."content_json_en",
       "lms_tales_talesstep"."content_json_fr",
       "lms_tales_talesstep"."copyright",
       "lms_tales_talesstep"."copyright_de",
       "lms_tales_talesstep"."copyright_en",
       "lms_tales_talesstep"."copyright_fr",
       "lms_tales_talesstep"."step_type",
       "lms_tales_talesstep"."duration",
       "lms_tales_talesstep"."order",
       "lms_tales_talesstep"."status",
       "lms_tales_talesstep"."allow_comments",
       "lms_tales_talesstep"."call_to_action",
       "lms_tales_talesstep"."call_to_action_de",
       "lms_tales_talesstep"."call_to_action_en",
       "lms_tales_talesstep"."call_to_action_fr",
       "lms_tales_talesstep"."chapter_id"
  FROM "lms_tales_talesstep"
 INNER JOIN "lms_tales_taleschapter"
    ON ("lms_tales_talesstep"."chapter_id" = "lms_tales_taleschapter"."id")
 WHERE ("lms_tales_talesstep"."chapter_id" = 22 AND NOT "lms_tales_talesstep"."is_removed" AND "lms_tales_talesstep"."status" = 'published')
 ORDER BY "lms_tales_taleschapter"."course_id" ASC,
          "lms_tales_taleschapter"."order" ASC,
          "lms_tales_talesstep"."order" ASC
 LIMIT 1
SELECT ••• FROM "lms_tales_talesstep" INNER JOIN "lms_tales_taleschapter" ON ("lms_tales_talesstep"."chapter_id" = "lms_tales_taleschapter"."id") WHERE ("lms_tales_talesstep"."chapter_id" = 22 AND NOT "lms_tales_talesstep"."is_removed" AND "lms_tales_talesstep"."status" = 'published') ORDER BY "lms_tales_taleschapter"."course_id" ASC, "lms_tales_taleschapter"."order" ASC, "lms_tales_talesstep"."order" ASC LIMIT 1
0,72

Verbindung: default

Transaktionsstatus: Wartet

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in run(101)
  return _run_old_run_func()

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in _run_old_run_func(94)
  return old_run_func(self, *a, **kw)

/usr/local/lib/python3.11/concurrent/futures/thread.py in _worker(83)
  work_item.run()

/usr/local/lib/python3.11/concurrent/futures/thread.py in run(58)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/corsheaders/middleware.py in __call__(56)
  result = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in middleware(32)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/allauth/account/middleware.py in middleware(36)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/simple_history/middleware.py in middleware(41)
  return get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/django_htmx/middleware.py in __call__(43)
  return self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in __call__(168)
  response = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/panels.py in process_request(41)
  return super(CachalotPanel, self).process_request(request)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in __call__(244)
  current_executor.run_until_future(call_result)

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run_until_future(81)
  work_item.run()

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run(40)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_wrapped_callback(90)
  return callback(request, *args, **kwargs)

/app/project/utils/decorators.py in apply_cache(72)
  cache.set(CACHE_KEY, response.render(), ttl)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_patched_render(41)
  return old_render(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in render(114)
  self.content = self.rendered_content

/usr/local/lib/python3.11/site-packages/sentry_sdk/utils.py in runner(1788)
  return sentry_patched_function(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/templates.py in rendered_content(77)
  return real_rendered_content.fget(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in rendered_content(92)
  return template.render(context, self._request)

/usr/local/lib/python3.11/site-packages/django/template/backends/django.py in render(61)
  return self.template.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(175)
  return self._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py in render(541)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/library.py in render(237)
  output = self.func(*resolved_args, **resolved_kwargs)

/app/project/lms_base/templatetags/utils.py in get_next_step(128)
  return step.get_next(published_only=True)

/app/project/lms_base/models.py in get_next(249)
  return self._get_neighbour_step(is_next=True, published_only=published_only)

/app/project/lms_base/models.py in _get_neighbour_step(236)
  step = qs.first()

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(37)
  return original(compiler, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(96)
  return _get_result_or_execute_query(

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in _get_result_or_execute_query(64)
  result = execute_query_func()

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in <lambda>(80)
  execute_query_func = lambda: original(compiler, *args, **kwargs)

SELECT "lms_tales_talesstep"."id",
       "lms_tales_talesstep"."created",
       "lms_tales_talesstep"."modified",
       "lms_tales_talesstep"."status_changed",
       "lms_tales_talesstep"."is_removed",
       "lms_tales_talesstep"."title",
       "lms_tales_talesstep"."title_de",
       "lms_tales_talesstep"."title_en",
       "lms_tales_talesstep"."title_fr",
       "lms_tales_talesstep"."subtitle",
       "lms_tales_talesstep"."subtitle_de",
       "lms_tales_talesstep"."subtitle_en",
       "lms_tales_talesstep"."subtitle_fr",
       "lms_tales_talesstep"."short_description",
       "lms_tales_talesstep"."short_description_de",
       "lms_tales_talesstep"."short_description_en",
       "lms_tales_talesstep"."short_description_fr",
       "lms_tales_talesstep"."title_image",
       "lms_tales_talesstep"."slug",
       "lms_tales_talesstep"."content",
       "lms_tales_talesstep"."content_de",
       "lms_tales_talesstep"."content_en",
       "lms_tales_talesstep"."content_fr",
       "lms_tales_talesstep"."content_html",
       "lms_tales_talesstep"."content_html_de",
       "lms_tales_talesstep"."content_html_en",
       "lms_tales_talesstep"."content_html_fr",
       "lms_tales_talesstep"."content_json",
       "lms_tales_talesstep"."content_json_de",
       "lms_tales_talesstep"."content_json_en",
       "lms_tales_talesstep"."content_json_fr",
       "lms_tales_talesstep"."copyright",
       "lms_tales_talesstep"."copyright_de",
       "lms_tales_talesstep"."copyright_en",
       "lms_tales_talesstep"."copyright_fr",
       "lms_tales_talesstep"."step_type",
       "lms_tales_talesstep"."duration",
       "lms_tales_talesstep"."order",
       "lms_tales_talesstep"."status",
       "lms_tales_talesstep"."allow_comments",
       "lms_tales_talesstep"."call_to_action",
       "lms_tales_talesstep"."call_to_action_de",
       "lms_tales_talesstep"."call_to_action_en",
       "lms_tales_talesstep"."call_to_action_fr",
       "lms_tales_talesstep"."chapter_id"
  FROM "lms_tales_talesstep"
 INNER JOIN "lms_tales_taleschapter"
    ON ("lms_tales_talesstep"."chapter_id" = "lms_tales_taleschapter"."id")
 WHERE ("lms_tales_talesstep"."chapter_id" = 21 AND NOT "lms_tales_talesstep"."is_removed" AND "lms_tales_talesstep"."status" = 'published' AND "lms_tales_talesstep"."order" < 5)
 ORDER BY "lms_tales_taleschapter"."course_id" DESC,
          "lms_tales_taleschapter"."order" DESC,
          "lms_tales_talesstep"."order" DESC
 LIMIT 1
SELECT ••• FROM "lms_tales_talesstep" INNER JOIN "lms_tales_taleschapter" ON ("lms_tales_talesstep"."chapter_id" = "lms_tales_taleschapter"."id") WHERE ("lms_tales_talesstep"."chapter_id" = 21 AND NOT "lms_tales_talesstep"."is_removed" AND "lms_tales_talesstep"."status" = 'published' AND "lms_tales_talesstep"."order" < 5) ORDER BY "lms_tales_taleschapter"."course_id" DESC, "lms_tales_taleschapter"."order" DESC, "lms_tales_talesstep"."order" DESC LIMIT 1
0,77

Verbindung: default

Transaktionsstatus: Wartet

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in run(101)
  return _run_old_run_func()

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in _run_old_run_func(94)
  return old_run_func(self, *a, **kw)

/usr/local/lib/python3.11/concurrent/futures/thread.py in _worker(83)
  work_item.run()

/usr/local/lib/python3.11/concurrent/futures/thread.py in run(58)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/corsheaders/middleware.py in __call__(56)
  result = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in middleware(32)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/allauth/account/middleware.py in middleware(36)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/simple_history/middleware.py in middleware(41)
  return get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/django_htmx/middleware.py in __call__(43)
  return self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in __call__(168)
  response = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/panels.py in process_request(41)
  return super(CachalotPanel, self).process_request(request)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in __call__(244)
  current_executor.run_until_future(call_result)

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run_until_future(81)
  work_item.run()

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run(40)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_wrapped_callback(90)
  return callback(request, *args, **kwargs)

/app/project/utils/decorators.py in apply_cache(72)
  cache.set(CACHE_KEY, response.render(), ttl)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_patched_render(41)
  return old_render(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in render(114)
  self.content = self.rendered_content

/usr/local/lib/python3.11/site-packages/sentry_sdk/utils.py in runner(1788)
  return sentry_patched_function(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/templates.py in rendered_content(77)
  return real_rendered_content.fget(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in rendered_content(92)
  return template.render(context, self._request)

/usr/local/lib/python3.11/site-packages/django/template/backends/django.py in render(61)
  return self.template.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(175)
  return self._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py in render(541)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/library.py in render(237)
  output = self.func(*resolved_args, **resolved_kwargs)

/app/project/lms_base/templatetags/utils.py in get_previous_step(105)
  return step.get_previous(published_only=True)

/app/project/lms_base/models.py in get_previous(255)
  return self._get_neighbour_step(is_next=False, published_only=published_only)

/app/project/lms_base/models.py in _get_neighbour_step(201)
  step = self.__class__.next_previous_manager.get_next_previous(

/app/project/lms_base/models.py in get_next_previous(72)
  return qs.last()

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(37)
  return original(compiler, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(96)
  return _get_result_or_execute_query(

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in _get_result_or_execute_query(64)
  result = execute_query_func()

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in <lambda>(80)
  execute_query_func = lambda: original(compiler, *args, **kwargs)

SELECT "auth_group"."id",
       "auth_group"."name"
  FROM "auth_group"
 INNER JOIN "lms_tales_talescourse_owner"
    ON ("auth_group"."id" = "lms_tales_talescourse_owner"."group_id")
 WHERE "lms_tales_talescourse_owner"."talescourse_id" = 6
SELECT ••• FROM "auth_group" INNER JOIN "lms_tales_talescourse_owner" ON ("auth_group"."id" = "lms_tales_talescourse_owner"."group_id") WHERE "lms_tales_talescourse_owner"."talescourse_id" = 6
0,87

Verbindung: default

Transaktionsstatus: Wartet

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in run(101)
  return _run_old_run_func()

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in _run_old_run_func(94)
  return old_run_func(self, *a, **kw)

/usr/local/lib/python3.11/concurrent/futures/thread.py in _worker(83)
  work_item.run()

/usr/local/lib/python3.11/concurrent/futures/thread.py in run(58)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/corsheaders/middleware.py in __call__(56)
  result = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in middleware(32)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/allauth/account/middleware.py in middleware(36)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/simple_history/middleware.py in middleware(41)
  return get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/django_htmx/middleware.py in __call__(43)
  return self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in __call__(168)
  response = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/panels.py in process_request(41)
  return super(CachalotPanel, self).process_request(request)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in __call__(244)
  current_executor.run_until_future(call_result)

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run_until_future(81)
  work_item.run()

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run(40)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_wrapped_callback(90)
  return callback(request, *args, **kwargs)

/app/project/utils/decorators.py in apply_cache(72)
  cache.set(CACHE_KEY, response.render(), ttl)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_patched_render(41)
  return old_render(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in render(114)
  self.content = self.rendered_content

/usr/local/lib/python3.11/site-packages/sentry_sdk/utils.py in runner(1788)
  return sentry_patched_function(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/templates.py in rendered_content(77)
  return real_rendered_content.fget(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in rendered_content(92)
  return template.render(context, self._request)

/usr/local/lib/python3.11/site-packages/django/template/backends/django.py in render(61)
  return self.template.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(175)
  return self._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py in render(541)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/library.py in render(237)
  output = self.func(*resolved_args, **resolved_kwargs)

/usr/local/lib/python3.11/site-packages/rules/templatetags/rules.py in has_perm(18)
  return user.has_perm(perm, obj)

/usr/local/lib/python3.11/site-packages/django/contrib/auth/models.py in has_perm(480)
  return _user_has_perm(self, perm, obj=obj)

/usr/local/lib/python3.11/site-packages/django/contrib/auth/models.py in _user_has_perm(220)
  if backend.has_perm(user, perm, obj):

/usr/local/lib/python3.11/site-packages/rules/permissions.py in has_perm(31)
  return has_perm(perm, user, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/rules/permissions.py in has_perm(23)
  return permissions.test_rule(name, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/rules/rulesets.py in test_rule(6)
  return name in self and self[name].test(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/rules/predicates.py in test(172)
  return bool(self._apply(*args))

/usr/local/lib/python3.11/site-packages/rules/predicates.py in _apply(235)
  result = self.fn(*callargs)

/usr/local/lib/python3.11/site-packages/rules/predicates.py in OR(184)
  return self._combine(other, operator.or_, args)

/usr/local/lib/python3.11/site-packages/rules/predicates.py in _combine(206)
  self_result = self._apply(*args)

/usr/local/lib/python3.11/site-packages/rules/predicates.py in _apply(235)
  result = self.fn(*callargs)

/app/project/lms_tales/rules.py in is_in_group(47)
  for owner in course.owner.all():

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(37)
  return original(compiler, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(96)
  return _get_result_or_execute_query(

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in _get_result_or_execute_query(64)
  result = execute_query_func()

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in <lambda>(80)
  execute_query_func = lambda: original(compiler, *args, **kwargs)

SELECT "waffle_flag"."id",
       "waffle_flag"."name",
       "waffle_flag"."everyone",
       "waffle_flag"."percent",
       "waffle_flag"."testing",
       "waffle_flag"."superusers",
       "waffle_flag"."staff",
       "waffle_flag"."authenticated",
       "waffle_flag"."languages",
       "waffle_flag"."rollout",
       "waffle_flag"."note",
       "waffle_flag"."created",
       "waffle_flag"."modified"
  FROM "waffle_flag"
 WHERE "waffle_flag"."name" = 'show_language_warning'
 LIMIT 21
SELECT ••• FROM "waffle_flag" WHERE "waffle_flag"."name" = 'show_language_warning' LIMIT 21
3 ähnliche Abfragen.
0,44

Verbindung: default

Transaktionsstatus: Wartet

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in run(101)
  return _run_old_run_func()

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in _run_old_run_func(94)
  return old_run_func(self, *a, **kw)

/usr/local/lib/python3.11/concurrent/futures/thread.py in _worker(83)
  work_item.run()

/usr/local/lib/python3.11/concurrent/futures/thread.py in run(58)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/corsheaders/middleware.py in __call__(56)
  result = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in middleware(32)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/allauth/account/middleware.py in middleware(36)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/simple_history/middleware.py in middleware(41)
  return get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/django_htmx/middleware.py in __call__(43)
  return self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in __call__(168)
  response = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/panels.py in process_request(41)
  return super(CachalotPanel, self).process_request(request)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in __call__(244)
  current_executor.run_until_future(call_result)

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run_until_future(81)
  work_item.run()

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run(40)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_wrapped_callback(90)
  return callback(request, *args, **kwargs)

/app/project/utils/decorators.py in apply_cache(72)
  cache.set(CACHE_KEY, response.render(), ttl)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_patched_render(41)
  return old_render(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in render(114)
  self.content = self.rendered_content

/usr/local/lib/python3.11/site-packages/sentry_sdk/utils.py in runner(1788)
  return sentry_patched_function(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/templates.py in rendered_content(77)
  return real_rendered_content.fget(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in rendered_content(92)
  return template.render(context, self._request)

/usr/local/lib/python3.11/site-packages/django/template/backends/django.py in render(61)
  return self.template.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(175)
  return self._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py in render(541)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/waffle/templatetags/waffle_tags.py in render(36)
  if self.condition(context.get('request', None), name):

/usr/local/lib/python3.11/site-packages/waffle/__init__.py in flag_is_active(19)
  flag = get_waffle_flag_model().get(flag_name)

/usr/local/lib/python3.11/site-packages/waffle/models.py in get(59)
  obj = cls.get_from_db(name)

/usr/local/lib/python3.11/site-packages/waffle/models.py in get_from_db(72)
  return objects.get(name=name)

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(37)
  return original(compiler, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(94)
  return execute_query_func()

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in <lambda>(80)
  execute_query_func = lambda: original(compiler, *args, **kwargs)

SELECT "lms_tales_taleschapter"."id",
       "lms_tales_taleschapter"."created",
       "lms_tales_taleschapter"."modified",
       "lms_tales_taleschapter"."status_changed",
       "lms_tales_taleschapter"."is_removed",
       "lms_tales_taleschapter"."title",
       "lms_tales_taleschapter"."title_de",
       "lms_tales_taleschapter"."title_en",
       "lms_tales_taleschapter"."title_fr",
       "lms_tales_taleschapter"."slug",
       "lms_tales_taleschapter"."order",
       "lms_tales_taleschapter"."status",
       "lms_tales_taleschapter"."course_id"
  FROM "lms_tales_taleschapter"
 WHERE ("lms_tales_taleschapter"."course_id" = 6 AND NOT "lms_tales_taleschapter"."is_removed" AND "lms_tales_taleschapter"."status" = 'published')
 ORDER BY "lms_tales_taleschapter"."order" ASC
SELECT ••• FROM "lms_tales_taleschapter" WHERE ("lms_tales_taleschapter"."course_id" = 6 AND NOT "lms_tales_taleschapter"."is_removed" AND "lms_tales_taleschapter"."status" = 'published') ORDER BY "lms_tales_taleschapter"."order" ASC
0,44

Verbindung: default

Transaktionsstatus: Wartet

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in run(101)
  return _run_old_run_func()

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in _run_old_run_func(94)
  return old_run_func(self, *a, **kw)

/usr/local/lib/python3.11/concurrent/futures/thread.py in _worker(83)
  work_item.run()

/usr/local/lib/python3.11/concurrent/futures/thread.py in run(58)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/corsheaders/middleware.py in __call__(56)
  result = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in middleware(32)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/allauth/account/middleware.py in middleware(36)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/simple_history/middleware.py in middleware(41)
  return get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/django_htmx/middleware.py in __call__(43)
  return self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in __call__(168)
  response = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/panels.py in process_request(41)
  return super(CachalotPanel, self).process_request(request)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in __call__(244)
  current_executor.run_until_future(call_result)

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run_until_future(81)
  work_item.run()

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run(40)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_wrapped_callback(90)
  return callback(request, *args, **kwargs)

/app/project/utils/decorators.py in apply_cache(72)
  cache.set(CACHE_KEY, response.render(), ttl)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_patched_render(41)
  return old_render(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in render(114)
  self.content = self.rendered_content

/usr/local/lib/python3.11/site-packages/sentry_sdk/utils.py in runner(1788)
  return sentry_patched_function(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/templates.py in rendered_content(77)
  return real_rendered_content.fget(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in rendered_content(92)
  return template.render(context, self._request)

/usr/local/lib/python3.11/site-packages/django/template/backends/django.py in render(61)
  return self.template.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(175)
  return self._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py in render(541)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1064)
  output = self.filter_expression.resolve(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in resolve(715)
  obj = self.var.resolve(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in resolve(847)
  value = self._resolve_lookup(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in _resolve_lookup(914)
  current = current()

/app/project/lms_tales/models.py in get_step_number(107)
  chapter_list = list(

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(37)
  return original(compiler, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(96)
  return _get_result_or_execute_query(

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in _get_result_or_execute_query(64)
  result = execute_query_func()

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in <lambda>(80)
  execute_query_func = lambda: original(compiler, *args, **kwargs)

SELECT "lms_tales_talesstep"."id",
       "lms_tales_talesstep"."created",
       "lms_tales_talesstep"."modified",
       "lms_tales_talesstep"."status_changed",
       "lms_tales_talesstep"."is_removed",
       "lms_tales_talesstep"."title",
       "lms_tales_talesstep"."title_de",
       "lms_tales_talesstep"."title_en",
       "lms_tales_talesstep"."title_fr",
       "lms_tales_talesstep"."subtitle",
       "lms_tales_talesstep"."subtitle_de",
       "lms_tales_talesstep"."subtitle_en",
       "lms_tales_talesstep"."subtitle_fr",
       "lms_tales_talesstep"."short_description",
       "lms_tales_talesstep"."short_description_de",
       "lms_tales_talesstep"."short_description_en",
       "lms_tales_talesstep"."short_description_fr",
       "lms_tales_talesstep"."title_image",
       "lms_tales_talesstep"."slug",
       "lms_tales_talesstep"."content",
       "lms_tales_talesstep"."content_de",
       "lms_tales_talesstep"."content_en",
       "lms_tales_talesstep"."content_fr",
       "lms_tales_talesstep"."content_html",
       "lms_tales_talesstep"."content_html_de",
       "lms_tales_talesstep"."content_html_en",
       "lms_tales_talesstep"."content_html_fr",
       "lms_tales_talesstep"."content_json",
       "lms_tales_talesstep"."content_json_de",
       "lms_tales_talesstep"."content_json_en",
       "lms_tales_talesstep"."content_json_fr",
       "lms_tales_talesstep"."copyright",
       "lms_tales_talesstep"."copyright_de",
       "lms_tales_talesstep"."copyright_en",
       "lms_tales_talesstep"."copyright_fr",
       "lms_tales_talesstep"."step_type",
       "lms_tales_talesstep"."duration",
       "lms_tales_talesstep"."order",
       "lms_tales_talesstep"."status",
       "lms_tales_talesstep"."allow_comments",
       "lms_tales_talesstep"."call_to_action",
       "lms_tales_talesstep"."call_to_action_de",
       "lms_tales_talesstep"."call_to_action_en",
       "lms_tales_talesstep"."call_to_action_fr",
       "lms_tales_talesstep"."chapter_id"
  FROM "lms_tales_talesstep"
 WHERE ("lms_tales_talesstep"."chapter_id" = 21 AND NOT "lms_tales_talesstep"."is_removed" AND "lms_tales_talesstep"."status" = 'published')
 ORDER BY "lms_tales_talesstep"."order" ASC
SELECT ••• FROM "lms_tales_talesstep" WHERE ("lms_tales_talesstep"."chapter_id" = 21 AND NOT "lms_tales_talesstep"."is_removed" AND "lms_tales_talesstep"."status" = 'published') ORDER BY "lms_tales_talesstep"."order" ASC
1,04

Verbindung: default

Transaktionsstatus: Wartet

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in run(101)
  return _run_old_run_func()

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in _run_old_run_func(94)
  return old_run_func(self, *a, **kw)

/usr/local/lib/python3.11/concurrent/futures/thread.py in _worker(83)
  work_item.run()

/usr/local/lib/python3.11/concurrent/futures/thread.py in run(58)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/corsheaders/middleware.py in __call__(56)
  result = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in middleware(32)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/allauth/account/middleware.py in middleware(36)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/simple_history/middleware.py in middleware(41)
  return get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/django_htmx/middleware.py in __call__(43)
  return self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in __call__(168)
  response = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/panels.py in process_request(41)
  return super(CachalotPanel, self).process_request(request)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in __call__(244)
  current_executor.run_until_future(call_result)

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run_until_future(81)
  work_item.run()

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run(40)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_wrapped_callback(90)
  return callback(request, *args, **kwargs)

/app/project/utils/decorators.py in apply_cache(72)
  cache.set(CACHE_KEY, response.render(), ttl)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_patched_render(41)
  return old_render(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in render(114)
  self.content = self.rendered_content

/usr/local/lib/python3.11/site-packages/sentry_sdk/utils.py in runner(1788)
  return sentry_patched_function(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/templates.py in rendered_content(77)
  return real_rendered_content.fget(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in rendered_content(92)
  return template.render(context, self._request)

/usr/local/lib/python3.11/site-packages/django/template/backends/django.py in render(61)
  return self.template.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(175)
  return self._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py in render(541)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1064)
  output = self.filter_expression.resolve(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in resolve(715)
  obj = self.var.resolve(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in resolve(847)
  value = self._resolve_lookup(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in _resolve_lookup(914)
  current = current()

/app/project/lms_tales/models.py in get_step_number(118)
  step_list = list(self.chapter.published_steps.all().order_by("order"))

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(37)
  return original(compiler, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(96)
  return _get_result_or_execute_query(

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in _get_result_or_execute_query(64)
  result = execute_query_func()

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in <lambda>(80)
  execute_query_func = lambda: original(compiler, *args, **kwargs)

SELECT "waffle_flag"."id",
       "waffle_flag"."name",
       "waffle_flag"."everyone",
       "waffle_flag"."percent",
       "waffle_flag"."testing",
       "waffle_flag"."superusers",
       "waffle_flag"."staff",
       "waffle_flag"."authenticated",
       "waffle_flag"."languages",
       "waffle_flag"."rollout",
       "waffle_flag"."note",
       "waffle_flag"."created",
       "waffle_flag"."modified"
  FROM "waffle_flag"
 WHERE "waffle_flag"."name" = 'comments_feature_is_active'
 LIMIT 21
SELECT ••• FROM "waffle_flag" WHERE "waffle_flag"."name" = 'comments_feature_is_active' LIMIT 21
3 ähnliche Abfragen.
0,42

Verbindung: default

Transaktionsstatus: Wartet

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in run(101)
  return _run_old_run_func()

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in _run_old_run_func(94)
  return old_run_func(self, *a, **kw)

/usr/local/lib/python3.11/concurrent/futures/thread.py in _worker(83)
  work_item.run()

/usr/local/lib/python3.11/concurrent/futures/thread.py in run(58)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/corsheaders/middleware.py in __call__(56)
  result = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in middleware(32)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/allauth/account/middleware.py in middleware(36)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/simple_history/middleware.py in middleware(41)
  return get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/django_htmx/middleware.py in __call__(43)
  return self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in __call__(168)
  response = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/panels.py in process_request(41)
  return super(CachalotPanel, self).process_request(request)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in __call__(244)
  current_executor.run_until_future(call_result)

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run_until_future(81)
  work_item.run()

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run(40)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_wrapped_callback(90)
  return callback(request, *args, **kwargs)

/app/project/utils/decorators.py in apply_cache(72)
  cache.set(CACHE_KEY, response.render(), ttl)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_patched_render(41)
  return old_render(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in render(114)
  self.content = self.rendered_content

/usr/local/lib/python3.11/site-packages/sentry_sdk/utils.py in runner(1788)
  return sentry_patched_function(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/templates.py in rendered_content(77)
  return real_rendered_content.fget(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in rendered_content(92)
  return template.render(context, self._request)

/usr/local/lib/python3.11/site-packages/django/template/backends/django.py in render(61)
  return self.template.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(175)
  return self._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py in render(541)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/waffle/templatetags/waffle_tags.py in render(36)
  if self.condition(context.get('request', None), name):

/usr/local/lib/python3.11/site-packages/waffle/__init__.py in flag_is_active(19)
  flag = get_waffle_flag_model().get(flag_name)

/usr/local/lib/python3.11/site-packages/waffle/models.py in get(59)
  obj = cls.get_from_db(name)

/usr/local/lib/python3.11/site-packages/waffle/models.py in get_from_db(72)
  return objects.get(name=name)

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(37)
  return original(compiler, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(94)
  return execute_query_func()

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in <lambda>(80)
  execute_query_func = lambda: original(compiler, *args, **kwargs)

Statische Dateien (273 gefunden, 7 benutzt)

Pfad mit statischen Dateien

  1. /app/project/static

Apps mit statischen Dateien

  1. modeltranslation
  2. django.contrib.admin
  3. django_extensions
  4. markdownx
  5. django_htmx
  6. rosetta
  7. notifications
  8. debug_toolbar

Statische Dateien

images/icon_tales_white.png
/app/project/static/images/icon_tales_white.png
images/icon_tales_transp.png
/app/project/static/images/icon_tales_transp.png
lms_base/css/lms_base.css
/app/project/static/lms_base/css/lms_base.css
lms_tales/css/lms_tales.css
None
lms_base/js/lms_base.js
/app/project/static/lms_base/js/lms_base.js
lms_tales/js/lms_tales.js
/app/project/static/lms_tales/js/lms_tales.js
images/uni-basel-logo-de.svg
/app/project/static/images/uni-basel-logo-de.svg

django.contrib.staticfiles.finders.FileSystemFinder (123 Dateien)

Pfad Ort
robots.txt /app/project/static/robots.txt
alphorn_07.jpg /app/project/static/alphorn_07.jpg
browserconfig.xml /app/project/static/browserconfig.xml
alphorn_11.jpg /app/project/static/alphorn_11.jpg
lottie/optimized_tales_banner2.mp4 /app/project/static/lottie/optimized_tales_banner2.mp4
lottie/optimized_tales_banner_av1.webm /app/project/static/lottie/optimized_tales_banner_av1.webm
lottie/tales_banner3.mp4 /app/project/static/lottie/tales_banner3.mp4
lottie/optimized_tales_banner3.webm /app/project/static/lottie/optimized_tales_banner3.webm
lottie/optimized_tales_banner2.webm /app/project/static/lottie/optimized_tales_banner2.webm
lottie/tales_banner.json /app/project/static/lottie/tales_banner.json
lottie/optimized_tales_banner3.mp4 /app/project/static/lottie/optimized_tales_banner3.mp4
lottie/optimized_tales_banner_av1.mp4 /app/project/static/lottie/optimized_tales_banner_av1.mp4
lottie/optimized_tales_banner.mp4 /app/project/static/lottie/optimized_tales_banner.mp4
lottie/tales_banner2.mp4 /app/project/static/lottie/tales_banner2.mp4
lms_base/font/nmc.woff /app/project/static/lms_base/font/nmc.woff
lms_base/font/icon-left.woff2 /app/project/static/lms_base/font/icon-left.woff2
lms_base/font/nmc.woff2 /app/project/static/lms_base/font/nmc.woff2
lms_base/font/nmc.eot /app/project/static/lms_base/font/nmc.eot
lms_base/font/icon-left.woff /app/project/static/lms_base/font/icon-left.woff
lms_base/font/nmc.svg /app/project/static/lms_base/font/nmc.svg
lms_base/font/icon-left.svg /app/project/static/lms_base/font/icon-left.svg
lms_base/font/nmc.ttf /app/project/static/lms_base/font/nmc.ttf
lms_base/font/icon-left.eot /app/project/static/lms_base/font/icon-left.eot
lms_base/font/icon-left.ttf /app/project/static/lms_base/font/icon-left.ttf
lms_base/css/lms_base.css /app/project/static/lms_base/css/lms_base.css
lms_base/css/lms_base.css.map /app/project/static/lms_base/css/lms_base.css.map
lms_base/js/lms_base.js /app/project/static/lms_base/js/lms_base.js
lms_base/js/bootstrap.bundle.min.js /app/project/static/lms_base/js/bootstrap.bundle.min.js
reporting/css/report_pdf.css.map /app/project/static/reporting/css/report_pdf.css.map
reporting/css/report_pdf.css /app/project/static/reporting/css/report_pdf.css
reporting/images/nmcunilogo.png /app/project/static/reporting/images/nmcunilogo.png
reporting/images/background.jpg /app/project/static/reporting/images/background.jpg
dropzone/dropzone.min.css /app/project/static/dropzone/dropzone.min.css
dropzone/dropzone-amd-module.min.js /app/project/static/dropzone/dropzone-amd-module.min.js
dropzone/basic.min.css /app/project/static/dropzone/basic.min.css
dropzone/dropzone.min.js /app/project/static/dropzone/dropzone.min.js
lms_tales/font/nmc.woff /app/project/static/lms_tales/font/nmc.woff
lms_tales/font/icon-left.woff2 /app/project/static/lms_tales/font/icon-left.woff2
lms_tales/font/nmc.woff2 /app/project/static/lms_tales/font/nmc.woff2
lms_tales/font/nmc.eot /app/project/static/lms_tales/font/nmc.eot
lms_tales/font/icon-left.woff /app/project/static/lms_tales/font/icon-left.woff
lms_tales/font/nmc.svg /app/project/static/lms_tales/font/nmc.svg
lms_tales/font/icon-left.svg /app/project/static/lms_tales/font/icon-left.svg
lms_tales/font/nmc.ttf /app/project/static/lms_tales/font/nmc.ttf
lms_tales/font/icon-left.eot /app/project/static/lms_tales/font/icon-left.eot
lms_tales/font/icon-left.ttf /app/project/static/lms_tales/font/icon-left.ttf
lms_tales/js/lms_tales.js /app/project/static/lms_tales/js/lms_tales.js
opos/4_4.html /app/project/static/opos/4_4.html
opos/4_3.html /app/project/static/opos/4_3.html
opos/4_5.html /app/project/static/opos/4_5.html
opos/4_1.html /app/project/static/opos/4_1.html
tales_editor/favicon.ico /app/project/static/tales_editor/favicon.ico
tales_editor/index.html /app/project/static/tales_editor/index.html
tales_editor/css/chunk-vendors.css /app/project/static/tales_editor/css/chunk-vendors.css
tales_editor/css/app.css /app/project/static/tales_editor/css/app.css
tales_editor/img/bootstrap-icons.svg /app/project/static/tales_editor/img/bootstrap-icons.svg
tales_editor/img/remixicon.symbol.svg /app/project/static/tales_editor/img/remixicon.symbol.svg
tales_editor/js/app.js /app/project/static/tales_editor/js/app.js
tales_editor/js/app.js.map /app/project/static/tales_editor/js/app.js.map
tales_editor/js/chunk-vendors.js /app/project/static/tales_editor/js/chunk-vendors.js
tales_editor/js/chunk-vendors.js.map /app/project/static/tales_editor/js/chunk-vendors.js.map
images/opos_map_xs.png /app/project/static/images/opos_map_xs.png
images/opos_map_xl.png /app/project/static/images/opos_map_xl.png
images/edu-id-button-gray.png /app/project/static/images/edu-id-button-gray.png
images/icon_tales_mint.png /app/project/static/images/icon_tales_mint.png
images/favicon.ico /app/project/static/images/favicon.ico
images/door.jpg /app/project/static/images/door.jpg
images/icon_tales_transp_32x32.png /app/project/static/images/icon_tales_transp_32x32.png
images/uni-basel-logo-de.svg /app/project/static/images/uni-basel-logo-de.svg
images/raymond_ammann.jpg /app/project/static/images/raymond_ammann.jpg
images/help_en.jpg /app/project/static/images/help_en.jpg
images/opos_map_xs.avif /app/project/static/images/opos_map_xs.avif
images/opos_map_md.png /app/project/static/images/opos_map_md.png
images/help_de.jpg /app/project/static/images/help_de.jpg
images/bild.png /app/project/static/images/bild.png
images/help.jpg /app/project/static/images/help.jpg
images/Hochformat.jpg /app/project/static/images/Hochformat.jpg
images/empty_classroom.jpg /app/project/static/images/empty_classroom.jpg
images/uni-basel-logo-de.png /app/project/static/images/uni-basel-logo-de.png
images/contact-side-image-1.jpg /app/project/static/images/contact-side-image-1.jpg
images/icon_tales_white.png /app/project/static/images/icon_tales_white.png
images/portalflag.png /app/project/static/images/portalflag.png
images/uni-basel-logo-en.svg /app/project/static/images/uni-basel-logo-en.svg
images/contact-side-image-2.jpg /app/project/static/images/contact-side-image-2.jpg
images/alp_und_hirtenhorn.jpg /app/project/static/images/alp_und_hirtenhorn.jpg
images/icon_tales_transp.png /app/project/static/images/icon_tales_transp.png
images/Weltkarte_Opos.png /app/project/static/images/Weltkarte_Opos.png
images/batkitty.jpg /app/project/static/images/batkitty.jpg
images/help_fr.jpg /app/project/static/images/help_fr.jpg
nahtkurs_glossar/antikoagu.jpg /app/project/static/nahtkurs_glossar/antikoagu.jpg
nahtkurs_glossar/anamnese.jpg /app/project/static/nahtkurs_glossar/anamnese.jpg
nahtkurs_glossar/wundinfektion.jpg /app/project/static/nahtkurs_glossar/wundinfektion.jpg
nahtkurs_glossar/tensilestength.jpg /app/project/static/nahtkurs_glossar/tensilestength.jpg
nahtkurs_glossar/glucose.jpg /app/project/static/nahtkurs_glossar/glucose.jpg
nahtkurs_glossar/nacl.jpg /app/project/static/nahtkurs_glossar/nacl.jpg
sounds/temperiert_nr_7.mp3 /app/project/static/sounds/temperiert_nr_7.mp3
sounds/alphorn_13.mp3 /app/project/static/sounds/alphorn_13.mp3
sounds/alphorn_05.mp3 /app/project/static/sounds/alphorn_05.mp3
sounds/alphorn_11.mp3 /app/project/static/sounds/alphorn_11.mp3
sounds/naturton_nr_7.mp3 /app/project/static/sounds/naturton_nr_7.mp3
sounds/hirtenhorn_04.mp3 /app/project/static/sounds/hirtenhorn_04.mp3
sounds/alphorn_14.mp3 /app/project/static/sounds/alphorn_14.mp3
sounds/alphorn_01.mp3 /app/project/static/sounds/alphorn_01.mp3
sounds/alphorn_12.mp3 /app/project/static/sounds/alphorn_12.mp3
sounds/alphorn_02.mp3 /app/project/static/sounds/alphorn_02.mp3
sounds/alphorn_09.mp3 /app/project/static/sounds/alphorn_09.mp3
sounds/alphorn_04.mp3 /app/project/static/sounds/alphorn_04.mp3
sounds/alphorn_15.mp3 /app/project/static/sounds/alphorn_15.mp3
sounds/hirtenhorn_07.mp3 /app/project/static/sounds/hirtenhorn_07.mp3
sounds/alphorn_08.mp3 /app/project/static/sounds/alphorn_08.mp3
sounds/alphorn_03.mp3 /app/project/static/sounds/alphorn_03.mp3
sounds/hirtenhorn_02.mp3 /app/project/static/sounds/hirtenhorn_02.mp3
sounds/alphorn_10.mp3 /app/project/static/sounds/alphorn_10.mp3
sounds/hirtenhorn_01.mp3 /app/project/static/sounds/hirtenhorn_01.mp3
sounds/hirtenhorn_06.mp3 /app/project/static/sounds/hirtenhorn_06.mp3
sounds/alphorn_07.mp3 /app/project/static/sounds/alphorn_07.mp3
sounds/temperiert_nr_11.mp3 /app/project/static/sounds/temperiert_nr_11.mp3
sounds/hirtenhorn_08.mp3 /app/project/static/sounds/hirtenhorn_08.mp3
sounds/naturton_nr_11.mp3 /app/project/static/sounds/naturton_nr_11.mp3
sounds/alphorn_16.mp3 /app/project/static/sounds/alphorn_16.mp3
sounds/hirtenhorn_05.mp3 /app/project/static/sounds/hirtenhorn_05.mp3
sounds/hirtenhorn_03.mp3 /app/project/static/sounds/hirtenhorn_03.mp3
sounds/alphorn_06.mp3 /app/project/static/sounds/alphorn_06.mp3

django.contrib.staticfiles.finders.AppDirectoriesFinder (150 Dateien)

Pfad Ort
modeltranslation/css/tabbed_translation_fields.css /usr/local/lib/python3.11/site-packages/modeltranslation/static/modeltranslation/css/tabbed_translation_fields.css
modeltranslation/js/clearable_inputs.js /usr/local/lib/python3.11/site-packages/modeltranslation/static/modeltranslation/js/clearable_inputs.js
modeltranslation/js/tabbed_translation_fields.js /usr/local/lib/python3.11/site-packages/modeltranslation/static/modeltranslation/js/tabbed_translation_fields.js
modeltranslation/js/force_jquery.js /usr/local/lib/python3.11/site-packages/modeltranslation/static/modeltranslation/js/force_jquery.js
admin/css/autocomplete.css /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/css/autocomplete.css
admin/css/responsive.css /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/css/responsive.css
admin/css/widgets.css /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/css/widgets.css
admin/css/changelists.css /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/css/changelists.css
admin/css/dark_mode.css /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/css/dark_mode.css
admin/css/responsive_rtl.css /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/css/responsive_rtl.css
admin/css/nav_sidebar.css /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/css/nav_sidebar.css
admin/css/dashboard.css /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/css/dashboard.css
admin/css/forms.css /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/css/forms.css
admin/css/rtl.css /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/css/rtl.css
admin/css/login.css /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/css/login.css
admin/css/base.css /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/css/base.css
admin/css/vendor/select2/select2.min.css /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/css/vendor/select2/select2.min.css
admin/css/vendor/select2/select2.css /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/css/vendor/select2/select2.css
admin/css/vendor/select2/LICENSE-SELECT2.md /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/css/vendor/select2/LICENSE-SELECT2.md
admin/img/icon-clock.svg /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/img/icon-clock.svg
admin/img/sorting-icons.svg /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/img/sorting-icons.svg
admin/img/icon-alert.svg /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/img/icon-alert.svg
admin/img/icon-changelink.svg /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/img/icon-changelink.svg
admin/img/selector-icons.svg /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/img/selector-icons.svg
admin/img/calendar-icons.svg /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/img/calendar-icons.svg
admin/img/tooltag-arrowright.svg /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/img/tooltag-arrowright.svg
admin/img/inline-delete.svg /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/img/inline-delete.svg
admin/img/icon-yes.svg /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/img/icon-yes.svg
admin/img/icon-unknown-alt.svg /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/img/icon-unknown-alt.svg
admin/img/icon-viewlink.svg /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/img/icon-viewlink.svg
admin/img/search.svg /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/img/search.svg
admin/img/icon-deletelink.svg /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/img/icon-deletelink.svg
admin/img/README.txt /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/img/README.txt
admin/img/LICENSE /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/img/LICENSE
admin/img/icon-calendar.svg /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/img/icon-calendar.svg
admin/img/tooltag-add.svg /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/img/tooltag-add.svg
admin/img/icon-unknown.svg /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/img/icon-unknown.svg
admin/img/icon-addlink.svg /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/img/icon-addlink.svg
admin/img/icon-no.svg /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/img/icon-no.svg
admin/img/gis/move_vertex_off.svg /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/img/gis/move_vertex_off.svg
admin/img/gis/move_vertex_on.svg /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/img/gis/move_vertex_on.svg
admin/js/SelectBox.js /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/js/SelectBox.js
admin/js/jquery.init.js /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/js/jquery.init.js
admin/js/inlines.js /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/js/inlines.js
admin/js/collapse.js /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/js/collapse.js
admin/js/filters.js /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/js/filters.js
admin/js/change_form.js /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/js/change_form.js
admin/js/autocomplete.js /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/js/autocomplete.js
admin/js/nav_sidebar.js /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/js/nav_sidebar.js
admin/js/popup_response.js /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/js/popup_response.js
admin/js/SelectFilter2.js /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/js/SelectFilter2.js
admin/js/actions.js /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/js/actions.js
admin/js/core.js /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/js/core.js
admin/js/cancel.js /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/js/cancel.js
admin/js/prepopulate.js /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/js/prepopulate.js
admin/js/urlify.js /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/js/urlify.js
admin/js/calendar.js /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/js/calendar.js
admin/js/prepopulate_init.js /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/js/prepopulate_init.js
admin/js/theme.js /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/js/theme.js
admin/js/admin/DateTimeShortcuts.js /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/js/admin/DateTimeShortcuts.js
admin/js/admin/RelatedObjectLookups.js /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/js/admin/RelatedObjectLookups.js
admin/js/vendor/select2/select2.full.js /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/js/vendor/select2/select2.full.js
admin/js/vendor/select2/select2.full.min.js /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/js/vendor/select2/select2.full.min.js
admin/js/vendor/select2/LICENSE.md /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/js/vendor/select2/LICENSE.md
admin/js/vendor/select2/i18n/zh-CN.js /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/js/vendor/select2/i18n/zh-CN.js
admin/js/vendor/select2/i18n/sr-Cyrl.js /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/js/vendor/select2/i18n/sr-Cyrl.js
admin/js/vendor/select2/i18n/uk.js /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/js/vendor/select2/i18n/uk.js
admin/js/vendor/select2/i18n/ar.js /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/js/vendor/select2/i18n/ar.js
admin/js/vendor/select2/i18n/ka.js /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/js/vendor/select2/i18n/ka.js
admin/js/vendor/select2/i18n/bn.js /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/js/vendor/select2/i18n/bn.js
admin/js/vendor/select2/i18n/pt.js /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/js/vendor/select2/i18n/pt.js
admin/js/vendor/select2/i18n/hi.js /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/js/vendor/select2/i18n/hi.js
admin/js/vendor/select2/i18n/dsb.js /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/js/vendor/select2/i18n/dsb.js
admin/js/vendor/select2/i18n/bs.js /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/js/vendor/select2/i18n/bs.js
admin/js/vendor/select2/i18n/ru.js /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/js/vendor/select2/i18n/ru.js
admin/js/vendor/select2/i18n/ms.js /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/js/vendor/select2/i18n/ms.js
admin/js/vendor/select2/i18n/et.js /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/js/vendor/select2/i18n/et.js
admin/js/vendor/select2/i18n/sl.js /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/js/vendor/select2/i18n/sl.js
admin/js/vendor/select2/i18n/he.js /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/js/vendor/select2/i18n/he.js
admin/js/vendor/select2/i18n/is.js /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/js/vendor/select2/i18n/is.js
admin/js/vendor/select2/i18n/cs.js /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/js/vendor/select2/i18n/cs.js
admin/js/vendor/select2/i18n/sq.js /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/js/vendor/select2/i18n/sq.js
admin/js/vendor/select2/i18n/sv.js /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/js/vendor/select2/i18n/sv.js
admin/js/vendor/select2/i18n/ne.js /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/js/vendor/select2/i18n/ne.js
admin/js/vendor/select2/i18n/ko.js /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/js/vendor/select2/i18n/ko.js
admin/js/vendor/select2/i18n/vi.js /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/js/vendor/select2/i18n/vi.js
admin/js/vendor/select2/i18n/ca.js /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/js/vendor/select2/i18n/ca.js
admin/js/vendor/select2/i18n/id.js /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/js/vendor/select2/i18n/id.js
admin/js/vendor/select2/i18n/nb.js /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/js/vendor/select2/i18n/nb.js
admin/js/vendor/select2/i18n/hr.js /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/js/vendor/select2/i18n/hr.js
admin/js/vendor/select2/i18n/af.js /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/js/vendor/select2/i18n/af.js
admin/js/vendor/select2/i18n/de.js /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/js/vendor/select2/i18n/de.js
admin/js/vendor/select2/i18n/mk.js /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/js/vendor/select2/i18n/mk.js
admin/js/vendor/select2/i18n/hy.js /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/js/vendor/select2/i18n/hy.js
admin/js/vendor/select2/i18n/it.js /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/js/vendor/select2/i18n/it.js
admin/js/vendor/select2/i18n/hu.js /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/js/vendor/select2/i18n/hu.js
admin/js/vendor/select2/i18n/ja.js /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/js/vendor/select2/i18n/ja.js
admin/js/vendor/select2/i18n/sk.js /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/js/vendor/select2/i18n/sk.js
admin/js/vendor/select2/i18n/hsb.js /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/js/vendor/select2/i18n/hsb.js
admin/js/vendor/select2/i18n/ro.js /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/js/vendor/select2/i18n/ro.js
admin/js/vendor/select2/i18n/en.js /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/js/vendor/select2/i18n/en.js
admin/js/vendor/select2/i18n/el.js /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/js/vendor/select2/i18n/el.js
admin/js/vendor/select2/i18n/fa.js /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/js/vendor/select2/i18n/fa.js
admin/js/vendor/select2/i18n/pt-BR.js /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/js/vendor/select2/i18n/pt-BR.js
admin/js/vendor/select2/i18n/da.js /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/js/vendor/select2/i18n/da.js
admin/js/vendor/select2/i18n/sr.js /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/js/vendor/select2/i18n/sr.js
admin/js/vendor/select2/i18n/ps.js /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/js/vendor/select2/i18n/ps.js
admin/js/vendor/select2/i18n/lt.js /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/js/vendor/select2/i18n/lt.js
admin/js/vendor/select2/i18n/az.js /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/js/vendor/select2/i18n/az.js
admin/js/vendor/select2/i18n/fr.js /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/js/vendor/select2/i18n/fr.js
admin/js/vendor/select2/i18n/fi.js /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/js/vendor/select2/i18n/fi.js
admin/js/vendor/select2/i18n/tk.js /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/js/vendor/select2/i18n/tk.js
admin/js/vendor/select2/i18n/th.js /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/js/vendor/select2/i18n/th.js
admin/js/vendor/select2/i18n/gl.js /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/js/vendor/select2/i18n/gl.js
admin/js/vendor/select2/i18n/eu.js /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/js/vendor/select2/i18n/eu.js
admin/js/vendor/select2/i18n/es.js /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/js/vendor/select2/i18n/es.js
admin/js/vendor/select2/i18n/km.js /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/js/vendor/select2/i18n/km.js
admin/js/vendor/select2/i18n/bg.js /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/js/vendor/select2/i18n/bg.js
admin/js/vendor/select2/i18n/lv.js /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/js/vendor/select2/i18n/lv.js
admin/js/vendor/select2/i18n/zh-TW.js /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/js/vendor/select2/i18n/zh-TW.js
admin/js/vendor/select2/i18n/pl.js /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/js/vendor/select2/i18n/pl.js
admin/js/vendor/select2/i18n/tr.js /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/js/vendor/select2/i18n/tr.js
admin/js/vendor/select2/i18n/nl.js /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/js/vendor/select2/i18n/nl.js
admin/js/vendor/xregexp/xregexp.min.js /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/js/vendor/xregexp/xregexp.min.js
admin/js/vendor/xregexp/LICENSE.txt /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/js/vendor/xregexp/LICENSE.txt
admin/js/vendor/xregexp/xregexp.js /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/js/vendor/xregexp/xregexp.js
admin/js/vendor/jquery/jquery.min.js /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/js/vendor/jquery/jquery.min.js
admin/js/vendor/jquery/jquery.js /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/js/vendor/jquery/jquery.js
admin/js/vendor/jquery/LICENSE.txt /usr/local/lib/python3.11/site-packages/django/contrib/admin/static/admin/js/vendor/jquery/LICENSE.txt
django_extensions/css/jquery.autocomplete.css /usr/local/lib/python3.11/site-packages/django_extensions/static/django_extensions/css/jquery.autocomplete.css
django_extensions/img/indicator.gif /usr/local/lib/python3.11/site-packages/django_extensions/static/django_extensions/img/indicator.gif
django_extensions/js/jquery.ajaxQueue.js /usr/local/lib/python3.11/site-packages/django_extensions/static/django_extensions/js/jquery.ajaxQueue.js
django_extensions/js/jquery.autocomplete.js /usr/local/lib/python3.11/site-packages/django_extensions/static/django_extensions/js/jquery.autocomplete.js
django_extensions/js/jquery.bgiframe.js /usr/local/lib/python3.11/site-packages/django_extensions/static/django_extensions/js/jquery.bgiframe.js
markdownx/admin/css/markdownx.css /usr/local/lib/python3.11/site-packages/markdownx/static/markdownx/admin/css/markdownx.css
markdownx/admin/css/markdownx.min.css /usr/local/lib/python3.11/site-packages/markdownx/static/markdownx/admin/css/markdownx.min.css
markdownx/js/markdownx.min.js /usr/local/lib/python3.11/site-packages/markdownx/static/markdownx/js/markdownx.min.js
markdownx/js/markdownx.js /usr/local/lib/python3.11/site-packages/markdownx/static/markdownx/js/markdownx.js
django-htmx.js /usr/local/lib/python3.11/site-packages/django_htmx/static/django-htmx.js
admin/rosetta/css/rosetta.css /usr/local/lib/python3.11/site-packages/rosetta/static/admin/rosetta/css/rosetta.css
admin/rosetta/js/rosetta.js /usr/local/lib/python3.11/site-packages/rosetta/static/admin/rosetta/js/rosetta.js
admin/img/icon_searchbox_rosetta.png /usr/local/lib/python3.11/site-packages/rosetta/static/admin/img/icon_searchbox_rosetta.png
notifications/notify.js /usr/local/lib/python3.11/site-packages/notifications/static/notifications/notify.js
debug_toolbar/css/toolbar.css /usr/local/lib/python3.11/site-packages/debug_toolbar/static/debug_toolbar/css/toolbar.css
debug_toolbar/css/print.css /usr/local/lib/python3.11/site-packages/debug_toolbar/static/debug_toolbar/css/print.css
debug_toolbar/js/utils.js /usr/local/lib/python3.11/site-packages/debug_toolbar/static/debug_toolbar/js/utils.js
debug_toolbar/js/toolbar.js /usr/local/lib/python3.11/site-packages/debug_toolbar/static/debug_toolbar/js/toolbar.js
debug_toolbar/js/history.js /usr/local/lib/python3.11/site-packages/debug_toolbar/static/debug_toolbar/js/history.js
debug_toolbar/js/timer.js /usr/local/lib/python3.11/site-packages/debug_toolbar/static/debug_toolbar/js/timer.js
debug_toolbar/js/redirect.js /usr/local/lib/python3.11/site-packages/debug_toolbar/static/debug_toolbar/js/redirect.js

Templates (6 gerendert)

Template-Pfade

  1. /app/project/templates
  2. /usr/local/lib/python3.11/site-packages/django/forms/templates

Templates

step/step_home.html
/app/project/lms_tales/templates/step/step_home.html
Context zeigen {'False': False, 'None': None, 'True': True} {'CI_COMMIT_SHORT_SHA': '484e3ae2', 'CI_COMMIT_TAG': '', 'DEFAULT_MESSAGE_LEVELS': {'DEBUG': 10, 'ERROR': 40, 'INFO': 20, 'SUCCESS': 25, 'WARNING': 30}, 'DEPLOY_ENV': 'staging', 'LANGUAGES': '<<languages>>', 'LANGUAGE_BIDI': False, 'LANGUAGE_CODE': 'de', 'MEDIA_URL': '/media/', 'RELEASE_NAME': '', 'STATIC_URL': '/static/', 'TIME_ZONE': 'Europe/Zurich', 'csrf_token': '<SimpleLazyObject: ' "'ylbgmrk2xvtlUzcyGr7ajBMLhXWgra1CdE7yg1smKqWNTQa8FyIrbutA2fOs1u65'>", 'messages': <FallbackStorage: request=<ASGIRequest: GET '/de/conducting-psychological-research-6/writing-a-scientific-report-21/write-an-abstract-1029'>>, 'perms': PermWrapper(<SimpleLazyObject: <SimpleLazyObject: <django.contrib.auth.models.AnonymousUser object at 0x7910c0d5d890>>>), 'request': '<<request>>', 'user': '<SimpleLazyObject: <SimpleLazyObject: ' '<django.contrib.auth.models.AnonymousUser object at ' '0x7910c0d5d890>>>'} {'active_courseruns': [], 'active_courserunsteps': [], 'active_language_available': True, 'available_languages': [('de', 'Deutsch')], 'course': <TalesCourse: Conducting Psychological Research>, 'course_contact': 'Dr. Jana Jarecki \r\n' 'Fakultät für Psychologie \r\n' 'Universität Basel \r\n' 'Missionsstrasse 62A \r\n' '4055 Basel \r\n' '\r\n' 'Telefon: [+41 (0)61 207 35 31](tel:+41612073531) \r\n' 'Email: ' '[jana.jarecki@unibas.ch](mailto:jana.jarecki@unibas.ch)', 'files': '<<queryset of lms_tales.TalesStepFileNew>>', 'object': <TalesStep: Write an abstract>, 'talesstep': <TalesStep: Write an abstract>, 'view': <lms_tales.views.step_views.StepDetails object at 0x7910c14ec610>}
lms_tales_base.html
/app/project/templates/lms_tales_base.html
Context zeigen {'False': False, 'None': None, 'True': True} {'CI_COMMIT_SHORT_SHA': '484e3ae2', 'CI_COMMIT_TAG': '', 'DEFAULT_MESSAGE_LEVELS': {'DEBUG': 10, 'ERROR': 40, 'INFO': 20, 'SUCCESS': 25, 'WARNING': 30}, 'DEPLOY_ENV': 'staging', 'LANGUAGES': '<<languages>>', 'LANGUAGE_BIDI': False, 'LANGUAGE_CODE': 'de', 'MEDIA_URL': '/media/', 'RELEASE_NAME': '', 'STATIC_URL': '/static/', 'TIME_ZONE': 'Europe/Zurich', 'csrf_token': '<SimpleLazyObject: ' "'ylbgmrk2xvtlUzcyGr7ajBMLhXWgra1CdE7yg1smKqWNTQa8FyIrbutA2fOs1u65'>", 'messages': <FallbackStorage: request=<ASGIRequest: GET '/de/conducting-psychological-research-6/writing-a-scientific-report-21/write-an-abstract-1029'>>, 'perms': PermWrapper(<SimpleLazyObject: <SimpleLazyObject: <django.contrib.auth.models.AnonymousUser object at 0x7910c0d5d890>>>), 'request': '<<request>>', 'user': '<SimpleLazyObject: <SimpleLazyObject: ' '<django.contrib.auth.models.AnonymousUser object at ' '0x7910c0d5d890>>>'} {'active_courseruns': [], 'active_courserunsteps': [], 'active_language_available': True, 'available_languages': [('de', 'Deutsch')], 'course': <TalesCourse: Conducting Psychological Research>, 'course_contact': 'Dr. Jana Jarecki \r\n' 'Fakultät für Psychologie \r\n' 'Universität Basel \r\n' 'Missionsstrasse 62A \r\n' '4055 Basel \r\n' '\r\n' 'Telefon: [+41 (0)61 207 35 31](tel:+41612073531) \r\n' 'Email: ' '[jana.jarecki@unibas.ch](mailto:jana.jarecki@unibas.ch)', 'files': '<<queryset of lms_tales.TalesStepFileNew>>', 'object': <TalesStep: Write an abstract>, 'talesstep': <TalesStep: Write an abstract>, 'view': <lms_tales.views.step_views.StepDetails object at 0x7910c14ec610>}
base.html
/app/project/templates/base.html
Context zeigen {'False': False, 'None': None, 'True': True} {'CI_COMMIT_SHORT_SHA': '484e3ae2', 'CI_COMMIT_TAG': '', 'DEFAULT_MESSAGE_LEVELS': {'DEBUG': 10, 'ERROR': 40, 'INFO': 20, 'SUCCESS': 25, 'WARNING': 30}, 'DEPLOY_ENV': 'staging', 'LANGUAGES': '<<languages>>', 'LANGUAGE_BIDI': False, 'LANGUAGE_CODE': 'de', 'MEDIA_URL': '/media/', 'RELEASE_NAME': '', 'STATIC_URL': '/static/', 'TIME_ZONE': 'Europe/Zurich', 'csrf_token': '<SimpleLazyObject: ' "'ylbgmrk2xvtlUzcyGr7ajBMLhXWgra1CdE7yg1smKqWNTQa8FyIrbutA2fOs1u65'>", 'messages': <FallbackStorage: request=<ASGIRequest: GET '/de/conducting-psychological-research-6/writing-a-scientific-report-21/write-an-abstract-1029'>>, 'perms': PermWrapper(<SimpleLazyObject: <SimpleLazyObject: <django.contrib.auth.models.AnonymousUser object at 0x7910c0d5d890>>>), 'request': '<<request>>', 'user': '<SimpleLazyObject: <SimpleLazyObject: ' '<django.contrib.auth.models.AnonymousUser object at ' '0x7910c0d5d890>>>'} {'active_courseruns': [], 'active_courserunsteps': [], 'active_language_available': True, 'available_languages': [('de', 'Deutsch')], 'course': <TalesCourse: Conducting Psychological Research>, 'course_contact': 'Dr. Jana Jarecki \r\n' 'Fakultät für Psychologie \r\n' 'Universität Basel \r\n' 'Missionsstrasse 62A \r\n' '4055 Basel \r\n' '\r\n' 'Telefon: [+41 (0)61 207 35 31](tel:+41612073531) \r\n' 'Email: ' '[jana.jarecki@unibas.ch](mailto:jana.jarecki@unibas.ch)', 'files': '<<queryset of lms_tales.TalesStepFileNew>>', 'object': <TalesStep: Write an abstract>, 'talesstep': <TalesStep: Write an abstract>, 'view': <lms_tales.views.step_views.StepDetails object at 0x7910c14ec610>}
components/header.html
/app/project/templates/components/header.html
Context zeigen {'False': False, 'None': None, 'True': True} {'CI_COMMIT_SHORT_SHA': '484e3ae2', 'CI_COMMIT_TAG': '', 'DEFAULT_MESSAGE_LEVELS': {'DEBUG': 10, 'ERROR': 40, 'INFO': 20, 'SUCCESS': 25, 'WARNING': 30}, 'DEPLOY_ENV': 'staging', 'LANGUAGES': '<<languages>>', 'LANGUAGE_BIDI': False, 'LANGUAGE_CODE': 'de', 'MEDIA_URL': '/media/', 'RELEASE_NAME': '', 'STATIC_URL': '/static/', 'TIME_ZONE': 'Europe/Zurich', 'csrf_token': '<SimpleLazyObject: ' "'ylbgmrk2xvtlUzcyGr7ajBMLhXWgra1CdE7yg1smKqWNTQa8FyIrbutA2fOs1u65'>", 'messages': <FallbackStorage: request=<ASGIRequest: GET '/de/conducting-psychological-research-6/writing-a-scientific-report-21/write-an-abstract-1029'>>, 'perms': PermWrapper(<SimpleLazyObject: <SimpleLazyObject: <django.contrib.auth.models.AnonymousUser object at 0x7910c0d5d890>>>), 'request': '<<request>>', 'user': '<SimpleLazyObject: <SimpleLazyObject: ' '<django.contrib.auth.models.AnonymousUser object at ' '0x7910c0d5d890>>>'} {'active_courseruns': [], 'active_courserunsteps': [], 'active_language_available': True, 'available_languages': [('de', 'Deutsch')], 'course': <TalesCourse: Conducting Psychological Research>, 'course_contact': 'Dr. Jana Jarecki \r\n' 'Fakultät für Psychologie \r\n' 'Universität Basel \r\n' 'Missionsstrasse 62A \r\n' '4055 Basel \r\n' '\r\n' 'Telefon: [+41 (0)61 207 35 31](tel:+41612073531) \r\n' 'Email: ' '[jana.jarecki@unibas.ch](mailto:jana.jarecki@unibas.ch)', 'files': '<<queryset of lms_tales.TalesStepFileNew>>', 'object': <TalesStep: Write an abstract>, 'talesstep': <TalesStep: Write an abstract>, 'view': <lms_tales.views.step_views.StepDetails object at 0x7910c14ec610>} {'block': <Block Node: header. Contents: [<TextNode: '\n '>, <IncludeNode: template=<FilterExpression '"components/header.html"'>>, <TextNode: '\n '>]>}
components/sidebar-navigation.html
/app/project/templates/components/sidebar-navigation.html
Context zeigen {'False': False, 'None': None, 'True': True} {'CI_COMMIT_SHORT_SHA': '484e3ae2', 'CI_COMMIT_TAG': '', 'DEFAULT_MESSAGE_LEVELS': {'DEBUG': 10, 'ERROR': 40, 'INFO': 20, 'SUCCESS': 25, 'WARNING': 30}, 'DEPLOY_ENV': 'staging', 'LANGUAGES': '<<languages>>', 'LANGUAGE_BIDI': False, 'LANGUAGE_CODE': 'de', 'MEDIA_URL': '/media/', 'RELEASE_NAME': '', 'STATIC_URL': '/static/', 'TIME_ZONE': 'Europe/Zurich', 'csrf_token': '<SimpleLazyObject: ' "'ylbgmrk2xvtlUzcyGr7ajBMLhXWgra1CdE7yg1smKqWNTQa8FyIrbutA2fOs1u65'>", 'messages': <FallbackStorage: request=<ASGIRequest: GET '/de/conducting-psychological-research-6/writing-a-scientific-report-21/write-an-abstract-1029'>>, 'perms': PermWrapper(<SimpleLazyObject: <SimpleLazyObject: <django.contrib.auth.models.AnonymousUser object at 0x7910c0d5d890>>>), 'request': '<<request>>', 'user': '<SimpleLazyObject: <SimpleLazyObject: ' '<django.contrib.auth.models.AnonymousUser object at ' '0x7910c0d5d890>>>'} {'active_courseruns': [], 'active_courserunsteps': [], 'active_language_available': True, 'available_languages': [('de', 'Deutsch')], 'course': <TalesCourse: Conducting Psychological Research>, 'course_contact': 'Dr. Jana Jarecki \r\n' 'Fakultät für Psychologie \r\n' 'Universität Basel \r\n' 'Missionsstrasse 62A \r\n' '4055 Basel \r\n' '\r\n' 'Telefon: [+41 (0)61 207 35 31](tel:+41612073531) \r\n' 'Email: ' '[jana.jarecki@unibas.ch](mailto:jana.jarecki@unibas.ch)', 'files': '<<queryset of lms_tales.TalesStepFileNew>>', 'object': <TalesStep: Write an abstract>, 'talesstep': <TalesStep: Write an abstract>, 'view': <lms_tales.views.step_views.StepDetails object at 0x7910c14ec610>} {'block': <Block Node: sidebar-nav. Contents: [<TextNode: '\n <nav id="sid'>, <django.template.library.SimpleNode object at 0x7910c17872d0>, <TextNode: '>\n '>, <django.templatetags.i18n.TranslateNode object at 0x7910c1787390>, <TextNode: '</span>\n '>, <IfNode>, <TextNode: '\n '>, <django.template.library.SimpleNode object at 0x7910c17ac510>, <TextNode: '>\n '>, <django.templatetags.i18n.TranslateNode object at 0x7910c17d7850>, <TextNode: '</span>\n '>, <Block Node: navigation. Contents: [<TextNode: '\n '>]>, <TextNode: '\n </div>\n '>]>} {'block': <Block Node: navigation. Contents: [<TextNode: '\n '>, <IncludeNode: template=<FilterExpression '"components/sidebar-navigation.html"'>>, <TextNode: '\n'>]>}
step/step-title.html
/app/project/lms_tales/templates/step/step-title.html
Context zeigen {'False': False, 'None': None, 'True': True} {'CI_COMMIT_SHORT_SHA': '484e3ae2', 'CI_COMMIT_TAG': '', 'DEFAULT_MESSAGE_LEVELS': {'DEBUG': 10, 'ERROR': 40, 'INFO': 20, 'SUCCESS': 25, 'WARNING': 30}, 'DEPLOY_ENV': 'staging', 'LANGUAGES': '<<languages>>', 'LANGUAGE_BIDI': False, 'LANGUAGE_CODE': 'de', 'MEDIA_URL': '/media/', 'RELEASE_NAME': '', 'STATIC_URL': '/static/', 'TIME_ZONE': 'Europe/Zurich', 'csrf_token': '<SimpleLazyObject: ' "'ylbgmrk2xvtlUzcyGr7ajBMLhXWgra1CdE7yg1smKqWNTQa8FyIrbutA2fOs1u65'>", 'messages': <FallbackStorage: request=<ASGIRequest: GET '/de/conducting-psychological-research-6/writing-a-scientific-report-21/write-an-abstract-1029'>>, 'perms': PermWrapper(<SimpleLazyObject: <SimpleLazyObject: <django.contrib.auth.models.AnonymousUser object at 0x7910c0d5d890>>>), 'request': '<<request>>', 'user': '<SimpleLazyObject: <SimpleLazyObject: ' '<django.contrib.auth.models.AnonymousUser object at ' '0x7910c0d5d890>>>'} {'active_courseruns': [], 'active_courserunsteps': [], 'active_language_available': True, 'available_languages': [('de', 'Deutsch')], 'course': <TalesCourse: Conducting Psychological Research>, 'course_contact': 'Dr. Jana Jarecki \r\n' 'Fakultät für Psychologie \r\n' 'Universität Basel \r\n' 'Missionsstrasse 62A \r\n' '4055 Basel \r\n' '\r\n' 'Telefon: [+41 (0)61 207 35 31](tel:+41612073531) \r\n' 'Email: ' '[jana.jarecki@unibas.ch](mailto:jana.jarecki@unibas.ch)', 'files': '<<queryset of lms_tales.TalesStepFileNew>>', 'object': <TalesStep: Write an abstract>, 'talesstep': <TalesStep: Write an abstract>, 'view': <lms_tales.views.step_views.StepDetails object at 0x7910c14ec610>} {'block': <Block Node: breadcrumb-bar. Contents: [<TextNode: '\n <div id="tit'>, <Block Node: sidebar-arrow. Contents: [<TextNode: '\n <div'>, <django.template.library.SimpleNode object at 0x7910c17d7810>, <TextNode: '\n '>, <django.templatetags.i18n.TranslateNode object at 0x7910c17866d0>, <TextNode: '</span>\n '>]>, <TextNode: '\n <div cla'>, <Block Node: breadcrumb. Contents: [<TextNode: '\n '>]>, <TextNode: '\n '>]>} {'block': <Block Node: breadcrumb. Contents: [<TextNode: '\n '>, <IncludeNode: template=<FilterExpression '"step/step-title.html"'>>, <TextNode: '\n'>]>}

Context-Prozessoren

django.template.context_processors.csrf
Context zeigen {'csrf_token': <SimpleLazyObject: 'ylbgmrk2xvtlUzcyGr7ajBMLhXWgra1CdE7yg1smKqWNTQa8FyIrbutA2fOs1u65'>}
django.template.context_processors.debug
Context zeigen {}
django.template.context_processors.request
Context zeigen {'request': <ASGIRequest: GET '/de/conducting-psychological-research-6/writing-a-scientific-report-21/write-an-abstract-1029'>}
django.contrib.auth.context_processors.auth
Context zeigen {'user': <SimpleLazyObject: <SimpleLazyObject: <django.contrib.auth.models.AnonymousUser object at 0x7910c0d5d890>>>, 'perms': PermWrapper(<SimpleLazyObject: <SimpleLazyObject: <django.contrib.auth.models.AnonymousUser object at 0x7910c0d5d890>>>)}
django.template.context_processors.i18n
Context zeigen {'LANGUAGES': (('de', 'Deutsch'), ('en', 'Englisch'), ('fr', 'Franzoesisch')), 'LANGUAGE_CODE': 'de', 'LANGUAGE_BIDI': False}
django.template.context_processors.media
Context zeigen {'MEDIA_URL': '/media/'}
django.template.context_processors.static
Context zeigen {'STATIC_URL': '/static/'}
django.template.context_processors.tz
Context zeigen {'TIME_ZONE': 'Europe/Zurich'}
django.contrib.messages.context_processors.messages
Context zeigen {'messages': <FallbackStorage: request=<ASGIRequest: GET '/de/conducting-psychological-research-6/writing-a-scientific-report-21/write-an-abstract-1029'>>, 'DEFAULT_MESSAGE_LEVELS': {'DEBUG': 10, 'INFO': 20, 'SUCCESS': 25, 'WARNING': 30, 'ERROR': 40}}
utils.context_processors.ci_info
Context zeigen {'CI_COMMIT_TAG': '', 'CI_COMMIT_SHORT_SHA': '484e3ae2', 'RELEASE_NAME': '', 'DEPLOY_ENV': 'staging'}

Cache-Aufrufe von 1 Backend

Zusammenfassung

Aufrufe gesamt Zeit gesamt Cache erfolgreich Cache verfehlt
62 25,130802765488625 ms 169 3

Befehle

add get set get_or_set touch delete clear get_many set_many delete_many has_key incr decr incr_version decr_version
3 4 1 0 0 0 0 36 18 0 0 0 0 0 0

Aufrufe

Zeit (ms) Typ Argumente Schlüsselwort-Argumente Backend
0,8921 get_many (dict_keys(['b5ac959681ff06eff632d25a5961a4d3cad09b42', '542c27005f4e84288827ce70a7d49bc73324a5e7', '887f8247d0ff979264c73b069f790024b2aa98e1', 'a2cec6efb2cb51d9fcdc73ec65d0d02848d3205f', 'af167bf678e72a9b2a64d8869d420b8d25e96148', 'f2b266a5acd7f191551fca80dea8475d456a300c', 'e5890f0f95e54c95fc7d85ffd3cd8f5079a384eb', '7d22fa9ec7aaf50b239b17bb4529f27be72f4b3d', 'fab86eaeb6f68c1bd14e3c42d6a32fc63fe5c10b', '1671d58e08fb6227d160e4add3baac34f778006f', '5634047d837b3106d3997f0611a298a16f6754cb', '38c0c9db04f183fb89086db2a3a02d20d5c1cbda', '33cd0b10f8c2fd53802b0948820b8b58da6bb27c', 'dbdc4e6f3de4931fbb7e39044291d87c49a581a7', 'bf555e2c224baeeac5838ee69c053900ce037b1d', '452aaa2adbf5d826d715538ebfd87013a599bacd', '5ef73f3d610667d7836abd847979ad8d02582140', '28b4f1c78186b497fc0611b76d5609a36a170804', 'acd1c2a120952e0445e89d8a2cc8faa99cc73454', '3fdb5b63faddfa01f5ebd09a89b74c9b3ec742bf', 'bc41695a90f568da6f9c44d14dbb30130bea76db', '6d6bdc7046f6d1410bd41d09cd570831af97fd31', '2288e6f142e998339c6d4985913358f76533a29e', 'f6e1a4d48790db63f8cb8c5653192a74ca00d34a', 'e19dd8b0e8a705c5914b55bbeb94d01f20e5368e', 'bf2a5aa392ac965fc14b9cc5fc8fcce588b2cf57', '9de26d60cec57eaab1ec19a62cf772073ae0e30f', '138549f5508bbba7283d6a0625e51c589d845e8f', '4f1f0b4dfbd30463b5587753e6f3e6ca21ddbf60', 'd890e5bc0b77c02793036efa76f50a25770a52a7', 'd00779073776b2287204a6fa5336494275fc73d5', '76e323efd8711853e13c9f7cf976845908364eb2', 'e3a5db5a670ad803efb866441f33de58309be2e2', '312c357d2eed306581bb334378808fbccf7019ea', 'd144abeb0db81d5dfea390a27c6d616aa1783141', 'b33158a576dd24b41063563867ce3f9044eb1acf', 'a78875b90f65061214a7b7eaa1a66176310060a1', 'd1accdb7a5e2af4fd7d0fc7e34b048f555cd65a0', '0b7593abe25ebbf222c98d71b199a17877e17478', 'da8bff0e0d25742e869a69b7508c37ccde5f8f33', '0098dff618e4e4ce8b226fb3dcd5d9042e69eb75', '8e3f73e6feaebee5ffbc4479f566917f08b4bbca', '5c50c6b3292213266ec6601a46b9ff857efec10a', '9ba11033f2e0b0478fa7ea0cfcde90c7ea880b1b', '810de96c2cc412e55eb18a19206c9b4f4879ec68', 'da75293c9ac4e9ae833da9fecd1ab668d629ce49', 'e4392949c2513e35c4d436a230e913efc13e4556', '9a3409722cd89bb29bc78c6bd4bca2cc2aad3e96', '5bd1ef7c64b457cbb725c42d97969db3ebe85f66', 'f3d241856fbbba355385868203e06010b65b882e', '1511f7c2f0ac6c43b58dfa27858c3d8561280f80', 'e2a6b84fc2a64f0ca59dd6e95fe6e1a5f3850ad5', 'b72f66480a030f14a954ea7eeb482d64fa1da084', '9e3a2b98ae55fa975425fa81a4e6e13342147b8a', '0e90ed3afbea5b3254d013a2b352642aaa2ce984', '2b2eb1f58e7ba0ac1ae04f9e9c95bde41f64e3fc', 'f38ac9d1db097d95b5062273e0a941d2da616361', 'cf84cec99a10af4507238b31bfce2171063a0c1d', 'c9b253ceb06244b30c24377ae68ae44353b4b3c4', '946a725506b18b4afe14d273540101238984908d', 'd34b8ed7c3bb0d3a712a5e42065744014bfe1542']),) {} <django_redis.cache.RedisCache object at 0x7910e287a790>
/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in run(101)
  return _run_old_run_func()

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in _run_old_run_func(94)
  return old_run_func(self, *a, **kw)

/usr/local/lib/python3.11/concurrent/futures/thread.py in _worker(83)
  work_item.run()

/usr/local/lib/python3.11/concurrent/futures/thread.py in run(58)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/corsheaders/middleware.py in __call__(56)
  result = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in middleware(32)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/allauth/account/middleware.py in middleware(36)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/simple_history/middleware.py in middleware(41)
  return get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/django_htmx/middleware.py in __call__(43)
  return self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in __call__(168)
  response = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/panels.py in process_request(40)
  self.collect_invalidations()

/usr/local/lib/python3.11/site-packages/cachalot/panels.py in collect_invalidations(52)
  for cache_key, timestamp in cache.get_many(

0,3838 get_many (['138549f5508bbba7283d6a0625e51c589d845e8f', '32866a6a96f6685b1ec0f5a6bbb379273be1bcae'],) {} <django_redis.cache.RedisCache object at 0x7910e287a790>
/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in run(101)
  return _run_old_run_func()

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in _run_old_run_func(94)
  return old_run_func(self, *a, **kw)

/usr/local/lib/python3.11/concurrent/futures/thread.py in _worker(83)
  work_item.run()

/usr/local/lib/python3.11/concurrent/futures/thread.py in run(58)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/corsheaders/middleware.py in __call__(56)
  result = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in middleware(32)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/allauth/account/middleware.py in middleware(36)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/simple_history/middleware.py in middleware(41)
  return get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/django_htmx/middleware.py in __call__(43)
  return self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in __call__(168)
  response = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/panels.py in process_request(41)
  return super(CachalotPanel, self).process_request(request)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in __call__(244)
  current_executor.run_until_future(call_result)

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run_until_future(81)
  work_item.run()

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run(40)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_wrapped_callback(90)
  return callback(request, *args, **kwargs)

/app/project/utils/decorators.py in apply_cache(64)
  response = function(request, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/django/views/generic/base.py in view(104)
  return self.dispatch(request, *args, **kwargs)

/app/project/lms_tales/views/mixins.py in dispatch(20)
  self.object = self.get_object()

/usr/local/lib/python3.11/site-packages/django/views/generic/detail.py in get_object(53)
  obj = queryset.get()

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(37)
  return original(compiler, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(96)
  return _get_result_or_execute_query(

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in _get_result_or_execute_query(46)
  data = cache.get_many(table_cache_keys + [cache_key])

0,4227 set_many ({'32866a6a96f6685b1ec0f5a6bbb379273be1bcae': (1736871783.0740576, [[(1029, datetime.datetime(2021, 11, 30, 8, 24, 22, 398141, tzinfo=datetime.timezone.utc), datetime.datetime(2021, 11, 30, 8, 24, 54, 831438, tzinfo=datetime.timezone.utc), datetime.datetime(2021, 11, 30, 8, 24, 54, 808989, tzinfo=datetime.timezone.utc), False, 'Write an abstract', 'Write an abstract', None, None, '', None, None, None, '', None, None, None, '', 'write-an-abstract', 'The abstract is one paragraph that summarizes the research question, hypothesis, design, methods, and results in an easy to read way. This chapter briefly outlines the basics of good abstracts.\r\n{.lead}\r\n\r\n**Short summary of everything** \r\nThe abstract is a written summary of a research. It is around 150 to maximally 250 words of length. When you write an abstract, take your time to be informative but brief and concise at the same time, rather than writing a long and verbose text. Also, write your abstract for readers from other fields or who have never heard of your specific methods or research topic. The audience of an abstract is a psychologist who is not necessarily working in your field and does not know your area of expertise.\r\n \r\n**How is the abstract structured?** \r\nThe text of the abstract of an empirical paper has a standard structure. It starts with one to two sentence that clearly state the problem or research question and goals of your research (for instance, *“This paper investigates the role of … in ...”*). The next one to two sentences must explicitly state all the tested hypotheses, even if exploratory (for instance, *“We hypothesized, based on prospect theory, that highly loss-averse individuals should … compared to people that are less loss-averse ...”*). Next, briefly write about the experimental design and methods that were used, including the sample size (for instance, *”To investigate this question, we conducted one online experiment (N = 89), which asked participants to … followed by … and ...”*), this usually takes one or two sentences. Afterwards, the next one or two sentences describe the main results, usually in plain text using words rather than in numbers (for instance, *”The results from a ANOVA show that … increases ….”*). This is followed by a very brief sentence that relates the result back to the hypotheses (for instance, *”These findings fail to support prospect theory”*). This is followed by the last sentence of the abstract which always is a conclusion from the empirical findings that mentions implications (for instance *”Taken together, our work shows that prospect theory is not ...”*). Implications are what the research findings mean for the practice or theory or future research.\r\n\r\n**How is the abstract formatted?** \r\nFollowing the APA format, the abstract has a section heading called **Abstract** in bold and centered. The abstract text is always formatted as one single paragraph, which means abstract texts contain no line breaks and no paragraph breaks. The line spacing is double-spaced (as usual in APA). Abstracts appear on the first page after the title page of psychological papers, and the abstract starts at the top of the page.', 'The abstract is one paragraph that summarizes the research question, hypothesis, design, methods, and results in an easy to read way. This chapter briefly outlines the basics of good abstracts.\r\n{.lead}\r\n\r\n**Short summary of everything** \r\nThe abstract is a written summary of a research. It is around 150 to maximally 250 words of length. When you write an abstract, take your time to be informative but brief and concise at the same time, rather than writing a long and verbose text. Also, write your abstract for readers from other fields or who have never heard of your specific methods or research topic. The audience of an abstract is a psychologist who is not necessarily working in your field and does not know your area of expertise.\r\n \r\n**How is the abstract structured?** \r\nThe text of the abstract of an empirical paper has a standard structure. It starts with one to two sentence that clearly state the problem or research question and goals of your research (for instance, *“This paper investigates the role of … in ...”*). The next one to two sentences must explicitly state all the tested hypotheses, even if exploratory (for instance, *“We hypothesized, based on prospect theory, that highly loss-averse individuals should … compared to people that are less loss-averse ...”*). Next, briefly write about the experimental design and methods that were used, including the sample size (for instance, *”To investigate this question, we conducted one online experiment (N = 89), which asked participants to … followed by … and ...”*), this usually takes one or two sentences. Afterwards, the next one or two sentences describe the main results, usually in plain text using words rather than in numbers (for instance, *”The results from a ANOVA show that … increases ….”*). This is followed by a very brief sentence that relates the result back to the hypotheses (for instance, *”These findings fail to support prospect theory”*). This is followed by the last sentence of the abstract which always is a conclusion from the empirical findings that mentions implications (for instance *”Taken together, our work shows that prospect theory is not ...”*). Implications are what the research findings mean for the practice or theory or future research.\r\n\r\n**How is the abstract formatted?** \r\nFollowing the APA format, the abstract has a section heading called **Abstract** in bold and centered. The abstract text is always formatted as one single paragraph, which means abstract texts contain no line breaks and no paragraph breaks. The line spacing is double-spaced (as usual in APA). Abstracts appear on the first page after the title page of psychological papers, and the abstract starts at the top of the page.', '', '', '', '', '', '', None, None, None, None, '', '', '', '', 'TT', '10 min', 5, 'published', False, None, None, None, None, 21)]])}, None) {} <django_redis.cache.RedisCache object at 0x7910e287a790>
/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in run(101)
  return _run_old_run_func()

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in _run_old_run_func(94)
  return old_run_func(self, *a, **kw)

/usr/local/lib/python3.11/concurrent/futures/thread.py in _worker(83)
  work_item.run()

/usr/local/lib/python3.11/concurrent/futures/thread.py in run(58)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/corsheaders/middleware.py in __call__(56)
  result = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in middleware(32)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/allauth/account/middleware.py in middleware(36)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/simple_history/middleware.py in middleware(41)
  return get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/django_htmx/middleware.py in __call__(43)
  return self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in __call__(168)
  response = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/panels.py in process_request(41)
  return super(CachalotPanel, self).process_request(request)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in __call__(244)
  current_executor.run_until_future(call_result)

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run_until_future(81)
  work_item.run()

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run(40)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_wrapped_callback(90)
  return callback(request, *args, **kwargs)

/app/project/utils/decorators.py in apply_cache(64)
  response = function(request, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/django/views/generic/base.py in view(104)
  return self.dispatch(request, *args, **kwargs)

/app/project/lms_tales/views/mixins.py in dispatch(20)
  self.object = self.get_object()

/usr/local/lib/python3.11/site-packages/django/views/generic/detail.py in get_object(53)
  obj = queryset.get()

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(37)
  return original(compiler, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(96)
  return _get_result_or_execute_query(

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in _get_result_or_execute_query(71)
  cache.set_many(to_be_set, cachalot_settings.CACHALOT_TIMEOUT)

0,3785 get_many (['138549f5508bbba7283d6a0625e51c589d845e8f', '32866a6a96f6685b1ec0f5a6bbb379273be1bcae'],) {} <django_redis.cache.RedisCache object at 0x7910e287a790>
/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in run(101)
  return _run_old_run_func()

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in _run_old_run_func(94)
  return old_run_func(self, *a, **kw)

/usr/local/lib/python3.11/concurrent/futures/thread.py in _worker(83)
  work_item.run()

/usr/local/lib/python3.11/concurrent/futures/thread.py in run(58)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/corsheaders/middleware.py in __call__(56)
  result = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in middleware(32)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/allauth/account/middleware.py in middleware(36)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/simple_history/middleware.py in middleware(41)
  return get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/django_htmx/middleware.py in __call__(43)
  return self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in __call__(168)
  response = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/panels.py in process_request(41)
  return super(CachalotPanel, self).process_request(request)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in __call__(244)
  current_executor.run_until_future(call_result)

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run_until_future(81)
  work_item.run()

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run(40)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_wrapped_callback(90)
  return callback(request, *args, **kwargs)

/app/project/utils/decorators.py in apply_cache(64)
  response = function(request, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/django/views/generic/base.py in view(104)
  return self.dispatch(request, *args, **kwargs)

/app/project/lms_tales/views/mixins.py in dispatch(31)
  return super().dispatch(request, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/django/views/generic/base.py in dispatch(143)
  return handler(request, *args, **kwargs)

/app/project/lms_tales/views/step_views.py in get(36)
  response = super().get(request, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/django/views/generic/detail.py in get(108)
  self.object = self.get_object()

/usr/local/lib/python3.11/site-packages/django/views/generic/detail.py in get_object(53)
  obj = queryset.get()

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(37)
  return original(compiler, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(96)
  return _get_result_or_execute_query(

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in _get_result_or_execute_query(46)
  data = cache.get_many(table_cache_keys + [cache_key])

0,3414 get_many (['138549f5508bbba7283d6a0625e51c589d845e8f', '4f1f0b4dfbd30463b5587753e6f3e6ca21ddbf60', 'a58a98a6b53a24e8798db0af57f84c170678422b'],) {} <django_redis.cache.RedisCache object at 0x7910e287a790>
/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in run(101)
  return _run_old_run_func()

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in _run_old_run_func(94)
  return old_run_func(self, *a, **kw)

/usr/local/lib/python3.11/concurrent/futures/thread.py in _worker(83)
  work_item.run()

/usr/local/lib/python3.11/concurrent/futures/thread.py in run(58)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/corsheaders/middleware.py in __call__(56)
  result = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in middleware(32)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/allauth/account/middleware.py in middleware(36)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/simple_history/middleware.py in middleware(41)
  return get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/django_htmx/middleware.py in __call__(43)
  return self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in __call__(168)
  response = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/panels.py in process_request(41)
  return super(CachalotPanel, self).process_request(request)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in __call__(244)
  current_executor.run_until_future(call_result)

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run_until_future(81)
  work_item.run()

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run(40)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_wrapped_callback(90)
  return callback(request, *args, **kwargs)

/app/project/utils/decorators.py in apply_cache(64)
  response = function(request, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/django/views/generic/base.py in view(104)
  return self.dispatch(request, *args, **kwargs)

/app/project/lms_tales/views/mixins.py in dispatch(31)
  return super().dispatch(request, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/django/views/generic/base.py in dispatch(143)
  return handler(request, *args, **kwargs)

/app/project/lms_tales/views/step_views.py in get(36)
  response = super().get(request, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/django/views/generic/detail.py in get(109)
  context = self.get_context_data(object=self.object)

/app/project/lms_tales/views/step_views.py in get_context_data(63)
  if len(step_files_new) == 0:

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(37)
  return original(compiler, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(96)
  return _get_result_or_execute_query(

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in _get_result_or_execute_query(46)
  data = cache.get_many(table_cache_keys + [cache_key])

0,3386 set_many ({'a58a98a6b53a24e8798db0af57f84c170678422b': (1736871783.0817764, [])}, None) {} <django_redis.cache.RedisCache object at 0x7910e287a790>
/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in run(101)
  return _run_old_run_func()

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in _run_old_run_func(94)
  return old_run_func(self, *a, **kw)

/usr/local/lib/python3.11/concurrent/futures/thread.py in _worker(83)
  work_item.run()

/usr/local/lib/python3.11/concurrent/futures/thread.py in run(58)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/corsheaders/middleware.py in __call__(56)
  result = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in middleware(32)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/allauth/account/middleware.py in middleware(36)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/simple_history/middleware.py in middleware(41)
  return get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/django_htmx/middleware.py in __call__(43)
  return self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in __call__(168)
  response = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/panels.py in process_request(41)
  return super(CachalotPanel, self).process_request(request)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in __call__(244)
  current_executor.run_until_future(call_result)

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run_until_future(81)
  work_item.run()

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run(40)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_wrapped_callback(90)
  return callback(request, *args, **kwargs)

/app/project/utils/decorators.py in apply_cache(64)
  response = function(request, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/django/views/generic/base.py in view(104)
  return self.dispatch(request, *args, **kwargs)

/app/project/lms_tales/views/mixins.py in dispatch(31)
  return super().dispatch(request, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/django/views/generic/base.py in dispatch(143)
  return handler(request, *args, **kwargs)

/app/project/lms_tales/views/step_views.py in get(36)
  response = super().get(request, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/django/views/generic/detail.py in get(109)
  context = self.get_context_data(object=self.object)

/app/project/lms_tales/views/step_views.py in get_context_data(63)
  if len(step_files_new) == 0:

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(37)
  return original(compiler, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(96)
  return _get_result_or_execute_query(

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in _get_result_or_execute_query(71)
  cache.set_many(to_be_set, cachalot_settings.CACHALOT_TIMEOUT)

0,3396 get_many (['138549f5508bbba7283d6a0625e51c589d845e8f', '4f1f0b4dfbd30463b5587753e6f3e6ca21ddbf60', 'a58a98a6b53a24e8798db0af57f84c170678422b'],) {} <django_redis.cache.RedisCache object at 0x7910e287a790>
/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in run(101)
  return _run_old_run_func()

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in _run_old_run_func(94)
  return old_run_func(self, *a, **kw)

/usr/local/lib/python3.11/concurrent/futures/thread.py in _worker(83)
  work_item.run()

/usr/local/lib/python3.11/concurrent/futures/thread.py in run(58)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/corsheaders/middleware.py in __call__(56)
  result = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in middleware(32)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/allauth/account/middleware.py in middleware(36)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/simple_history/middleware.py in middleware(41)
  return get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/django_htmx/middleware.py in __call__(43)
  return self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in __call__(168)
  response = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/panels.py in process_request(41)
  return super(CachalotPanel, self).process_request(request)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in __call__(244)
  current_executor.run_until_future(call_result)

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run_until_future(81)
  work_item.run()

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run(40)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_wrapped_callback(90)
  return callback(request, *args, **kwargs)

/app/project/utils/decorators.py in apply_cache(64)
  response = function(request, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/django/views/generic/base.py in view(104)
  return self.dispatch(request, *args, **kwargs)

/app/project/lms_tales/views/mixins.py in dispatch(31)
  return super().dispatch(request, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/django/views/generic/base.py in dispatch(143)
  return handler(request, *args, **kwargs)

/app/project/lms_tales/views/step_views.py in get(36)
  response = super().get(request, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/django/views/generic/detail.py in get(109)
  context = self.get_context_data(object=self.object)

/app/project/lms_tales/views/step_views.py in get_context_data(69)
  if len(step_files_new) > 0:

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(37)
  return original(compiler, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(96)
  return _get_result_or_execute_query(

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in _get_result_or_execute_query(46)
  data = cache.get_many(table_cache_keys + [cache_key])

0,3967 get_many (['138549f5508bbba7283d6a0625e51c589d845e8f', '4f1f0b4dfbd30463b5587753e6f3e6ca21ddbf60', '456c627f2712f38f5eebddb56f0f1877f996b1b3'],) {} <django_redis.cache.RedisCache object at 0x7910e287a790>
/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in run(101)
  return _run_old_run_func()

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in _run_old_run_func(94)
  return old_run_func(self, *a, **kw)

/usr/local/lib/python3.11/concurrent/futures/thread.py in _worker(83)
  work_item.run()

/usr/local/lib/python3.11/concurrent/futures/thread.py in run(58)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/corsheaders/middleware.py in __call__(56)
  result = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in middleware(32)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/allauth/account/middleware.py in middleware(36)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/simple_history/middleware.py in middleware(41)
  return get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/django_htmx/middleware.py in __call__(43)
  return self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in __call__(168)
  response = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/panels.py in process_request(41)
  return super(CachalotPanel, self).process_request(request)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in __call__(244)
  current_executor.run_until_future(call_result)

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run_until_future(81)
  work_item.run()

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run(40)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_wrapped_callback(90)
  return callback(request, *args, **kwargs)

/app/project/utils/decorators.py in apply_cache(64)
  response = function(request, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/django/views/generic/base.py in view(104)
  return self.dispatch(request, *args, **kwargs)

/app/project/lms_tales/views/mixins.py in dispatch(31)
  return super().dispatch(request, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/django/views/generic/base.py in dispatch(143)
  return handler(request, *args, **kwargs)

/app/project/lms_tales/views/step_views.py in get(36)
  response = super().get(request, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/django/views/generic/detail.py in get(109)
  context = self.get_context_data(object=self.object)

/app/project/lms_tales/views/step_views.py in get_context_data(69)
  if len(step_files_new) > 0:

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(37)
  return original(compiler, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(96)
  return _get_result_or_execute_query(

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in _get_result_or_execute_query(46)
  data = cache.get_many(table_cache_keys + [cache_key])

0,3284 set_many ({'456c627f2712f38f5eebddb56f0f1877f996b1b3': (1736871783.0877671, [])}, None) {} <django_redis.cache.RedisCache object at 0x7910e287a790>
/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in run(101)
  return _run_old_run_func()

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in _run_old_run_func(94)
  return old_run_func(self, *a, **kw)

/usr/local/lib/python3.11/concurrent/futures/thread.py in _worker(83)
  work_item.run()

/usr/local/lib/python3.11/concurrent/futures/thread.py in run(58)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/corsheaders/middleware.py in __call__(56)
  result = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in middleware(32)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/allauth/account/middleware.py in middleware(36)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/simple_history/middleware.py in middleware(41)
  return get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/django_htmx/middleware.py in __call__(43)
  return self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in __call__(168)
  response = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/panels.py in process_request(41)
  return super(CachalotPanel, self).process_request(request)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in __call__(244)
  current_executor.run_until_future(call_result)

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run_until_future(81)
  work_item.run()

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run(40)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_wrapped_callback(90)
  return callback(request, *args, **kwargs)

/app/project/utils/decorators.py in apply_cache(64)
  response = function(request, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/django/views/generic/base.py in view(104)
  return self.dispatch(request, *args, **kwargs)

/app/project/lms_tales/views/mixins.py in dispatch(31)
  return super().dispatch(request, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/django/views/generic/base.py in dispatch(143)
  return handler(request, *args, **kwargs)

/app/project/lms_tales/views/step_views.py in get(36)
  response = super().get(request, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/django/views/generic/detail.py in get(109)
  context = self.get_context_data(object=self.object)

/app/project/lms_tales/views/step_views.py in get_context_data(69)
  if len(step_files_new) > 0:

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(37)
  return original(compiler, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(96)
  return _get_result_or_execute_query(

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in _get_result_or_execute_query(71)
  cache.set_many(to_be_set, cachalot_settings.CACHALOT_TIMEOUT)

0,3312 get_many (['138549f5508bbba7283d6a0625e51c589d845e8f', '4f1f0b4dfbd30463b5587753e6f3e6ca21ddbf60', '914850ebf80706581ba37746aabecb7cd88d8973'],) {} <django_redis.cache.RedisCache object at 0x7910e287a790>
/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in run(101)
  return _run_old_run_func()

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in _run_old_run_func(94)
  return old_run_func(self, *a, **kw)

/usr/local/lib/python3.11/concurrent/futures/thread.py in _worker(83)
  work_item.run()

/usr/local/lib/python3.11/concurrent/futures/thread.py in run(58)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/corsheaders/middleware.py in __call__(56)
  result = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in middleware(32)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/allauth/account/middleware.py in middleware(36)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/simple_history/middleware.py in middleware(41)
  return get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/django_htmx/middleware.py in __call__(43)
  return self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in __call__(168)
  response = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/panels.py in process_request(41)
  return super(CachalotPanel, self).process_request(request)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in __call__(244)
  current_executor.run_until_future(call_result)

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run_until_future(81)
  work_item.run()

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run(40)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_wrapped_callback(90)
  return callback(request, *args, **kwargs)

/app/project/utils/decorators.py in apply_cache(64)
  response = function(request, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/django/views/generic/base.py in view(104)
  return self.dispatch(request, *args, **kwargs)

/app/project/lms_tales/views/mixins.py in dispatch(31)
  return super().dispatch(request, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/django/views/generic/base.py in dispatch(143)
  return handler(request, *args, **kwargs)

/app/project/lms_tales/views/step_views.py in get(36)
  response = super().get(request, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/django/views/generic/detail.py in get(109)
  context = self.get_context_data(object=self.object)

/app/project/lms_tales/views/step_views.py in get_context_data(69)
  if len(step_files_new) > 0:

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(37)
  return original(compiler, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(96)
  return _get_result_or_execute_query(

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in _get_result_or_execute_query(46)
  data = cache.get_many(table_cache_keys + [cache_key])

0,3438 set_many ({'914850ebf80706581ba37746aabecb7cd88d8973': (1736871783.0920336, [])}, None) {} <django_redis.cache.RedisCache object at 0x7910e287a790>
/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in run(101)
  return _run_old_run_func()

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in _run_old_run_func(94)
  return old_run_func(self, *a, **kw)

/usr/local/lib/python3.11/concurrent/futures/thread.py in _worker(83)
  work_item.run()

/usr/local/lib/python3.11/concurrent/futures/thread.py in run(58)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/corsheaders/middleware.py in __call__(56)
  result = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in middleware(32)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/allauth/account/middleware.py in middleware(36)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/simple_history/middleware.py in middleware(41)
  return get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/django_htmx/middleware.py in __call__(43)
  return self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in __call__(168)
  response = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/panels.py in process_request(41)
  return super(CachalotPanel, self).process_request(request)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in __call__(244)
  current_executor.run_until_future(call_result)

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run_until_future(81)
  work_item.run()

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run(40)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_wrapped_callback(90)
  return callback(request, *args, **kwargs)

/app/project/utils/decorators.py in apply_cache(64)
  response = function(request, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/django/views/generic/base.py in view(104)
  return self.dispatch(request, *args, **kwargs)

/app/project/lms_tales/views/mixins.py in dispatch(31)
  return super().dispatch(request, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/django/views/generic/base.py in dispatch(143)
  return handler(request, *args, **kwargs)

/app/project/lms_tales/views/step_views.py in get(36)
  response = super().get(request, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/django/views/generic/detail.py in get(109)
  context = self.get_context_data(object=self.object)

/app/project/lms_tales/views/step_views.py in get_context_data(69)
  if len(step_files_new) > 0:

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(37)
  return original(compiler, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(96)
  return _get_result_or_execute_query(

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in _get_result_or_execute_query(71)
  cache.set_many(to_be_set, cachalot_settings.CACHALOT_TIMEOUT)

0,4004 get_many (['76e323efd8711853e13c9f7cf976845908364eb2', '60712feda073c15a3803c02cda9d0e1a967758da'],) {} <django_redis.cache.RedisCache object at 0x7910e287a790>
/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in run(101)
  return _run_old_run_func()

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in _run_old_run_func(94)
  return old_run_func(self, *a, **kw)

/usr/local/lib/python3.11/concurrent/futures/thread.py in _worker(83)
  work_item.run()

/usr/local/lib/python3.11/concurrent/futures/thread.py in run(58)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/corsheaders/middleware.py in __call__(56)
  result = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in middleware(32)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/allauth/account/middleware.py in middleware(36)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/simple_history/middleware.py in middleware(41)
  return get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/django_htmx/middleware.py in __call__(43)
  return self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in __call__(168)
  response = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/panels.py in process_request(41)
  return super(CachalotPanel, self).process_request(request)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in __call__(244)
  current_executor.run_until_future(call_result)

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run_until_future(81)
  work_item.run()

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run(40)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_wrapped_callback(90)
  return callback(request, *args, **kwargs)

/app/project/utils/decorators.py in apply_cache(64)
  response = function(request, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/django/views/generic/base.py in view(104)
  return self.dispatch(request, *args, **kwargs)

/app/project/lms_tales/views/mixins.py in dispatch(31)
  return super().dispatch(request, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/django/views/generic/base.py in dispatch(143)
  return handler(request, *args, **kwargs)

/app/project/lms_tales/views/step_views.py in get(36)
  response = super().get(request, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/django/views/generic/detail.py in get(109)
  context = self.get_context_data(object=self.object)

/app/project/lms_tales/views/step_views.py in get_context_data(72)
  context["course"] = self.object.chapter.course

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(37)
  return original(compiler, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(96)
  return _get_result_or_execute_query(

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in _get_result_or_execute_query(46)
  data = cache.get_many(table_cache_keys + [cache_key])

0,4400 get_many (['e3a5db5a670ad803efb866441f33de58309be2e2', '8de636776a198de6ec9a987a55b157e4712013cf'],) {} <django_redis.cache.RedisCache object at 0x7910e287a790>
/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in run(101)
  return _run_old_run_func()

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in _run_old_run_func(94)
  return old_run_func(self, *a, **kw)

/usr/local/lib/python3.11/concurrent/futures/thread.py in _worker(83)
  work_item.run()

/usr/local/lib/python3.11/concurrent/futures/thread.py in run(58)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/corsheaders/middleware.py in __call__(56)
  result = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in middleware(32)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/allauth/account/middleware.py in middleware(36)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/simple_history/middleware.py in middleware(41)
  return get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/django_htmx/middleware.py in __call__(43)
  return self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in __call__(168)
  response = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/panels.py in process_request(41)
  return super(CachalotPanel, self).process_request(request)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in __call__(244)
  current_executor.run_until_future(call_result)

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run_until_future(81)
  work_item.run()

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run(40)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_wrapped_callback(90)
  return callback(request, *args, **kwargs)

/app/project/utils/decorators.py in apply_cache(64)
  response = function(request, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/django/views/generic/base.py in view(104)
  return self.dispatch(request, *args, **kwargs)

/app/project/lms_tales/views/mixins.py in dispatch(31)
  return super().dispatch(request, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/django/views/generic/base.py in dispatch(143)
  return handler(request, *args, **kwargs)

/app/project/lms_tales/views/step_views.py in get(36)
  response = super().get(request, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/django/views/generic/detail.py in get(109)
  context = self.get_context_data(object=self.object)

/app/project/lms_tales/views/step_views.py in get_context_data(72)
  context["course"] = self.object.chapter.course

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(37)
  return original(compiler, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(96)
  return _get_result_or_execute_query(

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in _get_result_or_execute_query(46)
  data = cache.get_many(table_cache_keys + [cache_key])

0,2938 get_many (['e3a5db5a670ad803efb866441f33de58309be2e2', '312c357d2eed306581bb334378808fbccf7019ea', '2d6f73002522751da21684c16b390e390efa9deb'],) {} <django_redis.cache.RedisCache object at 0x7910e287a790>
/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in run(101)
  return _run_old_run_func()

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in _run_old_run_func(94)
  return old_run_func(self, *a, **kw)

/usr/local/lib/python3.11/concurrent/futures/thread.py in _worker(83)
  work_item.run()

/usr/local/lib/python3.11/concurrent/futures/thread.py in run(58)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/corsheaders/middleware.py in __call__(56)
  result = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in middleware(32)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/allauth/account/middleware.py in middleware(36)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/simple_history/middleware.py in middleware(41)
  return get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/django_htmx/middleware.py in __call__(43)
  return self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in __call__(168)
  response = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/panels.py in process_request(41)
  return super(CachalotPanel, self).process_request(request)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in __call__(244)
  current_executor.run_until_future(call_result)

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run_until_future(81)
  work_item.run()

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run(40)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_wrapped_callback(90)
  return callback(request, *args, **kwargs)

/app/project/utils/decorators.py in apply_cache(72)
  cache.set(CACHE_KEY, response.render(), ttl)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_patched_render(41)
  return old_render(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in render(114)
  self.content = self.rendered_content

/usr/local/lib/python3.11/site-packages/sentry_sdk/utils.py in runner(1788)
  return sentry_patched_function(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/templates.py in rendered_content(77)
  return real_rendered_content.fget(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in rendered_content(92)
  return template.render(context, self._request)

/usr/local/lib/python3.11/site-packages/django/template/backends/django.py in render(61)
  return self.template.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(175)
  return self._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py in render(314)
  match = condition.eval(context)

/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py in eval(877)
  return self.value.resolve(context, ignore_failures=True)

/usr/local/lib/python3.11/site-packages/django/template/base.py in resolve(715)
  obj = self.var.resolve(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in resolve(847)
  value = self._resolve_lookup(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in _resolve_lookup(890)
  current = getattr(current, bit)

/app/project/lms_tales/models.py in meta(83)
  + ", ".join([author.name for author in self.get_course().authors.all()]),

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(37)
  return original(compiler, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(96)
  return _get_result_or_execute_query(

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in _get_result_or_execute_query(46)
  data = cache.get_many(table_cache_keys + [cache_key])

0,3521 set_many ({'2d6f73002522751da21684c16b390e390efa9deb': (1736871783.1112697, [[(10, datetime.datetime(2021, 3, 2, 14, 24, 18, 853556, tzinfo=datetime.timezone.utc), datetime.datetime(2021, 3, 2, 14, 24, 18, 881966, tzinfo=datetime.timezone.utc), 'Lea Nahon \r\n[lea.nahon@unibas.ch](mailto:lea.nahon@unibas.ch)', 'Lea Nahon \r\n[lea.nahon@unibas.ch](mailto:lea.nahon@unibas.ch)', None, None, 'conducting-psychological-research/LeaNahon_4KGa4Q6.jpg', 1, 6), (13, datetime.datetime(2021, 3, 2, 14, 24, 18, 853556, tzinfo=datetime.timezone.utc), datetime.datetime(2021, 3, 2, 14, 24, 18, 881966, tzinfo=datetime.timezone.utc), 'Sharon Steinemann \r\n[sharon.steinemann@unibas.ch](mailto:sharon.steinemann@unibas.ch)', 'Sharon Steinemann \r\n[sharon.steinemann@unibas.ch](mailto:sharon.steinemann@unibas.ch)', None, None, 'conducting-psychological-research/SharonSteinemann_3AvRS93.jpg', 27565, 6), (14, datetime.datetime(2021, 3, 2, 14, 24, 18, 853556, tzinfo=datetime.timezone.utc), datetime.datetime(2021, 3, 2, 14, 24, 18, 881966, tzinfo=datetime.timezone.utc), 'Loreen Tisdall \r\n[loreen.tidsall@unibas.ch](mailto:loreen.tidsall@unibas.ch)', 'Loreen Tisdall \r\n[loreen.tidsall@unibas.ch](mailto:loreen.tidsall@unibas.ch)', None, None, 'conducting-psychological-research/LoreenTisdall.jpg', 27566, 6), (3, datetime.datetime(2021, 3, 2, 14, 24, 18, 853556, tzinfo=datetime.timezone.utc), datetime.datetime(2021, 3, 2, 14, 24, 18, 881966, tzinfo=datetime.timezone.utc), 'Csaba Boglari \r\n[csaba.boglari@unibas.ch](mailto:csaba.boglari@unibas.ch)', 'Csaba Boglari \r\n[csaba.boglari@unibas.ch](mailto:csaba.boglari@unibas.ch)', None, None, 'conducting-psychological-research/CsabaBoglari.jpg', 27556, 6), (4, datetime.datetime(2021, 3, 2, 14, 24, 18, 853556, tzinfo=datetime.timezone.utc), datetime.datetime(2021, 3, 2, 14, 24, 18, 881966, tzinfo=datetime.timezone.utc), 'Julia Ayumi Bopp \r\n[j.bopp@unibas.ch](mailto:j.bopp@unibas.ch)', 'Julia Ayumi Bopp \r\n[j.bopp@unibas.ch](mailto:j.bopp@unibas.ch)', None, None, 'conducting-psychological-research/JuliaBopp_YNCL3Kr.jpg', 27557, 6), (5, datetime.datetime(2021, 3, 2, 14, 24, 18, 853556, tzinfo=datetime.timezone.utc), datetime.datetime(2021, 3, 2, 14, 24, 18, 881966, tzinfo=datetime.timezone.utc), 'Leonie Geissmann \r\n[leonie.geissmann@unibas.ch](mailto:leonie.geissmann@unibas.ch)', 'Leonie Geissmann \r\n[leonie.geissmann@unibas.ch](mailto:leonie.geissmann@unibas.ch)', None, None, 'conducting-psychological-research/leoniegeissmann.jpg', 27558, 6), (6, datetime.datetime(2021, 3, 2, 14, 24, 18, 853556, tzinfo=datetime.timezone.utc), datetime.datetime(2021, 3, 2, 14, 24, 18, 881966, tzinfo=datetime.timezone.utc), 'Steve Heinke \r\n[steve.heinke@unibas.ch](mailto:steve.heinke@unibas.ch)', 'Steve Heinke \r\n[steve.heinke@unibas.ch](mailto:steve.heinke@unibas.ch)', None, None, 'conducting-psychological-research/SteveHeinke_S7ZAxyz.jpg', 27559, 6), (7, datetime.datetime(2021, 3, 2, 14, 24, 18, 853556, tzinfo=datetime.timezone.utc), datetime.datetime(2021, 3, 2, 14, 24, 18, 881966, tzinfo=datetime.timezone.utc), 'Jana Jarecki \r\n[jana.jarecki@unibas.ch](mailto:jana.jarecki@unibas.ch)', 'Jana Jarecki \r\n[jana.jarecki@unibas.ch](mailto:jana.jarecki@unibas.ch)', None, None, 'conducting-psychological-research/JanaJarecki_VgPHWCu.jpg', 27560, 6), (8, datetime.datetime(2021, 3, 2, 14, 24, 18, 853556, tzinfo=datetime.timezone.utc), datetime.datetime(2021, 3, 2, 14, 24, 18, 881966, tzinfo=datetime.timezone.utc), 'Ashley James Luckman \r\n[ashleyjames.luckman@unibas.ch](mailto:ashleyjames.luckman@unibas.ch)', 'Ashley James Luckman \r\n[ashleyjames.luckman@unibas.ch](mailto:ashleyjames.luckman@unibas.ch)', None, None, 'conducting-psychological-research/headshot_Dq4dgIJ.png', 27561, 6), (9, datetime.datetime(2021, 3, 2, 14, 24, 18, 853556, tzinfo=datetime.timezone.utc), datetime.datetime(2021, 3, 2, 14, 24, 18, 881966, tzinfo=datetime.timezone.utc), 'Pavlina Mastrandreas \r\n[pavlina.mastrandreas@unibas.ch](mailto:pavlina.mastrandreas@unibas.ch)', 'Pavlina Mastrandreas \r\n[pavlina.mastrandreas@unibas.ch](mailto:pavlina.mastrandreas@unibas.ch)', None, None, 'conducting-psychological-research/headshot_tPLpQ02.png', 27562, 6), (11, datetime.datetime(2021, 3, 2, 14, 24, 18, 853556, tzinfo=datetime.timezone.utc), datetime.datetime(2021, 3, 2, 14, 24, 18, 881966, tzinfo=datetime.timezone.utc), 'Jana Petrovska \r\n[jana.petrovska@unibas.ch](mailto:jana.petrovska@unibas.ch)', 'Jana Petrovska \r\n[jana.petrovska@unibas.ch](mailto:jana.petrovska@unibas.ch)', None, None, 'conducting-psychological-research/JanaPetrovska_FBJKW6B.jpg', 27563, 6), (12, datetime.datetime(2021, 3, 2, 14, 24, 18, 853556, tzinfo=datetime.timezone.utc), datetime.datetime(2021, 3, 2, 14, 24, 18, 881966, tzinfo=datetime.timezone.utc), 'Victoria Siegrist \r\n[victoria.siegrist@unibas.ch](mailto:victoria.siegrist@unibas.ch)', 'Victoria Siegrist \r\n[victoria.siegrist@unibas.ch](mailto:victoria.siegrist@unibas.ch)', None, None, 'conducting-psychological-research/VictoriaSiegrist.jpg', 27564, 6)]])}, None) {} <django_redis.cache.RedisCache object at 0x7910e287a790>
/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in run(101)
  return _run_old_run_func()

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in _run_old_run_func(94)
  return old_run_func(self, *a, **kw)

/usr/local/lib/python3.11/concurrent/futures/thread.py in _worker(83)
  work_item.run()

/usr/local/lib/python3.11/concurrent/futures/thread.py in run(58)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/corsheaders/middleware.py in __call__(56)
  result = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in middleware(32)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/allauth/account/middleware.py in middleware(36)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/simple_history/middleware.py in middleware(41)
  return get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/django_htmx/middleware.py in __call__(43)
  return self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in __call__(168)
  response = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/panels.py in process_request(41)
  return super(CachalotPanel, self).process_request(request)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in __call__(244)
  current_executor.run_until_future(call_result)

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run_until_future(81)
  work_item.run()

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run(40)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_wrapped_callback(90)
  return callback(request, *args, **kwargs)

/app/project/utils/decorators.py in apply_cache(72)
  cache.set(CACHE_KEY, response.render(), ttl)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_patched_render(41)
  return old_render(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in render(114)
  self.content = self.rendered_content

/usr/local/lib/python3.11/site-packages/sentry_sdk/utils.py in runner(1788)
  return sentry_patched_function(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/templates.py in rendered_content(77)
  return real_rendered_content.fget(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in rendered_content(92)
  return template.render(context, self._request)

/usr/local/lib/python3.11/site-packages/django/template/backends/django.py in render(61)
  return self.template.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(175)
  return self._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py in render(314)
  match = condition.eval(context)

/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py in eval(877)
  return self.value.resolve(context, ignore_failures=True)

/usr/local/lib/python3.11/site-packages/django/template/base.py in resolve(715)
  obj = self.var.resolve(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in resolve(847)
  value = self._resolve_lookup(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in _resolve_lookup(890)
  current = getattr(current, bit)

/app/project/lms_tales/models.py in meta(83)
  + ", ".join([author.name for author in self.get_course().authors.all()]),

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(37)
  return original(compiler, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(96)
  return _get_result_or_execute_query(

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in _get_result_or_execute_query(71)
  cache.set_many(to_be_set, cachalot_settings.CACHALOT_TIMEOUT)

0,2565 get_many (['e3a5db5a670ad803efb866441f33de58309be2e2', '312c357d2eed306581bb334378808fbccf7019ea', '2d6f73002522751da21684c16b390e390efa9deb'],) {} <django_redis.cache.RedisCache object at 0x7910e287a790>
/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in run(101)
  return _run_old_run_func()

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in _run_old_run_func(94)
  return old_run_func(self, *a, **kw)

/usr/local/lib/python3.11/concurrent/futures/thread.py in _worker(83)
  work_item.run()

/usr/local/lib/python3.11/concurrent/futures/thread.py in run(58)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/corsheaders/middleware.py in __call__(56)
  result = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in middleware(32)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/allauth/account/middleware.py in middleware(36)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/simple_history/middleware.py in middleware(41)
  return get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/django_htmx/middleware.py in __call__(43)
  return self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in __call__(168)
  response = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/panels.py in process_request(41)
  return super(CachalotPanel, self).process_request(request)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in __call__(244)
  current_executor.run_until_future(call_result)

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run_until_future(81)
  work_item.run()

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run(40)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_wrapped_callback(90)
  return callback(request, *args, **kwargs)

/app/project/utils/decorators.py in apply_cache(72)
  cache.set(CACHE_KEY, response.render(), ttl)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_patched_render(41)
  return old_render(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in render(114)
  self.content = self.rendered_content

/usr/local/lib/python3.11/site-packages/sentry_sdk/utils.py in runner(1788)
  return sentry_patched_function(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/templates.py in rendered_content(77)
  return real_rendered_content.fget(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in rendered_content(92)
  return template.render(context, self._request)

/usr/local/lib/python3.11/site-packages/django/template/backends/django.py in render(61)
  return self.template.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(175)
  return self._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py in render(321)
  return nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1064)
  output = self.filter_expression.resolve(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in resolve(715)
  obj = self.var.resolve(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in resolve(847)
  value = self._resolve_lookup(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in _resolve_lookup(890)
  current = getattr(current, bit)

/app/project/lms_tales/models.py in meta(83)
  + ", ".join([author.name for author in self.get_course().authors.all()]),

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(37)
  return original(compiler, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(96)
  return _get_result_or_execute_query(

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in _get_result_or_execute_query(46)
  data = cache.get_many(table_cache_keys + [cache_key])

0,2503 get_many (['e3a5db5a670ad803efb866441f33de58309be2e2', '312c357d2eed306581bb334378808fbccf7019ea', '2d6f73002522751da21684c16b390e390efa9deb'],) {} <django_redis.cache.RedisCache object at 0x7910e287a790>
/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in run(101)
  return _run_old_run_func()

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in _run_old_run_func(94)
  return old_run_func(self, *a, **kw)

/usr/local/lib/python3.11/concurrent/futures/thread.py in _worker(83)
  work_item.run()

/usr/local/lib/python3.11/concurrent/futures/thread.py in run(58)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/corsheaders/middleware.py in __call__(56)
  result = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in middleware(32)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/allauth/account/middleware.py in middleware(36)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/simple_history/middleware.py in middleware(41)
  return get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/django_htmx/middleware.py in __call__(43)
  return self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in __call__(168)
  response = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/panels.py in process_request(41)
  return super(CachalotPanel, self).process_request(request)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in __call__(244)
  current_executor.run_until_future(call_result)

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run_until_future(81)
  work_item.run()

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run(40)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_wrapped_callback(90)
  return callback(request, *args, **kwargs)

/app/project/utils/decorators.py in apply_cache(72)
  cache.set(CACHE_KEY, response.render(), ttl)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_patched_render(41)
  return old_render(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in render(114)
  self.content = self.rendered_content

/usr/local/lib/python3.11/site-packages/sentry_sdk/utils.py in runner(1788)
  return sentry_patched_function(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/templates.py in rendered_content(77)
  return real_rendered_content.fget(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in rendered_content(92)
  return template.render(context, self._request)

/usr/local/lib/python3.11/site-packages/django/template/backends/django.py in render(61)
  return self.template.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(175)
  return self._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py in render(321)
  return nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1064)
  output = self.filter_expression.resolve(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in resolve(715)
  obj = self.var.resolve(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in resolve(847)
  value = self._resolve_lookup(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in _resolve_lookup(890)
  current = getattr(current, bit)

/app/project/lms_tales/models.py in meta(83)
  + ", ".join([author.name for author in self.get_course().authors.all()]),

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(37)
  return original(compiler, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(96)
  return _get_result_or_execute_query(

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in _get_result_or_execute_query(46)
  data = cache.get_many(table_cache_keys + [cache_key])

0,2661 get_many (['e3a5db5a670ad803efb866441f33de58309be2e2', '312c357d2eed306581bb334378808fbccf7019ea', '2d6f73002522751da21684c16b390e390efa9deb'],) {} <django_redis.cache.RedisCache object at 0x7910e287a790>
/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in run(101)
  return _run_old_run_func()

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in _run_old_run_func(94)
  return old_run_func(self, *a, **kw)

/usr/local/lib/python3.11/concurrent/futures/thread.py in _worker(83)
  work_item.run()

/usr/local/lib/python3.11/concurrent/futures/thread.py in run(58)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/corsheaders/middleware.py in __call__(56)
  result = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in middleware(32)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/allauth/account/middleware.py in middleware(36)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/simple_history/middleware.py in middleware(41)
  return get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/django_htmx/middleware.py in __call__(43)
  return self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in __call__(168)
  response = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/panels.py in process_request(41)
  return super(CachalotPanel, self).process_request(request)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in __call__(244)
  current_executor.run_until_future(call_result)

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run_until_future(81)
  work_item.run()

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run(40)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_wrapped_callback(90)
  return callback(request, *args, **kwargs)

/app/project/utils/decorators.py in apply_cache(72)
  cache.set(CACHE_KEY, response.render(), ttl)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_patched_render(41)
  return old_render(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in render(114)
  self.content = self.rendered_content

/usr/local/lib/python3.11/site-packages/sentry_sdk/utils.py in runner(1788)
  return sentry_patched_function(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/templates.py in rendered_content(77)
  return real_rendered_content.fget(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in rendered_content(92)
  return template.render(context, self._request)

/usr/local/lib/python3.11/site-packages/django/template/backends/django.py in render(61)
  return self.template.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(175)
  return self._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py in render(321)
  return nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1064)
  output = self.filter_expression.resolve(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in resolve(715)
  obj = self.var.resolve(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in resolve(847)
  value = self._resolve_lookup(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in _resolve_lookup(890)
  current = getattr(current, bit)

/app/project/lms_tales/models.py in meta(83)
  + ", ".join([author.name for author in self.get_course().authors.all()]),

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(37)
  return original(compiler, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(96)
  return _get_result_or_execute_query(

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in _get_result_or_execute_query(46)
  data = cache.get_many(table_cache_keys + [cache_key])

0,2566 get_many (['e3a5db5a670ad803efb866441f33de58309be2e2', '312c357d2eed306581bb334378808fbccf7019ea', '2d6f73002522751da21684c16b390e390efa9deb'],) {} <django_redis.cache.RedisCache object at 0x7910e287a790>
/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in run(101)
  return _run_old_run_func()

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in _run_old_run_func(94)
  return old_run_func(self, *a, **kw)

/usr/local/lib/python3.11/concurrent/futures/thread.py in _worker(83)
  work_item.run()

/usr/local/lib/python3.11/concurrent/futures/thread.py in run(58)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/corsheaders/middleware.py in __call__(56)
  result = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in middleware(32)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/allauth/account/middleware.py in middleware(36)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/simple_history/middleware.py in middleware(41)
  return get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/django_htmx/middleware.py in __call__(43)
  return self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in __call__(168)
  response = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/panels.py in process_request(41)
  return super(CachalotPanel, self).process_request(request)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in __call__(244)
  current_executor.run_until_future(call_result)

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run_until_future(81)
  work_item.run()

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run(40)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_wrapped_callback(90)
  return callback(request, *args, **kwargs)

/app/project/utils/decorators.py in apply_cache(72)
  cache.set(CACHE_KEY, response.render(), ttl)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_patched_render(41)
  return old_render(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in render(114)
  self.content = self.rendered_content

/usr/local/lib/python3.11/site-packages/sentry_sdk/utils.py in runner(1788)
  return sentry_patched_function(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/templates.py in rendered_content(77)
  return real_rendered_content.fget(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in rendered_content(92)
  return template.render(context, self._request)

/usr/local/lib/python3.11/site-packages/django/template/backends/django.py in render(61)
  return self.template.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(175)
  return self._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py in render(321)
  return nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1064)
  output = self.filter_expression.resolve(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in resolve(715)
  obj = self.var.resolve(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in resolve(847)
  value = self._resolve_lookup(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in _resolve_lookup(890)
  current = getattr(current, bit)

/app/project/lms_tales/models.py in meta(83)
  + ", ".join([author.name for author in self.get_course().authors.all()]),

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(37)
  return original(compiler, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(96)
  return _get_result_or_execute_query(

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in _get_result_or_execute_query(46)
  data = cache.get_many(table_cache_keys + [cache_key])

0,2457 get_many (['e3a5db5a670ad803efb866441f33de58309be2e2', '312c357d2eed306581bb334378808fbccf7019ea', '2d6f73002522751da21684c16b390e390efa9deb'],) {} <django_redis.cache.RedisCache object at 0x7910e287a790>
/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in run(101)
  return _run_old_run_func()

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in _run_old_run_func(94)
  return old_run_func(self, *a, **kw)

/usr/local/lib/python3.11/concurrent/futures/thread.py in _worker(83)
  work_item.run()

/usr/local/lib/python3.11/concurrent/futures/thread.py in run(58)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/corsheaders/middleware.py in __call__(56)
  result = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in middleware(32)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/allauth/account/middleware.py in middleware(36)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/simple_history/middleware.py in middleware(41)
  return get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/django_htmx/middleware.py in __call__(43)
  return self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in __call__(168)
  response = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/panels.py in process_request(41)
  return super(CachalotPanel, self).process_request(request)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in __call__(244)
  current_executor.run_until_future(call_result)

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run_until_future(81)
  work_item.run()

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run(40)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_wrapped_callback(90)
  return callback(request, *args, **kwargs)

/app/project/utils/decorators.py in apply_cache(72)
  cache.set(CACHE_KEY, response.render(), ttl)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_patched_render(41)
  return old_render(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in render(114)
  self.content = self.rendered_content

/usr/local/lib/python3.11/site-packages/sentry_sdk/utils.py in runner(1788)
  return sentry_patched_function(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/templates.py in rendered_content(77)
  return real_rendered_content.fget(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in rendered_content(92)
  return template.render(context, self._request)

/usr/local/lib/python3.11/site-packages/django/template/backends/django.py in render(61)
  return self.template.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(175)
  return self._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py in render(321)
  return nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1064)
  output = self.filter_expression.resolve(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in resolve(715)
  obj = self.var.resolve(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in resolve(847)
  value = self._resolve_lookup(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in _resolve_lookup(890)
  current = getattr(current, bit)

/app/project/lms_tales/models.py in meta(83)
  + ", ".join([author.name for author in self.get_course().authors.all()]),

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(37)
  return original(compiler, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(96)
  return _get_result_or_execute_query(

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in _get_result_or_execute_query(46)
  data = cache.get_many(table_cache_keys + [cache_key])

0,2514 get_many (['e3a5db5a670ad803efb866441f33de58309be2e2', '312c357d2eed306581bb334378808fbccf7019ea', '2d6f73002522751da21684c16b390e390efa9deb'],) {} <django_redis.cache.RedisCache object at 0x7910e287a790>
/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in run(101)
  return _run_old_run_func()

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in _run_old_run_func(94)
  return old_run_func(self, *a, **kw)

/usr/local/lib/python3.11/concurrent/futures/thread.py in _worker(83)
  work_item.run()

/usr/local/lib/python3.11/concurrent/futures/thread.py in run(58)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/corsheaders/middleware.py in __call__(56)
  result = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in middleware(32)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/allauth/account/middleware.py in middleware(36)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/simple_history/middleware.py in middleware(41)
  return get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/django_htmx/middleware.py in __call__(43)
  return self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in __call__(168)
  response = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/panels.py in process_request(41)
  return super(CachalotPanel, self).process_request(request)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in __call__(244)
  current_executor.run_until_future(call_result)

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run_until_future(81)
  work_item.run()

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run(40)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_wrapped_callback(90)
  return callback(request, *args, **kwargs)

/app/project/utils/decorators.py in apply_cache(72)
  cache.set(CACHE_KEY, response.render(), ttl)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_patched_render(41)
  return old_render(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in render(114)
  self.content = self.rendered_content

/usr/local/lib/python3.11/site-packages/sentry_sdk/utils.py in runner(1788)
  return sentry_patched_function(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/templates.py in rendered_content(77)
  return real_rendered_content.fget(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in rendered_content(92)
  return template.render(context, self._request)

/usr/local/lib/python3.11/site-packages/django/template/backends/django.py in render(61)
  return self.template.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(175)
  return self._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py in render(321)
  return nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1064)
  output = self.filter_expression.resolve(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in resolve(715)
  obj = self.var.resolve(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in resolve(847)
  value = self._resolve_lookup(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in _resolve_lookup(890)
  current = getattr(current, bit)

/app/project/lms_tales/models.py in meta(83)
  + ", ".join([author.name for author in self.get_course().authors.all()]),

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(37)
  return original(compiler, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(96)
  return _get_result_or_execute_query(

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in _get_result_or_execute_query(46)
  data = cache.get_many(table_cache_keys + [cache_key])

0,2079 get ('waffle:4.1.0a156ed0e9d07cd12e770c8dca0575feb',) {} <django_redis.cache.RedisCache object at 0x7910e287a790>
/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in run(101)
  return _run_old_run_func()

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in _run_old_run_func(94)
  return old_run_func(self, *a, **kw)

/usr/local/lib/python3.11/concurrent/futures/thread.py in _worker(83)
  work_item.run()

/usr/local/lib/python3.11/concurrent/futures/thread.py in run(58)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/corsheaders/middleware.py in __call__(56)
  result = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in middleware(32)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/allauth/account/middleware.py in middleware(36)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/simple_history/middleware.py in middleware(41)
  return get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/django_htmx/middleware.py in __call__(43)
  return self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in __call__(168)
  response = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/panels.py in process_request(41)
  return super(CachalotPanel, self).process_request(request)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in __call__(244)
  current_executor.run_until_future(call_result)

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run_until_future(81)
  work_item.run()

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run(40)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_wrapped_callback(90)
  return callback(request, *args, **kwargs)

/app/project/utils/decorators.py in apply_cache(72)
  cache.set(CACHE_KEY, response.render(), ttl)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_patched_render(41)
  return old_render(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in render(114)
  self.content = self.rendered_content

/usr/local/lib/python3.11/site-packages/sentry_sdk/utils.py in runner(1788)
  return sentry_patched_function(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/templates.py in rendered_content(77)
  return real_rendered_content.fget(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in rendered_content(92)
  return template.render(context, self._request)

/usr/local/lib/python3.11/site-packages/django/template/backends/django.py in render(61)
  return self.template.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(175)
  return self._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(208)
  return template.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(177)
  return self._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py in render(321)
  return nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/waffle/templatetags/waffle_tags.py in render(36)
  if self.condition(context.get('request', None), name):

/usr/local/lib/python3.11/site-packages/waffle/__init__.py in flag_is_active(19)
  flag = get_waffle_flag_model().get(flag_name)

/usr/local/lib/python3.11/site-packages/waffle/models.py in get(52)
  cached = cache.get(cache_key)

0,2882 add ('waffle:4.1.0a156ed0e9d07cd12e770c8dca0575feb', <Flag: show_login_button>) {} <django_redis.cache.RedisCache object at 0x7910e287a790>
/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in run(101)
  return _run_old_run_func()

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in _run_old_run_func(94)
  return old_run_func(self, *a, **kw)

/usr/local/lib/python3.11/concurrent/futures/thread.py in _worker(83)
  work_item.run()

/usr/local/lib/python3.11/concurrent/futures/thread.py in run(58)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/corsheaders/middleware.py in __call__(56)
  result = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in middleware(32)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/allauth/account/middleware.py in middleware(36)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/simple_history/middleware.py in middleware(41)
  return get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/django_htmx/middleware.py in __call__(43)
  return self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in __call__(168)
  response = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/panels.py in process_request(41)
  return super(CachalotPanel, self).process_request(request)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in __call__(244)
  current_executor.run_until_future(call_result)

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run_until_future(81)
  work_item.run()

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run(40)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_wrapped_callback(90)
  return callback(request, *args, **kwargs)

/app/project/utils/decorators.py in apply_cache(72)
  cache.set(CACHE_KEY, response.render(), ttl)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_patched_render(41)
  return old_render(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in render(114)
  self.content = self.rendered_content

/usr/local/lib/python3.11/site-packages/sentry_sdk/utils.py in runner(1788)
  return sentry_patched_function(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/templates.py in rendered_content(77)
  return real_rendered_content.fget(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in rendered_content(92)
  return template.render(context, self._request)

/usr/local/lib/python3.11/site-packages/django/template/backends/django.py in render(61)
  return self.template.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(175)
  return self._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(208)
  return template.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(177)
  return self._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py in render(321)
  return nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/waffle/templatetags/waffle_tags.py in render(36)
  if self.condition(context.get('request', None), name):

/usr/local/lib/python3.11/site-packages/waffle/__init__.py in flag_is_active(19)
  flag = get_waffle_flag_model().get(flag_name)

/usr/local/lib/python3.11/site-packages/waffle/models.py in get(64)
  cache.add(cache_key, obj)

0,2646 get_many (['e3a5db5a670ad803efb866441f33de58309be2e2', '76e323efd8711853e13c9f7cf976845908364eb2', 'f080e6b810d24906960c62b9447efefefed2d8ec'],) {} <django_redis.cache.RedisCache object at 0x7910e287a790>
/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in run(101)
  return _run_old_run_func()

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in _run_old_run_func(94)
  return old_run_func(self, *a, **kw)

/usr/local/lib/python3.11/concurrent/futures/thread.py in _worker(83)
  work_item.run()

/usr/local/lib/python3.11/concurrent/futures/thread.py in run(58)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/corsheaders/middleware.py in __call__(56)
  result = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in middleware(32)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/allauth/account/middleware.py in middleware(36)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/simple_history/middleware.py in middleware(41)
  return get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/django_htmx/middleware.py in __call__(43)
  return self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in __call__(168)
  response = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/panels.py in process_request(41)
  return super(CachalotPanel, self).process_request(request)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in __call__(244)
  current_executor.run_until_future(call_result)

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run_until_future(81)
  work_item.run()

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run(40)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_wrapped_callback(90)
  return callback(request, *args, **kwargs)

/app/project/utils/decorators.py in apply_cache(72)
  cache.set(CACHE_KEY, response.render(), ttl)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_patched_render(41)
  return old_render(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in render(114)
  self.content = self.rendered_content

/usr/local/lib/python3.11/site-packages/sentry_sdk/utils.py in runner(1788)
  return sentry_patched_function(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/templates.py in rendered_content(77)
  return real_rendered_content.fget(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in rendered_content(92)
  return template.render(context, self._request)

/usr/local/lib/python3.11/site-packages/django/template/backends/django.py in render(61)
  return self.template.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(175)
  return self._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(208)
  return template.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(177)
  return self._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py in render(321)
  return nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py in render(194)
  len_values = len(values)

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(37)
  return original(compiler, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(96)
  return _get_result_or_execute_query(

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in _get_result_or_execute_query(46)
  data = cache.get_many(table_cache_keys + [cache_key])

0,2981 set_many ({'f080e6b810d24906960c62b9447efefefed2d8ec': (1736871783.1504014, [[(20, datetime.datetime(2020, 11, 2, 15, 9, 33, 545649, tzinfo=datetime.timezone.utc), datetime.datetime(2020, 11, 2, 15, 9, 38, 575786, tzinfo=datetime.timezone.utc), datetime.datetime(2020, 11, 2, 15, 9, 38, 575816, tzinfo=datetime.timezone.utc), False, 'Research questions and theories', 'Research questions and theories', 'Research questions and theories', None, 'research-questions-and-theories', 0, 'published', 6), (19, datetime.datetime(2020, 11, 2, 15, 9, 33, 545649, tzinfo=datetime.timezone.utc), datetime.datetime(2020, 11, 2, 15, 9, 38, 576980, tzinfo=datetime.timezone.utc), datetime.datetime(2020, 11, 2, 15, 9, 38, 576990, tzinfo=datetime.timezone.utc), False, 'Design your experiment', 'Design your experiment', 'Design your experiment', None, 'design-your-experiment', 1, 'published', 6), (21, datetime.datetime(2020, 11, 2, 15, 9, 33, 545649, tzinfo=datetime.timezone.utc), datetime.datetime(2020, 11, 2, 15, 9, 38, 578149, tzinfo=datetime.timezone.utc), datetime.datetime(2020, 11, 2, 15, 9, 38, 578160, tzinfo=datetime.timezone.utc), False, 'Writing a scientific report', 'Writing a scientific report', 'Writing a scientific report', None, 'writing-a-scientific-report', 2, 'published', 6), (22, datetime.datetime(2020, 11, 2, 15, 9, 33, 545649, tzinfo=datetime.timezone.utc), datetime.datetime(2020, 11, 2, 15, 9, 38, 579443, tzinfo=datetime.timezone.utc), datetime.datetime(2020, 11, 2, 15, 9, 38, 579454, tzinfo=datetime.timezone.utc), False, 'Statistics and analyses', 'Statistics and analyses', 'Statistics and analyses', None, 'statistics-and-analyses', 3, 'published', 6)]])}, None) {} <django_redis.cache.RedisCache object at 0x7910e287a790>
/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in run(101)
  return _run_old_run_func()

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in _run_old_run_func(94)
  return old_run_func(self, *a, **kw)

/usr/local/lib/python3.11/concurrent/futures/thread.py in _worker(83)
  work_item.run()

/usr/local/lib/python3.11/concurrent/futures/thread.py in run(58)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/corsheaders/middleware.py in __call__(56)
  result = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in middleware(32)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/allauth/account/middleware.py in middleware(36)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/simple_history/middleware.py in middleware(41)
  return get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/django_htmx/middleware.py in __call__(43)
  return self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in __call__(168)
  response = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/panels.py in process_request(41)
  return super(CachalotPanel, self).process_request(request)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in __call__(244)
  current_executor.run_until_future(call_result)

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run_until_future(81)
  work_item.run()

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run(40)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_wrapped_callback(90)
  return callback(request, *args, **kwargs)

/app/project/utils/decorators.py in apply_cache(72)
  cache.set(CACHE_KEY, response.render(), ttl)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_patched_render(41)
  return old_render(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in render(114)
  self.content = self.rendered_content

/usr/local/lib/python3.11/site-packages/sentry_sdk/utils.py in runner(1788)
  return sentry_patched_function(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/templates.py in rendered_content(77)
  return real_rendered_content.fget(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in rendered_content(92)
  return template.render(context, self._request)

/usr/local/lib/python3.11/site-packages/django/template/backends/django.py in render(61)
  return self.template.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(175)
  return self._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(208)
  return template.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(177)
  return self._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py in render(321)
  return nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py in render(194)
  len_values = len(values)

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(37)
  return original(compiler, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(96)
  return _get_result_or_execute_query(

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in _get_result_or_execute_query(71)
  cache.set_many(to_be_set, cachalot_settings.CACHALOT_TIMEOUT)

0,6530 get_many (['e3a5db5a670ad803efb866441f33de58309be2e2', '76e323efd8711853e13c9f7cf976845908364eb2', '138549f5508bbba7283d6a0625e51c589d845e8f', 'a6ff55efe0a13dfd23f18fe68ac784e4a86ec0f5'],) {} <django_redis.cache.RedisCache object at 0x7910e287a790>
/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in run(101)
  return _run_old_run_func()

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in _run_old_run_func(94)
  return old_run_func(self, *a, **kw)

/usr/local/lib/python3.11/concurrent/futures/thread.py in _worker(83)
  work_item.run()

/usr/local/lib/python3.11/concurrent/futures/thread.py in run(58)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/corsheaders/middleware.py in __call__(56)
  result = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in middleware(32)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/allauth/account/middleware.py in middleware(36)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/simple_history/middleware.py in middleware(41)
  return get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/django_htmx/middleware.py in __call__(43)
  return self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in __call__(168)
  response = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/panels.py in process_request(41)
  return super(CachalotPanel, self).process_request(request)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in __call__(244)
  current_executor.run_until_future(call_result)

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run_until_future(81)
  work_item.run()

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run(40)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_wrapped_callback(90)
  return callback(request, *args, **kwargs)

/app/project/utils/decorators.py in apply_cache(72)
  cache.set(CACHE_KEY, response.render(), ttl)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_patched_render(41)
  return old_render(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in render(114)
  self.content = self.rendered_content

/usr/local/lib/python3.11/site-packages/sentry_sdk/utils.py in runner(1788)
  return sentry_patched_function(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/templates.py in rendered_content(77)
  return real_rendered_content.fget(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in rendered_content(92)
  return template.render(context, self._request)

/usr/local/lib/python3.11/site-packages/django/template/backends/django.py in render(61)
  return self.template.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(175)
  return self._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(208)
  return template.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(177)
  return self._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py in render(321)
  return nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py in render(238)
  nodelist.append(node.render_annotated(context))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py in render(194)
  len_values = len(values)

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(37)
  return original(compiler, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(96)
  return _get_result_or_execute_query(

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in _get_result_or_execute_query(46)
  data = cache.get_many(table_cache_keys + [cache_key])

1,5753 set_many ({'a6ff55efe0a13dfd23f18fe68ac784e4a86ec0f5': (1736871783.1601658, [[(48, datetime.datetime(2020, 11, 2, 15, 9, 33, 774510, tzinfo=datetime.timezone.utc), datetime.datetime(2020, 11, 2, 15, 9, 37, 343363, tzinfo=datetime.timezone.utc), datetime.datetime(2020, 11, 2, 15, 9, 37, 343372, tzinfo=datetime.timezone.utc), False, 'What is a good research question?', 'What is a good research question?', 'What is a good research question?', None, '', '', None, None, '', None, None, None, 'conducting-psychological-research/research-questions-and-theories/what-is-a-good-research-question/notizen4.jpg', 'what-is-a-good-research-question', 'Every good research project answers a question that observes a few rules. This presentation introduces you to the following three rules.\r\n{.lead}\r\n\r\n**Rule No. 1:** Be focused. \r\n**Rule No. 2:** Don’t be too obvious. \r\n**Rule No. 3:** Use clear language. \r\n \r\nIf you understand and follow these rules you should come up with a good research question. You will improve your question even further if you follow these vital steps:\r\n\r\n**Step No. 1:** Get to know your broad topic area. \r\n**Step No. 2:** Look for open questions and missing links in the current literature on your topic. \r\n**Step No. 3:** Once you know where the gaps in research are, define the question that will help to provide the answer that will fill the one you want to examine. \r\n\r\n![embed](https://vimeo.com/250771058/36c64b03cb)\r\n\r\nWatching this video you come across an exemplary research question deemed to be good but not optimal: ‘Is the mental wellbeing of 13- to 16-year-olds decreased depending on whether their self-reported best friend owns the latest iPhone?’ \r\n\r\n**Try to think of another example with a ‘directed’ hypothesis** (e.g., ‘Does daily smartphone usage increase the wellbeing…’). Then **try to find an example with a comparative vs. a non-comparative question** (e.g., ‘Does daily smartphone usage lead to more stress if the five closest friends have smartphones, compared to if they have none?’). Maybe you want to take notes of your examples – they can be quite helpful if you need to find your own research question.', 'Every good research project answers a question that observes a few rules. This presentation introduces you to the following three rules.\r\n{.lead}\r\n\r\n**Rule No. 1:** Be focused. \r\n**Rule No. 2:** Don’t be too obvious. \r\n**Rule No. 3:** Use clear language. \r\n \r\nIf you understand and follow these rules you should come up with a good research question. You will improve your question even further if you follow these vital steps:\r\n\r\n**Step No. 1:** Get to know your broad topic area. \r\n**Step No. 2:** Look for open questions and missing links in the current literature on your topic. \r\n**Step No. 3:** Once you know where the gaps in research are, define the question that will help to provide the answer that will fill the one you want to examine. \r\n\r\n![embed](https://vimeo.com/250771058/36c64b03cb)\r\n\r\nWatching this video you come across an exemplary research question deemed to be good but not optimal: ‘Is the mental wellbeing of 13- to 16-year-olds decreased depending on whether their self-reported best friend owns the latest iPhone?’ \r\n\r\n**Try to think of another example with a ‘directed’ hypothesis** (e.g., ‘Does daily smartphone usage increase the wellbeing…’). Then **try to find an example with a comparative vs. a non-comparative question** (e.g., ‘Does daily smartphone usage lead to more stress if the five closest friends have smartphones, compared to if they have none?’). Maybe you want to take notes of your examples – they can be quite helpful if you need to find your own research question.', 'Every good research project answers a question that observes a few rules. This presentation introduces you to the following three rules.\r\n{.lead}\r\n\r\n**Rule No. 1:** Be focused. \r\n**Rule No. 2:** Don’t be too obvious. \r\n**Rule No. 3:** Use clear language. \r\n \r\nIf you understand and follow these rules you should come up with a good research question. You will improve your question even further if you follow these vital steps:\r\n\r\n**Step No. 1:** Get to know your broad topic area. \r\n**Step No. 2:** Look for open questions and missing links in the current literature on your topic. \r\n**Step No. 3:** Once you know where the gaps in research are, define the question that will help to provide the answer that will fill the one you want to examine. \r\n\r\n![embed](https://vimeo.com/250771058/36c64b03cb)\r\n\r\nWatching this video you come across an exemplary research question deemed to be good but not optimal: ‘Is the mental wellbeing of 13- to 16-year-olds decreased depending on whether their self-reported best friend owns the latest iPhone?’ \r\n\r\n**Try to think of another example with a ‘directed’ hypothesis** (e.g., ‘Does daily smartphone usage increase the wellbeing…’). Then **try to find an example with a comparative vs. a non-comparative question** (e.g., ‘Does daily smartphone usage lead to more stress if the five closest friends have smartphones, compared to if they have none?’). Maybe you want to take notes of your examples – they can be quite helpful if you need to find your own research question.', None, '', None, None, None, None, None, None, None, 'University of Basel', 'University of Basel', 'University of Basel', None, 'TV', '10 Min.', 0, 'published', False, None, None, None, None, 20), (52, datetime.datetime(2020, 11, 2, 15, 9, 33, 774510, tzinfo=datetime.timezone.utc), datetime.datetime(2020, 11, 2, 15, 9, 37, 344950, tzinfo=datetime.timezone.utc), datetime.datetime(2020, 11, 2, 15, 9, 37, 344960, tzinfo=datetime.timezone.utc), False, 'How to find theories and hypothesis', 'How to find theories and hypothesis', 'How to find theories and hypothesis', None, '', '', '', None, '', None, None, None, '', 'how-to-find-theories-and-hypothesis', 'Psychological theories are one way to derive possible answers to your research question. In order to do so, you need to derive both the plausible and less plausible answers to your research question in a systematic, structured way (just saying ‘answer A could be true, or answer B could be wrong’ is not enough). This tutorial helps you to navigate psychological theories.\r\n{.lead}\r\n\r\nFirst of all, you should look for theories that make predictions for your questions. You can also look for data that helps you predict answers. (If you look for empirical data, write down how you searched for this data.)\r\n\r\n**What are theories?** \r\nTheories give different possible answers to your research question before gathering data. (To find a clear research question see [1.1. What is a good research question?](https://tales.nmc.unibas.ch/de/psychological-research-6/research-questions-and-theories-20/what-is-a-good-research-question-48).) A theory is ‘a supposition or a system of ideas intended to explain something, especially one based on general principles independent of the thing to be explained.’<sup>1</sup> Remember: good science aims at reliable and reproducible **general statements** (i.e. theories) about a particular aspects of reality that are as universal as possible. \r\n\r\nFor example, Pavlov investigated how individuals learn physiological reactions to the world. He always rang a bell when he was feeding his dogs. He observed that, after a while, the dogs started to salivate when the bell rang, without even seeing or smelling food. The figure below shows Pavlov’s resulting theory – the more general rules – of how individuals learn such physiological or other responses: the theory of Classical Conditioning. Note: this theory is more abstract than Pavlov’s observations. According to the theory of Classical Conditioning individuals will, after they experienced something that causes a physiological reaction together with something neutral (that by itself causes no reaction), substitute the original stimulus with the neutral stimulus and then the neutral stimulus will elicit a physiological reaction.\r\n\r\n![Chart showing Pavlov’s experiment](/media/tales/markdownx/8c595999-6222-498f-aee6-10c447312e8d.png)\r\n\r\nThis abstract theory can be applied not only to food, but to all sorts of learning situations! So, the theory helps to make predictions – before we have even conducted an experiment – about how people learn to dislike food or get addicted to substances or various other areas. \r\n<br/>\r\n**1. To find a suitable theorie you can have a look into psychology handbooks** (e.g., ‘The Cambridge Handbook of ...’, ‘Wiley Handbook of …’) or standard textbooks. Check if they contain chapters related to your topic and look for theories. Important: in the end you have to read and reference the original article with the theory, not a handbook or textbook! \r\n<br/>\r\n**2. You can also directly find scientific articles on your topic.** \r\na) Read summary papers (called ‘reviews’ or ‘meta analyses’) where you will find several theories, clustered by specific criteria, with a different view on a topic. Use ‘review’ or ‘meta-analysis’ as search keywords. Some of the important journals that publish reviews or meta-analyses are *Psychological Bulletin*, *Psychological Review* and *Review of General Psychology*. If there is no review article on your topic, do not worry. \r\nb) Read empirical research articles. Good news: there is no need to read every article completely, because according to APA style, theories and hypothesis are part of the introduction. You will usually find relevant theories at the beginning of the introduction or after the research question and literature review. Sometimes, there is an explicit theory section which might be called ‘model’, particularly in more formal papers, or ‘conceptual framework’. Careful: do not just look for the word ‘theory’. For example, a memory theory may be called memory model, memory viewpoint, memory position, memory approach, and so on. \r\n\r\nSome articles do not contain explicit theories or frameworks, rather they contain just a literature review. That’s actually good: you can read the literature review closely to find the hypothesis that will be tested in the paper. Check the literature review carefully: it will refer to other published articles which can contain other theories. It is always good to search for these articles as well and read them properly.\r\n\r\nThere is usually more than one theory for a research question, so you should always try to find further theoretical literature on your question of interest.\r\n\r\n**What to do after you have found theories?** \r\nWrite down what the theory predicts for your research question. Important: never mention a theory without the author, always write the name plus the author, e.g. ‘Query Theory’ (Johnson, Häubl, & Keinan; 2007). Sometimes there is no real name for a theory. In that case mention the author and come up with a good describing name by yourself.\r\n\r\nWrite down the prediction of the theories for your research question. Think through what you should observe (what participants would do), given that the theory you have found was actually true (even if you personally think this is not how people will do it). Note: in general one empirical test of a theory is not enough to falsify it, researchers test theories in various ways and derive plenty of empirical testable hypothesis from them.\r\n\r\n**What if you cannot find theories related to your research question?** \r\nFirst of all: ask your supervisors, they may have ideas where to find related works. While it is a good scientific practice to derive hypotheses from theoretical considerations and thus make the underlying assumptions and logic transparent and clear, it does not necessarily have to be the case that hypothesis are the result from theoretical considerations. In fact, it does not matter where you get your hypothesis from, as long as you can show how they relate (or oppose) to existing theories. But if you have no theory, you have to argue harder to justify your hypothesis and face more critical suspicion. \r\n\r\nNevertheless, most of fundamental scientific change started with a hypothesis not grounded in the current accepted theoretical framework. But they formed the foundation for better explanation, as the empirical evidence grew in their favor. This brings us to another important point on theories: even though their claims might sound universally true they might not exist forever. \r\n\r\n**What is a good theory?** \r\n1. Good theories target narrow questions. \r\nPavlov, for instance, answered the question of how individuals learn positive emotions for something neutral through experience. \r\n2. Good theories ignore parts of the reality. \r\nPavlov’s classical conditioning ignored that the first experiment was about food and a bell, but spoke about learning in more general terms. \r\n3. Theories clearly state their assumptions and principles they use. In plus, they avoids ambiguity and unnecessary assumptions. \r\nPavlov stated that he assumed ‘frequent presentation of neutral and positive stimulus’. \r\n4. Theories should NOT say: due to X there will be X. \r\nPavlov’s theory did not assume what it explains, rather it made a new prediction. \r\n5. Theories are always empirically grounded and they have to be falsifiable with an empirical test. \r\nPavlov’s classical conditioning is falsifiable because it makes predictions that we can test with experiments. \r\n\r\nOne comment regarding the last point: A statement that is always true, like ‘tomorrow it will rain or not’, is not useful. While it is an empirical testable statement, it is not useful in making predictions about tomorrow’s weather. The same holds for theories on the upcoming hair trend among livings in the intergalaxy 49. While for sure such a theory is intellectually interesting and fun, there is no way, yet, how one can test such a theory empirically. Therefore, it must remain speculative and of limited use for the knowledge of mankind. While this might sound like a harsh statement, consider that there are potentially many theories on the new hair trend among livings in the intergalaxy 49. How should we discriminate between them? How should we filter the most valid explanations? First, one can eliminate all logical inconsistent theories. Second, one might try to find plausibility criteria and thus eliminate another bunch of theories. However, we will still end up with a plethora of alternative and competing theories, all with different implications. The only way is an empirical test, which theory fails to explain more often the empirical world.\r\n\r\n<sup>1</sup> [Oxford Dictionary](https://en.oxforddictionaries.com/definition/theory), accessed September 10th, 2017.\r\n{.footnote}\r\n\r\n<br/>\r\n\r\n------\r\n\r\n \r\n###References\r\n\r\nBlackburn, S. (2005). *The Oxford dictionary of philosophy*. OUP Oxford.\r\n{.citation-indented}\r\n \r\nOnline Sources: \r\nOxford Dictionary: https://en.oxforddictionaries.com/definition/theory, accessed September 10th, 2017.', 'Psychological theories are one way to derive possible answers to your research question. In order to do so, you need to derive both the plausible and less plausible answers to your research question in a systematic, structured way (just saying ‘answer A could be true, or answer B could be wrong’ is not enough). This tutorial helps you to navigate psychological theories.\r\n{.lead}\r\n\r\nFirst of all, you should look for theories that make predictions for your questions. You can also look for data that helps you predict answers. (If you look for empirical data, write down how you searched for this data.)\r\n\r\n**What are theories?** \r\nTheories give different possible answers to your research question before gathering data. (To find a clear research question see [1.1. What is a good research question?](https://tales.nmc.unibas.ch/de/psychological-research-6/research-questions-and-theories-20/what-is-a-good-research-question-48).) A theory is ‘a supposition or a system of ideas intended to explain something, especially one based on general principles independent of the thing to be explained.’<sup>1</sup> Remember: good science aims at reliable and reproducible **general statements** (i.e. theories) about a particular aspects of reality that are as universal as possible. \r\n\r\nFor example, Pavlov investigated how individuals learn physiological reactions to the world. He always rang a bell when he was feeding his dogs. He observed that, after a while, the dogs started to salivate when the bell rang, without even seeing or smelling food. The figure below shows Pavlov’s resulting theory – the more general rules – of how individuals learn such physiological or other responses: the theory of Classical Conditioning. Note: this theory is more abstract than Pavlov’s observations. According to the theory of Classical Conditioning individuals will, after they experienced something that causes a physiological reaction together with something neutral (that by itself causes no reaction), substitute the original stimulus with the neutral stimulus and then the neutral stimulus will elicit a physiological reaction.\r\n\r\n![Chart showing Pavlov’s experiment](/media/markdownx/8c595999-6222-498f-aee6-10c447312e8d.png)\r\n\r\nThis abstract theory can be applied not only to food, but to all sorts of learning situations! So, the theory helps to make predictions – before we have even conducted an experiment – about how people learn to dislike food or get addicted to substances or various other areas. \r\n<br/>\r\n**1. To find a suitable theorie you can have a look into psychology handbooks** (e.g., ‘The Cambridge Handbook of ...’, ‘Wiley Handbook of …’) or standard textbooks. Check if they contain chapters related to your topic and look for theories. Important: in the end you have to read and reference the original article with the theory, not a handbook or textbook! \r\n<br/>\r\n**2. You can also directly find scientific articles on your topic.** \r\na) Read summary papers (called ‘reviews’ or ‘meta analyses’) where you will find several theories, clustered by specific criteria, with a different view on a topic. Use ‘review’ or ‘meta-analysis’ as search keywords. Some of the important journals that publish reviews or meta-analyses are *Psychological Bulletin*, *Psychological Review* and *Review of General Psychology*. If there is no review article on your topic, do not worry. \r\nb) Read empirical research articles. Good news: there is no need to read every article completely, because according to APA style, theories and hypothesis are part of the introduction. You will usually find relevant theories at the beginning of the introduction or after the research question and literature review. Sometimes, there is an explicit theory section which might be called ‘model’, particularly in more formal papers, or ‘conceptual framework’. Careful: do not just look for the word ‘theory’. For example, a memory theory may be called memory model, memory viewpoint, memory position, memory approach, and so on. \r\n\r\nSome articles do not contain explicit theories or frameworks, rather they contain just a literature review. That’s actually good: you can read the literature review closely to find the hypothesis that will be tested in the paper. Check the literature review carefully: it will refer to other published articles which can contain other theories. It is always good to search for these articles as well and read them properly.\r\n\r\nThere is usually more than one theory for a research question, so you should always try to find further theoretical literature on your question of interest.\r\n\r\n**What to do after you have found theories?** \r\nWrite down what the theory predicts for your research question. Important: never mention a theory without the author, always write the name plus the author, e.g. ‘Query Theory’ (Johnson, Häubl, & Keinan; 2007). Sometimes there is no real name for a theory. In that case mention the author and come up with a good describing name by yourself.\r\n\r\nWrite down the prediction of the theories for your research question. Think through what you should observe (what participants would do), given that the theory you have found was actually true (even if you personally think this is not how people will do it). Note: in general one empirical test of a theory is not enough to falsify it, researchers test theories in various ways and derive plenty of empirical testable hypothesis from them.\r\n\r\n**What if you cannot find theories related to your research question?** \r\nFirst of all: ask your supervisors, they may have ideas where to find related works. While it is a good scientific practice to derive hypotheses from theoretical considerations and thus make the underlying assumptions and logic transparent and clear, it does not necessarily have to be the case that hypothesis are the result from theoretical considerations. In fact, it does not matter where you get your hypothesis from, as long as you can show how they relate (or oppose) to existing theories. But if you have no theory, you have to argue harder to justify your hypothesis and face more critical suspicion. \r\n\r\nNevertheless, most of fundamental scientific change started with a hypothesis not grounded in the current accepted theoretical framework. But they formed the foundation for better explanation, as the empirical evidence grew in their favor. This brings us to another important point on theories: even though their claims might sound universally true they might not exist forever. \r\n\r\n**What is a good theory?** \r\n1. Good theories target narrow questions. \r\nPavlov, for instance, answered the question of how individuals learn positive emotions for something neutral through experience. \r\n2. Good theories ignore parts of the reality. \r\nPavlov’s classical conditioning ignored that the first experiment was about food and a bell, but spoke about learning in more general terms. \r\n3. Theories clearly state their assumptions and principles they use. In plus, they avoids ambiguity and unnecessary assumptions. \r\nPavlov stated that he assumed ‘frequent presentation of neutral and positive stimulus’. \r\n4. Theories should NOT say: due to X there will be X. \r\nPavlov’s theory did not assume what it explains, rather it made a new prediction. \r\n5. Theories are always empirically grounded and they have to be falsifiable with an empirical test. \r\nPavlov’s classical conditioning is falsifiable because it makes predictions that we can test with experiments. \r\n\r\nOne comment regarding the last point: A statement that is always true, like ‘tomorrow it will rain or not’, is not useful. While it is an empirical testable statement, it is not useful in making predictions about tomorrow’s weather. The same holds for theories on the upcoming hair trend among livings in the intergalaxy 49. While for sure such a theory is intellectually interesting and fun, there is no way, yet, how one can test such a theory empirically. Therefore, it must remain speculative and of limited use for the knowledge of mankind. While this might sound like a harsh statement, consider that there are potentially many theories on the new hair trend among livings in the intergalaxy 49. How should we discriminate between them? How should we filter the most valid explanations? First, one can eliminate all logical inconsistent theories. Second, one might try to find plausibility criteria and thus eliminate another bunch of theories. However, we will still end up with a plethora of alternative and competing theories, all with different implications. The only way is an empirical test, which theory fails to explain more often the empirical world.\r\n\r\n<sup>1</sup> [Oxford Dictionary](https://en.oxforddictionaries.com/definition/theory), accessed September 10th, 2017.\r\n{.footnote}\r\n\r\n<br/>\r\n\r\n------\r\n\r\n \r\n###References\r\n\r\nBlackburn, S. (2005). *The Oxford dictionary of philosophy*. OUP Oxford.\r\n{.citation-indented}\r\n \r\nOnline Sources: \r\nOxford Dictionary: https://en.oxforddictionaries.com/definition/theory, accessed September 10th, 2017.', 'Psychological theories are one way to derive possible answers to your research question. In order to do so, you need to derive both the plausible and less plausible answers to your research question in a systematic, structured way (just saying ‘answer A could be true, or answer B could be wrong’ is not enough). This tutorial helps you to navigate psychological theories.\r\n{.lead}\r\n\r\nFirst of all, you should look for theories that make predictions for your questions. You can also look for data that helps you predict answers. (If you look for empirical data, write down how you searched for this data.)\r\n\r\n**What are theories?** \r\nTheories give different possible answers to your research question before gathering data. (To find a clear research question see [1.1. What is a good research question?](https://tales.nmc.unibas.ch/de/psychological-research-6/research-questions-and-theories-20/what-is-a-good-research-question-48).) A theory is ‘a supposition or a system of ideas intended to explain something, especially one based on general principles independent of the thing to be explained.’<sup>1</sup> Remember: good science aims at reliable and reproducible **general statements** (i.e. theories) about a particular aspects of reality that are as universal as possible. \r\n\r\nFor example, Pavlov investigated how individuals learn physiological reactions to the world. He always rang a bell when he was feeding his dogs. He observed that, after a while, the dogs started to salivate when the bell rang, without even seeing or smelling food. The figure below shows Pavlov’s resulting theory – the more general rules – of how individuals learn such physiological or other responses: the theory of Classical Conditioning. Note: this theory is more abstract than Pavlov’s observations. According to the theory of Classical Conditioning individuals will, after they experienced something that causes a physiological reaction together with something neutral (that by itself causes no reaction), substitute the original stimulus with the neutral stimulus and then the neutral stimulus will elicit a physiological reaction.\r\n\r\n![Chart showing Pavlov’s experiment](/media/markdownx/8c595999-6222-498f-aee6-10c447312e8d.png)\r\n\r\nThis abstract theory can be applied not only to food, but to all sorts of learning situations! So, the theory helps to make predictions – before we have even conducted an experiment – about how people learn to dislike food or get addicted to substances or various other areas. \r\n<br/>\r\n**1. To find a suitable theorie you can have a look into psychology handbooks** (e.g., ‘The Cambridge Handbook of ...’, ‘Wiley Handbook of …’) or standard textbooks. Check if they contain chapters related to your topic and look for theories. Important: in the end you have to read and reference the original article with the theory, not a handbook or textbook! \r\n<br/>\r\n**2. You can also directly find scientific articles on your topic.** \r\na) Read summary papers (called ‘reviews’ or ‘meta analyses’) where you will find several theories, clustered by specific criteria, with a different view on a topic. Use ‘review’ or ‘meta-analysis’ as search keywords. Some of the important journals that publish reviews or meta-analyses are *Psychological Bulletin*, *Psychological Review* and *Review of General Psychology*. If there is no review article on your topic, do not worry. \r\nb) Read empirical research articles. Good news: there is no need to read every article completely, because according to APA style, theories and hypothesis are part of the introduction. You will usually find relevant theories at the beginning of the introduction or after the research question and literature review. Sometimes, there is an explicit theory section which might be called ‘model’, particularly in more formal papers, or ‘conceptual framework’. Careful: do not just look for the word ‘theory’. For example, a memory theory may be called memory model, memory viewpoint, memory position, memory approach, and so on. \r\n\r\nSome articles do not contain explicit theories or frameworks, rather they contain just a literature review. That’s actually good: you can read the literature review closely to find the hypothesis that will be tested in the paper. Check the literature review carefully: it will refer to other published articles which can contain other theories. It is always good to search for these articles as well and read them properly.\r\n\r\nThere is usually more than one theory for a research question, so you should always try to find further theoretical literature on your question of interest.\r\n\r\n**What to do after you have found theories?** \r\nWrite down what the theory predicts for your research question. Important: never mention a theory without the author, always write the name plus the author, e.g. ‘Query Theory’ (Johnson, Häubl, & Keinan; 2007). Sometimes there is no real name for a theory. In that case mention the author and come up with a good describing name by yourself.\r\n\r\nWrite down the prediction of the theories for your research question. Think through what you should observe (what participants would do), given that the theory you have found was actually true (even if you personally think this is not how people will do it). Note: in general one empirical test of a theory is not enough to falsify it, researchers test theories in various ways and derive plenty of empirical testable hypothesis from them.\r\n\r\n**What if you cannot find theories related to your research question?** \r\nFirst of all: ask your supervisors, they may have ideas where to find related works. While it is a good scientific practice to derive hypotheses from theoretical considerations and thus make the underlying assumptions and logic transparent and clear, it does not necessarily have to be the case that hypothesis are the result from theoretical considerations. In fact, it does not matter where you get your hypothesis from, as long as you can show how they relate (or oppose) to existing theories. But if you have no theory, you have to argue harder to justify your hypothesis and face more critical suspicion. \r\n\r\nNevertheless, most of fundamental scientific change started with a hypothesis not grounded in the current accepted theoretical framework. But they formed the foundation for better explanation, as the empirical evidence grew in their favor. This brings us to another important point on theories: even though their claims might sound universally true they might not exist forever. \r\n\r\n**What is a good theory?** \r\n1. Good theories target narrow questions. \r\nPavlov, for instance, answered the question of how individuals learn positive emotions for something neutral through experience. \r\n2. Good theories ignore parts of the reality. \r\nPavlov’s classical conditioning ignored that the first experiment was about food and a bell, but spoke about learning in more general terms. \r\n3. Theories clearly state their assumptions and principles they use. In plus, they avoids ambiguity and unnecessary assumptions. \r\nPavlov stated that he assumed ‘frequent presentation of neutral and positive stimulus’. \r\n4. Theories should NOT say: due to X there will be X. \r\nPavlov’s theory did not assume what it explains, rather it made a new prediction. \r\n5. Theories are always empirically grounded and they have to be falsifiable with an empirical test. \r\nPavlov’s classical conditioning is falsifiable because it makes predictions that we can test with experiments. \r\n\r\nOne comment regarding the last point: A statement that is always true, like ‘tomorrow it will rain or not’, is not useful. While it is an empirical testable statement, it is not useful in making predictions about tomorrow’s weather. The same holds for theories on the upcoming hair trend among livings in the intergalaxy 49. While for sure such a theory is intellectually interesting and fun, there is no way, yet, how one can test such a theory empirically. Therefore, it must remain speculative and of limited use for the knowledge of mankind. While this might sound like a harsh statement, consider that there are potentially many theories on the new hair trend among livings in the intergalaxy 49. How should we discriminate between them? How should we filter the most valid explanations? First, one can eliminate all logical inconsistent theories. Second, one might try to find plausibility criteria and thus eliminate another bunch of theories. However, we will still end up with a plethora of alternative and competing theories, all with different implications. The only way is an empirical test, which theory fails to explain more often the empirical world.\r\n\r\n<sup>1</sup> [Oxford Dictionary](https://en.oxforddictionaries.com/definition/theory), accessed September 10th, 2017.\r\n{.footnote}\r\n\r\n<br/>\r\n\r\n------\r\n\r\n \r\n###References\r\n\r\nBlackburn, S. (2005). *The Oxford dictionary of philosophy*. OUP Oxford.\r\n{.citation-indented}\r\n \r\nOnline Sources: \r\nOxford Dictionary: https://en.oxforddictionaries.com/definition/theory, accessed September 10th, 2017.', None, '', None, None, None, None, None, None, None, 'University of Basel', 'University of Basel', 'University of Basel', None, 'TT', '15 min.', 1, 'published', False, None, None, None, None, 20), (53, datetime.datetime(2020, 11, 2, 15, 9, 33, 774510, tzinfo=datetime.timezone.utc), datetime.datetime(2020, 11, 2, 15, 9, 37, 347538, tzinfo=datetime.timezone.utc), datetime.datetime(2020, 11, 2, 15, 9, 37, 347549, tzinfo=datetime.timezone.utc), False, 'What is a good source?', 'What is a good source?', 'What is a good source?', None, 'Select and evaluate literature', 'Select and evaluate literature', 'Select and evaluate literature', None, '', None, None, None, '', 'what-is-a-good-source', 'If you start to inform yourself about a research topic, you might start with surfing the web and having a look at Wikipedia or other online sources. Most of the sources are written by people who have a clue about the topic or consider themselves to be an expert (e.g. Wikipedia). It is totally okay to take this as a first step, but these sources do not necessarily fulfill the criteria of reliability and replicability which characterize good academic research. This means, you need to search for sources that satisfy academic standards.\r\n{.lead}\r\n\r\n**Which sources should I use?** \r\nUsing good scientific sources is key for academic work. Do not cite Wikipedia or web-pages in your seminar papers (unless your research is about Wikipedia or web-pages). Instead: \r\n➔ **Use peer-reviewed articles**: Research literature consists of peer-reviewed and non-peer-reviewed publications. Peer-reviewed means that a publications went through a lengthy review process before publication. Peer-reviewed articles look like the articles you may have read in seminars. Wikipedia, Websites, Youtube, or common books are usually not peer-reviewed (except for books containing collections of scientific articles). So, how do you find peer-reviewed articles? If you search in Google Scholar, you will get both peer-reviewed and non-peer-reviewed results. If you use IsiWebOfKnowledge, PsychInfo, or Psyndex, you will find mostly peer-reviewed articles. \r\n➔ **Use psychology journals**: There is a rule of thumb that says if a journal has the word ‘psychology’ in the title, it’s a psychology journal. Below you will find a PDF with a selection of journals, sorted roughly by importance (top journals are bigger journals), that you may wish to download. A full, more-or-less accurate, list of psychology journals can be found at [Wikipedia](https://en.wikipedia.org/wiki/List_of_psychology_journals).\r\n\r\n**I found many articles on my topic, which ones should I use?** \r\n**Rule A: Use well-cited work.** \r\nWork that is cited more often is more important. Citations are a good indicator for important research, since other researchers also mention this work (caution: sometimes they mention it because it is wrong!). But, an article from 1990 will be more-cited than an article from 2016 simply because it is older. So, check citations per year. More is better, and more than 20 citations per year are good. But, be careful with looking only at citation counts as sometimes there is a tendency of citations among peers. \r\n**Rule B: Use important (psychology) journals.** \r\nAmong psychological journals there are some small and some really important journals. Journals are ranked by an impact factor (IF), which counts the number of citation of the average article published in the journal. The famous journals *Science* or *Nature* have IFs above 30. In psychology a 5-year IF that is bigger than 2 is rather good. But be aware, the IF is far from perfect. For a critical discussion read [this article](http://www.sciencemag.org/news/2016/07/hate-journal-impact-factors-new-study-gives-you-one-more-reason). \r\n**Rule C: Clarity as a soft-quality criterion.** \r\nGood articles should be written in a clear and precise way. The authors must argue with clarity within the whole paper. If they are not good in highlighting the structure of their argument and each necessary building block, they might have trouble to bring their clear thoughts across to the reader and their thought process is not finished yet. Thus, a clearly written and precise paper is also an useful indicator for a good source. (But be careful: if a paper is clearly written and understandable, this does not imply that you can read it on the fly, you might need to spend some time thinking about it yourself.)\r\n\r\n**How to judge non-peer-reviewed publications like books?** \r\nThe quality of non-peer-reviewed publications is harder to judge and requires more self-responsibility. Handle them with more care. Not-yet published manuscripts that are under review can be available as so-called working papers; they might mark the research frontier and thus might be worth reading. Books are usually not peer-reviewed, but if they are from a good publisher or the authors are well-known and established researchers, they can be high in their quality, too. Often, books provide summaries of previously peer-reviewed work.\r\n\r\n**How can I use psychological search engines?** \r\nThere are several web-based search engines for your literature research, like [Google Scholar](https://scholar.google.de) and [Web of Science](http://webofknowledge.com/) that you can use. There are also special psychological search engines, like Psyndex, or PsychInfo that will give you search results which are usually only from psychological sources (unlike Google Scholar, for instance). You can also specify the topic to ‘psychology’ in [Web of Science](http://webofknowledge.com/). In the following video step, we take a closer look at Google Scholar.', 'If you start to inform yourself about a research topic, you might start with surfing the web and having a look at Wikipedia or other online sources. Most of the sources are written by people who have a clue about the topic or consider themselves to be an expert (e.g. Wikipedia). It is totally okay to take this as a first step, but these sources do not necessarily fulfill the criteria of reliability and replicability which characterize good academic research. This means, you need to search for sources that satisfy academic standards.\r\n{.lead}\r\n\r\n**Which sources should I use?** \r\nUsing good scientific sources is key for academic work. Do not cite Wikipedia or web-pages in your seminar papers (unless your research is about Wikipedia or web-pages). Instead: \r\n➔ **Use peer-reviewed articles**: Research literature consists of peer-reviewed and non-peer-reviewed publications. Peer-reviewed means that a publications went through a lengthy review process before publication. Peer-reviewed articles look like the articles you may have read in seminars. Wikipedia, Websites, Youtube, or common books are usually not peer-reviewed (except for books containing collections of scientific articles). So, how do you find peer-reviewed articles? If you search in Google Scholar, you will get both peer-reviewed and non-peer-reviewed results. If you use IsiWebOfKnowledge, PsychInfo, or Psyndex, you will find mostly peer-reviewed articles. \r\n➔ **Use psychology journals**: There is a rule of thumb that says if a journal has the word ‘psychology’ in the title, it’s a psychology journal. Below you will find a PDF with a selection of journals, sorted roughly by importance (top journals are bigger journals), that you may wish to download. A full, more-or-less accurate, list of psychology journals can be found at [Wikipedia](https://en.wikipedia.org/wiki/List_of_psychology_journals).\r\n\r\n**I found many articles on my topic, which ones should I use?** \r\n**Rule A: Use well-cited work.** \r\nWork that is cited more often is more important. Citations are a good indicator for important research, since other researchers also mention this work (caution: sometimes they mention it because it is wrong!). But, an article from 1990 will be more-cited than an article from 2016 simply because it is older. So, check citations per year. More is better, and more than 20 citations per year are good. But, be careful with looking only at citation counts as sometimes there is a tendency of citations among peers. \r\n**Rule B: Use important (psychology) journals.** \r\nAmong psychological journals there are some small and some really important journals. Journals are ranked by an impact factor (IF), which counts the number of citation of the average article published in the journal. The famous journals *Science* or *Nature* have IFs above 30. In psychology a 5-year IF that is bigger than 2 is rather good. But be aware, the IF is far from perfect. For a critical discussion read [this article](http://www.sciencemag.org/news/2016/07/hate-journal-impact-factors-new-study-gives-you-one-more-reason). \r\n**Rule C: Clarity as a soft-quality criterion.** \r\nGood articles should be written in a clear and precise way. The authors must argue with clarity within the whole paper. If they are not good in highlighting the structure of their argument and each necessary building block, they might have trouble to bring their clear thoughts across to the reader and their thought process is not finished yet. Thus, a clearly written and precise paper is also an useful indicator for a good source. (But be careful: if a paper is clearly written and understandable, this does not imply that you can read it on the fly, you might need to spend some time thinking about it yourself.)\r\n\r\n**How to judge non-peer-reviewed publications like books?** \r\nThe quality of non-peer-reviewed publications is harder to judge and requires more self-responsibility. Handle them with more care. Not-yet published manuscripts that are under review can be available as so-called working papers; they might mark the research frontier and thus might be worth reading. Books are usually not peer-reviewed, but if they are from a good publisher or the authors are well-known and established researchers, they can be high in their quality, too. Often, books provide summaries of previously peer-reviewed work.\r\n\r\n**How can I use psychological search engines?** \r\nThere are several web-based search engines for your literature research, like [Google Scholar](https://scholar.google.de) and [Web of Science](http://webofknowledge.com/) that you can use. There are also special psychological search engines, like Psyndex, or PsychInfo that will give you search results which are usually only from psychological sources (unlike Google Scholar, for instance). You can also specify the topic to ‘psychology’ in [Web of Science](http://webofknowledge.com/). In the following video step, we take a closer look at Google Scholar.', 'If you start to inform yourself about a research topic, you might start with surfing the web and having a look at Wikipedia or other online sources. Most of the sources are written by people who have a clue about the topic or consider themselves to be an expert (e.g. Wikipedia). It is totally okay to take this as a first step, but these sources do not necessarily fulfill the criteria of reliability and replicability which characterize good academic research. This means, you need to search for sources that satisfy academic standards.\r\n{.lead}\r\n\r\n**Which sources should I use?** \r\nUsing good scientific sources is key for academic work. Do not cite Wikipedia or web-pages in your seminar papers (unless your research is about Wikipedia or web-pages). Instead: \r\n➔ **Use peer-reviewed articles**: Research literature consists of peer-reviewed and non-peer-reviewed publications. Peer-reviewed means that a publications went through a lengthy review process before publication. Peer-reviewed articles look like the articles you may have read in seminars. Wikipedia, Websites, Youtube, or common books are usually not peer-reviewed (except for books containing collections of scientific articles). So, how do you find peer-reviewed articles? If you search in Google Scholar, you will get both peer-reviewed and non-peer-reviewed results. If you use IsiWebOfKnowledge, PsychInfo, or Psyndex, you will find mostly peer-reviewed articles. \r\n➔ **Use psychology journals**: There is a rule of thumb that says if a journal has the word ‘psychology’ in the title, it’s a psychology journal. Below you will find a PDF with a selection of journals, sorted roughly by importance (top journals are bigger journals), that you may wish to download. A full, more-or-less accurate, list of psychology journals can be found at [Wikipedia](https://en.wikipedia.org/wiki/List_of_psychology_journals).\r\n\r\n**I found many articles on my topic, which ones should I use?** \r\n**Rule A: Use well-cited work.** \r\nWork that is cited more often is more important. Citations are a good indicator for important research, since other researchers also mention this work (caution: sometimes they mention it because it is wrong!). But, an article from 1990 will be more-cited than an article from 2016 simply because it is older. So, check citations per year. More is better, and more than 20 citations per year are good. But, be careful with looking only at citation counts as sometimes there is a tendency of citations among peers. \r\n**Rule B: Use important (psychology) journals.** \r\nAmong psychological journals there are some small and some really important journals. Journals are ranked by an impact factor (IF), which counts the number of citation of the average article published in the journal. The famous journals *Science* or *Nature* have IFs above 30. In psychology a 5-year IF that is bigger than 2 is rather good. But be aware, the IF is far from perfect. For a critical discussion read [this article](http://www.sciencemag.org/news/2016/07/hate-journal-impact-factors-new-study-gives-you-one-more-reason). \r\n**Rule C: Clarity as a soft-quality criterion.** \r\nGood articles should be written in a clear and precise way. The authors must argue with clarity within the whole paper. If they are not good in highlighting the structure of their argument and each necessary building block, they might have trouble to bring their clear thoughts across to the reader and their thought process is not finished yet. Thus, a clearly written and precise paper is also an useful indicator for a good source. (But be careful: if a paper is clearly written and understandable, this does not imply that you can read it on the fly, you might need to spend some time thinking about it yourself.)\r\n\r\n**How to judge non-peer-reviewed publications like books?** \r\nThe quality of non-peer-reviewed publications is harder to judge and requires more self-responsibility. Handle them with more care. Not-yet published manuscripts that are under review can be available as so-called working papers; they might mark the research frontier and thus might be worth reading. Books are usually not peer-reviewed, but if they are from a good publisher or the authors are well-known and established researchers, they can be high in their quality, too. Often, books provide summaries of previously peer-reviewed work.\r\n\r\n**How can I use psychological search engines?** \r\nThere are several web-based search engines for your literature research, like [Google Scholar](https://scholar.google.de) and [Web of Science](http://webofknowledge.com/) that you can use. There are also special psychological search engines, like Psyndex, or PsychInfo that will give you search results which are usually only from psychological sources (unlike Google Scholar, for instance). You can also specify the topic to ‘psychology’ in [Web of Science](http://webofknowledge.com/). In the following video step, we take a closer look at Google Scholar.', None, '', None, None, None, None, None, None, None, 'University of Basel', 'University of Basel', 'University of Basel', None, 'TT', '10 min.', 2, 'published', False, None, None, None, None, 20), (54, datetime.datetime(2020, 11, 2, 15, 9, 33, 774510, tzinfo=datetime.timezone.utc), datetime.datetime(2020, 11, 2, 15, 9, 37, 349568, tzinfo=datetime.timezone.utc), datetime.datetime(2020, 11, 2, 15, 9, 37, 349578, tzinfo=datetime.timezone.utc), False, 'Find articles with Google Scholar', 'Find articles with Google Scholar', 'Find articles with Google Scholar', None, '', '', '', None, '', None, None, None, '', 'find-articles-with-google-scholar', 'The following tutorial shows you the most important functions of Google Scholar, a search engine for scientific literature. It offers one effective way to find a range of scientific papers and books. \r\n{.lead}\r\n\r\nGoogle Scholar is a very easy to use search engine, but its results are very broad and sometimes they are unspecific. If you are a member of an university and you want to precisely search through psychology articles, you can activate the VPN service of your University and use the [Web of Science](http://webofknowledge.com/) within the area ‘psychology’ or other psychological search engines like [Psyndex and PsychInfo](http://ovidsp.ovid.com/ovidweb.cgi?T=JS&MODE=ovid&PAGE=main&NEWS=n&DBC=y&D=psyh,psyn,pskm).\r\n\r\nWatch Jana Jarecki explaining the basics of Google Scholar:\r\n\r\n![embed](https://vimeo.com/252880905)\r\n\r\nNote: to download full texts you may need a license (ask your library). Other search engines – which may be interesting because they are more specific to psychology – are the [APA PsycNet](http://psycnet.apa.org/search?fa=search.advancedSearchForm) or the [Web of Science](http://apps.webofknowledge.com). You may want to check with your local university library if they have access to those databases as well.', 'The following tutorial shows you the most important functions of Google Scholar, a search engine for scientific literature. It offers one effective way to find a range of scientific papers and books. \r\n{.lead}\r\n\r\nGoogle Scholar is a very easy to use search engine, but its results are very broad and sometimes they are unspecific. If you are a member of an university and you want to precisely search through psychology articles, you can activate the VPN service of your University and use the [Web of Science](http://webofknowledge.com/) within the area ‘psychology’ or other psychological search engines like [Psyndex and PsychInfo](http://ovidsp.ovid.com/ovidweb.cgi?T=JS&MODE=ovid&PAGE=main&NEWS=n&DBC=y&D=psyh,psyn,pskm).\r\n\r\nWatch Jana Jarecki explaining the basics of Google Scholar:\r\n\r\n![embed](https://vimeo.com/252880905)\r\n\r\nNote: to download full texts you may need a license (ask your library). Other search engines – which may be interesting because they are more specific to psychology – are the [APA PsycNet](http://psycnet.apa.org/search?fa=search.advancedSearchForm) or the [Web of Science](http://apps.webofknowledge.com). You may want to check with your local university library if they have access to those databases as well.', 'The following tutorial shows you the most important functions of Google Scholar, a search engine for scientific literature. It offers one effective way to find a range of scientific papers and books. \r\n{.lead}\r\n\r\nGoogle Scholar is a very easy to use search engine, but its results are very broad and sometimes they are unspecific. If you are a member of an university and you want to precisely search through psychology articles, you can activate the VPN service of your University and use the [Web of Science](http://webofknowledge.com/) within the area ‘psychology’ or other psychological search engines like [Psyndex and PsychInfo](http://ovidsp.ovid.com/ovidweb.cgi?T=JS&MODE=ovid&PAGE=main&NEWS=n&DBC=y&D=psyh,psyn,pskm).\r\n\r\nWatch Jana Jarecki explaining the basics of Google Scholar:\r\n\r\n![embed](https://vimeo.com/252880905)\r\n\r\nNote: to download full texts you may need a license (ask your library). Other search engines – which may be interesting because they are more specific to psychology – are the [APA PsycNet](http://psycnet.apa.org/search?fa=search.advancedSearchForm) or the [Web of Science](http://apps.webofknowledge.com). You may want to check with your local university library if they have access to those databases as well.', None, '', None, None, None, None, None, None, None, 'University of Basel', 'University of Basel', 'University of Basel', None, 'TV', '6 min.', 3, 'published', False, None, None, None, None, 20), (55, datetime.datetime(2020, 11, 2, 15, 9, 33, 774510, tzinfo=datetime.timezone.utc), datetime.datetime(2021, 11, 30, 8, 7, 5, 674199, tzinfo=datetime.timezone.utc), datetime.datetime(2021, 11, 30, 8, 7, 5, 635725, tzinfo=datetime.timezone.utc), False, 'When to cite?', 'When to cite?', 'When to cite?', None, 'Citation guidelines', 'Citation guidelines', 'Citation guidelines', None, '', None, None, None, '', 'when-to-cite', 'Scientific knowledge evolves thanks to the contributions of many different scientists (VandenBos, 2010). Therefore, every scientific work needs to be placed into context in order to show how it refers to theories in the field and findings of earlier work. Correct citations document the impact of a given work on scientific theory and show how the work further extends previous results. This presentation helps to understand when citations are needed. \r\n{.lead}\r\n\r\nIt is important to credit the work of other researchers that you draw on in your own inquiry. By doing so, you avoid plagiarism. Examine the following issues that are further explored in the video:\r\n\r\n> Question: When do I need a citation? \r\n> Answer: Whenever a statement is not self-evident.\r\n\r\n> Question: How often can I use ‘direct quotes’ in my text? \r\n> Answer: As rarely as possible, as often as absolutely necessary. Reformulate in your own words – use direct quotes only for definitions. \r\n\r\n> Question: When do I need multiple citations?\r\n> Answer: With general statements, multiple topics, and topics investigated by many studies.\r\n\r\n\r\nWatch Sharon Steinemann explaining how to follow the citation guidelines:\r\n\r\n![embed](https://vimeo.com/250771421/8426302d96)\r\n\r\n<br/>\r\n\r\n------\r\n\r\n###References (in English APA style)\r\n\r\nMaglio, S. J., Trope, Y., & Liberman, N. (2013). Distance from a distance: Psychological distance reduces sensitivity to any further psychological distance. *Journal of Experimental Psychology: General, 142*, 644-657. [https://doi.org/10.1037/a0030258](https://doi.org/10.1037/a0030258)\r\n\r\n{.citation-indented}\r\n\r\nNosofsky, R. M. (1988). Similarity, frequency, and category representations. *Journal of Experimental Psychology: Learning, Memory, and Cognition, 14*, 54–65. doi:10.1037//0278-7393.14.1.54\r\n{.citation-indented}\r\n\r\nSoderberg, C. K., Callahan, S. P., Kochersberger, A. O., Amit, E., & Ledgerwood, A. (2015). The effects of psychological distance on abstraction: Two meta-analyses. *Psychological Bulletin, 141*, 525-548. [https://doi.org/10.1037/bul0000005](https://doi.org/10.1037/bul0000005) \r\n{.citation-indented}\r\n\r\nTrope, Y., & Liberman, N. (2010). Construal-level theory of psychological distance. *Psychological Review, 117*, 440-463. [https://doi.org/10.1037/a0018963](https://doi.org/10.1037/a0018963) \r\n{.citation-indented}\r\n\r\n\r\nVandenBos, G. R. (Ed.). (2010). *Publication Manual of the American Psychological Association* (6th ed.). Washington, DC: American Psychological Association.\r\n{.citation-indented}\r\n\r\nExample 3 was adapted from Nosofsky, 1988, p. 54; Examples 4 and 5 were adapted from Soderberg, Callahan, Kochersberger, Amit, & Ledgerwood, 2015, p. 525; Examples 6 and 7 from Trope & Liberman, 2010, p. 440 and p. 645; Example 8 from Maglio et al., 2013, p. 655.', 'Scientific knowledge evolves thanks to the contributions of many different scientists (VandenBos, 2010). Therefore, every scientific work needs to be placed into context in order to show how it refers to theories in the field and findings of earlier work. Correct citations document the impact of a given work on scientific theory and show how the work further extends previous results. This presentation helps to understand when citations are needed. \r\n{.lead}\r\n\r\nIt is important to credit the work of other researchers that you draw on in your own inquiry. By doing so, you avoid plagiarism. Examine the following issues that are further explored in the video:\r\n\r\n> Question: When do I need a citation? \r\n> Answer: Whenever a statement is not self-evident.\r\n\r\n> Question: How often can I use ‘direct quotes’ in my text? \r\n> Answer: As rarely as possible, as often as absolutely necessary. Reformulate in your own words – use direct quotes only for definitions. \r\n\r\n> Question: When do I need multiple citations?\r\n> Answer: With general statements, multiple topics, and topics investigated by many studies.\r\n\r\n\r\nWatch Sharon Steinemann explaining how to follow the citation guidelines:\r\n\r\n![embed](https://vimeo.com/250771421/8426302d96)\r\n\r\n<br/>\r\n\r\n------\r\n\r\n###References (in English APA style)\r\n\r\nMaglio, S. J., Trope, Y., & Liberman, N. (2013). Distance from a distance: Psychological distance reduces sensitivity to any further psychological distance. *Journal of Experimental Psychology: General, 142*, 644-657. [https://doi.org/10.1037/a0030258](https://doi.org/10.1037/a0030258)\r\n\r\n{.citation-indented}\r\n\r\nNosofsky, R. M. (1988). Similarity, frequency, and category representations. *Journal of Experimental Psychology: Learning, Memory, and Cognition, 14*, 54–65. doi:10.1037//0278-7393.14.1.54\r\n{.citation-indented}\r\n\r\nSoderberg, C. K., Callahan, S. P., Kochersberger, A. O., Amit, E., & Ledgerwood, A. (2015). The effects of psychological distance on abstraction: Two meta-analyses. *Psychological Bulletin, 141*, 525-548. [https://doi.org/10.1037/bul0000005](https://doi.org/10.1037/bul0000005) \r\n{.citation-indented}\r\n\r\nTrope, Y., & Liberman, N. (2010). Construal-level theory of psychological distance. *Psychological Review, 117*, 440-463. [https://doi.org/10.1037/a0018963](https://doi.org/10.1037/a0018963) \r\n{.citation-indented}\r\n\r\n\r\nVandenBos, G. R. (Ed.). (2010). *Publication Manual of the American Psychological Association* (6th ed.). Washington, DC: American Psychological Association.\r\n{.citation-indented}\r\n\r\nExample 3 was adapted from Nosofsky, 1988, p. 54; Examples 4 and 5 were adapted from Soderberg, Callahan, Kochersberger, Amit, & Ledgerwood, 2015, p. 525; Examples 6 and 7 from Trope & Liberman, 2010, p. 440 and p. 645; Example 8 from Maglio et al., 2013, p. 655.', 'Scientific knowledge evolves thanks to the contributions of many different scientists (VandenBos, 2010). Therefore, every scientific work needs to be placed into context in order to show how it refers to theories in the field and findings of earlier work. Correct citations document the impact of a given work on scientific theory and show how the work further extends previous results. This presentation helps to understand when citations are needed. \r\n{.lead}\r\n\r\nIt is important to credit the work of other researchers that you draw on in your own inquiry. By doing so, you avoid plagiarism. Examine the following issues that are further explored in the video:\r\n\r\n> Question: When do I need a citation? \r\n> Answer: Whenever a statement is not self-evident.\r\n\r\n> Question: How often can I use ‘direct quotes’ in my text? \r\n> Answer: As rarely as possible, as often as absolutely necessary. Reformulate in your own words – use direct quotes only for definitions. \r\n\r\n> Question: When do I need multiple citations?\r\n> Answer: With general statements, multiple topics, and topics investigated by many studies.\r\n\r\n\r\nWatch Sharon Steinemann explaining how to follow the citation guidelines:\r\n\r\n![embed](https://vimeo.com/250771421/8426302d96)\r\n\r\n<br/>\r\n\r\n------\r\n\r\n###References (in English APA style)\r\n\r\nMaglio, S. J., Trope, Y., & Liberman, N. (2013). Distance from a distance: Psychological distance reduces sensitivity to any further psychological distance. *Journal of Experimental Psychology: General, 142*, 644-657. doi: 10.1037/a0030258\r\n{.citation-indented}\r\n\r\nNosofsky, R. M. (1988). Similarity, frequency, and category representations. *Journal of Experimental Psychology: Learning, Memory, and Cognition, 14*, 54–65. doi:10.1037//0278-7393.14.1.54\r\n{.citation-indented}\r\n\r\nSoderberg, C. K., Callahan, S. P., Kochersberger, A. O., Amit, E., & Ledgerwood, A. (2015). The effects of psychological distance on abstraction: Two meta-analyses. *Psychological Bulletin, 141*, 525-548. doi: 10.1037/bul0000005\r\n{.citation-indented}\r\n\r\nTrope, Y., & Liberman, N. (2010). Construal-level theory of psychological distance. *Psychological Review, 117*, 440-463. doi: 10.1037/a0018963\r\n{.citation-indented}\r\n\r\nVandenBos, G. R. (Ed.). (2010). *Publication Manual of the American Psychological Association* (6th ed.). Washington, DC: American Psychological Association.\r\n{.citation-indented}\r\n\r\nExample 3 was adapted from Nosofsky, 1988, p. 54; Examples 4 and 5 were adapted from Soderberg, Callahan, Kochersberger, Amit, & Ledgerwood, 2015, p. 525; Examples 6 and 7 from Trope & Liberman, 2010, p. 440 and p. 645; Example 8 from Maglio et al., 2013, p. 655.', '', '', '', '', '', None, None, None, None, 'University of Basel', 'University of Basel', 'University of Basel', '', 'TV', '6 min.', 4, 'published', False, None, None, None, None, 20), (56, datetime.datetime(2020, 11, 2, 15, 9, 33, 774510, tzinfo=datetime.timezone.utc), datetime.datetime(2021, 11, 30, 12, 39, 5, 344991, tzinfo=datetime.timezone.utc), datetime.datetime(2021, 11, 30, 12, 39, 5, 319635, tzinfo=datetime.timezone.utc), False, 'How to cite?', 'How to cite?', 'How to cite?', None, 'APA citation format', 'APA citation format', 'APA citation format', None, '', None, None, None, '', 'how-to-cite', 'As you format citations and reference lists, you need to follow certain rules and the practice used in scientific writing. This article outlines how citations are formatted in psychology (other scientific fields may differ).\r\n{.lead}\r\n\r\nThe manner of formatting which is used in psychology is called the **APA style**. The abbreviation APA refers to the American Psychological Association, this association offers a “publication manual” which specifies the formatting style of papers to be published in the field of psychology. The next paragraphs teach you how to format citations of sources according to the APA Publication Manual in its Seventh Edition (APA 7th). Parts of this material were adopted from Prof. Dr. Greifeneder with permission. You may find examples and more information on the [APA webpage](https://apastyle.apa.org/). \r\n \r\n<br>\r\n\r\n#Citations consist of two parts\r\n \r\nThe APA specifies how we as psychologists format the citations of sources in scientific papers. Citations appear in two places in a paper. First, in a paper’s main text we cite for example “Risky choice has been studied in evolutionary psychology (Houston & McNamara, 1988)”. This in-text citation in parenthesis is short and only mentions the author name(s) and the publication year of the source. Besides the in-text citation, at the end of the main text, we insert a much longer citation into a section titled “References”. The references section contains a longer reference to each source that was cited in-text. The longer reference includes author(s), year, title, journal title, journal issue number, and page numbers. The APA defines rules for formatting these citations in psychology. The APA rules exist because if the citations look similar in all psychological papers it makes it a lot easier for readers to find what they are looking for.\r\n\r\n<br>\r\n\r\n#Citing sources: parentheses or embedded\r\n\r\nWhen we write, we can either use parentheses or embed sources within the text itself. Using parentheses we can cite for example like so: “Risky choice has been studied in the field of evolutionary psychology (Houston & McNamara, 1988)”. Alternatively, embedded in the written text, we can write this as “Houston and McNamara (1988) have studied risky choice in the field of evolutionary psychology.” In papers written in German versus English papers there is a slight difference regarding the comma (see the PDF below).\r\n\r\n<br>\r\n\r\n#Writing content: paraphrasing vs. direct quote\r\n \r\nWe can write about others’ ideas, theories, results, etc. either by directly quoting word by word (this is not common) or by describing others’ ideas in our own words (paraphrasing, this is very common). Paraphrasing is how we as scientists mostly write papers. A paraphrase should be followed by a citation in brackets “()”, like “Risky choice has been studied in the field of evolutionary psychology (Houston & McNamara, 1988)”. A direct quote needs quotation marks and must be followed by the quoted text’s page number, for instance: "... we thought that we would have no difficulty in finding an unambiguous answer" (Herzog & Hertwig, 2013, p. 191). Note: Direct quotes longer than 40 words are formatted indented and without quotation marks. Please keep in mind that in psychology we commonly **avoid direct quotes** in our scientific writing but **mostly paraphrase** and summarize other content.\r\n\r\n<br>\r\n\r\n#Finding the correct format\r\n\r\nPlease click on the link that describes best what you want to cite. It will take you to the respective instruction. (At the end of this article, you will find a PDF version of this format guide in case you would like to download and print it.)\r\n\r\nYou are citing **one source**:\r\n \r\n* [with one or two authors](#oneauthor) \r\n* [with three and more authors](#threeauthors)\r\n \r\nYou are citing **multiple sources**:\r\n \r\n* [by different authors](#differentauthors)\r\n* by the same authors \r\na) [in different years](#differentyears) \r\nb) [in the same year](#sameyear) \r\n\r\n<br>\r\n\r\n#The references section\r\n\r\nIn the references section, all references are listed that appear in the text (and only these). The list is **sorted in ascending order by last name and year**. The last names of authors and their initials are listed. In article titles, only the first word or words after a colon or period are capitalized. The lines of a reference are indented after the first line. As in text, double line spacing is required. For the three most important types of references, examples are listed in the following – for more information see the APA manual.\r\n\r\n---\r\n\r\n###Articles \r\n\r\n`Author`, `A. A.` (`year`). `Article title.` *`Journal Title, volume no.`*(issue no.), `xxx-xxx.` https://doi.org/`10.xxxxx` \r\n\r\n<br>\r\n\r\n* The article title is lowercase, except names and words after a full stop (.) or a colon (:). The journal title is italicized and the capitalization is maintained. After the volume (italicized), add theissue (in parentheses), the page numbers, the digital object identifier (doi). The doi is a unique hyperlink to find the paper online and dois can be found at https://www.crossref.org/guestquery/. \r\n* Please note that the issue number can be omitted, if a journal has no issue numbers. \r\n\r\n**Example**: \r\nHiggins, E. T. (1998). The aboutness principle: A pervasive influence on human inference. *Social Cognition, 16(1)*, 173-198. https://doi.org/10.1521/soco.1998.16.1.173 \r\n{.footnote} \r\n\r\n---\r\n\r\n###Books \r\n\r\n`Author`, `A. A.` (`year`). *`Book title`*. `Publisher.` \r\n`Author`, `A. A.` (`year`). *`Book title`* [maybe e-reader version]. http://xxxxx\r\n\r\n<br>\r\n\r\n* The book title is italicized. List the publisher or, for online-only books, the webpage.\r\n\r\n**Example**: \r\nMalhotra, D., & Bazerman, M. (2008). *Negotiation genius: How to overcome obstacles and achieve brilliant results at the bargaining table and beyond.* Bantam Books. \r\n{.footnote} \r\n \r\n---\r\n\r\n###Chapter in edited book\r\n`Author`, `A. A.` (`year`). `Chapter title.` In `E. E. Editor` (Ed.), *`Book title`* (pp. `xx-xx`). `Publisher`. \r\n\r\n<br>\r\n\r\n* List editors (initials before the last name). List page numbers.\r\n* German: Ed. / Eds. = Hrsg. / pp. = S. \r\n\r\n**Examples**: \r\nWinkielman, P., Schwarz, N., Fazendeiro, T. A., & Reber, R. (2003). The hedonic marking of processing fluency: Implications for evaluative judgment. In J. Musch & K. C. Klauer (Eds.), *The psychology of evaluation: Affective processes in cognition and emotion* (pp. 189-217). Lawrence Erlbaum Associates.\r\n{.footnote}\r\n\r\n---\r\n\r\n<br>\r\n\r\n#Format guide for citations in the text \r\n\r\n##<a name="oneauthor"></a>One source, one or two authors\r\n\r\n---\r\n\r\n###Written in parentheses \r\n1. (`name`, `year`) \r\n2. (`name1` & `name2`, `year`) \r\n \r\n**Example**: \r\n1. …found the effect (Higgins, 1998). \r\n2. …found the effect (Reber & Schwarz, 1999).\r\n{.footnote} \r\n\r\n---\r\n \r\n###Embedded \r\n 1. `name` (`year`) \r\n 2. `name1` and `name2` (`year`) \r\n \r\n**Examples**: \r\n1. Higgins (1998) pointed out… \r\n2. Reber and Schwarz (1999) conducted a study… \r\n{.footnote} \r\n\r\n<br>\r\n \r\n##<a name="threeauthors"></a>One source, three and more authors\r\n\r\n---\r\n\r\n###Written in parentheses \r\n(`name1 et al.`, `year`)\r\n \r\n**Example**: \r\n(Meyer et al., 2015)\r\n{.footnote}\r\n \r\n---\r\n\r\n###Embedded \r\n`name1 et al.` (`year`)\r\n\r\n**Example**: \r\nMeyer et al. (2015) wanted to know… \r\n{.footnote}\r\n\r\n<br>\r\n\r\n* Write the first author’s name and use “et al.” to replace the remaining authors; “et al.” means “and others” in Latin.\r\n* Note that there is one exception to using “et al.”: if there are two sources like “Smith, Wang, & Miller, 2018” and “Smith, Brown, & Thompson, 2018”, that both share the first author and year, then both of those would both be abbreviated to “Smith et al., 2018”. The citation “Smith et al., 2018” could refer to “Smith, Wang, & Miller, 2018” or to “Smith, Brown, & Thompson, 2018” and it is unclear which source it refers to. In this case, we spell out all authors’ names until the first discriminating name. Please, see https://apastyle.apa.org/style-grammar-guidelines/citations/basic-principles/same-year-first-author\r\n\r\n---\r\n\r\n<br>\r\n\r\n##<a name="differentauthors"></a>Multiple sources by different authors \r\n\r\n----\r\n\r\n###Written in parentheses: alphabetical order, separated by semicolons\r\n\r\n* In which cases you need to give more than one reference is explained in the [previous chapter](https://tales.nmc.unibas.ch/de/conducting-psychological-research-6/research-questions-and-theories-20/when-to-cite-citation-guidelines-55).\r\n \r\n**Example**: \r\n(Higgins, 1998; Reber & Schwarz, 1999)\r\n{.footnote} \r\n\r\n---\r\n\r\n<br>\r\n\r\n\r\n##<a name="differentyears"></a>Multiple sources by the same authors in different years\r\n\r\n---\r\n\r\n###Written in parentheses: chronological order, separation by commas, ‘in press’ last\r\n \r\n**Example**: \r\n(Reber & Schwarz, 1999, 2001)\r\n {.footnote} \r\n\r\n---\r\n\r\n###Embedded: Chronological order, separated by commas, ‘in press’ last\r\n \r\n**Example**: \r\nReber and Schwarz (1999, 2001) investigated...\r\n {.footnote} \r\n\r\n---\r\n\r\n<br>\r\n\r\n##<a name="sameyear"></a>Multiple sources by the same authors in the same year\r\n\r\n---\r\n\r\n###Written in parentheses \r\n(`names`, `year a`, `year b`)\r\n \r\n**Example**: \r\n(Leary, 2005a, 2005b)\r\n {.footnote} \r\n \r\n---\r\n\r\n###Embedded\r\nnames (`year a`, `year b`)\r\n \r\n**Example**: \r\nLeary (2005a, 2005b) found...\r\n {.footnote} \r\n \r\n------\r\n\r\n\r\n<br>\r\n\r\n<br>\r\n\r\n\r\n###References (in English APA style)\r\n\r\nHiggins, E. T. (1998). The aboutness principle: A pervasive influence on human inference. *Social Cognition, 16*, 173-198. https://doi.org/10.1521/soco.1998.16.1.173\r\n{.citation-indented}\r\n\r\nLeary, M. R. (2005a). Interpersonal cognition and the quest for social acceptance: Inside the sociometer. In M. W. Baldwin (Ed.), *Interpersonal cognition* (pp. 85-102). New York, NY: The Guilford Press.\r\n{.citation-indented}\r\n\r\nLeary, M. R. (2005b). Sociometer theory and the pursuit of relational value: Getting to the root of self-esteem. *European Review of Social Psychology, 16*, 75-111. https://doi.org/10.1080/10463280540000007\r\n{.citation-indented}\r\n\r\nMalhotra, D., & Bazerman, M. (2008). *Negotiation genius: How to overcome obstacles and achieve brilliant results at the bargaining table and beyond.* New York, NY: Bantam Books.\r\n{.citation-indented}\r\n\r\nMeyer, A., Frederick, S., Burnham, T., Guevara Pinto, J., Boyer, T., Ball, L., . . . Schuldt, J. (2015). Disfluent fonts don’t help people solve math problems. *Journal of Experimental Psychology: General, 144*, e16-e30. https://doi.org/10.1037/xge0000049\r\n{.citation-indented}\r\n\r\nMüller, P., Greifeneder, R., Stahlberg, D., Van den Bos, K., & Bless, H. (2010). Shaping cooperation behavior: The role of accessibility experiences. *European Journal of Social Psychology, 40*, 178-187. https://doi.org/10.1002/ejsp.632\r\n{.citation-indented}\r\n\r\nReber, R., & Schwarz, N. (1999). Effects of perceptual fluency on judgments of truth. *Consciousness and Cognition: An International Journal, 8*, 338-342. https://doi.org/10.1006/ccog.1999.0386\r\n{.citation-indented}\r\n\r\nReber, R., & Schwarz, N. (2001). The hot fringes of consciousness: Perceptual fluency and affect. *Consciousness and Emotion, 2*, 223-231. https://doi.org/10.1075/ce.2.2.03reb\r\n{.citation-indented}\r\n\r\nWinkielman, P., Schwarz, N., Fazendeiro, T. A., & Reber, R. (2003). The hedonic marking of processing fluency: Implications for evaluative judgment. In J. Musch & K. C. Klauer (Eds.), *The psychology of evaluation: Affective processes in cognition and emotion* (pp. 189-217). Mahwah, NJ: Lawrence Erlbaum Associates.\r\n{.citation-indented}\r\n\r\n\r\nVandenBos, G. R. (Ed.). (2010). *Publication Manual of the American Psychological Association* (6th ed.). Washington, DC: American Psychological Association.\r\n{.citation-indented}\r\n\r\nHerzog, S. M., & Hertwig, R. (2013). The ecological validity of fluency. In C. Unkelbach & R. Greifeneder (Eds.), *The experience of thinking: How the fluency of mental processes influences cognition and behavior* (pp. 190-219). Hove, United Kingdom: Psychology Press.\r\n{.citation-indented}', 'As you format citations and reference lists, you need to follow certain rules and the practice used in scientific writing. This article outlines how citations are formatted in psychology (other scientific fields may differ).\r\n{.lead}\r\n\r\nThe manner of formatting which is used in psychology is called the **APA style**. The abbreviation APA refers to the American Psychological Association, this association offers a “publication manual” which specifies the formatting style of papers to be published in the field of psychology. The next paragraphs teach you how to format citations of sources according to the APA Publication Manual in its Seventh Edition (APA 7th). Parts of this material were adopted from Prof. Dr. Greifeneder with permission. You may find examples and more information on the [APA webpage](https://apastyle.apa.org/). \r\n \r\n<br>\r\n\r\n#Citations consist of two parts\r\n \r\nThe APA specifies how we as psychologists format the citations of sources in scientific papers. Citations appear in two places in a paper. First, in a paper’s main text we cite for example “Risky choice has been studied in evolutionary psychology (Houston & McNamara, 1988)”. This in-text citation in parenthesis is short and only mentions the author name(s) and the publication year of the source. Besides the in-text citation, at the end of the main text, we insert a much longer citation into a section titled “References”. The references section contains a longer reference to each source that was cited in-text. The longer reference includes author(s), year, title, journal title, journal issue number, and page numbers. The APA defines rules for formatting these citations in psychology. The APA rules exist because if the citations look similar in all psychological papers it makes it a lot easier for readers to find what they are looking for.\r\n\r\n<br>\r\n\r\n#Citing sources: parentheses or embedded\r\n\r\nWhen we write, we can either use parentheses or embed sources within the text itself. Using parentheses we can cite for example like so: “Risky choice has been studied in the field of evolutionary psychology (Houston & McNamara, 1988)”. Alternatively, embedded in the written text, we can write this as “Houston and McNamara (1988) have studied risky choice in the field of evolutionary psychology.” In papers written in German versus English papers there is a slight difference regarding the comma (see the PDF below).\r\n\r\n<br>\r\n\r\n#Writing content: paraphrasing vs. direct quote\r\n \r\nWe can write about others’ ideas, theories, results, etc. either by directly quoting word by word (this is not common) or by describing others’ ideas in our own words (paraphrasing, this is very common). Paraphrasing is how we as scientists mostly write papers. A paraphrase should be followed by a citation in brackets “()”, like “Risky choice has been studied in the field of evolutionary psychology (Houston & McNamara, 1988)”. A direct quote needs quotation marks and must be followed by the quoted text’s page number, for instance: "... we thought that we would have no difficulty in finding an unambiguous answer" (Herzog & Hertwig, 2013, p. 191). Note: Direct quotes longer than 40 words are formatted indented and without quotation marks. Please keep in mind that in psychology we commonly **avoid direct quotes** in our scientific writing but **mostly paraphrase** and summarize other content.\r\n\r\n<br>\r\n\r\n#Finding the correct format\r\n\r\nPlease click on the link that describes best what you want to cite. It will take you to the respective instruction. (At the end of this article, you will find a PDF version of this format guide in case you would like to download and print it.)\r\n\r\nYou are citing **one source**:\r\n \r\n* [with one or two authors](#oneauthor) \r\n* [with three and more authors](#threeauthors)\r\n \r\nYou are citing **multiple sources**:\r\n \r\n* [by different authors](#differentauthors)\r\n* by the same authors \r\na) [in different years](#differentyears) \r\nb) [in the same year](#sameyear) \r\n\r\n<br>\r\n\r\n#The references section\r\n\r\nIn the references section, all references are listed that appear in the text (and only these). The list is **sorted in ascending order by last name and year**. The last names of authors and their initials are listed. In article titles, only the first word or words after a colon or period are capitalized. The lines of a reference are indented after the first line. As in text, double line spacing is required. For the three most important types of references, examples are listed in the following – for more information see the APA manual.\r\n\r\n---\r\n\r\n###Articles \r\n\r\n`Author`, `A. A.` (`year`). `Article title.` *`Journal Title, volume no.`*(issue no.), `xxx-xxx.` https://doi.org/`10.xxxxx` \r\n\r\n<br>\r\n\r\n* The article title is lowercase, except names and words after a full stop (.) or a colon (:). The journal title is italicized and the capitalization is maintained. After the volume (italicized), add theissue (in parentheses), the page numbers, the digital object identifier (doi). The doi is a unique hyperlink to find the paper online and dois can be found at https://www.crossref.org/guestquery/. \r\n* Please note that the issue number can be omitted, if a journal has no issue numbers. \r\n\r\n**Example**: \r\nHiggins, E. T. (1998). The aboutness principle: A pervasive influence on human inference. *Social Cognition, 16(1)*, 173-198. https://doi.org/10.1521/soco.1998.16.1.173 \r\n{.footnote} \r\n\r\n---\r\n\r\n###Books \r\n\r\n`Author`, `A. A.` (`year`). *`Book title`*. `Publisher.` \r\n`Author`, `A. A.` (`year`). *`Book title`* [maybe e-reader version]. http://xxxxx\r\n\r\n<br>\r\n\r\n* The book title is italicized. List the publisher or, for online-only books, the webpage.\r\n\r\n**Example**: \r\nMalhotra, D., & Bazerman, M. (2008). *Negotiation genius: How to overcome obstacles and achieve brilliant results at the bargaining table and beyond.* Bantam Books. \r\n{.footnote} \r\n \r\n---\r\n\r\n###Chapter in edited book\r\n`Author`, `A. A.` (`year`). `Chapter title.` In `E. E. Editor` (Ed.), *`Book title`* (pp. `xx-xx`). `Publisher`. \r\n\r\n<br>\r\n\r\n* List editors (initials before the last name). List page numbers.\r\n* German: Ed. / Eds. = Hrsg. / pp. = S. \r\n\r\n**Examples**: \r\nWinkielman, P., Schwarz, N., Fazendeiro, T. A., & Reber, R. (2003). The hedonic marking of processing fluency: Implications for evaluative judgment. In J. Musch & K. C. Klauer (Eds.), *The psychology of evaluation: Affective processes in cognition and emotion* (pp. 189-217). Lawrence Erlbaum Associates.\r\n{.footnote}\r\n\r\n---\r\n\r\n<br>\r\n\r\n#Format guide for citations in the text \r\n\r\n##<a name="oneauthor"></a>One source, one or two authors\r\n\r\n---\r\n\r\n###Written in parentheses \r\n1. (`name`, `year`) \r\n2. (`name1` & `name2`, `year`) \r\n \r\n**Example**: \r\n1. …found the effect (Higgins, 1998). \r\n2. …found the effect (Reber & Schwarz, 1999).\r\n{.footnote} \r\n\r\n---\r\n \r\n###Embedded \r\n 1. `name` (`year`) \r\n 2. `name1` and `name2` (`year`) \r\n \r\n**Examples**: \r\n1. Higgins (1998) pointed out… \r\n2. Reber and Schwarz (1999) conducted a study… \r\n{.footnote} \r\n\r\n<br>\r\n \r\n##<a name="threeauthors"></a>One source, three and more authors\r\n\r\n---\r\n\r\n###Written in parentheses \r\n(`name1 et al.`, `year`)\r\n \r\n**Example**: \r\n(Meyer et al., 2015)\r\n{.footnote}\r\n \r\n---\r\n\r\n###Embedded \r\n`name1 et al.` (`year`)\r\n\r\n**Example**: \r\nMeyer et al. (2015) wanted to know… \r\n{.footnote}\r\n\r\n<br>\r\n\r\n* Write the first author’s name and use “et al.” to replace the remaining authors; “et al.” means “and others” in Latin.\r\n* Note that there is one exception to using “et al.”: if there are two sources like “Smith, Wang, & Miller, 2018” and “Smith, Brown, & Thompson, 2018”, that both share the first author and year, then both of those would both be abbreviated to “Smith et al., 2018”. The citation “Smith et al., 2018” could refer to “Smith, Wang, & Miller, 2018” or to “Smith, Brown, & Thompson, 2018” and it is unclear which source it refers to. In this case, we spell out all authors’ names until the first discriminating name. Please, see https://apastyle.apa.org/style-grammar-guidelines/citations/basic-principles/same-year-first-author\r\n\r\n---\r\n\r\n<br>\r\n\r\n##<a name="differentauthors"></a>Multiple sources by different authors \r\n\r\n----\r\n\r\n###Written in parentheses: alphabetical order, separated by semicolons\r\n\r\n* In which cases you need to give more than one reference is explained in the [previous chapter](https://tales.nmc.unibas.ch/de/conducting-psychological-research-6/research-questions-and-theories-20/when-to-cite-citation-guidelines-55).\r\n \r\n**Example**: \r\n(Higgins, 1998; Reber & Schwarz, 1999)\r\n{.footnote} \r\n\r\n---\r\n\r\n<br>\r\n\r\n\r\n##<a name="differentyears"></a>Multiple sources by the same authors in different years\r\n\r\n---\r\n\r\n###Written in parentheses: chronological order, separation by commas, ‘in press’ last\r\n \r\n**Example**: \r\n(Reber & Schwarz, 1999, 2001)\r\n {.footnote} \r\n\r\n---\r\n\r\n###Embedded: Chronological order, separated by commas, ‘in press’ last\r\n \r\n**Example**: \r\nReber and Schwarz (1999, 2001) investigated...\r\n {.footnote} \r\n\r\n---\r\n\r\n<br>\r\n\r\n##<a name="sameyear"></a>Multiple sources by the same authors in the same year\r\n\r\n---\r\n\r\n###Written in parentheses \r\n(`names`, `year a`, `year b`)\r\n \r\n**Example**: \r\n(Leary, 2005a, 2005b)\r\n {.footnote} \r\n \r\n---\r\n\r\n###Embedded\r\nnames (`year a`, `year b`)\r\n \r\n**Example**: \r\nLeary (2005a, 2005b) found...\r\n {.footnote} \r\n \r\n------\r\n\r\n\r\n<br>\r\n\r\n<br>\r\n\r\n\r\n###References (in English APA style)\r\n\r\nHiggins, E. T. (1998). The aboutness principle: A pervasive influence on human inference. *Social Cognition, 16*, 173-198. https://doi.org/10.1521/soco.1998.16.1.173\r\n{.citation-indented}\r\n\r\nLeary, M. R. (2005a). Interpersonal cognition and the quest for social acceptance: Inside the sociometer. In M. W. Baldwin (Ed.), *Interpersonal cognition* (pp. 85-102). New York, NY: The Guilford Press.\r\n{.citation-indented}\r\n\r\nLeary, M. R. (2005b). Sociometer theory and the pursuit of relational value: Getting to the root of self-esteem. *European Review of Social Psychology, 16*, 75-111. https://doi.org/10.1080/10463280540000007\r\n{.citation-indented}\r\n\r\nMalhotra, D., & Bazerman, M. (2008). *Negotiation genius: How to overcome obstacles and achieve brilliant results at the bargaining table and beyond.* New York, NY: Bantam Books.\r\n{.citation-indented}\r\n\r\nMeyer, A., Frederick, S., Burnham, T., Guevara Pinto, J., Boyer, T., Ball, L., . . . Schuldt, J. (2015). Disfluent fonts don’t help people solve math problems. *Journal of Experimental Psychology: General, 144*, e16-e30. https://doi.org/10.1037/xge0000049\r\n{.citation-indented}\r\n\r\nMüller, P., Greifeneder, R., Stahlberg, D., Van den Bos, K., & Bless, H. (2010). Shaping cooperation behavior: The role of accessibility experiences. *European Journal of Social Psychology, 40*, 178-187. https://doi.org/10.1002/ejsp.632\r\n{.citation-indented}\r\n\r\nReber, R., & Schwarz, N. (1999). Effects of perceptual fluency on judgments of truth. *Consciousness and Cognition: An International Journal, 8*, 338-342. https://doi.org/10.1006/ccog.1999.0386\r\n{.citation-indented}\r\n\r\nReber, R., & Schwarz, N. (2001). The hot fringes of consciousness: Perceptual fluency and affect. *Consciousness and Emotion, 2*, 223-231. https://doi.org/10.1075/ce.2.2.03reb\r\n{.citation-indented}\r\n\r\nWinkielman, P., Schwarz, N., Fazendeiro, T. A., & Reber, R. (2003). The hedonic marking of processing fluency: Implications for evaluative judgment. In J. Musch & K. C. Klauer (Eds.), *The psychology of evaluation: Affective processes in cognition and emotion* (pp. 189-217). Mahwah, NJ: Lawrence Erlbaum Associates.\r\n{.citation-indented}\r\n\r\n\r\nVandenBos, G. R. (Ed.). (2010). *Publication Manual of the American Psychological Association* (6th ed.). Washington, DC: American Psychological Association.\r\n{.citation-indented}\r\n\r\nHerzog, S. M., & Hertwig, R. (2013). The ecological validity of fluency. In C. Unkelbach & R. Greifeneder (Eds.), *The experience of thinking: How the fluency of mental processes influences cognition and behavior* (pp. 190-219). Hove, United Kingdom: Psychology Press.\r\n{.citation-indented}', 'As you format citations and reference lists, you need to adhere to certain rules and follow the practice used in scientific texts. This article outlines how this is done in psychology. Other scientific fields may use different styles. \r\n{.lead}\r\n\r\nThe manner of formatting which is used in psychology is called the APA style. The abbreviation refers to the American Psychological Association. The next paragraphs specify how to format quotes according to the Publication Manual of the American Psychological Association, Sixth Edition, in short APA 6th (VandenBos, 2010). You find further information on the [APA style blog](http://blog.apastyle.org/). Parts of the following material were adopted from Prof. Dr. Rainer Greifeneder with his kind permission.\r\n \r\n**Citations consist of two parts** \r\nCitations are marked by a short mention of author(s) and year **in the main text** and a full reference to the complete source in the section ‘References’ **at the end of the paper**. The APA defined rules for formatting both, and your references need to adhere exactly to these rules. Rules ensure the standardization of references across all psychological research articles; this helps readers to orient themselves quickly. \r\n \r\n**Paraphrasing versus direct quotation** \r\nYou can explain others’ ideas, theories, results, etc. either by describing the content in your words **(paraphrased)** or you can quote them word by word **(directly quoted)**. Paraphrasing is more common. \r\n➔ Every paraphrase should be followed by an expression in brackets that contains the family name(s) of the author(s) and the year of publication, for instance (Herzog & Hertwig, 2013). \r\n➔ When quoting directly, set the text in quotation marks. After a direct quote, you always cite the exact page number, for example: ‘. . . we thought that we would have no difficulty in finding an unambiguous answer . . .’ (Herzog & Hertwig, 2013, p. 191). Please note: direct quotes that are longer than 40 words are indented and the quotation marks are omitted. \r\n \r\n**Citing in parentheses or embedded** \r\nIn a text, the authors can either be written in parentheses or can be embedded in the text itself. In German (GER) versus English (EN) texts, the commas in citations differ with more than two names. The following decision diagram helps you to find the correct formatting for your references.\r\n\r\n**Finding the correct format** \r\nIn the ‘downloads’ section below you will find a PDF with a format guide. It helps you to find the correct format for different scenarios.\r\n\r\n<br/>\r\n\r\n------\r\n\r\n###References (in English APA style)\r\n\r\nVandenBos, G. R. (Ed.). (2010). *Publication Manual of the American Psychological Association* (6th ed.). Washington, DC: American Psychological Association.\r\n{.citation-indented}\r\n\r\nHerzog, S. M., & Hertwig, R. (2013). The ecological validity of fluency. In C. Unkelbach & R. Greifeneder (Eds.), *The experience of thinking: How the fluency of mental processes influences cognition and behavior* (pp. 190-219). Hove, United Kingdom: Psychology Press.\r\n{.citation-indented}', '', '', '', '', '', None, None, None, None, 'University of Basel', 'University of Basel', 'University of Basel', '', 'TT', '15 min.', 5, 'published', False, None, None, None, None, 20), (57, datetime.datetime(2020, 11, 2, 15, 9, 33, 774510, tzinfo=datetime.timezone.utc), datetime.datetime(2020, 11, 2, 15, 9, 37, 354643, tzinfo=datetime.timezone.utc), datetime.datetime(2020, 11, 2, 15, 9, 37, 354654, tzinfo=datetime.timezone.utc), False, 'How to remember what you read', 'How to remember what you read', 'How to remember what you read', None, 'Organize your literature', 'Organize your literature', 'Organize your literature', None, '', None, None, None, '', 'how-to-remember-what-you-read', "Most successful authors read a lot and keep track of the papers and articles that are relevant to a topic. A literature management program is an ideal tool to help with this task. \r\n{.lead}\r\n\r\nImagine you and your colleague are preparing the final draft of your seminar paper. Time is running out, the deadline is approaching. The following quirky dialogue unfolds:\r\n \r\n> You: Which paper was it again, that mentioned our main theory?? \r\n> Your colleague: Don’t remember. Let me search for the papers… I can’t find them…\r\n \r\nAvoid this by using a tool called literature management program. Why? You will read a lot before you write your scientific article or seminar thesis. Some papers will be relevant, others will not advance your research. However, it is difficult to know at the beginning what you need in the end. If you do not want to lose information or even yourself in this process there is one wise approach: **Organize what you read when you read it.**\r\n \r\n**What is the aim of literature management?** \r\nLiterature management keeps your sources organized, helps you find PDFs again, assists you to remember what was in which article, and it makes it **easier to cite all your papers in APA format** (see [1.6 How to cite?](https://tales.nmc.unibas.ch/de/conducting-psychological-research-6/research-questions-and-theories-20/how-to-cite-56)).\r\n \r\n**Can’t I simply put all literature in folders on my computer?** \r\nSure, you can. However, programs are usually more user-friendly. If you really want to save your literature in folders, use a system! It is advisable to group literature by similar subjects using sub-folders and sub-sub-folders, for example:\r\n\r\n> .../user/Documents/Literature/Mood_Management/Mood_Induction/. \r\n\r\nYou should name files consistently. You could label each document by applying the same sequence, for instance:\r\n\r\n> NameFirstAuthor_keyword_publication_year\r\n\r\nas in:\r\n\r\n> Birk_self-esteem_2015.pdf. \r\n\r\nIf you proceed by saving the literature you use in a systematic way into folders, you get the benefit that you do not need to become familiar with a new software. There is also a downside: You may easily lose track if you collect a lot of literature. And your system will not provide help for citations in APA format; you will have to ensure the correct formatting on your own.\r\n \r\n**How does literature management work?** \r\nLiterature management works in three easy steps: \r\n1. **Find** an article you want to store \r\n2. **Add** the article to Zotero (or any other program you use) \r\n3. **Correct** the data of the article \r\n \r\n**OK. But where can I get a literature management program?** \r\nThere are many simple to use programs you can download from the internet. Some are free, for others you need to pay a fee. Here are two examples that you can use without charge: \r\n➔ **Zotero**: A free application for collecting, organizing, citing, and sharing literature, available for Mac, Windows, and Linux. It can be downloaded from the [Zotero Webpage](https://www.zotero.org/). \r\n➔ **Mendeley**: A free application for collecting, organizing, reading, citing, sharing, and storing literature. It features also elements for social networking. Mendeley is available for Mac and Windows [here](https://www.mendeley.com/).\r\n\r\n**Share a library with your group** \r\nIt helps your research if everybody in your group sees the articles the other group members have found. You can share your literature via Zotero. If you would like to do this, one of your group needs a Zotero account. If you do not have one, you need to register [here](https://www.zotero.org/user/register/). After that, select ‘Group’ in the top navigation bar, then find the submenu ‘Create a New Group’. Chose a name for your group and the group type (public, public with closed membership, private). Use the ‘Members settings’ to ‘invite members’ and insert the email addresses or the usernames of the members into the textbox.\r\n \r\n**Organize articles by topic: tags** \r\nTags are short keywords that help you group your literature by topic. Thus, the keywords 'academic writing', and 'experimental design' might be added as tags to the following book: \r\nHarris, P. (2008). Designing and Reporting Experiments in Psychology.\r\n\r\nIf you want to see the tags in Zotero, click on an article and choose ‘tags’ in the navigation on the right side (Zotero adds tags automatically) You can also add your own tags or change the auto-tags. \r\nZotero allows you to search for articles or filter them by tags, for instance, if you want to see all the articles you have gathered that refer to a certain theory. To do so, you can either type the tag into the search field of Zotero at the upper right corner or click on a tag from the list in the bottom left corner.\r\n \r\nYou find further information on tags [here](https://www.zotero.org/support/collections_and_tags).\r\n \r\n**Find duplicated articles** \r\nSometimes an article is added twice. With Zotero, you can easily find duplicates by going to ‘Dublicate Items (*Eintragsdubletten*)’ in the left side navigation, and then click on ‘Merge Items (*2 Einträge zusammenführen*)’ at the upper right corner. Thus, you merge two identical articles.", "Most successful authors read a lot and keep track of the papers and articles that are relevant to a topic. A literature management program is an ideal tool to help with this task. \r\n{.lead}\r\n\r\nImagine you and your colleague are preparing the final draft of your seminar paper. Time is running out, the deadline is approaching. The following quirky dialogue unfolds:\r\n \r\n> You: Which paper was it again, that mentioned our main theory?? \r\n> Your colleague: Don’t remember. Let me search for the papers… I can’t find them…\r\n \r\nAvoid this by using a tool called literature management program. Why? You will read a lot before you write your scientific article or seminar thesis. Some papers will be relevant, others will not advance your research. However, it is difficult to know at the beginning what you need in the end. If you do not want to lose information or even yourself in this process there is one wise approach: **Organize what you read when you read it.**\r\n \r\n**What is the aim of literature management?** \r\nLiterature management keeps your sources organized, helps you find PDFs again, assists you to remember what was in which article, and it makes it **easier to cite all your papers in APA format** (see [1.6 How to cite?](https://tales.nmc.unibas.ch/de/conducting-psychological-research-6/research-questions-and-theories-20/how-to-cite-56)).\r\n \r\n**Can’t I simply put all literature in folders on my computer?** \r\nSure, you can. However, programs are usually more user-friendly. If you really want to save your literature in folders, use a system! It is advisable to group literature by similar subjects using sub-folders and sub-sub-folders, for example:\r\n\r\n> .../user/Documents/Literature/Mood_Management/Mood_Induction/. \r\n\r\nYou should name files consistently. You could label each document by applying the same sequence, for instance:\r\n\r\n> NameFirstAuthor_keyword_publication_year\r\n\r\nas in:\r\n\r\n> Birk_self-esteem_2015.pdf. \r\n\r\nIf you proceed by saving the literature you use in a systematic way into folders, you get the benefit that you do not need to become familiar with a new software. There is also a downside: You may easily lose track if you collect a lot of literature. And your system will not provide help for citations in APA format; you will have to ensure the correct formatting on your own.\r\n \r\n**How does literature management work?** \r\nLiterature management works in three easy steps: \r\n1. **Find** an article you want to store \r\n2. **Add** the article to Zotero (or any other program you use) \r\n3. **Correct** the data of the article \r\n \r\n**OK. But where can I get a literature management program?** \r\nThere are many simple to use programs you can download from the internet. Some are free, for others you need to pay a fee. Here are two examples that you can use without charge: \r\n➔ **Zotero**: A free application for collecting, organizing, citing, and sharing literature, available for Mac, Windows, and Linux. It can be downloaded from the [Zotero Webpage](https://www.zotero.org/). \r\n➔ **Mendeley**: A free application for collecting, organizing, reading, citing, sharing, and storing literature. It features also elements for social networking. Mendeley is available for Mac and Windows [here](https://www.mendeley.com/).\r\n\r\n**Share a library with your group** \r\nIt helps your research if everybody in your group sees the articles the other group members have found. You can share your literature via Zotero. If you would like to do this, one of your group needs a Zotero account. If you do not have one, you need to register [here](https://www.zotero.org/user/register/). After that, select ‘Group’ in the top navigation bar, then find the submenu ‘Create a New Group’. Chose a name for your group and the group type (public, public with closed membership, private). Use the ‘Members settings’ to ‘invite members’ and insert the email addresses or the usernames of the members into the textbox.\r\n \r\n**Organize articles by topic: tags** \r\nTags are short keywords that help you group your literature by topic. Thus, the keywords 'academic writing', and 'experimental design' might be added as tags to the following book: \r\nHarris, P. (2008). Designing and Reporting Experiments in Psychology.\r\n\r\nIf you want to see the tags in Zotero, click on an article and choose ‘tags’ in the navigation on the right side (Zotero adds tags automatically) You can also add your own tags or change the auto-tags. \r\nZotero allows you to search for articles or filter them by tags, for instance, if you want to see all the articles you have gathered that refer to a certain theory. To do so, you can either type the tag into the search field of Zotero at the upper right corner or click on a tag from the list in the bottom left corner.\r\n \r\nYou find further information on tags [here](https://www.zotero.org/support/collections_and_tags).\r\n \r\n**Find duplicated articles** \r\nSometimes an article is added twice. With Zotero, you can easily find duplicates by going to ‘Dublicate Items (*Eintragsdubletten*)’ in the left side navigation, and then click on ‘Merge Items (*2 Einträge zusammenführen*)’ at the upper right corner. Thus, you merge two identical articles.", "Most successful authors read a lot and keep track of the papers and articles that are relevant to a topic. A literature management program is an ideal tool to help with this task. \r\n{.lead}\r\n\r\nImagine you and your colleague are preparing the final draft of your seminar paper. Time is running out, the deadline is approaching. The following quirky dialogue unfolds:\r\n \r\n> You: Which paper was it again, that mentioned our main theory?? \r\n> Your colleague: Don’t remember. Let me search for the papers… I can’t find them…\r\n \r\nAvoid this by using a tool called literature management program. Why? You will read a lot before you write your scientific article or seminar thesis. Some papers will be relevant, others will not advance your research. However, it is difficult to know at the beginning what you need in the end. If you do not want to lose information or even yourself in this process there is one wise approach: **Organize what you read when you read it.**\r\n \r\n**What is the aim of literature management?** \r\nLiterature management keeps your sources organized, helps you find PDFs again, assists you to remember what was in which article, and it makes it **easier to cite all your papers in APA format** (see [1.6 How to cite?](https://tales.nmc.unibas.ch/de/conducting-psychological-research-6/research-questions-and-theories-20/how-to-cite-56)).\r\n \r\n**Can’t I simply put all literature in folders on my computer?** \r\nSure, you can. However, programs are usually more user-friendly. If you really want to save your literature in folders, use a system! It is advisable to group literature by similar subjects using sub-folders and sub-sub-folders, for example:\r\n\r\n> .../user/Documents/Literature/Mood_Management/Mood_Induction/. \r\n\r\nYou should name files consistently. You could label each document by applying the same sequence, for instance:\r\n\r\n> NameFirstAuthor_keyword_publication_year\r\n\r\nas in:\r\n\r\n> Birk_self-esteem_2015.pdf. \r\n\r\nIf you proceed by saving the literature you use in a systematic way into folders, you get the benefit that you do not need to become familiar with a new software. There is also a downside: You may easily lose track if you collect a lot of literature. And your system will not provide help for citations in APA format; you will have to ensure the correct formatting on your own.\r\n \r\n**How does literature management work?** \r\nLiterature management works in three easy steps: \r\n1. **Find** an article you want to store \r\n2. **Add** the article to Zotero (or any other program you use) \r\n3. **Correct** the data of the article \r\n \r\n**OK. But where can I get a literature management program?** \r\nThere are many simple to use programs you can download from the internet. Some are free, for others you need to pay a fee. Here are two examples that you can use without charge: \r\n➔ **Zotero**: A free application for collecting, organizing, citing, and sharing literature, available for Mac, Windows, and Linux. It can be downloaded from the [Zotero Webpage](https://www.zotero.org/). \r\n➔ **Mendeley**: A free application for collecting, organizing, reading, citing, sharing, and storing literature. It features also elements for social networking. Mendeley is available for Mac and Windows [here](https://www.mendeley.com/).\r\n\r\n**Share a library with your group** \r\nIt helps your research if everybody in your group sees the articles the other group members have found. You can share your literature via Zotero. If you would like to do this, one of your group needs a Zotero account. If you do not have one, you need to register [here](https://www.zotero.org/user/register/). After that, select ‘Group’ in the top navigation bar, then find the submenu ‘Create a New Group’. Chose a name for your group and the group type (public, public with closed membership, private). Use the ‘Members settings’ to ‘invite members’ and insert the email addresses or the usernames of the members into the textbox.\r\n \r\n**Organize articles by topic: tags** \r\nTags are short keywords that help you group your literature by topic. Thus, the keywords 'academic writing', and 'experimental design' might be added as tags to the following book: \r\nHarris, P. (2008). Designing and Reporting Experiments in Psychology.\r\n\r\nIf you want to see the tags in Zotero, click on an article and choose ‘tags’ in the navigation on the right side (Zotero adds tags automatically) You can also add your own tags or change the auto-tags. \r\nZotero allows you to search for articles or filter them by tags, for instance, if you want to see all the articles you have gathered that refer to a certain theory. To do so, you can either type the tag into the search field of Zotero at the upper right corner or click on a tag from the list in the bottom left corner.\r\n \r\nYou find further information on tags [here](https://www.zotero.org/support/collections_and_tags).\r\n \r\n**Find duplicated articles** \r\nSometimes an article is added twice. With Zotero, you can easily find duplicates by going to ‘Dublicate Items (*Eintragsdubletten*)’ in the left side navigation, and then click on ‘Merge Items (*2 Einträge zusammenführen*)’ at the upper right corner. Thus, you merge two identical articles.", None, '', None, None, None, None, None, None, None, 'University of Basel', 'University of Basel', 'University of Basel', None, 'TT', '10 min.', 6, 'published', False, None, None, None, None, 20), (58, datetime.datetime(2020, 11, 2, 15, 9, 33, 774510, tzinfo=datetime.timezone.utc), datetime.datetime(2020, 11, 2, 15, 9, 37, 356686, tzinfo=datetime.timezone.utc), datetime.datetime(2020, 11, 2, 15, 9, 37, 356696, tzinfo=datetime.timezone.utc), False, 'Introduction to a literature management program', 'Introduction to a literature management program', 'Introduction to a literature management program', None, '', '', '', None, '', None, None, None, '', 'introduction-to-a-literature-management-program', 'A literature management program helps you to easily organize, store, and find your articles and papers. This video shows the basics of one literature management program called Zotero.\r\n{.lead}\r\n \r\nThe following screencast takes you through the installation and use of the program. You will learn how to add articles to your library and how to organize them. If you would like to emulate the steps, you might wish to have an article ready – for example [this one](https://doi.org/10.3389/fpsyg.2017.01393). To download the program you can visit the [Zotero website](https://www.zotero.org./download/).\r\n\r\nHere you find the version for Mac users:\r\n\r\n![embed](https://vimeo.com/252882103)\r\n\r\n<br/>\r\n\r\nIn case you work with a personal computer (PC) you might want to check out this video instead:\r\n\r\n![embed](https://vimeo.com/252883471)\r\n\r\n<br/>\r\n\r\n------\r\n\r\n###Links\r\n\r\nFor further help go to the [Zotero support page](https://www.zotero.org/support/) or watch [this film](https://youtu.be/mP5AzJHXfIA) on youtube. Specific information about how to import into Zotero is provided by [this page](https://www.zotero.org/support/getting_stuff_into_your_library).', 'A literature management program helps you to easily organize, store, and find your articles and papers. This video shows the basics of one literature management program called Zotero.\r\n{.lead}\r\n \r\nThe following screencast takes you through the installation and use of the program. You will learn how to add articles to your library and how to organize them. If you would like to emulate the steps, you might wish to have an article ready – for example [this one](https://doi.org/10.3389/fpsyg.2017.01393). To download the program you can visit the [Zotero website](https://www.zotero.org./download/).\r\n\r\nHere you find the version for Mac users:\r\n\r\n![embed](https://vimeo.com/252882103)\r\n\r\n<br/>\r\n\r\nIn case you work with a personal computer (PC) you might want to check out this video instead:\r\n\r\n![embed](https://vimeo.com/252883471)\r\n\r\n<br/>\r\n\r\n------\r\n\r\n###Links\r\n\r\nFor further help go to the [Zotero support page](https://www.zotero.org/support/) or watch [this film](https://youtu.be/mP5AzJHXfIA) on youtube. Specific information about how to import into Zotero is provided by [this page](https://www.zotero.org/support/getting_stuff_into_your_library).', 'A literature management program helps you to easily organize, store, and find your articles and papers. This video shows the basics of one literature management program called Zotero.\r\n{.lead}\r\n \r\nThe following screencast takes you through the installation and use of the program. You will learn how to add articles to your library and how to organize them. If you would like to emulate the steps, you might wish to have an article ready – for example [this one](https://doi.org/10.3389/fpsyg.2017.01393). To download the program you can visit the [Zotero website](https://www.zotero.org./download/).\r\n\r\nHere you find the version for Mac users:\r\n\r\n![embed](https://vimeo.com/252882103)\r\n\r\n<br/>\r\n\r\nIn case you work with a personal computer (PC) you might want to check out this video instead:\r\n\r\n![embed](https://vimeo.com/252883471)\r\n\r\n<br/>\r\n\r\n------\r\n\r\n###Links\r\n\r\nFor further help go to the [Zotero support page](https://www.zotero.org/support/) or watch [this film](https://youtu.be/mP5AzJHXfIA) on youtube. Specific information about how to import into Zotero is provided by [this page](https://www.zotero.org/support/getting_stuff_into_your_library).', None, '', None, None, None, None, None, None, None, 'University of Basel', 'University of Basel', 'University of Basel', None, 'TV', '10 min.', 7, 'published', False, None, None, None, None, 20), (59, datetime.datetime(2020, 11, 2, 15, 9, 33, 774510, tzinfo=datetime.timezone.utc), datetime.datetime(2020, 11, 2, 15, 9, 37, 358156, tzinfo=datetime.timezone.utc), datetime.datetime(2020, 11, 2, 15, 9, 37, 358166, tzinfo=datetime.timezone.utc), False, 'References in APA style with Zotero', 'References in APA style with Zotero', 'References in APA style with Zotero', None, '', '', '', None, '', None, None, None, '', 'references-in-apa-style-with-zotero', 'Content:\r\nThe literature management program Zotero helps you to ‘cite while you write’. Cite while you write means adding the correctly-formatted APA-style reference without leaving your word processing program.\r\n{.lead}\r\n \r\nThis screencast introduces you on how to integrate Zotero into your writing process and how the program automatically creates an APA-style reference list of all articles that you have cited in your text. \r\n\r\nIf you want to emulate the screencast step by step it might be best to open a new document in your word processing program (the Zotero plugins are available for Microsoft Word or LibreOffice). For this you already need to have downloaded and installed [Zotero](https://www.zotero.org./download/) as well as the [Zotero Word Processor Plugin](https://www.zotero.org/support/word_processor_integration).\r\n\r\n![embed](https://vimeo.com/252884956)', 'Content:\r\nThe literature management program Zotero helps you to ‘cite while you write’. Cite while you write means adding the correctly-formatted APA-style reference without leaving your word processing program.\r\n{.lead}\r\n \r\nThis screencast introduces you on how to integrate Zotero into your writing process and how the program automatically creates an APA-style reference list of all articles that you have cited in your text. \r\n\r\nIf you want to emulate the screencast step by step it might be best to open a new document in your word processing program (the Zotero plugins are available for Microsoft Word or LibreOffice). For this you already need to have downloaded and installed [Zotero](https://www.zotero.org./download/) as well as the [Zotero Word Processor Plugin](https://www.zotero.org/support/word_processor_integration).\r\n\r\n![embed](https://vimeo.com/252884956)', 'Content:\r\nThe literature management program Zotero helps you to ‘cite while you write’. Cite while you write means adding the correctly-formatted APA-style reference without leaving your word processing program.\r\n{.lead}\r\n \r\nThis screencast introduces you on how to integrate Zotero into your writing process and how the program automatically creates an APA-style reference list of all articles that you have cited in your text. \r\n\r\nIf you want to emulate the screencast step by step it might be best to open a new document in your word processing program (the Zotero plugins are available for Microsoft Word or LibreOffice). For this you already need to have downloaded and installed [Zotero](https://www.zotero.org./download/) as well as the [Zotero Word Processor Plugin](https://www.zotero.org/support/word_processor_integration).\r\n\r\n![embed](https://vimeo.com/252884956)', None, '', None, None, None, None, None, None, None, 'University of Basel', 'University of Basel', 'University of Basel', None, 'TV', '10 min.', 8, 'published', False, None, None, None, None, 20)]])}, None) {} <django_redis.cache.RedisCache object at 0x7910e287a790>
/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in run(101)
  return _run_old_run_func()

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in _run_old_run_func(94)
  return old_run_func(self, *a, **kw)

/usr/local/lib/python3.11/concurrent/futures/thread.py in _worker(83)
  work_item.run()

/usr/local/lib/python3.11/concurrent/futures/thread.py in run(58)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/corsheaders/middleware.py in __call__(56)
  result = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in middleware(32)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/allauth/account/middleware.py in middleware(36)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/simple_history/middleware.py in middleware(41)
  return get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/django_htmx/middleware.py in __call__(43)
  return self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in __call__(168)
  response = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/panels.py in process_request(41)
  return super(CachalotPanel, self).process_request(request)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in __call__(244)
  current_executor.run_until_future(call_result)

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run_until_future(81)
  work_item.run()

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run(40)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_wrapped_callback(90)
  return callback(request, *args, **kwargs)

/app/project/utils/decorators.py in apply_cache(72)
  cache.set(CACHE_KEY, response.render(), ttl)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_patched_render(41)
  return old_render(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in render(114)
  self.content = self.rendered_content

/usr/local/lib/python3.11/site-packages/sentry_sdk/utils.py in runner(1788)
  return sentry_patched_function(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/templates.py in rendered_content(77)
  return real_rendered_content.fget(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in rendered_content(92)
  return template.render(context, self._request)

/usr/local/lib/python3.11/site-packages/django/template/backends/django.py in render(61)
  return self.template.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(175)
  return self._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(208)
  return template.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(177)
  return self._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py in render(321)
  return nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py in render(238)
  nodelist.append(node.render_annotated(context))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py in render(194)
  len_values = len(values)

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(37)
  return original(compiler, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(96)
  return _get_result_or_execute_query(

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in _get_result_or_execute_query(71)
  cache.set_many(to_be_set, cachalot_settings.CACHALOT_TIMEOUT)

0,3655 get_many (['e3a5db5a670ad803efb866441f33de58309be2e2', '76e323efd8711853e13c9f7cf976845908364eb2', '138549f5508bbba7283d6a0625e51c589d845e8f', 'd884586c6395d3cc25f9e31ec5dc46f14dd4922e'],) {} <django_redis.cache.RedisCache object at 0x7910e287a790>
/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in run(101)
  return _run_old_run_func()

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in _run_old_run_func(94)
  return old_run_func(self, *a, **kw)

/usr/local/lib/python3.11/concurrent/futures/thread.py in _worker(83)
  work_item.run()

/usr/local/lib/python3.11/concurrent/futures/thread.py in run(58)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/corsheaders/middleware.py in __call__(56)
  result = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in middleware(32)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/allauth/account/middleware.py in middleware(36)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/simple_history/middleware.py in middleware(41)
  return get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/django_htmx/middleware.py in __call__(43)
  return self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in __call__(168)
  response = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/panels.py in process_request(41)
  return super(CachalotPanel, self).process_request(request)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in __call__(244)
  current_executor.run_until_future(call_result)

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run_until_future(81)
  work_item.run()

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run(40)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_wrapped_callback(90)
  return callback(request, *args, **kwargs)

/app/project/utils/decorators.py in apply_cache(72)
  cache.set(CACHE_KEY, response.render(), ttl)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_patched_render(41)
  return old_render(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in render(114)
  self.content = self.rendered_content

/usr/local/lib/python3.11/site-packages/sentry_sdk/utils.py in runner(1788)
  return sentry_patched_function(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/templates.py in rendered_content(77)
  return real_rendered_content.fget(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in rendered_content(92)
  return template.render(context, self._request)

/usr/local/lib/python3.11/site-packages/django/template/backends/django.py in render(61)
  return self.template.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(175)
  return self._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(208)
  return template.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(177)
  return self._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py in render(321)
  return nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py in render(238)
  nodelist.append(node.render_annotated(context))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py in render(194)
  len_values = len(values)

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(37)
  return original(compiler, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(96)
  return _get_result_or_execute_query(

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in _get_result_or_execute_query(46)
  data = cache.get_many(table_cache_keys + [cache_key])

0,7594 set_many ({'d884586c6395d3cc25f9e31ec5dc46f14dd4922e': (1736871783.1720693, [[(49, datetime.datetime(2020, 11, 2, 15, 9, 33, 774510, tzinfo=datetime.timezone.utc), datetime.datetime(2020, 11, 2, 15, 9, 37, 359620, tzinfo=datetime.timezone.utc), datetime.datetime(2020, 11, 2, 15, 9, 37, 359630, tzinfo=datetime.timezone.utc), False, 'Create a flowchart', 'Create a flowchart', 'Create a flowchart', None, '', '', '', None, '', None, None, None, 'conducting-psychological-research/design-your-experiment/create-a-flowchart/planen2.jpg', 'create-a-flowchart', 'Experimental design begins with a plan, a recipe. This plan outlines every step of your experiment, ideally from the participants’ view. It is very useful to discuss missing parts, think about errors, and improve your design. \r\n{.lead}\r\n\r\nOne way to plan your experiment is by a flowchart. It’s simple and extremely helpful. Here is one example for an experiment:\r\n\r\n![embed](https://vimeo.com/252896289)', 'Experimental design begins with a plan, a recipe. This plan outlines every step of your experiment, ideally from the participants’ view. It is very useful to discuss missing parts, think about errors, and improve your design. \r\n{.lead}\r\n\r\nOne way to plan your experiment is by a flowchart. It’s simple and extremely helpful. Here is one example for an experiment:\r\n\r\n![embed](https://vimeo.com/252896289)', 'Experimental design begins with a plan, a recipe. This plan outlines every step of your experiment, ideally from the participants’ view. It is very useful to discuss missing parts, think about errors, and improve your design. \r\n{.lead}\r\n\r\nOne way to plan your experiment is by a flowchart. It’s simple and extremely helpful. Here is one example for an experiment:\r\n\r\n![embed](https://vimeo.com/252896289)', None, '', None, None, None, None, None, None, None, 'University of Basel', 'University of Basel', 'University of Basel', None, 'TV', '10 min.', 0, 'published', False, None, None, None, None, 19), (61, datetime.datetime(2020, 11, 2, 15, 9, 33, 774510, tzinfo=datetime.timezone.utc), datetime.datetime(2024, 11, 26, 10, 36, 1, 308397, tzinfo=datetime.timezone.utc), datetime.datetime(2024, 11, 26, 10, 36, 1, 235429, tzinfo=datetime.timezone.utc), False, 'Ethics and informed consent', 'Ethics and informed consent', 'Ethics and informed consent', None, '', None, None, None, '', None, None, None, '', 'ethics-and-informed-consent', "When you plan to conduct an experiment it is very important that you think about ethical aspects first. In this step you get a short instruction on how to follow the necessary guidelines.\r\n{.lead}\r\n\r\n**What is Ethics?** \r\nThe term ‘ethics’ describes moral principles that govern a person’s or group’s behaviour or the conducting of an activity. It therefore specifies the correctness of a specified conduct.<sup>1</sup> \r\n \r\n**Famous unethical experiments in psychology history** \r\nYou might have already heard of some potentially unethical experiments. One of these is the psychology experiment ‘little Albert’ from John B. Watson and Rosalie Rayner (1920). In this study the researchers wanted to test the hypothesis that people's emotional reactions could be classically conditioned. The researchers chose a nine months old child with the fictitious name of ‘little Albert’ as participant and conducted the following experiment on him.\r\n\r\nLittle Albert was exposed to several stimuli including a white rat and a rabbit. During his first encounters with the stimuli, the boy showed no fear of any of the objects. In the next step of the experiment the rat was paired with a loud noise by hitting a metal pipe with a hammer. Of course, little Albert began to cry after hearing the loud and unpleasant sound. After pairing the noise with the stimuli several times, little Albert began to cry only after seeing the rat. \r\n\r\nAlthough the experiment is still very famous, it raises several ethical concerns: There was **no informed consent** (from the parents or the child) and the **principle of ‘do no harm**’ was violated. (Additionally, the study had many methodological shortcomings, i.e. no control condition and too few participants, namely one).\r\n \r\nYou might think that it is obvious that this experiment was unethical, but unfortunately there are several psychology experiments in our research history, which violated ethical principles (e.g., Harry Harlow with the experiment on infant monkeys and their surrogate mothers (1961) or the Stanford prison experiment from Zimbardo, 1971). As unethical studies are likely to cause negative outcomes for the participants, it completely makes sense that experiments get checked for ethical principles before the researcher can actually start recruiting.\r\n \r\n**How do you get your ethics approval for your research project?** \r\nBy getting it approved by an Institutional Review Board (IRB), which is a group of people checking your work. Usually, the local IRB board at the institution where you conduct your research can tell you how you apply for ethical approval of your research. Do not worry, this process is usually not complicated, you just need to be detail-oriented. \r\n\r\n**University of Basel students** \r\nIn the following we will describe the required steps you need to fulfill to get your ethics approval if you are researching at the University of Basel:\r\n\r\nFor the project seminar you have to hand in an **IRB-Checkliste**, which you can find – along with more information – [here](https://psychologie.unibas.ch/de/forschung/forschungseinrichtungen/institutional-review-board/). Unfortunately, at the moment, the informations are only available in German.\r\n \r\nFill out the [IRB Checklist](https://psychologie.unibas.ch/fileadmin/user_upload/psychologie/Forschung/IRB/IRB-Checkliste_11.4.16.docx). You can also find explanations for the checklist under the link mentioned above (unfortunately this checklist is also only available in German. It is called ‘Erläuterungen zu den Fragen der IRB Checkliste’). \r\na) If all questions from the checklist can be answered with ‘no’, the document will be signed by all researchers and contributors and handed in to the IRB. \r\nb) If any of the questions is answered with a ‘yes’, an application to the IRB or the Ethikkommission Nordwest- und Zentralschweiz ([EKNZ](https://www.eknz.ch)) is mandatory.\r\n \r\nIn case of ‘b)’ you need an IRB ethics application, the following documents are necessary for a successful ethics application: \r\n➔ Antragsformular (Antrag zur Durchführung von Untersuchungen mit freiwilligen Testpersonen) \r\n➔ Kurzbeschreibung der Studie (Punkt 8 des Antragsformulars) \r\n➔ Liste der verwendeten Untersuchungsinstrumente (Punkt 16 des Antragsformulars) \r\n➔ Einverständniserklärung (informed consent) \r\n➔ Bestätigungsformular, dass elektronische und Papierversion des Antrags identisch sind \r\n\r\nAll documents can be found [here](https://psychologie.unibas.ch/de/forschung/forschungseinrichtungen/institutional-review-board/antragsdokumente/).\r\n \r\n**How do you hand in the documents?** \r\nAll documents need to be handed in **electronic** (PDF) **and paper** form. The applicant needs to check that the paper and the electronic form are identical. In case of doubt the electronic form is valid.\r\n \r\n**Where do you hand in the project proposal?** \r\nEmail the PDF to [irb-psychologie@unibas.ch](mailto:irb-psychologie@unibas.ch) and put the paper version into the post box of the ‘Sekretariat IRB’ in the first floor of Missionsstr 62a (or it can be send via post to Sekretariat IRB, Missionsstrasse 62A, 4055 Basel).\r\n \r\n**When do you hand in your project proposal?** \r\nYou can hand it in any time, usually 2 months before you want to run your study. The IRB will review it every 1<sup>st</sup> and 3<sup>rd</sup> week of the month. Important: your proposal will only be reviewed if the paper AND the electronic version arrived at the IRB office.\r\n \r\n**How long does the procedure take?** \r\nIt can take up to four weeks until you receive a definite answer. Therefore, please make sure you are planning enough time for the IRB approval.\r\n\r\n**Which information do you need for your application?** \r\nA short description of your research project, sample selection criteria and special features of your participants, a short description of the study procedure, burden, potential risks, and potential after effects for participants, how you anonymize the data, and information about the extent and content of informed consent.\r\n\r\n<sup>1</sup> [Oxford Dictionary](https://en.oxforddictionaries.com/definition/ethics)), accessed September 10th, 2017.\r\n{.footnote}", "When you plan to conduct an experiment it is very important that you think about ethical aspects first. In this step you get a short instruction on how to follow the necessary guidelines.\r\n{.lead}\r\n\r\n**What is Ethics?** \r\nThe term ‘ethics’ describes moral principles that govern a person’s or group’s behaviour or the conducting of an activity. It therefore specifies the correctness of a specified conduct.<sup>1</sup> \r\n \r\n**Famous unethical experiments in psychology history** \r\nYou might have already heard of some potentially unethical experiments. One of these is the psychology experiment ‘little Albert’ from John B. Watson and Rosalie Rayner (1920). In this study the researchers wanted to test the hypothesis that people's emotional reactions could be classically conditioned. The researchers chose a nine months old child with the fictitious name of ‘little Albert’ as participant and conducted the following experiment on him.\r\n\r\nLittle Albert was exposed to several stimuli including a white rat and a rabbit. During his first encounters with the stimuli, the boy showed no fear of any of the objects. In the next step of the experiment the rat was paired with a loud noise by hitting a metal pipe with a hammer. Of course, little Albert began to cry after hearing the loud and unpleasant sound. After pairing the noise with the stimuli several times, little Albert began to cry only after seeing the rat. \r\n\r\nAlthough the experiment is still very famous, it raises several ethical concerns: There was **no informed consent** (from the parents or the child) and the **principle of ‘do no harm’** was violated. (Additionally, the study had many methodological shortcomings, i.e. no control condition and too few participants, namely one).\r\n \r\nYou might think that it is obvious that this experiment was unethical, but unfortunately there are several psychology experiments in our research history, which violated ethical principles (e.g. Harry Harlow with the experiment on infant monkeys and their surrogate mothers (1961) or the Stanford prison experiment from Zimbardo, 1971). As unethical studies are likely to cause negative outcomes for the participants, it completely makes sense that experiments get checked for ethical principles before the researcher can actually start recruiting.\r\n \r\n**How do you get your ethics approval for your research project?** \r\nBy getting it approved by an Institutional Review Board (IRB), which is a group of people checking your work. Usually, the local IRB at the institution where you conduct your research can tell you how you apply for ethical approval of your research. Do not worry, this process is usually not complicated, you just need to be detail-oriented. \r\n\r\n**University of Basel students** \r\nIn the following we will describe the required steps you need to fulfill to get your ethics approval if you are a student participating in the project seminar at the University of Basel (this does not apply if you are a Master’s student): You fill out (1) the Psychology faculty’s ethics application form and (2) the Psychology faculty’s ethics checklist. You hand the ethics application form and the checklist o your supervisor who will check it and help you to process it further.\r\n\r\n**Which information do you need for your application?** \r\nA **short** description of your research project, sample selection criteria and, if necessary, any special features of your participants, a short description of the study procedure, with a focus on potential burden, potential risks, and potential after effects of taking part for your participants, how you anonymize the data, and information about the extent and content of informed consent. Usually, you attach a copy of the informed consent text. You usually also need a power analysis. \r\n \r\n**How do you hand in the documents?** \r\nAll documents need to be handed in **electronic** (PDF) to your supervisor who will check the documents and tell you how to proceed. \r\n\r\n**When do you hand in your project proposal?** \r\nYou can hand it in any time, usually 2 months before you want to run your study. In most of the cases an ethics review takes 4-8 weeks and the committee meets usually every 1<sup>st</sup> and 3<sup>rd</sup> week of the month.\r\n \r\n**How long does the procedure take?** \r\nIt can take up to eight weeks until you receive a definite answer. Therefore, please make sure you are planning enough time.\r\n\r\n<sup>1</sup> [Oxford Dictionary](https://en.oxforddictionaries.com/definition/ethics), accessed September 10th, 2017.\r\n{.footnote}", "When you plan to conduct an experiment it is very important that you think about ethical aspects first. In this step you get a short instruction on how to follow the necessary guidelines.\r\n{.lead}\r\n\r\n**What is Ethics?** \r\nThe term ‘ethics’ describes moral principles that govern a person’s or group’s behaviour or the conducting of an activity. It therefore specifies the correctness of a specified conduct.<sup>1</sup> \r\n \r\n**Famous unethical experiments in psychology history** \r\nYou might have already heard of some potentially unethical experiments. One of these is the psychology experiment ‘little Albert’ from John B. Watson and Rosalie Rayner (1920). In this study the researchers wanted to test the hypothesis that people's emotional reactions could be classically conditioned. The researchers chose a nine months old child with the fictitious name of ‘little Albert’ as participant and conducted the following experiment on him.\r\n\r\nLittle Albert was exposed to several stimuli including a white rat and a rabbit. During his first encounters with the stimuli, the boy showed no fear of any of the objects. In the next step of the experiment the rat was paired with a loud noise by hitting a metal pipe with a hammer. Of course, little Albert began to cry after hearing the loud and unpleasant sound. After pairing the noise with the stimuli several times, little Albert began to cry only after seeing the rat. \r\n\r\nAlthough the experiment is still very famous, it raises several ethical concerns: There was **no informed consent** (from the parents or the child) and the **principle of ‘do no harm**’ was violated. (Additionally, the study had many methodological shortcomings, i.e. no control condition and too few participants, namely one).\r\n \r\nYou might think that it is obvious that this experiment was unethical, but unfortunately there are several psychology experiments in our research history, which violated ethical principles (e.g., Harry Harlow with the experiment on infant monkeys and their surrogate mothers (1961) or the Stanford prison experiment from Zimbardo, 1971). As unethical studies are likely to cause negative outcomes for the participants, it completely makes sense that experiments get checked for ethical principles before the researcher can actually start recruiting.\r\n \r\n**How do you get your ethics approval for your research project?** \r\nBy getting it approved by an Institutional Review Board (IRB), which is a group of people checking your work. Usually, the local IRB board at the institution where you conduct your research can tell you how you apply for ethical approval of your research. Do not worry, this process is usually not complicated, you just need to be detail-oriented. \r\n\r\n**University of Basel students** \r\nIn the following we will describe the required steps you need to fulfill to get your ethics approval if you are researching at the University of Basel:\r\n\r\nFor the project seminar you have to hand in an **IRB-Checkliste**, which you can find – along with more information – [here](https://psychologie.unibas.ch/de/forschung/forschungseinrichtungen/institutional-review-board/). Unfortunately, at the moment, the informations are only available in German.\r\n \r\nFill out the [IRB Checklist](https://psychologie.unibas.ch/fileadmin/user_upload/psychologie/Forschung/IRB/IRB-Checkliste_11.4.16.docx). You can also find explanations for the checklist under the link mentioned above (unfortunately this checklist is also only available in German. It is called ‘Erläuterungen zu den Fragen der IRB Checkliste’). \r\na) If all questions from the checklist can be answered with ‘no’, the document will be signed by all researchers and contributors and handed in to the IRB. \r\nb) If any of the questions is answered with a ‘yes’, an application to the IRB or the Ethikkommission Nordwest- und Zentralschweiz ([EKNZ](https://www.eknz.ch)) is mandatory.\r\n \r\nIn case of ‘b)’ you need an IRB ethics application, the following documents are necessary for a successful ethics application: \r\n➔ Antragsformular (Antrag zur Durchführung von Untersuchungen mit freiwilligen Testpersonen) \r\n➔ Kurzbeschreibung der Studie (Punkt 8 des Antragsformulars) \r\n➔ Liste der verwendeten Untersuchungsinstrumente (Punkt 16 des Antragsformulars) \r\n➔ Einverständniserklärung (informed consent) \r\n➔ Bestätigungsformular, dass elektronische und Papierversion des Antrags identisch sind \r\n\r\nAll documents can be found [here](https://psychologie.unibas.ch/de/forschung/forschungseinrichtungen/institutional-review-board/antragsdokumente/).\r\n \r\n**How do you hand in the documents?** \r\nAll documents need to be handed in **electronic** (PDF) **and paper** form. The applicant needs to check that the paper and the electronic form are identical. In case of doubt the electronic form is valid.\r\n \r\n**Where do you hand in the project proposal?** \r\nEmail the PDF to [irb-psychologie@unibas.ch](mailto:irb-psychologie@unibas.ch) and put the paper version into the post box of the ‘Sekretariat IRB’ in the first floor of Missionsstr 62a (or it can be send via post to Sekretariat IRB, Missionsstrasse 62A, 4055 Basel).\r\n \r\n**When do you hand in your project proposal?** \r\nYou can hand it in any time, usually 2 months before you want to run your study. The IRB will review it every 1<sup>st</sup> and 3<sup>rd</sup> week of the month. Important: your proposal will only be reviewed if the paper AND the electronic version arrived at the IRB office.\r\n \r\n**How long does the procedure take?** \r\nIt can take up to four weeks until you receive a definite answer. Therefore, please make sure you are planning enough time for the IRB approval.\r\n\r\n**Which information do you need for your application?** \r\nA short description of your research project, sample selection criteria and special features of your participants, a short description of the study procedure, burden, potential risks, and potential after effects for participants, how you anonymize the data, and information about the extent and content of informed consent.\r\n\r\n<sup>1</sup> [Oxford Dictionary](https://en.oxforddictionaries.com/definition/ethics)), accessed September 10th, 2017.\r\n{.footnote}", '', '', '', '', '', None, None, None, None, 'University of Basel', 'University of Basel', 'University of Basel', '', 'TT', '10 min.', 2, 'published', False, None, None, None, None, 19), (62, datetime.datetime(2020, 11, 2, 15, 9, 33, 774510, tzinfo=datetime.timezone.utc), datetime.datetime(2020, 11, 2, 15, 9, 37, 363032, tzinfo=datetime.timezone.utc), datetime.datetime(2020, 11, 2, 15, 9, 37, 363042, tzinfo=datetime.timezone.utc), False, 'Interview with ethics expert Dr. David Shaw', 'Interview with ethics expert Dr. David Shaw', 'Interview with ethics expert Dr. David Shaw', None, '', '', '', None, '', None, None, None, '', 'interview-with-ethics-expert-dr-david-shaw', 'What is the key element of ethics to be considered in behavioral experiments with human subjects? \r\n{.lead}\r\n\r\nEthics’ expert Dr. David Shaw explains the basics of research ethics for psychologists, the most-common pitfall for psychology researchers, and how modern sampling methods pose new ethical challenges. \r\n\r\n![embed](https://vimeo.com/252897690)', 'What is the key element of ethics to be considered in behavioral experiments with human subjects? \r\n{.lead}\r\n\r\nEthics’ expert Dr. David Shaw explains the basics of research ethics for psychologists, the most-common pitfall for psychology researchers, and how modern sampling methods pose new ethical challenges. \r\n\r\n![embed](https://vimeo.com/252897690)', 'What is the key element of ethics to be considered in behavioral experiments with human subjects? \r\n{.lead}\r\n\r\nEthics’ expert Dr. David Shaw explains the basics of research ethics for psychologists, the most-common pitfall for psychology researchers, and how modern sampling methods pose new ethical challenges. \r\n\r\n![embed](https://vimeo.com/252897690)', None, '', None, None, None, None, None, None, None, 'University of Basel', 'University of Basel', 'University of Basel', None, 'TV', '12 min.', 3, 'published', False, None, None, None, None, 19), (66, datetime.datetime(2020, 11, 2, 15, 9, 33, 774510, tzinfo=datetime.timezone.utc), datetime.datetime(2020, 11, 2, 15, 9, 37, 364396, tzinfo=datetime.timezone.utc), datetime.datetime(2020, 11, 2, 15, 9, 37, 364406, tzinfo=datetime.timezone.utc), False, 'Covariates, demographics and manipulation check', 'Covariates, demographics and manipulation check', 'Covariates, demographics and manipulation check', None, '', '', '', None, '', None, None, None, '', 'covariates-demographics-and-manipulation-check', 'Covariates are psychological factors that could influence the data. Your experiment cannot manipulate them experimentally (think of personality). You want to measure these covariates. Demographics too have to be measured in all experiments. And last but not least, manipulation checks are usually included in experiments with manipulations of an independent variable. This article explains how to measure these variables.\r\n{.lead}\r\n\r\n**Covariates** \r\nThink carefully about any psychological constructs that may influence your dependent variable. Let’s say you want to find out if a new teaching style improves learning in college students. One group of students is exposed to the new teaching style, a second group is taught with the old style. After the semester you compare the groups’ performance in a final exam. Sounds pretty straightforward, doesn’t it? But wait – students’ performance is not only influenced by teaching style: test anxiety, motivation, intelligence, interest in the topic etc. can also play an important role. \r\n\r\nWe call these variables covariates. If some of them systematically differ between experimental groups, this can be an alternative explanation for an observed difference in the final exam scores. Therefore, you need to decide in advance which are the potentially relevant covariates for your study and take them into account when designing your experiment. There will probably be many potential covariates, so you may need to settle for capturing only the most important ones.\r\n\r\nThe tricky part about covariates is that often they are **latent constructs**. Latent constructs are usually complex and abstract, and not directly observable. To measure them we use carefully designed tests and questionnaires. \r\n\r\nFor example, if our covariate is neuroticism, you can use a suitable questionnaire from the literature, like the **NEO Five-Factor Inventory** (Costa & McCrae, 1992). Participants’ score on the neuroticism subscale of this test is the measure of your covariate. One construct can be measured in multiple ways, for instance, subjective pain can be measured through self-reported pain intensity, observing pain behavior (flinching, crying, avoidance of painful stimuli etc.), or a clinician’s judgment, just to name a few.\r\n\r\nFinding the **right measure for your covariate** is crucial in designing your experiment. Below we show you where to look for it. Note, it is not advisable to invent and use a new questionnaire without validating it. Whereas no single measure will perfectly capture your construct, good measures should be administered in a consistent way, i.e. be **standardized**. They should produce replicable results, i.e., be **reliable**. And they should measure what they are supposed to measure, i.e. be **valid**. Also it is nice if they are, efficiently administered and add the most relevant information for your experiment (don’t just measure everything).\r\n\r\nDefinitely discuss potential covariates with your research team, and find the best measure – rather than the first measure – to measure the constructs of interest!\r\n \r\n**Where to find standardized tests?** \r\nIf you are studying at a university, you don’t need to buy tests (many psychological tests are licensed, costing 300 USD or more due to expensive research and development processes, think of medicine or books). Here are three ways to find standardized tests: the database PsychTEST (if you have access), a test library (if you have access), or material from previous studies. The University of Basel offers access to all three.\r\n\r\n**PsycTESTS** is an online database of psychological measures, scales, surveys, and other instruments. It includes aptitude tests, personality scales, cognitive functioning measures, etc. The majority of them are available for download and they include reliability and validity information. \r\nImportant: Access requires the [VPN-Client](https://mobile.unibas.ch/home.html) or a connection with [Eduroam](https://mobile.unibas.ch/home.html). \r\n\r\nThere are two possibilities to get to PsychTESTS: \r\n➔ Find PsycTESTS via the university library at[→Recherche→Fachgebiete→Psychologie](http://www.ub.unibas.ch/ub-hauptbibliothek/recherche/fachgebiete/psychologie/) \r\n➔ Find a link to PsycTESTS on the [Testothek website](https://testothek.psycho.unibas.ch/).\r\n\r\n**The Testothek** is simply a library of psychological tests. Borrow a standardized test, like a book, from there. If you work in a psychology department, check with your library if your department offers a test library, often called Testothek in German-speaking countries. If you wish, you can check out our [video tutorial for the Testothek](https://tales.nmc.unibas.ch/de/conducting-psychological-research-6/design-your-experiment-19/testothek-64).\r\n\r\n**Previous studies** can be very helpful to find testing materials for your experiment. There are three different approaches to maintain them: \r\n➔ **Appendices of papers:** While looking for supporting literature for your study, you probably came across some papers that used test material you could also apply to your experiment. Have a look at the method section of these papers. Go to the part where they describe the task and you may come across something like ‘Testing materials/tests/stimuli are presented in Appendix X’. If so, you can simply go to Appendix X and find your potential measures. \r\n➔ **Citations:** Some studies use measures that have been described in a previous study. Therefore, they provide a citation of the study where the measures are presented in greater detail in the method section. If so, simply look up the cited paper to find the instrument. Here is an example of finding measures by using previous studies: \r\n\r\n![Example of how to find measures in previous studies](/media/tales/markdownx/6e707964-1ef3-4f9c-b6ec-935ab1d58b75.png) \r\n\r\n➔ **Contact the authors:** Sometimes during your ‘test hunting’ you will find statements that the material is available upon request. If this is the case, don’t shy away from asking the authors for it. You’ll usually need to provide a brief summary of your experiment in order to get the instrument. Also, it may take quite some time for the authors to answer, so if using resources in this manner, do not leave this task for the last minute.\r\n\r\n**Demographics: Why the extra information?** \r\nThe bare minimum demographic information involves a **record of participants’ age, sex, and occupation**. Depending on the specifics of your experiment, you can further extend the demographic records to include variables such as: educational attainment, family size, first language, marital status, nationality, religion etc. It depends on your study design!\r\n \r\n**Other variables: Manipulation check** \r\nManipulation checks are important: Does the experimentally-manipulated independent variable vary like you expect it to? Consider studying the effect of emotions on memory by exposing participants to a sad film compared to a happy film followed by a memory task. After the film and before the memory task ask participants how sad or happy they actually feel! This safeguards against the case that observing no between-group differences is merely a result of a failed manipulation, rather than an actual lack of impact of the independent variables on the dependent ones. Without manipulation check there is simply no way to be sure about this. \r\n\r\n<br/>\r\n\r\n------\r\n\r\n###References\r\n\r\nCosta, P. T., & McCrae, R. R. (1992). *Revised NEO personality inventory (NEO-PI-R) and NEO five-factor inventory (NEO-FFI): Professional manual*. Odessa, FL: Psychological Assessment Resources, Inc.', 'Covariates are psychological factors that could influence the data. Your experiment cannot manipulate them experimentally (think of personality). You want to measure these covariates. Demographics too have to be measured in all experiments. And last but not least, manipulation checks are usually included in experiments with manipulations of an independent variable. This article explains how to measure these variables.\r\n{.lead}\r\n\r\n**Covariates** \r\nThink carefully about any psychological constructs that may influence your dependent variable. Let’s say you want to find out if a new teaching style improves learning in college students. One group of students is exposed to the new teaching style, a second group is taught with the old style. After the semester you compare the groups’ performance in a final exam. Sounds pretty straightforward, doesn’t it? But wait – students’ performance is not only influenced by teaching style: test anxiety, motivation, intelligence, interest in the topic etc. can also play an important role. \r\n\r\nWe call these variables covariates. If some of them systematically differ between experimental groups, this can be an alternative explanation for an observed difference in the final exam scores. Therefore, you need to decide in advance which are the potentially relevant covariates for your study and take them into account when designing your experiment. There will probably be many potential covariates, so you may need to settle for capturing only the most important ones.\r\n\r\nThe tricky part about covariates is that often they are **latent constructs**. Latent constructs are usually complex and abstract, and not directly observable. To measure them we use carefully designed tests and questionnaires. \r\n\r\nFor example, if our covariate is neuroticism, you can use a suitable questionnaire from the literature, like the **NEO Five-Factor Inventory** (Costa & McCrae, 1992). Participants’ score on the neuroticism subscale of this test is the measure of your covariate. One construct can be measured in multiple ways, for instance, subjective pain can be measured through self-reported pain intensity, observing pain behavior (flinching, crying, avoidance of painful stimuli etc.), or a clinician’s judgment, just to name a few.\r\n\r\nFinding the **right measure for your covariate** is crucial in designing your experiment. Below we show you where to look for it. Note, it is not advisable to invent and use a new questionnaire without validating it. Whereas no single measure will perfectly capture your construct, good measures should be administered in a consistent way, i.e. be **standardized**. They should produce replicable results, i.e., be **reliable**. And they should measure what they are supposed to measure, i.e. be **valid**. Also it is nice if they are, efficiently administered and add the most relevant information for your experiment (don’t just measure everything).\r\n\r\nDefinitely discuss potential covariates with your research team, and find the best measure – rather than the first measure – to measure the constructs of interest!\r\n \r\n**Where to find standardized tests?** \r\nIf you are studying at a university, you don’t need to buy tests (many psychological tests are licensed, costing 300 USD or more due to expensive research and development processes, think of medicine or books). Here are three ways to find standardized tests: the database PsychTEST (if you have access), a test library (if you have access), or material from previous studies. The University of Basel offers access to all three.\r\n\r\n**PsycTESTS** is an online database of psychological measures, scales, surveys, and other instruments. It includes aptitude tests, personality scales, cognitive functioning measures, etc. The majority of them are available for download and they include reliability and validity information. \r\nImportant: Access requires the [VPN-Client](https://mobile.unibas.ch/home.html) or a connection with [Eduroam](https://mobile.unibas.ch/home.html). \r\n\r\nThere are two possibilities to get to PsychTESTS: \r\n➔ Find PsycTESTS via the university library at[→Recherche→Fachgebiete→Psychologie](http://www.ub.unibas.ch/ub-hauptbibliothek/recherche/fachgebiete/psychologie/) \r\n➔ Find a link to PsycTESTS on the [Testothek website](https://testothek.psycho.unibas.ch/).\r\n\r\n**The Testothek** is simply a library of psychological tests. Borrow a standardized test, like a book, from there. If you work in a psychology department, check with your library if your department offers a test library, often called Testothek in German-speaking countries. If you wish, you can check out our [video tutorial for the Testothek](https://tales.nmc.unibas.ch/de/conducting-psychological-research-6/design-your-experiment-19/testothek-64).\r\n\r\n**Previous studies** can be very helpful to find testing materials for your experiment. There are three different approaches to maintain them: \r\n➔ **Appendices of papers:** While looking for supporting literature for your study, you probably came across some papers that used test material you could also apply to your experiment. Have a look at the method section of these papers. Go to the part where they describe the task and you may come across something like ‘Testing materials/tests/stimuli are presented in Appendix X’. If so, you can simply go to Appendix X and find your potential measures. \r\n➔ **Citations:** Some studies use measures that have been described in a previous study. Therefore, they provide a citation of the study where the measures are presented in greater detail in the method section. If so, simply look up the cited paper to find the instrument. Here is an example of finding measures by using previous studies: \r\n\r\n![Example of how to find measures in previous studies](/media/markdownx/6e707964-1ef3-4f9c-b6ec-935ab1d58b75.png) \r\n\r\n➔ **Contact the authors:** Sometimes during your ‘test hunting’ you will find statements that the material is available upon request. If this is the case, don’t shy away from asking the authors for it. You’ll usually need to provide a brief summary of your experiment in order to get the instrument. Also, it may take quite some time for the authors to answer, so if using resources in this manner, do not leave this task for the last minute.\r\n\r\n**Demographics: Why the extra information?** \r\nThe bare minimum demographic information involves a **record of participants’ age, sex, and occupation**. Depending on the specifics of your experiment, you can further extend the demographic records to include variables such as: educational attainment, family size, first language, marital status, nationality, religion etc. It depends on your study design!\r\n \r\n**Other variables: Manipulation check** \r\nManipulation checks are important: Does the experimentally-manipulated independent variable vary like you expect it to? Consider studying the effect of emotions on memory by exposing participants to a sad film compared to a happy film followed by a memory task. After the film and before the memory task ask participants how sad or happy they actually feel! This safeguards against the case that observing no between-group differences is merely a result of a failed manipulation, rather than an actual lack of impact of the independent variables on the dependent ones. Without manipulation check there is simply no way to be sure about this. \r\n\r\n<br/>\r\n\r\n------\r\n\r\n###References\r\n\r\nCosta, P. T., & McCrae, R. R. (1992). *Revised NEO personality inventory (NEO-PI-R) and NEO five-factor inventory (NEO-FFI): Professional manual*. Odessa, FL: Psychological Assessment Resources, Inc.', 'Covariates are psychological factors that could influence the data. Your experiment cannot manipulate them experimentally (think of personality). You want to measure these covariates. Demographics too have to be measured in all experiments. And last but not least, manipulation checks are usually included in experiments with manipulations of an independent variable. This article explains how to measure these variables.\r\n{.lead}\r\n\r\n**Covariates** \r\nThink carefully about any psychological constructs that may influence your dependent variable. Let’s say you want to find out if a new teaching style improves learning in college students. One group of students is exposed to the new teaching style, a second group is taught with the old style. After the semester you compare the groups’ performance in a final exam. Sounds pretty straightforward, doesn’t it? But wait – students’ performance is not only influenced by teaching style: test anxiety, motivation, intelligence, interest in the topic etc. can also play an important role. \r\n\r\nWe call these variables covariates. If some of them systematically differ between experimental groups, this can be an alternative explanation for an observed difference in the final exam scores. Therefore, you need to decide in advance which are the potentially relevant covariates for your study and take them into account when designing your experiment. There will probably be many potential covariates, so you may need to settle for capturing only the most important ones.\r\n\r\nThe tricky part about covariates is that often they are **latent constructs**. Latent constructs are usually complex and abstract, and not directly observable. To measure them we use carefully designed tests and questionnaires. \r\n\r\nFor example, if our covariate is neuroticism, you can use a suitable questionnaire from the literature, like the **NEO Five-Factor Inventory** (Costa & McCrae, 1992). Participants’ score on the neuroticism subscale of this test is the measure of your covariate. One construct can be measured in multiple ways, for instance, subjective pain can be measured through self-reported pain intensity, observing pain behavior (flinching, crying, avoidance of painful stimuli etc.), or a clinician’s judgment, just to name a few.\r\n\r\nFinding the **right measure for your covariate** is crucial in designing your experiment. Below we show you where to look for it. Note, it is not advisable to invent and use a new questionnaire without validating it. Whereas no single measure will perfectly capture your construct, good measures should be administered in a consistent way, i.e. be **standardized**. They should produce replicable results, i.e., be **reliable**. And they should measure what they are supposed to measure, i.e. be **valid**. Also it is nice if they are, efficiently administered and add the most relevant information for your experiment (don’t just measure everything).\r\n\r\nDefinitely discuss potential covariates with your research team, and find the best measure – rather than the first measure – to measure the constructs of interest!\r\n \r\n**Where to find standardized tests?** \r\nIf you are studying at a university, you don’t need to buy tests (many psychological tests are licensed, costing 300 USD or more due to expensive research and development processes, think of medicine or books). Here are three ways to find standardized tests: the database PsychTEST (if you have access), a test library (if you have access), or material from previous studies. The University of Basel offers access to all three.\r\n\r\n**PsycTESTS** is an online database of psychological measures, scales, surveys, and other instruments. It includes aptitude tests, personality scales, cognitive functioning measures, etc. The majority of them are available for download and they include reliability and validity information. \r\nImportant: Access requires the [VPN-Client](https://mobile.unibas.ch/home.html) or a connection with [Eduroam](https://mobile.unibas.ch/home.html). \r\n\r\nThere are two possibilities to get to PsychTESTS: \r\n➔ Find PsycTESTS via the university library at[→Recherche→Fachgebiete→Psychologie](http://www.ub.unibas.ch/ub-hauptbibliothek/recherche/fachgebiete/psychologie/) \r\n➔ Find a link to PsycTESTS on the [Testothek website](https://testothek.psycho.unibas.ch/).\r\n\r\n**The Testothek** is simply a library of psychological tests. Borrow a standardized test, like a book, from there. If you work in a psychology department, check with your library if your department offers a test library, often called Testothek in German-speaking countries. If you wish, you can check out our [video tutorial for the Testothek](https://tales.nmc.unibas.ch/de/conducting-psychological-research-6/design-your-experiment-19/testothek-64).\r\n\r\n**Previous studies** can be very helpful to find testing materials for your experiment. There are three different approaches to maintain them: \r\n➔ **Appendices of papers:** While looking for supporting literature for your study, you probably came across some papers that used test material you could also apply to your experiment. Have a look at the method section of these papers. Go to the part where they describe the task and you may come across something like ‘Testing materials/tests/stimuli are presented in Appendix X’. If so, you can simply go to Appendix X and find your potential measures. \r\n➔ **Citations:** Some studies use measures that have been described in a previous study. Therefore, they provide a citation of the study where the measures are presented in greater detail in the method section. If so, simply look up the cited paper to find the instrument. Here is an example of finding measures by using previous studies: \r\n\r\n![Example of how to find measures in previous studies](/media/markdownx/6e707964-1ef3-4f9c-b6ec-935ab1d58b75.png) \r\n\r\n➔ **Contact the authors:** Sometimes during your ‘test hunting’ you will find statements that the material is available upon request. If this is the case, don’t shy away from asking the authors for it. You’ll usually need to provide a brief summary of your experiment in order to get the instrument. Also, it may take quite some time for the authors to answer, so if using resources in this manner, do not leave this task for the last minute.\r\n\r\n**Demographics: Why the extra information?** \r\nThe bare minimum demographic information involves a **record of participants’ age, sex, and occupation**. Depending on the specifics of your experiment, you can further extend the demographic records to include variables such as: educational attainment, family size, first language, marital status, nationality, religion etc. It depends on your study design!\r\n \r\n**Other variables: Manipulation check** \r\nManipulation checks are important: Does the experimentally-manipulated independent variable vary like you expect it to? Consider studying the effect of emotions on memory by exposing participants to a sad film compared to a happy film followed by a memory task. After the film and before the memory task ask participants how sad or happy they actually feel! This safeguards against the case that observing no between-group differences is merely a result of a failed manipulation, rather than an actual lack of impact of the independent variables on the dependent ones. Without manipulation check there is simply no way to be sure about this. \r\n\r\n<br/>\r\n\r\n------\r\n\r\n###References\r\n\r\nCosta, P. T., & McCrae, R. R. (1992). *Revised NEO personality inventory (NEO-PI-R) and NEO five-factor inventory (NEO-FFI): Professional manual*. Odessa, FL: Psychological Assessment Resources, Inc.', None, '', None, None, None, None, None, None, None, 'University of Basel', 'University of Basel', 'University of Basel', None, 'TT', '15 Min.', 4, 'published', False, None, None, None, None, 19), (64, datetime.datetime(2020, 11, 2, 15, 9, 33, 774510, tzinfo=datetime.timezone.utc), datetime.datetime(2020, 11, 2, 15, 9, 37, 366738, tzinfo=datetime.timezone.utc), datetime.datetime(2020, 11, 2, 15, 9, 37, 366749, tzinfo=datetime.timezone.utc), False, 'Testothek', 'Testothek', 'Testothek', None, 'A tool for Basel researchers', 'A tool for Basel researchers', 'A tool for Basel researchers', None, '', None, None, None, '', 'testothek', 'A testothek is a library of psychological tests. You can borrow licensed psychological tests ranging from the Beck Depression Inventory (Hautzinger, Keller, Kühne; 2009) to the Wechsler Adult Intelligence Scale (Petermann, 2012). \r\n{.lead}\r\n\r\nMost universities’ psychology departments have a testothek, we recommend you to check with your institution for more information. The following brief tutorial introduces the search functionality at the University of Basel.\r\n\r\n![embed](https://vimeo.com/252900682)\r\n\r\nYou can find more information (in German) about the location and the opening hours of the testothek at the psychology department of the University of Basel [here](https://psychologie.unibas.ch/de/forschung/forschungseinrichtungen/testothek/). To find tests you can follow the direct link to the [Testothek](https://testothek.psycho.unibas.ch/). Note: certain links are only freely accessible within [eduroam](https://mobile.unibas.ch/home.html). If you want to use resources from the university at home, you need to install a [VPN Client](https://mobile.unibas.ch/home.html).\r\n\r\nTip: note down how to score the test results (see test manual) if you need to return the test prior to gathering data. Also note down the test results of the general population (test norms). Remember that the test material is copyright protected, that means you cannot share the test information publicly.\r\n\r\n<br/>\r\n\r\n------\r\n\r\n###References\r\n\r\nHautzinger, M., Keller, F., Kühner C. (2009). *Beck-Depressions-Inventar–Revision (BDI-II). Deutsche Version* [Measurement instrument]. 2nd Ed. Frankfurt/Main: Pearson Assessment.\r\n{.citation-indented}\r\n\r\nPetermann, F. (2012). *WAIS-IV. Wechsler Adult Intelligence Scale–Fourth Edition. Deutschsprachige Adaptation der WAIS-IV von D. Wechsler* [Measurement instrument]. Frankfurt/Main: Pearson Assessment.\r\n{.citation-indented}', 'A testothek is a library of psychological tests. You can borrow licensed psychological tests ranging from the Beck Depression Inventory (Hautzinger, Keller, Kühne; 2009) to the Wechsler Adult Intelligence Scale (Petermann, 2012). \r\n{.lead}\r\n\r\nMost universities’ psychology departments have a testothek, we recommend you to check with your institution for more information. The following brief tutorial introduces the search functionality at the University of Basel.\r\n\r\n![embed](https://vimeo.com/252900682)\r\n\r\nYou can find more information (in German) about the location and the opening hours of the testothek at the psychology department of the University of Basel [here](https://psychologie.unibas.ch/de/forschung/forschungseinrichtungen/testothek/). To find tests you can follow the direct link to the [Testothek](https://testothek.psycho.unibas.ch/). Note: certain links are only freely accessible within [eduroam](https://mobile.unibas.ch/home.html). If you want to use resources from the university at home, you need to install a [VPN Client](https://mobile.unibas.ch/home.html).\r\n\r\nTip: note down how to score the test results (see test manual) if you need to return the test prior to gathering data. Also note down the test results of the general population (test norms). Remember that the test material is copyright protected, that means you cannot share the test information publicly.\r\n\r\n<br/>\r\n\r\n------\r\n\r\n###References\r\n\r\nHautzinger, M., Keller, F., Kühner C. (2009). *Beck-Depressions-Inventar–Revision (BDI-II). Deutsche Version* [Measurement instrument]. 2nd Ed. Frankfurt/Main: Pearson Assessment.\r\n{.citation-indented}\r\n\r\nPetermann, F. (2012). *WAIS-IV. Wechsler Adult Intelligence Scale–Fourth Edition. Deutschsprachige Adaptation der WAIS-IV von D. Wechsler* [Measurement instrument]. Frankfurt/Main: Pearson Assessment.\r\n{.citation-indented}', 'A testothek is a library of psychological tests. You can borrow licensed psychological tests ranging from the Beck Depression Inventory (Hautzinger, Keller, Kühne; 2009) to the Wechsler Adult Intelligence Scale (Petermann, 2012). \r\n{.lead}\r\n\r\nMost universities’ psychology departments have a testothek, we recommend you to check with your institution for more information. The following brief tutorial introduces the search functionality at the University of Basel.\r\n\r\n![embed](https://vimeo.com/252900682)\r\n\r\nYou can find more information (in German) about the location and the opening hours of the testothek at the psychology department of the University of Basel [here](https://psychologie.unibas.ch/de/forschung/forschungseinrichtungen/testothek/). To find tests you can follow the direct link to the [Testothek](https://testothek.psycho.unibas.ch/). Note: certain links are only freely accessible within [eduroam](https://mobile.unibas.ch/home.html). If you want to use resources from the university at home, you need to install a [VPN Client](https://mobile.unibas.ch/home.html).\r\n\r\nTip: note down how to score the test results (see test manual) if you need to return the test prior to gathering data. Also note down the test results of the general population (test norms). Remember that the test material is copyright protected, that means you cannot share the test information publicly.\r\n\r\n<br/>\r\n\r\n------\r\n\r\n###References\r\n\r\nHautzinger, M., Keller, F., Kühner C. (2009). *Beck-Depressions-Inventar–Revision (BDI-II). Deutsche Version* [Measurement instrument]. 2nd Ed. Frankfurt/Main: Pearson Assessment.\r\n{.citation-indented}\r\n\r\nPetermann, F. (2012). *WAIS-IV. Wechsler Adult Intelligence Scale–Fourth Edition. Deutschsprachige Adaptation der WAIS-IV von D. Wechsler* [Measurement instrument]. Frankfurt/Main: Pearson Assessment.\r\n{.citation-indented}', None, '', None, None, None, None, None, None, None, 'University of Basel', 'University of Basel', 'University of Basel', None, 'TV', '3 min.', 5, 'published', False, None, None, None, None, 19)]])}, None) {} <django_redis.cache.RedisCache object at 0x7910e287a790>
/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in run(101)
  return _run_old_run_func()

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in _run_old_run_func(94)
  return old_run_func(self, *a, **kw)

/usr/local/lib/python3.11/concurrent/futures/thread.py in _worker(83)
  work_item.run()

/usr/local/lib/python3.11/concurrent/futures/thread.py in run(58)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/corsheaders/middleware.py in __call__(56)
  result = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in middleware(32)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/allauth/account/middleware.py in middleware(36)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/simple_history/middleware.py in middleware(41)
  return get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/django_htmx/middleware.py in __call__(43)
  return self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in __call__(168)
  response = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/panels.py in process_request(41)
  return super(CachalotPanel, self).process_request(request)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in __call__(244)
  current_executor.run_until_future(call_result)

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run_until_future(81)
  work_item.run()

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run(40)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_wrapped_callback(90)
  return callback(request, *args, **kwargs)

/app/project/utils/decorators.py in apply_cache(72)
  cache.set(CACHE_KEY, response.render(), ttl)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_patched_render(41)
  return old_render(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in render(114)
  self.content = self.rendered_content

/usr/local/lib/python3.11/site-packages/sentry_sdk/utils.py in runner(1788)
  return sentry_patched_function(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/templates.py in rendered_content(77)
  return real_rendered_content.fget(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in rendered_content(92)
  return template.render(context, self._request)

/usr/local/lib/python3.11/site-packages/django/template/backends/django.py in render(61)
  return self.template.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(175)
  return self._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(208)
  return template.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(177)
  return self._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py in render(321)
  return nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py in render(238)
  nodelist.append(node.render_annotated(context))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py in render(194)
  len_values = len(values)

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(37)
  return original(compiler, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(96)
  return _get_result_or_execute_query(

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in _get_result_or_execute_query(71)
  cache.set_many(to_be_set, cachalot_settings.CACHALOT_TIMEOUT)

0,4493 get_many (['e3a5db5a670ad803efb866441f33de58309be2e2', '76e323efd8711853e13c9f7cf976845908364eb2', '138549f5508bbba7283d6a0625e51c589d845e8f', '4af1b946643503680f9e0e13f1f816fa46caf02a'],) {} <django_redis.cache.RedisCache object at 0x7910e287a790>
/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in run(101)
  return _run_old_run_func()

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in _run_old_run_func(94)
  return old_run_func(self, *a, **kw)

/usr/local/lib/python3.11/concurrent/futures/thread.py in _worker(83)
  work_item.run()

/usr/local/lib/python3.11/concurrent/futures/thread.py in run(58)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/corsheaders/middleware.py in __call__(56)
  result = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in middleware(32)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/allauth/account/middleware.py in middleware(36)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/simple_history/middleware.py in middleware(41)
  return get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/django_htmx/middleware.py in __call__(43)
  return self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in __call__(168)
  response = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/panels.py in process_request(41)
  return super(CachalotPanel, self).process_request(request)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in __call__(244)
  current_executor.run_until_future(call_result)

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run_until_future(81)
  work_item.run()

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run(40)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_wrapped_callback(90)
  return callback(request, *args, **kwargs)

/app/project/utils/decorators.py in apply_cache(72)
  cache.set(CACHE_KEY, response.render(), ttl)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_patched_render(41)
  return old_render(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in render(114)
  self.content = self.rendered_content

/usr/local/lib/python3.11/site-packages/sentry_sdk/utils.py in runner(1788)
  return sentry_patched_function(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/templates.py in rendered_content(77)
  return real_rendered_content.fget(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in rendered_content(92)
  return template.render(context, self._request)

/usr/local/lib/python3.11/site-packages/django/template/backends/django.py in render(61)
  return self.template.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(175)
  return self._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(208)
  return template.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(177)
  return self._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py in render(321)
  return nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py in render(238)
  nodelist.append(node.render_annotated(context))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py in render(194)
  len_values = len(values)

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(37)
  return original(compiler, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(96)
  return _get_result_or_execute_query(

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in _get_result_or_execute_query(46)
  data = cache.get_many(table_cache_keys + [cache_key])

1,1885 set_many ({'4af1b946643503680f9e0e13f1f816fa46caf02a': (1736871783.182115, [[(50, datetime.datetime(2020, 11, 2, 15, 9, 33, 774510, tzinfo=datetime.timezone.utc), datetime.datetime(2020, 11, 2, 15, 9, 37, 368340, tzinfo=datetime.timezone.utc), datetime.datetime(2020, 11, 2, 15, 9, 37, 368351, tzinfo=datetime.timezone.utc), False, 'Structuring a scientific paper', 'Structuring a scientific paper', 'Structuring a scientific paper', None, '', '', None, None, '', None, None, None, 'conducting-psychological-research/writing-a-scientific-report/structuring-a-scientific-paper/offenes_buch.jpg', 'structuring-a-scientific-paper', 'In this article we will give you a short overview about how to set up your final paper according to the guidelines of the American Psychological Association (APA) and the sections of your article.\r\n{.lead}\r\n\r\nAn APA article has a predefined number of sections and a certain formatting. The structure contains the first-level headings: Abstract, Introduction, Method, Results, Discussion, Implications/Conclusion and References. \r\n\r\nWe compiled a PDF with a beginner’s guide to APA that you find in the ‘downloads’ section below.', 'In this article we will give you a short overview about how to set up your final paper according to the guidelines of the American Psychological Association (APA) and the sections of your article.\r\n{.lead}\r\n\r\nAn APA article has a predefined number of sections and a certain formatting. The structure contains the first-level headings: Abstract, Introduction, Method, Results, Discussion, Implications/Conclusion and References. \r\n\r\nWe compiled a PDF with a beginner’s guide to APA that you find in the ‘downloads’ section below.', 'In this article we will give you a short overview about how to set up your final paper according to the guidelines of the American Psychological Association (APA) and the sections of your article.\r\n{.lead}\r\n\r\nAn APA article has a predefined number of sections and a certain formatting. The structure contains the first-level headings: Abstract, Introduction, Method, Results, Discussion, Implications/Conclusion and References. \r\n\r\nWe compiled a PDF with a beginner’s guide to APA that you find in the ‘downloads’ section below.', '', '', None, None, None, None, None, None, None, 'University of Basel', 'University of Basel', 'University of Basel', '', 'TT', '10 min.', 0, 'published', False, None, None, None, None, 21), (68, datetime.datetime(2020, 11, 2, 15, 9, 33, 774510, tzinfo=datetime.timezone.utc), datetime.datetime(2021, 11, 30, 8, 25, 14, 46017, tzinfo=datetime.timezone.utc), datetime.datetime(2021, 11, 30, 8, 25, 14, 19941, tzinfo=datetime.timezone.utc), False, 'How to write introductions and theory sections', 'How to write introductions and theory sections', 'How to write introductions and theory sections', None, '', None, None, None, '', None, None, None, '', 'how-to-write-introductions-and-theory-sections', "Let us show you briefly how to write a paper. You should supplement this reading with more detailed literature, such as the book by Peter Harris ‘Designing and reporting experiments in Psychology’.\r\n{.lead}\r\n \r\n**Preliminary remarks** \r\nA brief word on the order in which you want to arrange different parts of your introduction: many of the main textbooks (including the book by Harris) will encourage you to think of your introduction like a funnel. This means you start very broad and basic and then become more and more specific. This is in principle a good method to follow. However, always remember that it is crucial for the readers to get hooked on early, as they may get bored or worse: stop reading. Therefore, it is always good to start your introduction with a short and precise ‘Why care?’ sentence or paragraph. Basically, you want catch the readers’ interest within the very first sentences.\r\n \r\n**Relevance of the study** \r\nYou may want to consider opening your introduction with one of the following four reasons why you consider your study as relevant. \r\n**Motive 1: Practical (current) importance** (for example: ‘Brexit has shown that…’, ‘Trump’s 2017 election was a sign that…’) \r\n**Motive 2: Contribution to an ongoing debate in the literature** (for example: ‘There is mixed evidence in the literature about how people decide between choice alternatives depending on their mood.’) \r\n**Motive 3: Understand outstanding phenomena** (your work has potential to elucidate mechanisms for phenomena or patterns that are extraordinary or outstanding, for example: ‘Humans are remarkable at recognizing faces, however we don’t fully understand how they do it.’) \r\n**Motive 4: Understand problematic phenomena** (your work potential identifies and addresses mechanisms for phenomena or patterns that are considered problematic, pathological or the source of harm, for example: ‘Humans often deviate from economic rationality and make decisions which incur substantial losses, but we do not fully understand the factors contributing to such disadvantageous decision making.’) \r\n \r\nOne way to start your paper in an attention-grabbing way is to ask a direct question. This makes the readers curious and the chance that they continue their reading is bigger. Once you have grabbed your readers’ attention, you can limit the scope of your subject and ‘start thinking funnel’!\r\n\r\n**Literature review (ca. 2-4 pages)** \r\nAs a next step, you need to write a literature review. It **summarizes relevant theories and research findings**. The emphasis here lies on the word **relevant**. Don’t try to impress the readers with tons of literature. They only will be satisfied if you are able to precisely summarize the main studies, results, debates, theories in your field of interest.\r\n\r\nIt may be hard to decide which studies to include and which to leave out, because of the large body of literature. It may help to ask yourself whether a study is **directly relevant** for your work or whether it is not. The former should be included, the latter should probably be left out. How is it possible to differentiate between these two? If the findings of the study you want to review directly address your research question, it must be included. If the findings address different questions, they probably can be left out. A good starting point is to include meta-analyses, reviews, as well as the most cited and most recent works that are directly related to your research question. This does NOT mean you should ignore original papers or only look at publications from the past five years! A well-balanced and well-informed literature review often spans many decades, fields and ideas, but recent papers usually give you a good starting point for your own literature search.\r\n \r\nOnce you have decided on the materials that will form the content of your introduction, the summary you provide must be as precise, short and informative as possible. Here are some advices to reach this goal: \r\n➔ First, make sure you **introduce the theoretical framework before you present empirical studies**. A good introduction does not simply list research findings, but states the main theoretical framework(s) first and then summarizes the evidence for, or against, a certain theory. \r\n➔ Be aware of the **difference between theory and evidence**. This is an important distinction. Evidence or research findings only provide a specific pattern in your data, perhaps the mean difference between two groups or the effect of one variable on another. Theory in contrast suggests what patterns are to be expected given certain assumptions about the underlying mechanisms. Put differently, evidence pertains to what you observe in your data, whereas theory pertains to what you would expect, possible interpretations, and how or why you would expect certain observations. \r\n➔ A good introduction not only describes but **critically evaluates prior work**, which is only possible if you establish the criteria for your evaluation. Your evaluation criteria should be immediately transparent to the readers by delineating your theoretical framework. This provides the boundaries and conditions for your expectations. \r\n \r\nIf your work aims to directly test a theory or pit theories against each other, you will automatically include a theory section. However, you may have a situation where there is no (or no useful) theory. In this case it can help to shift your focus and delve into other fields. For example, you may be interested in the effect of hormones on risk taking, but you may also find a lot of relevant research if you look at studies investigating the link between personality, impulsivity, or self-control. Some of these differences may be purely semantic and rooted in different fields using different terminology for ostensibly the same thing. But this is not always the case and you may find a lot of useful theory if you cross over to related research topics.\r\n \r\n**Writing tip**: do not use vague words. Instead you should define key terms for your readers. It is better to define too much than too little. The definition can be in parenthesis, between hyphens, commas, or as a single sentence. For example:\r\n\r\n>The current work investigates prosocial behavior (people acting benevolently for others without a direct or indirect reward). \r\n>\r\n>We study the influence of shame - feeling emotionally uncomfortable after doing something - on consumer behavior. \r\n>\r\n>Risk-taking is an important topic in psychology. Throughout this paper risk-taking is defined as selecting actions with great variability in consequences. \r\n\r\nYou can improve your writing style by using standard phrases that writers use in academic writing. Check out sentences, which occur again and again in papers that you read (it is okay to use these phrases). Or use sources that provide you with such phrases, such as the [Academic Phrasebank](http://www.phrasebank.manchester.ac.uk/).\r\n\r\n**Introduce your research question (ca. 1-4 paragraphs)** \r\nAfter you have introduced and critically evaluated the current state of research, it is time to present and justify your research question. Explain the readers what is currently not known, debated or unclear, reveal the research gaps in the literature, and thereby create your niche. Where does a current theory (the one that you have reviewed before) fall short? Perhaps a prominent theory has not been tested thoroughly? Do two theories predict opposite patterns in the data? In formulating your research question, you position your research and make explicit why your work matters. Remember: you want to keep the readers interested, so if you can show why your work is essential and/or has implications for (e.g. clinical) applications, you have successfully motivated your work. Therefore it helps to ask yourself and answer the following questions: \r\n<br/>\r\n1. How does my work contribute to the current literature? \r\n2. How does my work contribute to or build on existing work? \r\n3. What research gap does my work close, how is my work related to other studies? \r\n \r\nYou can provide a **brief overview of your study** here, perhaps to show why it differs from previous work (different data? different design? different participants? etc.) or how you are going to close the gap you identified while motivating your work. Important: do not provide details, this is what the method section is for. But if there is anything special about your study, say so, it keeps the readers interested.\r\n\r\n**State your research hypothesis (ca. 1-2 paragraphs)** \r\nNow, you are almost finished writing your introduction. The only thing missing is to succinctly **state your research hypothesis**. This means, you need to tell the readers what results you expect from your study. It should be clear by now that the theories you mentioned before have to logically lead to the answers to the hypothesis (see [1.2 How to find theories and hypothesis](https://tales.nmc.unibas.ch/de/conducting-psychological-research-6/research-questions-and-theories-20/how-to-find-theories-and-hypothesis-52)). Previous findings can of course also guide your expectations, but these should ideally be discussed with reference to your theory.\r\n\r\nIf you want to **pitch two theories against each other**, here is an example how you could formulate this: ‘According to the ‘mood maintenance hypothesis’, positive affect will result in risk averse behaviour, whereas according to the ‘affect infusion model’ positive affect will result in risk seeking behaviour.’\r\n \r\nMake sure you use the appropriate terminology, such as **one-sided (directed) hypothesis** or **two-sided (undirected) hypothesis**, and distinguish between the **experimental and null hypothesis**. If you are unsure what these terms refer to, please consult Peter Harris’ 'Designing and reporting experiments in Psychology'.\r\n\r\nBefore you finish, check if everything you mention in your hypothesis appears at least once in the paragraphs before the hypothesis. It is a mistake if your hypothesis introduce new concepts or new theories. In the example above for instance, it would be a mistake if the mood maintenance hypothesis had not been explained before.\r\n\r\n<br/>\r\n\r\n------\r\n\r\n###References \r\n\r\nHarris, P. (2008). *Designing and reporting experiments in psychology*. McGraw-Hill Education (UK).\r\n{.citation-indented}", "Let us show you briefly how to write a paper. You should supplement this reading with more detailed literature, such as the book by Peter Harris ‘Designing and reporting experiments in Psychology’.\r\n{.lead}\r\n \r\n**Preliminary remarks** \r\nA brief word on the order in which you want to arrange different parts of your introduction: many of the main textbooks (including the book by Harris) will encourage you to think of your introduction like a funnel. This means you start very broad and basic and then become more and more specific. This is in principle a good method to follow. However, always remember that it is crucial for the readers to get hooked on early, as they may get bored or worse: stop reading. Therefore, it is always good to start your introduction with a short and precise ‘Why care?’ sentence or paragraph. Basically, you want catch the readers’ interest within the very first sentences.\r\n \r\n**Relevance of the study** \r\nYou may want to consider opening your introduction with one of the following four reasons why you consider your study as relevant. \r\n**Motive 1: Practical (current) importance** (for example: ‘Brexit has shown that…’, ‘Trump’s 2017 election was a sign that…’) \r\n**Motive 2: Contribution to an ongoing debate in the literature** (for example: ‘There is mixed evidence in the literature about how people decide between choice alternatives depending on their mood.’) \r\n**Motive 3: Understand outstanding phenomena** (your work has potential to elucidate mechanisms for phenomena or patterns that are extraordinary or outstanding, for example: ‘Humans are remarkable at recognizing faces, however we don’t fully understand how they do it.’) \r\n**Motive 4: Understand problematic phenomena** (your work potential identifies and addresses mechanisms for phenomena or patterns that are considered problematic, pathological or the source of harm, for example: ‘Humans often deviate from economic rationality and make decisions which incur substantial losses, but we do not fully understand the factors contributing to such disadvantageous decision making.’) \r\n \r\nOne way to start your paper in an attention-grabbing way is to ask a direct question. This makes the readers curious and the chance that they continue their reading is bigger. Once you have grabbed your readers’ attention, you can limit the scope of your subject and ‘start thinking funnel’!\r\n\r\n**Literature review (ca. 2-4 pages)** \r\nAs a next step, you need to write a literature review. It **summarizes relevant theories and research findings**. The emphasis here lies on the word **relevant**. Don’t try to impress the readers with tons of literature. They only will be satisfied if you are able to precisely summarize the main studies, results, debates, theories in your field of interest.\r\n\r\nIt may be hard to decide which studies to include and which to leave out, because of the large body of literature. It may help to ask yourself whether a study is **directly relevant** for your work or whether it is not. The former should be included, the latter should probably be left out. How is it possible to differentiate between these two? If the findings of the study you want to review directly address your research question, it must be included. If the findings address different questions, they probably can be left out. A good starting point is to include meta-analyses, reviews, as well as the most cited and most recent works that are directly related to your research question. This does NOT mean you should ignore original papers or only look at publications from the past five years! A well-balanced and well-informed literature review often spans many decades, fields and ideas, but recent papers usually give you a good starting point for your own literature search.\r\n \r\nOnce you have decided on the materials that will form the content of your introduction, the summary you provide must be as precise, short and informative as possible. Here are some advices to reach this goal: \r\n➔ First, make sure you **introduce the theoretical framework before you present empirical studies**. A good introduction does not simply list research findings, but states the main theoretical framework(s) first and then summarizes the evidence for, or against, a certain theory. \r\n➔ Be aware of the **difference between theory and evidence**. This is an important distinction. Evidence or research findings only provide a specific pattern in your data, perhaps the mean difference between two groups or the effect of one variable on another. Theory in contrast suggests what patterns are to be expected given certain assumptions about the underlying mechanisms. Put differently, evidence pertains to what you observe in your data, whereas theory pertains to what you would expect, possible interpretations, and how or why you would expect certain observations. \r\n➔ A good introduction not only describes but **critically evaluates prior work**, which is only possible if you establish the criteria for your evaluation. Your evaluation criteria should be immediately transparent to the readers by delineating your theoretical framework. This provides the boundaries and conditions for your expectations. \r\n \r\nIf your work aims to directly test a theory or pit theories against each other, you will automatically include a theory section. However, you may have a situation where there is no (or no useful) theory. In this case it can help to shift your focus and delve into other fields. For example, you may be interested in the effect of hormones on risk taking, but you may also find a lot of relevant research if you look at studies investigating the link between personality, impulsivity, or self-control. Some of these differences may be purely semantic and rooted in different fields using different terminology for ostensibly the same thing. But this is not always the case and you may find a lot of useful theory if you cross over to related research topics.\r\n \r\n**Writing tip**: do not use vague words. Instead you should define key terms for your readers. It is better to define too much than too little. The definition can be in parenthesis, between hyphens, commas, or as a single sentence. For example:\r\n\r\n>The current work investigates prosocial behavior (people acting benevolently for others without a direct or indirect reward). \r\n>\r\n>We study the influence of shame - feeling emotionally uncomfortable after doing something - on consumer behavior. \r\n>\r\n>Risk-taking is an important topic in psychology. Throughout this paper risk-taking is defined as selecting actions with great variability in consequences. \r\n\r\nYou can improve your writing style by using standard phrases that writers use in academic writing. Check out sentences, which occur again and again in papers that you read (it is okay to use these phrases). Or use sources that provide you with such phrases, such as the [Academic Phrasebank](http://www.phrasebank.manchester.ac.uk/).\r\n\r\n**Introduce your research question (ca. 1-4 paragraphs)** \r\nAfter you have introduced and critically evaluated the current state of research, it is time to present and justify your research question. Explain the readers what is currently not known, debated or unclear, reveal the research gaps in the literature, and thereby create your niche. Where does a current theory (the one that you have reviewed before) fall short? Perhaps a prominent theory has not been tested thoroughly? Do two theories predict opposite patterns in the data? In formulating your research question, you position your research and make explicit why your work matters. Remember: you want to keep the readers interested, so if you can show why your work is essential and/or has implications for (e.g. clinical) applications, you have successfully motivated your work. Therefore it helps to ask yourself and answer the following questions: \r\n<br/>\r\n1. How does my work contribute to the current literature? \r\n2. How does my work contribute to or build on existing work? \r\n3. What research gap does my work close, how is my work related to other studies? \r\n \r\nYou can provide a **brief overview of your study** here, perhaps to show why it differs from previous work (different data? different design? different participants? etc.) or how you are going to close the gap you identified while motivating your work. Important: do not provide details, this is what the method section is for. But if there is anything special about your study, say so, it keeps the readers interested.\r\n\r\n**State your research hypothesis (ca. 1-2 paragraphs)** \r\nNow, you are almost finished writing your introduction. The only thing missing is to succinctly **state your research hypothesis**. This means, you need to tell the readers what results you expect from your study. It should be clear by now that the theories you mentioned before have to logically lead to the answers to the hypothesis (see [1.2 How to find theories and hypothesis](https://tales.nmc.unibas.ch/de/conducting-psychological-research-6/research-questions-and-theories-20/how-to-find-theories-and-hypothesis-52)). Previous findings can of course also guide your expectations, but these should ideally be discussed with reference to your theory.\r\n\r\nIf you want to **pitch two theories against each other**, here is an example how you could formulate this: ‘According to the ‘mood maintenance hypothesis’, positive affect will result in risk averse behaviour, whereas according to the ‘affect infusion model’ positive affect will result in risk seeking behaviour.’\r\n \r\nMake sure you use the appropriate terminology, such as **one-sided (directed) hypothesis** or **two-sided (undirected) hypothesis**, and distinguish between the **experimental and null hypothesis**. If you are unsure what these terms refer to, please consult Peter Harris’ 'Designing and reporting experiments in Psychology'.\r\n\r\nBefore you finish, check if everything you mention in your hypothesis appears at least once in the paragraphs before the hypothesis. It is a mistake if your hypothesis introduce new concepts or new theories. In the example above for instance, it would be a mistake if the mood maintenance hypothesis had not been explained before.\r\n\r\n<br/>\r\n\r\n------\r\n\r\n###References \r\n\r\nHarris, P. (2008). *Designing and reporting experiments in psychology*. McGraw-Hill Education (UK).\r\n{.citation-indented}", "Let us show you briefly how to write a paper. You should supplement this reading with more detailed literature, such as the book by Peter Harris ‘Designing and reporting experiments in Psychology’.\r\n{.lead}\r\n \r\n**Preliminary remarks** \r\nA brief word on the order in which you want to arrange different parts of your introduction: many of the main textbooks (including the book by Harris) will encourage you to think of your introduction like a funnel. This means you start very broad and basic and then become more and more specific. This is in principle a good method to follow. However, always remember that it is crucial for the readers to get hooked on early, as they may get bored or worse: stop reading. Therefore, it is always good to start your introduction with a short and precise ‘Why care?’ sentence or paragraph. Basically, you want catch the readers’ interest within the very first sentences.\r\n \r\n**Relevance of the study** \r\nYou may want to consider opening your introduction with one of the following four reasons why you consider your study as relevant. \r\n**Motive 1: Practical (current) importance** (for example: ‘Brexit has shown that…’, ‘Trump’s 2017 election was a sign that…’) \r\n**Motive 2: Contribution to an ongoing debate in the literature** (for example: ‘There is mixed evidence in the literature about how people decide between choice alternatives depending on their mood.’) \r\n**Motive 3: Understand outstanding phenomena** (your work has potential to elucidate mechanisms for phenomena or patterns that are extraordinary or outstanding, for example: ‘Humans are remarkable at recognizing faces, however we don’t fully understand how they do it.’) \r\n**Motive 4: Understand problematic phenomena** (your work potential identifies and addresses mechanisms for phenomena or patterns that are considered problematic, pathological or the source of harm, for example: ‘Humans often deviate from economic rationality and make decisions which incur substantial losses, but we do not fully understand the factors contributing to such disadvantageous decision making.’) \r\n \r\nOne way to start your paper in an attention-grabbing way is to ask a direct question. This makes the readers curious and the chance that they continue their reading is bigger. Once you have grabbed your readers’ attention, you can limit the scope of your subject and ‘start thinking funnel’!\r\n\r\n**Literature review (ca. 2-4 pages)** \r\nAs a next step, you need to write a literature review. It **summarizes relevant theories and research findings**. The emphasis here lies on the word **relevant**. Don’t try to impress the readers with tons of literature. They only will be satisfied if you are able to precisely summarize the main studies, results, debates, theories in your field of interest.\r\n\r\nIt may be hard to decide which studies to include and which to leave out, because of the large body of literature. It may help to ask yourself whether a study is **directly relevant** for your work or whether it is not. The former should be included, the latter should probably be left out. How is it possible to differentiate between these two? If the findings of the study you want to review directly address your research question, it must be included. If the findings address different questions, they probably can be left out. A good starting point is to include meta-analyses, reviews, as well as the most cited and most recent works that are directly related to your research question. This does NOT mean you should ignore original papers or only look at publications from the past five years! A well-balanced and well-informed literature review often spans many decades, fields and ideas, but recent papers usually give you a good starting point for your own literature search.\r\n \r\nOnce you have decided on the materials that will form the content of your introduction, the summary you provide must be as precise, short and informative as possible. Here are some advices to reach this goal: \r\n➔ First, make sure you **introduce the theoretical framework before you present empirical studies**. A good introduction does not simply list research findings, but states the main theoretical framework(s) first and then summarizes the evidence for, or against, a certain theory. \r\n➔ Be aware of the **difference between theory and evidence**. This is an important distinction. Evidence or research findings only provide a specific pattern in your data, perhaps the mean difference between two groups or the effect of one variable on another. Theory in contrast suggests what patterns are to be expected given certain assumptions about the underlying mechanisms. Put differently, evidence pertains to what you observe in your data, whereas theory pertains to what you would expect, possible interpretations, and how or why you would expect certain observations. \r\n➔ A good introduction not only describes but **critically evaluates prior work**, which is only possible if you establish the criteria for your evaluation. Your evaluation criteria should be immediately transparent to the readers by delineating your theoretical framework. This provides the boundaries and conditions for your expectations. \r\n \r\nIf your work aims to directly test a theory or pit theories against each other, you will automatically include a theory section. However, you may have a situation where there is no (or no useful) theory. In this case it can help to shift your focus and delve into other fields. For example, you may be interested in the effect of hormones on risk taking, but you may also find a lot of relevant research if you look at studies investigating the link between personality, impulsivity, or self-control. Some of these differences may be purely semantic and rooted in different fields using different terminology for ostensibly the same thing. But this is not always the case and you may find a lot of useful theory if you cross over to related research topics.\r\n \r\n**Writing tip**: do not use vague words. Instead you should define key terms for your readers. It is better to define too much than too little. The definition can be in parenthesis, between hyphens, commas, or as a single sentence. For example:\r\n\r\n>The current work investigates prosocial behavior (people acting benevolently for others without a direct or indirect reward). \r\n>\r\n>We study the influence of shame - feeling emotionally uncomfortable after doing something - on consumer behavior. \r\n>\r\n>Risk-taking is an important topic in psychology. Throughout this paper risk-taking is defined as selecting actions with great variability in consequences. \r\n\r\nYou can improve your writing style by using standard phrases that writers use in academic writing. Check out sentences, which occur again and again in papers that you read (it is okay to use these phrases). Or use sources that provide you with such phrases, such as the [Academic Phrasebank](http://www.phrasebank.manchester.ac.uk/).\r\n\r\n**Introduce your research question (ca. 1-4 paragraphs)** \r\nAfter you have introduced and critically evaluated the current state of research, it is time to present and justify your research question. Explain the readers what is currently not known, debated or unclear, reveal the research gaps in the literature, and thereby create your niche. Where does a current theory (the one that you have reviewed before) fall short? Perhaps a prominent theory has not been tested thoroughly? Do two theories predict opposite patterns in the data? In formulating your research question, you position your research and make explicit why your work matters. Remember: you want to keep the readers interested, so if you can show why your work is essential and/or has implications for (e.g. clinical) applications, you have successfully motivated your work. Therefore it helps to ask yourself and answer the following questions: \r\n<br/>\r\n1. How does my work contribute to the current literature? \r\n2. How does my work contribute to or build on existing work? \r\n3. What research gap does my work close, how is my work related to other studies? \r\n \r\nYou can provide a **brief overview of your study** here, perhaps to show why it differs from previous work (different data? different design? different participants? etc.) or how you are going to close the gap you identified while motivating your work. Important: do not provide details, this is what the method section is for. But if there is anything special about your study, say so, it keeps the readers interested.\r\n\r\n**State your research hypothesis (ca. 1-2 paragraphs)** \r\nNow, you are almost finished writing your introduction. The only thing missing is to succinctly **state your research hypothesis**. This means, you need to tell the readers what results you expect from your study. It should be clear by now that the theories you mentioned before have to logically lead to the answers to the hypothesis (see [1.2 How to find theories and hypothesis](https://tales.nmc.unibas.ch/de/conducting-psychological-research-6/research-questions-and-theories-20/how-to-find-theories-and-hypothesis-52)). Previous findings can of course also guide your expectations, but these should ideally be discussed with reference to your theory.\r\n\r\nIf you want to **pitch two theories against each other**, here is an example how you could formulate this: ‘According to the ‘mood maintenance hypothesis’, positive affect will result in risk averse behaviour, whereas according to the ‘affect infusion model’ positive affect will result in risk seeking behaviour.’\r\n \r\nMake sure you use the appropriate terminology, such as **one-sided (directed) hypothesis** or **two-sided (undirected) hypothesis**, and distinguish between the **experimental and null hypothesis**. If you are unsure what these terms refer to, please consult Peter Harris’ 'Designing and reporting experiments in Psychology'.\r\n\r\nBefore you finish, check if everything you mention in your hypothesis appears at least once in the paragraphs before the hypothesis. It is a mistake if your hypothesis introduce new concepts or new theories. In the example above for instance, it would be a mistake if the mood maintenance hypothesis had not been explained before.\r\n\r\n<br/>\r\n\r\n------\r\n\r\n###References \r\n\r\nHarris, P. (2008). *Designing and reporting experiments in psychology*. McGraw-Hill Education (UK).\r\n{.citation-indented}", '', '', '', '', '', None, None, None, None, 'University of Basel', 'University of Basel', 'University of Basel', '', 'TT', '20 min.', 1, 'published', False, None, None, None, None, 21), (74, datetime.datetime(2020, 11, 2, 15, 9, 33, 774510, tzinfo=datetime.timezone.utc), datetime.datetime(2020, 11, 2, 15, 9, 37, 372391, tzinfo=datetime.timezone.utc), datetime.datetime(2020, 11, 2, 15, 9, 37, 372401, tzinfo=datetime.timezone.utc), False, 'Write a method section', 'Write a method section', 'Write a method section', None, '', '', '', None, '', None, None, None, '', 'write-a-method-section', 'This article briefly introduces how to write a method section. The method section of a paper describes the participant pool, your experimental design, and your measurement. \r\n{.lead}\r\n\r\nThe first part of the method section is called ‘Participants’. It always contains information about the subjects you gathered, their basic demographic data, where and when you recruited them, how they were compensated and which Institutional Review Board (IRB) approved your study. Here is an example of a ‘Participants’ section (Jarecki, Meder, & Nelson, 2017, p. 18):\r\n\r\n> Thirty people (mean age 23.8 years, range 19 to 33 years, 67% female) participated; remuneration was 12 euros. We recruited via the Center for Adaptive Behavior and Cognition at the Max Planck Institute for Human Development in Berlin, Germany. Data were collected from September to December 2012 at the center; the experiment was conducted in accordance with the ethical and data protection guidelines there.\r\n\r\nThe second part of the method section is called ‘Procedure’. It describes the participants’ task in as much detail as possible such that another researcher could re-do the experiment. Writing tip: write from the participants’ point of view and be very specific. Here a very short example:\r\n\r\n> Participants’ task was to try out different chewing gums with the flavors cherry, lime, and peanut. Participants first tried one chewing gum. The tasting was self-paced. Chewing gums were presented in random order. Participants rated each sample on a 5-point Likert scale (from *1 = extremely bad* to *5 = extremely good*). Thereafter, participants filled out a personality scale, and demographic information.\r\n\r\nThe next part of the method section is called ‘Material’. It details the measurement instruments used including standardized tests. Writing tip: in this section some writers prefer to use passive voice. This section is sometimes rather short. For example:\r\n\r\n> The experiment consisted of a computerized laboratory task. Participants’ personality was measured with the Neo-PIR short form for adults (Mooi, Comijs, De Fruyt, De Ritter, Hoekstra, & Beekman; 2011). \r\n\r\nIf you use vignettes, it is good practice to include a description of the vignette or the task. For example (Stewart, Chater, Stott, & Reimers; 2003, p. 36): \r\n\r\n> Participants were given brief oral instructions. They were told that they would have to imagine making choices between playing a prospect to receive an amount of money and taking a smaller amount for sure. Each pair of options was presented on a separate page of a 36-page booklet and appeared as follows: \r\n>\r\n> Which option do you prefer? \r\n> ☐ 10% chance of £300 \r\n> ☐ £12 \r\n>\r\n> Participants were told to mark the option they would prefer and move on to the next page. They were also made aware that there was no objective right answer and that choice was a matter of personal preference.\r\n\r\nOften, writers also combine ‘Procedure’ and ‘Materials’ into one longer section. Sometimes the title ‘Stimuli’ is also used instead of ‘Material’.\r\n\r\n\r\n<br/>\r\n\r\n------\r\n\r\n###References\r\n\r\nJarecki, J. B., Meder, B., & Nelson, J. D. (2017). Naive and robust: class-conditional independence in human classification learning. *Cognitive Science*, 1–39. doi:10.1111/cogs.12496\r\n{.citation-indented}\r\n\r\nMooi, B., Comijs, H. C., De Fruyt, F., De Ritter, D., Hoekstra, H. A., & Beekman, A. T. F. (2011). A neo-pi-r short form for older adults. *International Journal of Methods in Psychiatric Research, 18*, n/a-n/a. doi:10.1002/mpr.342\r\n{.citation-indented}\r\n\r\nStewart, N., Chater, N., Stott, H. P., & Reimers, S. (2003). Prospect relativity: how choice options influence decision under risk. *Journal of Experimental Psychology: General, 132*, 23–46. doi:10.1037/0096-3445.132.1.23\r\n{.citation-indented}', 'This article briefly introduces how to write a method section. The method section of a paper describes the participant pool, your experimental design, and your measurement. \r\n{.lead}\r\n\r\nThe first part of the method section is called ‘Participants’. It always contains information about the subjects you gathered, their basic demographic data, where and when you recruited them, how they were compensated and which Institutional Review Board (IRB) approved your study. Here is an example of a ‘Participants’ section (Jarecki, Meder, & Nelson, 2017, p. 18):\r\n\r\n> Thirty people (mean age 23.8 years, range 19 to 33 years, 67% female) participated; remuneration was 12 euros. We recruited via the Center for Adaptive Behavior and Cognition at the Max Planck Institute for Human Development in Berlin, Germany. Data were collected from September to December 2012 at the center; the experiment was conducted in accordance with the ethical and data protection guidelines there.\r\n\r\nThe second part of the method section is called ‘Procedure’. It describes the participants’ task in as much detail as possible such that another researcher could re-do the experiment. Writing tip: write from the participants’ point of view and be very specific. Here a very short example:\r\n\r\n> Participants’ task was to try out different chewing gums with the flavors cherry, lime, and peanut. Participants first tried one chewing gum. The tasting was self-paced. Chewing gums were presented in random order. Participants rated each sample on a 5-point Likert scale (from *1 = extremely bad* to *5 = extremely good*). Thereafter, participants filled out a personality scale, and demographic information.\r\n\r\nThe next part of the method section is called ‘Material’. It details the measurement instruments used including standardized tests. Writing tip: in this section some writers prefer to use passive voice. This section is sometimes rather short. For example:\r\n\r\n> The experiment consisted of a computerized laboratory task. Participants’ personality was measured with the Neo-PIR short form for adults (Mooi, Comijs, De Fruyt, De Ritter, Hoekstra, & Beekman; 2011). \r\n\r\nIf you use vignettes, it is good practice to include a description of the vignette or the task. For example (Stewart, Chater, Stott, & Reimers; 2003, p. 36): \r\n\r\n> Participants were given brief oral instructions. They were told that they would have to imagine making choices between playing a prospect to receive an amount of money and taking a smaller amount for sure. Each pair of options was presented on a separate page of a 36-page booklet and appeared as follows: \r\n>\r\n> Which option do you prefer? \r\n> ☐ 10% chance of £300 \r\n> ☐ £12 \r\n>\r\n> Participants were told to mark the option they would prefer and move on to the next page. They were also made aware that there was no objective right answer and that choice was a matter of personal preference.\r\n\r\nOften, writers also combine ‘Procedure’ and ‘Materials’ into one longer section. Sometimes the title ‘Stimuli’ is also used instead of ‘Material’.\r\n\r\n\r\n<br/>\r\n\r\n------\r\n\r\n###References\r\n\r\nJarecki, J. B., Meder, B., & Nelson, J. D. (2017). Naive and robust: class-conditional independence in human classification learning. *Cognitive Science*, 1–39. doi:10.1111/cogs.12496\r\n{.citation-indented}\r\n\r\nMooi, B., Comijs, H. C., De Fruyt, F., De Ritter, D., Hoekstra, H. A., & Beekman, A. T. F. (2011). A neo-pi-r short form for older adults. *International Journal of Methods in Psychiatric Research, 18*, n/a-n/a. doi:10.1002/mpr.342\r\n{.citation-indented}\r\n\r\nStewart, N., Chater, N., Stott, H. P., & Reimers, S. (2003). Prospect relativity: how choice options influence decision under risk. *Journal of Experimental Psychology: General, 132*, 23–46. doi:10.1037/0096-3445.132.1.23\r\n{.citation-indented}', 'This article briefly introduces how to write a method section. The method section of a paper describes the participant pool, your experimental design, and your measurement. \r\n{.lead}\r\n\r\nThe first part of the method section is called ‘Participants’. It always contains information about the subjects you gathered, their basic demographic data, where and when you recruited them, how they were compensated and which Institutional Review Board (IRB) approved your study. Here is an example of a ‘Participants’ section (Jarecki, Meder, & Nelson, 2017, p. 18):\r\n\r\n> Thirty people (mean age 23.8 years, range 19 to 33 years, 67% female) participated; remuneration was 12 euros. We recruited via the Center for Adaptive Behavior and Cognition at the Max Planck Institute for Human Development in Berlin, Germany. Data were collected from September to December 2012 at the center; the experiment was conducted in accordance with the ethical and data protection guidelines there.\r\n\r\nThe second part of the method section is called ‘Procedure’. It describes the participants’ task in as much detail as possible such that another researcher could re-do the experiment. Writing tip: write from the participants’ point of view and be very specific. Here a very short example:\r\n\r\n> Participants’ task was to try out different chewing gums with the flavors cherry, lime, and peanut. Participants first tried one chewing gum. The tasting was self-paced. Chewing gums were presented in random order. Participants rated each sample on a 5-point Likert scale (from *1 = extremely bad* to *5 = extremely good*). Thereafter, participants filled out a personality scale, and demographic information.\r\n\r\nThe next part of the method section is called ‘Material’. It details the measurement instruments used including standardized tests. Writing tip: in this section some writers prefer to use passive voice. This section is sometimes rather short. For example:\r\n\r\n> The experiment consisted of a computerized laboratory task. Participants’ personality was measured with the Neo-PIR short form for adults (Mooi, Comijs, De Fruyt, De Ritter, Hoekstra, & Beekman; 2011). \r\n\r\nIf you use vignettes, it is good practice to include a description of the vignette or the task. For example (Stewart, Chater, Stott, & Reimers; 2003, p. 36): \r\n\r\n> Participants were given brief oral instructions. They were told that they would have to imagine making choices between playing a prospect to receive an amount of money and taking a smaller amount for sure. Each pair of options was presented on a separate page of a 36-page booklet and appeared as follows: \r\n>\r\n> Which option do you prefer? \r\n> ☐ 10% chance of £300 \r\n> ☐ £12 \r\n>\r\n> Participants were told to mark the option they would prefer and move on to the next page. They were also made aware that there was no objective right answer and that choice was a matter of personal preference.\r\n\r\nOften, writers also combine ‘Procedure’ and ‘Materials’ into one longer section. Sometimes the title ‘Stimuli’ is also used instead of ‘Material’.\r\n\r\n\r\n<br/>\r\n\r\n------\r\n\r\n###References\r\n\r\nJarecki, J. B., Meder, B., & Nelson, J. D. (2017). Naive and robust: class-conditional independence in human classification learning. *Cognitive Science*, 1–39. doi:10.1111/cogs.12496\r\n{.citation-indented}\r\n\r\nMooi, B., Comijs, H. C., De Fruyt, F., De Ritter, D., Hoekstra, H. A., & Beekman, A. T. F. (2011). A neo-pi-r short form for older adults. *International Journal of Methods in Psychiatric Research, 18*, n/a-n/a. doi:10.1002/mpr.342\r\n{.citation-indented}\r\n\r\nStewart, N., Chater, N., Stott, H. P., & Reimers, S. (2003). Prospect relativity: how choice options influence decision under risk. *Journal of Experimental Psychology: General, 132*, 23–46. doi:10.1037/0096-3445.132.1.23\r\n{.citation-indented}', None, '', None, None, None, None, None, None, None, 'University of Basel', 'University of Basel', 'University of Basel', None, 'TT', '5 min.', 2, 'published', False, None, None, None, None, 21), (75, datetime.datetime(2020, 11, 2, 15, 9, 33, 774510, tzinfo=datetime.timezone.utc), datetime.datetime(2021, 11, 30, 14, 54, 27, 844434, tzinfo=datetime.timezone.utc), datetime.datetime(2021, 11, 30, 14, 54, 27, 820112, tzinfo=datetime.timezone.utc), False, 'Write a results section', 'Write a results section', 'Write a results section', None, 'Show your results according to APA', 'Show your results according to APA', 'Show your results according to APA', None, '', None, None, None, '', 'write-a-results-section', 'This article explains how to report your results according to APA standards. The results section simply reports your results, which means it presents the ‘dry facts’ without much interpretation (interpretation is done in the discussion section). Writing it up is relatively simple, because there are established guidelines. \r\n{.lead}\r\n\r\nPresent your results as clearly and accurately as possible. The following topics should be covered by your result section: \r\n➔ General information (optional) \r\n➔ How does the data look? \r\n➔ How was the data analyzed? \r\n➔ What was the outcome? What does that tell us?\r\n \r\n**General information (optional, 1 paragraph)** \r\nSome authors start by outlining information that is relevant to all analyses, like the p-value threshold used, statistical programs, or data aggregation. This step is optional. Consider the examples in Mullane et al (2011, p. 314)...\r\n\r\n> Data analyses were conducted in R (R Development Core Team, 2007).\r\n\r\n...and McKenna, Horswill, and Alexander (2006, p. 4):\r\n\r\n> We used an alpha level of .05 to determine statistical significance. Cohen’s *d*, *f*, and *w* were used to indicate effect sizes, where *d* values of 0.50 and 0.80, *f* values of 0.25 and 0.40, and *w* values of 0.300 and 0.500 refer to medium and large effect sizes, respectively (Cohen, 1992).\r\n\r\n**Descriptive statistics (1-2 paragraphs, maybe as a table)** \r\nThe readers need to get to know your data before learning about your analysis. Write one brief sentence about what information was gathered (e.g. reaction times) to avoid forcing readers to go back in the text. \r\nFollow this example in Chen et al., (2014, p. 4):\r\n\r\n> The result of primary interest was the relationship between how often participants responded Very Sure Old for the superstrong items and the curvature of the ROC function across the old rating levels (the first 3 ROC points) for the ‘standard’ items (studied without the deep processing tasks).\r\n\r\nThen describe the variables of interest in your data (no statistical tests yet). Outline in one or two sentences what your data looks like. Describe the main features of your data with descriptive statistics: means (*M*), medians (*MED*), measures of variation like standard deviation (*SD*), and range. Often, small tables are used. You can use this example as blueprint:\r\n<br>\r\n\r\n> Table 1 shows participants’ navigation ability (averaged over participants) for the experimental group in the 3D environment and the control group in the 2D environment.\r\n>\r\n> ![picture of a table](https://tales.nmc.unibas.ch/media/tales/conducting-psychological-research/table_image.PNG)\r\n\r\n**Inferential statistics (multiple paragraphs)** \r\nAfter describing your data, you are ready to present the results of your analysis. We will show you how to report t-test, ANOVA, and regression results in the examples below. But first, these are the general rules: \r\n➔ Write down in complete sentences which variable you analyzed in which way, and what was the result. \r\n➔ Use the full name of the test (e.g., ‘one-way analysis of variance (ANOVA) for unrelated samples’, instead of ‘ANOVA’). \r\nYou can follow this pattern:\r\n\r\n> The variable X was analyzed with test Y between ABC, revealing RESULT…\r\n\r\nAfter this first part add a comma and report inferential statistics in the following general way:\r\n\r\n> , statistic (degrees of freedom) = value, p = value, effect-size statistic = value’.\r\n\r\nIf you do a null-hypothesis test, there are some more general rules you need to follow in the statistics part: \r\n➔ Statistic: exact value of the test statistic (abbreviated to e.g., *F*, *t*) \r\n➔ Additional information like degrees of freedom, number of observations in parentheses \r\n➔ Exact p-value associated with your statistic. Report actual p-values, rather than surpassing of thresholds (good: *p = .03*, bad: *p < .05*). \r\n➔ Effect sizes \r\n➔ Significance level used and test direction (one- or two-sided) \r\n\r\n**How to report t-tests, ANOVAs and regressions** \r\nPresent your **t-test** results similar to this example adapted from McKenna, Horswill, and Alexander (2006, p. 4):\r\n\r\n> There were no significant differences between the trained and untrained groups in age, *t(77.16) = 0.72, p = .38 (ns), d = 0.15*; years elapsed since the driving test was passed, *t(82.31) = 0.86, p = .11 (ns), d = 0.18*.\r\n\r\nNote: *t* is the name of the test-statistic; *0.72* is the t-value; *77.16* are their degrees of freedom, *ns* means not significant, *d = 0.18* is their Cohen’s d value (effect size).\r\n\r\nPresent a **repeated-measures ANOVA** like the example adapted from Su et al (2013 p. 7):\r\n\r\n> Decision times were analyzed with a 3 (task: single-play probability task, multiple-play probability task, proportion task) x 2 (computational difficulty: high, low) repeated-measures analysis of variance (ANOVA). The results revealed a significant effect of task, *F(2, 96) = 96.05, p < .001, η<sup>2</sup> = .67*, on decision time.\r\n\r\nNote: *F* is the name of their test statistic; 2 and 96 are degrees of freedom; 96.05 is their F-value, *η<sup>2</sup>* is the effect size.\r\n\r\nPresent **between or within-subjects ANOVA results** as shown in this example in Yang and Lewandowsky (2003, p. 666).\r\n\r\n> Training performance was analyzed using the proportion of correct responses in each block as the dependent measure. A 2 (condition) x 10 (training block) between-within analysis of variance (ANOVA) revealed a significant main effect of block, *F(9, 540) = 51.193, MSE = .009, p < .001*, along with a marginal main effect of condition, *F(1, 60) = 3.889, MSE = 0.103, p = .053*.\r\n\r\nNote: *F* is the name of the test statistic; 51.193 is their F-value; 9 and 540 are the degrees of freedom; MSE = mean-squared error of the ANOVA.\r\n\r\nPresent **regression analysis results** as Gino and Ariely (2012, p. 449):\r\n\r\n>This analysis revealed that creativity as an individual difference was positively and significantly associated with dishonesty, *B = 0.48*, *SE = 0.084*, *ß = .51, t = 5.73, p < .001*, whereas intelligence was not, *B = 0.059*, *SE = 0.086*, *ß = .062*, *t = 0.695*, *p = .49*. \r\n \r\n**How to format numbers** \r\nMake sure that your numbers are displayed correctly. Here are some rules: \r\n➔ Use a point as a decimal separator (*1.14* instead of *1,14*). \r\n➔ Statistical abbreviations, such as *M*, *SD*, or *p*, as well as their values are written in italic. \r\n➔ The 0 before the decimal separator is omitted for numbers between 0 and 1 (e.g. p-values: .012, .01). If the number is not between 0 and 1, the 0 before the decimal separator is written. \r\n➔ Round decimal numbers to 2 or 3 decimal places (be consistent). Always round up p-values (p-value of 0.051 to *p = .06*, not *p = .05*). \r\n➔ Report exact p-values, not surpassing of thresholds. Exception: if you have a very small p-value below 0.001, then report *p < .001* (e.g. p-value of 0.00099 is reported as *p < .001*, not *p = .001*). \r\n\r\n**Where to find the statistics in R** \r\nIf you are working with R it is not always easy to find the corresponding numbers to your results.\r\n\r\nHere is an example where to find the statistics in R if you are reporting a **two sample t-test**: \r\n![two sample t-test*](/media/tales/markdownx/af55ac95-0f6e-4380-b21a-322b49f3bc55.png)\r\n\r\nIf you are reporting a **one-way ANOVA**, you can use this example: \r\n![one-way ANOVA](/media/tales/markdownx/05f329d2-6d03-4d09-ab40-7a73ead1c439.png)\r\n\r\n**Tables and figures** \r\nTables and figures can be very useful for presenting your results. Let’s talk about the content of tables and figures (you can find out how to format them in the [beginner’s guide to APA](https://tales.nmc.unibas.ch/de/conducting-psychological-research-6/writing-a-scientific-report-21/structuring-a-scientific-paper-50) that we compiled for this course). A lot is said about the proper graphical presentation of data in scientific papers. Here are some basic tips to get you started: \r\n➔ Do not copy-paste tables produced with statistical software, they usually contain redundant information and are not formatted suitably for a scientific thesis or manuscript. Instead, identify the relevant information and report it according to the guidelines listed above. \r\n➔ All tables and figures should be labeled with Arabic numbers, in order of appearance in the text (e.g. Table 1, Table 2, Figure 1, Figure 2). Note that the first letters are always capitalized, have a meaningful title and have self-explanatory entries or contain a note of explanation below them (such as in Table 1 we presented to you as an example above). \r\n➔ Every table and figure needs to be referred to in the text, but do not repeat the full table or figure content in the text.\r\n\r\n<br/>\r\n\r\n------\r\n\r\n###References\r\n\r\nChen, T., Starns, J. J., Rotello, C. M., Chen, T., Starns, J. J., & Rotello, C. M. (2014). A violation of the conditional independence assumption in the two-high-threshold model of recognition memory. *Journal of Experimental Psychology: Learning, Memory, and Cognition*. doi:10.1037/xlm0000077\r\n{.citation-indented}\r\n\r\nMcKenna, F. P., Horswill, M. S., & Alexander, J. L. (2006). Does anticipation training affect drivers’ risk taking? *Journal of Experimental Psychology. Applied, 12*, 1–10. doi:10.1037/1076-898X.12.1.1\r\n{.citation-indented}\r\n\r\nSu, Y., Rao, L.-L., Sun, H.-Y., Du, X.-L., Li, X., & Li, S. (2013). Is making a risky choice based on a weighting and adding process? an eye-tracking investigation. *Journal of Experimental Psychology: Learning, Memory, and Cognition, 39*, 1765–1780. doi:10.1037/a0032861\r\n{.citation-indented}\r\n\r\nYang, L.-X., & Lewandowsky, S. (2003). Context-gated knowledge partitioning in categorization. *Journal of Experimental Psychology: Learning, Memory, and Cognition, 29*, 663–679. doi:10.1037/0278-7393.29.4.663\r\n{.citation-indented}', 'This article explains how to report your results according to APA standards. The results section simply reports your results, which means it presents the ‘dry facts’ without much interpretation (interpretation is done in the discussion section). Writing it up is relatively simple, because there are established guidelines. \r\n{.lead}\r\n\r\nPresent your results as clearly and accurately as possible. The following topics should be covered by your result section: \r\n➔ General information (optional) \r\n➔ How does the data look? \r\n➔ How was the data analyzed? \r\n➔ What was the outcome? What does that tell us?\r\n \r\n**General information (optional, 1 paragraph)** \r\nSome authors start by outlining information that is relevant to all analyses, like the p-value threshold used, statistical programs, or data aggregation. This step is optional. Consider the examples in Mullane et al (2011, p. 314)...\r\n\r\n> Data analyses were conducted in R (R Development Core Team, 2007).\r\n\r\n...and McKenna, Horswill, and Alexander (2006, p. 4):\r\n\r\n> We used an alpha level of .05 to determine statistical significance. Cohen’s *d*, *f*, and *w* were used to indicate effect sizes, where *d* values of 0.50 and 0.80, *f* values of 0.25 and 0.40, and *w* values of 0.300 and 0.500 refer to medium and large effect sizes, respectively (Cohen, 1992).\r\n\r\n**Descriptive statistics (1-2 paragraphs, maybe as a table)** \r\nThe readers need to get to know your data before learning about your analysis. Write one brief sentence about what information was gathered (e.g. reaction times) to avoid forcing readers to go back in the text. \r\nFollow this example in Chen et al., (2014, p. 4):\r\n\r\n> The result of primary interest was the relationship between how often participants responded Very Sure Old for the superstrong items and the curvature of the ROC function across the old rating levels (the first 3 ROC points) for the ‘standard’ items (studied without the deep processing tasks).\r\n\r\nThen describe the variables of interest in your data (no statistical tests yet). Outline in one or two sentences what your data looks like. Describe the main features of your data with descriptive statistics: means (*M*), medians (*MED*), measures of variation like standard deviation (*SD*), and range. Often, small tables are used. You can use this example as blueprint:\r\n<br>\r\n\r\n> Table 1 shows participants’ navigation ability (averaged over participants) for the experimental group in the 3D environment and the control group in the 2D environment.\r\n>\r\n> ![picture of a table](https://tales.nmc.unibas.ch/media/conducting-psychological-research/table_image.PNG)\r\n\r\n**Inferential statistics (multiple paragraphs)** \r\nAfter describing your data, you are ready to present the results of your analysis. We will show you how to report t-test, ANOVA, and regression results in the examples below. But first, these are the general rules: \r\n➔ Write down in complete sentences which variable you analyzed in which way, and what was the result. \r\n➔ Use the full name of the test (e.g., ‘one-way analysis of variance (ANOVA) for unrelated samples’, instead of ‘ANOVA’). \r\nYou can follow this pattern:\r\n\r\n> The variable X was analyzed with test Y between ABC, revealing RESULT…\r\n\r\nAfter this first part add a comma and report inferential statistics in the following general way:\r\n\r\n> , statistic (degrees of freedom) = value, p = value, effect-size statistic = value’.\r\n\r\nIf you do a null-hypothesis test, there are some more general rules you need to follow in the statistics part: \r\n➔ Statistic: exact value of the test statistic (abbreviated to e.g., *F*, *t*) \r\n➔ Additional information like degrees of freedom, number of observations in parentheses \r\n➔ Exact p-value associated with your statistic. Report actual p-values, rather than surpassing of thresholds (good: *p = .03*, bad: *p < .05*). \r\n➔ Effect sizes \r\n➔ Significance level used and test direction (one- or two-sided) \r\n\r\n**How to report t-tests, ANOVAs and regressions** \r\nPresent your **t-test** results similar to this example adapted from McKenna, Horswill, and Alexander (2006, p. 4):\r\n\r\n> There were no significant differences between the trained and untrained groups in age, *t(77.16) = 0.72, p = .38 (ns), d = 0.15*; years elapsed since the driving test was passed, *t(82.31) = 0.86, p = .11 (ns), d = 0.18*.\r\n\r\nNote: *t* is the name of the test-statistic; *0.72* is the t-value; *77.16* are their degrees of freedom, *ns* means not significant, *d = 0.18* is their Cohen’s d value (effect size).\r\n\r\nPresent a **repeated-measures ANOVA** like the example adapted from Su et al (2013 p. 7):\r\n\r\n> Decision times were analyzed with a 3 (task: single-play probability task, multiple-play probability task, proportion task) x 2 (computational difficulty: high, low) repeated-measures analysis of variance (ANOVA). The results revealed a significant effect of task, *F(2, 96) = 96.05, p < .001, η<sup>2</sup> = .67*, on decision time.\r\n\r\nNote: *F* is the name of their test statistic; 2 and 96 are degrees of freedom; 96.05 is their F-value, *η<sup>2</sup>* is the effect size.\r\n\r\nPresent **between or within-subjects ANOVA results** as shown in this example in Yang and Lewandowsky (2003, p. 666).\r\n\r\n> Training performance was analyzed using the proportion of correct responses in each block as the dependent measure. A 2 (condition) x 10 (training block) between-within analysis of variance (ANOVA) revealed a significant main effect of block, *F(9, 540) = 51.193, MSE = .009, p < .001*, along with a marginal main effect of condition, *F(1, 60) = 3.889, MSE = 0.103, p = .053*.\r\n\r\nNote: *F* is the name of the test statistic; 51.193 is their F-value; 9 and 540 are the degrees of freedom; MSE = mean-squared error of the ANOVA.\r\n\r\nPresent **regression analysis results** as Gino and Ariely (2012, p. 449):\r\n\r\n>This analysis revealed that creativity as an individual difference was positively and significantly associated with dishonesty, *B = 0.48*, *SE = 0.084*, *ß = .51, t = 5.73, p < .001*, whereas intelligence was not, *B = 0.059*, *SE = 0.086*, *ß = .062*, *t = 0.695*, *p = .49*. \r\n \r\n**How to format numbers** \r\nMake sure that your numbers are displayed correctly. Here are some rules: \r\n➔ Use a point as a decimal separator (*1.14* instead of *1,14*). \r\n➔ Statistical abbreviations, such as *M*, *SD*, or *p*, as well as their values are written in italic. \r\n➔ The 0 before the decimal separator is omitted for numbers between 0 and 1 (e.g. p-values: .012, .01). If the number is not between 0 and 1, the 0 before the decimal separator is written. \r\n➔ Round decimal numbers to 2 or 3 decimal places (be consistent). Always round up p-values (p-value of 0.051 to *p = .06*, not *p = .05*). \r\n➔ Report exact p-values, not surpassing of thresholds. Exception: if you have a very small p-value below 0.001, then report *p < .001* (e.g. p-value of 0.00099 is reported as *p < .001*, not *p = .001*). \r\n\r\n**Where to find the statistics in R** \r\nIf you are working with R it is not always easy to find the corresponding numbers to your results.\r\n\r\nHere is an example where to find the statistics in R if you are reporting a **two sample t-test**: \r\n![two sample t-test*](/media/markdownx/af55ac95-0f6e-4380-b21a-322b49f3bc55.png)\r\n\r\nIf you are reporting a **one-way ANOVA**, you can use this example: \r\n![one-way ANOVA](/media/markdownx/05f329d2-6d03-4d09-ab40-7a73ead1c439.png)\r\n\r\n**Tables and figures** \r\nTables and figures can be very useful for presenting your results. Let’s talk about the content of tables and figures (you can find out how to format them in the [beginner’s guide to APA](https://tales.nmc.unibas.ch/de/conducting-psychological-research-6/writing-a-scientific-report-21/structuring-a-scientific-paper-50) that we compiled for this course). A lot is said about the proper graphical presentation of data in scientific papers. Here are some basic tips to get you started: \r\n➔ Do not copy-paste tables produced with statistical software, they usually contain redundant information and are not formatted suitably for a scientific thesis or manuscript. Instead, identify the relevant information and report it according to the guidelines listed above. \r\n➔ All tables and figures should be labeled with Arabic numbers, in order of appearance in the text (e.g. Table 1, Table 2, Figure 1, Figure 2). Note that the first letters are always capitalized, have a meaningful title and have self-explanatory entries or contain a note of explanation below them (such as in Table 1 we presented to you as an example above). \r\n➔ Every table and figure needs to be referred to in the text, but do not repeat the full table or figure content in the text.\r\n\r\n<br/>\r\n\r\n------\r\n\r\n###References\r\n\r\nChen, T., Starns, J. J., Rotello, C. M., Chen, T., Starns, J. J., & Rotello, C. M. (2014). A violation of the conditional independence assumption in the two-high-threshold model of recognition memory. *Journal of Experimental Psychology: Learning, Memory, and Cognition*. doi:10.1037/xlm0000077\r\n{.citation-indented}\r\n\r\nMcKenna, F. P., Horswill, M. S., & Alexander, J. L. (2006). Does anticipation training affect drivers’ risk taking? *Journal of Experimental Psychology. Applied, 12*, 1–10. doi:10.1037/1076-898X.12.1.1\r\n{.citation-indented}\r\n\r\nSu, Y., Rao, L.-L., Sun, H.-Y., Du, X.-L., Li, X., & Li, S. (2013). Is making a risky choice based on a weighting and adding process? an eye-tracking investigation. *Journal of Experimental Psychology: Learning, Memory, and Cognition, 39*, 1765–1780. doi:10.1037/a0032861\r\n{.citation-indented}\r\n\r\nYang, L.-X., & Lewandowsky, S. (2003). Context-gated knowledge partitioning in categorization. *Journal of Experimental Psychology: Learning, Memory, and Cognition, 29*, 663–679. doi:10.1037/0278-7393.29.4.663\r\n{.citation-indented}', 'This article explains how to report your results according to APA standards. The results section simply reports your results, which means it presents the ‘dry facts’ without much interpretation (interpretation is done in the discussion section). Writing it up is relatively simple, because there are established guidelines. \r\n{.lead}\r\n\r\nPresent your results as clearly and accurately as possible. The following topics should be covered by your result section: \r\n➔ General information (optional) \r\n➔ How does the data look? \r\n➔ How was the data analyzed? \r\n➔ What was the outcome? What does that tell us?\r\n \r\n**General information (optional, 1 paragraph)** \r\nSome authors start by outlining information that is relevant to all analyses, like the p-value threshold used, statistical programs, or data aggregation. This step is optional. Consider the examples in Mullane et al (2011, p. 314)...\r\n\r\n> Data analyses were conducted in R (R Development Core Team, 2007).\r\n\r\n...and McKenna, Horswill, and Alexander (2006, p. 4):\r\n\r\n> We used an alpha level of .05 to determine statistical significance. Cohen’s *d*, *f*, and *w* were used to indicate effect sizes, where *d* values of 0.50 and 0.80, *f* values of 0.25 and 0.40, and *w* values of 0.300 and 0.500 refer to medium and large effect sizes, respectively (Cohen, 1992).\r\n\r\n**Descriptive statistics (1-2 paragraphs, maybe as a table)** \r\nThe readers need to get to know your data before learning about your analysis. Write one brief sentence about what information was gathered (e.g. reaction times) to avoid forcing readers to go back in the text. \r\nFollow this example in Chen et al., (2014, p. 4):\r\n\r\n> The result of primary interest was the relationship between how often participants responded Very Sure Old for the superstrong items and the curvature of the ROC function across the old rating levels (the first 3 ROC points) for the ‘standard’ items (studied without the deep processing tasks).\r\n\r\nThen describe the variables of interest in your data (no statistical tests yet). Outline in one or two sentences what your data looks like. Describe the main features of your data with descriptive statistics: means (*M*), medians (*MED*), measures of variation like standard deviation (*SD*), and range. Often, small tables are used. You can use this example as blueprint:\r\n\r\n> Table 1 shows participants’ navigation ability (averaged over participants) for the experimental group in the 3D environment and the control group in the 2D environment.\r\n> ![picture of a table](/media/markdownx/77d67eb3-e791-428b-b43a-46681063bf72.png)\r\n\r\n**Inferential statistics (multiple paragraphs)** \r\nAfter describing your data, you are ready to present the results of your analysis. We will show you how to report t-test, ANOVA, and regression results in the examples below. But first, these are the general rules: \r\n➔ Write down in complete sentences which variable you analyzed in which way, and what was the result. \r\n➔ Use the full name of the test (e.g., ‘one-way analysis of variance (ANOVA) for unrelated samples’, instead of ‘ANOVA’). \r\nYou can follow this pattern:\r\n\r\n> The variable X was analyzed with test Y between ABC, revealing RESULT…\r\n\r\nAfter this first part add a comma and report inferential statistics in the following general way:\r\n\r\n> , statistic (degrees of freedom) = value, p = value, effect-size statistic = value’.\r\n\r\nIf you do a null-hypothesis test, there are some more general rules you need to follow in the statistics part: \r\n➔ Statistic: exact value of the test statistic (abbreviated to e.g., *F*, *t*) \r\n➔ Additional information like degrees of freedom, number of observations in parentheses \r\n➔ Exact p-value associated with your statistic. Report actual p-values, rather than surpassing of thresholds (good: *p = .03*, bad: *p < .05*). \r\n➔ Effect sizes \r\n➔ Significance level used and test direction (one- or two-sided) \r\n\r\n**How to report t-tests, ANOVAs and regressions** \r\nPresent your **t-test** results similar to this example adapted from McKenna, Horswill, and Alexander (2006, p. 4):\r\n\r\n> There were no significant differences between the trained and untrained groups in age, *t(77.16) = 0.72, p = .38 (ns), d = 0.15*; years elapsed since the driving test was passed, *t(82.31) = 0.86, p = .11 (ns), d = 0.18*.\r\n\r\nNote: *t* is the name of the test-statistic; *0.72* is the t-value; *77.16* are their degrees of freedom, *ns* means not significant, *d = 0.18* is their Cohen’s d value (effect size).\r\n\r\nPresent a **repeated-measures ANOVA** like the example adapted from Su et al (2013 p. 7):\r\n\r\n> Decision times were analyzed with a 3 (task: single-play probability task, multiple-play probability task, proportion task) x 2 (computational difficulty: high, low) repeated-measures analysis of variance (ANOVA). The results revealed a significant effect of task, *F(2, 96) = 96.05, p < .001, η<sup>2</sup> = .67*, on decision time.\r\n\r\nNote: *F* is the name of their test statistic; 2 and 96 are degrees of freedom; 96.05 is their F-value, *η<sup>2</sup>* is the effect size.\r\n\r\nPresent **between or within-subjects ANOVA results** as shown in this example in Yang and Lewandowsky (2003, p. 666).\r\n\r\n> Training performance was analyzed using the proportion of correct responses in each block as the dependent measure. A 2 (condition) x 10 (training block) between-within analysis of variance (ANOVA) revealed a significant main effect of block, *F(9, 540) = 51.193, MSE = .009, p < .001*, along with a marginal main effect of condition, *F(1, 60) = 3.889, MSE = 0.103, p = .053*.\r\n\r\nNote: *F* is the name of the test statistic; 51.193 is their F-value; 9 and 540 are the degrees of freedom; MSE = mean-squared error of the ANOVA.\r\n\r\nPresent **regression analysis results** as Gino and Ariely (2012, p. 449):\r\n\r\n>This analysis revealed that creativity as an individual difference was positively and significantly associated with dishonesty, *B = 0.48*, *SE = 0.084*, *ß = .51, t = 5.73, p < .001*, whereas intelligence was not, *B = 0.059*, *SE = 0.086*, *ß = .062*, *t = 0.695*, *p = .49*. \r\n \r\n**How to format numbers** \r\nMake sure that your numbers are displayed correctly. Here are some rules: \r\n➔ Use a point as a decimal separator (*1.14* instead of *1,14*). \r\n➔ Statistical abbreviations, such as *M*, *SD*, or *p*, as well as their values are written in italic. \r\n➔ The 0 before the decimal separator is omitted for numbers between 0 and 1 (e.g. p-values: .012, .01). If the number is not between 0 and 1, the 0 before the decimal separator is written. \r\n➔ Round decimal numbers to 2 or 3 decimal places (be consistent). Always round up p-values (p-value of 0.051 to *p = .06*, not *p = .05*). \r\n➔ Report exact p-values, not surpassing of thresholds. Exception: if you have a very small p-value below 0.001, then report *p < .001* (e.g. p-value of 0.00099 is reported as *p < .001*, not *p = .001*). \r\n\r\n**Where to find the statistics in R** \r\nIf you are working with R it is not always easy to find the corresponding numbers to your results.\r\n\r\nHere is an example where to find the statistics in R if you are reporting a **two sample t-test**: \r\n![two sample t-test*](/media/markdownx/af55ac95-0f6e-4380-b21a-322b49f3bc55.png)\r\n\r\nIf you are reporting a **one-way ANOVA**, you can use this example: \r\n![one-way ANOVA](/media/markdownx/05f329d2-6d03-4d09-ab40-7a73ead1c439.png)\r\n\r\n**Tables and figures** \r\nTables and figures can be very useful for presenting your results. Let’s talk about the content of tables and figures (you can find out how to format them in the [beginner’s guide to APA](https://tales.nmc.unibas.ch/de/conducting-psychological-research-6/writing-a-scientific-report-21/structuring-a-scientific-paper-50) that we compiled for this course). A lot is said about the proper graphical presentation of data in scientific papers. Here are some basic tips to get you started: \r\n➔ Do not copy-paste tables produced with statistical software, they usually contain redundant information and are not formatted suitably for a scientific thesis or manuscript. Instead, identify the relevant information and report it according to the guidelines listed above. \r\n➔ All tables and figures should be labeled with Arabic numbers, in order of appearance in the text (e.g. Table 1, Table 2, Figure 1, Figure 2). Note that the first letters are always capitalized, have a meaningful title and have self-explanatory entries or contain a note of explanation below them (such as in Table 1 we presented to you as an example above). \r\n➔ Every table and figure needs to be referred to in the text, but do not repeat the full table or figure content in the text.\r\n\r\n<br/>\r\n\r\n------\r\n\r\n###References\r\n\r\nChen, T., Starns, J. J., Rotello, C. M., Chen, T., Starns, J. J., & Rotello, C. M. (2014). A violation of the conditional independence assumption in the two-high-threshold model of recognition memory. *Journal of Experimental Psychology: Learning, Memory, and Cognition*. doi:10.1037/xlm0000077\r\n{.citation-indented}\r\n\r\nMcKenna, F. P., Horswill, M. S., & Alexander, J. L. (2006). Does anticipation training affect drivers’ risk taking? *Journal of Experimental Psychology. Applied, 12*, 1–10. doi:10.1037/1076-898X.12.1.1\r\n{.citation-indented}\r\n\r\nSu, Y., Rao, L.-L., Sun, H.-Y., Du, X.-L., Li, X., & Li, S. (2013). Is making a risky choice based on a weighting and adding process? an eye-tracking investigation. *Journal of Experimental Psychology: Learning, Memory, and Cognition, 39*, 1765–1780. doi:10.1037/a0032861\r\n{.citation-indented}\r\n\r\nYang, L.-X., & Lewandowsky, S. (2003). Context-gated knowledge partitioning in categorization. *Journal of Experimental Psychology: Learning, Memory, and Cognition, 29*, 663–679. doi:10.1037/0278-7393.29.4.663\r\n{.citation-indented}', '', '', '', '', '', None, None, None, None, 'University of Basel', 'University of Basel', 'University of Basel', '', 'TT', '20 min.', 3, 'published', False, None, None, None, None, 21), (76, datetime.datetime(2020, 11, 2, 15, 9, 33, 774510, tzinfo=datetime.timezone.utc), datetime.datetime(2020, 11, 2, 15, 9, 37, 376832, tzinfo=datetime.timezone.utc), datetime.datetime(2020, 11, 2, 15, 9, 37, 376843, tzinfo=datetime.timezone.utc), False, 'Write a discussion section', 'Write a discussion section', 'Write a discussion section', None, '', '', '', None, '', None, None, None, '', 'write-a-discussion-section', 'The discussion section interprets the results. This chapter briefly outlines the basics of the discussion section.\r\n{.lead}\r\n\r\n**Discussion section vs. result section?** \r\nThe main difference between the discussion and the result section is that you **interpret** your results in the discussion. That means, while you explain what you have found objectively in the result section, in the discussion section you explain your findings by interpreting them. \r\n \r\n**How is the discussion section structured?** \r\nThe discussion section contains four parts:\r\n<br/>\r\n1. \tRecap of the research question and your main findings \r\n2. \tHow do your findings relate to the theories and what do they mean? \r\n3. \tWhat do your findings imply, and which limitations have been introduced by the design? \r\n4. \tConclusion of your main findings and discussion points \r\nIn the following paragraphs we give you more details and some examples for each part. \r\n \r\n**1. Recap of the research question and main your findings** \r\nIn the first paragraph, you briefly repeat the research question or hypothesis, what you found, and if your findings confirm your hypothesis. Although you repeat your findings, this paragraph is not a copy of the result section. Rather, in the discussion section, you should use phrases instead of numbers and graphs. Here is an example for a discussion section (few numbers, more text and intuition than in the result section):\r\n\r\n> The results confirmed our hypotheses that autonomy and engagement with characters lead to enjoyable experiences.\r\n\r\nThis is very different from a result section (facts, numbers, statistics), which could be:\r\n\r\n> A multiple regression was calculated with needs as predictors of enjoyment (*R = .62*, *R2 adjusted = .39*, *F(8, 114) = 11.38, p < .001*).\r\n \r\n\r\n \r\n**2. How do your findings relate to the theories and what do they mean?** \r\nIn the second part of your discussion, you revisit the theories and previous studies you have introduced in the introduction section and explain how your findings fit in. That means, you showcase what similarities or dissimilarities you found compared to the theories and previous studies. For example:\r\n\r\n> In line with previous studies (Johnson et al., 2015; Oliver & Raney, 2011), increased autonomy was associated with high enjoyment. ...\r\n \r\nIn the discussion section, it is particularly important to critically question your findings. Consider whether the difference in the dependent variable is really caused by the manipulation of the independent variable, or whether alternative explanations exist (e.g. confounding variables, influential variable assessed in previous studies but not in yours). Correspondingly, if you find no significant difference in the dependent variable, you need to ask yourself it this means that there is no relationship between your independent and dependent variable.\r\n \r\n**3. What are the implications of your findings, and what limitations of design exist?** \r\nThis third part of the discussion section is divided further into three subsections. \r\nFirst, you write about how your findings inform new research questions. Consider what is important or interesting to explore further. For instance, if the relationship between IV and DV was not clear in your experiment, how could a future study investigate it better? For example:\r\n\r\n> Future research may examine how to encourage players to share their feelings and thoughts evoked by game events with others. This seems especially important for serious games, as it may promote discussion of the subject. ...\r\n \r\nNext, if you think there is an implication for practitioners, who will merit from your findings and what practical relevance they have. It’s important to be specific, simply to mention that your findings have implication is not enough. For example:\r\n\r\n> Our findings have implication for researchers and practitioners wanting to evaluate long-lasting game experience. Such experiences have been argued to be difficult to assess in the long run (Lacovides & Cox, 2015). A possible work-around would be to take appreciation into account as this was found in our study to be associated to long-lasting effect. ...\r\n \r\nFinally, briefly discuss (max. 1 paragraph) the limitations of your experimental design. Consider what could be changed when replicating your study. For example:\r\n\r\n> A limitation is that the present study asked participants to recall a past game experience. But as the retrospective evaluation of an experience may differ from the moment-to-moment experience (Kahnemann & Riis, 2005), it is necessary to also explore players’ feelings and thoughts during or immediately after a gaming experience in future work.\r\n \r\n**4. Conclusion of your main implication** \r\nIn the last paragraph of the discussion section, you briefly summarize your study. In contrast to the abstract, the focus of the conclusion lies on the main findings and the main discussion points. Here, you present the take-home message for the reader of your paper. For example:\r\n\r\n> In conclusion, our results suggest that autonomy of players and appreciation of game elements play a key role in evoking positive emotions in a variety of computer games. Both factors, high autonomy and high appreciation, increase positive emotional experiences for players of both genders, especially in games involving a social component. Autonomy and appreciation thereby provide a mechanism to influence player experiences.', 'The discussion section interprets the results. This chapter briefly outlines the basics of the discussion section.\r\n{.lead}\r\n\r\n**Discussion section vs. result section?** \r\nThe main difference between the discussion and the result section is that you **interpret** your results in the discussion. That means, while you explain what you have found objectively in the result section, in the discussion section you explain your findings by interpreting them. \r\n \r\n**How is the discussion section structured?** \r\nThe discussion section contains four parts:\r\n<br/>\r\n1. \tRecap of the research question and your main findings \r\n2. \tHow do your findings relate to the theories and what do they mean? \r\n3. \tWhat do your findings imply, and which limitations have been introduced by the design? \r\n4. \tConclusion of your main findings and discussion points \r\nIn the following paragraphs we give you more details and some examples for each part. \r\n \r\n**1. Recap of the research question and main your findings** \r\nIn the first paragraph, you briefly repeat the research question or hypothesis, what you found, and if your findings confirm your hypothesis. Although you repeat your findings, this paragraph is not a copy of the result section. Rather, in the discussion section, you should use phrases instead of numbers and graphs. Here is an example for a discussion section (few numbers, more text and intuition than in the result section):\r\n\r\n> The results confirmed our hypotheses that autonomy and engagement with characters lead to enjoyable experiences.\r\n\r\nThis is very different from a result section (facts, numbers, statistics), which could be:\r\n\r\n> A multiple regression was calculated with needs as predictors of enjoyment (*R = .62*, *R2 adjusted = .39*, *F(8, 114) = 11.38, p < .001*).\r\n \r\n\r\n \r\n**2. How do your findings relate to the theories and what do they mean?** \r\nIn the second part of your discussion, you revisit the theories and previous studies you have introduced in the introduction section and explain how your findings fit in. That means, you showcase what similarities or dissimilarities you found compared to the theories and previous studies. For example:\r\n\r\n> In line with previous studies (Johnson et al., 2015; Oliver & Raney, 2011), increased autonomy was associated with high enjoyment. ...\r\n \r\nIn the discussion section, it is particularly important to critically question your findings. Consider whether the difference in the dependent variable is really caused by the manipulation of the independent variable, or whether alternative explanations exist (e.g. confounding variables, influential variable assessed in previous studies but not in yours). Correspondingly, if you find no significant difference in the dependent variable, you need to ask yourself it this means that there is no relationship between your independent and dependent variable.\r\n \r\n**3. What are the implications of your findings, and what limitations of design exist?** \r\nThis third part of the discussion section is divided further into three subsections. \r\nFirst, you write about how your findings inform new research questions. Consider what is important or interesting to explore further. For instance, if the relationship between IV and DV was not clear in your experiment, how could a future study investigate it better? For example:\r\n\r\n> Future research may examine how to encourage players to share their feelings and thoughts evoked by game events with others. This seems especially important for serious games, as it may promote discussion of the subject. ...\r\n \r\nNext, if you think there is an implication for practitioners, who will merit from your findings and what practical relevance they have. It’s important to be specific, simply to mention that your findings have implication is not enough. For example:\r\n\r\n> Our findings have implication for researchers and practitioners wanting to evaluate long-lasting game experience. Such experiences have been argued to be difficult to assess in the long run (Lacovides & Cox, 2015). A possible work-around would be to take appreciation into account as this was found in our study to be associated to long-lasting effect. ...\r\n \r\nFinally, briefly discuss (max. 1 paragraph) the limitations of your experimental design. Consider what could be changed when replicating your study. For example:\r\n\r\n> A limitation is that the present study asked participants to recall a past game experience. But as the retrospective evaluation of an experience may differ from the moment-to-moment experience (Kahnemann & Riis, 2005), it is necessary to also explore players’ feelings and thoughts during or immediately after a gaming experience in future work.\r\n \r\n**4. Conclusion of your main implication** \r\nIn the last paragraph of the discussion section, you briefly summarize your study. In contrast to the abstract, the focus of the conclusion lies on the main findings and the main discussion points. Here, you present the take-home message for the reader of your paper. For example:\r\n\r\n> In conclusion, our results suggest that autonomy of players and appreciation of game elements play a key role in evoking positive emotions in a variety of computer games. Both factors, high autonomy and high appreciation, increase positive emotional experiences for players of both genders, especially in games involving a social component. Autonomy and appreciation thereby provide a mechanism to influence player experiences.', 'The discussion section interprets the results. This chapter briefly outlines the basics of the discussion section.\r\n{.lead}\r\n\r\n**Discussion section vs. result section?** \r\nThe main difference between the discussion and the result section is that you **interpret** your results in the discussion. That means, while you explain what you have found objectively in the result section, in the discussion section you explain your findings by interpreting them. \r\n \r\n**How is the discussion section structured?** \r\nThe discussion section contains four parts:\r\n<br/>\r\n1. \tRecap of the research question and your main findings \r\n2. \tHow do your findings relate to the theories and what do they mean? \r\n3. \tWhat do your findings imply, and which limitations have been introduced by the design? \r\n4. \tConclusion of your main findings and discussion points \r\nIn the following paragraphs we give you more details and some examples for each part. \r\n \r\n**1. Recap of the research question and main your findings** \r\nIn the first paragraph, you briefly repeat the research question or hypothesis, what you found, and if your findings confirm your hypothesis. Although you repeat your findings, this paragraph is not a copy of the result section. Rather, in the discussion section, you should use phrases instead of numbers and graphs. Here is an example for a discussion section (few numbers, more text and intuition than in the result section):\r\n\r\n> The results confirmed our hypotheses that autonomy and engagement with characters lead to enjoyable experiences.\r\n\r\nThis is very different from a result section (facts, numbers, statistics), which could be:\r\n\r\n> A multiple regression was calculated with needs as predictors of enjoyment (*R = .62*, *R2 adjusted = .39*, *F(8, 114) = 11.38, p < .001*).\r\n \r\n\r\n \r\n**2. How do your findings relate to the theories and what do they mean?** \r\nIn the second part of your discussion, you revisit the theories and previous studies you have introduced in the introduction section and explain how your findings fit in. That means, you showcase what similarities or dissimilarities you found compared to the theories and previous studies. For example:\r\n\r\n> In line with previous studies (Johnson et al., 2015; Oliver & Raney, 2011), increased autonomy was associated with high enjoyment. ...\r\n \r\nIn the discussion section, it is particularly important to critically question your findings. Consider whether the difference in the dependent variable is really caused by the manipulation of the independent variable, or whether alternative explanations exist (e.g. confounding variables, influential variable assessed in previous studies but not in yours). Correspondingly, if you find no significant difference in the dependent variable, you need to ask yourself it this means that there is no relationship between your independent and dependent variable.\r\n \r\n**3. What are the implications of your findings, and what limitations of design exist?** \r\nThis third part of the discussion section is divided further into three subsections. \r\nFirst, you write about how your findings inform new research questions. Consider what is important or interesting to explore further. For instance, if the relationship between IV and DV was not clear in your experiment, how could a future study investigate it better? For example:\r\n\r\n> Future research may examine how to encourage players to share their feelings and thoughts evoked by game events with others. This seems especially important for serious games, as it may promote discussion of the subject. ...\r\n \r\nNext, if you think there is an implication for practitioners, who will merit from your findings and what practical relevance they have. It’s important to be specific, simply to mention that your findings have implication is not enough. For example:\r\n\r\n> Our findings have implication for researchers and practitioners wanting to evaluate long-lasting game experience. Such experiences have been argued to be difficult to assess in the long run (Lacovides & Cox, 2015). A possible work-around would be to take appreciation into account as this was found in our study to be associated to long-lasting effect. ...\r\n \r\nFinally, briefly discuss (max. 1 paragraph) the limitations of your experimental design. Consider what could be changed when replicating your study. For example:\r\n\r\n> A limitation is that the present study asked participants to recall a past game experience. But as the retrospective evaluation of an experience may differ from the moment-to-moment experience (Kahnemann & Riis, 2005), it is necessary to also explore players’ feelings and thoughts during or immediately after a gaming experience in future work.\r\n \r\n**4. Conclusion of your main implication** \r\nIn the last paragraph of the discussion section, you briefly summarize your study. In contrast to the abstract, the focus of the conclusion lies on the main findings and the main discussion points. Here, you present the take-home message for the reader of your paper. For example:\r\n\r\n> In conclusion, our results suggest that autonomy of players and appreciation of game elements play a key role in evoking positive emotions in a variety of computer games. Both factors, high autonomy and high appreciation, increase positive emotional experiences for players of both genders, especially in games involving a social component. Autonomy and appreciation thereby provide a mechanism to influence player experiences.', None, '', None, None, None, None, None, None, None, 'University of Basel', 'University of Basel', 'University of Basel', None, 'TT', '10 min.', 4, 'published', False, None, None, None, None, 21), (1029, datetime.datetime(2021, 11, 30, 8, 24, 22, 398141, tzinfo=datetime.timezone.utc), datetime.datetime(2021, 11, 30, 8, 24, 54, 831438, tzinfo=datetime.timezone.utc), datetime.datetime(2021, 11, 30, 8, 24, 54, 808989, tzinfo=datetime.timezone.utc), False, 'Write an abstract', 'Write an abstract', None, None, '', None, None, None, '', None, None, None, '', 'write-an-abstract', 'The abstract is one paragraph that summarizes the research question, hypothesis, design, methods, and results in an easy to read way. This chapter briefly outlines the basics of good abstracts.\r\n{.lead}\r\n\r\n**Short summary of everything** \r\nThe abstract is a written summary of a research. It is around 150 to maximally 250 words of length. When you write an abstract, take your time to be informative but brief and concise at the same time, rather than writing a long and verbose text. Also, write your abstract for readers from other fields or who have never heard of your specific methods or research topic. The audience of an abstract is a psychologist who is not necessarily working in your field and does not know your area of expertise.\r\n \r\n**How is the abstract structured?** \r\nThe text of the abstract of an empirical paper has a standard structure. It starts with one to two sentence that clearly state the problem or research question and goals of your research (for instance, *“This paper investigates the role of … in ...”*). The next one to two sentences must explicitly state all the tested hypotheses, even if exploratory (for instance, *“We hypothesized, based on prospect theory, that highly loss-averse individuals should … compared to people that are less loss-averse ...”*). Next, briefly write about the experimental design and methods that were used, including the sample size (for instance, *”To investigate this question, we conducted one online experiment (N = 89), which asked participants to … followed by … and ...”*), this usually takes one or two sentences. Afterwards, the next one or two sentences describe the main results, usually in plain text using words rather than in numbers (for instance, *”The results from a ANOVA show that … increases ….”*). This is followed by a very brief sentence that relates the result back to the hypotheses (for instance, *”These findings fail to support prospect theory”*). This is followed by the last sentence of the abstract which always is a conclusion from the empirical findings that mentions implications (for instance *”Taken together, our work shows that prospect theory is not ...”*). Implications are what the research findings mean for the practice or theory or future research.\r\n\r\n**How is the abstract formatted?** \r\nFollowing the APA format, the abstract has a section heading called **Abstract** in bold and centered. The abstract text is always formatted as one single paragraph, which means abstract texts contain no line breaks and no paragraph breaks. The line spacing is double-spaced (as usual in APA). Abstracts appear on the first page after the title page of psychological papers, and the abstract starts at the top of the page.', 'The abstract is one paragraph that summarizes the research question, hypothesis, design, methods, and results in an easy to read way. This chapter briefly outlines the basics of good abstracts.\r\n{.lead}\r\n\r\n**Short summary of everything** \r\nThe abstract is a written summary of a research. It is around 150 to maximally 250 words of length. When you write an abstract, take your time to be informative but brief and concise at the same time, rather than writing a long and verbose text. Also, write your abstract for readers from other fields or who have never heard of your specific methods or research topic. The audience of an abstract is a psychologist who is not necessarily working in your field and does not know your area of expertise.\r\n \r\n**How is the abstract structured?** \r\nThe text of the abstract of an empirical paper has a standard structure. It starts with one to two sentence that clearly state the problem or research question and goals of your research (for instance, *“This paper investigates the role of … in ...”*). The next one to two sentences must explicitly state all the tested hypotheses, even if exploratory (for instance, *“We hypothesized, based on prospect theory, that highly loss-averse individuals should … compared to people that are less loss-averse ...”*). Next, briefly write about the experimental design and methods that were used, including the sample size (for instance, *”To investigate this question, we conducted one online experiment (N = 89), which asked participants to … followed by … and ...”*), this usually takes one or two sentences. Afterwards, the next one or two sentences describe the main results, usually in plain text using words rather than in numbers (for instance, *”The results from a ANOVA show that … increases ….”*). This is followed by a very brief sentence that relates the result back to the hypotheses (for instance, *”These findings fail to support prospect theory”*). This is followed by the last sentence of the abstract which always is a conclusion from the empirical findings that mentions implications (for instance *”Taken together, our work shows that prospect theory is not ...”*). Implications are what the research findings mean for the practice or theory or future research.\r\n\r\n**How is the abstract formatted?** \r\nFollowing the APA format, the abstract has a section heading called **Abstract** in bold and centered. The abstract text is always formatted as one single paragraph, which means abstract texts contain no line breaks and no paragraph breaks. The line spacing is double-spaced (as usual in APA). Abstracts appear on the first page after the title page of psychological papers, and the abstract starts at the top of the page.', '', '', '', '', '', '', None, None, None, None, '', '', '', '', 'TT', '10 min', 5, 'published', False, None, None, None, None, 21)]])}, None) {} <django_redis.cache.RedisCache object at 0x7910e287a790>
/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in run(101)
  return _run_old_run_func()

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in _run_old_run_func(94)
  return old_run_func(self, *a, **kw)

/usr/local/lib/python3.11/concurrent/futures/thread.py in _worker(83)
  work_item.run()

/usr/local/lib/python3.11/concurrent/futures/thread.py in run(58)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/corsheaders/middleware.py in __call__(56)
  result = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in middleware(32)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/allauth/account/middleware.py in middleware(36)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/simple_history/middleware.py in middleware(41)
  return get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/django_htmx/middleware.py in __call__(43)
  return self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in __call__(168)
  response = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/panels.py in process_request(41)
  return super(CachalotPanel, self).process_request(request)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in __call__(244)
  current_executor.run_until_future(call_result)

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run_until_future(81)
  work_item.run()

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run(40)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_wrapped_callback(90)
  return callback(request, *args, **kwargs)

/app/project/utils/decorators.py in apply_cache(72)
  cache.set(CACHE_KEY, response.render(), ttl)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_patched_render(41)
  return old_render(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in render(114)
  self.content = self.rendered_content

/usr/local/lib/python3.11/site-packages/sentry_sdk/utils.py in runner(1788)
  return sentry_patched_function(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/templates.py in rendered_content(77)
  return real_rendered_content.fget(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in rendered_content(92)
  return template.render(context, self._request)

/usr/local/lib/python3.11/site-packages/django/template/backends/django.py in render(61)
  return self.template.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(175)
  return self._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(208)
  return template.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(177)
  return self._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py in render(321)
  return nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py in render(238)
  nodelist.append(node.render_annotated(context))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py in render(194)
  len_values = len(values)

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(37)
  return original(compiler, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(96)
  return _get_result_or_execute_query(

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in _get_result_or_execute_query(71)
  cache.set_many(to_be_set, cachalot_settings.CACHALOT_TIMEOUT)

0,5737 get_many (['e3a5db5a670ad803efb866441f33de58309be2e2', '76e323efd8711853e13c9f7cf976845908364eb2', '138549f5508bbba7283d6a0625e51c589d845e8f', '0638aa1bb99ae9bb9b47534cb50fd4134ec361e3'],) {} <django_redis.cache.RedisCache object at 0x7910e287a790>
/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in run(101)
  return _run_old_run_func()

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in _run_old_run_func(94)
  return old_run_func(self, *a, **kw)

/usr/local/lib/python3.11/concurrent/futures/thread.py in _worker(83)
  work_item.run()

/usr/local/lib/python3.11/concurrent/futures/thread.py in run(58)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/corsheaders/middleware.py in __call__(56)
  result = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in middleware(32)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/allauth/account/middleware.py in middleware(36)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/simple_history/middleware.py in middleware(41)
  return get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/django_htmx/middleware.py in __call__(43)
  return self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in __call__(168)
  response = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/panels.py in process_request(41)
  return super(CachalotPanel, self).process_request(request)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in __call__(244)
  current_executor.run_until_future(call_result)

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run_until_future(81)
  work_item.run()

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run(40)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_wrapped_callback(90)
  return callback(request, *args, **kwargs)

/app/project/utils/decorators.py in apply_cache(72)
  cache.set(CACHE_KEY, response.render(), ttl)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_patched_render(41)
  return old_render(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in render(114)
  self.content = self.rendered_content

/usr/local/lib/python3.11/site-packages/sentry_sdk/utils.py in runner(1788)
  return sentry_patched_function(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/templates.py in rendered_content(77)
  return real_rendered_content.fget(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in rendered_content(92)
  return template.render(context, self._request)

/usr/local/lib/python3.11/site-packages/django/template/backends/django.py in render(61)
  return self.template.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(175)
  return self._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(208)
  return template.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(177)
  return self._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py in render(321)
  return nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py in render(238)
  nodelist.append(node.render_annotated(context))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py in render(194)
  len_values = len(values)

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(37)
  return original(compiler, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(96)
  return _get_result_or_execute_query(

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in _get_result_or_execute_query(46)
  data = cache.get_many(table_cache_keys + [cache_key])

1,6674 set_many ({'0638aa1bb99ae9bb9b47534cb50fd4134ec361e3': (1736871783.193308, [[(70, datetime.datetime(2020, 11, 2, 15, 9, 33, 774510, tzinfo=datetime.timezone.utc), datetime.datetime(2020, 11, 2, 15, 9, 37, 378907, tzinfo=datetime.timezone.utc), datetime.datetime(2020, 11, 2, 15, 9, 37, 378917, tzinfo=datetime.timezone.utc), False, 'How to make an analysis plan', 'How to make an analysis plan', 'How to make an analysis plan', None, '', '', '', None, '', None, None, None, 'conducting-psychological-research/chapter-4/how-to-make-an-analysis-plan/hand.jpg', 'how-to-make-an-analysis-plan', 'It is important to plan your analysis during the design of the experiment. This means that you already have to think in detail about the statistical tests for your hypotheses and the approximate computations when you design the experiment. You want to do this before running the experiment, because if you realize that some variables are missing after you ran the study, it’s just too late. Analysis plans are easy. You can simply follow these four steps:\r\n{.lead}\r\n\r\n**1. Select the hypothesis.** \r\nFor example: \r\n> H1: Listening to classical music increases performance\r\nin math taks more than rock music because it distracts people less.\r\n\r\n**2. Write down the test.** \r\nFor example:\r\n> Test for H1: T-test between the % of correct answers of the rock-music-group and the % of correct answers of classic-music-group.\r\n\r\n**3. Write down the variables in your experiment that relate to this hypothesis.** \r\nIf you don’t know how these variables will be called in the end, write them down with an approximate name. The most important thing is that you write down what data your experiment will give you. \r\nFor example:\r\n>Variable in our experiment:\r\n> \r\n>v_123 = experimental groups (1 = classic, 2 = rock)\r\n> \r\n>v_009 = maths test answer 1\r\n>v_010 = maths test answer 2\r\n>v_011 = maths test answer 3\r\n>v_012 = maths test answer 4\r\n\r\nIn this example it would be clever if you renamed the variables v_123 as experimental_condition and v_009 - v_012 as maths_1 through maths_4.\r\n\r\nNow you can see that there are four maths test answers but the t-test in step 2 needs the % of correct answers. Therefore, you need to first calculate the mean. In this case you can write down another step.\r\n\r\n**4. Transform the data.** \r\nFor example: \r\n>Data transformations: \r\n>1. Compute which maths test answer was correct (v_009 - v_012) \r\n>2. Compute for each person in the sample the mean number of correct answers\r\n\r\nYou can also already write down the requirements for the t-test (look into your statistics book if you don’t remember how). \r\nFor example: \r\n>For t-test: compute test of variance homogeneity of correct answers\r\n\r\nImportant: See what the difference between step 3 and step 4 above is? Step 4 mentions the variables v_009 to v_012 while step 3 only mentions the ‘correct answers’ which are not in your raw data.\r\n\r\n**Repeat these four steps with all your hypotheses.**\r\n\r\nTip: if you are a bit familiar with R you can write the statistical commands for the test of your hypothesis directly in R. For example: \r\n\r\n\r\n```R\r\n# H1: Listening to classical music increases performance in math taks more than rock music because it distracts people less \r\n\r\n# Mean number of correct maths test items \r\nmean_correct_per_person <- rowSums(data[, c(“v_009”, “v_010”, “v_011”, “v_012”)] / 4) \r\nheard_classic <- data$v_123 # 1 = classic, 2 = rock \r\n\r\n# Homogeneity of variances? \r\nbartlett.test(x = mean_correct_per_persom, y = heard_classic) \r\n\r\n# Differences in groups? \r\nmean_correct_classic <- mean_correct_per_person[heard_classic == 1] \r\nmean_correct_rock <- mean_correct_per_person[heard_classic == 2] \r\nt.test(x = mean_correct_classic, y = mean_correct_rock )\r\n```\r\nNote: a line beginning with a hashtag (#) indicates a comment in R. This means that it is not carried out as code.\r\n\r\nIf you are not familiar with R yet, do not worry. We will introduce R in the following chapters.', 'It is important to plan your analysis during the design of the experiment. This means that you already have to think in detail about the statistical tests for your hypotheses and the approximate computations when you design the experiment. You want to do this before running the experiment, because if you realize that some variables are missing after you ran the study, it’s just too late. Analysis plans are easy. You can simply follow these four steps:\r\n{.lead}\r\n\r\n**1. Select the hypothesis.** \r\nFor example: \r\n> H1: Listening to classical music increases performance\r\nin math taks more than rock music because it distracts people less.\r\n\r\n**2. Write down the test.** \r\nFor example:\r\n> Test for H1: T-test between the % of correct answers of the rock-music-group and the % of correct answers of classic-music-group.\r\n\r\n**3. Write down the variables in your experiment that relate to this hypothesis.** \r\nIf you don’t know how these variables will be called in the end, write them down with an approximate name. The most important thing is that you write down what data your experiment will give you. \r\nFor example:\r\n>Variable in our experiment:\r\n> \r\n>v_123 = experimental groups (1 = classic, 2 = rock)\r\n> \r\n>v_009 = maths test answer 1\r\n>v_010 = maths test answer 2\r\n>v_011 = maths test answer 3\r\n>v_012 = maths test answer 4\r\n\r\nIn this example it would be clever if you renamed the variables v_123 as experimental_condition and v_009 - v_012 as maths_1 through maths_4.\r\n\r\nNow you can see that there are four maths test answers but the t-test in step 2 needs the % of correct answers. Therefore, you need to first calculate the mean. In this case you can write down another step.\r\n\r\n**4. Transform the data.** \r\nFor example: \r\n>Data transformations: \r\n>1. Compute which maths test answer was correct (v_009 - v_012) \r\n>2. Compute for each person in the sample the mean number of correct answers\r\n\r\nYou can also already write down the requirements for the t-test (look into your statistics book if you don’t remember how). \r\nFor example: \r\n>For t-test: compute test of variance homogeneity of correct answers\r\n\r\nImportant: See what the difference between step 3 and step 4 above is? Step 4 mentions the variables v_009 to v_012 while step 3 only mentions the ‘correct answers’ which are not in your raw data.\r\n\r\n**Repeat these four steps with all your hypotheses.**\r\n\r\nTip: if you are a bit familiar with R you can write the statistical commands for the test of your hypothesis directly in R. For example: \r\n\r\n\r\n```R\r\n# H1: Listening to classical music increases performance in math taks more than rock music because it distracts people less \r\n\r\n# Mean number of correct maths test items \r\nmean_correct_per_person <- rowSums(data[, c(“v_009”, “v_010”, “v_011”, “v_012”)] / 4) \r\nheard_classic <- data$v_123 # 1 = classic, 2 = rock \r\n\r\n# Homogeneity of variances? \r\nbartlett.test(x = mean_correct_per_persom, y = heard_classic) \r\n\r\n# Differences in groups? \r\nmean_correct_classic <- mean_correct_per_person[heard_classic == 1] \r\nmean_correct_rock <- mean_correct_per_person[heard_classic == 2] \r\nt.test(x = mean_correct_classic, y = mean_correct_rock )\r\n```\r\nNote: a line beginning with a hashtag (#) indicates a comment in R. This means that it is not carried out as code.\r\n\r\nIf you are not familiar with R yet, do not worry. We will introduce R in the following chapters.', 'It is important to plan your analysis during the design of the experiment. This means that you already have to think in detail about the statistical tests for your hypotheses and the approximate computations when you design the experiment. You want to do this before running the experiment, because if you realize that some variables are missing after you ran the study, it’s just too late. Analysis plans are easy. You can simply follow these four steps:\r\n{.lead}\r\n\r\n**1. Select the hypothesis.** \r\nFor example: \r\n> H1: Listening to classical music increases performance\r\nin math taks more than rock music because it distracts people less.\r\n\r\n**2. Write down the test.** \r\nFor example:\r\n> Test for H1: T-test between the % of correct answers of the rock-music-group and the % of correct answers of classic-music-group.\r\n\r\n**3. Write down the variables in your experiment that relate to this hypothesis.** \r\nIf you don’t know how these variables will be called in the end, write them down with an approximate name. The most important thing is that you write down what data your experiment will give you. \r\nFor example:\r\n>Variable in our experiment:\r\n> \r\n>v_123 = experimental groups (1 = classic, 2 = rock)\r\n> \r\n>v_009 = maths test answer 1\r\n>v_010 = maths test answer 2\r\n>v_011 = maths test answer 3\r\n>v_012 = maths test answer 4\r\n\r\nIn this example it would be clever if you renamed the variables v_123 as experimental_condition and v_009 - v_012 as maths_1 through maths_4.\r\n\r\nNow you can see that there are four maths test answers but the t-test in step 2 needs the % of correct answers. Therefore, you need to first calculate the mean. In this case you can write down another step.\r\n\r\n**4. Transform the data.** \r\nFor example: \r\n>Data transformations: \r\n>1. Compute which maths test answer was correct (v_009 - v_012) \r\n>2. Compute for each person in the sample the mean number of correct answers\r\n\r\nYou can also already write down the requirements for the t-test (look into your statistics book if you don’t remember how). \r\nFor example: \r\n>For t-test: compute test of variance homogeneity of correct answers\r\n\r\nImportant: See what the difference between step 3 and step 4 above is? Step 4 mentions the variables v_009 to v_012 while step 3 only mentions the ‘correct answers’ which are not in your raw data.\r\n\r\n**Repeat these four steps with all your hypotheses.**\r\n\r\nTip: if you are a bit familiar with R you can write the statistical commands for the test of your hypothesis directly in R. For example: \r\n\r\n\r\n```R\r\n# H1: Listening to classical music increases performance in math taks more than rock music because it distracts people less \r\n\r\n# Mean number of correct maths test items \r\nmean_correct_per_person <- rowSums(data[, c(“v_009”, “v_010”, “v_011”, “v_012”)] / 4) \r\nheard_classic <- data$v_123 # 1 = classic, 2 = rock \r\n\r\n# Homogeneity of variances? \r\nbartlett.test(x = mean_correct_per_persom, y = heard_classic) \r\n\r\n# Differences in groups? \r\nmean_correct_classic <- mean_correct_per_person[heard_classic == 1] \r\nmean_correct_rock <- mean_correct_per_person[heard_classic == 2] \r\nt.test(x = mean_correct_classic, y = mean_correct_rock )\r\n```\r\nNote: a line beginning with a hashtag (#) indicates a comment in R. This means that it is not carried out as code.\r\n\r\nIf you are not familiar with R yet, do not worry. We will introduce R in the following chapters.', None, '', None, None, None, None, None, None, None, 'University of Basel', 'University of Basel', 'University of Basel', None, 'TT', '10 Min.', 0, 'published', False, None, None, None, None, 22), (71, datetime.datetime(2020, 11, 2, 15, 9, 33, 774510, tzinfo=datetime.timezone.utc), datetime.datetime(2020, 11, 2, 15, 9, 37, 380664, tzinfo=datetime.timezone.utc), datetime.datetime(2020, 11, 2, 15, 9, 37, 380674, tzinfo=datetime.timezone.utc), False, 'Which test for which hypothesis?', 'Which test for which hypothesis?', 'Which test for which hypothesis?', None, 'Stats recap', 'Stats recap', 'Stats recap', None, '', None, None, None, '', 'which-test-for-which-hypothesis', 'Choosing the correct statistical test is crucial for your experiment. Which test you should use is determined by your study design, your hypotheses, and the type of data you gather. Let’s first revise some important terminology (if you already know what these are you can [skip ahead](#rules).)\r\n{.lead}\r\n\r\n**Dependent variables (DV) and independent variables (IV)** \r\nIn many studies the variables can be classified as dependent variable (also called criterion) or independent variable (or predictor). If you have conducted a true experiment, then the independent variables (IVs) are those that you have directly manipulated, and the dependent variables (DVs) are those you have merely measured. For quasi-experimental designs, the IVs are those variables that you have somehow controlled or selected for (e.g. gender), with the goal of testing how the DV changes as a function of the IVs. However, in some designs you do not have a clear DV and IV, instead you merely want to see whether there is a relationship between two measured variables.\r\n\r\n**Continuous variables and categorical variables** \r\nCategorical variables are variables where each level of the variable is a separate category. These variables are measured on a nominal or ordinal scale. \r\n➔ In nominal scales these categories or levels of the variable cannot be ranked or ordered (e.g. gender = female, male; or nationality = Swiss, Italian). \r\n➔ In ordinal variables the categories or levels of the variable can be ranked or ordered (e.g. degree level = none < Bachelor’s < Master’s).\r\n\r\nContinuous variables are measured on interval or ratio scales. In both of these scales not only the levels of the variable are ordered, but also the differences between the levels is in a meaningful unit. That means the difference between level 1 and level 2, is the same as the difference between level 2 and 3 (e.g. temperature in Celsius = 0° < 1° and the distance between 0° and 1° is the same as the distance between 1° and 2°). \r\n➔ Ratio scales have an additional property over interval scales in such a way that they also have a meaningful 0 point (e.g. length in cm, number of correct items).\r\n\r\n<a name="rules"></a>**Rules for determining the right test** \r\nCheck out the [decision tree](#decisiontree) below for determining the appropriate test. If you can answer the following seven questions, you should be able to determine which statistical test is appropriate for your experiment: \r\n<br/>\r\n1. Do I have a clear dependent variable (DV) and independent variable (IV), or am I testing for an association between two variables? \r\n2. Is my DV continuous in nature or discrete/categorical? \r\n3. Do I have more than one IV? \r\n4. Are all of my IVs categorical in nature? \r\n5. Do I have any categorical IVs with more than two categories? \r\n6. Is my manipulation within or between subjects? \r\n7. Do I satisfy the assumptions to use a parametric version of the test? \r\n\r\nThe first six questions in this decision tree are all based on decisions you made when you were designing your study. So, they should be easy to answer. The last question, however, is used to decide whether you should use a parametric version of the test (those generally shown in the table) or a non-parametric equivalent.\r\n\r\n**Parametric tests and non-parametric tests** \r\nSome statistical test assume distributions of variables, like a normal distribution. The tests are called parametric tests, because they estimate certain parameters from the distribution that they assume to be true. \r\n\r\nAlternatively, statistical tests can make no assumptions about the distributions of variables. These tests are called non-parametric tests, because they do not estimate parameters from a hypothetical distribution of the data. Most statistical tests make certain assumptions (without knowing the data) about how the data looks like. Tests need these assumptions to provide accurate results. Here are the three most important assumptions: \r\n\r\n**Normal distribution (normality assumption)**: The DV is approximately normally distributed at each level of the IV. \r\n**Constant variance (homoscedasticity assumption)**: The variance of the DV is equal at all levels of the IV. It is also called homogeneity of variance. \r\n**Constant differences (sphericity assumption)**: This assumption is quite similar to homoscedasticity but it is applicable when you have a within subjects/repeated measures design with more than two repeats (i.e., the DV has been measured three or more times for each participant). If we calculate difference scores between any two measures in such a scenario (e.g. pretreat – posttreat), the variance of these differences scores should be the same as any other combination of two measures (e.g. pretreat – followup or followup – posttreat).\r\n\r\nWhen you can not be sure that your DV and IV data generating process follows the assumed distribution for a **parametric test**, you might use a related non-parametric test. You might either know that these assumptions are incorrect before running your experiment, or you might infer from the data you have collected that they are likely to be incorrect (e.g. checking the residuals are roughly normally distributed).\r\n**Non-parametric tests** can be applied to many datasets, but usually parametric tests allow for a more detailed statement: For instance, the non-parametric test says, ‘Both distribution are different’, while the parametric test can say, ‘The mean of distribution A is higher than that of B’. Further, if the assumptions are met in general, a parametric test will be more powerful, than a non-parametric test.\r\n\r\n<a name="decisiontree"></a>**Decision tree** \r\nThis decision tree helps you to find the right test for your experiment. How to run the test in R is explained in chapter [4.6 Hypothesis test with R](https://tales.nmc.unibas.ch/de/conducting-psychological-research-6/statistics-and-analyses-22/hypothesis-tests-with-r-77).\r\n\r\n![Diagram Tests](/media/tales/markdownx/e2d02798-2306-4d2c-a2b0-4b65941d72d5.png)\r\n\r\n**Answering the questions** \r\nWhich Tests do I use if I don’t have an IV and DV?\r\n\r\n* If the variables are categorical:\r\n\t* If they are ordinal variables (think of degree): Spearman Correlation Test\r\n\t* If they are nominal variables (think of gender): Chi-Squared test\r\n* If the variables are continuous and they are linearly related:\r\n\t* If the assumptions of homoscedasticity and normality are met: Pearson Correlation Test\r\n\t* If these assumptions aren’t met: Spearman Correlation Test\r\n\r\nWhich Tests do I use if my DV is categorical (think of degree, gender)?\r\n\r\n* If the IV is also categorical: Chi-squared test\r\n* If the IV is continuous and/or there is more than one IV: Binomial regression, such as a logistic or probit regression.\r\n\r\nWhich Tests do I use if I my DV is continuous and I have a single categorical IV?\r\n\r\n* If the IV has 1 or 2 levels: \r\n\t* and the manipulation is between-subjects\r\n\t\t* Independent Samples t-test if manipulation is between subjects and homoscedasticity and normality assumptions are met.\r\n\t\t* If the assumptions aren’t met, a Wilcoxin Rank-sum/Mann Whitney test is appropriate.\r\n\t* and the the manipulation is within-subjects or the IV has only a single level \r\n\t\t* and the IV normally distributed: Dependent/Single Means t-test.\r\n\t\t* if normality is not satisfied use a Wilcoxin Sign test.\r\n* If the IV has 3 levels:\r\n\t* and the manipulation is between-subjects\r\n\t\t* ANOVA if normality and homoscedasticity are met\r\n\t\t* else Kruskal-Wallis Test\r\n\t* and the manipulation is within-subjects\r\n\t\t* Within subjects ANOVA if normality and sphericity are satisfied\r\n\t\t* else a Friedman Test.\r\n\r\nWhich Tests do I use if I my DV is continuous and I have a single continuous IV?\r\n\r\n* Simple Linear Regression if homoscedasticity and normality assumptions are satisfied and relationship is linear.\r\n* If data is not normally distributed, for instance, if it is positively skewed, you can use box-cox or log transformations to try to achieve normality. However you should be careful when describing the relationship.\r\n\r\nWhich Tests do I use if I my DV is continuous and I have multiple IVs?\r\n\r\n* If all IVs are categorical: Between Subjects ANOVA if all IVs are between subjects and homoscedasticity and normality assumptions are satisfied.\r\n\t* Repeated Measures ANOVA if all IVs are within subjects and sphericity and normality assumptions are satisfied.\r\n\t* Mixed ANOVA if some IVs are within subjects and some between subjects. Assumptions of sphericity, homoscedasticity and normality must be satisfied.\r\n\t* If the assumptions aren’t met for these tests you can apply corrections for some violations, or transform your data (for instance log or box-cox transformations for skewed data) to try to meet normality requirements.\r\n* Otherwise:\r\n\t* Multiple Linear Regression if homoscedasticity and normality assumptions are satisfied and relationships are linear.\r\n\t* If data is not normally distributed, for instance if it is positively skewed, you can use box-cox or log transformations to try to achieve normality. However, you should be careful when then describing the relationship.\r\n\r\n**Other Tests** \r\nThese are the main statistical tests you are likely to use in your project. However, there are many more complicated tests you might need to use. You may also decide not to use a traditional frequentist statistical test, but use Bayesian Statistics instead. In any case, you should discuss with your supervisor what test is appropriate for your project.\r\n\r\n**Multiple Comparisons** \r\nAnother important issue to consider is that of multiple comparisons and contrast effects. Depending on the design of your study, you might be running either the same test on multiple dependent variables, or run multiple tests comparing particular combinations of IV groups. For example, you might have a design with a control group and 2 different treatment groups. You might want to compare each treatment group to the control group, and the two treatment groups to each other. In this case you should start to consider whether you need to correct your alpha level to account for the multiple comparisons you are conducting.', 'Choosing the correct statistical test is crucial for your experiment. Which test you should use is determined by your study design, your hypotheses, and the type of data you gather. Let’s first revise some important terminology (if you already know what these are you can [skip ahead](#rules).)\r\n{.lead}\r\n\r\n**Dependent variables (DV) and independent variables (IV)** \r\nIn many studies the variables can be classified as dependent variable (also called criterion) or independent variable (or predictor). If you have conducted a true experiment, then the independent variables (IVs) are those that you have directly manipulated, and the dependent variables (DVs) are those you have merely measured. For quasi-experimental designs, the IVs are those variables that you have somehow controlled or selected for (e.g. gender), with the goal of testing how the DV changes as a function of the IVs. However, in some designs you do not have a clear DV and IV, instead you merely want to see whether there is a relationship between two measured variables.\r\n\r\n**Continuous variables and categorical variables** \r\nCategorical variables are variables where each level of the variable is a separate category. These variables are measured on a nominal or ordinal scale. \r\n➔ In nominal scales these categories or levels of the variable cannot be ranked or ordered (e.g. gender = female, male; or nationality = Swiss, Italian). \r\n➔ In ordinal variables the categories or levels of the variable can be ranked or ordered (e.g. degree level = none < Bachelor’s < Master’s).\r\n\r\nContinuous variables are measured on interval or ratio scales. In both of these scales not only the levels of the variable are ordered, but also the differences between the levels is in a meaningful unit. That means the difference between level 1 and level 2, is the same as the difference between level 2 and 3 (e.g. temperature in Celsius = 0° < 1° and the distance between 0° and 1° is the same as the distance between 1° and 2°). \r\n➔ Ratio scales have an additional property over interval scales in such a way that they also have a meaningful 0 point (e.g. length in cm, number of correct items).\r\n\r\n<a name="rules"></a>**Rules for determining the right test** \r\nCheck out the [decision tree](#decisiontree) below for determining the appropriate test. If you can answer the following seven questions, you should be able to determine which statistical test is appropriate for your experiment: \r\n<br/>\r\n1. Do I have a clear dependent variable (DV) and independent variable (IV), or am I testing for an association between two variables? \r\n2. Is my DV continuous in nature or discrete/categorical? \r\n3. Do I have more than one IV? \r\n4. Are all of my IVs categorical in nature? \r\n5. Do I have any categorical IVs with more than two categories? \r\n6. Is my manipulation within or between subjects? \r\n7. Do I satisfy the assumptions to use a parametric version of the test? \r\n\r\nThe first six questions in this decision tree are all based on decisions you made when you were designing your study. So, they should be easy to answer. The last question, however, is used to decide whether you should use a parametric version of the test (those generally shown in the table) or a non-parametric equivalent.\r\n\r\n**Parametric tests and non-parametric tests** \r\nSome statistical test assume distributions of variables, like a normal distribution. The tests are called parametric tests, because they estimate certain parameters from the distribution that they assume to be true. \r\n\r\nAlternatively, statistical tests can make no assumptions about the distributions of variables. These tests are called non-parametric tests, because they do not estimate parameters from a hypothetical distribution of the data. Most statistical tests make certain assumptions (without knowing the data) about how the data looks like. Tests need these assumptions to provide accurate results. Here are the three most important assumptions: \r\n\r\n**Normal distribution (normality assumption)**: The DV is approximately normally distributed at each level of the IV. \r\n**Constant variance (homoscedasticity assumption)**: The variance of the DV is equal at all levels of the IV. It is also called homogeneity of variance. \r\n**Constant differences (sphericity assumption)**: This assumption is quite similar to homoscedasticity but it is applicable when you have a within subjects/repeated measures design with more than two repeats (i.e., the DV has been measured three or more times for each participant). If we calculate difference scores between any two measures in such a scenario (e.g. pretreat – posttreat), the variance of these differences scores should be the same as any other combination of two measures (e.g. pretreat – followup or followup – posttreat).\r\n\r\nWhen you can not be sure that your DV and IV data generating process follows the assumed distribution for a **parametric test**, you might use a related non-parametric test. You might either know that these assumptions are incorrect before running your experiment, or you might infer from the data you have collected that they are likely to be incorrect (e.g. checking the residuals are roughly normally distributed).\r\n**Non-parametric tests** can be applied to many datasets, but usually parametric tests allow for a more detailed statement: For instance, the non-parametric test says, ‘Both distribution are different’, while the parametric test can say, ‘The mean of distribution A is higher than that of B’. Further, if the assumptions are met in general, a parametric test will be more powerful, than a non-parametric test.\r\n\r\n<a name="decisiontree"></a>**Decision tree** \r\nThis decision tree helps you to find the right test for your experiment. How to run the test in R is explained in chapter [4.6 Hypothesis test with R](https://tales.nmc.unibas.ch/de/conducting-psychological-research-6/statistics-and-analyses-22/hypothesis-tests-with-r-77).\r\n\r\n![Diagram Tests](/media/markdownx/e2d02798-2306-4d2c-a2b0-4b65941d72d5.png)\r\n\r\n**Answering the questions** \r\nWhich Tests do I use if I don’t have an IV and DV?\r\n\r\n* If the variables are categorical:\r\n\t* If they are ordinal variables (think of degree): Spearman Correlation Test\r\n\t* If they are nominal variables (think of gender): Chi-Squared test\r\n* If the variables are continuous and they are linearly related:\r\n\t* If the assumptions of homoscedasticity and normality are met: Pearson Correlation Test\r\n\t* If these assumptions aren’t met: Spearman Correlation Test\r\n\r\nWhich Tests do I use if my DV is categorical (think of degree, gender)?\r\n\r\n* If the IV is also categorical: Chi-squared test\r\n* If the IV is continuous and/or there is more than one IV: Binomial regression, such as a logistic or probit regression.\r\n\r\nWhich Tests do I use if I my DV is continuous and I have a single categorical IV?\r\n\r\n* If the IV has 1 or 2 levels: \r\n\t* and the manipulation is between-subjects\r\n\t\t* Independent Samples t-test if manipulation is between subjects and homoscedasticity and normality assumptions are met.\r\n\t\t* If the assumptions aren’t met, a Wilcoxin Rank-sum/Mann Whitney test is appropriate.\r\n\t* and the the manipulation is within-subjects or the IV has only a single level \r\n\t\t* and the IV normally distributed: Dependent/Single Means t-test.\r\n\t\t* if normality is not satisfied use a Wilcoxin Sign test.\r\n* If the IV has 3 levels:\r\n\t* and the manipulation is between-subjects\r\n\t\t* ANOVA if normality and homoscedasticity are met\r\n\t\t* else Kruskal-Wallis Test\r\n\t* and the manipulation is within-subjects\r\n\t\t* Within subjects ANOVA if normality and sphericity are satisfied\r\n\t\t* else a Friedman Test.\r\n\r\nWhich Tests do I use if I my DV is continuous and I have a single continuous IV?\r\n\r\n* Simple Linear Regression if homoscedasticity and normality assumptions are satisfied and relationship is linear.\r\n* If data is not normally distributed, for instance, if it is positively skewed, you can use box-cox or log transformations to try to achieve normality. However you should be careful when describing the relationship.\r\n\r\nWhich Tests do I use if I my DV is continuous and I have multiple IVs?\r\n\r\n* If all IVs are categorical: Between Subjects ANOVA if all IVs are between subjects and homoscedasticity and normality assumptions are satisfied.\r\n\t* Repeated Measures ANOVA if all IVs are within subjects and sphericity and normality assumptions are satisfied.\r\n\t* Mixed ANOVA if some IVs are within subjects and some between subjects. Assumptions of sphericity, homoscedasticity and normality must be satisfied.\r\n\t* If the assumptions aren’t met for these tests you can apply corrections for some violations, or transform your data (for instance log or box-cox transformations for skewed data) to try to meet normality requirements.\r\n* Otherwise:\r\n\t* Multiple Linear Regression if homoscedasticity and normality assumptions are satisfied and relationships are linear.\r\n\t* If data is not normally distributed, for instance if it is positively skewed, you can use box-cox or log transformations to try to achieve normality. However, you should be careful when then describing the relationship.\r\n\r\n**Other Tests** \r\nThese are the main statistical tests you are likely to use in your project. However, there are many more complicated tests you might need to use. You may also decide not to use a traditional frequentist statistical test, but use Bayesian Statistics instead. In any case, you should discuss with your supervisor what test is appropriate for your project.\r\n\r\n**Multiple Comparisons** \r\nAnother important issue to consider is that of multiple comparisons and contrast effects. Depending on the design of your study, you might be running either the same test on multiple dependent variables, or run multiple tests comparing particular combinations of IV groups. For example, you might have a design with a control group and 2 different treatment groups. You might want to compare each treatment group to the control group, and the two treatment groups to each other. In this case you should start to consider whether you need to correct your alpha level to account for the multiple comparisons you are conducting.', 'Choosing the correct statistical test is crucial for your experiment. Which test you should use is determined by your study design, your hypotheses, and the type of data you gather. Let’s first revise some important terminology (if you already know what these are you can [skip ahead](#rules).)\r\n{.lead}\r\n\r\n**Dependent variables (DV) and independent variables (IV)** \r\nIn many studies the variables can be classified as dependent variable (also called criterion) or independent variable (or predictor). If you have conducted a true experiment, then the independent variables (IVs) are those that you have directly manipulated, and the dependent variables (DVs) are those you have merely measured. For quasi-experimental designs, the IVs are those variables that you have somehow controlled or selected for (e.g. gender), with the goal of testing how the DV changes as a function of the IVs. However, in some designs you do not have a clear DV and IV, instead you merely want to see whether there is a relationship between two measured variables.\r\n\r\n**Continuous variables and categorical variables** \r\nCategorical variables are variables where each level of the variable is a separate category. These variables are measured on a nominal or ordinal scale. \r\n➔ In nominal scales these categories or levels of the variable cannot be ranked or ordered (e.g. gender = female, male; or nationality = Swiss, Italian). \r\n➔ In ordinal variables the categories or levels of the variable can be ranked or ordered (e.g. degree level = none < Bachelor’s < Master’s).\r\n\r\nContinuous variables are measured on interval or ratio scales. In both of these scales not only the levels of the variable are ordered, but also the differences between the levels is in a meaningful unit. That means the difference between level 1 and level 2, is the same as the difference between level 2 and 3 (e.g. temperature in Celsius = 0° < 1° and the distance between 0° and 1° is the same as the distance between 1° and 2°). \r\n➔ Ratio scales have an additional property over interval scales in such a way that they also have a meaningful 0 point (e.g. length in cm, number of correct items).\r\n\r\n<a name="rules"></a>**Rules for determining the right test** \r\nCheck out the [decision tree](#decisiontree) below for determining the appropriate test. If you can answer the following seven questions, you should be able to determine which statistical test is appropriate for your experiment: \r\n<br/>\r\n1. Do I have a clear dependent variable (DV) and independent variable (IV), or am I testing for an association between two variables? \r\n2. Is my DV continuous in nature or discrete/categorical? \r\n3. Do I have more than one IV? \r\n4. Are all of my IVs categorical in nature? \r\n5. Do I have any categorical IVs with more than two categories? \r\n6. Is my manipulation within or between subjects? \r\n7. Do I satisfy the assumptions to use a parametric version of the test? \r\n\r\nThe first six questions in this decision tree are all based on decisions you made when you were designing your study. So, they should be easy to answer. The last question, however, is used to decide whether you should use a parametric version of the test (those generally shown in the table) or a non-parametric equivalent.\r\n\r\n**Parametric tests and non-parametric tests** \r\nSome statistical test assume distributions of variables, like a normal distribution. The tests are called parametric tests, because they estimate certain parameters from the distribution that they assume to be true. \r\n\r\nAlternatively, statistical tests can make no assumptions about the distributions of variables. These tests are called non-parametric tests, because they do not estimate parameters from a hypothetical distribution of the data. Most statistical tests make certain assumptions (without knowing the data) about how the data looks like. Tests need these assumptions to provide accurate results. Here are the three most important assumptions: \r\n\r\n**Normal distribution (normality assumption)**: The DV is approximately normally distributed at each level of the IV. \r\n**Constant variance (homoscedasticity assumption)**: The variance of the DV is equal at all levels of the IV. It is also called homogeneity of variance. \r\n**Constant differences (sphericity assumption)**: This assumption is quite similar to homoscedasticity but it is applicable when you have a within subjects/repeated measures design with more than two repeats (i.e., the DV has been measured three or more times for each participant). If we calculate difference scores between any two measures in such a scenario (e.g. pretreat – posttreat), the variance of these differences scores should be the same as any other combination of two measures (e.g. pretreat – followup or followup – posttreat).\r\n\r\nWhen you can not be sure that your DV and IV data generating process follows the assumed distribution for a **parametric test**, you might use a related non-parametric test. You might either know that these assumptions are incorrect before running your experiment, or you might infer from the data you have collected that they are likely to be incorrect (e.g. checking the residuals are roughly normally distributed).\r\n**Non-parametric tests** can be applied to many datasets, but usually parametric tests allow for a more detailed statement: For instance, the non-parametric test says, ‘Both distribution are different’, while the parametric test can say, ‘The mean of distribution A is higher than that of B’. Further, if the assumptions are met in general, a parametric test will be more powerful, than a non-parametric test.\r\n\r\n<a name="decisiontree"></a>**Decision tree** \r\nThis decision tree helps you to find the right test for your experiment. How to run the test in R is explained in chapter [4.6 Hypothesis test with R](https://tales.nmc.unibas.ch/de/conducting-psychological-research-6/statistics-and-analyses-22/hypothesis-tests-with-r-77).\r\n\r\n![Diagram Tests](/media/markdownx/e2d02798-2306-4d2c-a2b0-4b65941d72d5.png)\r\n\r\n**Answering the questions** \r\nWhich Tests do I use if I don’t have an IV and DV?\r\n\r\n* If the variables are categorical:\r\n\t* If they are ordinal variables (think of degree): Spearman Correlation Test\r\n\t* If they are nominal variables (think of gender): Chi-Squared test\r\n* If the variables are continuous and they are linearly related:\r\n\t* If the assumptions of homoscedasticity and normality are met: Pearson Correlation Test\r\n\t* If these assumptions aren’t met: Spearman Correlation Test\r\n\r\nWhich Tests do I use if my DV is categorical (think of degree, gender)?\r\n\r\n* If the IV is also categorical: Chi-squared test\r\n* If the IV is continuous and/or there is more than one IV: Binomial regression, such as a logistic or probit regression.\r\n\r\nWhich Tests do I use if I my DV is continuous and I have a single categorical IV?\r\n\r\n* If the IV has 1 or 2 levels: \r\n\t* and the manipulation is between-subjects\r\n\t\t* Independent Samples t-test if manipulation is between subjects and homoscedasticity and normality assumptions are met.\r\n\t\t* If the assumptions aren’t met, a Wilcoxin Rank-sum/Mann Whitney test is appropriate.\r\n\t* and the the manipulation is within-subjects or the IV has only a single level \r\n\t\t* and the IV normally distributed: Dependent/Single Means t-test.\r\n\t\t* if normality is not satisfied use a Wilcoxin Sign test.\r\n* If the IV has 3 levels:\r\n\t* and the manipulation is between-subjects\r\n\t\t* ANOVA if normality and homoscedasticity are met\r\n\t\t* else Kruskal-Wallis Test\r\n\t* and the manipulation is within-subjects\r\n\t\t* Within subjects ANOVA if normality and sphericity are satisfied\r\n\t\t* else a Friedman Test.\r\n\r\nWhich Tests do I use if I my DV is continuous and I have a single continuous IV?\r\n\r\n* Simple Linear Regression if homoscedasticity and normality assumptions are satisfied and relationship is linear.\r\n* If data is not normally distributed, for instance, if it is positively skewed, you can use box-cox or log transformations to try to achieve normality. However you should be careful when describing the relationship.\r\n\r\nWhich Tests do I use if I my DV is continuous and I have multiple IVs?\r\n\r\n* If all IVs are categorical: Between Subjects ANOVA if all IVs are between subjects and homoscedasticity and normality assumptions are satisfied.\r\n\t* Repeated Measures ANOVA if all IVs are within subjects and sphericity and normality assumptions are satisfied.\r\n\t* Mixed ANOVA if some IVs are within subjects and some between subjects. Assumptions of sphericity, homoscedasticity and normality must be satisfied.\r\n\t* If the assumptions aren’t met for these tests you can apply corrections for some violations, or transform your data (for instance log or box-cox transformations for skewed data) to try to meet normality requirements.\r\n* Otherwise:\r\n\t* Multiple Linear Regression if homoscedasticity and normality assumptions are satisfied and relationships are linear.\r\n\t* If data is not normally distributed, for instance if it is positively skewed, you can use box-cox or log transformations to try to achieve normality. However, you should be careful when then describing the relationship.\r\n\r\n**Other Tests** \r\nThese are the main statistical tests you are likely to use in your project. However, there are many more complicated tests you might need to use. You may also decide not to use a traditional frequentist statistical test, but use Bayesian Statistics instead. In any case, you should discuss with your supervisor what test is appropriate for your project.\r\n\r\n**Multiple Comparisons** \r\nAnother important issue to consider is that of multiple comparisons and contrast effects. Depending on the design of your study, you might be running either the same test on multiple dependent variables, or run multiple tests comparing particular combinations of IV groups. For example, you might have a design with a control group and 2 different treatment groups. You might want to compare each treatment group to the control group, and the two treatment groups to each other. In this case you should start to consider whether you need to correct your alpha level to account for the multiple comparisons you are conducting.', None, '', None, None, None, None, None, None, None, 'University of Basel', 'University of Basel', 'University of Basel', None, 'TT', '15 min.', 1, 'published', False, None, None, None, None, 22), (51, datetime.datetime(2020, 11, 2, 15, 9, 33, 774510, tzinfo=datetime.timezone.utc), datetime.datetime(2020, 11, 2, 15, 9, 37, 383196, tzinfo=datetime.timezone.utc), datetime.datetime(2020, 11, 2, 15, 9, 37, 383207, tzinfo=datetime.timezone.utc), False, 'Installing R and R Studio', 'Installing R and R Studio', 'Installing R and R Studio', None, '', '', '', None, '', None, None, None, '', 'installing-r-and-r-studio', 'We encourage students to use R for conducting their data analysis. R is a free language and environment for conducting statistical computing and creating graphics. In addition to being free, R has several advantages over other statistics programs like SPSS. \r\n{.lead}\r\n\r\nFirstly, R can be used to create all the figures that you need for a scientific report (please never put SPSS figures in a report). Secondly, it is much more flexible than SPSS, with both an in-built library of functions for conducting analyses, creating figures, transforming data and a host of other tasks you may need to perform, and a set of user contributed packages that expand on this library. Thirdly, R allows you to write your own functions and code to perform even more custom analyses.\r\n\r\nTo get started with R you first need to install what is often referred to as Base R. R is available on Mac OS X, Windows and a variety of UNIX platforms and can be downloaded from the [Comprehensive R Archive Network](https://cran.r-project.org/index.html). If you are using a Mac or Windows system, just use the appropriate links above and follow the instructions to download and install R.\r\n\r\nRStudio like R is another piece of free open source software. It provides some additional features and an interface to make using Base R a bit easier. You can download and install RStudio for Mac OSX, Windows and Linux systems for free by going to the [RSudio website](https://www.rstudio.com/products/rstudio/download/), and following the instructions for the free version.\r\n\r\nIn the following chapters we provide several tutorials to introduce you to some basic aspects of using R and help you to get started on your data analysis. A good resource for learning R is the textbook [‘Yarr: The Pirates Guide to R’ by Nathaniel Phillips](https://bookdown.org/ndphillips/YaRrr/).', 'We encourage students to use R for conducting their data analysis. R is a free language and environment for conducting statistical computing and creating graphics. In addition to being free, R has several advantages over other statistics programs like SPSS. \r\n{.lead}\r\n\r\nFirstly, R can be used to create all the figures that you need for a scientific report (please never put SPSS figures in a report). Secondly, it is much more flexible than SPSS, with both an in-built library of functions for conducting analyses, creating figures, transforming data and a host of other tasks you may need to perform, and a set of user contributed packages that expand on this library. Thirdly, R allows you to write your own functions and code to perform even more custom analyses.\r\n\r\nTo get started with R you first need to install what is often referred to as Base R. R is available on Mac OS X, Windows and a variety of UNIX platforms and can be downloaded from the [Comprehensive R Archive Network](https://cran.r-project.org/index.html). If you are using a Mac or Windows system, just use the appropriate links above and follow the instructions to download and install R.\r\n\r\nRStudio like R is another piece of free open source software. It provides some additional features and an interface to make using Base R a bit easier. You can download and install RStudio for Mac OSX, Windows and Linux systems for free by going to the [RSudio website](https://www.rstudio.com/products/rstudio/download/), and following the instructions for the free version.\r\n\r\nIn the following chapters we provide several tutorials to introduce you to some basic aspects of using R and help you to get started on your data analysis. A good resource for learning R is the textbook [‘Yarr: The Pirates Guide to R’ by Nathaniel Phillips](https://bookdown.org/ndphillips/YaRrr/).', 'We encourage students to use R for conducting their data analysis. R is a free language and environment for conducting statistical computing and creating graphics. In addition to being free, R has several advantages over other statistics programs like SPSS. \r\n{.lead}\r\n\r\nFirstly, R can be used to create all the figures that you need for a scientific report (please never put SPSS figures in a report). Secondly, it is much more flexible than SPSS, with both an in-built library of functions for conducting analyses, creating figures, transforming data and a host of other tasks you may need to perform, and a set of user contributed packages that expand on this library. Thirdly, R allows you to write your own functions and code to perform even more custom analyses.\r\n\r\nTo get started with R you first need to install what is often referred to as Base R. R is available on Mac OS X, Windows and a variety of UNIX platforms and can be downloaded from the [Comprehensive R Archive Network](https://cran.r-project.org/index.html). If you are using a Mac or Windows system, just use the appropriate links above and follow the instructions to download and install R.\r\n\r\nRStudio like R is another piece of free open source software. It provides some additional features and an interface to make using Base R a bit easier. You can download and install RStudio for Mac OSX, Windows and Linux systems for free by going to the [RSudio website](https://www.rstudio.com/products/rstudio/download/), and following the instructions for the free version.\r\n\r\nIn the following chapters we provide several tutorials to introduce you to some basic aspects of using R and help you to get started on your data analysis. A good resource for learning R is the textbook [‘Yarr: The Pirates Guide to R’ by Nathaniel Phillips](https://bookdown.org/ndphillips/YaRrr/).', None, '', None, None, None, None, None, None, None, '', '', '', None, 'TT', '5 min.', 2, 'published', False, None, None, None, None, 22), (72, datetime.datetime(2020, 11, 2, 15, 9, 33, 774510, tzinfo=datetime.timezone.utc), datetime.datetime(2020, 11, 2, 15, 9, 37, 384993, tzinfo=datetime.timezone.utc), datetime.datetime(2020, 11, 2, 15, 9, 37, 385023, tzinfo=datetime.timezone.utc), False, 'Read data with R', 'Read data with R', 'Read data with R', None, 'Read data', 'Read data', 'Read data', None, '', None, None, None, '', 'read-data-with-r', 'In this step we will cover basics of importing in your data in R. If you need more informations, we recommend you the textbook [Yarr: The Pirates Guide to R](https://bookdown.org/ndphillips/YaRrr/) by Nathaniel Phillips which is a good resource for for learning R.\r\n{.lead}\r\n\r\nFirst, you need to open RStudio. Type your R-code into the R-script in the top-left window (if there is no such window, use the menu File > New File > R Script). Hit Ctrl + enter to run your code. In the following video we explain to you how to read data into R. You can take hold of our example data in the ‘downloads’ section below.\r\n\r\n![embed](https://vimeo.com/253384563)', 'In this step we will cover basics of importing in your data in R. If you need more informations, we recommend you the textbook [Yarr: The Pirates Guide to R](https://bookdown.org/ndphillips/YaRrr/) by Nathaniel Phillips which is a good resource for for learning R.\r\n{.lead}\r\n\r\nFirst, you need to open RStudio. Type your R-code into the R-script in the top-left window (if there is no such window, use the menu File > New File > R Script). Hit Ctrl + enter to run your code. In the following video we explain to you how to read data into R. You can take hold of our example data in the ‘downloads’ section below.\r\n\r\n![embed](https://vimeo.com/253384563)', 'In this step we will cover basics of importing in your data in R. If you need more informations, we recommend you the textbook [Yarr: The Pirates Guide to R](https://bookdown.org/ndphillips/YaRrr/) by Nathaniel Phillips which is a good resource for for learning R.\r\n{.lead}\r\n\r\nFirst, you need to open RStudio. Type your R-code into the R-script in the top-left window (if there is no such window, use the menu File > New File > R Script). Hit Ctrl + enter to run your code. In the following video we explain to you how to read data into R. You can take hold of our example data in the ‘downloads’ section below.\r\n\r\n![embed](https://vimeo.com/253384563)', None, '', None, None, None, None, None, None, None, 'University of Basel', 'University of Basel', 'University of Basel', None, 'TV', '7 min.', 3, 'published', False, None, None, None, None, 22), (69, datetime.datetime(2020, 11, 2, 15, 9, 33, 774510, tzinfo=datetime.timezone.utc), datetime.datetime(2023, 11, 7, 8, 18, 30, 877024, tzinfo=datetime.timezone.utc), datetime.datetime(2023, 11, 7, 8, 18, 30, 836854, tzinfo=datetime.timezone.utc), False, 'Clean data with R', 'Clean data with R', 'Clean data with R', None, '', None, None, None, '', None, None, None, '', 'clean-data-with-r', 'In the last step you learned how to read data in R. But what if you need to clean your data in R? This video shows you how to check your data for invalid responses (think of typos like age = 125), or how to rename variables.\r\n{.lead}\r\n\r\nBelow the video, you find the R-code we used in the video. In plus, we added some code that could be useful for you as well. Once again, you can find the example data in the ‘downloads’ section below. Note: it is the same data as in the previous step.\r\n\r\n![embed](https://vimeo.com/253432398)\r\n\r\nHere is the code: \r\n\r\n``` R\r\n# Clean data with R\r\n\r\n# Set working directory\r\nsetwd("~/Desktop/Test R") # Change the content between quotation marks. It needs to be the path to the folder with your data\r\n\r\nmydata <- read.csv2("clean_data.csv") \t# read the data in\r\nhead(mydata) \t\t\t\t\t# look at the data\r\n\r\n# Clean this dataset\r\n# For example, we want no value > 100\r\nwhich(mydata > 100)\r\ntoohigh <- which(mydata > 100)\r\n\r\n# For example, we want no value < 0\r\nwhich(mydata < 0)\r\ntoolow <- which(mydata < 0)\r\n\r\n# Second version of my data\r\nmydatav2 <- mydata # copy data\r\nmydatav2[ mydatav2 > 100] <- NA # substitute by "NA" (missing value)\r\n\r\nwhich(mydatav2 > 100)\r\nwhich(mydata > 100)\r\n\r\nmydatav2[ mydatav2 < 0 ] <- NA\r\nwhich(mydatav2 < 0)\r\nwhich(mydata < 0)\r\n\r\n# variable privilege should not be 50\r\nmydata$privileges\r\n# substitute 50 for NA\r\nmydatav3 <- mydata # copy data set\r\nmydatav3$privileges[ mydatav3$privileges == 50 ] # two cases\r\n# substitute these cases with NA\r\nmydatav3$privileges[ mydatav3$privileges == 50 ] <- NA\r\n\r\nwhich( mydata$privileges == 50 ) # two cases of 50\r\nwhich( mydatav3$privileges == 50 ) # no case\r\n\r\n# column names\r\nhead(mydata)\r\nnames(mydata)\r\n# rename "rating" to "score"\r\nnames(mydata)[1] # return the first entry\r\nnames(mydata)[names(mydata) == "rating"] # alternative way to select 1. entry\r\n# rename the first entry\r\nnames(mydata)[1] <- "score"\r\nnames(mydata) # with new names\r\n\r\n\r\n\r\n# ADDITIONAL CODE THAT COULD BE USEFUL TO YOU (not shown in the video)\r\n\r\n# Mean of different variables\r\n# Calculate the mean of several variables in your dataset\r\n# For example the mean of \'complaints\' and \'privileges\'\r\nvariable_names <- c("complaints", "privileges") # store names of variables\r\nMW <- rowSums(mydata[, variable_names]) # compute mean of these two variables for each row and store it in MW\r\nmydata$Mean <- MW # Store the computed mean in mydata as variable ‘Mean’\r\n\r\nhead(mydata) # check the result\r\n\r\n\r\n# Recode reverse-coded variables\r\n# Say the variable \'complaints\' was reverse coded with the highest value of 111\r\n# Recoding works by subtracting the variable from the highest possible value and adding 1\r\n# highest value - variable + 1\r\n\r\ncomplaints_rev <- 111 - mydata$complaints - 1 # Recode complaints and store it in complaints_rev\r\nmydata$complaints_rev <- complaints_rev # store complaints_rev in the data mydata\r\n\r\nhead(mydata) # check the result\r\n```\r\n\r\nA good resource for learning R is the textbook [‘Yarr: The Pirates Guide to R’ by Nathaniel Phillips](https://bookdown.org/ndphillips/YaRrr/).', 'In the last step you learned how to read data in R. But what if you need to clean your data in R? This video shows you how to check your data for invalid responses (think of typos like age = 125), or how to rename variables.\r\n{.lead}\r\n\r\nBelow the video, you find the R-code we used in the video. In plus, we added some code that could be useful for you as well. Once again, you can find the example data in the ‘downloads’ section below. Note: it is the same data as in the previous step.\r\n\r\n![embed](https://vimeo.com/253432398)\r\n\r\nHere is the code: \r\n\r\n```R\r\n# Clean data with R\r\n\r\n# Read the data and assign them to mydata\r\nmydata <- read.csv2(file.choose())\r\n\r\n# Alternative way to read the data:\r\n# Set working directory\r\nsetwd("~/Desktop/Test R") # Change the content between quotation marks. It needs to be the path to the folder with your data\r\nmydata <- read.csv2("clean_data.csv") \t# read the data in\r\n\r\n# look at the data\r\nhead(mydata) \t\t\t\t\t\r\n\r\n# Clean this dataset\r\n# For example, we want no value > 100\r\nwhich(mydata > 100)\r\ntoohigh <- which(mydata > 100)\r\n\r\n# For example, we want no value < 0\r\nwhich(mydata < 0)\r\ntoolow <- which(mydata < 0)\r\n\r\n# Second version of my data\r\nmydatav2 <- mydata # copy data\r\nmydatav2[ mydatav2 > 100] <- NA # substitute by "NA" (missing value)\r\n\r\nwhich(mydatav2 > 100)\r\nwhich(mydata > 100)\r\n\r\nmydatav2[ mydatav2 < 0 ] <- NA\r\nwhich(mydatav2 < 0)\r\nwhich(mydata < 0)\r\n\r\n# variable privilege should not be 50\r\nmydata$privileges\r\n# substitute 50 for NA\r\nmydatav3 <- mydata # copy data set\r\nmydatav3$privileges[ mydatav3$privileges == 50 ] # two cases\r\n# substitute these cases with NA\r\nmydatav3$privileges[ mydatav3$privileges == 50 ] <- NA\r\n\r\nwhich( mydata$privileges == 50 ) # two cases of 50\r\nwhich( mydatav3$privileges == 50 ) # no case\r\n\r\n# column names\r\nhead(mydata)\r\nnames(mydata)\r\n# rename "rating" to "score"\r\nnames(mydata)[1] # return the first entry\r\nnames(mydata)[names(mydata) == "rating"] # alternative way to select 1. entry\r\n# rename the first entry\r\nnames(mydata)[1] <- "score"\r\nnames(mydata) # with new names\r\n\r\n\r\n\r\n# ADDITIONAL CODE THAT COULD BE USEFUL TO YOU (not shown in the video)\r\n\r\n# Mean of different variables\r\n# Calculate the mean of several variables in your dataset\r\n# For example the mean of \'complaints\' and \'privileges\'\r\nvariable_names <- c("complaints", "privileges") # store names of variables\r\nMW <- rowSums(mydata[, variable_names]) # compute mean of these two variables for each row and store it in MW\r\nmydata$Mean <- MW # Store the computed mean in mydata as variable ‘Mean’\r\n\r\nhead(mydata) # check the result\r\n\r\n\r\n# Recode reverse-coded variables\r\n# Say the variable \'complaints\' was reverse coded with the highest value of 111\r\n# Recoding works by subtracting the variable from the highest possible value and adding 1\r\n# highest value - variable + 1\r\n\r\ncomplaints_rev <- 111 - mydata$complaints - 1 # Recode complaints and store it in complaints_rev\r\nmydata$complaints_rev <- complaints_rev # store complaints_rev in the data mydata\r\n\r\nhead(mydata) # check the result\r\n```\r\n\r\nA good resource for learning R is the textbook [‘Yarr: The Pirates Guide to R’ by Nathaniel Phillips](https://bookdown.org/ndphillips/YaRrr/).', 'In the last step you learned how to read data in R. But what if you need to clean your data in R? This video shows you how to check your data for invalid responses (think of typos like age = 125), or how to rename variables.\r\n{.lead}\r\n\r\nBelow the video, you find the R-code we used in the video. In plus, we added some code that could be useful for you as well. Once again, you can find the example data in the ‘downloads’ section below. Note: it is the same data as in the previous step.\r\n\r\n![embed](https://vimeo.com/253432398)\r\n\r\nHere is the code: \r\n\r\n``` R\r\n# Clean data with R\r\n\r\n# Set working directory\r\nsetwd("~/Desktop/Test R") # Change the content between quotation marks. It needs to be the path to the folder with your data\r\n\r\nmydata <- read.csv2("clean_data.csv") \t# read the data in\r\nhead(mydata) \t\t\t\t\t# look at the data\r\n\r\n# Clean this dataset\r\n# For example, we want no value > 100\r\nwhich(mydata > 100)\r\ntoohigh <- which(mydata > 100)\r\n\r\n# For example, we want no value < 0\r\nwhich(mydata < 0)\r\ntoolow <- which(mydata < 0)\r\n\r\n# Second version of my data\r\nmydatav2 <- mydata # copy data\r\nmydatav2[ mydatav2 > 100] <- NA # substitute by "NA" (missing value)\r\n\r\nwhich(mydatav2 > 100)\r\nwhich(mydata > 100)\r\n\r\nmydatav2[ mydatav2 < 0 ] <- NA\r\nwhich(mydatav2 < 0)\r\nwhich(mydata < 0)\r\n\r\n# variable privilege should not be 50\r\nmydata$privileges\r\n# substitute 50 for NA\r\nmydatav3 <- mydata # copy data set\r\nmydatav3$privileges[ mydatav3$privileges == 50 ] # two cases\r\n# substitute these cases with NA\r\nmydatav3$privileges[ mydatav3$privileges == 50 ] <- NA\r\n\r\nwhich( mydata$privileges == 50 ) # two cases of 50\r\nwhich( mydatav3$privileges == 50 ) # no case\r\n\r\n# column names\r\nhead(mydata)\r\nnames(mydata)\r\n# rename "rating" to "score"\r\nnames(mydata)[1] # return the first entry\r\nnames(mydata)[names(mydata) == "rating"] # alternative way to select 1. entry\r\n# rename the first entry\r\nnames(mydata)[1] <- "score"\r\nnames(mydata) # with new names\r\n\r\n\r\n\r\n# ADDITIONAL CODE THAT COULD BE USEFUL TO YOU (not shown in the video)\r\n\r\n# Mean of different variables\r\n# Calculate the mean of several variables in your dataset\r\n# For example the mean of \'complaints\' and \'privileges\'\r\nvariable_names <- c("complaints", "privileges") # store names of variables\r\nMW <- rowSums(mydata[, variable_names]) # compute mean of these two variables for each row and store it in MW\r\nmydata$Mean <- MW # Store the computed mean in mydata as variable ‘Mean’\r\n\r\nhead(mydata) # check the result\r\n\r\n\r\n# Recode reverse-coded variables\r\n# Say the variable \'complaints\' was reverse coded with the highest value of 111\r\n# Recoding works by subtracting the variable from the highest possible value and adding 1\r\n# highest value - variable + 1\r\n\r\ncomplaints_rev <- 111 - mydata$complaints - 1 # Recode complaints and store it in complaints_rev\r\nmydata$complaints_rev <- complaints_rev # store complaints_rev in the data mydata\r\n\r\nhead(mydata) # check the result\r\n```\r\n\r\nA good resource for learning R is the textbook [‘Yarr: The Pirates Guide to R’ by Nathaniel Phillips](https://bookdown.org/ndphillips/YaRrr/).', '', '', '', '', '', None, None, None, None, 'University of Basel', 'University of Basel', 'University of Basel', '', 'TV', '15 min.', 4, 'published', False, None, None, None, None, 22), (77, datetime.datetime(2020, 11, 2, 15, 9, 33, 774510, tzinfo=datetime.timezone.utc), datetime.datetime(2025, 1, 9, 14, 9, 4, 478298, tzinfo=datetime.timezone.utc), datetime.datetime(2025, 1, 9, 14, 9, 4, 404275, tzinfo=datetime.timezone.utc), False, 'Hypothesis tests with R', 'Hypothesis tests with R', 'Hypothesis tests with R', None, '', None, None, None, '', None, None, None, '', 'hypothesis-tests-with-r', 'In this article we show you the commands that you need to carry out various statistical tests within R. \r\n{.lead}\r\n\r\nWe presuppose you know which test(s) you want to run. If you are unsure which test you need for your hypothesis and data, check the [decision tree](https://tales.nmc.unibas.ch/de/conducting-psychological-research-6/statistics-and-analyses-22/which-test-for-which-hypothesis-71) we encountered in a previous chapter.\r\n\r\nIn the example below we start by reading two data sets which we will use to illustrate. Download the [‘diet’ data](https://tales.nmc.unibas.ch/media/conducting-psychological-research/statistics-and-analyses/hypothesis-tests-with-r/diet_data_syzuN9d.csv) and drag it in the folder where you have saved your R script.\r\n\r\nNote: a line beginning with a hashtag (#) indicates a comment in R. This means that it is not carried out as code.\r\n\r\n```R\r\n# Load packages and read in the data\r\nlibrary(MASS)\r\n# If this line throws an error, run the following command once before the library() command: install.packages(“MASS”)\r\n\r\n# Download the diet data from the link in the text above.\r\n# Read data\r\nDiet <- read.csv(file.choose())\r\n\r\n# Alternative way to read the data\r\n# Set the working directory to the folder where the data lies with setwd(“path/to/your/folder”)\r\nDiet <- read.csv("diet_data.csv")\t\t# read “Diet” data\r\n\r\n# Look at the data\r\nhead(Diet)\t\t\t\t\t\t\t\r\n#\tPerson\tgender\tAge\tHeight\tpre.weight\tDiet \tweight6weeks\tHealthStatus\r\n# 1\t25\t\tNA\t\t41\t171\t\t60\t\t\t2\t\t60.0\t\t\tunaffected\r\n# 2\t26\t\tNA\t\t32\t174 \t103\t\t\t2\t\t103.0 \t\tunaffected\r\n# 3\t1\t\t0\t\t22\t159\t\t58\t\t\t1\t\t54.2\t\t\taffected\r\n# ...\r\n\r\n# Load another test data set\r\ndata("survey") # load data (note: this data is part of R, therefore we do not read it from a csv file)\r\nhead(survey)\t # look at the first rows and all variables in “survey”\r\n#\tSex\t\tWr.Hnd\t\tNW.Hnd\t\tW.Hnd\tFold\tPulse\tClap\t\tExer\tSmoke\tHeight\tM.I\t\t\tAge\r\n# 1\tFemale\t18.5\t\t18.0\t\tRight\tR on L\t92\t\tLeft\t\tSome\tNever\t173.00\tMetric\t\t18.250\r\n# 2\tMale\t19.5\t\t20.5\t\tLeft\tR on L\t104\t\tLeft\t\tNone\tRegul\t177.80\tImperial\t17.583\r\n# 3\tMale\t18.0\t\t13.3\t\tRight\tL on R\t87\t\tNeither\t\tNone\tOccas\tNA\t\t<NA>\t\t16.917\r\n# …\r\n```\r\n\r\nThe ‘diet’ data contains data about health and dieting (the data originates from [this website](https://bioinformatics-core-shared-training.github.io/linear-models-r/anova.html)). The ‘survey’ data is a survey about exercise and smoking.\r\n\r\n\r\n**Chi-squared test** \r\nThis example uses the ‘survey’ data to test an association of the two categorical variables ‘smoke’ (smoking measured from never to heavy) and ‘exer’ (exercise frequency measured as none, some or frequently). \r\n\r\nThis is a test against the independence of the variables<sup>1</sup>:\r\n\r\n```R\r\n# Look at the data\r\ntbl <- table(survey$Smoke, survey$Exer) # contingency table\r\ntbl \t\t# view the table\r\n\r\nchisq.test(tbl) # Conduct the Chi-squared test\r\n# output: if significant we reject the null hypothesis that exercise level is independent of smoking habit.\r\n```\r\n\r\n**Correlation analysis** \r\nThe next example uses the ‘diet’ data set, to check if the continuous variables ‘age’ and ‘pre.weight’ (weight before the diet) are correlated.\r\n\r\n```R\r\ncor(Diet$Age, Diet$pre.weight, # specify data set and variables\r\n\tuse="complete.obs", \t# pairwise exclusion of NA values\r\n\tmethod="pearson") \t# specify correlation method\r\n\r\n# Additionally compute a test of the value being zero, testing for significance\r\ncor.test(Diet$Age, Diet$pre.weight, # specify data and variables\r\n\t method = "pearson", \t \t# specify correlation method\r\n\t alternative = "two.sided") \t# directionality\r\n```\r\nNote: other types of correlation are possible (see `?cor`).\r\n\r\n\r\n**Repeated measures ANOVA** \r\nThis example of R code uses the ‘diet’ dataset to check the effect of ‘time’ (pre diet vs. post diet) on the continuous variable ‘weight’ while controlling for the covariates ‘age’ and ‘gender’. Weight is a repeated (within-subject) continuous dependent variable, because every participant reported their weight twice.\r\n\r\n```R\r\n# The data contains two weight columns ‘pre.weight’ and ‘weight6weeks’\r\n# Person\tgender\tAge\tHeight\tpre.weight\tDiet \tweight6weeks\tHealthStatus\r\n# 25\t\tNA\t\t41\t171\t\t60\t\t\t2\t\t60.0\t\t\tunaffected\r\n# 26\t\tNA\t\t32\t174\t\t103\t\t\t2\t\t103.0\t\t\tunaffected\r\n\r\n# We want it to contain one longer ‘Weight’ column and a ‘Time’ column, like this: \r\n# Person\tgender\tAge\tHeight\tDiet\tHealthStatus\tTime\t\t\tWeight\r\n# 25\t\tNA\t\t41\t171\t\t2\t\tunaffected\t\tpre.weight\t\t60\r\n# 26\t\tNA\t\t32\t174\t\t2\t\tunaffected\t\tpre.weight\t\t103\r\n# - … -\r\n# 77\t\t1\t\t40\t167\t\t3\t\tunaffected\t\tweight6weeks\t77.8\r\n# 78\t\t1\t\t51\t175\t\t3\t\tunaffected\t\tweight6weeks\t81.9\r\n\r\nlibrary(tidyr) # If you do not have the package, run install.packages(‘tidyr’)\r\n\r\nDiet_long <- gather(data = Diet,\t\t \t # specify which data to use\r\n\t\t\t\t\tTime, Weight, \t\t # specify names of NEW variables\r\n\t\t\t\t\tPre.weight, weight6weeks) # specify variables combine\r\n\r\nhead(Diet_long)\t\t\t\t \t # Check result \r\n\r\nRun the repeated measures ANOVA\r\nlibrary(nlme) # load the package, if it is missing run install.packages(‘nlme’)\r\nmodel <- lme(Weight ~ Age + gender + Time, # specify DV and fixed effects\r\n\t\t\trandom = ~1|Person, # specify random effects\r\n\t\t\tdata = Diet_long, # specify dataset \r\n\t\t\tcontrol = lmeControl(opt="optim"), \r\n\t\t\tna.action = "na.omit") # what to do in case of NA values\r\n \r\nsummary(model)\t\t\t\t# View full results\r\nanova(model, type = “marginal”)\t\t# Just print the fixed effects\r\n```\r\n\r\n**Between-subjects ANOVA** \r\nThis example uses the ‘survey’ data set to regress the continuous dependent variable ‘pulse’ (pulse of participants) on the categorical independent variable ‘exer’ (exercise level).\r\n\r\n```R\r\nmodel <- aov(Pulse ~ Exer,\t # specify dependent and indep. variables\r\n\t\t\t data = survey)\t # specify data\r\nsummary(model)\t\t\t # show the results\r\n```\r\n\r\nNow, we add age and gender as covariates\r\n\r\n```R\r\nmodel <- aov(Pulse ~ Exer + Age + Sex,\t \t# specify variables and covariates\r\n\t\t\t data = survey)\t \t\t# specify data\r\nsummary(model)\t\t\t\t\t# show the results\r\n```\r\n\r\n**Single-sample t-test** \r\nThis example uses the ‘survey’ data set to test if the continuous variable ‘pulse’ (the pulse of participants) is, on average, equal to 79 with a one-sample t-test.\r\n\r\n```R\r\nmean(survey$Pulse, na.rm = T)\t\t# view the mean (74.15) ignoring NA values\r\n\r\nt.test(survey$Pulse,\t\t\t# your data and the variable\r\n\t mu = 79, \t\t# the value against which to test\r\n\t alternative = "two.sided") \t# directionality\r\n```\r\n\r\n**Paired samples t-test** \r\nThe next example uses the ‘diet’ data set to test if the continuous within-subject (repeated measures) variable ‘weight’ changed before and after a diet.\r\n\r\nFirst, we need to reshape the data a bit to contain a new variable ‘time’ and only one variable ‘weight’ (currently there is not ‘time’ variable and there are two ‘weight’ variables). If your data contains a ‘time’ (or ‘block‘, ‘repetition’, ‘trial’, ...) variable and only one independent variable, skip this lines of code and compute the t-test directly. \r\n\r\nThis is called reshaping from wide to long format:\r\n\r\n```R\r\n# Currently the data has TWO weight-variables (‘pre.weight’ and ‘weight6weeks’)\r\n# Person\tgender\tAge\tHeight\tpre.weight\tDiet\tweight6weeks\tHealthStatus\r\n# 25\t\tNA\t\t41\t171\t\t60\t\t\t2\t\t60.0\t\t\tunaffected\r\n# 26\t\tNA\t\t32\t174\t\t103\t\t\t2\t\t103.0\t\t\tunaffected\r\n\r\n# We want the data to have ONE weight variable and one new TIME variable\r\n# Person\tgender\tAge\tHeight\tDiet\tHealthStatus\tTime\t\t\tWeight\r\n# 25\t \tNA\t\t41\t171\t\t2\t\tunaffected \t\tpre.weight\t\t60\r\n# 26\t \tNA\t\t32\t174\t\t2 \t\tunaffected\t\tpre.weight\t\t103\r\n# - … -\r\n# 155 77\t1\t\t40\t167\t\t3\t\tunaffected\t\tweight6weeks\t77.8\r\n# 156 78\t1\t\t51\t175\t\t3\t\tunaffected\t\tweight6weeks\t81.9\r\n\r\nlibrary(tidyr) # If you do not have the package, run install.packages(‘tidyr’)\r\n# Generate a new dataset ‘Diet_long’\r\nDiet_long <- gather(data = Diet,\t\t\t# specify which data to use\r\n\t\t\t\t\tTime, Weight,\t\t\t# specify names of NEW variables\r\n\t\t\t\t\tpre.weight, weight6weeks) \t# specify the two variables combine\r\nhead(Diet_long)\t\t\t\t\t\t# Check if this was successful\r\n```\r\n\r\nNow we can perform the t-test:\r\n\r\n```R\r\nt.test(Weight ~ Time,\t\t\t# specify dependent var. and time variable\r\n\t data = Diet_long, \t\t\t# specify data to use\r\n\t paired = TRUE,\t\t\t# specify that it is a paired test\r\nalternative = "two.sided") \t# directionality\r\n```\r\n\r\n**Independent samples t-test** \r\nThis example uses the ‘diet’ data set to test if the continuous variable ‘height’ differs between the categorical variable ‘gender’.\r\n\r\n```R\r\nt.test(Height ~ gender,\t\t\t\t# specify the variables\r\n\t data = Diet,\t\t\t\t\t# specify data\r\n\t alternative = "two.sided") \t\t# directionality\r\n```\r\n\r\n**Simple regression** \r\nThe next code uses the ‘diet’ data to regress ‘weight6weeks’ on ‘age’.\r\n\r\n```R\r\nmodel <- lm(weight6weeks ~ Age,\t\t# specify dependent and independent var.\r\n\t\t data = Diet) \t# specify data\r\nsummary(model) # view results\r\n\r\n# Other results\r\ncoefficients(model) \t# parameter estimates\r\nconfint(model, level = 0.95) \t# confidence interval\r\nfitted(model) \t# predicted values\r\nresiduals(model) \t# residuals\r\nanova(model) \t# effect of age on weight at week 6\r\nvcov(model) \t# covariance matrix for model parameters\r\ninfluence(model) \t# regression diagnostics\r\n```\r\n\r\n**Multiple Regression** \r\nThe below example uses the ‘diet’ data to regress three measured variables (age, gender, and height) onto a continuous dependent variable (‘weight6weeks’).\r\n\r\n```R\r\nmodel <- lm(weight6weeks ~ Age + gender + Height, \t# specify variables\r\n\t\t data = Diet) \t\t\t\t# specify data\r\n \r\n# After running the line(s) above, display at the results\r\nsummary(model) \t\t\t# Pr(|z|) is the significance of coefficients\r\ncoefficients(model) \t\t# View the regression coefficients\r\nconfint(model, level = 0.95) \t# view the confidence intervals\r\n\r\n# Predict the values with the model\r\nfitted(model)\t\t# predict the dependent variable values\r\n\r\n# Further analytics of the quality of the regression\r\nresiduals(model)\t# residuals\r\nanova(model)\t\t# ANOVA table, good for tables in a paper\r\nvcov(model)\t\t# variance covariance matrix\r\n```\r\n\r\n**Binomial regression, such as a logistic or probit regression** \r\nThis code uses the ‘diet’ dataset to regress the categorical variable ‘healthstatus’ on age, gender, weights before and after the diet and whether participants participated in a diet. If you are interested in more information on logistic regression, you can find it [here](https://www.r-bloggers.com/how-to-perform-a-logistic-regression-in-r/).\r\n\r\n```R\r\nmodel <- glm(HealthStatus ~ Age + gender + weight6weeks + pre.weight + Diet, # specify the independent an ddependent variables\r\n\t\t\tData = Diet, # specify the data \r\n\t\t\tFamily = binomial(link=\'logit\')) # specify the logistic regression\r\n\r\nsummary(model) # The column Pr(>|z|) # view result\r\n# shows the p-value of the beta weights\r\n\r\n# Compare your model performance vs. a null model (model with only an intercept)\r\nanova(model, test="Chisq") \r\n\r\n# assess the how good the model fit is, using McFadden R \t\r\nlibrary(pscl) # if you do not have the package, run install.packages(“pscl”)\r\npR2(model) \t2\r\nfitted.results <- predict(model, newdata = DF_test, type = "response")\r\nmisClassificationError <- mean(fitted.results != DF_test$Group)\r\nprint(paste(\'Accuracy\',1-misClassificationError))\r\n# Further steps: use ROC (see the above link)\r\n```\r\n\r\n<sup>1</sup> This is an example from [R Tutorial](http://www.r-tutor.com/elementary-statistics/goodness-fit/chi-squared-test-independence), accessed December 6th, 2017.\r\n{.footnote}', 'In this article we show you the commands that you need to carry out various statistical tests within R. \r\n{.lead}\r\n\r\nWe presuppose you know which test(s) you want to run. If you are unsure which test you need for your hypothesis and data, check the [decision tree](https://tales.nmc.unibas.ch/de/conducting-psychological-research-6/statistics-and-analyses-22/which-test-for-which-hypothesis-71) we encountered in a previous chapter.\r\n\r\nIn the example below we start by reading two data sets which we will use to illustrate. Download the [‘diet’ data](https://tales.nmc.unibas.ch/media/conducting-psychological-research/statistics-and-analyses/hypothesis-tests-with-r/diet_data_syzuN9d.csv) and drag it in the folder where you have saved your R script.\r\n\r\nNote: a line beginning with a hashtag (#) indicates a comment in R. This means that it is not carried out as code.\r\n\r\n```R\r\n# Load packages and read in the data\r\nlibrary(MASS)\r\n# If this line throws an error, run the following command once before the library() command: install.packages(“MASS”)\r\n\r\n# Download the diet data from the link in the text above.\r\n# Read data\r\nDiet <- read.csv(file.choose())\r\n\r\n# Alternative way to read the data\r\n# Set the working directory to the folder where the data lies with setwd(“path/to/your/folder”)\r\nDiet <- read.csv("diet_data.csv")\t\t# read “Diet” data\r\n\r\n# Look at the data\r\nhead(Diet)\t\t\t\t\t\t\t\r\n#\tPerson\tgender\tAge\tHeight\tpre.weight\tDiet \tweight6weeks\tHealthStatus\r\n# 1\t25\t\tNA\t\t41\t171\t\t60\t\t\t2\t\t60.0\t\t\tunaffected\r\n# 2\t26\t\tNA\t\t32\t174 \t103\t\t\t2\t\t103.0 \t\tunaffected\r\n# 3\t1\t\t0\t\t22\t159\t\t58\t\t\t1\t\t54.2\t\t\taffected\r\n# ...\r\n\r\n# Load another test data set\r\ndata("survey") # load data (note: this data is part of R, therefore we do not read it from a csv file)\r\nhead(survey)\t # look at the first rows and all variables in “survey”\r\n#\tSex\t\tWr.Hnd\t\tNW.Hnd\t\tW.Hnd\tFold\tPulse\tClap\t\tExer\tSmoke\tHeight\tM.I\t\t\tAge\r\n# 1\tFemale\t18.5\t\t18.0\t\tRight\tR on L\t92\t\tLeft\t\tSome\tNever\t173.00\tMetric\t\t18.250\r\n# 2\tMale\t19.5\t\t20.5\t\tLeft\tR on L\t104\t\tLeft\t\tNone\tRegul\t177.80\tImperial\t17.583\r\n# 3\tMale\t18.0\t\t13.3\t\tRight\tL on R\t87\t\tNeither\t\tNone\tOccas\tNA\t\t<NA>\t\t16.917\r\n# …\r\n```\r\n\r\nThe ‘diet’ data contains data about health and dieting (the data originates from [this website](https://bioinformatics-core-shared-training.github.io/linear-models-r/anova.html)). The ‘survey’ data is a survey about exercise and smoking.\r\n\r\n\r\n**Chi-squared test** \r\nThis example uses the ‘survey’ data to test an association of the two categorical variables ‘smoke’ (smoking measured from never to heavy) and ‘exer’ (exercise frequency measured as none, some or frequently). \r\n\r\nThis is a test against the independence of the variables<sup>1</sup>:\r\n\r\n```R\r\n# Look at the data\r\ntbl <- table(survey$Smoke, survey$Exer) # contingency table\r\ntbl \t\t# view the table\r\n\r\nchisq.test(tbl) # Conduct the Chi-squared test\r\n# output: if significant we reject the null hypothesis that exercise level is independent of smoking habit.\r\n```\r\n\r\n**Correlation analysis** \r\nThe next example uses the ‘diet’ data set, to check if the continuous variables ‘age’ and ‘pre.weight’ (weight before the diet) are correlated.\r\n\r\n```R\r\ncor(Diet$Age, Diet$pre.weight, # specify data set and variables\r\n\tuse="complete.obs", \t# pairwise exclusion of NA values\r\n\tmethod="pearson") \t# specify correlation method\r\n\r\n# Additionally compute a test of the value being zero, testing for significance\r\ncor.test(Diet$Age, Diet$pre.weight, # specify data and variables\r\n\t method = "pearson", \t \t# specify correlation method\r\n\t alternative = "two.sided") \t# directionality\r\n```\r\nNote: other types of correlation are possible (see `?cor`).\r\n\r\n\r\n**Repeated measures ANOVA** \r\nThis example of R code uses the ‘diet’ dataset to check the effect of ‘time’ (pre diet vs. post diet) on the continuous variable ‘weight’ while controlling for the covariates ‘age’ and ‘gender’. Weight is a repeated (within-subject) continuous dependent variable, because every participant reported their weight twice.\r\n\r\n```R\r\n# The data contains two weight columns ‘pre.weight’ and ‘weight6weeks’\r\n# Person\tgender\tAge\tHeight\tpre.weight\tDiet \tweight6weeks\tHealthStatus\r\n# 25\t\tNA\t\t41\t171\t\t60\t\t\t2\t\t60.0\t\t\tunaffected\r\n# 26\t\tNA\t\t32\t174\t\t103\t\t\t2\t\t103.0\t\t\tunaffected\r\n\r\n# We want it to contain one longer ‘Weight’ column and a ‘Time’ column, like this: \r\n# Person\tgender\tAge\tHeight\tDiet\tHealthStatus\tTime\t\t\tWeight\r\n# 25\t\tNA\t\t41\t171\t\t2\t\tunaffected\t\tpre.weight\t\t60\r\n# 26\t\tNA\t\t32\t174\t\t2\t\tunaffected\t\tpre.weight\t\t103\r\n# - … -\r\n# 77\t\t1\t\t40\t167\t\t3\t\tunaffected\t\tweight6weeks\t77.8\r\n# 78\t\t1\t\t51\t175\t\t3\t\tunaffected\t\tweight6weeks\t81.9\r\n\r\nlibrary(tidyr) # If you do not have the package, run install.packages(‘tidyr’)\r\n\r\nDiet_long <- gather(data = Diet,\t\t \t # specify which data to use\r\n\t\t\t\t\tTime, Weight, \t\t # specify names of NEW variables\r\n\t\t\t\t\tPre.weight, weight6weeks) # specify variables combine\r\n\r\nhead(Diet_long)\t\t\t\t \t # Check result \r\n\r\nRun the repeated measures ANOVA\r\nlibrary(nlme) # load the package, if it is missing run install.packages(‘nlme’)\r\nmodel <- lme(Weight ~ Age + gender + Time, # specify DV and fixed effects\r\n\t\t\trandom = ~1|Person, # specify random effects\r\n\t\t\tdata = Diet_long, # specify dataset \r\n\t\t\tcontrol = lmeControl(opt="optim"), \r\n\t\t\tna.action = "na.omit") # what to do in case of NA values\r\n \r\nsummary(model)\t\t\t\t# View full results\r\nanova(model, type = “marginal”)\t\t# Just print the fixed effects\r\n```\r\n\r\n**Between-subjects ANOVA** \r\nThis example uses the ‘survey’ data set to regress the continuous dependent variable ‘pulse’ (pulse of participants) on the categorical independent variable ‘exer’ (exercise level).\r\n\r\n```R\r\nmodel <- aov(Pulse ~ Exer,\t # specify dependent and indep. variables\r\n\t\t\t data = survey)\t # specify data\r\nsummary(model)\t\t\t # show the results\r\n```\r\n\r\nNow, we add age and gender as covariates\r\n\r\n```R\r\nmodel <- aov(Pulse ~ Exer + Age + Sex,\t \t# specify variables and covariates\r\n\t\t\t data = survey)\t \t\t# specify data\r\nsummary(model)\t\t\t\t\t# show the results\r\n```\r\n\r\n**Single-sample t-test** \r\nThis example uses the ‘survey’ data set to test if the continuous variable ‘pulse’ (the pulse of participants) is, on average, equal to 79 with a one-sample t-test.\r\n\r\n```R\r\nmean(survey$Pulse, na.rm = T)\t\t# view the mean (74.15) ignoring NA values\r\n\r\nt.test(survey$Pulse,\t\t\t# your data and the variable\r\n\t mu = 79, \t\t# the value against which to test\r\n\t alternative = "two.sided") \t# directionality\r\n```\r\n\r\n**Paired samples t-test** \r\nThe next example uses the ‘diet’ data set to test if the continuous within-subject (repeated measures) variable ‘weight’ changed before and after a diet.\r\n\r\nFirst, we need to reshape the data a bit to contain a new variable ‘time’ and only one variable ‘weight’ (currently there is not ‘time’ variable and there are two ‘weight’ variables). If your data contains a ‘time’ (or ‘block‘, ‘repetition’, ‘trial’, ...) variable and only one independent variable, skip this lines of code and compute the t-test directly. \r\n\r\nThis is called reshaping from wide to long format:\r\n\r\n```R\r\n# Currently the data has TWO weight-variables (‘pre.weight’ and ‘weight6weeks’)\r\n# Person\tgender\tAge\tHeight\tpre.weight\tDiet\tweight6weeks\tHealthStatus\r\n# 25\t\tNA\t\t41\t171\t\t60\t\t\t2\t\t60.0\t\t\tunaffected\r\n# 26\t\tNA\t\t32\t174\t\t103\t\t\t2\t\t103.0\t\t\tunaffected\r\n\r\n# We want the data to have ONE weight variable and one new TIME variable\r\n# Person\tgender\tAge\tHeight\tDiet\tHealthStatus\tTime\t\t\tWeight\r\n# 25\t \tNA\t\t41\t171\t\t2\t\tunaffected \t\tpre.weight\t\t60\r\n# 26\t \tNA\t\t32\t174\t\t2 \t\tunaffected\t\tpre.weight\t\t103\r\n# - … -\r\n# 155 77\t1\t\t40\t167\t\t3\t\tunaffected\t\tweight6weeks\t77.8\r\n# 156 78\t1\t\t51\t175\t\t3\t\tunaffected\t\tweight6weeks\t81.9\r\n\r\nlibrary(tidyr) # If you do not have the package, run install.packages(‘tidyr’)\r\n# Generate a new dataset ‘Diet_long’\r\nDiet_long <- gather(data = Diet,\t\t\t# specify which data to use\r\n\t\t\t\t\tTime, Weight,\t\t\t# specify names of NEW variables\r\n\t\t\t\t\tpre.weight, weight6weeks) \t# specify the two variables combine\r\nhead(Diet_long)\t\t\t\t\t\t# Check if this was successful\r\n```\r\n\r\nNow we can perform the t-test:\r\n\r\n```R\r\nt.test(Weight ~ Time,\t\t\t# specify dependent var. and time variable\r\n\t data = Diet_long, \t\t\t# specify data to use\r\n\t paired = TRUE,\t\t\t# specify that it is a paired test\r\nalternative = "two.sided") \t# directionality\r\n```\r\n\r\n**Independent samples t-test** \r\nThis example uses the ‘diet’ data set to test if the continuous variable ‘height’ differs between the categorical variable ‘gender’.\r\n\r\n```R\r\nt.test(Height ~ gender,\t\t\t\t# specify the variables\r\n\t data = Diet,\t\t\t\t\t# specify data\r\n\t alternative = "two.sided") \t\t# directionality\r\n```\r\n\r\n**Simple regression** \r\nThe next code uses the ‘diet’ data to regress ‘weight6weeks’ on ‘age’.\r\n\r\n```R\r\nmodel <- lm(weight6weeks ~ Age,\t\t# specify dependent and independent var.\r\n\t\t data = Diet) \t# specify data\r\nsummary(model) # view results\r\n\r\n# Other results\r\ncoefficients(model) \t# parameter estimates\r\nconfint(model, level = 0.95) \t# confidence interval\r\nfitted(model) \t# predicted values\r\nresiduals(model) \t# residuals\r\nanova(model) \t# effect of age on weight at week 6\r\nvcov(model) \t# covariance matrix for model parameters\r\ninfluence(model) \t# regression diagnostics\r\n```\r\n\r\n**Multiple Regression** \r\nThe below example uses the ‘diet’ data to regress three measured variables (age, gender, and height) onto a continuous dependent variable (‘weight6weeks’).\r\n\r\n```R\r\nmodel <- lm(weight6weeks ~ Age + gender + Height, \t# specify variables\r\n\t\t data = Diet) \t\t\t\t# specify data\r\n \r\n# After running the line(s) above, display at the results\r\nsummary(model) \t\t\t# Pr(|z|) is the significance of coefficients\r\ncoefficients(model) \t\t# View the regression coefficients\r\nconfint(model, level = 0.95) \t# view the confidence intervals\r\n\r\n# Predict the values with the model\r\nfitted(model)\t\t# predict the dependent variable values\r\n\r\n# Further analytics of the quality of the regression\r\nresiduals(model)\t# residuals\r\nanova(model)\t\t# ANOVA table, good for tables in a paper\r\nvcov(model)\t\t# variance covariance matrix\r\n```\r\n\r\n**Binomial regression, such as a logistic or probit regression** \r\nThis code uses the ‘diet’ dataset to regress the categorical variable ‘healthstatus’ on age, gender, weights before and after the diet and whether participants participated in a diet. If you are interested in more information on logistic regression, you can find it [here](https://www.r-bloggers.com/how-to-perform-a-logistic-regression-in-r/).\r\n\r\n```R\r\nmodel <- glm(HealthStatus ~ Age + gender + weight6weeks + pre.weight + Diet, # specify the independent an ddependent variables\r\n\t\t\tData = Diet, # specify the data \r\n\t\t\tFamily = binomial(link=\'logit\')) # specify the logistic regression\r\n\r\nsummary(model) # The column Pr(>|z|) # view result\r\n# shows the p-value of the beta weights\r\n\r\n# Compare your model performance vs. a null model (model with only an intercept)\r\nanova(model, test="Chisq") \r\n\r\n# assess the how good the model fit is, using McFadden R \t\r\nlibrary(pscl) # if you do not have the package, run install.packages(“pscl”)\r\npR2(model) \t2\r\nfitted.results <- predict(model, newdata = DF_test, type = "response")\r\nmisClassificationError <- mean(fitted.results != DF_test$Group)\r\nprint(paste(\'Accuracy\',1-misClassificationError))\r\n# Further steps: use ROC (see the above link)\r\n```\r\n\r\n<sup>1</sup> This is an example from [R Tutorial](http://www.r-tutor.com/elementary-statistics/goodness-fit/chi-squared-test-independence), accessed December 6th, 2017.\r\n{.footnote}', 'In this article we show you the commands that you need to carry out various statistical tests within R. \r\n{.lead}\r\n\r\nWe presuppose you know which test(s) you want to run. If you are unsure which test you need for your hypothesis and data, check the [decision tree](https://tales.nmc.unibas.ch/de/conducting-psychological-research-6/statistics-and-analyses-22/which-test-for-which-hypothesis-71) we encountered in a previous chapter.\r\n\r\nIn the example below we start by reading two data sets which we will use to illustrate. Download the [‘diet’ data](https://tales.nmc.unibas.ch/media/conducting-psychological-research/statistics-and-analyses/hypothesis-tests-with-r/diet_data.csv) and drag it in the folder where you have saved your R script.\r\n\r\nNote: a line beginning with a hashtag (#) indicates a comment in R. This means that it is not carried out as code.\r\n\r\n```R\r\n# Load packages and read in the data\r\nlibrary(MASS)\r\n# If this line throws an error, run the following command once before the library() command: install.packages(“MASS”)\r\n\r\n# Download the diet data from the link in the text above.\r\n# Read data\r\nDiet <- read.csv(file.choose())\r\n\r\n# Alternative way to read the data\r\n# Set the working directory to the folder where the data lies with setwd(“path/to/your/folder”)\r\nDiet <- read.csv("diet_data.csv")\t\t# read “Diet” data\r\n\r\n# Look at the data\r\nhead(Diet)\t\t\t\t\t\t\t\r\n#\tPerson\tgender\tAge\tHeight\tpre.weight\tDiet \tweight6weeks\tHealthStatus\r\n# 1\t25\t\tNA\t\t41\t171\t\t60\t\t\t2\t\t60.0\t\t\tunaffected\r\n# 2\t26\t\tNA\t\t32\t174 \t103\t\t\t2\t\t103.0 \t\tunaffected\r\n# 3\t1\t\t0\t\t22\t159\t\t58\t\t\t1\t\t54.2\t\t\taffected\r\n# ...\r\n\r\n# Load another test data set\r\ndata("survey") # load data (note: this data is part of R, therefore we do not read it from a csv file)\r\nhead(survey)\t # look at the first rows and all variables in “survey”\r\n#\tSex\t\tWr.Hnd\t\tNW.Hnd\t\tW.Hnd\tFold\tPulse\tClap\t\tExer\tSmoke\tHeight\tM.I\t\t\tAge\r\n# 1\tFemale\t18.5\t\t18.0\t\tRight\tR on L\t92\t\tLeft\t\tSome\tNever\t173.00\tMetric\t\t18.250\r\n# 2\tMale\t19.5\t\t20.5\t\tLeft\tR on L\t104\t\tLeft\t\tNone\tRegul\t177.80\tImperial\t17.583\r\n# 3\tMale\t18.0\t\t13.3\t\tRight\tL on R\t87\t\tNeither\t\tNone\tOccas\tNA\t\t<NA>\t\t16.917\r\n# …\r\n```\r\n\r\nThe ‘diet’ data contains data about health and dieting (the data originates from [this website](https://bioinformatics-core-shared-training.github.io/linear-models-r/ANOVA.html)). The ‘survey’ data is a survey about exercise and smoking.\r\n\r\n\r\n**Chi-squared test** \r\nThis example uses the ‘survey’ data to test an association of the two categorical variables ‘smoke’ (smoking measured from never to heavy) and ‘exer’ (exercise frequency measured as none, some or frequently). \r\n\r\nThis is a test against the independence of the variables<sup>1</sup>:\r\n\r\n```R\r\n# Look at the data\r\ntbl <- table(survey$Smoke, survey$Exer) # contingency table\r\ntbl \t\t# view the table\r\n\r\nchisq.test(tbl) # Conduct the Chi-squared test\r\n# output: if significant we reject the null hypothesis that exercise level is independent of smoking habit.\r\n```\r\n\r\n**Correlation analysis** \r\nThe next example uses the ‘diet’ data set, to check if the continuous variables ‘age’ and ‘pre.weight’ (weight before the diet) are correlated.\r\n\r\n```R\r\ncor(Diet$Age, Diet$pre.weight, # specify data set and variables\r\n\tuse="complete.obs", \t# pairwise exclusion of NA values\r\n\tmethod="pearson") \t# specify correlation method\r\n\r\n# Additionally compute a test of the value being zero, testing for significance\r\ncor.test(Diet$Age, Diet$pre.weight, # specify data and variables\r\n\t method = "pearson", \t \t# specify correlation method\r\n\t alternative = "two.sided") \t# directionality\r\n```\r\nNote: other types of correlation are possible (see `?cor`).\r\n\r\n\r\n**Repeated measures ANOVA** \r\nThis example of R code uses the ‘diet’ dataset to check the effect of ‘time’ (pre diet vs. post diet) on the continuous variable ‘weight’ while controlling for the covariates ‘age’ and ‘gender’. Weight is a repeated (within-subject) continuous dependent variable, because every participant reported their weight twice.\r\n\r\n```R\r\n# The data contains two weight columns ‘pre.weight’ and ‘weight6weeks’\r\n# Person\tgender\tAge\tHeight\tpre.weight\tDiet \tweight6weeks\tHealthStatus\r\n# 25\t\tNA\t\t41\t171\t\t60\t\t\t2\t\t60.0\t\t\tunaffected\r\n# 26\t\tNA\t\t32\t174\t\t103\t\t\t2\t\t103.0\t\t\tunaffected\r\n\r\n# We want it to contain one longer ‘Weight’ column and a ‘Time’ column, like this: \r\n# Person\tgender\tAge\tHeight\tDiet\tHealthStatus\tTime\t\t\tWeight\r\n# 25\t\tNA\t\t41\t171\t\t2\t\tunaffected\t\tpre.weight\t\t60\r\n# 26\t\tNA\t\t32\t174\t\t2\t\tunaffected\t\tpre.weight\t\t103\r\n# - … -\r\n# 77\t\t1\t\t40\t167\t\t3\t\tunaffected\t\tweight6weeks\t77.8\r\n# 78\t\t1\t\t51\t175\t\t3\t\tunaffected\t\tweight6weeks\t81.9\r\n\r\nlibrary(tidyr) # If you do not have the package, run install.packages(‘tidyr’)\r\n\r\nDiet_long <- gather(data = Diet,\t\t \t # specify which data to use\r\n\t\t\t\t\tTime, Weight, \t\t # specify names of NEW variables\r\n\t\t\t\t\tPre.weight, weight6weeks) # specify variables combine\r\n\r\nhead(Diet_long)\t\t\t\t \t # Check result \r\n\r\nRun the repeated measures ANOVA\r\nlibrary(nlme) # load the package, if it is missing run install.packages(‘nlme’)\r\nmodel <- lme(Weight ~ Age + gender + Time, # specify DV and fixed effects\r\n\t\t\trandom = ~1|Person, # specify random effects\r\n\t\t\tdata = Diet_long, # specify dataset \r\n\t\t\tcontrol = lmeControl(opt="optim"), \r\n\t\t\tna.action = "na.omit") # what to do in case of NA values\r\n \r\nsummary(model)\t\t\t\t# View full results\r\nanova(model, type = “marginal”)\t\t# Just print the fixed effects\r\n```\r\n\r\n**Between-subjects ANOVA** \r\nThis example uses the ‘survey’ data set to regress the continuous dependent variable ‘pulse’ (pulse of participants) on the categorical independent variable ‘exer’ (exercise level).\r\n\r\n```R\r\nmodel <- aov(Pulse ~ Exer,\t # specify dependent and indep. variables\r\n\t\t\t data = survey)\t # specify data\r\nsummary(model)\t\t\t # show the results\r\n```\r\n\r\nNow, we add age and gender as covariates\r\n\r\n```R\r\nmodel <- aov(Pulse ~ Exer + Age + Sex,\t \t# specify variables and covariates\r\n\t\t\t data = survey)\t \t\t# specify data\r\nsummary(model)\t\t\t\t\t# show the results\r\n```\r\n\r\n**Single-sample t-test** \r\nThis example uses the ‘survey’ data set to test if the continuous variable ‘pulse’ (the pulse of participants) is, on average, equal to 79 with a one-sample t-test.\r\n\r\n```R\r\nmean(survey$Pulse, na.rm = T)\t\t# view the mean (74.15) ignoring NA values\r\n\r\nt.test(survey$Pulse,\t\t\t# your data and the variable\r\n\t mu = 79, \t\t# the value against which to test\r\n\t alternative = "two.sided") \t# directionality\r\n```\r\n\r\n**Paired samples t-test** \r\nThe next example uses the ‘diet’ data set to test if the continuous within-subject (repeated measures) variable ‘weight’ changed before and after a diet.\r\n\r\nFirst, we need to reshape the data a bit to contain a new variable ‘time’ and only one variable ‘weight’ (currently there is not ‘time’ variable and there are two ‘weight’ variables). If your data contains a ‘time’ (or ‘block‘, ‘repetition’, ‘trial’, ...) variable and only one independent variable, skip this lines of code and compute the t-test directly. \r\n\r\nThis is called reshaping from wide to long format:\r\n\r\n```R\r\n# Currently the data has TWO weight-variables (‘pre.weight’ and ‘weight6weeks’)\r\n# Person\tgender\tAge\tHeight\tpre.weight\tDiet\tweight6weeks\tHealthStatus\r\n# 25\t\tNA\t\t41\t171\t\t60\t\t\t2\t\t60.0\t\t\tunaffected\r\n# 26\t\tNA\t\t32\t174\t\t103\t\t\t2\t\t103.0\t\t\tunaffected\r\n\r\n# We want the data to have ONE weight variable and one new TIME variable\r\n# Person\tgender\tAge\tHeight\tDiet\tHealthStatus\tTime\t\t\tWeight\r\n# 25\t \tNA\t\t41\t171\t\t2\t\tunaffected \t\tpre.weight\t\t60\r\n# 26\t \tNA\t\t32\t174\t\t2 \t\tunaffected\t\tpre.weight\t\t103\r\n# - … -\r\n# 155 77\t1\t\t40\t167\t\t3\t\tunaffected\t\tweight6weeks\t77.8\r\n# 156 78\t1\t\t51\t175\t\t3\t\tunaffected\t\tweight6weeks\t81.9\r\n\r\nlibrary(tidyr) # If you do not have the package, run install.packages(‘tidyr’)\r\n# Generate a new dataset ‘Diet_long’\r\nDiet_long <- gather(data = Diet,\t\t\t# specify which data to use\r\n\t\t\t\t\tTime, Weight,\t\t\t# specify names of NEW variables\r\n\t\t\t\t\tpre.weight, weight6weeks) \t# specify the two variables combine\r\nhead(Diet_long)\t\t\t\t\t\t# Check if this was successful\r\n```\r\n\r\nNow we can perform the t-test:\r\n\r\n```R\r\nt.test(Weight ~ Time,\t\t\t# specify dependent var. and time variable\r\n\t data = Diet_long, \t\t\t# specify data to use\r\n\t paired = TRUE,\t\t\t# specify that it is a paired test\r\nalternative = "two.sided") \t# directionality\r\n```\r\n\r\n**Independent samples t-test** \r\nThis example uses the ‘diet’ data set to test if the continuous variable ‘height’ differs between the categorical variable ‘gender’.\r\n\r\n```R\r\nt.test(Height ~ gender,\t\t\t\t# specify the variables\r\n\t data = Diet,\t\t\t\t\t# specify data\r\n\t alternative = "two.sided") \t\t# directionality\r\n```\r\n\r\n**Simple regression** \r\nThe next code uses the ‘diet’ data to regress ‘weight6weeks’ on ‘age’.\r\n\r\n```R\r\nmodel <- lm(weight6weeks ~ Age,\t\t# specify dependent and independent var.\r\n\t\t data = Diet) \t# specify data\r\nsummary(model) # view results\r\n\r\n# Other results\r\ncoefficients(model) \t# parameter estimates\r\nconfint(model, level = 0.95) \t# confidence interval\r\nfitted(model) \t# predicted values\r\nresiduals(model) \t# residuals\r\nanova(model) \t# effect of age on weight at week 6\r\nvcov(model) \t# covariance matrix for model parameters\r\ninfluence(model) \t# regression diagnostics\r\n```\r\n\r\n**Multiple Regression** \r\nThe below example uses the ‘diet’ data to regress three measured variables (age, gender, and height) onto a continuous dependent variable (‘weight6weeks’).\r\n\r\n```R\r\nmodel <- lm(weight6weeks ~ Age + gender + Height, \t# specify variables\r\n\t\t data = Diet) \t\t\t\t# specify data\r\n \r\n# After running the line(s) above, display at the results\r\nsummary(model) \t\t\t# Pr(|z|) is the significance of coefficients\r\ncoefficients(model) \t\t# View the regression coefficients\r\nconfint(model, level = 0.95) \t# view the confidence intervals\r\n\r\n# Predict the values with the model\r\nfitted(model)\t\t# predict the dependent variable values\r\n\r\n# Further analytics of the quality of the regression\r\nresiduals(model)\t# residuals\r\nanova(model)\t\t# ANOVA table, good for tables in a paper\r\nvcov(model)\t\t# variance covariance matrix\r\n```\r\n\r\n**Binomial regression, such as a logistic or probit regression** \r\nThis code uses the ‘diet’ dataset to regress the categorical variable ‘healthstatus’ on age, gender, weights before and after the diet and whether participants participated in a diet. If you are interested in more information on logistic regression, you can find it [here](https://www.r-bloggers.com/how-to-perform-a-logistic-regression-in-r/).\r\n\r\n```R\r\nmodel <- glm(HealthStatus ~ Age + gender + weight6weeks + pre.weight + Diet, # specify the independent an ddependent variables\r\n\t\t\tData = Diet, # specify the data \r\n\t\t\tFamily = binomial(link=\'logit\')) # specify the logistic regression\r\n\r\nsummary(model) # The column Pr(>|z|) # view result\r\n# shows the p-value of the beta weights\r\n\r\n# Compare your model performance vs. a null model (model with only an intercept)\r\nanova(model, test="Chisq") \r\n\r\n# assess the how good the model fit is, using McFadden R \t\r\nlibrary(pscl) # if you do not have the package, run install.packages(“pscl”)\r\npR2(model) \t2\r\nfitted.results <- predict(model, newdata = DF_test, type = "response")\r\nmisClassificationError <- mean(fitted.results != DF_test$Group)\r\nprint(paste(\'Accuracy\',1-misClassificationError))\r\n# Further steps: use ROC (see the above link)\r\n```\r\n\r\n<sup>1</sup> This is an example from [R Tutorial](http://www.r-tutor.com/elementary-statistics/goodness-fit/chi-squared-test-independence), accessed December 6th, 2017.\r\n{.footnote}', '', '', '', '', '', None, None, None, None, '', '', '', '', 'TT', '30 min.', 5, 'published', False, None, None, None, None, 22), (78, datetime.datetime(2020, 11, 2, 15, 9, 33, 774510, tzinfo=datetime.timezone.utc), datetime.datetime(2020, 11, 2, 15, 9, 37, 390920, tzinfo=datetime.timezone.utc), datetime.datetime(2020, 11, 2, 15, 9, 37, 390931, tzinfo=datetime.timezone.utc), False, 'Graphics with R', 'Graphics with R', 'Graphics with R', None, '', None, None, None, '', None, None, None, '', 'graphics-with-r', 'In this article we introduce you to plotting with R. It is always a good idea to first look at your data before you run statistical tests. Keep in mind, that using graphs, charts and images help your audience to understand the data more quickly. \r\n{.lead}\r\n\r\nThis is a brief illustration of the types of plots you can use for different experimental designs: \r\n![Illustration of different plot types](/media/tales/markdownx/2b471a9b-c60e-4cf1-9c7d-6e01aaa635f0.png)\r\n\r\nThe following examples show your R code for different types of plots.\r\n\r\nWe use a package called ggplot, which you need to install once and then you can load it every time you need to use it:\r\n\r\n```R\r\ninstall.packages("ggplot2") #run this only ONE TIME then comment it out (it\'s like installing a program)\r\nlibrary(ggplot2) #run this every time, it\'s like opening a program\r\ntheme_set(theme_classic()) # This comment defines a background \r\n# You can check out all themes here http://ggplot2.tidyverse.org/reference/ggtheme.html\r\n```\r\n\r\nTo test the plots, download our [test data](https://tales.nmc.unibas.ch/media/tales/conducting-psychological-research/statistics-and-analyses/graphics-with-r/test_data.csv) and save it into the folder where you saved your R script.\r\n\r\n```R\r\n# Read the testdata and name it mydata\r\nmydata <- read.csv(file.chose())\r\n\r\n# Alternative way to read data:\r\n# set the working directory to the folder where the test data is stored\r\nsetwd(“.../your path/your folder”) # See tutorial ‘Read data with R’\r\n# Alternatively, save data and Rcode in the same folder and use Session > Set Working Directory > To Source File Location\r\n# Read the testdata and name it "mydata"\r\nmydata <- read.csv("test_data.csv")\r\n\r\n # Look at the variables and values in the first rows\r\nhead(mydata) # look at the variables and values in the first rows\r\nsubj_ID\tcondition_AB\tcondition_B\tcondition_3\tage\t\tgender\tdegree\t\tincome\trating\tchoice\r\nabcz\t\tcond A\t\tstrong\t\t7.14\t\t23 \t\tfemale\tBachelor\t867\t\t5.9\t\tOption X\r\nicoa\t\tcond B\t\tstrong\t \t4.78\t\t28 \t\tfemale\tMaster\t\t900\t\t8.26\tOption X\r\naetr\t\tcond A\t\tstrong\t \t4.89\t\t22 \tmale \tBachelor \t393 \t10.62 \tOption X\r\nhefb\t\tcond B\t\tmedium\t \t2.96\t\t25 \tfemale \tBachelor \t890 \t-9.06 \tOption Y\r\nbdza\t\tcond A\t\tstrong\t \t4.03\t\t-99\t\tmale \tBachelor \t900 \t6.89 \tOption X\r\nntqb\t\tcond B\t\tmedium\t \t5.18\t\t33 \tfemale \tMaster \t\t900 \t7.05\tOption X\r\n\r\n# Clean the data\r\nmydata$age[mydata$age < 0 | mydata$age > 80] <- NA\r\n```\r\n\r\n**1. No real DVs/IVs, plot two variables** \r\nThink of measured continuous variables; for example, the IQ, age, or income of the participants.\r\n\r\nYou can plot one of the variables, say age, as histogram:\r\n\r\n```R\r\n# This plots a histogram of one continuous variable\r\nggplot(data = mydata, \t\t# data = ... specifies how your data is called (‘mydata’)\r\n\t aes(x = age)) + \t# aes(x = …) specifies variable on x-axis (‘age’)\r\n\t geom_histogram() \t# + geom_histogramm() specifies that we want a histogram\r\n```\r\n\r\n![histogram](/media/tales/markdownx/7522e3e7-f220-45d8-b445-b001d285d3a1.png)\r\n\r\nYou can plot two measured continuous variables:\r\n\r\n```R\r\n# This generates a point plot of two continuous variables\r\nggplot(data = mydata, \t\t# (unchanged)\r\n\t aes(x = age, y = income)) + \t# NEW: y = … specifies a y-variable (‘income’)\r\n\t geom_point() \t\t# NEW: +geom_point() means now we want points\r\n```\r\n\r\n![point plot](/media/tales/markdownx/f4624fb3-e835-423d-9677-18df69eaaf2c.png)\r\n\r\nNext, think of your **measured categorical variables**, like gender, educational degree, or occupation, etc. You can plot how many participants fall into each combination of the gender-degree-combinations:\r\n\r\n```R\r\n# Plot two categorical variables as colour-filled bars\r\nggplot(data = mydata, \t\t\t\t# (unchanged)\r\n\t aes(x = gender, fill = degree)) + \t# NEW: new x-variable and fill-with-variable\r\n\t geom_bar() \t\t\t\t# NEW: we want bars\r\n# Note that the y-variable is not specified. It is automatically computed by counting how many rows in your data fall into each gender-degree category. It also works of there are more than two categories.\r\n```\r\n\r\n![colour-filled bar](/media/tales/markdownx/3a79e4a4-361b-446c-8fff-4ff0ace3b1db.png)\r\n\r\n```R\r\n# Change the colours\r\nggplot(data = mydata, \t \t# (unchanged)\r\n\t aes(x = gender, fill = degree)) + \t# (unchanged)\r\n\t geom_bar() + \t \t# (unchanged)\r\n\t scale_fill_manual( \t \t# NEW: scale_fill_manual() adds ourfilling colors\r\n\t \t values = c("orange", "grey")) # define the color values\r\n```\r\n\r\n![other colours](/media/tales/markdownx/5f5503e1-bd30-49e6-905c-89bb41a647e6.png)\r\n\r\nYou can find a list of more colour names [here](http://sape.inf.usi.ch/quick-reference/ggplot2/colour).\r\n\r\n**2. Continuous Dependent Variables and Categorical Independent variable** \r\nNext, think of an experimental design with a continuous dependent variable and experimental conditions, for example condition ‘A’ and ‘B’. Think of something like a 1 x 2 factorial between-subject design. To show if your continuous dependent variable changes given the levels of your categorical independent variable, you can use a side-by-side boxplot like this:\r\n\r\n```R\r\n# This plots boxplots of a continuous variable given a categorical variable\r\nggplot(data = mydata, \t\t # (unchanged)\r\n\t aes(x = condition_AB, y = rating)) + # NEW: new x- and y-variables\r\n\t geom_boxplot() \t # NEW: now we plot a boxplot\r\n```\r\n\r\n![boxplot](/media/tales/markdownx/2c3d4e83-d71c-4e13-977a-9af734189305.png)\r\n\r\nNote: this will also work if your categorical independent variable has more than two levels\r\n\r\n```R\r\n# Same data but only the mean values shown as bars\r\nggplot(data = mydata, \t # (unchanged)\r\n\t aes(x = condition_AB, y = rating)) + # (unchanged)\r\n\t geom_bar( # NEW: now we want to plot bars\r\n \t \t fun.y = mean, stat = "summary") # specify that top of bar = mean of y\r\n```\r\n\r\n![bars](/media/tales/markdownx/6cce9bb9-e303-456e-be23-e7763f01eb07.png)\r\n\r\n```R\r\n# Same data as points with error bars representing standard deviation (SD)\r\nggplot(data = mydata, \t\t# (unchanged)\r\n\t aes(x = condition_AB, y = rating)) + # (unchanged)\r\n\t geom_point( \t# NEW: now we to add points\r\n \t \t fun.y = mean, stat = "summary") +\t# (unchanged)\r\n\t geom_errorbar( # NEW: we want to add error bars\r\n \t \t fun.ymin = function(z) mean(z)-sd(z), # define minimum of error bar\r\n \t \t fun.ymax = function(z) mean(z)+sd(z), # define maximum of error bar\r\n \t \t stat = "summary",\r\n \t \t width = .1) \t# makes it prettier\r\n```\r\n\r\n![error bars](/media/tales/markdownx/f0c7451e-6cb4-45ff-afe2-c722f4cf130c.png)\r\n\r\nYou can use the command ‘geom_errorbar(...)’ also for the bar plot shown above to add error bars to a bar plot. Try to copy all lines of the command ‘geom_errorbar(...)’ from the point plot, and add them with a ‘+’ to the barplot above.\r\n\r\n```R\r\n# Let’s go back to boxplots. Add the raw data in the background\r\nggplot(data = mydata, \t\t # (unchanged)\r\n\t aes(x = condition_AB, y = rating)) + # (unchanged)\r\n\t geom_boxplot() + \t # NEW: we want the boxplot again\r\n\t geom_jitter() # NEW: we want to add jittered points\r\n```\r\n\r\n![boxplot raw data](/media/tales/markdownx/9490148a-e7c8-47f9-8d75-ca2441136ea3.png)\r\n\r\n```R\r\n# Color the the raw data\r\nggplot(data = mydata, \t\t # (unchanged)\r\n\t aes(x = condition_AB, y = rating)) + # (unchanged)\r\n\t geom_boxplot() + \t # (unchanged\r\n\t geom_jitter( \t # (unchanged)\r\n \t \t aes(color = condition_AB)) + # NEW: specify color represents condition_AB\r\n\t scale_colour_manual( \t# NEW: define the colour values\r\n \t \t values = c("orange", "grey"))\r\n```\r\n\r\n![Color raw data](/media/tales/markdownx/db1daf57-8497-4b06-9e3f-0d383bc07992.png)\r\n\r\nIf your categorical independent variable has more levels, that’s no problem at all. All you need to change is to add more manual color values:\r\n\r\n```R\r\n# The categorical independent variable ‘conditon_LMS’ has three levels\r\nggplot(data = mydata,\r\n\t aes(x = condition_LMS, y = rating)) +\t# NEW: new x-variable with 3 levels\r\n\t geom_boxplot() +\t\t\t# (unchanged)\r\n\t geom_jitter(\r\n\t \t aes(color=condition_LMS)) +\t\t# NEW: new color-variable\r\n\t scale_color_manual(\r\n\t \t values = c("orange", "grey", "blue"))\t# NEW: three colors\t\r\n```\r\n\r\n![three levels](/media/tales/markdownx/7ffe8a9e-696f-4f0b-84d6-d057e2de9c9b.png)\r\n\r\nNext, think of a situation where you have two categorical independent variables, like one condition called ‘A’ vs. ‘B’, and another condition with for example time pressure ‘low’, ‘medium’, or ‘strong’. Think of a 2 x 3 factorial design. To display if a continuous dependent variable changes given the six different combinations of the conditions, you can use a side-by-side boxplot with different colors for the other condition, like this:\r\n\r\n```R\r\n# This plots boxplots for each value combination of two categorical variables\r\nggplot(data = mydata,\r\n\t aes(x = condition_LMS, # NEW: categorical x-variable\r\n\t \t y = rating,\t\t # (unchanged y variable)\r\n\t \t fill = condition_AB)) +\t# NEW: second categorical fill-variable\r\n\t geom_boxplot() +\r\n\t scale_fill_manual(\t\t\t# (unchanged)\r\n\t \t values = c("orange", "grey"))\r\n```\r\n\r\n![boxplot each value combination](/media/tales/markdownx/97c523df-d4da-43d2-987e-e42cf9bd0e1e.png)\r\n\r\n```R\r\n# Same data as bar plots with the mean of the y-values as height of bars\r\nggplot(data = mydata, # (unchanged)\r\n\t aes(x = condition_LMS,\t # (unchanged)\r\n\t \t y = rating,\t\t # (unchanged)\r\n\t \t fill = condition_AB)) + # (unchanged)\r\n\t geom_bar(\t\t\t\t# NEW: now we plot bars\r\n\t \t fun.y = mean, stat = "summary", # NEW: end of the bar = mean y values\r\n\t \t pos = "dodge") + # NEW: put bars side-by-side\r\n\t scale_fill_manual(\t\t\t\t# (unchanged)\r\n\t \t values = c("orange", "grey"))\r\n```\r\n\r\n![bar plots](/media/tales/markdownx/0b26accd-2100-47fb-ba56-70beb5016343.png)\r\n\r\n```R\r\n# Same bar plot with error bars\r\npos_dod <- position_dodge(width = .9) # NEW: to position the bars correctly\r\nggplot(data = mydata, \t # (unchanged)\r\n \t aes(x = condition_LMS, \t # (unchanged)\r\n\t \t y = rating, \t # (unchanged)\r\n\t \t fill = condition_AB)) + # (unchanged)\r\n\t geom_bar( # (unchanged)\r\n\t \t fun.y = mean, stat = "summary", # (unchanged)\r\n\t \t pos = "dodge") + # (unchanged)\r\n\t scale_fill_manual( # (unchanged)\r\n\t \t values = c("orange", "grey")) +\r\n\t geom_errorbar(\t\t\t\t\t#NEW: add error bars\r\n\t \t fun.ymin = function(z) mean(z)-sd(z),\t# define minimum of bar\r\n\t \t fun.ymax = function(z) mean(z)+sd(z),\t# define maximum of bar\r\n\t \t stat = "summary",\t\t\t\t# plot the summary\r\n\t \t width = .2,\t\t\t\t\t# make ends of bars smaller\r\n\t \t pos = pos_dod)\t\t\t\t\t# correct position of bars\r\n```\r\n\r\n![error bars](/media/tales/markdownx/a161dd45-ba95-4b2e-ad87-4d2abe635354.png)\r\n\r\n**3. Continuous dependent variable and continuous independent variable** \r\nThink of a correlational design where you have manipulated e.g. stress level of participants and you measure some rating, both the dependent and independent variable are on a continuous scale. You can do a simple regression or correlation plot.\r\n\r\n```R\r\n# Plot two continuous variables and a correlation/regression line\r\nggplot(data = mydata, \t \r\n\t aes(x = condition_3, y = rating)) + # NEW: continuous x- and y-variables\r\n\t geom_point() + \t\t\t # NEW: we want points \t \r\n\t geom_smooth(method = "lm") # NEW: we want a line\r\n# “lm” means “linear model” since the correlation line is a linear line\r\n# The grey area is the 95% confidence level interval for predictions from a linear model \r\n```\r\n\r\n![regression line](/media/tales/markdownx/69cb1800-946d-467d-902b-46d605d7d093.png)\r\n\r\n```R\r\n# Change the color of the line\r\nggplot(data = mydata, \t \t\t\t# (unchanged)\r\n\t aes(x = condition_3, y = rating)) + \t# (unchanged)\r\n\t geom_point() + \t \t\t# (unchanged)\r\n\t geom_smooth(method = "lm",\t\t\t\t# (unchanged)\r\n\t \t color = "springgreen") # NEW: define color\r\n```\r\n\r\n![Color of line](/media/tales/markdownx/11f1bf4a-609d-434f-91b4-4510d09c07a5.png)\r\n\r\nSuppose your experiment contains one continuous independent variable and one categorical independent variable (and a continuous dependent variable). To see if the relationship between the continuous variables changes for the levels of the categorical variable, you can plot two side-by-side correlation lines like this:\r\n\r\n```R\r\n# Mixed design: continuous and categorical independent variables\r\nggplot(data = mydata, \t \r\n\taes(x = condition_3, y = rating)) + # (unchanged)\r\n\tgeom_point() + \t # (unchanged)\r\n\tgeom_smooth(method = "lm") + # (unchanged)\r\n\tfacet_wrap(~condition_AB) \t # NEW: add the categorical variable\r\n```\r\n\r\n\r\n![mixed design](/media/tales/markdownx/4c6b9e36-cd17-4940-9c1a-9d7c71a597e2.png)\r\n\r\nThis will also work if your categorical variable has more than two levels.\r\n\r\nFinally, let’s consider a design with a categorical dependent variable and a continuous independent variable. If the categorical dependent variable has only two levels (think of ‘Option A’ and ‘Option B’), then you can plot a logistic regression line as follows:\r\n\r\n```R\r\n# Categorical dependent variable with two levels\r\n# transform categorical variable to have numeric values 0 and 1\r\nmydata$choice.numeric <- as.numeric(mydata$choice) - 1\r\n# Make the plot\r\nggplot(data = mydata, \t \t\t\t\t# (unchaned)\r\n\t aes(x = condition_3, y = choice.numeric)) + \t# NEW: new y-variable\r\n\t geom_point() + \t \t\t\t# (unchanged)\r\n\t geom_smooth(method = "glm",\t\t\t\t# NEW: “glm”\r\n\t \t method.args = list(family = "binomial")) \t\t# NEW: plots a logistic regression line\r\n```\r\n\r\n![logistic regression line](/media/tales/markdownx/344032ca-08b1-4227-8671-cc1e1428c37e.png)\r\n\r\n**4. Saving your plots** \r\nSaving plots is super easy. After you have generated the plot, you use the command:\r\n\r\n```R\r\n# Save the last plot you generated\r\nggsave(“filename_of_plot.png”)\r\n```\r\n\r\nThen your plot will be saved as PNG file with the name filename_of_plot. The file will be saved in the same location where your R code is. If you want to save the plot to a different location simply type your personal path to the folder, which should look similar but different from this:\r\n```R\r\n# Add a longer file path if you want to save to a different location\r\nggsave(“C:/Users/.../Folder/Folder/filename_of_plot.png”)\r\n# If you need a JPG or TIFF file, just type:\r\nggsave(“filename_of_plot.jpg”)\r\nggsave(“filename_of_plot.tiff”)\r\n# If you want a different size use\r\nggsave(“filename_of_plot.png”, width = 8, height =5)\r\n# If you want the font to be bigger, use ‘scale = …’\r\nggsave(“filename_of_plot.png”, scale = 0.8)\r\n```', 'In this article we introduce you to plotting with R. It is always a good idea to first look at your data before you run statistical tests. Keep in mind, that using graphs, charts and images help your audience to understand the data more quickly. \r\n{.lead}\r\n\r\nThis is a brief illustration of the types of plots you can use for different experimental designs: \r\n![Illustration of different plot types](/media/markdownx/2b471a9b-c60e-4cf1-9c7d-6e01aaa635f0.png)\r\n\r\nThe following examples show your R code for different types of plots.\r\n\r\nWe use a package called ggplot, which you need to install once and then you can load it every time you need to use it:\r\n\r\n```R\r\ninstall.packages("ggplot2") #run this only ONE TIME then comment it out (it\'s like installing a program)\r\nlibrary(ggplot2) #run this every time, it\'s like opening a program\r\ntheme_set(theme_classic()) # This comment defines a background \r\n# You can check out all themes here http://ggplot2.tidyverse.org/reference/ggtheme.html\r\n```\r\n\r\nTo test the plots, download our [test data](https://tales.nmc.unibas.ch/media/conducting-psychological-research/statistics-and-analyses/graphics-with-r/test_data.csv) and save it into the folder where you saved your R script.\r\n\r\n```R\r\n# Read the testdata and name it mydata\r\nmydata <- read.csv(file.chose())\r\n\r\n# Alternative way to read data:\r\n# set the working directory to the folder where the test data is stored\r\nsetwd(“.../your path/your folder”) # See tutorial ‘Read data with R’\r\n# Alternatively, save data and Rcode in the same folder and use Session > Set Working Directory > To Source File Location\r\n# Read the testdata and name it "mydata"\r\nmydata <- read.csv("test_data.csv")\r\n\r\n # Look at the variables and values in the first rows\r\nhead(mydata) # look at the variables and values in the first rows\r\nsubj_ID\tcondition_AB\tcondition_B\tcondition_3\tage\t\tgender\tdegree\t\tincome\trating\tchoice\r\nabcz\t\tcond A\t\tstrong\t\t7.14\t\t23 \t\tfemale\tBachelor\t867\t\t5.9\t\tOption X\r\nicoa\t\tcond B\t\tstrong\t \t4.78\t\t28 \t\tfemale\tMaster\t\t900\t\t8.26\tOption X\r\naetr\t\tcond A\t\tstrong\t \t4.89\t\t22 \tmale \tBachelor \t393 \t10.62 \tOption X\r\nhefb\t\tcond B\t\tmedium\t \t2.96\t\t25 \tfemale \tBachelor \t890 \t-9.06 \tOption Y\r\nbdza\t\tcond A\t\tstrong\t \t4.03\t\t-99\t\tmale \tBachelor \t900 \t6.89 \tOption X\r\nntqb\t\tcond B\t\tmedium\t \t5.18\t\t33 \tfemale \tMaster \t\t900 \t7.05\tOption X\r\n\r\n# Clean the data\r\nmydata$age[mydata$age < 0 | mydata$age > 80] <- NA\r\n```\r\n\r\n**1. No real DVs/IVs, plot two variables** \r\nThink of measured continuous variables; for example, the IQ, age, or income of the participants.\r\n\r\nYou can plot one of the variables, say age, as histogram:\r\n\r\n```R\r\n# This plots a histogram of one continuous variable\r\nggplot(data = mydata, \t\t# data = ... specifies how your data is called (‘mydata’)\r\n\t aes(x = age)) + \t# aes(x = …) specifies variable on x-axis (‘age’)\r\n\t geom_histogram() \t# + geom_histogramm() specifies that we want a histogram\r\n```\r\n\r\n![histogram](/media/markdownx/7522e3e7-f220-45d8-b445-b001d285d3a1.png)\r\n\r\nYou can plot two measured continuous variables:\r\n\r\n```R\r\n# This generates a point plot of two continuous variables\r\nggplot(data = mydata, \t\t# (unchanged)\r\n\t aes(x = age, y = income)) + \t# NEW: y = … specifies a y-variable (‘income’)\r\n\t geom_point() \t\t# NEW: +geom_point() means now we want points\r\n```\r\n\r\n![point plot](/media/markdownx/f4624fb3-e835-423d-9677-18df69eaaf2c.png)\r\n\r\nNext, think of your **measured categorical variables**, like gender, educational degree, or occupation, etc. You can plot how many participants fall into each combination of the gender-degree-combinations:\r\n\r\n```R\r\n# Plot two categorical variables as colour-filled bars\r\nggplot(data = mydata, \t\t\t\t# (unchanged)\r\n\t aes(x = gender, fill = degree)) + \t# NEW: new x-variable and fill-with-variable\r\n\t geom_bar() \t\t\t\t# NEW: we want bars\r\n# Note that the y-variable is not specified. It is automatically computed by counting how many rows in your data fall into each gender-degree category. It also works of there are more than two categories.\r\n```\r\n\r\n![colour-filled bar](/media/markdownx/3a79e4a4-361b-446c-8fff-4ff0ace3b1db.png)\r\n\r\n```R\r\n# Change the colours\r\nggplot(data = mydata, \t \t# (unchanged)\r\n\t aes(x = gender, fill = degree)) + \t# (unchanged)\r\n\t geom_bar() + \t \t# (unchanged)\r\n\t scale_fill_manual( \t \t# NEW: scale_fill_manual() adds ourfilling colors\r\n\t \t values = c("orange", "grey")) # define the color values\r\n```\r\n\r\n![other colours](/media/markdownx/5f5503e1-bd30-49e6-905c-89bb41a647e6.png)\r\n\r\nYou can find a list of more colour names [here](http://sape.inf.usi.ch/quick-reference/ggplot2/colour).\r\n\r\n**2. Continuous Dependent Variables and Categorical Independent variable** \r\nNext, think of an experimental design with a continuous dependent variable and experimental conditions, for example condition ‘A’ and ‘B’. Think of something like a 1 x 2 factorial between-subject design. To show if your continuous dependent variable changes given the levels of your categorical independent variable, you can use a side-by-side boxplot like this:\r\n\r\n```R\r\n# This plots boxplots of a continuous variable given a categorical variable\r\nggplot(data = mydata, \t\t # (unchanged)\r\n\t aes(x = condition_AB, y = rating)) + # NEW: new x- and y-variables\r\n\t geom_boxplot() \t # NEW: now we plot a boxplot\r\n```\r\n\r\n![boxplot](/media/markdownx/2c3d4e83-d71c-4e13-977a-9af734189305.png)\r\n\r\nNote: this will also work if your categorical independent variable has more than two levels\r\n\r\n```R\r\n# Same data but only the mean values shown as bars\r\nggplot(data = mydata, \t # (unchanged)\r\n\t aes(x = condition_AB, y = rating)) + # (unchanged)\r\n\t geom_bar( # NEW: now we want to plot bars\r\n \t \t fun.y = mean, stat = "summary") # specify that top of bar = mean of y\r\n```\r\n\r\n![bars](/media/markdownx/6cce9bb9-e303-456e-be23-e7763f01eb07.png)\r\n\r\n```R\r\n# Same data as points with error bars representing standard deviation (SD)\r\nggplot(data = mydata, \t\t# (unchanged)\r\n\t aes(x = condition_AB, y = rating)) + # (unchanged)\r\n\t geom_point( \t# NEW: now we to add points\r\n \t \t fun.y = mean, stat = "summary") +\t# (unchanged)\r\n\t geom_errorbar( # NEW: we want to add error bars\r\n \t \t fun.ymin = function(z) mean(z)-sd(z), # define minimum of error bar\r\n \t \t fun.ymax = function(z) mean(z)+sd(z), # define maximum of error bar\r\n \t \t stat = "summary",\r\n \t \t width = .1) \t# makes it prettier\r\n```\r\n\r\n![error bars](/media/markdownx/f0c7451e-6cb4-45ff-afe2-c722f4cf130c.png)\r\n\r\nYou can use the command ‘geom_errorbar(...)’ also for the bar plot shown above to add error bars to a bar plot. Try to copy all lines of the command ‘geom_errorbar(...)’ from the point plot, and add them with a ‘+’ to the barplot above.\r\n\r\n```R\r\n# Let’s go back to boxplots. Add the raw data in the background\r\nggplot(data = mydata, \t\t # (unchanged)\r\n\t aes(x = condition_AB, y = rating)) + # (unchanged)\r\n\t geom_boxplot() + \t # NEW: we want the boxplot again\r\n\t geom_jitter() # NEW: we want to add jittered points\r\n```\r\n\r\n![boxplot raw data](/media/markdownx/9490148a-e7c8-47f9-8d75-ca2441136ea3.png)\r\n\r\n```R\r\n# Color the the raw data\r\nggplot(data = mydata, \t\t # (unchanged)\r\n\t aes(x = condition_AB, y = rating)) + # (unchanged)\r\n\t geom_boxplot() + \t # (unchanged\r\n\t geom_jitter( \t # (unchanged)\r\n \t \t aes(color = condition_AB)) + # NEW: specify color represents condition_AB\r\n\t scale_colour_manual( \t# NEW: define the colour values\r\n \t \t values = c("orange", "grey"))\r\n```\r\n\r\n![Color raw data](/media/markdownx/db1daf57-8497-4b06-9e3f-0d383bc07992.png)\r\n\r\nIf your categorical independent variable has more levels, that’s no problem at all. All you need to change is to add more manual color values:\r\n\r\n```R\r\n# The categorical independent variable ‘conditon_LMS’ has three levels\r\nggplot(data = mydata,\r\n\t aes(x = condition_LMS, y = rating)) +\t# NEW: new x-variable with 3 levels\r\n\t geom_boxplot() +\t\t\t# (unchanged)\r\n\t geom_jitter(\r\n\t \t aes(color=condition_LMS)) +\t\t# NEW: new color-variable\r\n\t scale_color_manual(\r\n\t \t values = c("orange", "grey", "blue"))\t# NEW: three colors\t\r\n```\r\n\r\n![three levels](/media/markdownx/7ffe8a9e-696f-4f0b-84d6-d057e2de9c9b.png)\r\n\r\nNext, think of a situation where you have two categorical independent variables, like one condition called ‘A’ vs. ‘B’, and another condition with for example time pressure ‘low’, ‘medium’, or ‘strong’. Think of a 2 x 3 factorial design. To display if a continuous dependent variable changes given the six different combinations of the conditions, you can use a side-by-side boxplot with different colors for the other condition, like this:\r\n\r\n```R\r\n# This plots boxplots for each value combination of two categorical variables\r\nggplot(data = mydata,\r\n\t aes(x = condition_LMS, # NEW: categorical x-variable\r\n\t \t y = rating,\t\t # (unchanged y variable)\r\n\t \t fill = condition_AB)) +\t# NEW: second categorical fill-variable\r\n\t geom_boxplot() +\r\n\t scale_fill_manual(\t\t\t# (unchanged)\r\n\t \t values = c("orange", "grey"))\r\n```\r\n\r\n![boxplot each value combination](/media/markdownx/97c523df-d4da-43d2-987e-e42cf9bd0e1e.png)\r\n\r\n```R\r\n# Same data as bar plots with the mean of the y-values as height of bars\r\nggplot(data = mydata, # (unchanged)\r\n\t aes(x = condition_LMS,\t # (unchanged)\r\n\t \t y = rating,\t\t # (unchanged)\r\n\t \t fill = condition_AB)) + # (unchanged)\r\n\t geom_bar(\t\t\t\t# NEW: now we plot bars\r\n\t \t fun.y = mean, stat = "summary", # NEW: end of the bar = mean y values\r\n\t \t pos = "dodge") + # NEW: put bars side-by-side\r\n\t scale_fill_manual(\t\t\t\t# (unchanged)\r\n\t \t values = c("orange", "grey"))\r\n```\r\n\r\n![bar plots](/media/markdownx/0b26accd-2100-47fb-ba56-70beb5016343.png)\r\n\r\n```R\r\n# Same bar plot with error bars\r\npos_dod <- position_dodge(width = .9) # NEW: to position the bars correctly\r\nggplot(data = mydata, \t # (unchanged)\r\n \t aes(x = condition_LMS, \t # (unchanged)\r\n\t \t y = rating, \t # (unchanged)\r\n\t \t fill = condition_AB)) + # (unchanged)\r\n\t geom_bar( # (unchanged)\r\n\t \t fun.y = mean, stat = "summary", # (unchanged)\r\n\t \t pos = "dodge") + # (unchanged)\r\n\t scale_fill_manual( # (unchanged)\r\n\t \t values = c("orange", "grey")) +\r\n\t geom_errorbar(\t\t\t\t\t#NEW: add error bars\r\n\t \t fun.ymin = function(z) mean(z)-sd(z),\t# define minimum of bar\r\n\t \t fun.ymax = function(z) mean(z)+sd(z),\t# define maximum of bar\r\n\t \t stat = "summary",\t\t\t\t# plot the summary\r\n\t \t width = .2,\t\t\t\t\t# make ends of bars smaller\r\n\t \t pos = pos_dod)\t\t\t\t\t# correct position of bars\r\n```\r\n\r\n![error bars](/media/markdownx/a161dd45-ba95-4b2e-ad87-4d2abe635354.png)\r\n\r\n**3. Continuous dependent variable and continuous independent variable** \r\nThink of a correlational design where you have manipulated e.g. stress level of participants and you measure some rating, both the dependent and independent variable are on a continuous scale. You can do a simple regression or correlation plot.\r\n\r\n```R\r\n# Plot two continuous variables and a correlation/regression line\r\nggplot(data = mydata, \t \r\n\t aes(x = condition_3, y = rating)) + # NEW: continuous x- and y-variables\r\n\t geom_point() + \t\t\t # NEW: we want points \t \r\n\t geom_smooth(method = "lm") # NEW: we want a line\r\n# “lm” means “linear model” since the correlation line is a linear line\r\n# The grey area is the 95% confidence level interval for predictions from a linear model \r\n```\r\n\r\n![regression line](/media/markdownx/69cb1800-946d-467d-902b-46d605d7d093.png)\r\n\r\n```R\r\n# Change the color of the line\r\nggplot(data = mydata, \t \t\t\t# (unchanged)\r\n\t aes(x = condition_3, y = rating)) + \t# (unchanged)\r\n\t geom_point() + \t \t\t# (unchanged)\r\n\t geom_smooth(method = "lm",\t\t\t\t# (unchanged)\r\n\t \t color = "springgreen") # NEW: define color\r\n```\r\n\r\n![Color of line](/media/markdownx/11f1bf4a-609d-434f-91b4-4510d09c07a5.png)\r\n\r\nSuppose your experiment contains one continuous independent variable and one categorical independent variable (and a continuous dependent variable). To see if the relationship between the continuous variables changes for the levels of the categorical variable, you can plot two side-by-side correlation lines like this:\r\n\r\n```R\r\n# Mixed design: continuous and categorical independent variables\r\nggplot(data = mydata, \t \r\n\taes(x = condition_3, y = rating)) + # (unchanged)\r\n\tgeom_point() + \t # (unchanged)\r\n\tgeom_smooth(method = "lm") + # (unchanged)\r\n\tfacet_wrap(~condition_AB) \t # NEW: add the categorical variable\r\n```\r\n\r\n\r\n![mixed design](/media/markdownx/4c6b9e36-cd17-4940-9c1a-9d7c71a597e2.png)\r\n\r\nThis will also work if your categorical variable has more than two levels.\r\n\r\nFinally, let’s consider a design with a categorical dependent variable and a continuous independent variable. If the categorical dependent variable has only two levels (think of ‘Option A’ and ‘Option B’), then you can plot a logistic regression line as follows:\r\n\r\n```R\r\n# Categorical dependent variable with two levels\r\n# transform categorical variable to have numeric values 0 and 1\r\nmydata$choice.numeric <- as.numeric(mydata$choice) - 1\r\n# Make the plot\r\nggplot(data = mydata, \t \t\t\t\t# (unchaned)\r\n\t aes(x = condition_3, y = choice.numeric)) + \t# NEW: new y-variable\r\n\t geom_point() + \t \t\t\t# (unchanged)\r\n\t geom_smooth(method = "glm",\t\t\t\t# NEW: “glm”\r\n\t \t method.args = list(family = "binomial")) \t\t# NEW: plots a logistic regression line\r\n```\r\n\r\n![logistic regression line](/media/markdownx/344032ca-08b1-4227-8671-cc1e1428c37e.png)\r\n\r\n**4. Saving your plots** \r\nSaving plots is super easy. After you have generated the plot, you use the command:\r\n\r\n```R\r\n# Save the last plot you generated\r\nggsave(“filename_of_plot.png”)\r\n```\r\n\r\nThen your plot will be saved as PNG file with the name filename_of_plot. The file will be saved in the same location where your R code is. If you want to save the plot to a different location simply type your personal path to the folder, which should look similar but different from this:\r\n```R\r\n# Add a longer file path if you want to save to a different location\r\nggsave(“C:/Users/.../Folder/Folder/filename_of_plot.png”)\r\n# If you need a JPG or TIFF file, just type:\r\nggsave(“filename_of_plot.jpg”)\r\nggsave(“filename_of_plot.tiff”)\r\n# If you want a different size use\r\nggsave(“filename_of_plot.png”, width = 8, height =5)\r\n# If you want the font to be bigger, use ‘scale = …’\r\nggsave(“filename_of_plot.png”, scale = 0.8)\r\n```', 'In this article we introduce you to plotting with R. It is always a good idea to first look at your data before you run statistical tests. Keep in mind, that using graphs, charts and images help your audience to understand the data more quickly. \r\n{.lead}\r\n\r\nThis is a brief illustration of the types of plots you can use for different experimental designs: \r\n![Illustration of different plot types](/media/markdownx/2b471a9b-c60e-4cf1-9c7d-6e01aaa635f0.png)\r\n\r\nThe following examples show your R code for different types of plots.\r\n\r\nWe use a package called ggplot, which you need to install once and then you can load it every time you need to use it:\r\n\r\n```R\r\ninstall.packages("ggplot2") #run this only ONE TIME then comment it out (it\'s like installing a program)\r\nlibrary(ggplot2) #run this every time, it\'s like opening a program\r\ntheme_set(theme_classic()) # This comment defines a background \r\n# You can check out all themes here http://ggplot2.tidyverse.org/reference/ggtheme.html\r\n```\r\n\r\nTo test the plots, download our [test data](https://tales.nmc.unibas.ch/media/conducting-psychological-research/statistics-and-analyses/graphics-with-r/test_data.csv) and save it into the folder where you saved your R script.\r\n\r\n```R\r\n# Read the testdata and name it mydata\r\nmydata <- read.csv(file.chose())\r\n\r\n# Alternative way to read data:\r\n# set the working directory to the folder where the test data is stored\r\nsetwd(“.../your path/your folder”) # See tutorial ‘Read data with R’\r\n# Alternatively, save data and Rcode in the same folder and use Session > Set Working Directory > To Source File Location\r\n# Read the testdata and name it "mydata"\r\nmydata <- read.csv("test_data.csv")\r\n\r\n # Look at the variables and values in the first rows\r\nhead(mydata) # look at the variables and values in the first rows\r\nsubj_ID\tcondition_AB\tcondition_B\tcondition_3\tage\t\tgender\tdegree\t\tincome\trating\tchoice\r\nabcz\t\tcond A\t\tstrong\t\t7.14\t\t23 \t\tfemale\tBachelor\t867\t\t5.9\t\tOption X\r\nicoa\t\tcond B\t\tstrong\t \t4.78\t\t28 \t\tfemale\tMaster\t\t900\t\t8.26\tOption X\r\naetr\t\tcond A\t\tstrong\t \t4.89\t\t22 \tmale \tBachelor \t393 \t10.62 \tOption X\r\nhefb\t\tcond B\t\tmedium\t \t2.96\t\t25 \tfemale \tBachelor \t890 \t-9.06 \tOption Y\r\nbdza\t\tcond A\t\tstrong\t \t4.03\t\t-99\t\tmale \tBachelor \t900 \t6.89 \tOption X\r\nntqb\t\tcond B\t\tmedium\t \t5.18\t\t33 \tfemale \tMaster \t\t900 \t7.05\tOption X\r\n\r\n# Clean the data\r\nmydata$age[mydata$age < 0 | mydata$age > 80] <- NA\r\n```\r\n\r\n**1. No real DVs/IVs, plot two variables** \r\nThink of measured continuous variables; for example, the IQ, age, or income of the participants.\r\n\r\nYou can plot one of the variables, say age, as histogram:\r\n\r\n```R\r\n# This plots a histogram of one continuous variable\r\nggplot(data = mydata, \t\t# data = ... specifies how your data is called (‘mydata’)\r\n\t aes(x = age)) + \t# aes(x = …) specifies variable on x-axis (‘age’)\r\n\t geom_histogram() \t# + geom_histogramm() specifies that we want a histogram\r\n```\r\n\r\n![histogram](/media/markdownx/7522e3e7-f220-45d8-b445-b001d285d3a1.png)\r\n\r\nYou can plot two measured continuous variables:\r\n\r\n```R\r\n# This generates a point plot of two continuous variables\r\nggplot(data = mydata, \t\t# (unchanged)\r\n\t aes(x = age, y = income)) + \t# NEW: y = … specifies a y-variable (‘income’)\r\n\t geom_point() \t\t# NEW: +geom_point() means now we want points\r\n```\r\n\r\n![point plot](/media/markdownx/f4624fb3-e835-423d-9677-18df69eaaf2c.png)\r\n\r\nNext, think of your **measured categorical variables**, like gender, educational degree, or occupation, etc. You can plot how many participants fall into each combination of the gender-degree-combinations:\r\n\r\n```R\r\n# Plot two categorical variables as colour-filled bars\r\nggplot(data = mydata, \t\t\t\t# (unchanged)\r\n\t aes(x = gender, fill = degree)) + \t# NEW: new x-variable and fill-with-variable\r\n\t geom_bar() \t\t\t\t# NEW: we want bars\r\n# Note that the y-variable is not specified. It is automatically computed by counting how many rows in your data fall into each gender-degree category. It also works of there are more than two categories.\r\n```\r\n\r\n![colour-filled bar](/media/markdownx/3a79e4a4-361b-446c-8fff-4ff0ace3b1db.png)\r\n\r\n```R\r\n# Change the colours\r\nggplot(data = mydata, \t \t# (unchanged)\r\n\t aes(x = gender, fill = degree)) + \t# (unchanged)\r\n\t geom_bar() + \t \t# (unchanged)\r\n\t scale_fill_manual( \t \t# NEW: scale_fill_manual() adds ourfilling colors\r\n\t \t values = c("orange", "grey")) # define the color values\r\n```\r\n\r\n![other colours](/media/markdownx/5f5503e1-bd30-49e6-905c-89bb41a647e6.png)\r\n\r\nYou can find a list of more colour names [here](http://sape.inf.usi.ch/quick-reference/ggplot2/colour).\r\n\r\n**2. Continuous Dependent Variables and Categorical Independent variable** \r\nNext, think of an experimental design with a continuous dependent variable and experimental conditions, for example condition ‘A’ and ‘B’. Think of something like a 1 x 2 factorial between-subject design. To show if your continuous dependent variable changes given the levels of your categorical independent variable, you can use a side-by-side boxplot like this:\r\n\r\n```R\r\n# This plots boxplots of a continuous variable given a categorical variable\r\nggplot(data = mydata, \t\t # (unchanged)\r\n\t aes(x = condition_AB, y = rating)) + # NEW: new x- and y-variables\r\n\t geom_boxplot() \t # NEW: now we plot a boxplot\r\n```\r\n\r\n![boxplot](/media/markdownx/2c3d4e83-d71c-4e13-977a-9af734189305.png)\r\n\r\nNote: this will also work if your categorical independent variable has more than two levels\r\n\r\n```R\r\n# Same data but only the mean values shown as bars\r\nggplot(data = mydata, \t # (unchanged)\r\n\t aes(x = condition_AB, y = rating)) + # (unchanged)\r\n\t geom_bar( # NEW: now we want to plot bars\r\n \t \t fun.y = mean, stat = "summary") # specify that top of bar = mean of y\r\n```\r\n\r\n![bars](/media/markdownx/6cce9bb9-e303-456e-be23-e7763f01eb07.png)\r\n\r\n```R\r\n# Same data as points with error bars representing standard deviation (SD)\r\nggplot(data = mydata, \t\t# (unchanged)\r\n\t aes(x = condition_AB, y = rating)) + # (unchanged)\r\n\t geom_point( \t# NEW: now we to add points\r\n \t \t fun.y = mean, stat = "summary") +\t# (unchanged)\r\n\t geom_errorbar( # NEW: we want to add error bars\r\n \t \t fun.ymin = function(z) mean(z)-sd(z), # define minimum of error bar\r\n \t \t fun.ymax = function(z) mean(z)+sd(z), # define maximum of error bar\r\n \t \t stat = "summary",\r\n \t \t width = .1) \t# makes it prettier\r\n```\r\n\r\n![error bars](/media/markdownx/f0c7451e-6cb4-45ff-afe2-c722f4cf130c.png)\r\n\r\nYou can use the command ‘geom_errorbar(...)’ also for the bar plot shown above to add error bars to a bar plot. Try to copy all lines of the command ‘geom_errorbar(...)’ from the point plot, and add them with a ‘+’ to the barplot above.\r\n\r\n```R\r\n# Let’s go back to boxplots. Add the raw data in the background\r\nggplot(data = mydata, \t\t # (unchanged)\r\n\t aes(x = condition_AB, y = rating)) + # (unchanged)\r\n\t geom_boxplot() + \t # NEW: we want the boxplot again\r\n\t geom_jitter() # NEW: we want to add jittered points\r\n```\r\n\r\n![boxplot raw data](/media/markdownx/9490148a-e7c8-47f9-8d75-ca2441136ea3.png)\r\n\r\n```R\r\n# Color the the raw data\r\nggplot(data = mydata, \t\t # (unchanged)\r\n\t aes(x = condition_AB, y = rating)) + # (unchanged)\r\n\t geom_boxplot() + \t # (unchanged\r\n\t geom_jitter( \t # (unchanged)\r\n \t \t aes(color = condition_AB)) + # NEW: specify color represents condition_AB\r\n\t scale_colour_manual( \t# NEW: define the colour values\r\n \t \t values = c("orange", "grey"))\r\n```\r\n\r\n![Color raw data](/media/markdownx/db1daf57-8497-4b06-9e3f-0d383bc07992.png)\r\n\r\nIf your categorical independent variable has more levels, that’s no problem at all. All you need to change is to add more manual color values:\r\n\r\n```R\r\n# The categorical independent variable ‘conditon_LMS’ has three levels\r\nggplot(data = mydata,\r\n\t aes(x = condition_LMS, y = rating)) +\t# NEW: new x-variable with 3 levels\r\n\t geom_boxplot() +\t\t\t# (unchanged)\r\n\t geom_jitter(\r\n\t \t aes(color=condition_LMS)) +\t\t# NEW: new color-variable\r\n\t scale_color_manual(\r\n\t \t values = c("orange", "grey", "blue"))\t# NEW: three colors\t\r\n```\r\n\r\n![three levels](/media/markdownx/7ffe8a9e-696f-4f0b-84d6-d057e2de9c9b.png)\r\n\r\nNext, think of a situation where you have two categorical independent variables, like one condition called ‘A’ vs. ‘B’, and another condition with for example time pressure ‘low’, ‘medium’, or ‘strong’. Think of a 2 x 3 factorial design. To display if a continuous dependent variable changes given the six different combinations of the conditions, you can use a side-by-side boxplot with different colors for the other condition, like this:\r\n\r\n```R\r\n# This plots boxplots for each value combination of two categorical variables\r\nggplot(data = mydata,\r\n\t aes(x = condition_LMS, # NEW: categorical x-variable\r\n\t \t y = rating,\t\t # (unchanged y variable)\r\n\t \t fill = condition_AB)) +\t# NEW: second categorical fill-variable\r\n\t geom_boxplot() +\r\n\t scale_fill_manual(\t\t\t# (unchanged)\r\n\t \t values = c("orange", "grey"))\r\n```\r\n\r\n![boxplot each value combination](/media/markdownx/97c523df-d4da-43d2-987e-e42cf9bd0e1e.png)\r\n\r\n```R\r\n# Same data as bar plots with the mean of the y-values as height of bars\r\nggplot(data = mydata, # (unchanged)\r\n\t aes(x = condition_LMS,\t # (unchanged)\r\n\t \t y = rating,\t\t # (unchanged)\r\n\t \t fill = condition_AB)) + # (unchanged)\r\n\t geom_bar(\t\t\t\t# NEW: now we plot bars\r\n\t \t fun.y = mean, stat = "summary", # NEW: end of the bar = mean y values\r\n\t \t pos = "dodge") + # NEW: put bars side-by-side\r\n\t scale_fill_manual(\t\t\t\t# (unchanged)\r\n\t \t values = c("orange", "grey"))\r\n```\r\n\r\n![bar plots](/media/markdownx/0b26accd-2100-47fb-ba56-70beb5016343.png)\r\n\r\n```R\r\n# Same bar plot with error bars\r\npos_dod <- position_dodge(width = .9) # NEW: to position the bars correctly\r\nggplot(data = mydata, \t # (unchanged)\r\n \t aes(x = condition_LMS, \t # (unchanged)\r\n\t \t y = rating, \t # (unchanged)\r\n\t \t fill = condition_AB)) + # (unchanged)\r\n\t geom_bar( # (unchanged)\r\n\t \t fun.y = mean, stat = "summary", # (unchanged)\r\n\t \t pos = "dodge") + # (unchanged)\r\n\t scale_fill_manual( # (unchanged)\r\n\t \t values = c("orange", "grey")) +\r\n\t geom_errorbar(\t\t\t\t\t#NEW: add error bars\r\n\t \t fun.ymin = function(z) mean(z)-sd(z),\t# define minimum of bar\r\n\t \t fun.ymax = function(z) mean(z)+sd(z),\t# define maximum of bar\r\n\t \t stat = "summary",\t\t\t\t# plot the summary\r\n\t \t width = .2,\t\t\t\t\t# make ends of bars smaller\r\n\t \t pos = pos_dod)\t\t\t\t\t# correct position of bars\r\n```\r\n\r\n![error bars](/media/markdownx/a161dd45-ba95-4b2e-ad87-4d2abe635354.png)\r\n\r\n**3. Continuous dependent variable and continuous independent variable** \r\nThink of a correlational design where you have manipulated e.g. stress level of participants and you measure some rating, both the dependent and independent variable are on a continuous scale. You can do a simple regression or correlation plot.\r\n\r\n```R\r\n# Plot two continuous variables and a correlation/regression line\r\nggplot(data = mydata, \t \r\n\t aes(x = condition_3, y = rating)) + # NEW: continuous x- and y-variables\r\n\t geom_point() + \t\t\t # NEW: we want points \t \r\n\t geom_smooth(method = "lm") # NEW: we want a line\r\n# “lm” means “linear model” since the correlation line is a linear line\r\n# The grey area is the 95% confidence level interval for predictions from a linear model \r\n```\r\n\r\n![regression line](/media/markdownx/69cb1800-946d-467d-902b-46d605d7d093.png)\r\n\r\n```R\r\n# Change the color of the line\r\nggplot(data = mydata, \t \t\t\t# (unchanged)\r\n\t aes(x = condition_3, y = rating)) + \t# (unchanged)\r\n\t geom_point() + \t \t\t# (unchanged)\r\n\t geom_smooth(method = "lm",\t\t\t\t# (unchanged)\r\n\t \t color = "springgreen") # NEW: define color\r\n```\r\n\r\n![Color of line](/media/markdownx/11f1bf4a-609d-434f-91b4-4510d09c07a5.png)\r\n\r\nSuppose your experiment contains one continuous independent variable and one categorical independent variable (and a continuous dependent variable). To see if the relationship between the continuous variables changes for the levels of the categorical variable, you can plot two side-by-side correlation lines like this:\r\n\r\n```R\r\n# Mixed design: continuous and categorical independent variables\r\nggplot(data = mydata, \t \r\n\taes(x = condition_3, y = rating)) + # (unchanged)\r\n\tgeom_point() + \t # (unchanged)\r\n\tgeom_smooth(method = "lm") + # (unchanged)\r\n\tfacet_wrap(~condition_AB) \t # NEW: add the categorical variable\r\n```\r\n\r\n\r\n![mixed design](/media/markdownx/4c6b9e36-cd17-4940-9c1a-9d7c71a597e2.png)\r\n\r\nThis will also work if your categorical variable has more than two levels.\r\n\r\nFinally, let’s consider a design with a categorical dependent variable and a continuous independent variable. If the categorical dependent variable has only two levels (think of ‘Option A’ and ‘Option B’), then you can plot a logistic regression line as follows:\r\n\r\n```R\r\n# Categorical dependent variable with two levels\r\n# transform categorical variable to have numeric values 0 and 1\r\nmydata$choice.numeric <- as.numeric(mydata$choice) - 1\r\n# Make the plot\r\nggplot(data = mydata, \t \t\t\t\t# (unchaned)\r\n\t aes(x = condition_3, y = choice.numeric)) + \t# NEW: new y-variable\r\n\t geom_point() + \t \t\t\t# (unchanged)\r\n\t geom_smooth(method = "glm",\t\t\t\t# NEW: “glm”\r\n\t \t method.args = list(family = "binomial")) \t\t# NEW: plots a logistic regression line\r\n```\r\n\r\n![logistic regression line](/media/markdownx/344032ca-08b1-4227-8671-cc1e1428c37e.png)\r\n\r\n**4. Saving your plots** \r\nSaving plots is super easy. After you have generated the plot, you use the command:\r\n\r\n```R\r\n# Save the last plot you generated\r\nggsave(“filename_of_plot.png”)\r\n```\r\n\r\nThen your plot will be saved as PNG file with the name filename_of_plot. The file will be saved in the same location where your R code is. If you want to save the plot to a different location simply type your personal path to the folder, which should look similar but different from this:\r\n```R\r\n# Add a longer file path if you want to save to a different location\r\nggsave(“C:/Users/.../Folder/Folder/filename_of_plot.png”)\r\n# If you need a JPG or TIFF file, just type:\r\nggsave(“filename_of_plot.jpg”)\r\nggsave(“filename_of_plot.tiff”)\r\n# If you want a different size use\r\nggsave(“filename_of_plot.png”, width = 8, height =5)\r\n# If you want the font to be bigger, use ‘scale = …’\r\nggsave(“filename_of_plot.png”, scale = 0.8)\r\n```', '', '', None, None, None, None, None, None, None, 'University of Basel', 'University of Basel', 'University of Basel', '', 'TT', '30 min.', 6, 'published', False, None, None, None, None, 22)]])}, None) {} <django_redis.cache.RedisCache object at 0x7910e287a790>
/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in run(101)
  return _run_old_run_func()

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in _run_old_run_func(94)
  return old_run_func(self, *a, **kw)

/usr/local/lib/python3.11/concurrent/futures/thread.py in _worker(83)
  work_item.run()

/usr/local/lib/python3.11/concurrent/futures/thread.py in run(58)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/corsheaders/middleware.py in __call__(56)
  result = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in middleware(32)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/allauth/account/middleware.py in middleware(36)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/simple_history/middleware.py in middleware(41)
  return get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/django_htmx/middleware.py in __call__(43)
  return self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in __call__(168)
  response = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/panels.py in process_request(41)
  return super(CachalotPanel, self).process_request(request)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in __call__(244)
  current_executor.run_until_future(call_result)

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run_until_future(81)
  work_item.run()

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run(40)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_wrapped_callback(90)
  return callback(request, *args, **kwargs)

/app/project/utils/decorators.py in apply_cache(72)
  cache.set(CACHE_KEY, response.render(), ttl)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_patched_render(41)
  return old_render(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in render(114)
  self.content = self.rendered_content

/usr/local/lib/python3.11/site-packages/sentry_sdk/utils.py in runner(1788)
  return sentry_patched_function(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/templates.py in rendered_content(77)
  return real_rendered_content.fget(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in rendered_content(92)
  return template.render(context, self._request)

/usr/local/lib/python3.11/site-packages/django/template/backends/django.py in render(61)
  return self.template.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(175)
  return self._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(208)
  return template.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(177)
  return self._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py in render(321)
  return nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py in render(238)
  nodelist.append(node.render_annotated(context))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py in render(194)
  len_values = len(values)

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(37)
  return original(compiler, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(96)
  return _get_result_or_execute_query(

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in _get_result_or_execute_query(71)
  cache.set_many(to_be_set, cachalot_settings.CACHALOT_TIMEOUT)

0,2609 get_many (['e3a5db5a670ad803efb866441f33de58309be2e2', '76e323efd8711853e13c9f7cf976845908364eb2', '138549f5508bbba7283d6a0625e51c589d845e8f', '2bfd2c1975571b5440cc86283d19e74e1764b4a9'],) {} <django_redis.cache.RedisCache object at 0x7910e287a790>
/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in run(101)
  return _run_old_run_func()

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in _run_old_run_func(94)
  return old_run_func(self, *a, **kw)

/usr/local/lib/python3.11/concurrent/futures/thread.py in _worker(83)
  work_item.run()

/usr/local/lib/python3.11/concurrent/futures/thread.py in run(58)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/corsheaders/middleware.py in __call__(56)
  result = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in middleware(32)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/allauth/account/middleware.py in middleware(36)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/simple_history/middleware.py in middleware(41)
  return get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/django_htmx/middleware.py in __call__(43)
  return self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in __call__(168)
  response = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/panels.py in process_request(41)
  return super(CachalotPanel, self).process_request(request)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in __call__(244)
  current_executor.run_until_future(call_result)

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run_until_future(81)
  work_item.run()

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run(40)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_wrapped_callback(90)
  return callback(request, *args, **kwargs)

/app/project/utils/decorators.py in apply_cache(72)
  cache.set(CACHE_KEY, response.render(), ttl)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_patched_render(41)
  return old_render(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in render(114)
  self.content = self.rendered_content

/usr/local/lib/python3.11/site-packages/sentry_sdk/utils.py in runner(1788)
  return sentry_patched_function(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/templates.py in rendered_content(77)
  return real_rendered_content.fget(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in rendered_content(92)
  return template.render(context, self._request)

/usr/local/lib/python3.11/site-packages/django/template/backends/django.py in render(61)
  return self.template.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(175)
  return self._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py in render(541)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/library.py in render(237)
  output = self.func(*resolved_args, **resolved_kwargs)

/app/project/lms_base/templatetags/utils.py in get_next_step(128)
  return step.get_next(published_only=True)

/app/project/lms_base/models.py in get_next(249)
  return self._get_neighbour_step(is_next=True, published_only=published_only)

/app/project/lms_base/models.py in _get_neighbour_step(201)
  step = self.__class__.next_previous_manager.get_next_previous(

/app/project/lms_base/models.py in get_next_previous(71)
  return qs.first()

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(37)
  return original(compiler, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(96)
  return _get_result_or_execute_query(

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in _get_result_or_execute_query(46)
  data = cache.get_many(table_cache_keys + [cache_key])

0,2401 set_many ({'2bfd2c1975571b5440cc86283d19e74e1764b4a9': (1736871783.2051635, [])}, None) {} <django_redis.cache.RedisCache object at 0x7910e287a790>
/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in run(101)
  return _run_old_run_func()

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in _run_old_run_func(94)
  return old_run_func(self, *a, **kw)

/usr/local/lib/python3.11/concurrent/futures/thread.py in _worker(83)
  work_item.run()

/usr/local/lib/python3.11/concurrent/futures/thread.py in run(58)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/corsheaders/middleware.py in __call__(56)
  result = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in middleware(32)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/allauth/account/middleware.py in middleware(36)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/simple_history/middleware.py in middleware(41)
  return get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/django_htmx/middleware.py in __call__(43)
  return self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in __call__(168)
  response = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/panels.py in process_request(41)
  return super(CachalotPanel, self).process_request(request)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in __call__(244)
  current_executor.run_until_future(call_result)

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run_until_future(81)
  work_item.run()

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run(40)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_wrapped_callback(90)
  return callback(request, *args, **kwargs)

/app/project/utils/decorators.py in apply_cache(72)
  cache.set(CACHE_KEY, response.render(), ttl)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_patched_render(41)
  return old_render(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in render(114)
  self.content = self.rendered_content

/usr/local/lib/python3.11/site-packages/sentry_sdk/utils.py in runner(1788)
  return sentry_patched_function(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/templates.py in rendered_content(77)
  return real_rendered_content.fget(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in rendered_content(92)
  return template.render(context, self._request)

/usr/local/lib/python3.11/site-packages/django/template/backends/django.py in render(61)
  return self.template.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(175)
  return self._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py in render(541)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/library.py in render(237)
  output = self.func(*resolved_args, **resolved_kwargs)

/app/project/lms_base/templatetags/utils.py in get_next_step(128)
  return step.get_next(published_only=True)

/app/project/lms_base/models.py in get_next(249)
  return self._get_neighbour_step(is_next=True, published_only=published_only)

/app/project/lms_base/models.py in _get_neighbour_step(201)
  step = self.__class__.next_previous_manager.get_next_previous(

/app/project/lms_base/models.py in get_next_previous(71)
  return qs.first()

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(37)
  return original(compiler, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(96)
  return _get_result_or_execute_query(

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in _get_result_or_execute_query(71)
  cache.set_many(to_be_set, cachalot_settings.CACHALOT_TIMEOUT)

0,2422 get_many (['e3a5db5a670ad803efb866441f33de58309be2e2', '76e323efd8711853e13c9f7cf976845908364eb2', '5ae1cd1b91e2394afa4824d6dfedb3b55099d41b'],) {} <django_redis.cache.RedisCache object at 0x7910e287a790>
/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in run(101)
  return _run_old_run_func()

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in _run_old_run_func(94)
  return old_run_func(self, *a, **kw)

/usr/local/lib/python3.11/concurrent/futures/thread.py in _worker(83)
  work_item.run()

/usr/local/lib/python3.11/concurrent/futures/thread.py in run(58)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/corsheaders/middleware.py in __call__(56)
  result = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in middleware(32)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/allauth/account/middleware.py in middleware(36)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/simple_history/middleware.py in middleware(41)
  return get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/django_htmx/middleware.py in __call__(43)
  return self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in __call__(168)
  response = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/panels.py in process_request(41)
  return super(CachalotPanel, self).process_request(request)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in __call__(244)
  current_executor.run_until_future(call_result)

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run_until_future(81)
  work_item.run()

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run(40)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_wrapped_callback(90)
  return callback(request, *args, **kwargs)

/app/project/utils/decorators.py in apply_cache(72)
  cache.set(CACHE_KEY, response.render(), ttl)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_patched_render(41)
  return old_render(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in render(114)
  self.content = self.rendered_content

/usr/local/lib/python3.11/site-packages/sentry_sdk/utils.py in runner(1788)
  return sentry_patched_function(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/templates.py in rendered_content(77)
  return real_rendered_content.fget(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in rendered_content(92)
  return template.render(context, self._request)

/usr/local/lib/python3.11/site-packages/django/template/backends/django.py in render(61)
  return self.template.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(175)
  return self._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py in render(541)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/library.py in render(237)
  output = self.func(*resolved_args, **resolved_kwargs)

/app/project/lms_base/templatetags/utils.py in get_next_step(128)
  return step.get_next(published_only=True)

/app/project/lms_base/models.py in get_next(249)
  return self._get_neighbour_step(is_next=True, published_only=published_only)

/app/project/lms_base/models.py in _get_neighbour_step(216)
  chapter = chapter.get_next(published_only=True)

/app/project/lms_base/models.py in get_next(314)
  return self.__class__.next_previous_manager.get_next_previous(

/app/project/lms_base/models.py in get_next_previous(71)
  return qs.first()

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(37)
  return original(compiler, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(96)
  return _get_result_or_execute_query(

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in _get_result_or_execute_query(46)
  data = cache.get_many(table_cache_keys + [cache_key])

0,3393 set_many ({'5ae1cd1b91e2394afa4824d6dfedb3b55099d41b': (1736871783.2106314, [[(22, datetime.datetime(2020, 11, 2, 15, 9, 33, 545649, tzinfo=datetime.timezone.utc), datetime.datetime(2020, 11, 2, 15, 9, 38, 579443, tzinfo=datetime.timezone.utc), datetime.datetime(2020, 11, 2, 15, 9, 38, 579454, tzinfo=datetime.timezone.utc), False, 'Statistics and analyses', 'Statistics and analyses', 'Statistics and analyses', None, 'statistics-and-analyses', 3, 'published', 6)]])}, None) {} <django_redis.cache.RedisCache object at 0x7910e287a790>
/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in run(101)
  return _run_old_run_func()

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in _run_old_run_func(94)
  return old_run_func(self, *a, **kw)

/usr/local/lib/python3.11/concurrent/futures/thread.py in _worker(83)
  work_item.run()

/usr/local/lib/python3.11/concurrent/futures/thread.py in run(58)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/corsheaders/middleware.py in __call__(56)
  result = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in middleware(32)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/allauth/account/middleware.py in middleware(36)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/simple_history/middleware.py in middleware(41)
  return get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/django_htmx/middleware.py in __call__(43)
  return self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in __call__(168)
  response = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/panels.py in process_request(41)
  return super(CachalotPanel, self).process_request(request)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in __call__(244)
  current_executor.run_until_future(call_result)

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run_until_future(81)
  work_item.run()

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run(40)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_wrapped_callback(90)
  return callback(request, *args, **kwargs)

/app/project/utils/decorators.py in apply_cache(72)
  cache.set(CACHE_KEY, response.render(), ttl)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_patched_render(41)
  return old_render(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in render(114)
  self.content = self.rendered_content

/usr/local/lib/python3.11/site-packages/sentry_sdk/utils.py in runner(1788)
  return sentry_patched_function(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/templates.py in rendered_content(77)
  return real_rendered_content.fget(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in rendered_content(92)
  return template.render(context, self._request)

/usr/local/lib/python3.11/site-packages/django/template/backends/django.py in render(61)
  return self.template.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(175)
  return self._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py in render(541)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/library.py in render(237)
  output = self.func(*resolved_args, **resolved_kwargs)

/app/project/lms_base/templatetags/utils.py in get_next_step(128)
  return step.get_next(published_only=True)

/app/project/lms_base/models.py in get_next(249)
  return self._get_neighbour_step(is_next=True, published_only=published_only)

/app/project/lms_base/models.py in _get_neighbour_step(216)
  chapter = chapter.get_next(published_only=True)

/app/project/lms_base/models.py in get_next(314)
  return self.__class__.next_previous_manager.get_next_previous(

/app/project/lms_base/models.py in get_next_previous(71)
  return qs.first()

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(37)
  return original(compiler, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(96)
  return _get_result_or_execute_query(

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in _get_result_or_execute_query(71)
  cache.set_many(to_be_set, cachalot_settings.CACHALOT_TIMEOUT)

0,2333 get_many (['76e323efd8711853e13c9f7cf976845908364eb2', '138549f5508bbba7283d6a0625e51c589d845e8f', 'edeb48f04c3cc21da068755618b09b0f340b8421'],) {} <django_redis.cache.RedisCache object at 0x7910e287a790>
/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in run(101)
  return _run_old_run_func()

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in _run_old_run_func(94)
  return old_run_func(self, *a, **kw)

/usr/local/lib/python3.11/concurrent/futures/thread.py in _worker(83)
  work_item.run()

/usr/local/lib/python3.11/concurrent/futures/thread.py in run(58)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/corsheaders/middleware.py in __call__(56)
  result = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in middleware(32)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/allauth/account/middleware.py in middleware(36)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/simple_history/middleware.py in middleware(41)
  return get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/django_htmx/middleware.py in __call__(43)
  return self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in __call__(168)
  response = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/panels.py in process_request(41)
  return super(CachalotPanel, self).process_request(request)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in __call__(244)
  current_executor.run_until_future(call_result)

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run_until_future(81)
  work_item.run()

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run(40)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_wrapped_callback(90)
  return callback(request, *args, **kwargs)

/app/project/utils/decorators.py in apply_cache(72)
  cache.set(CACHE_KEY, response.render(), ttl)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_patched_render(41)
  return old_render(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in render(114)
  self.content = self.rendered_content

/usr/local/lib/python3.11/site-packages/sentry_sdk/utils.py in runner(1788)
  return sentry_patched_function(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/templates.py in rendered_content(77)
  return real_rendered_content.fget(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in rendered_content(92)
  return template.render(context, self._request)

/usr/local/lib/python3.11/site-packages/django/template/backends/django.py in render(61)
  return self.template.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(175)
  return self._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py in render(541)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/library.py in render(237)
  output = self.func(*resolved_args, **resolved_kwargs)

/app/project/lms_base/templatetags/utils.py in get_next_step(128)
  return step.get_next(published_only=True)

/app/project/lms_base/models.py in get_next(249)
  return self._get_neighbour_step(is_next=True, published_only=published_only)

/app/project/lms_base/models.py in _get_neighbour_step(232)
  if qs.count() == 0:

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(37)
  return original(compiler, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(96)
  return _get_result_or_execute_query(

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in _get_result_or_execute_query(46)
  data = cache.get_many(table_cache_keys + [cache_key])

0,2143 set_many ({'edeb48f04c3cc21da068755618b09b0f340b8421': (1736871783.21584, (7,))}, None) {} <django_redis.cache.RedisCache object at 0x7910e287a790>
/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in run(101)
  return _run_old_run_func()

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in _run_old_run_func(94)
  return old_run_func(self, *a, **kw)

/usr/local/lib/python3.11/concurrent/futures/thread.py in _worker(83)
  work_item.run()

/usr/local/lib/python3.11/concurrent/futures/thread.py in run(58)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/corsheaders/middleware.py in __call__(56)
  result = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in middleware(32)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/allauth/account/middleware.py in middleware(36)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/simple_history/middleware.py in middleware(41)
  return get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/django_htmx/middleware.py in __call__(43)
  return self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in __call__(168)
  response = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/panels.py in process_request(41)
  return super(CachalotPanel, self).process_request(request)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in __call__(244)
  current_executor.run_until_future(call_result)

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run_until_future(81)
  work_item.run()

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run(40)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_wrapped_callback(90)
  return callback(request, *args, **kwargs)

/app/project/utils/decorators.py in apply_cache(72)
  cache.set(CACHE_KEY, response.render(), ttl)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_patched_render(41)
  return old_render(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in render(114)
  self.content = self.rendered_content

/usr/local/lib/python3.11/site-packages/sentry_sdk/utils.py in runner(1788)
  return sentry_patched_function(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/templates.py in rendered_content(77)
  return real_rendered_content.fget(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in rendered_content(92)
  return template.render(context, self._request)

/usr/local/lib/python3.11/site-packages/django/template/backends/django.py in render(61)
  return self.template.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(175)
  return self._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py in render(541)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/library.py in render(237)
  output = self.func(*resolved_args, **resolved_kwargs)

/app/project/lms_base/templatetags/utils.py in get_next_step(128)
  return step.get_next(published_only=True)

/app/project/lms_base/models.py in get_next(249)
  return self._get_neighbour_step(is_next=True, published_only=published_only)

/app/project/lms_base/models.py in _get_neighbour_step(232)
  if qs.count() == 0:

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(37)
  return original(compiler, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(96)
  return _get_result_or_execute_query(

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in _get_result_or_execute_query(71)
  cache.set_many(to_be_set, cachalot_settings.CACHALOT_TIMEOUT)

0,2800 get_many (['e3a5db5a670ad803efb866441f33de58309be2e2', '76e323efd8711853e13c9f7cf976845908364eb2', '138549f5508bbba7283d6a0625e51c589d845e8f', '693eb46bcbeff037a3783c1461abf327ded210dd'],) {} <django_redis.cache.RedisCache object at 0x7910e287a790>
/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in run(101)
  return _run_old_run_func()

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in _run_old_run_func(94)
  return old_run_func(self, *a, **kw)

/usr/local/lib/python3.11/concurrent/futures/thread.py in _worker(83)
  work_item.run()

/usr/local/lib/python3.11/concurrent/futures/thread.py in run(58)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/corsheaders/middleware.py in __call__(56)
  result = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in middleware(32)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/allauth/account/middleware.py in middleware(36)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/simple_history/middleware.py in middleware(41)
  return get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/django_htmx/middleware.py in __call__(43)
  return self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in __call__(168)
  response = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/panels.py in process_request(41)
  return super(CachalotPanel, self).process_request(request)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in __call__(244)
  current_executor.run_until_future(call_result)

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run_until_future(81)
  work_item.run()

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run(40)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_wrapped_callback(90)
  return callback(request, *args, **kwargs)

/app/project/utils/decorators.py in apply_cache(72)
  cache.set(CACHE_KEY, response.render(), ttl)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_patched_render(41)
  return old_render(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in render(114)
  self.content = self.rendered_content

/usr/local/lib/python3.11/site-packages/sentry_sdk/utils.py in runner(1788)
  return sentry_patched_function(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/templates.py in rendered_content(77)
  return real_rendered_content.fget(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in rendered_content(92)
  return template.render(context, self._request)

/usr/local/lib/python3.11/site-packages/django/template/backends/django.py in render(61)
  return self.template.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(175)
  return self._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py in render(541)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/library.py in render(237)
  output = self.func(*resolved_args, **resolved_kwargs)

/app/project/lms_base/templatetags/utils.py in get_next_step(128)
  return step.get_next(published_only=True)

/app/project/lms_base/models.py in get_next(249)
  return self._get_neighbour_step(is_next=True, published_only=published_only)

/app/project/lms_base/models.py in _get_neighbour_step(236)
  step = qs.first()

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(37)
  return original(compiler, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(96)
  return _get_result_or_execute_query(

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in _get_result_or_execute_query(46)
  data = cache.get_many(table_cache_keys + [cache_key])

0,3719 set_many ({'693eb46bcbeff037a3783c1461abf327ded210dd': (1736871783.2213926, [[(70, datetime.datetime(2020, 11, 2, 15, 9, 33, 774510, tzinfo=datetime.timezone.utc), datetime.datetime(2020, 11, 2, 15, 9, 37, 378907, tzinfo=datetime.timezone.utc), datetime.datetime(2020, 11, 2, 15, 9, 37, 378917, tzinfo=datetime.timezone.utc), False, 'How to make an analysis plan', 'How to make an analysis plan', 'How to make an analysis plan', None, '', '', '', None, '', None, None, None, 'conducting-psychological-research/chapter-4/how-to-make-an-analysis-plan/hand.jpg', 'how-to-make-an-analysis-plan', 'It is important to plan your analysis during the design of the experiment. This means that you already have to think in detail about the statistical tests for your hypotheses and the approximate computations when you design the experiment. You want to do this before running the experiment, because if you realize that some variables are missing after you ran the study, it’s just too late. Analysis plans are easy. You can simply follow these four steps:\r\n{.lead}\r\n\r\n**1. Select the hypothesis.** \r\nFor example: \r\n> H1: Listening to classical music increases performance\r\nin math taks more than rock music because it distracts people less.\r\n\r\n**2. Write down the test.** \r\nFor example:\r\n> Test for H1: T-test between the % of correct answers of the rock-music-group and the % of correct answers of classic-music-group.\r\n\r\n**3. Write down the variables in your experiment that relate to this hypothesis.** \r\nIf you don’t know how these variables will be called in the end, write them down with an approximate name. The most important thing is that you write down what data your experiment will give you. \r\nFor example:\r\n>Variable in our experiment:\r\n> \r\n>v_123 = experimental groups (1 = classic, 2 = rock)\r\n> \r\n>v_009 = maths test answer 1\r\n>v_010 = maths test answer 2\r\n>v_011 = maths test answer 3\r\n>v_012 = maths test answer 4\r\n\r\nIn this example it would be clever if you renamed the variables v_123 as experimental_condition and v_009 - v_012 as maths_1 through maths_4.\r\n\r\nNow you can see that there are four maths test answers but the t-test in step 2 needs the % of correct answers. Therefore, you need to first calculate the mean. In this case you can write down another step.\r\n\r\n**4. Transform the data.** \r\nFor example: \r\n>Data transformations: \r\n>1. Compute which maths test answer was correct (v_009 - v_012) \r\n>2. Compute for each person in the sample the mean number of correct answers\r\n\r\nYou can also already write down the requirements for the t-test (look into your statistics book if you don’t remember how). \r\nFor example: \r\n>For t-test: compute test of variance homogeneity of correct answers\r\n\r\nImportant: See what the difference between step 3 and step 4 above is? Step 4 mentions the variables v_009 to v_012 while step 3 only mentions the ‘correct answers’ which are not in your raw data.\r\n\r\n**Repeat these four steps with all your hypotheses.**\r\n\r\nTip: if you are a bit familiar with R you can write the statistical commands for the test of your hypothesis directly in R. For example: \r\n\r\n\r\n```R\r\n# H1: Listening to classical music increases performance in math taks more than rock music because it distracts people less \r\n\r\n# Mean number of correct maths test items \r\nmean_correct_per_person <- rowSums(data[, c(“v_009”, “v_010”, “v_011”, “v_012”)] / 4) \r\nheard_classic <- data$v_123 # 1 = classic, 2 = rock \r\n\r\n# Homogeneity of variances? \r\nbartlett.test(x = mean_correct_per_persom, y = heard_classic) \r\n\r\n# Differences in groups? \r\nmean_correct_classic <- mean_correct_per_person[heard_classic == 1] \r\nmean_correct_rock <- mean_correct_per_person[heard_classic == 2] \r\nt.test(x = mean_correct_classic, y = mean_correct_rock )\r\n```\r\nNote: a line beginning with a hashtag (#) indicates a comment in R. This means that it is not carried out as code.\r\n\r\nIf you are not familiar with R yet, do not worry. We will introduce R in the following chapters.', 'It is important to plan your analysis during the design of the experiment. This means that you already have to think in detail about the statistical tests for your hypotheses and the approximate computations when you design the experiment. You want to do this before running the experiment, because if you realize that some variables are missing after you ran the study, it’s just too late. Analysis plans are easy. You can simply follow these four steps:\r\n{.lead}\r\n\r\n**1. Select the hypothesis.** \r\nFor example: \r\n> H1: Listening to classical music increases performance\r\nin math taks more than rock music because it distracts people less.\r\n\r\n**2. Write down the test.** \r\nFor example:\r\n> Test for H1: T-test between the % of correct answers of the rock-music-group and the % of correct answers of classic-music-group.\r\n\r\n**3. Write down the variables in your experiment that relate to this hypothesis.** \r\nIf you don’t know how these variables will be called in the end, write them down with an approximate name. The most important thing is that you write down what data your experiment will give you. \r\nFor example:\r\n>Variable in our experiment:\r\n> \r\n>v_123 = experimental groups (1 = classic, 2 = rock)\r\n> \r\n>v_009 = maths test answer 1\r\n>v_010 = maths test answer 2\r\n>v_011 = maths test answer 3\r\n>v_012 = maths test answer 4\r\n\r\nIn this example it would be clever if you renamed the variables v_123 as experimental_condition and v_009 - v_012 as maths_1 through maths_4.\r\n\r\nNow you can see that there are four maths test answers but the t-test in step 2 needs the % of correct answers. Therefore, you need to first calculate the mean. In this case you can write down another step.\r\n\r\n**4. Transform the data.** \r\nFor example: \r\n>Data transformations: \r\n>1. Compute which maths test answer was correct (v_009 - v_012) \r\n>2. Compute for each person in the sample the mean number of correct answers\r\n\r\nYou can also already write down the requirements for the t-test (look into your statistics book if you don’t remember how). \r\nFor example: \r\n>For t-test: compute test of variance homogeneity of correct answers\r\n\r\nImportant: See what the difference between step 3 and step 4 above is? Step 4 mentions the variables v_009 to v_012 while step 3 only mentions the ‘correct answers’ which are not in your raw data.\r\n\r\n**Repeat these four steps with all your hypotheses.**\r\n\r\nTip: if you are a bit familiar with R you can write the statistical commands for the test of your hypothesis directly in R. For example: \r\n\r\n\r\n```R\r\n# H1: Listening to classical music increases performance in math taks more than rock music because it distracts people less \r\n\r\n# Mean number of correct maths test items \r\nmean_correct_per_person <- rowSums(data[, c(“v_009”, “v_010”, “v_011”, “v_012”)] / 4) \r\nheard_classic <- data$v_123 # 1 = classic, 2 = rock \r\n\r\n# Homogeneity of variances? \r\nbartlett.test(x = mean_correct_per_persom, y = heard_classic) \r\n\r\n# Differences in groups? \r\nmean_correct_classic <- mean_correct_per_person[heard_classic == 1] \r\nmean_correct_rock <- mean_correct_per_person[heard_classic == 2] \r\nt.test(x = mean_correct_classic, y = mean_correct_rock )\r\n```\r\nNote: a line beginning with a hashtag (#) indicates a comment in R. This means that it is not carried out as code.\r\n\r\nIf you are not familiar with R yet, do not worry. We will introduce R in the following chapters.', 'It is important to plan your analysis during the design of the experiment. This means that you already have to think in detail about the statistical tests for your hypotheses and the approximate computations when you design the experiment. You want to do this before running the experiment, because if you realize that some variables are missing after you ran the study, it’s just too late. Analysis plans are easy. You can simply follow these four steps:\r\n{.lead}\r\n\r\n**1. Select the hypothesis.** \r\nFor example: \r\n> H1: Listening to classical music increases performance\r\nin math taks more than rock music because it distracts people less.\r\n\r\n**2. Write down the test.** \r\nFor example:\r\n> Test for H1: T-test between the % of correct answers of the rock-music-group and the % of correct answers of classic-music-group.\r\n\r\n**3. Write down the variables in your experiment that relate to this hypothesis.** \r\nIf you don’t know how these variables will be called in the end, write them down with an approximate name. The most important thing is that you write down what data your experiment will give you. \r\nFor example:\r\n>Variable in our experiment:\r\n> \r\n>v_123 = experimental groups (1 = classic, 2 = rock)\r\n> \r\n>v_009 = maths test answer 1\r\n>v_010 = maths test answer 2\r\n>v_011 = maths test answer 3\r\n>v_012 = maths test answer 4\r\n\r\nIn this example it would be clever if you renamed the variables v_123 as experimental_condition and v_009 - v_012 as maths_1 through maths_4.\r\n\r\nNow you can see that there are four maths test answers but the t-test in step 2 needs the % of correct answers. Therefore, you need to first calculate the mean. In this case you can write down another step.\r\n\r\n**4. Transform the data.** \r\nFor example: \r\n>Data transformations: \r\n>1. Compute which maths test answer was correct (v_009 - v_012) \r\n>2. Compute for each person in the sample the mean number of correct answers\r\n\r\nYou can also already write down the requirements for the t-test (look into your statistics book if you don’t remember how). \r\nFor example: \r\n>For t-test: compute test of variance homogeneity of correct answers\r\n\r\nImportant: See what the difference between step 3 and step 4 above is? Step 4 mentions the variables v_009 to v_012 while step 3 only mentions the ‘correct answers’ which are not in your raw data.\r\n\r\n**Repeat these four steps with all your hypotheses.**\r\n\r\nTip: if you are a bit familiar with R you can write the statistical commands for the test of your hypothesis directly in R. For example: \r\n\r\n\r\n```R\r\n# H1: Listening to classical music increases performance in math taks more than rock music because it distracts people less \r\n\r\n# Mean number of correct maths test items \r\nmean_correct_per_person <- rowSums(data[, c(“v_009”, “v_010”, “v_011”, “v_012”)] / 4) \r\nheard_classic <- data$v_123 # 1 = classic, 2 = rock \r\n\r\n# Homogeneity of variances? \r\nbartlett.test(x = mean_correct_per_persom, y = heard_classic) \r\n\r\n# Differences in groups? \r\nmean_correct_classic <- mean_correct_per_person[heard_classic == 1] \r\nmean_correct_rock <- mean_correct_per_person[heard_classic == 2] \r\nt.test(x = mean_correct_classic, y = mean_correct_rock )\r\n```\r\nNote: a line beginning with a hashtag (#) indicates a comment in R. This means that it is not carried out as code.\r\n\r\nIf you are not familiar with R yet, do not worry. We will introduce R in the following chapters.', None, '', None, None, None, None, None, None, None, 'University of Basel', 'University of Basel', 'University of Basel', None, 'TT', '10 Min.', 0, 'published', False, None, None, None, None, 22)]])}, None) {} <django_redis.cache.RedisCache object at 0x7910e287a790>
/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in run(101)
  return _run_old_run_func()

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in _run_old_run_func(94)
  return old_run_func(self, *a, **kw)

/usr/local/lib/python3.11/concurrent/futures/thread.py in _worker(83)
  work_item.run()

/usr/local/lib/python3.11/concurrent/futures/thread.py in run(58)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/corsheaders/middleware.py in __call__(56)
  result = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in middleware(32)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/allauth/account/middleware.py in middleware(36)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/simple_history/middleware.py in middleware(41)
  return get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/django_htmx/middleware.py in __call__(43)
  return self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in __call__(168)
  response = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/panels.py in process_request(41)
  return super(CachalotPanel, self).process_request(request)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in __call__(244)
  current_executor.run_until_future(call_result)

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run_until_future(81)
  work_item.run()

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run(40)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_wrapped_callback(90)
  return callback(request, *args, **kwargs)

/app/project/utils/decorators.py in apply_cache(72)
  cache.set(CACHE_KEY, response.render(), ttl)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_patched_render(41)
  return old_render(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in render(114)
  self.content = self.rendered_content

/usr/local/lib/python3.11/site-packages/sentry_sdk/utils.py in runner(1788)
  return sentry_patched_function(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/templates.py in rendered_content(77)
  return real_rendered_content.fget(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in rendered_content(92)
  return template.render(context, self._request)

/usr/local/lib/python3.11/site-packages/django/template/backends/django.py in render(61)
  return self.template.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(175)
  return self._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py in render(541)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/library.py in render(237)
  output = self.func(*resolved_args, **resolved_kwargs)

/app/project/lms_base/templatetags/utils.py in get_next_step(128)
  return step.get_next(published_only=True)

/app/project/lms_base/models.py in get_next(249)
  return self._get_neighbour_step(is_next=True, published_only=published_only)

/app/project/lms_base/models.py in _get_neighbour_step(236)
  step = qs.first()

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(37)
  return original(compiler, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(96)
  return _get_result_or_execute_query(

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in _get_result_or_execute_query(71)
  cache.set_many(to_be_set, cachalot_settings.CACHALOT_TIMEOUT)

0,2945 get_many (['e3a5db5a670ad803efb866441f33de58309be2e2', '76e323efd8711853e13c9f7cf976845908364eb2', '138549f5508bbba7283d6a0625e51c589d845e8f', '2aa00b581875342aa790ee1ae2337fc1e1f8040e'],) {} <django_redis.cache.RedisCache object at 0x7910e287a790>
/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in run(101)
  return _run_old_run_func()

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in _run_old_run_func(94)
  return old_run_func(self, *a, **kw)

/usr/local/lib/python3.11/concurrent/futures/thread.py in _worker(83)
  work_item.run()

/usr/local/lib/python3.11/concurrent/futures/thread.py in run(58)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/corsheaders/middleware.py in __call__(56)
  result = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in middleware(32)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/allauth/account/middleware.py in middleware(36)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/simple_history/middleware.py in middleware(41)
  return get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/django_htmx/middleware.py in __call__(43)
  return self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in __call__(168)
  response = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/panels.py in process_request(41)
  return super(CachalotPanel, self).process_request(request)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in __call__(244)
  current_executor.run_until_future(call_result)

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run_until_future(81)
  work_item.run()

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run(40)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_wrapped_callback(90)
  return callback(request, *args, **kwargs)

/app/project/utils/decorators.py in apply_cache(72)
  cache.set(CACHE_KEY, response.render(), ttl)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_patched_render(41)
  return old_render(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in render(114)
  self.content = self.rendered_content

/usr/local/lib/python3.11/site-packages/sentry_sdk/utils.py in runner(1788)
  return sentry_patched_function(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/templates.py in rendered_content(77)
  return real_rendered_content.fget(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in rendered_content(92)
  return template.render(context, self._request)

/usr/local/lib/python3.11/site-packages/django/template/backends/django.py in render(61)
  return self.template.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(175)
  return self._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py in render(541)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/library.py in render(237)
  output = self.func(*resolved_args, **resolved_kwargs)

/app/project/lms_base/templatetags/utils.py in get_previous_step(105)
  return step.get_previous(published_only=True)

/app/project/lms_base/models.py in get_previous(255)
  return self._get_neighbour_step(is_next=False, published_only=published_only)

/app/project/lms_base/models.py in _get_neighbour_step(201)
  step = self.__class__.next_previous_manager.get_next_previous(

/app/project/lms_base/models.py in get_next_previous(72)
  return qs.last()

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(37)
  return original(compiler, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(96)
  return _get_result_or_execute_query(

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in _get_result_or_execute_query(46)
  data = cache.get_many(table_cache_keys + [cache_key])

0,4288 set_many ({'2aa00b581875342aa790ee1ae2337fc1e1f8040e': (1736871783.2280781, [[(76, datetime.datetime(2020, 11, 2, 15, 9, 33, 774510, tzinfo=datetime.timezone.utc), datetime.datetime(2020, 11, 2, 15, 9, 37, 376832, tzinfo=datetime.timezone.utc), datetime.datetime(2020, 11, 2, 15, 9, 37, 376843, tzinfo=datetime.timezone.utc), False, 'Write a discussion section', 'Write a discussion section', 'Write a discussion section', None, '', '', '', None, '', None, None, None, '', 'write-a-discussion-section', 'The discussion section interprets the results. This chapter briefly outlines the basics of the discussion section.\r\n{.lead}\r\n\r\n**Discussion section vs. result section?** \r\nThe main difference between the discussion and the result section is that you **interpret** your results in the discussion. That means, while you explain what you have found objectively in the result section, in the discussion section you explain your findings by interpreting them. \r\n \r\n**How is the discussion section structured?** \r\nThe discussion section contains four parts:\r\n<br/>\r\n1. \tRecap of the research question and your main findings \r\n2. \tHow do your findings relate to the theories and what do they mean? \r\n3. \tWhat do your findings imply, and which limitations have been introduced by the design? \r\n4. \tConclusion of your main findings and discussion points \r\nIn the following paragraphs we give you more details and some examples for each part. \r\n \r\n**1. Recap of the research question and main your findings** \r\nIn the first paragraph, you briefly repeat the research question or hypothesis, what you found, and if your findings confirm your hypothesis. Although you repeat your findings, this paragraph is not a copy of the result section. Rather, in the discussion section, you should use phrases instead of numbers and graphs. Here is an example for a discussion section (few numbers, more text and intuition than in the result section):\r\n\r\n> The results confirmed our hypotheses that autonomy and engagement with characters lead to enjoyable experiences.\r\n\r\nThis is very different from a result section (facts, numbers, statistics), which could be:\r\n\r\n> A multiple regression was calculated with needs as predictors of enjoyment (*R = .62*, *R2 adjusted = .39*, *F(8, 114) = 11.38, p < .001*).\r\n \r\n\r\n \r\n**2. How do your findings relate to the theories and what do they mean?** \r\nIn the second part of your discussion, you revisit the theories and previous studies you have introduced in the introduction section and explain how your findings fit in. That means, you showcase what similarities or dissimilarities you found compared to the theories and previous studies. For example:\r\n\r\n> In line with previous studies (Johnson et al., 2015; Oliver & Raney, 2011), increased autonomy was associated with high enjoyment. ...\r\n \r\nIn the discussion section, it is particularly important to critically question your findings. Consider whether the difference in the dependent variable is really caused by the manipulation of the independent variable, or whether alternative explanations exist (e.g. confounding variables, influential variable assessed in previous studies but not in yours). Correspondingly, if you find no significant difference in the dependent variable, you need to ask yourself it this means that there is no relationship between your independent and dependent variable.\r\n \r\n**3. What are the implications of your findings, and what limitations of design exist?** \r\nThis third part of the discussion section is divided further into three subsections. \r\nFirst, you write about how your findings inform new research questions. Consider what is important or interesting to explore further. For instance, if the relationship between IV and DV was not clear in your experiment, how could a future study investigate it better? For example:\r\n\r\n> Future research may examine how to encourage players to share their feelings and thoughts evoked by game events with others. This seems especially important for serious games, as it may promote discussion of the subject. ...\r\n \r\nNext, if you think there is an implication for practitioners, who will merit from your findings and what practical relevance they have. It’s important to be specific, simply to mention that your findings have implication is not enough. For example:\r\n\r\n> Our findings have implication for researchers and practitioners wanting to evaluate long-lasting game experience. Such experiences have been argued to be difficult to assess in the long run (Lacovides & Cox, 2015). A possible work-around would be to take appreciation into account as this was found in our study to be associated to long-lasting effect. ...\r\n \r\nFinally, briefly discuss (max. 1 paragraph) the limitations of your experimental design. Consider what could be changed when replicating your study. For example:\r\n\r\n> A limitation is that the present study asked participants to recall a past game experience. But as the retrospective evaluation of an experience may differ from the moment-to-moment experience (Kahnemann & Riis, 2005), it is necessary to also explore players’ feelings and thoughts during or immediately after a gaming experience in future work.\r\n \r\n**4. Conclusion of your main implication** \r\nIn the last paragraph of the discussion section, you briefly summarize your study. In contrast to the abstract, the focus of the conclusion lies on the main findings and the main discussion points. Here, you present the take-home message for the reader of your paper. For example:\r\n\r\n> In conclusion, our results suggest that autonomy of players and appreciation of game elements play a key role in evoking positive emotions in a variety of computer games. Both factors, high autonomy and high appreciation, increase positive emotional experiences for players of both genders, especially in games involving a social component. Autonomy and appreciation thereby provide a mechanism to influence player experiences.', 'The discussion section interprets the results. This chapter briefly outlines the basics of the discussion section.\r\n{.lead}\r\n\r\n**Discussion section vs. result section?** \r\nThe main difference between the discussion and the result section is that you **interpret** your results in the discussion. That means, while you explain what you have found objectively in the result section, in the discussion section you explain your findings by interpreting them. \r\n \r\n**How is the discussion section structured?** \r\nThe discussion section contains four parts:\r\n<br/>\r\n1. \tRecap of the research question and your main findings \r\n2. \tHow do your findings relate to the theories and what do they mean? \r\n3. \tWhat do your findings imply, and which limitations have been introduced by the design? \r\n4. \tConclusion of your main findings and discussion points \r\nIn the following paragraphs we give you more details and some examples for each part. \r\n \r\n**1. Recap of the research question and main your findings** \r\nIn the first paragraph, you briefly repeat the research question or hypothesis, what you found, and if your findings confirm your hypothesis. Although you repeat your findings, this paragraph is not a copy of the result section. Rather, in the discussion section, you should use phrases instead of numbers and graphs. Here is an example for a discussion section (few numbers, more text and intuition than in the result section):\r\n\r\n> The results confirmed our hypotheses that autonomy and engagement with characters lead to enjoyable experiences.\r\n\r\nThis is very different from a result section (facts, numbers, statistics), which could be:\r\n\r\n> A multiple regression was calculated with needs as predictors of enjoyment (*R = .62*, *R2 adjusted = .39*, *F(8, 114) = 11.38, p < .001*).\r\n \r\n\r\n \r\n**2. How do your findings relate to the theories and what do they mean?** \r\nIn the second part of your discussion, you revisit the theories and previous studies you have introduced in the introduction section and explain how your findings fit in. That means, you showcase what similarities or dissimilarities you found compared to the theories and previous studies. For example:\r\n\r\n> In line with previous studies (Johnson et al., 2015; Oliver & Raney, 2011), increased autonomy was associated with high enjoyment. ...\r\n \r\nIn the discussion section, it is particularly important to critically question your findings. Consider whether the difference in the dependent variable is really caused by the manipulation of the independent variable, or whether alternative explanations exist (e.g. confounding variables, influential variable assessed in previous studies but not in yours). Correspondingly, if you find no significant difference in the dependent variable, you need to ask yourself it this means that there is no relationship between your independent and dependent variable.\r\n \r\n**3. What are the implications of your findings, and what limitations of design exist?** \r\nThis third part of the discussion section is divided further into three subsections. \r\nFirst, you write about how your findings inform new research questions. Consider what is important or interesting to explore further. For instance, if the relationship between IV and DV was not clear in your experiment, how could a future study investigate it better? For example:\r\n\r\n> Future research may examine how to encourage players to share their feelings and thoughts evoked by game events with others. This seems especially important for serious games, as it may promote discussion of the subject. ...\r\n \r\nNext, if you think there is an implication for practitioners, who will merit from your findings and what practical relevance they have. It’s important to be specific, simply to mention that your findings have implication is not enough. For example:\r\n\r\n> Our findings have implication for researchers and practitioners wanting to evaluate long-lasting game experience. Such experiences have been argued to be difficult to assess in the long run (Lacovides & Cox, 2015). A possible work-around would be to take appreciation into account as this was found in our study to be associated to long-lasting effect. ...\r\n \r\nFinally, briefly discuss (max. 1 paragraph) the limitations of your experimental design. Consider what could be changed when replicating your study. For example:\r\n\r\n> A limitation is that the present study asked participants to recall a past game experience. But as the retrospective evaluation of an experience may differ from the moment-to-moment experience (Kahnemann & Riis, 2005), it is necessary to also explore players’ feelings and thoughts during or immediately after a gaming experience in future work.\r\n \r\n**4. Conclusion of your main implication** \r\nIn the last paragraph of the discussion section, you briefly summarize your study. In contrast to the abstract, the focus of the conclusion lies on the main findings and the main discussion points. Here, you present the take-home message for the reader of your paper. For example:\r\n\r\n> In conclusion, our results suggest that autonomy of players and appreciation of game elements play a key role in evoking positive emotions in a variety of computer games. Both factors, high autonomy and high appreciation, increase positive emotional experiences for players of both genders, especially in games involving a social component. Autonomy and appreciation thereby provide a mechanism to influence player experiences.', 'The discussion section interprets the results. This chapter briefly outlines the basics of the discussion section.\r\n{.lead}\r\n\r\n**Discussion section vs. result section?** \r\nThe main difference between the discussion and the result section is that you **interpret** your results in the discussion. That means, while you explain what you have found objectively in the result section, in the discussion section you explain your findings by interpreting them. \r\n \r\n**How is the discussion section structured?** \r\nThe discussion section contains four parts:\r\n<br/>\r\n1. \tRecap of the research question and your main findings \r\n2. \tHow do your findings relate to the theories and what do they mean? \r\n3. \tWhat do your findings imply, and which limitations have been introduced by the design? \r\n4. \tConclusion of your main findings and discussion points \r\nIn the following paragraphs we give you more details and some examples for each part. \r\n \r\n**1. Recap of the research question and main your findings** \r\nIn the first paragraph, you briefly repeat the research question or hypothesis, what you found, and if your findings confirm your hypothesis. Although you repeat your findings, this paragraph is not a copy of the result section. Rather, in the discussion section, you should use phrases instead of numbers and graphs. Here is an example for a discussion section (few numbers, more text and intuition than in the result section):\r\n\r\n> The results confirmed our hypotheses that autonomy and engagement with characters lead to enjoyable experiences.\r\n\r\nThis is very different from a result section (facts, numbers, statistics), which could be:\r\n\r\n> A multiple regression was calculated with needs as predictors of enjoyment (*R = .62*, *R2 adjusted = .39*, *F(8, 114) = 11.38, p < .001*).\r\n \r\n\r\n \r\n**2. How do your findings relate to the theories and what do they mean?** \r\nIn the second part of your discussion, you revisit the theories and previous studies you have introduced in the introduction section and explain how your findings fit in. That means, you showcase what similarities or dissimilarities you found compared to the theories and previous studies. For example:\r\n\r\n> In line with previous studies (Johnson et al., 2015; Oliver & Raney, 2011), increased autonomy was associated with high enjoyment. ...\r\n \r\nIn the discussion section, it is particularly important to critically question your findings. Consider whether the difference in the dependent variable is really caused by the manipulation of the independent variable, or whether alternative explanations exist (e.g. confounding variables, influential variable assessed in previous studies but not in yours). Correspondingly, if you find no significant difference in the dependent variable, you need to ask yourself it this means that there is no relationship between your independent and dependent variable.\r\n \r\n**3. What are the implications of your findings, and what limitations of design exist?** \r\nThis third part of the discussion section is divided further into three subsections. \r\nFirst, you write about how your findings inform new research questions. Consider what is important or interesting to explore further. For instance, if the relationship between IV and DV was not clear in your experiment, how could a future study investigate it better? For example:\r\n\r\n> Future research may examine how to encourage players to share their feelings and thoughts evoked by game events with others. This seems especially important for serious games, as it may promote discussion of the subject. ...\r\n \r\nNext, if you think there is an implication for practitioners, who will merit from your findings and what practical relevance they have. It’s important to be specific, simply to mention that your findings have implication is not enough. For example:\r\n\r\n> Our findings have implication for researchers and practitioners wanting to evaluate long-lasting game experience. Such experiences have been argued to be difficult to assess in the long run (Lacovides & Cox, 2015). A possible work-around would be to take appreciation into account as this was found in our study to be associated to long-lasting effect. ...\r\n \r\nFinally, briefly discuss (max. 1 paragraph) the limitations of your experimental design. Consider what could be changed when replicating your study. For example:\r\n\r\n> A limitation is that the present study asked participants to recall a past game experience. But as the retrospective evaluation of an experience may differ from the moment-to-moment experience (Kahnemann & Riis, 2005), it is necessary to also explore players’ feelings and thoughts during or immediately after a gaming experience in future work.\r\n \r\n**4. Conclusion of your main implication** \r\nIn the last paragraph of the discussion section, you briefly summarize your study. In contrast to the abstract, the focus of the conclusion lies on the main findings and the main discussion points. Here, you present the take-home message for the reader of your paper. For example:\r\n\r\n> In conclusion, our results suggest that autonomy of players and appreciation of game elements play a key role in evoking positive emotions in a variety of computer games. Both factors, high autonomy and high appreciation, increase positive emotional experiences for players of both genders, especially in games involving a social component. Autonomy and appreciation thereby provide a mechanism to influence player experiences.', None, '', None, None, None, None, None, None, None, 'University of Basel', 'University of Basel', 'University of Basel', None, 'TT', '10 min.', 4, 'published', False, None, None, None, None, 21)]])}, None) {} <django_redis.cache.RedisCache object at 0x7910e287a790>
/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in run(101)
  return _run_old_run_func()

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in _run_old_run_func(94)
  return old_run_func(self, *a, **kw)

/usr/local/lib/python3.11/concurrent/futures/thread.py in _worker(83)
  work_item.run()

/usr/local/lib/python3.11/concurrent/futures/thread.py in run(58)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/corsheaders/middleware.py in __call__(56)
  result = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in middleware(32)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/allauth/account/middleware.py in middleware(36)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/simple_history/middleware.py in middleware(41)
  return get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/django_htmx/middleware.py in __call__(43)
  return self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in __call__(168)
  response = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/panels.py in process_request(41)
  return super(CachalotPanel, self).process_request(request)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in __call__(244)
  current_executor.run_until_future(call_result)

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run_until_future(81)
  work_item.run()

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run(40)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_wrapped_callback(90)
  return callback(request, *args, **kwargs)

/app/project/utils/decorators.py in apply_cache(72)
  cache.set(CACHE_KEY, response.render(), ttl)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_patched_render(41)
  return old_render(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in render(114)
  self.content = self.rendered_content

/usr/local/lib/python3.11/site-packages/sentry_sdk/utils.py in runner(1788)
  return sentry_patched_function(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/templates.py in rendered_content(77)
  return real_rendered_content.fget(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in rendered_content(92)
  return template.render(context, self._request)

/usr/local/lib/python3.11/site-packages/django/template/backends/django.py in render(61)
  return self.template.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(175)
  return self._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py in render(541)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/library.py in render(237)
  output = self.func(*resolved_args, **resolved_kwargs)

/app/project/lms_base/templatetags/utils.py in get_previous_step(105)
  return step.get_previous(published_only=True)

/app/project/lms_base/models.py in get_previous(255)
  return self._get_neighbour_step(is_next=False, published_only=published_only)

/app/project/lms_base/models.py in _get_neighbour_step(201)
  step = self.__class__.next_previous_manager.get_next_previous(

/app/project/lms_base/models.py in get_next_previous(72)
  return qs.last()

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(37)
  return original(compiler, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(96)
  return _get_result_or_execute_query(

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in _get_result_or_execute_query(71)
  cache.set_many(to_be_set, cachalot_settings.CACHALOT_TIMEOUT)

0,2377 get_many (['e3a5db5a670ad803efb866441f33de58309be2e2', '53169bc24a037802f3e42b2df3d6e48b7ae8482f', '542c27005f4e84288827ce70a7d49bc73324a5e7', '521ea13d4bffb1cab2e57fab555c3579840cd773'],) {} <django_redis.cache.RedisCache object at 0x7910e287a790>
/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in run(101)
  return _run_old_run_func()

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in _run_old_run_func(94)
  return old_run_func(self, *a, **kw)

/usr/local/lib/python3.11/concurrent/futures/thread.py in _worker(83)
  work_item.run()

/usr/local/lib/python3.11/concurrent/futures/thread.py in run(58)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/corsheaders/middleware.py in __call__(56)
  result = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in middleware(32)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/allauth/account/middleware.py in middleware(36)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/simple_history/middleware.py in middleware(41)
  return get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/django_htmx/middleware.py in __call__(43)
  return self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in __call__(168)
  response = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/panels.py in process_request(41)
  return super(CachalotPanel, self).process_request(request)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in __call__(244)
  current_executor.run_until_future(call_result)

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run_until_future(81)
  work_item.run()

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run(40)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_wrapped_callback(90)
  return callback(request, *args, **kwargs)

/app/project/utils/decorators.py in apply_cache(72)
  cache.set(CACHE_KEY, response.render(), ttl)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_patched_render(41)
  return old_render(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in render(114)
  self.content = self.rendered_content

/usr/local/lib/python3.11/site-packages/sentry_sdk/utils.py in runner(1788)
  return sentry_patched_function(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/templates.py in rendered_content(77)
  return real_rendered_content.fget(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in rendered_content(92)
  return template.render(context, self._request)

/usr/local/lib/python3.11/site-packages/django/template/backends/django.py in render(61)
  return self.template.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(175)
  return self._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py in render(541)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/library.py in render(237)
  output = self.func(*resolved_args, **resolved_kwargs)

/usr/local/lib/python3.11/site-packages/rules/templatetags/rules.py in has_perm(18)
  return user.has_perm(perm, obj)

/usr/local/lib/python3.11/site-packages/django/contrib/auth/models.py in has_perm(480)
  return _user_has_perm(self, perm, obj=obj)

/usr/local/lib/python3.11/site-packages/django/contrib/auth/models.py in _user_has_perm(220)
  if backend.has_perm(user, perm, obj):

/usr/local/lib/python3.11/site-packages/rules/permissions.py in has_perm(31)
  return has_perm(perm, user, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/rules/permissions.py in has_perm(23)
  return permissions.test_rule(name, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/rules/rulesets.py in test_rule(6)
  return name in self and self[name].test(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/rules/predicates.py in test(172)
  return bool(self._apply(*args))

/usr/local/lib/python3.11/site-packages/rules/predicates.py in _apply(235)
  result = self.fn(*callargs)

/usr/local/lib/python3.11/site-packages/rules/predicates.py in OR(184)
  return self._combine(other, operator.or_, args)

/usr/local/lib/python3.11/site-packages/rules/predicates.py in _combine(206)
  self_result = self._apply(*args)

/usr/local/lib/python3.11/site-packages/rules/predicates.py in _apply(235)
  result = self.fn(*callargs)

/app/project/lms_tales/rules.py in is_in_group(47)
  for owner in course.owner.all():

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(37)
  return original(compiler, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(96)
  return _get_result_or_execute_query(

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in _get_result_or_execute_query(46)
  data = cache.get_many(table_cache_keys + [cache_key])

0,2191 set_many ({'521ea13d4bffb1cab2e57fab555c3579840cd773': (1736871783.233756, [[(3, 'nmc_staff')]])}, None) {} <django_redis.cache.RedisCache object at 0x7910e287a790>
/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in run(101)
  return _run_old_run_func()

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in _run_old_run_func(94)
  return old_run_func(self, *a, **kw)

/usr/local/lib/python3.11/concurrent/futures/thread.py in _worker(83)
  work_item.run()

/usr/local/lib/python3.11/concurrent/futures/thread.py in run(58)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/corsheaders/middleware.py in __call__(56)
  result = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in middleware(32)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/allauth/account/middleware.py in middleware(36)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/simple_history/middleware.py in middleware(41)
  return get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/django_htmx/middleware.py in __call__(43)
  return self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in __call__(168)
  response = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/panels.py in process_request(41)
  return super(CachalotPanel, self).process_request(request)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in __call__(244)
  current_executor.run_until_future(call_result)

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run_until_future(81)
  work_item.run()

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run(40)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_wrapped_callback(90)
  return callback(request, *args, **kwargs)

/app/project/utils/decorators.py in apply_cache(72)
  cache.set(CACHE_KEY, response.render(), ttl)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_patched_render(41)
  return old_render(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in render(114)
  self.content = self.rendered_content

/usr/local/lib/python3.11/site-packages/sentry_sdk/utils.py in runner(1788)
  return sentry_patched_function(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/templates.py in rendered_content(77)
  return real_rendered_content.fget(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in rendered_content(92)
  return template.render(context, self._request)

/usr/local/lib/python3.11/site-packages/django/template/backends/django.py in render(61)
  return self.template.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(175)
  return self._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py in render(541)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/library.py in render(237)
  output = self.func(*resolved_args, **resolved_kwargs)

/usr/local/lib/python3.11/site-packages/rules/templatetags/rules.py in has_perm(18)
  return user.has_perm(perm, obj)

/usr/local/lib/python3.11/site-packages/django/contrib/auth/models.py in has_perm(480)
  return _user_has_perm(self, perm, obj=obj)

/usr/local/lib/python3.11/site-packages/django/contrib/auth/models.py in _user_has_perm(220)
  if backend.has_perm(user, perm, obj):

/usr/local/lib/python3.11/site-packages/rules/permissions.py in has_perm(31)
  return has_perm(perm, user, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/rules/permissions.py in has_perm(23)
  return permissions.test_rule(name, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/rules/rulesets.py in test_rule(6)
  return name in self and self[name].test(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/rules/predicates.py in test(172)
  return bool(self._apply(*args))

/usr/local/lib/python3.11/site-packages/rules/predicates.py in _apply(235)
  result = self.fn(*callargs)

/usr/local/lib/python3.11/site-packages/rules/predicates.py in OR(184)
  return self._combine(other, operator.or_, args)

/usr/local/lib/python3.11/site-packages/rules/predicates.py in _combine(206)
  self_result = self._apply(*args)

/usr/local/lib/python3.11/site-packages/rules/predicates.py in _apply(235)
  result = self.fn(*callargs)

/app/project/lms_tales/rules.py in is_in_group(47)
  for owner in course.owner.all():

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(37)
  return original(compiler, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(96)
  return _get_result_or_execute_query(

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in _get_result_or_execute_query(71)
  cache.set_many(to_be_set, cachalot_settings.CACHALOT_TIMEOUT)

0,2318 get_many (['e3a5db5a670ad803efb866441f33de58309be2e2', '53169bc24a037802f3e42b2df3d6e48b7ae8482f', '542c27005f4e84288827ce70a7d49bc73324a5e7', '521ea13d4bffb1cab2e57fab555c3579840cd773'],) {} <django_redis.cache.RedisCache object at 0x7910e287a790>
/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in run(101)
  return _run_old_run_func()

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in _run_old_run_func(94)
  return old_run_func(self, *a, **kw)

/usr/local/lib/python3.11/concurrent/futures/thread.py in _worker(83)
  work_item.run()

/usr/local/lib/python3.11/concurrent/futures/thread.py in run(58)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/corsheaders/middleware.py in __call__(56)
  result = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in middleware(32)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/allauth/account/middleware.py in middleware(36)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/simple_history/middleware.py in middleware(41)
  return get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/django_htmx/middleware.py in __call__(43)
  return self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in __call__(168)
  response = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/panels.py in process_request(41)
  return super(CachalotPanel, self).process_request(request)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in __call__(244)
  current_executor.run_until_future(call_result)

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run_until_future(81)
  work_item.run()

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run(40)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_wrapped_callback(90)
  return callback(request, *args, **kwargs)

/app/project/utils/decorators.py in apply_cache(72)
  cache.set(CACHE_KEY, response.render(), ttl)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_patched_render(41)
  return old_render(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in render(114)
  self.content = self.rendered_content

/usr/local/lib/python3.11/site-packages/sentry_sdk/utils.py in runner(1788)
  return sentry_patched_function(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/templates.py in rendered_content(77)
  return real_rendered_content.fget(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in rendered_content(92)
  return template.render(context, self._request)

/usr/local/lib/python3.11/site-packages/django/template/backends/django.py in render(61)
  return self.template.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(175)
  return self._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py in render(541)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/library.py in render(237)
  output = self.func(*resolved_args, **resolved_kwargs)

/usr/local/lib/python3.11/site-packages/rules/templatetags/rules.py in has_perm(18)
  return user.has_perm(perm, obj)

/usr/local/lib/python3.11/site-packages/django/contrib/auth/models.py in has_perm(480)
  return _user_has_perm(self, perm, obj=obj)

/usr/local/lib/python3.11/site-packages/django/contrib/auth/models.py in _user_has_perm(220)
  if backend.has_perm(user, perm, obj):

/usr/local/lib/python3.11/site-packages/rules/permissions.py in has_perm(31)
  return has_perm(perm, user, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/rules/permissions.py in has_perm(23)
  return permissions.test_rule(name, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/rules/rulesets.py in test_rule(6)
  return name in self and self[name].test(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/rules/predicates.py in test(172)
  return bool(self._apply(*args))

/usr/local/lib/python3.11/site-packages/rules/predicates.py in _apply(235)
  result = self.fn(*callargs)

/usr/local/lib/python3.11/site-packages/rules/predicates.py in OR(184)
  return self._combine(other, operator.or_, args)

/usr/local/lib/python3.11/site-packages/rules/predicates.py in _combine(206)
  self_result = self._apply(*args)

/usr/local/lib/python3.11/site-packages/rules/predicates.py in _apply(235)
  result = self.fn(*callargs)

/app/project/lms_tales/rules.py in is_in_group(47)
  for owner in course.owner.all():

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(37)
  return original(compiler, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(96)
  return _get_result_or_execute_query(

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in _get_result_or_execute_query(46)
  data = cache.get_many(table_cache_keys + [cache_key])

0,2716 get_many (['e3a5db5a670ad803efb866441f33de58309be2e2', '53169bc24a037802f3e42b2df3d6e48b7ae8482f', '542c27005f4e84288827ce70a7d49bc73324a5e7', '521ea13d4bffb1cab2e57fab555c3579840cd773'],) {} <django_redis.cache.RedisCache object at 0x7910e287a790>
/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in run(101)
  return _run_old_run_func()

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in _run_old_run_func(94)
  return old_run_func(self, *a, **kw)

/usr/local/lib/python3.11/concurrent/futures/thread.py in _worker(83)
  work_item.run()

/usr/local/lib/python3.11/concurrent/futures/thread.py in run(58)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/corsheaders/middleware.py in __call__(56)
  result = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in middleware(32)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/allauth/account/middleware.py in middleware(36)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/simple_history/middleware.py in middleware(41)
  return get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/django_htmx/middleware.py in __call__(43)
  return self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in __call__(168)
  response = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/panels.py in process_request(41)
  return super(CachalotPanel, self).process_request(request)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in __call__(244)
  current_executor.run_until_future(call_result)

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run_until_future(81)
  work_item.run()

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run(40)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_wrapped_callback(90)
  return callback(request, *args, **kwargs)

/app/project/utils/decorators.py in apply_cache(72)
  cache.set(CACHE_KEY, response.render(), ttl)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_patched_render(41)
  return old_render(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in render(114)
  self.content = self.rendered_content

/usr/local/lib/python3.11/site-packages/sentry_sdk/utils.py in runner(1788)
  return sentry_patched_function(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/templates.py in rendered_content(77)
  return real_rendered_content.fget(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in rendered_content(92)
  return template.render(context, self._request)

/usr/local/lib/python3.11/site-packages/django/template/backends/django.py in render(61)
  return self.template.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(175)
  return self._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py in render(541)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/library.py in render(237)
  output = self.func(*resolved_args, **resolved_kwargs)

/usr/local/lib/python3.11/site-packages/rules/templatetags/rules.py in has_perm(18)
  return user.has_perm(perm, obj)

/usr/local/lib/python3.11/site-packages/django/contrib/auth/models.py in has_perm(480)
  return _user_has_perm(self, perm, obj=obj)

/usr/local/lib/python3.11/site-packages/django/contrib/auth/models.py in _user_has_perm(220)
  if backend.has_perm(user, perm, obj):

/usr/local/lib/python3.11/site-packages/rules/permissions.py in has_perm(31)
  return has_perm(perm, user, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/rules/permissions.py in has_perm(23)
  return permissions.test_rule(name, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/rules/rulesets.py in test_rule(6)
  return name in self and self[name].test(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/rules/predicates.py in test(172)
  return bool(self._apply(*args))

/usr/local/lib/python3.11/site-packages/rules/predicates.py in _apply(235)
  result = self.fn(*callargs)

/usr/local/lib/python3.11/site-packages/rules/predicates.py in OR(184)
  return self._combine(other, operator.or_, args)

/usr/local/lib/python3.11/site-packages/rules/predicates.py in _combine(206)
  self_result = self._apply(*args)

/usr/local/lib/python3.11/site-packages/rules/predicates.py in _apply(235)
  result = self.fn(*callargs)

/app/project/lms_tales/rules.py in is_in_group(47)
  for owner in course.owner.all():

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(37)
  return original(compiler, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(96)
  return _get_result_or_execute_query(

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in _get_result_or_execute_query(46)
  data = cache.get_many(table_cache_keys + [cache_key])

0,2164 get ('waffle:4.1.0f1f61030d824f38a8926961f0e221887',) {} <django_redis.cache.RedisCache object at 0x7910e287a790>
/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in run(101)
  return _run_old_run_func()

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in _run_old_run_func(94)
  return old_run_func(self, *a, **kw)

/usr/local/lib/python3.11/concurrent/futures/thread.py in _worker(83)
  work_item.run()

/usr/local/lib/python3.11/concurrent/futures/thread.py in run(58)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/corsheaders/middleware.py in __call__(56)
  result = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in middleware(32)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/allauth/account/middleware.py in middleware(36)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/simple_history/middleware.py in middleware(41)
  return get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/django_htmx/middleware.py in __call__(43)
  return self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in __call__(168)
  response = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/panels.py in process_request(41)
  return super(CachalotPanel, self).process_request(request)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in __call__(244)
  current_executor.run_until_future(call_result)

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run_until_future(81)
  work_item.run()

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run(40)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_wrapped_callback(90)
  return callback(request, *args, **kwargs)

/app/project/utils/decorators.py in apply_cache(72)
  cache.set(CACHE_KEY, response.render(), ttl)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_patched_render(41)
  return old_render(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in render(114)
  self.content = self.rendered_content

/usr/local/lib/python3.11/site-packages/sentry_sdk/utils.py in runner(1788)
  return sentry_patched_function(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/templates.py in rendered_content(77)
  return real_rendered_content.fget(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in rendered_content(92)
  return template.render(context, self._request)

/usr/local/lib/python3.11/site-packages/django/template/backends/django.py in render(61)
  return self.template.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(175)
  return self._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py in render(541)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/waffle/templatetags/waffle_tags.py in render(36)
  if self.condition(context.get('request', None), name):

/usr/local/lib/python3.11/site-packages/waffle/__init__.py in flag_is_active(19)
  flag = get_waffle_flag_model().get(flag_name)

/usr/local/lib/python3.11/site-packages/waffle/models.py in get(52)
  cached = cache.get(cache_key)

0,2683 add ('waffle:4.1.0f1f61030d824f38a8926961f0e221887', <Flag: show_language_warning>) {} <django_redis.cache.RedisCache object at 0x7910e287a790>
/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in run(101)
  return _run_old_run_func()

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in _run_old_run_func(94)
  return old_run_func(self, *a, **kw)

/usr/local/lib/python3.11/concurrent/futures/thread.py in _worker(83)
  work_item.run()

/usr/local/lib/python3.11/concurrent/futures/thread.py in run(58)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/corsheaders/middleware.py in __call__(56)
  result = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in middleware(32)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/allauth/account/middleware.py in middleware(36)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/simple_history/middleware.py in middleware(41)
  return get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/django_htmx/middleware.py in __call__(43)
  return self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in __call__(168)
  response = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/panels.py in process_request(41)
  return super(CachalotPanel, self).process_request(request)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in __call__(244)
  current_executor.run_until_future(call_result)

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run_until_future(81)
  work_item.run()

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run(40)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_wrapped_callback(90)
  return callback(request, *args, **kwargs)

/app/project/utils/decorators.py in apply_cache(72)
  cache.set(CACHE_KEY, response.render(), ttl)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_patched_render(41)
  return old_render(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in render(114)
  self.content = self.rendered_content

/usr/local/lib/python3.11/site-packages/sentry_sdk/utils.py in runner(1788)
  return sentry_patched_function(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/templates.py in rendered_content(77)
  return real_rendered_content.fget(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in rendered_content(92)
  return template.render(context, self._request)

/usr/local/lib/python3.11/site-packages/django/template/backends/django.py in render(61)
  return self.template.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(175)
  return self._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py in render(541)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/waffle/templatetags/waffle_tags.py in render(36)
  if self.condition(context.get('request', None), name):

/usr/local/lib/python3.11/site-packages/waffle/__init__.py in flag_is_active(19)
  flag = get_waffle_flag_model().get(flag_name)

/usr/local/lib/python3.11/site-packages/waffle/models.py in get(64)
  cache.add(cache_key, obj)

0,2499 get_many (['e3a5db5a670ad803efb866441f33de58309be2e2', '76e323efd8711853e13c9f7cf976845908364eb2', '7c96801406a29fc885cf03b6207bb9d544331c61'],) {} <django_redis.cache.RedisCache object at 0x7910e287a790>
/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in run(101)
  return _run_old_run_func()

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in _run_old_run_func(94)
  return old_run_func(self, *a, **kw)

/usr/local/lib/python3.11/concurrent/futures/thread.py in _worker(83)
  work_item.run()

/usr/local/lib/python3.11/concurrent/futures/thread.py in run(58)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/corsheaders/middleware.py in __call__(56)
  result = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in middleware(32)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/allauth/account/middleware.py in middleware(36)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/simple_history/middleware.py in middleware(41)
  return get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/django_htmx/middleware.py in __call__(43)
  return self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in __call__(168)
  response = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/panels.py in process_request(41)
  return super(CachalotPanel, self).process_request(request)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in __call__(244)
  current_executor.run_until_future(call_result)

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run_until_future(81)
  work_item.run()

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run(40)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_wrapped_callback(90)
  return callback(request, *args, **kwargs)

/app/project/utils/decorators.py in apply_cache(72)
  cache.set(CACHE_KEY, response.render(), ttl)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_patched_render(41)
  return old_render(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in render(114)
  self.content = self.rendered_content

/usr/local/lib/python3.11/site-packages/sentry_sdk/utils.py in runner(1788)
  return sentry_patched_function(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/templates.py in rendered_content(77)
  return real_rendered_content.fget(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in rendered_content(92)
  return template.render(context, self._request)

/usr/local/lib/python3.11/site-packages/django/template/backends/django.py in render(61)
  return self.template.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(175)
  return self._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py in render(541)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1064)
  output = self.filter_expression.resolve(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in resolve(715)
  obj = self.var.resolve(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in resolve(847)
  value = self._resolve_lookup(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in _resolve_lookup(914)
  current = current()

/app/project/lms_tales/models.py in get_step_number(107)
  chapter_list = list(

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(37)
  return original(compiler, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(96)
  return _get_result_or_execute_query(

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in _get_result_or_execute_query(46)
  data = cache.get_many(table_cache_keys + [cache_key])

0,2460 set_many ({'7c96801406a29fc885cf03b6207bb9d544331c61': (1736871783.248013, [[(20, datetime.datetime(2020, 11, 2, 15, 9, 33, 545649, tzinfo=datetime.timezone.utc), datetime.datetime(2020, 11, 2, 15, 9, 38, 575786, tzinfo=datetime.timezone.utc), datetime.datetime(2020, 11, 2, 15, 9, 38, 575816, tzinfo=datetime.timezone.utc), False, 'Research questions and theories', 'Research questions and theories', 'Research questions and theories', None, 'research-questions-and-theories', 0, 'published', 6), (19, datetime.datetime(2020, 11, 2, 15, 9, 33, 545649, tzinfo=datetime.timezone.utc), datetime.datetime(2020, 11, 2, 15, 9, 38, 576980, tzinfo=datetime.timezone.utc), datetime.datetime(2020, 11, 2, 15, 9, 38, 576990, tzinfo=datetime.timezone.utc), False, 'Design your experiment', 'Design your experiment', 'Design your experiment', None, 'design-your-experiment', 1, 'published', 6), (21, datetime.datetime(2020, 11, 2, 15, 9, 33, 545649, tzinfo=datetime.timezone.utc), datetime.datetime(2020, 11, 2, 15, 9, 38, 578149, tzinfo=datetime.timezone.utc), datetime.datetime(2020, 11, 2, 15, 9, 38, 578160, tzinfo=datetime.timezone.utc), False, 'Writing a scientific report', 'Writing a scientific report', 'Writing a scientific report', None, 'writing-a-scientific-report', 2, 'published', 6), (22, datetime.datetime(2020, 11, 2, 15, 9, 33, 545649, tzinfo=datetime.timezone.utc), datetime.datetime(2020, 11, 2, 15, 9, 38, 579443, tzinfo=datetime.timezone.utc), datetime.datetime(2020, 11, 2, 15, 9, 38, 579454, tzinfo=datetime.timezone.utc), False, 'Statistics and analyses', 'Statistics and analyses', 'Statistics and analyses', None, 'statistics-and-analyses', 3, 'published', 6)]])}, None) {} <django_redis.cache.RedisCache object at 0x7910e287a790>
/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in run(101)
  return _run_old_run_func()

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in _run_old_run_func(94)
  return old_run_func(self, *a, **kw)

/usr/local/lib/python3.11/concurrent/futures/thread.py in _worker(83)
  work_item.run()

/usr/local/lib/python3.11/concurrent/futures/thread.py in run(58)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/corsheaders/middleware.py in __call__(56)
  result = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in middleware(32)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/allauth/account/middleware.py in middleware(36)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/simple_history/middleware.py in middleware(41)
  return get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/django_htmx/middleware.py in __call__(43)
  return self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in __call__(168)
  response = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/panels.py in process_request(41)
  return super(CachalotPanel, self).process_request(request)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in __call__(244)
  current_executor.run_until_future(call_result)

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run_until_future(81)
  work_item.run()

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run(40)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_wrapped_callback(90)
  return callback(request, *args, **kwargs)

/app/project/utils/decorators.py in apply_cache(72)
  cache.set(CACHE_KEY, response.render(), ttl)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_patched_render(41)
  return old_render(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in render(114)
  self.content = self.rendered_content

/usr/local/lib/python3.11/site-packages/sentry_sdk/utils.py in runner(1788)
  return sentry_patched_function(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/templates.py in rendered_content(77)
  return real_rendered_content.fget(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in rendered_content(92)
  return template.render(context, self._request)

/usr/local/lib/python3.11/site-packages/django/template/backends/django.py in render(61)
  return self.template.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(175)
  return self._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py in render(541)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1064)
  output = self.filter_expression.resolve(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in resolve(715)
  obj = self.var.resolve(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in resolve(847)
  value = self._resolve_lookup(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in _resolve_lookup(914)
  current = current()

/app/project/lms_tales/models.py in get_step_number(107)
  chapter_list = list(

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(37)
  return original(compiler, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(96)
  return _get_result_or_execute_query(

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in _get_result_or_execute_query(71)
  cache.set_many(to_be_set, cachalot_settings.CACHALOT_TIMEOUT)

0,4291 get_many (['76e323efd8711853e13c9f7cf976845908364eb2', '138549f5508bbba7283d6a0625e51c589d845e8f', 'e8fbcaca54a4b5a8e72836985647a60b875b3793'],) {} <django_redis.cache.RedisCache object at 0x7910e287a790>
/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in run(101)
  return _run_old_run_func()

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in _run_old_run_func(94)
  return old_run_func(self, *a, **kw)

/usr/local/lib/python3.11/concurrent/futures/thread.py in _worker(83)
  work_item.run()

/usr/local/lib/python3.11/concurrent/futures/thread.py in run(58)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/corsheaders/middleware.py in __call__(56)
  result = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in middleware(32)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/allauth/account/middleware.py in middleware(36)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/simple_history/middleware.py in middleware(41)
  return get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/django_htmx/middleware.py in __call__(43)
  return self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in __call__(168)
  response = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/panels.py in process_request(41)
  return super(CachalotPanel, self).process_request(request)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in __call__(244)
  current_executor.run_until_future(call_result)

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run_until_future(81)
  work_item.run()

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run(40)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_wrapped_callback(90)
  return callback(request, *args, **kwargs)

/app/project/utils/decorators.py in apply_cache(72)
  cache.set(CACHE_KEY, response.render(), ttl)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_patched_render(41)
  return old_render(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in render(114)
  self.content = self.rendered_content

/usr/local/lib/python3.11/site-packages/sentry_sdk/utils.py in runner(1788)
  return sentry_patched_function(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/templates.py in rendered_content(77)
  return real_rendered_content.fget(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in rendered_content(92)
  return template.render(context, self._request)

/usr/local/lib/python3.11/site-packages/django/template/backends/django.py in render(61)
  return self.template.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(175)
  return self._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py in render(541)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1064)
  output = self.filter_expression.resolve(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in resolve(715)
  obj = self.var.resolve(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in resolve(847)
  value = self._resolve_lookup(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in _resolve_lookup(914)
  current = current()

/app/project/lms_tales/models.py in get_step_number(118)
  step_list = list(self.chapter.published_steps.all().order_by("order"))

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(37)
  return original(compiler, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(96)
  return _get_result_or_execute_query(

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in _get_result_or_execute_query(46)
  data = cache.get_many(table_cache_keys + [cache_key])

1,1034 set_many ({'e8fbcaca54a4b5a8e72836985647a60b875b3793': (1736871783.2550242, [[(50, datetime.datetime(2020, 11, 2, 15, 9, 33, 774510, tzinfo=datetime.timezone.utc), datetime.datetime(2020, 11, 2, 15, 9, 37, 368340, tzinfo=datetime.timezone.utc), datetime.datetime(2020, 11, 2, 15, 9, 37, 368351, tzinfo=datetime.timezone.utc), False, 'Structuring a scientific paper', 'Structuring a scientific paper', 'Structuring a scientific paper', None, '', '', None, None, '', None, None, None, 'conducting-psychological-research/writing-a-scientific-report/structuring-a-scientific-paper/offenes_buch.jpg', 'structuring-a-scientific-paper', 'In this article we will give you a short overview about how to set up your final paper according to the guidelines of the American Psychological Association (APA) and the sections of your article.\r\n{.lead}\r\n\r\nAn APA article has a predefined number of sections and a certain formatting. The structure contains the first-level headings: Abstract, Introduction, Method, Results, Discussion, Implications/Conclusion and References. \r\n\r\nWe compiled a PDF with a beginner’s guide to APA that you find in the ‘downloads’ section below.', 'In this article we will give you a short overview about how to set up your final paper according to the guidelines of the American Psychological Association (APA) and the sections of your article.\r\n{.lead}\r\n\r\nAn APA article has a predefined number of sections and a certain formatting. The structure contains the first-level headings: Abstract, Introduction, Method, Results, Discussion, Implications/Conclusion and References. \r\n\r\nWe compiled a PDF with a beginner’s guide to APA that you find in the ‘downloads’ section below.', 'In this article we will give you a short overview about how to set up your final paper according to the guidelines of the American Psychological Association (APA) and the sections of your article.\r\n{.lead}\r\n\r\nAn APA article has a predefined number of sections and a certain formatting. The structure contains the first-level headings: Abstract, Introduction, Method, Results, Discussion, Implications/Conclusion and References. \r\n\r\nWe compiled a PDF with a beginner’s guide to APA that you find in the ‘downloads’ section below.', '', '', None, None, None, None, None, None, None, 'University of Basel', 'University of Basel', 'University of Basel', '', 'TT', '10 min.', 0, 'published', False, None, None, None, None, 21), (68, datetime.datetime(2020, 11, 2, 15, 9, 33, 774510, tzinfo=datetime.timezone.utc), datetime.datetime(2021, 11, 30, 8, 25, 14, 46017, tzinfo=datetime.timezone.utc), datetime.datetime(2021, 11, 30, 8, 25, 14, 19941, tzinfo=datetime.timezone.utc), False, 'How to write introductions and theory sections', 'How to write introductions and theory sections', 'How to write introductions and theory sections', None, '', None, None, None, '', None, None, None, '', 'how-to-write-introductions-and-theory-sections', "Let us show you briefly how to write a paper. You should supplement this reading with more detailed literature, such as the book by Peter Harris ‘Designing and reporting experiments in Psychology’.\r\n{.lead}\r\n \r\n**Preliminary remarks** \r\nA brief word on the order in which you want to arrange different parts of your introduction: many of the main textbooks (including the book by Harris) will encourage you to think of your introduction like a funnel. This means you start very broad and basic and then become more and more specific. This is in principle a good method to follow. However, always remember that it is crucial for the readers to get hooked on early, as they may get bored or worse: stop reading. Therefore, it is always good to start your introduction with a short and precise ‘Why care?’ sentence or paragraph. Basically, you want catch the readers’ interest within the very first sentences.\r\n \r\n**Relevance of the study** \r\nYou may want to consider opening your introduction with one of the following four reasons why you consider your study as relevant. \r\n**Motive 1: Practical (current) importance** (for example: ‘Brexit has shown that…’, ‘Trump’s 2017 election was a sign that…’) \r\n**Motive 2: Contribution to an ongoing debate in the literature** (for example: ‘There is mixed evidence in the literature about how people decide between choice alternatives depending on their mood.’) \r\n**Motive 3: Understand outstanding phenomena** (your work has potential to elucidate mechanisms for phenomena or patterns that are extraordinary or outstanding, for example: ‘Humans are remarkable at recognizing faces, however we don’t fully understand how they do it.’) \r\n**Motive 4: Understand problematic phenomena** (your work potential identifies and addresses mechanisms for phenomena or patterns that are considered problematic, pathological or the source of harm, for example: ‘Humans often deviate from economic rationality and make decisions which incur substantial losses, but we do not fully understand the factors contributing to such disadvantageous decision making.’) \r\n \r\nOne way to start your paper in an attention-grabbing way is to ask a direct question. This makes the readers curious and the chance that they continue their reading is bigger. Once you have grabbed your readers’ attention, you can limit the scope of your subject and ‘start thinking funnel’!\r\n\r\n**Literature review (ca. 2-4 pages)** \r\nAs a next step, you need to write a literature review. It **summarizes relevant theories and research findings**. The emphasis here lies on the word **relevant**. Don’t try to impress the readers with tons of literature. They only will be satisfied if you are able to precisely summarize the main studies, results, debates, theories in your field of interest.\r\n\r\nIt may be hard to decide which studies to include and which to leave out, because of the large body of literature. It may help to ask yourself whether a study is **directly relevant** for your work or whether it is not. The former should be included, the latter should probably be left out. How is it possible to differentiate between these two? If the findings of the study you want to review directly address your research question, it must be included. If the findings address different questions, they probably can be left out. A good starting point is to include meta-analyses, reviews, as well as the most cited and most recent works that are directly related to your research question. This does NOT mean you should ignore original papers or only look at publications from the past five years! A well-balanced and well-informed literature review often spans many decades, fields and ideas, but recent papers usually give you a good starting point for your own literature search.\r\n \r\nOnce you have decided on the materials that will form the content of your introduction, the summary you provide must be as precise, short and informative as possible. Here are some advices to reach this goal: \r\n➔ First, make sure you **introduce the theoretical framework before you present empirical studies**. A good introduction does not simply list research findings, but states the main theoretical framework(s) first and then summarizes the evidence for, or against, a certain theory. \r\n➔ Be aware of the **difference between theory and evidence**. This is an important distinction. Evidence or research findings only provide a specific pattern in your data, perhaps the mean difference between two groups or the effect of one variable on another. Theory in contrast suggests what patterns are to be expected given certain assumptions about the underlying mechanisms. Put differently, evidence pertains to what you observe in your data, whereas theory pertains to what you would expect, possible interpretations, and how or why you would expect certain observations. \r\n➔ A good introduction not only describes but **critically evaluates prior work**, which is only possible if you establish the criteria for your evaluation. Your evaluation criteria should be immediately transparent to the readers by delineating your theoretical framework. This provides the boundaries and conditions for your expectations. \r\n \r\nIf your work aims to directly test a theory or pit theories against each other, you will automatically include a theory section. However, you may have a situation where there is no (or no useful) theory. In this case it can help to shift your focus and delve into other fields. For example, you may be interested in the effect of hormones on risk taking, but you may also find a lot of relevant research if you look at studies investigating the link between personality, impulsivity, or self-control. Some of these differences may be purely semantic and rooted in different fields using different terminology for ostensibly the same thing. But this is not always the case and you may find a lot of useful theory if you cross over to related research topics.\r\n \r\n**Writing tip**: do not use vague words. Instead you should define key terms for your readers. It is better to define too much than too little. The definition can be in parenthesis, between hyphens, commas, or as a single sentence. For example:\r\n\r\n>The current work investigates prosocial behavior (people acting benevolently for others without a direct or indirect reward). \r\n>\r\n>We study the influence of shame - feeling emotionally uncomfortable after doing something - on consumer behavior. \r\n>\r\n>Risk-taking is an important topic in psychology. Throughout this paper risk-taking is defined as selecting actions with great variability in consequences. \r\n\r\nYou can improve your writing style by using standard phrases that writers use in academic writing. Check out sentences, which occur again and again in papers that you read (it is okay to use these phrases). Or use sources that provide you with such phrases, such as the [Academic Phrasebank](http://www.phrasebank.manchester.ac.uk/).\r\n\r\n**Introduce your research question (ca. 1-4 paragraphs)** \r\nAfter you have introduced and critically evaluated the current state of research, it is time to present and justify your research question. Explain the readers what is currently not known, debated or unclear, reveal the research gaps in the literature, and thereby create your niche. Where does a current theory (the one that you have reviewed before) fall short? Perhaps a prominent theory has not been tested thoroughly? Do two theories predict opposite patterns in the data? In formulating your research question, you position your research and make explicit why your work matters. Remember: you want to keep the readers interested, so if you can show why your work is essential and/or has implications for (e.g. clinical) applications, you have successfully motivated your work. Therefore it helps to ask yourself and answer the following questions: \r\n<br/>\r\n1. How does my work contribute to the current literature? \r\n2. How does my work contribute to or build on existing work? \r\n3. What research gap does my work close, how is my work related to other studies? \r\n \r\nYou can provide a **brief overview of your study** here, perhaps to show why it differs from previous work (different data? different design? different participants? etc.) or how you are going to close the gap you identified while motivating your work. Important: do not provide details, this is what the method section is for. But if there is anything special about your study, say so, it keeps the readers interested.\r\n\r\n**State your research hypothesis (ca. 1-2 paragraphs)** \r\nNow, you are almost finished writing your introduction. The only thing missing is to succinctly **state your research hypothesis**. This means, you need to tell the readers what results you expect from your study. It should be clear by now that the theories you mentioned before have to logically lead to the answers to the hypothesis (see [1.2 How to find theories and hypothesis](https://tales.nmc.unibas.ch/de/conducting-psychological-research-6/research-questions-and-theories-20/how-to-find-theories-and-hypothesis-52)). Previous findings can of course also guide your expectations, but these should ideally be discussed with reference to your theory.\r\n\r\nIf you want to **pitch two theories against each other**, here is an example how you could formulate this: ‘According to the ‘mood maintenance hypothesis’, positive affect will result in risk averse behaviour, whereas according to the ‘affect infusion model’ positive affect will result in risk seeking behaviour.’\r\n \r\nMake sure you use the appropriate terminology, such as **one-sided (directed) hypothesis** or **two-sided (undirected) hypothesis**, and distinguish between the **experimental and null hypothesis**. If you are unsure what these terms refer to, please consult Peter Harris’ 'Designing and reporting experiments in Psychology'.\r\n\r\nBefore you finish, check if everything you mention in your hypothesis appears at least once in the paragraphs before the hypothesis. It is a mistake if your hypothesis introduce new concepts or new theories. In the example above for instance, it would be a mistake if the mood maintenance hypothesis had not been explained before.\r\n\r\n<br/>\r\n\r\n------\r\n\r\n###References \r\n\r\nHarris, P. (2008). *Designing and reporting experiments in psychology*. McGraw-Hill Education (UK).\r\n{.citation-indented}", "Let us show you briefly how to write a paper. You should supplement this reading with more detailed literature, such as the book by Peter Harris ‘Designing and reporting experiments in Psychology’.\r\n{.lead}\r\n \r\n**Preliminary remarks** \r\nA brief word on the order in which you want to arrange different parts of your introduction: many of the main textbooks (including the book by Harris) will encourage you to think of your introduction like a funnel. This means you start very broad and basic and then become more and more specific. This is in principle a good method to follow. However, always remember that it is crucial for the readers to get hooked on early, as they may get bored or worse: stop reading. Therefore, it is always good to start your introduction with a short and precise ‘Why care?’ sentence or paragraph. Basically, you want catch the readers’ interest within the very first sentences.\r\n \r\n**Relevance of the study** \r\nYou may want to consider opening your introduction with one of the following four reasons why you consider your study as relevant. \r\n**Motive 1: Practical (current) importance** (for example: ‘Brexit has shown that…’, ‘Trump’s 2017 election was a sign that…’) \r\n**Motive 2: Contribution to an ongoing debate in the literature** (for example: ‘There is mixed evidence in the literature about how people decide between choice alternatives depending on their mood.’) \r\n**Motive 3: Understand outstanding phenomena** (your work has potential to elucidate mechanisms for phenomena or patterns that are extraordinary or outstanding, for example: ‘Humans are remarkable at recognizing faces, however we don’t fully understand how they do it.’) \r\n**Motive 4: Understand problematic phenomena** (your work potential identifies and addresses mechanisms for phenomena or patterns that are considered problematic, pathological or the source of harm, for example: ‘Humans often deviate from economic rationality and make decisions which incur substantial losses, but we do not fully understand the factors contributing to such disadvantageous decision making.’) \r\n \r\nOne way to start your paper in an attention-grabbing way is to ask a direct question. This makes the readers curious and the chance that they continue their reading is bigger. Once you have grabbed your readers’ attention, you can limit the scope of your subject and ‘start thinking funnel’!\r\n\r\n**Literature review (ca. 2-4 pages)** \r\nAs a next step, you need to write a literature review. It **summarizes relevant theories and research findings**. The emphasis here lies on the word **relevant**. Don’t try to impress the readers with tons of literature. They only will be satisfied if you are able to precisely summarize the main studies, results, debates, theories in your field of interest.\r\n\r\nIt may be hard to decide which studies to include and which to leave out, because of the large body of literature. It may help to ask yourself whether a study is **directly relevant** for your work or whether it is not. The former should be included, the latter should probably be left out. How is it possible to differentiate between these two? If the findings of the study you want to review directly address your research question, it must be included. If the findings address different questions, they probably can be left out. A good starting point is to include meta-analyses, reviews, as well as the most cited and most recent works that are directly related to your research question. This does NOT mean you should ignore original papers or only look at publications from the past five years! A well-balanced and well-informed literature review often spans many decades, fields and ideas, but recent papers usually give you a good starting point for your own literature search.\r\n \r\nOnce you have decided on the materials that will form the content of your introduction, the summary you provide must be as precise, short and informative as possible. Here are some advices to reach this goal: \r\n➔ First, make sure you **introduce the theoretical framework before you present empirical studies**. A good introduction does not simply list research findings, but states the main theoretical framework(s) first and then summarizes the evidence for, or against, a certain theory. \r\n➔ Be aware of the **difference between theory and evidence**. This is an important distinction. Evidence or research findings only provide a specific pattern in your data, perhaps the mean difference between two groups or the effect of one variable on another. Theory in contrast suggests what patterns are to be expected given certain assumptions about the underlying mechanisms. Put differently, evidence pertains to what you observe in your data, whereas theory pertains to what you would expect, possible interpretations, and how or why you would expect certain observations. \r\n➔ A good introduction not only describes but **critically evaluates prior work**, which is only possible if you establish the criteria for your evaluation. Your evaluation criteria should be immediately transparent to the readers by delineating your theoretical framework. This provides the boundaries and conditions for your expectations. \r\n \r\nIf your work aims to directly test a theory or pit theories against each other, you will automatically include a theory section. However, you may have a situation where there is no (or no useful) theory. In this case it can help to shift your focus and delve into other fields. For example, you may be interested in the effect of hormones on risk taking, but you may also find a lot of relevant research if you look at studies investigating the link between personality, impulsivity, or self-control. Some of these differences may be purely semantic and rooted in different fields using different terminology for ostensibly the same thing. But this is not always the case and you may find a lot of useful theory if you cross over to related research topics.\r\n \r\n**Writing tip**: do not use vague words. Instead you should define key terms for your readers. It is better to define too much than too little. The definition can be in parenthesis, between hyphens, commas, or as a single sentence. For example:\r\n\r\n>The current work investigates prosocial behavior (people acting benevolently for others without a direct or indirect reward). \r\n>\r\n>We study the influence of shame - feeling emotionally uncomfortable after doing something - on consumer behavior. \r\n>\r\n>Risk-taking is an important topic in psychology. Throughout this paper risk-taking is defined as selecting actions with great variability in consequences. \r\n\r\nYou can improve your writing style by using standard phrases that writers use in academic writing. Check out sentences, which occur again and again in papers that you read (it is okay to use these phrases). Or use sources that provide you with such phrases, such as the [Academic Phrasebank](http://www.phrasebank.manchester.ac.uk/).\r\n\r\n**Introduce your research question (ca. 1-4 paragraphs)** \r\nAfter you have introduced and critically evaluated the current state of research, it is time to present and justify your research question. Explain the readers what is currently not known, debated or unclear, reveal the research gaps in the literature, and thereby create your niche. Where does a current theory (the one that you have reviewed before) fall short? Perhaps a prominent theory has not been tested thoroughly? Do two theories predict opposite patterns in the data? In formulating your research question, you position your research and make explicit why your work matters. Remember: you want to keep the readers interested, so if you can show why your work is essential and/or has implications for (e.g. clinical) applications, you have successfully motivated your work. Therefore it helps to ask yourself and answer the following questions: \r\n<br/>\r\n1. How does my work contribute to the current literature? \r\n2. How does my work contribute to or build on existing work? \r\n3. What research gap does my work close, how is my work related to other studies? \r\n \r\nYou can provide a **brief overview of your study** here, perhaps to show why it differs from previous work (different data? different design? different participants? etc.) or how you are going to close the gap you identified while motivating your work. Important: do not provide details, this is what the method section is for. But if there is anything special about your study, say so, it keeps the readers interested.\r\n\r\n**State your research hypothesis (ca. 1-2 paragraphs)** \r\nNow, you are almost finished writing your introduction. The only thing missing is to succinctly **state your research hypothesis**. This means, you need to tell the readers what results you expect from your study. It should be clear by now that the theories you mentioned before have to logically lead to the answers to the hypothesis (see [1.2 How to find theories and hypothesis](https://tales.nmc.unibas.ch/de/conducting-psychological-research-6/research-questions-and-theories-20/how-to-find-theories-and-hypothesis-52)). Previous findings can of course also guide your expectations, but these should ideally be discussed with reference to your theory.\r\n\r\nIf you want to **pitch two theories against each other**, here is an example how you could formulate this: ‘According to the ‘mood maintenance hypothesis’, positive affect will result in risk averse behaviour, whereas according to the ‘affect infusion model’ positive affect will result in risk seeking behaviour.’\r\n \r\nMake sure you use the appropriate terminology, such as **one-sided (directed) hypothesis** or **two-sided (undirected) hypothesis**, and distinguish between the **experimental and null hypothesis**. If you are unsure what these terms refer to, please consult Peter Harris’ 'Designing and reporting experiments in Psychology'.\r\n\r\nBefore you finish, check if everything you mention in your hypothesis appears at least once in the paragraphs before the hypothesis. It is a mistake if your hypothesis introduce new concepts or new theories. In the example above for instance, it would be a mistake if the mood maintenance hypothesis had not been explained before.\r\n\r\n<br/>\r\n\r\n------\r\n\r\n###References \r\n\r\nHarris, P. (2008). *Designing and reporting experiments in psychology*. McGraw-Hill Education (UK).\r\n{.citation-indented}", "Let us show you briefly how to write a paper. You should supplement this reading with more detailed literature, such as the book by Peter Harris ‘Designing and reporting experiments in Psychology’.\r\n{.lead}\r\n \r\n**Preliminary remarks** \r\nA brief word on the order in which you want to arrange different parts of your introduction: many of the main textbooks (including the book by Harris) will encourage you to think of your introduction like a funnel. This means you start very broad and basic and then become more and more specific. This is in principle a good method to follow. However, always remember that it is crucial for the readers to get hooked on early, as they may get bored or worse: stop reading. Therefore, it is always good to start your introduction with a short and precise ‘Why care?’ sentence or paragraph. Basically, you want catch the readers’ interest within the very first sentences.\r\n \r\n**Relevance of the study** \r\nYou may want to consider opening your introduction with one of the following four reasons why you consider your study as relevant. \r\n**Motive 1: Practical (current) importance** (for example: ‘Brexit has shown that…’, ‘Trump’s 2017 election was a sign that…’) \r\n**Motive 2: Contribution to an ongoing debate in the literature** (for example: ‘There is mixed evidence in the literature about how people decide between choice alternatives depending on their mood.’) \r\n**Motive 3: Understand outstanding phenomena** (your work has potential to elucidate mechanisms for phenomena or patterns that are extraordinary or outstanding, for example: ‘Humans are remarkable at recognizing faces, however we don’t fully understand how they do it.’) \r\n**Motive 4: Understand problematic phenomena** (your work potential identifies and addresses mechanisms for phenomena or patterns that are considered problematic, pathological or the source of harm, for example: ‘Humans often deviate from economic rationality and make decisions which incur substantial losses, but we do not fully understand the factors contributing to such disadvantageous decision making.’) \r\n \r\nOne way to start your paper in an attention-grabbing way is to ask a direct question. This makes the readers curious and the chance that they continue their reading is bigger. Once you have grabbed your readers’ attention, you can limit the scope of your subject and ‘start thinking funnel’!\r\n\r\n**Literature review (ca. 2-4 pages)** \r\nAs a next step, you need to write a literature review. It **summarizes relevant theories and research findings**. The emphasis here lies on the word **relevant**. Don’t try to impress the readers with tons of literature. They only will be satisfied if you are able to precisely summarize the main studies, results, debates, theories in your field of interest.\r\n\r\nIt may be hard to decide which studies to include and which to leave out, because of the large body of literature. It may help to ask yourself whether a study is **directly relevant** for your work or whether it is not. The former should be included, the latter should probably be left out. How is it possible to differentiate between these two? If the findings of the study you want to review directly address your research question, it must be included. If the findings address different questions, they probably can be left out. A good starting point is to include meta-analyses, reviews, as well as the most cited and most recent works that are directly related to your research question. This does NOT mean you should ignore original papers or only look at publications from the past five years! A well-balanced and well-informed literature review often spans many decades, fields and ideas, but recent papers usually give you a good starting point for your own literature search.\r\n \r\nOnce you have decided on the materials that will form the content of your introduction, the summary you provide must be as precise, short and informative as possible. Here are some advices to reach this goal: \r\n➔ First, make sure you **introduce the theoretical framework before you present empirical studies**. A good introduction does not simply list research findings, but states the main theoretical framework(s) first and then summarizes the evidence for, or against, a certain theory. \r\n➔ Be aware of the **difference between theory and evidence**. This is an important distinction. Evidence or research findings only provide a specific pattern in your data, perhaps the mean difference between two groups or the effect of one variable on another. Theory in contrast suggests what patterns are to be expected given certain assumptions about the underlying mechanisms. Put differently, evidence pertains to what you observe in your data, whereas theory pertains to what you would expect, possible interpretations, and how or why you would expect certain observations. \r\n➔ A good introduction not only describes but **critically evaluates prior work**, which is only possible if you establish the criteria for your evaluation. Your evaluation criteria should be immediately transparent to the readers by delineating your theoretical framework. This provides the boundaries and conditions for your expectations. \r\n \r\nIf your work aims to directly test a theory or pit theories against each other, you will automatically include a theory section. However, you may have a situation where there is no (or no useful) theory. In this case it can help to shift your focus and delve into other fields. For example, you may be interested in the effect of hormones on risk taking, but you may also find a lot of relevant research if you look at studies investigating the link between personality, impulsivity, or self-control. Some of these differences may be purely semantic and rooted in different fields using different terminology for ostensibly the same thing. But this is not always the case and you may find a lot of useful theory if you cross over to related research topics.\r\n \r\n**Writing tip**: do not use vague words. Instead you should define key terms for your readers. It is better to define too much than too little. The definition can be in parenthesis, between hyphens, commas, or as a single sentence. For example:\r\n\r\n>The current work investigates prosocial behavior (people acting benevolently for others without a direct or indirect reward). \r\n>\r\n>We study the influence of shame - feeling emotionally uncomfortable after doing something - on consumer behavior. \r\n>\r\n>Risk-taking is an important topic in psychology. Throughout this paper risk-taking is defined as selecting actions with great variability in consequences. \r\n\r\nYou can improve your writing style by using standard phrases that writers use in academic writing. Check out sentences, which occur again and again in papers that you read (it is okay to use these phrases). Or use sources that provide you with such phrases, such as the [Academic Phrasebank](http://www.phrasebank.manchester.ac.uk/).\r\n\r\n**Introduce your research question (ca. 1-4 paragraphs)** \r\nAfter you have introduced and critically evaluated the current state of research, it is time to present and justify your research question. Explain the readers what is currently not known, debated or unclear, reveal the research gaps in the literature, and thereby create your niche. Where does a current theory (the one that you have reviewed before) fall short? Perhaps a prominent theory has not been tested thoroughly? Do two theories predict opposite patterns in the data? In formulating your research question, you position your research and make explicit why your work matters. Remember: you want to keep the readers interested, so if you can show why your work is essential and/or has implications for (e.g. clinical) applications, you have successfully motivated your work. Therefore it helps to ask yourself and answer the following questions: \r\n<br/>\r\n1. How does my work contribute to the current literature? \r\n2. How does my work contribute to or build on existing work? \r\n3. What research gap does my work close, how is my work related to other studies? \r\n \r\nYou can provide a **brief overview of your study** here, perhaps to show why it differs from previous work (different data? different design? different participants? etc.) or how you are going to close the gap you identified while motivating your work. Important: do not provide details, this is what the method section is for. But if there is anything special about your study, say so, it keeps the readers interested.\r\n\r\n**State your research hypothesis (ca. 1-2 paragraphs)** \r\nNow, you are almost finished writing your introduction. The only thing missing is to succinctly **state your research hypothesis**. This means, you need to tell the readers what results you expect from your study. It should be clear by now that the theories you mentioned before have to logically lead to the answers to the hypothesis (see [1.2 How to find theories and hypothesis](https://tales.nmc.unibas.ch/de/conducting-psychological-research-6/research-questions-and-theories-20/how-to-find-theories-and-hypothesis-52)). Previous findings can of course also guide your expectations, but these should ideally be discussed with reference to your theory.\r\n\r\nIf you want to **pitch two theories against each other**, here is an example how you could formulate this: ‘According to the ‘mood maintenance hypothesis’, positive affect will result in risk averse behaviour, whereas according to the ‘affect infusion model’ positive affect will result in risk seeking behaviour.’\r\n \r\nMake sure you use the appropriate terminology, such as **one-sided (directed) hypothesis** or **two-sided (undirected) hypothesis**, and distinguish between the **experimental and null hypothesis**. If you are unsure what these terms refer to, please consult Peter Harris’ 'Designing and reporting experiments in Psychology'.\r\n\r\nBefore you finish, check if everything you mention in your hypothesis appears at least once in the paragraphs before the hypothesis. It is a mistake if your hypothesis introduce new concepts or new theories. In the example above for instance, it would be a mistake if the mood maintenance hypothesis had not been explained before.\r\n\r\n<br/>\r\n\r\n------\r\n\r\n###References \r\n\r\nHarris, P. (2008). *Designing and reporting experiments in psychology*. McGraw-Hill Education (UK).\r\n{.citation-indented}", '', '', '', '', '', None, None, None, None, 'University of Basel', 'University of Basel', 'University of Basel', '', 'TT', '20 min.', 1, 'published', False, None, None, None, None, 21), (74, datetime.datetime(2020, 11, 2, 15, 9, 33, 774510, tzinfo=datetime.timezone.utc), datetime.datetime(2020, 11, 2, 15, 9, 37, 372391, tzinfo=datetime.timezone.utc), datetime.datetime(2020, 11, 2, 15, 9, 37, 372401, tzinfo=datetime.timezone.utc), False, 'Write a method section', 'Write a method section', 'Write a method section', None, '', '', '', None, '', None, None, None, '', 'write-a-method-section', 'This article briefly introduces how to write a method section. The method section of a paper describes the participant pool, your experimental design, and your measurement. \r\n{.lead}\r\n\r\nThe first part of the method section is called ‘Participants’. It always contains information about the subjects you gathered, their basic demographic data, where and when you recruited them, how they were compensated and which Institutional Review Board (IRB) approved your study. Here is an example of a ‘Participants’ section (Jarecki, Meder, & Nelson, 2017, p. 18):\r\n\r\n> Thirty people (mean age 23.8 years, range 19 to 33 years, 67% female) participated; remuneration was 12 euros. We recruited via the Center for Adaptive Behavior and Cognition at the Max Planck Institute for Human Development in Berlin, Germany. Data were collected from September to December 2012 at the center; the experiment was conducted in accordance with the ethical and data protection guidelines there.\r\n\r\nThe second part of the method section is called ‘Procedure’. It describes the participants’ task in as much detail as possible such that another researcher could re-do the experiment. Writing tip: write from the participants’ point of view and be very specific. Here a very short example:\r\n\r\n> Participants’ task was to try out different chewing gums with the flavors cherry, lime, and peanut. Participants first tried one chewing gum. The tasting was self-paced. Chewing gums were presented in random order. Participants rated each sample on a 5-point Likert scale (from *1 = extremely bad* to *5 = extremely good*). Thereafter, participants filled out a personality scale, and demographic information.\r\n\r\nThe next part of the method section is called ‘Material’. It details the measurement instruments used including standardized tests. Writing tip: in this section some writers prefer to use passive voice. This section is sometimes rather short. For example:\r\n\r\n> The experiment consisted of a computerized laboratory task. Participants’ personality was measured with the Neo-PIR short form for adults (Mooi, Comijs, De Fruyt, De Ritter, Hoekstra, & Beekman; 2011). \r\n\r\nIf you use vignettes, it is good practice to include a description of the vignette or the task. For example (Stewart, Chater, Stott, & Reimers; 2003, p. 36): \r\n\r\n> Participants were given brief oral instructions. They were told that they would have to imagine making choices between playing a prospect to receive an amount of money and taking a smaller amount for sure. Each pair of options was presented on a separate page of a 36-page booklet and appeared as follows: \r\n>\r\n> Which option do you prefer? \r\n> ☐ 10% chance of £300 \r\n> ☐ £12 \r\n>\r\n> Participants were told to mark the option they would prefer and move on to the next page. They were also made aware that there was no objective right answer and that choice was a matter of personal preference.\r\n\r\nOften, writers also combine ‘Procedure’ and ‘Materials’ into one longer section. Sometimes the title ‘Stimuli’ is also used instead of ‘Material’.\r\n\r\n\r\n<br/>\r\n\r\n------\r\n\r\n###References\r\n\r\nJarecki, J. B., Meder, B., & Nelson, J. D. (2017). Naive and robust: class-conditional independence in human classification learning. *Cognitive Science*, 1–39. doi:10.1111/cogs.12496\r\n{.citation-indented}\r\n\r\nMooi, B., Comijs, H. C., De Fruyt, F., De Ritter, D., Hoekstra, H. A., & Beekman, A. T. F. (2011). A neo-pi-r short form for older adults. *International Journal of Methods in Psychiatric Research, 18*, n/a-n/a. doi:10.1002/mpr.342\r\n{.citation-indented}\r\n\r\nStewart, N., Chater, N., Stott, H. P., & Reimers, S. (2003). Prospect relativity: how choice options influence decision under risk. *Journal of Experimental Psychology: General, 132*, 23–46. doi:10.1037/0096-3445.132.1.23\r\n{.citation-indented}', 'This article briefly introduces how to write a method section. The method section of a paper describes the participant pool, your experimental design, and your measurement. \r\n{.lead}\r\n\r\nThe first part of the method section is called ‘Participants’. It always contains information about the subjects you gathered, their basic demographic data, where and when you recruited them, how they were compensated and which Institutional Review Board (IRB) approved your study. Here is an example of a ‘Participants’ section (Jarecki, Meder, & Nelson, 2017, p. 18):\r\n\r\n> Thirty people (mean age 23.8 years, range 19 to 33 years, 67% female) participated; remuneration was 12 euros. We recruited via the Center for Adaptive Behavior and Cognition at the Max Planck Institute for Human Development in Berlin, Germany. Data were collected from September to December 2012 at the center; the experiment was conducted in accordance with the ethical and data protection guidelines there.\r\n\r\nThe second part of the method section is called ‘Procedure’. It describes the participants’ task in as much detail as possible such that another researcher could re-do the experiment. Writing tip: write from the participants’ point of view and be very specific. Here a very short example:\r\n\r\n> Participants’ task was to try out different chewing gums with the flavors cherry, lime, and peanut. Participants first tried one chewing gum. The tasting was self-paced. Chewing gums were presented in random order. Participants rated each sample on a 5-point Likert scale (from *1 = extremely bad* to *5 = extremely good*). Thereafter, participants filled out a personality scale, and demographic information.\r\n\r\nThe next part of the method section is called ‘Material’. It details the measurement instruments used including standardized tests. Writing tip: in this section some writers prefer to use passive voice. This section is sometimes rather short. For example:\r\n\r\n> The experiment consisted of a computerized laboratory task. Participants’ personality was measured with the Neo-PIR short form for adults (Mooi, Comijs, De Fruyt, De Ritter, Hoekstra, & Beekman; 2011). \r\n\r\nIf you use vignettes, it is good practice to include a description of the vignette or the task. For example (Stewart, Chater, Stott, & Reimers; 2003, p. 36): \r\n\r\n> Participants were given brief oral instructions. They were told that they would have to imagine making choices between playing a prospect to receive an amount of money and taking a smaller amount for sure. Each pair of options was presented on a separate page of a 36-page booklet and appeared as follows: \r\n>\r\n> Which option do you prefer? \r\n> ☐ 10% chance of £300 \r\n> ☐ £12 \r\n>\r\n> Participants were told to mark the option they would prefer and move on to the next page. They were also made aware that there was no objective right answer and that choice was a matter of personal preference.\r\n\r\nOften, writers also combine ‘Procedure’ and ‘Materials’ into one longer section. Sometimes the title ‘Stimuli’ is also used instead of ‘Material’.\r\n\r\n\r\n<br/>\r\n\r\n------\r\n\r\n###References\r\n\r\nJarecki, J. B., Meder, B., & Nelson, J. D. (2017). Naive and robust: class-conditional independence in human classification learning. *Cognitive Science*, 1–39. doi:10.1111/cogs.12496\r\n{.citation-indented}\r\n\r\nMooi, B., Comijs, H. C., De Fruyt, F., De Ritter, D., Hoekstra, H. A., & Beekman, A. T. F. (2011). A neo-pi-r short form for older adults. *International Journal of Methods in Psychiatric Research, 18*, n/a-n/a. doi:10.1002/mpr.342\r\n{.citation-indented}\r\n\r\nStewart, N., Chater, N., Stott, H. P., & Reimers, S. (2003). Prospect relativity: how choice options influence decision under risk. *Journal of Experimental Psychology: General, 132*, 23–46. doi:10.1037/0096-3445.132.1.23\r\n{.citation-indented}', 'This article briefly introduces how to write a method section. The method section of a paper describes the participant pool, your experimental design, and your measurement. \r\n{.lead}\r\n\r\nThe first part of the method section is called ‘Participants’. It always contains information about the subjects you gathered, their basic demographic data, where and when you recruited them, how they were compensated and which Institutional Review Board (IRB) approved your study. Here is an example of a ‘Participants’ section (Jarecki, Meder, & Nelson, 2017, p. 18):\r\n\r\n> Thirty people (mean age 23.8 years, range 19 to 33 years, 67% female) participated; remuneration was 12 euros. We recruited via the Center for Adaptive Behavior and Cognition at the Max Planck Institute for Human Development in Berlin, Germany. Data were collected from September to December 2012 at the center; the experiment was conducted in accordance with the ethical and data protection guidelines there.\r\n\r\nThe second part of the method section is called ‘Procedure’. It describes the participants’ task in as much detail as possible such that another researcher could re-do the experiment. Writing tip: write from the participants’ point of view and be very specific. Here a very short example:\r\n\r\n> Participants’ task was to try out different chewing gums with the flavors cherry, lime, and peanut. Participants first tried one chewing gum. The tasting was self-paced. Chewing gums were presented in random order. Participants rated each sample on a 5-point Likert scale (from *1 = extremely bad* to *5 = extremely good*). Thereafter, participants filled out a personality scale, and demographic information.\r\n\r\nThe next part of the method section is called ‘Material’. It details the measurement instruments used including standardized tests. Writing tip: in this section some writers prefer to use passive voice. This section is sometimes rather short. For example:\r\n\r\n> The experiment consisted of a computerized laboratory task. Participants’ personality was measured with the Neo-PIR short form for adults (Mooi, Comijs, De Fruyt, De Ritter, Hoekstra, & Beekman; 2011). \r\n\r\nIf you use vignettes, it is good practice to include a description of the vignette or the task. For example (Stewart, Chater, Stott, & Reimers; 2003, p. 36): \r\n\r\n> Participants were given brief oral instructions. They were told that they would have to imagine making choices between playing a prospect to receive an amount of money and taking a smaller amount for sure. Each pair of options was presented on a separate page of a 36-page booklet and appeared as follows: \r\n>\r\n> Which option do you prefer? \r\n> ☐ 10% chance of £300 \r\n> ☐ £12 \r\n>\r\n> Participants were told to mark the option they would prefer and move on to the next page. They were also made aware that there was no objective right answer and that choice was a matter of personal preference.\r\n\r\nOften, writers also combine ‘Procedure’ and ‘Materials’ into one longer section. Sometimes the title ‘Stimuli’ is also used instead of ‘Material’.\r\n\r\n\r\n<br/>\r\n\r\n------\r\n\r\n###References\r\n\r\nJarecki, J. B., Meder, B., & Nelson, J. D. (2017). Naive and robust: class-conditional independence in human classification learning. *Cognitive Science*, 1–39. doi:10.1111/cogs.12496\r\n{.citation-indented}\r\n\r\nMooi, B., Comijs, H. C., De Fruyt, F., De Ritter, D., Hoekstra, H. A., & Beekman, A. T. F. (2011). A neo-pi-r short form for older adults. *International Journal of Methods in Psychiatric Research, 18*, n/a-n/a. doi:10.1002/mpr.342\r\n{.citation-indented}\r\n\r\nStewart, N., Chater, N., Stott, H. P., & Reimers, S. (2003). Prospect relativity: how choice options influence decision under risk. *Journal of Experimental Psychology: General, 132*, 23–46. doi:10.1037/0096-3445.132.1.23\r\n{.citation-indented}', None, '', None, None, None, None, None, None, None, 'University of Basel', 'University of Basel', 'University of Basel', None, 'TT', '5 min.', 2, 'published', False, None, None, None, None, 21), (75, datetime.datetime(2020, 11, 2, 15, 9, 33, 774510, tzinfo=datetime.timezone.utc), datetime.datetime(2021, 11, 30, 14, 54, 27, 844434, tzinfo=datetime.timezone.utc), datetime.datetime(2021, 11, 30, 14, 54, 27, 820112, tzinfo=datetime.timezone.utc), False, 'Write a results section', 'Write a results section', 'Write a results section', None, 'Show your results according to APA', 'Show your results according to APA', 'Show your results according to APA', None, '', None, None, None, '', 'write-a-results-section', 'This article explains how to report your results according to APA standards. The results section simply reports your results, which means it presents the ‘dry facts’ without much interpretation (interpretation is done in the discussion section). Writing it up is relatively simple, because there are established guidelines. \r\n{.lead}\r\n\r\nPresent your results as clearly and accurately as possible. The following topics should be covered by your result section: \r\n➔ General information (optional) \r\n➔ How does the data look? \r\n➔ How was the data analyzed? \r\n➔ What was the outcome? What does that tell us?\r\n \r\n**General information (optional, 1 paragraph)** \r\nSome authors start by outlining information that is relevant to all analyses, like the p-value threshold used, statistical programs, or data aggregation. This step is optional. Consider the examples in Mullane et al (2011, p. 314)...\r\n\r\n> Data analyses were conducted in R (R Development Core Team, 2007).\r\n\r\n...and McKenna, Horswill, and Alexander (2006, p. 4):\r\n\r\n> We used an alpha level of .05 to determine statistical significance. Cohen’s *d*, *f*, and *w* were used to indicate effect sizes, where *d* values of 0.50 and 0.80, *f* values of 0.25 and 0.40, and *w* values of 0.300 and 0.500 refer to medium and large effect sizes, respectively (Cohen, 1992).\r\n\r\n**Descriptive statistics (1-2 paragraphs, maybe as a table)** \r\nThe readers need to get to know your data before learning about your analysis. Write one brief sentence about what information was gathered (e.g. reaction times) to avoid forcing readers to go back in the text. \r\nFollow this example in Chen et al., (2014, p. 4):\r\n\r\n> The result of primary interest was the relationship between how often participants responded Very Sure Old for the superstrong items and the curvature of the ROC function across the old rating levels (the first 3 ROC points) for the ‘standard’ items (studied without the deep processing tasks).\r\n\r\nThen describe the variables of interest in your data (no statistical tests yet). Outline in one or two sentences what your data looks like. Describe the main features of your data with descriptive statistics: means (*M*), medians (*MED*), measures of variation like standard deviation (*SD*), and range. Often, small tables are used. You can use this example as blueprint:\r\n<br>\r\n\r\n> Table 1 shows participants’ navigation ability (averaged over participants) for the experimental group in the 3D environment and the control group in the 2D environment.\r\n>\r\n> ![picture of a table](https://tales.nmc.unibas.ch/media/tales/conducting-psychological-research/table_image.PNG)\r\n\r\n**Inferential statistics (multiple paragraphs)** \r\nAfter describing your data, you are ready to present the results of your analysis. We will show you how to report t-test, ANOVA, and regression results in the examples below. But first, these are the general rules: \r\n➔ Write down in complete sentences which variable you analyzed in which way, and what was the result. \r\n➔ Use the full name of the test (e.g., ‘one-way analysis of variance (ANOVA) for unrelated samples’, instead of ‘ANOVA’). \r\nYou can follow this pattern:\r\n\r\n> The variable X was analyzed with test Y between ABC, revealing RESULT…\r\n\r\nAfter this first part add a comma and report inferential statistics in the following general way:\r\n\r\n> , statistic (degrees of freedom) = value, p = value, effect-size statistic = value’.\r\n\r\nIf you do a null-hypothesis test, there are some more general rules you need to follow in the statistics part: \r\n➔ Statistic: exact value of the test statistic (abbreviated to e.g., *F*, *t*) \r\n➔ Additional information like degrees of freedom, number of observations in parentheses \r\n➔ Exact p-value associated with your statistic. Report actual p-values, rather than surpassing of thresholds (good: *p = .03*, bad: *p < .05*). \r\n➔ Effect sizes \r\n➔ Significance level used and test direction (one- or two-sided) \r\n\r\n**How to report t-tests, ANOVAs and regressions** \r\nPresent your **t-test** results similar to this example adapted from McKenna, Horswill, and Alexander (2006, p. 4):\r\n\r\n> There were no significant differences between the trained and untrained groups in age, *t(77.16) = 0.72, p = .38 (ns), d = 0.15*; years elapsed since the driving test was passed, *t(82.31) = 0.86, p = .11 (ns), d = 0.18*.\r\n\r\nNote: *t* is the name of the test-statistic; *0.72* is the t-value; *77.16* are their degrees of freedom, *ns* means not significant, *d = 0.18* is their Cohen’s d value (effect size).\r\n\r\nPresent a **repeated-measures ANOVA** like the example adapted from Su et al (2013 p. 7):\r\n\r\n> Decision times were analyzed with a 3 (task: single-play probability task, multiple-play probability task, proportion task) x 2 (computational difficulty: high, low) repeated-measures analysis of variance (ANOVA). The results revealed a significant effect of task, *F(2, 96) = 96.05, p < .001, η<sup>2</sup> = .67*, on decision time.\r\n\r\nNote: *F* is the name of their test statistic; 2 and 96 are degrees of freedom; 96.05 is their F-value, *η<sup>2</sup>* is the effect size.\r\n\r\nPresent **between or within-subjects ANOVA results** as shown in this example in Yang and Lewandowsky (2003, p. 666).\r\n\r\n> Training performance was analyzed using the proportion of correct responses in each block as the dependent measure. A 2 (condition) x 10 (training block) between-within analysis of variance (ANOVA) revealed a significant main effect of block, *F(9, 540) = 51.193, MSE = .009, p < .001*, along with a marginal main effect of condition, *F(1, 60) = 3.889, MSE = 0.103, p = .053*.\r\n\r\nNote: *F* is the name of the test statistic; 51.193 is their F-value; 9 and 540 are the degrees of freedom; MSE = mean-squared error of the ANOVA.\r\n\r\nPresent **regression analysis results** as Gino and Ariely (2012, p. 449):\r\n\r\n>This analysis revealed that creativity as an individual difference was positively and significantly associated with dishonesty, *B = 0.48*, *SE = 0.084*, *ß = .51, t = 5.73, p < .001*, whereas intelligence was not, *B = 0.059*, *SE = 0.086*, *ß = .062*, *t = 0.695*, *p = .49*. \r\n \r\n**How to format numbers** \r\nMake sure that your numbers are displayed correctly. Here are some rules: \r\n➔ Use a point as a decimal separator (*1.14* instead of *1,14*). \r\n➔ Statistical abbreviations, such as *M*, *SD*, or *p*, as well as their values are written in italic. \r\n➔ The 0 before the decimal separator is omitted for numbers between 0 and 1 (e.g. p-values: .012, .01). If the number is not between 0 and 1, the 0 before the decimal separator is written. \r\n➔ Round decimal numbers to 2 or 3 decimal places (be consistent). Always round up p-values (p-value of 0.051 to *p = .06*, not *p = .05*). \r\n➔ Report exact p-values, not surpassing of thresholds. Exception: if you have a very small p-value below 0.001, then report *p < .001* (e.g. p-value of 0.00099 is reported as *p < .001*, not *p = .001*). \r\n\r\n**Where to find the statistics in R** \r\nIf you are working with R it is not always easy to find the corresponding numbers to your results.\r\n\r\nHere is an example where to find the statistics in R if you are reporting a **two sample t-test**: \r\n![two sample t-test*](/media/tales/markdownx/af55ac95-0f6e-4380-b21a-322b49f3bc55.png)\r\n\r\nIf you are reporting a **one-way ANOVA**, you can use this example: \r\n![one-way ANOVA](/media/tales/markdownx/05f329d2-6d03-4d09-ab40-7a73ead1c439.png)\r\n\r\n**Tables and figures** \r\nTables and figures can be very useful for presenting your results. Let’s talk about the content of tables and figures (you can find out how to format them in the [beginner’s guide to APA](https://tales.nmc.unibas.ch/de/conducting-psychological-research-6/writing-a-scientific-report-21/structuring-a-scientific-paper-50) that we compiled for this course). A lot is said about the proper graphical presentation of data in scientific papers. Here are some basic tips to get you started: \r\n➔ Do not copy-paste tables produced with statistical software, they usually contain redundant information and are not formatted suitably for a scientific thesis or manuscript. Instead, identify the relevant information and report it according to the guidelines listed above. \r\n➔ All tables and figures should be labeled with Arabic numbers, in order of appearance in the text (e.g. Table 1, Table 2, Figure 1, Figure 2). Note that the first letters are always capitalized, have a meaningful title and have self-explanatory entries or contain a note of explanation below them (such as in Table 1 we presented to you as an example above). \r\n➔ Every table and figure needs to be referred to in the text, but do not repeat the full table or figure content in the text.\r\n\r\n<br/>\r\n\r\n------\r\n\r\n###References\r\n\r\nChen, T., Starns, J. J., Rotello, C. M., Chen, T., Starns, J. J., & Rotello, C. M. (2014). A violation of the conditional independence assumption in the two-high-threshold model of recognition memory. *Journal of Experimental Psychology: Learning, Memory, and Cognition*. doi:10.1037/xlm0000077\r\n{.citation-indented}\r\n\r\nMcKenna, F. P., Horswill, M. S., & Alexander, J. L. (2006). Does anticipation training affect drivers’ risk taking? *Journal of Experimental Psychology. Applied, 12*, 1–10. doi:10.1037/1076-898X.12.1.1\r\n{.citation-indented}\r\n\r\nSu, Y., Rao, L.-L., Sun, H.-Y., Du, X.-L., Li, X., & Li, S. (2013). Is making a risky choice based on a weighting and adding process? an eye-tracking investigation. *Journal of Experimental Psychology: Learning, Memory, and Cognition, 39*, 1765–1780. doi:10.1037/a0032861\r\n{.citation-indented}\r\n\r\nYang, L.-X., & Lewandowsky, S. (2003). Context-gated knowledge partitioning in categorization. *Journal of Experimental Psychology: Learning, Memory, and Cognition, 29*, 663–679. doi:10.1037/0278-7393.29.4.663\r\n{.citation-indented}', 'This article explains how to report your results according to APA standards. The results section simply reports your results, which means it presents the ‘dry facts’ without much interpretation (interpretation is done in the discussion section). Writing it up is relatively simple, because there are established guidelines. \r\n{.lead}\r\n\r\nPresent your results as clearly and accurately as possible. The following topics should be covered by your result section: \r\n➔ General information (optional) \r\n➔ How does the data look? \r\n➔ How was the data analyzed? \r\n➔ What was the outcome? What does that tell us?\r\n \r\n**General information (optional, 1 paragraph)** \r\nSome authors start by outlining information that is relevant to all analyses, like the p-value threshold used, statistical programs, or data aggregation. This step is optional. Consider the examples in Mullane et al (2011, p. 314)...\r\n\r\n> Data analyses were conducted in R (R Development Core Team, 2007).\r\n\r\n...and McKenna, Horswill, and Alexander (2006, p. 4):\r\n\r\n> We used an alpha level of .05 to determine statistical significance. Cohen’s *d*, *f*, and *w* were used to indicate effect sizes, where *d* values of 0.50 and 0.80, *f* values of 0.25 and 0.40, and *w* values of 0.300 and 0.500 refer to medium and large effect sizes, respectively (Cohen, 1992).\r\n\r\n**Descriptive statistics (1-2 paragraphs, maybe as a table)** \r\nThe readers need to get to know your data before learning about your analysis. Write one brief sentence about what information was gathered (e.g. reaction times) to avoid forcing readers to go back in the text. \r\nFollow this example in Chen et al., (2014, p. 4):\r\n\r\n> The result of primary interest was the relationship between how often participants responded Very Sure Old for the superstrong items and the curvature of the ROC function across the old rating levels (the first 3 ROC points) for the ‘standard’ items (studied without the deep processing tasks).\r\n\r\nThen describe the variables of interest in your data (no statistical tests yet). Outline in one or two sentences what your data looks like. Describe the main features of your data with descriptive statistics: means (*M*), medians (*MED*), measures of variation like standard deviation (*SD*), and range. Often, small tables are used. You can use this example as blueprint:\r\n<br>\r\n\r\n> Table 1 shows participants’ navigation ability (averaged over participants) for the experimental group in the 3D environment and the control group in the 2D environment.\r\n>\r\n> ![picture of a table](https://tales.nmc.unibas.ch/media/conducting-psychological-research/table_image.PNG)\r\n\r\n**Inferential statistics (multiple paragraphs)** \r\nAfter describing your data, you are ready to present the results of your analysis. We will show you how to report t-test, ANOVA, and regression results in the examples below. But first, these are the general rules: \r\n➔ Write down in complete sentences which variable you analyzed in which way, and what was the result. \r\n➔ Use the full name of the test (e.g., ‘one-way analysis of variance (ANOVA) for unrelated samples’, instead of ‘ANOVA’). \r\nYou can follow this pattern:\r\n\r\n> The variable X was analyzed with test Y between ABC, revealing RESULT…\r\n\r\nAfter this first part add a comma and report inferential statistics in the following general way:\r\n\r\n> , statistic (degrees of freedom) = value, p = value, effect-size statistic = value’.\r\n\r\nIf you do a null-hypothesis test, there are some more general rules you need to follow in the statistics part: \r\n➔ Statistic: exact value of the test statistic (abbreviated to e.g., *F*, *t*) \r\n➔ Additional information like degrees of freedom, number of observations in parentheses \r\n➔ Exact p-value associated with your statistic. Report actual p-values, rather than surpassing of thresholds (good: *p = .03*, bad: *p < .05*). \r\n➔ Effect sizes \r\n➔ Significance level used and test direction (one- or two-sided) \r\n\r\n**How to report t-tests, ANOVAs and regressions** \r\nPresent your **t-test** results similar to this example adapted from McKenna, Horswill, and Alexander (2006, p. 4):\r\n\r\n> There were no significant differences between the trained and untrained groups in age, *t(77.16) = 0.72, p = .38 (ns), d = 0.15*; years elapsed since the driving test was passed, *t(82.31) = 0.86, p = .11 (ns), d = 0.18*.\r\n\r\nNote: *t* is the name of the test-statistic; *0.72* is the t-value; *77.16* are their degrees of freedom, *ns* means not significant, *d = 0.18* is their Cohen’s d value (effect size).\r\n\r\nPresent a **repeated-measures ANOVA** like the example adapted from Su et al (2013 p. 7):\r\n\r\n> Decision times were analyzed with a 3 (task: single-play probability task, multiple-play probability task, proportion task) x 2 (computational difficulty: high, low) repeated-measures analysis of variance (ANOVA). The results revealed a significant effect of task, *F(2, 96) = 96.05, p < .001, η<sup>2</sup> = .67*, on decision time.\r\n\r\nNote: *F* is the name of their test statistic; 2 and 96 are degrees of freedom; 96.05 is their F-value, *η<sup>2</sup>* is the effect size.\r\n\r\nPresent **between or within-subjects ANOVA results** as shown in this example in Yang and Lewandowsky (2003, p. 666).\r\n\r\n> Training performance was analyzed using the proportion of correct responses in each block as the dependent measure. A 2 (condition) x 10 (training block) between-within analysis of variance (ANOVA) revealed a significant main effect of block, *F(9, 540) = 51.193, MSE = .009, p < .001*, along with a marginal main effect of condition, *F(1, 60) = 3.889, MSE = 0.103, p = .053*.\r\n\r\nNote: *F* is the name of the test statistic; 51.193 is their F-value; 9 and 540 are the degrees of freedom; MSE = mean-squared error of the ANOVA.\r\n\r\nPresent **regression analysis results** as Gino and Ariely (2012, p. 449):\r\n\r\n>This analysis revealed that creativity as an individual difference was positively and significantly associated with dishonesty, *B = 0.48*, *SE = 0.084*, *ß = .51, t = 5.73, p < .001*, whereas intelligence was not, *B = 0.059*, *SE = 0.086*, *ß = .062*, *t = 0.695*, *p = .49*. \r\n \r\n**How to format numbers** \r\nMake sure that your numbers are displayed correctly. Here are some rules: \r\n➔ Use a point as a decimal separator (*1.14* instead of *1,14*). \r\n➔ Statistical abbreviations, such as *M*, *SD*, or *p*, as well as their values are written in italic. \r\n➔ The 0 before the decimal separator is omitted for numbers between 0 and 1 (e.g. p-values: .012, .01). If the number is not between 0 and 1, the 0 before the decimal separator is written. \r\n➔ Round decimal numbers to 2 or 3 decimal places (be consistent). Always round up p-values (p-value of 0.051 to *p = .06*, not *p = .05*). \r\n➔ Report exact p-values, not surpassing of thresholds. Exception: if you have a very small p-value below 0.001, then report *p < .001* (e.g. p-value of 0.00099 is reported as *p < .001*, not *p = .001*). \r\n\r\n**Where to find the statistics in R** \r\nIf you are working with R it is not always easy to find the corresponding numbers to your results.\r\n\r\nHere is an example where to find the statistics in R if you are reporting a **two sample t-test**: \r\n![two sample t-test*](/media/markdownx/af55ac95-0f6e-4380-b21a-322b49f3bc55.png)\r\n\r\nIf you are reporting a **one-way ANOVA**, you can use this example: \r\n![one-way ANOVA](/media/markdownx/05f329d2-6d03-4d09-ab40-7a73ead1c439.png)\r\n\r\n**Tables and figures** \r\nTables and figures can be very useful for presenting your results. Let’s talk about the content of tables and figures (you can find out how to format them in the [beginner’s guide to APA](https://tales.nmc.unibas.ch/de/conducting-psychological-research-6/writing-a-scientific-report-21/structuring-a-scientific-paper-50) that we compiled for this course). A lot is said about the proper graphical presentation of data in scientific papers. Here are some basic tips to get you started: \r\n➔ Do not copy-paste tables produced with statistical software, they usually contain redundant information and are not formatted suitably for a scientific thesis or manuscript. Instead, identify the relevant information and report it according to the guidelines listed above. \r\n➔ All tables and figures should be labeled with Arabic numbers, in order of appearance in the text (e.g. Table 1, Table 2, Figure 1, Figure 2). Note that the first letters are always capitalized, have a meaningful title and have self-explanatory entries or contain a note of explanation below them (such as in Table 1 we presented to you as an example above). \r\n➔ Every table and figure needs to be referred to in the text, but do not repeat the full table or figure content in the text.\r\n\r\n<br/>\r\n\r\n------\r\n\r\n###References\r\n\r\nChen, T., Starns, J. J., Rotello, C. M., Chen, T., Starns, J. J., & Rotello, C. M. (2014). A violation of the conditional independence assumption in the two-high-threshold model of recognition memory. *Journal of Experimental Psychology: Learning, Memory, and Cognition*. doi:10.1037/xlm0000077\r\n{.citation-indented}\r\n\r\nMcKenna, F. P., Horswill, M. S., & Alexander, J. L. (2006). Does anticipation training affect drivers’ risk taking? *Journal of Experimental Psychology. Applied, 12*, 1–10. doi:10.1037/1076-898X.12.1.1\r\n{.citation-indented}\r\n\r\nSu, Y., Rao, L.-L., Sun, H.-Y., Du, X.-L., Li, X., & Li, S. (2013). Is making a risky choice based on a weighting and adding process? an eye-tracking investigation. *Journal of Experimental Psychology: Learning, Memory, and Cognition, 39*, 1765–1780. doi:10.1037/a0032861\r\n{.citation-indented}\r\n\r\nYang, L.-X., & Lewandowsky, S. (2003). Context-gated knowledge partitioning in categorization. *Journal of Experimental Psychology: Learning, Memory, and Cognition, 29*, 663–679. doi:10.1037/0278-7393.29.4.663\r\n{.citation-indented}', 'This article explains how to report your results according to APA standards. The results section simply reports your results, which means it presents the ‘dry facts’ without much interpretation (interpretation is done in the discussion section). Writing it up is relatively simple, because there are established guidelines. \r\n{.lead}\r\n\r\nPresent your results as clearly and accurately as possible. The following topics should be covered by your result section: \r\n➔ General information (optional) \r\n➔ How does the data look? \r\n➔ How was the data analyzed? \r\n➔ What was the outcome? What does that tell us?\r\n \r\n**General information (optional, 1 paragraph)** \r\nSome authors start by outlining information that is relevant to all analyses, like the p-value threshold used, statistical programs, or data aggregation. This step is optional. Consider the examples in Mullane et al (2011, p. 314)...\r\n\r\n> Data analyses were conducted in R (R Development Core Team, 2007).\r\n\r\n...and McKenna, Horswill, and Alexander (2006, p. 4):\r\n\r\n> We used an alpha level of .05 to determine statistical significance. Cohen’s *d*, *f*, and *w* were used to indicate effect sizes, where *d* values of 0.50 and 0.80, *f* values of 0.25 and 0.40, and *w* values of 0.300 and 0.500 refer to medium and large effect sizes, respectively (Cohen, 1992).\r\n\r\n**Descriptive statistics (1-2 paragraphs, maybe as a table)** \r\nThe readers need to get to know your data before learning about your analysis. Write one brief sentence about what information was gathered (e.g. reaction times) to avoid forcing readers to go back in the text. \r\nFollow this example in Chen et al., (2014, p. 4):\r\n\r\n> The result of primary interest was the relationship between how often participants responded Very Sure Old for the superstrong items and the curvature of the ROC function across the old rating levels (the first 3 ROC points) for the ‘standard’ items (studied without the deep processing tasks).\r\n\r\nThen describe the variables of interest in your data (no statistical tests yet). Outline in one or two sentences what your data looks like. Describe the main features of your data with descriptive statistics: means (*M*), medians (*MED*), measures of variation like standard deviation (*SD*), and range. Often, small tables are used. You can use this example as blueprint:\r\n\r\n> Table 1 shows participants’ navigation ability (averaged over participants) for the experimental group in the 3D environment and the control group in the 2D environment.\r\n> ![picture of a table](/media/markdownx/77d67eb3-e791-428b-b43a-46681063bf72.png)\r\n\r\n**Inferential statistics (multiple paragraphs)** \r\nAfter describing your data, you are ready to present the results of your analysis. We will show you how to report t-test, ANOVA, and regression results in the examples below. But first, these are the general rules: \r\n➔ Write down in complete sentences which variable you analyzed in which way, and what was the result. \r\n➔ Use the full name of the test (e.g., ‘one-way analysis of variance (ANOVA) for unrelated samples’, instead of ‘ANOVA’). \r\nYou can follow this pattern:\r\n\r\n> The variable X was analyzed with test Y between ABC, revealing RESULT…\r\n\r\nAfter this first part add a comma and report inferential statistics in the following general way:\r\n\r\n> , statistic (degrees of freedom) = value, p = value, effect-size statistic = value’.\r\n\r\nIf you do a null-hypothesis test, there are some more general rules you need to follow in the statistics part: \r\n➔ Statistic: exact value of the test statistic (abbreviated to e.g., *F*, *t*) \r\n➔ Additional information like degrees of freedom, number of observations in parentheses \r\n➔ Exact p-value associated with your statistic. Report actual p-values, rather than surpassing of thresholds (good: *p = .03*, bad: *p < .05*). \r\n➔ Effect sizes \r\n➔ Significance level used and test direction (one- or two-sided) \r\n\r\n**How to report t-tests, ANOVAs and regressions** \r\nPresent your **t-test** results similar to this example adapted from McKenna, Horswill, and Alexander (2006, p. 4):\r\n\r\n> There were no significant differences between the trained and untrained groups in age, *t(77.16) = 0.72, p = .38 (ns), d = 0.15*; years elapsed since the driving test was passed, *t(82.31) = 0.86, p = .11 (ns), d = 0.18*.\r\n\r\nNote: *t* is the name of the test-statistic; *0.72* is the t-value; *77.16* are their degrees of freedom, *ns* means not significant, *d = 0.18* is their Cohen’s d value (effect size).\r\n\r\nPresent a **repeated-measures ANOVA** like the example adapted from Su et al (2013 p. 7):\r\n\r\n> Decision times were analyzed with a 3 (task: single-play probability task, multiple-play probability task, proportion task) x 2 (computational difficulty: high, low) repeated-measures analysis of variance (ANOVA). The results revealed a significant effect of task, *F(2, 96) = 96.05, p < .001, η<sup>2</sup> = .67*, on decision time.\r\n\r\nNote: *F* is the name of their test statistic; 2 and 96 are degrees of freedom; 96.05 is their F-value, *η<sup>2</sup>* is the effect size.\r\n\r\nPresent **between or within-subjects ANOVA results** as shown in this example in Yang and Lewandowsky (2003, p. 666).\r\n\r\n> Training performance was analyzed using the proportion of correct responses in each block as the dependent measure. A 2 (condition) x 10 (training block) between-within analysis of variance (ANOVA) revealed a significant main effect of block, *F(9, 540) = 51.193, MSE = .009, p < .001*, along with a marginal main effect of condition, *F(1, 60) = 3.889, MSE = 0.103, p = .053*.\r\n\r\nNote: *F* is the name of the test statistic; 51.193 is their F-value; 9 and 540 are the degrees of freedom; MSE = mean-squared error of the ANOVA.\r\n\r\nPresent **regression analysis results** as Gino and Ariely (2012, p. 449):\r\n\r\n>This analysis revealed that creativity as an individual difference was positively and significantly associated with dishonesty, *B = 0.48*, *SE = 0.084*, *ß = .51, t = 5.73, p < .001*, whereas intelligence was not, *B = 0.059*, *SE = 0.086*, *ß = .062*, *t = 0.695*, *p = .49*. \r\n \r\n**How to format numbers** \r\nMake sure that your numbers are displayed correctly. Here are some rules: \r\n➔ Use a point as a decimal separator (*1.14* instead of *1,14*). \r\n➔ Statistical abbreviations, such as *M*, *SD*, or *p*, as well as their values are written in italic. \r\n➔ The 0 before the decimal separator is omitted for numbers between 0 and 1 (e.g. p-values: .012, .01). If the number is not between 0 and 1, the 0 before the decimal separator is written. \r\n➔ Round decimal numbers to 2 or 3 decimal places (be consistent). Always round up p-values (p-value of 0.051 to *p = .06*, not *p = .05*). \r\n➔ Report exact p-values, not surpassing of thresholds. Exception: if you have a very small p-value below 0.001, then report *p < .001* (e.g. p-value of 0.00099 is reported as *p < .001*, not *p = .001*). \r\n\r\n**Where to find the statistics in R** \r\nIf you are working with R it is not always easy to find the corresponding numbers to your results.\r\n\r\nHere is an example where to find the statistics in R if you are reporting a **two sample t-test**: \r\n![two sample t-test*](/media/markdownx/af55ac95-0f6e-4380-b21a-322b49f3bc55.png)\r\n\r\nIf you are reporting a **one-way ANOVA**, you can use this example: \r\n![one-way ANOVA](/media/markdownx/05f329d2-6d03-4d09-ab40-7a73ead1c439.png)\r\n\r\n**Tables and figures** \r\nTables and figures can be very useful for presenting your results. Let’s talk about the content of tables and figures (you can find out how to format them in the [beginner’s guide to APA](https://tales.nmc.unibas.ch/de/conducting-psychological-research-6/writing-a-scientific-report-21/structuring-a-scientific-paper-50) that we compiled for this course). A lot is said about the proper graphical presentation of data in scientific papers. Here are some basic tips to get you started: \r\n➔ Do not copy-paste tables produced with statistical software, they usually contain redundant information and are not formatted suitably for a scientific thesis or manuscript. Instead, identify the relevant information and report it according to the guidelines listed above. \r\n➔ All tables and figures should be labeled with Arabic numbers, in order of appearance in the text (e.g. Table 1, Table 2, Figure 1, Figure 2). Note that the first letters are always capitalized, have a meaningful title and have self-explanatory entries or contain a note of explanation below them (such as in Table 1 we presented to you as an example above). \r\n➔ Every table and figure needs to be referred to in the text, but do not repeat the full table or figure content in the text.\r\n\r\n<br/>\r\n\r\n------\r\n\r\n###References\r\n\r\nChen, T., Starns, J. J., Rotello, C. M., Chen, T., Starns, J. J., & Rotello, C. M. (2014). A violation of the conditional independence assumption in the two-high-threshold model of recognition memory. *Journal of Experimental Psychology: Learning, Memory, and Cognition*. doi:10.1037/xlm0000077\r\n{.citation-indented}\r\n\r\nMcKenna, F. P., Horswill, M. S., & Alexander, J. L. (2006). Does anticipation training affect drivers’ risk taking? *Journal of Experimental Psychology. Applied, 12*, 1–10. doi:10.1037/1076-898X.12.1.1\r\n{.citation-indented}\r\n\r\nSu, Y., Rao, L.-L., Sun, H.-Y., Du, X.-L., Li, X., & Li, S. (2013). Is making a risky choice based on a weighting and adding process? an eye-tracking investigation. *Journal of Experimental Psychology: Learning, Memory, and Cognition, 39*, 1765–1780. doi:10.1037/a0032861\r\n{.citation-indented}\r\n\r\nYang, L.-X., & Lewandowsky, S. (2003). Context-gated knowledge partitioning in categorization. *Journal of Experimental Psychology: Learning, Memory, and Cognition, 29*, 663–679. doi:10.1037/0278-7393.29.4.663\r\n{.citation-indented}', '', '', '', '', '', None, None, None, None, 'University of Basel', 'University of Basel', 'University of Basel', '', 'TT', '20 min.', 3, 'published', False, None, None, None, None, 21), (76, datetime.datetime(2020, 11, 2, 15, 9, 33, 774510, tzinfo=datetime.timezone.utc), datetime.datetime(2020, 11, 2, 15, 9, 37, 376832, tzinfo=datetime.timezone.utc), datetime.datetime(2020, 11, 2, 15, 9, 37, 376843, tzinfo=datetime.timezone.utc), False, 'Write a discussion section', 'Write a discussion section', 'Write a discussion section', None, '', '', '', None, '', None, None, None, '', 'write-a-discussion-section', 'The discussion section interprets the results. This chapter briefly outlines the basics of the discussion section.\r\n{.lead}\r\n\r\n**Discussion section vs. result section?** \r\nThe main difference between the discussion and the result section is that you **interpret** your results in the discussion. That means, while you explain what you have found objectively in the result section, in the discussion section you explain your findings by interpreting them. \r\n \r\n**How is the discussion section structured?** \r\nThe discussion section contains four parts:\r\n<br/>\r\n1. \tRecap of the research question and your main findings \r\n2. \tHow do your findings relate to the theories and what do they mean? \r\n3. \tWhat do your findings imply, and which limitations have been introduced by the design? \r\n4. \tConclusion of your main findings and discussion points \r\nIn the following paragraphs we give you more details and some examples for each part. \r\n \r\n**1. Recap of the research question and main your findings** \r\nIn the first paragraph, you briefly repeat the research question or hypothesis, what you found, and if your findings confirm your hypothesis. Although you repeat your findings, this paragraph is not a copy of the result section. Rather, in the discussion section, you should use phrases instead of numbers and graphs. Here is an example for a discussion section (few numbers, more text and intuition than in the result section):\r\n\r\n> The results confirmed our hypotheses that autonomy and engagement with characters lead to enjoyable experiences.\r\n\r\nThis is very different from a result section (facts, numbers, statistics), which could be:\r\n\r\n> A multiple regression was calculated with needs as predictors of enjoyment (*R = .62*, *R2 adjusted = .39*, *F(8, 114) = 11.38, p < .001*).\r\n \r\n\r\n \r\n**2. How do your findings relate to the theories and what do they mean?** \r\nIn the second part of your discussion, you revisit the theories and previous studies you have introduced in the introduction section and explain how your findings fit in. That means, you showcase what similarities or dissimilarities you found compared to the theories and previous studies. For example:\r\n\r\n> In line with previous studies (Johnson et al., 2015; Oliver & Raney, 2011), increased autonomy was associated with high enjoyment. ...\r\n \r\nIn the discussion section, it is particularly important to critically question your findings. Consider whether the difference in the dependent variable is really caused by the manipulation of the independent variable, or whether alternative explanations exist (e.g. confounding variables, influential variable assessed in previous studies but not in yours). Correspondingly, if you find no significant difference in the dependent variable, you need to ask yourself it this means that there is no relationship between your independent and dependent variable.\r\n \r\n**3. What are the implications of your findings, and what limitations of design exist?** \r\nThis third part of the discussion section is divided further into three subsections. \r\nFirst, you write about how your findings inform new research questions. Consider what is important or interesting to explore further. For instance, if the relationship between IV and DV was not clear in your experiment, how could a future study investigate it better? For example:\r\n\r\n> Future research may examine how to encourage players to share their feelings and thoughts evoked by game events with others. This seems especially important for serious games, as it may promote discussion of the subject. ...\r\n \r\nNext, if you think there is an implication for practitioners, who will merit from your findings and what practical relevance they have. It’s important to be specific, simply to mention that your findings have implication is not enough. For example:\r\n\r\n> Our findings have implication for researchers and practitioners wanting to evaluate long-lasting game experience. Such experiences have been argued to be difficult to assess in the long run (Lacovides & Cox, 2015). A possible work-around would be to take appreciation into account as this was found in our study to be associated to long-lasting effect. ...\r\n \r\nFinally, briefly discuss (max. 1 paragraph) the limitations of your experimental design. Consider what could be changed when replicating your study. For example:\r\n\r\n> A limitation is that the present study asked participants to recall a past game experience. But as the retrospective evaluation of an experience may differ from the moment-to-moment experience (Kahnemann & Riis, 2005), it is necessary to also explore players’ feelings and thoughts during or immediately after a gaming experience in future work.\r\n \r\n**4. Conclusion of your main implication** \r\nIn the last paragraph of the discussion section, you briefly summarize your study. In contrast to the abstract, the focus of the conclusion lies on the main findings and the main discussion points. Here, you present the take-home message for the reader of your paper. For example:\r\n\r\n> In conclusion, our results suggest that autonomy of players and appreciation of game elements play a key role in evoking positive emotions in a variety of computer games. Both factors, high autonomy and high appreciation, increase positive emotional experiences for players of both genders, especially in games involving a social component. Autonomy and appreciation thereby provide a mechanism to influence player experiences.', 'The discussion section interprets the results. This chapter briefly outlines the basics of the discussion section.\r\n{.lead}\r\n\r\n**Discussion section vs. result section?** \r\nThe main difference between the discussion and the result section is that you **interpret** your results in the discussion. That means, while you explain what you have found objectively in the result section, in the discussion section you explain your findings by interpreting them. \r\n \r\n**How is the discussion section structured?** \r\nThe discussion section contains four parts:\r\n<br/>\r\n1. \tRecap of the research question and your main findings \r\n2. \tHow do your findings relate to the theories and what do they mean? \r\n3. \tWhat do your findings imply, and which limitations have been introduced by the design? \r\n4. \tConclusion of your main findings and discussion points \r\nIn the following paragraphs we give you more details and some examples for each part. \r\n \r\n**1. Recap of the research question and main your findings** \r\nIn the first paragraph, you briefly repeat the research question or hypothesis, what you found, and if your findings confirm your hypothesis. Although you repeat your findings, this paragraph is not a copy of the result section. Rather, in the discussion section, you should use phrases instead of numbers and graphs. Here is an example for a discussion section (few numbers, more text and intuition than in the result section):\r\n\r\n> The results confirmed our hypotheses that autonomy and engagement with characters lead to enjoyable experiences.\r\n\r\nThis is very different from a result section (facts, numbers, statistics), which could be:\r\n\r\n> A multiple regression was calculated with needs as predictors of enjoyment (*R = .62*, *R2 adjusted = .39*, *F(8, 114) = 11.38, p < .001*).\r\n \r\n\r\n \r\n**2. How do your findings relate to the theories and what do they mean?** \r\nIn the second part of your discussion, you revisit the theories and previous studies you have introduced in the introduction section and explain how your findings fit in. That means, you showcase what similarities or dissimilarities you found compared to the theories and previous studies. For example:\r\n\r\n> In line with previous studies (Johnson et al., 2015; Oliver & Raney, 2011), increased autonomy was associated with high enjoyment. ...\r\n \r\nIn the discussion section, it is particularly important to critically question your findings. Consider whether the difference in the dependent variable is really caused by the manipulation of the independent variable, or whether alternative explanations exist (e.g. confounding variables, influential variable assessed in previous studies but not in yours). Correspondingly, if you find no significant difference in the dependent variable, you need to ask yourself it this means that there is no relationship between your independent and dependent variable.\r\n \r\n**3. What are the implications of your findings, and what limitations of design exist?** \r\nThis third part of the discussion section is divided further into three subsections. \r\nFirst, you write about how your findings inform new research questions. Consider what is important or interesting to explore further. For instance, if the relationship between IV and DV was not clear in your experiment, how could a future study investigate it better? For example:\r\n\r\n> Future research may examine how to encourage players to share their feelings and thoughts evoked by game events with others. This seems especially important for serious games, as it may promote discussion of the subject. ...\r\n \r\nNext, if you think there is an implication for practitioners, who will merit from your findings and what practical relevance they have. It’s important to be specific, simply to mention that your findings have implication is not enough. For example:\r\n\r\n> Our findings have implication for researchers and practitioners wanting to evaluate long-lasting game experience. Such experiences have been argued to be difficult to assess in the long run (Lacovides & Cox, 2015). A possible work-around would be to take appreciation into account as this was found in our study to be associated to long-lasting effect. ...\r\n \r\nFinally, briefly discuss (max. 1 paragraph) the limitations of your experimental design. Consider what could be changed when replicating your study. For example:\r\n\r\n> A limitation is that the present study asked participants to recall a past game experience. But as the retrospective evaluation of an experience may differ from the moment-to-moment experience (Kahnemann & Riis, 2005), it is necessary to also explore players’ feelings and thoughts during or immediately after a gaming experience in future work.\r\n \r\n**4. Conclusion of your main implication** \r\nIn the last paragraph of the discussion section, you briefly summarize your study. In contrast to the abstract, the focus of the conclusion lies on the main findings and the main discussion points. Here, you present the take-home message for the reader of your paper. For example:\r\n\r\n> In conclusion, our results suggest that autonomy of players and appreciation of game elements play a key role in evoking positive emotions in a variety of computer games. Both factors, high autonomy and high appreciation, increase positive emotional experiences for players of both genders, especially in games involving a social component. Autonomy and appreciation thereby provide a mechanism to influence player experiences.', 'The discussion section interprets the results. This chapter briefly outlines the basics of the discussion section.\r\n{.lead}\r\n\r\n**Discussion section vs. result section?** \r\nThe main difference between the discussion and the result section is that you **interpret** your results in the discussion. That means, while you explain what you have found objectively in the result section, in the discussion section you explain your findings by interpreting them. \r\n \r\n**How is the discussion section structured?** \r\nThe discussion section contains four parts:\r\n<br/>\r\n1. \tRecap of the research question and your main findings \r\n2. \tHow do your findings relate to the theories and what do they mean? \r\n3. \tWhat do your findings imply, and which limitations have been introduced by the design? \r\n4. \tConclusion of your main findings and discussion points \r\nIn the following paragraphs we give you more details and some examples for each part. \r\n \r\n**1. Recap of the research question and main your findings** \r\nIn the first paragraph, you briefly repeat the research question or hypothesis, what you found, and if your findings confirm your hypothesis. Although you repeat your findings, this paragraph is not a copy of the result section. Rather, in the discussion section, you should use phrases instead of numbers and graphs. Here is an example for a discussion section (few numbers, more text and intuition than in the result section):\r\n\r\n> The results confirmed our hypotheses that autonomy and engagement with characters lead to enjoyable experiences.\r\n\r\nThis is very different from a result section (facts, numbers, statistics), which could be:\r\n\r\n> A multiple regression was calculated with needs as predictors of enjoyment (*R = .62*, *R2 adjusted = .39*, *F(8, 114) = 11.38, p < .001*).\r\n \r\n\r\n \r\n**2. How do your findings relate to the theories and what do they mean?** \r\nIn the second part of your discussion, you revisit the theories and previous studies you have introduced in the introduction section and explain how your findings fit in. That means, you showcase what similarities or dissimilarities you found compared to the theories and previous studies. For example:\r\n\r\n> In line with previous studies (Johnson et al., 2015; Oliver & Raney, 2011), increased autonomy was associated with high enjoyment. ...\r\n \r\nIn the discussion section, it is particularly important to critically question your findings. Consider whether the difference in the dependent variable is really caused by the manipulation of the independent variable, or whether alternative explanations exist (e.g. confounding variables, influential variable assessed in previous studies but not in yours). Correspondingly, if you find no significant difference in the dependent variable, you need to ask yourself it this means that there is no relationship between your independent and dependent variable.\r\n \r\n**3. What are the implications of your findings, and what limitations of design exist?** \r\nThis third part of the discussion section is divided further into three subsections. \r\nFirst, you write about how your findings inform new research questions. Consider what is important or interesting to explore further. For instance, if the relationship between IV and DV was not clear in your experiment, how could a future study investigate it better? For example:\r\n\r\n> Future research may examine how to encourage players to share their feelings and thoughts evoked by game events with others. This seems especially important for serious games, as it may promote discussion of the subject. ...\r\n \r\nNext, if you think there is an implication for practitioners, who will merit from your findings and what practical relevance they have. It’s important to be specific, simply to mention that your findings have implication is not enough. For example:\r\n\r\n> Our findings have implication for researchers and practitioners wanting to evaluate long-lasting game experience. Such experiences have been argued to be difficult to assess in the long run (Lacovides & Cox, 2015). A possible work-around would be to take appreciation into account as this was found in our study to be associated to long-lasting effect. ...\r\n \r\nFinally, briefly discuss (max. 1 paragraph) the limitations of your experimental design. Consider what could be changed when replicating your study. For example:\r\n\r\n> A limitation is that the present study asked participants to recall a past game experience. But as the retrospective evaluation of an experience may differ from the moment-to-moment experience (Kahnemann & Riis, 2005), it is necessary to also explore players’ feelings and thoughts during or immediately after a gaming experience in future work.\r\n \r\n**4. Conclusion of your main implication** \r\nIn the last paragraph of the discussion section, you briefly summarize your study. In contrast to the abstract, the focus of the conclusion lies on the main findings and the main discussion points. Here, you present the take-home message for the reader of your paper. For example:\r\n\r\n> In conclusion, our results suggest that autonomy of players and appreciation of game elements play a key role in evoking positive emotions in a variety of computer games. Both factors, high autonomy and high appreciation, increase positive emotional experiences for players of both genders, especially in games involving a social component. Autonomy and appreciation thereby provide a mechanism to influence player experiences.', None, '', None, None, None, None, None, None, None, 'University of Basel', 'University of Basel', 'University of Basel', None, 'TT', '10 min.', 4, 'published', False, None, None, None, None, 21), (1029, datetime.datetime(2021, 11, 30, 8, 24, 22, 398141, tzinfo=datetime.timezone.utc), datetime.datetime(2021, 11, 30, 8, 24, 54, 831438, tzinfo=datetime.timezone.utc), datetime.datetime(2021, 11, 30, 8, 24, 54, 808989, tzinfo=datetime.timezone.utc), False, 'Write an abstract', 'Write an abstract', None, None, '', None, None, None, '', None, None, None, '', 'write-an-abstract', 'The abstract is one paragraph that summarizes the research question, hypothesis, design, methods, and results in an easy to read way. This chapter briefly outlines the basics of good abstracts.\r\n{.lead}\r\n\r\n**Short summary of everything** \r\nThe abstract is a written summary of a research. It is around 150 to maximally 250 words of length. When you write an abstract, take your time to be informative but brief and concise at the same time, rather than writing a long and verbose text. Also, write your abstract for readers from other fields or who have never heard of your specific methods or research topic. The audience of an abstract is a psychologist who is not necessarily working in your field and does not know your area of expertise.\r\n \r\n**How is the abstract structured?** \r\nThe text of the abstract of an empirical paper has a standard structure. It starts with one to two sentence that clearly state the problem or research question and goals of your research (for instance, *“This paper investigates the role of … in ...”*). The next one to two sentences must explicitly state all the tested hypotheses, even if exploratory (for instance, *“We hypothesized, based on prospect theory, that highly loss-averse individuals should … compared to people that are less loss-averse ...”*). Next, briefly write about the experimental design and methods that were used, including the sample size (for instance, *”To investigate this question, we conducted one online experiment (N = 89), which asked participants to … followed by … and ...”*), this usually takes one or two sentences. Afterwards, the next one or two sentences describe the main results, usually in plain text using words rather than in numbers (for instance, *”The results from a ANOVA show that … increases ….”*). This is followed by a very brief sentence that relates the result back to the hypotheses (for instance, *”These findings fail to support prospect theory”*). This is followed by the last sentence of the abstract which always is a conclusion from the empirical findings that mentions implications (for instance *”Taken together, our work shows that prospect theory is not ...”*). Implications are what the research findings mean for the practice or theory or future research.\r\n\r\n**How is the abstract formatted?** \r\nFollowing the APA format, the abstract has a section heading called **Abstract** in bold and centered. The abstract text is always formatted as one single paragraph, which means abstract texts contain no line breaks and no paragraph breaks. The line spacing is double-spaced (as usual in APA). Abstracts appear on the first page after the title page of psychological papers, and the abstract starts at the top of the page.', 'The abstract is one paragraph that summarizes the research question, hypothesis, design, methods, and results in an easy to read way. This chapter briefly outlines the basics of good abstracts.\r\n{.lead}\r\n\r\n**Short summary of everything** \r\nThe abstract is a written summary of a research. It is around 150 to maximally 250 words of length. When you write an abstract, take your time to be informative but brief and concise at the same time, rather than writing a long and verbose text. Also, write your abstract for readers from other fields or who have never heard of your specific methods or research topic. The audience of an abstract is a psychologist who is not necessarily working in your field and does not know your area of expertise.\r\n \r\n**How is the abstract structured?** \r\nThe text of the abstract of an empirical paper has a standard structure. It starts with one to two sentence that clearly state the problem or research question and goals of your research (for instance, *“This paper investigates the role of … in ...”*). The next one to two sentences must explicitly state all the tested hypotheses, even if exploratory (for instance, *“We hypothesized, based on prospect theory, that highly loss-averse individuals should … compared to people that are less loss-averse ...”*). Next, briefly write about the experimental design and methods that were used, including the sample size (for instance, *”To investigate this question, we conducted one online experiment (N = 89), which asked participants to … followed by … and ...”*), this usually takes one or two sentences. Afterwards, the next one or two sentences describe the main results, usually in plain text using words rather than in numbers (for instance, *”The results from a ANOVA show that … increases ….”*). This is followed by a very brief sentence that relates the result back to the hypotheses (for instance, *”These findings fail to support prospect theory”*). This is followed by the last sentence of the abstract which always is a conclusion from the empirical findings that mentions implications (for instance *”Taken together, our work shows that prospect theory is not ...”*). Implications are what the research findings mean for the practice or theory or future research.\r\n\r\n**How is the abstract formatted?** \r\nFollowing the APA format, the abstract has a section heading called **Abstract** in bold and centered. The abstract text is always formatted as one single paragraph, which means abstract texts contain no line breaks and no paragraph breaks. The line spacing is double-spaced (as usual in APA). Abstracts appear on the first page after the title page of psychological papers, and the abstract starts at the top of the page.', '', '', '', '', '', '', None, None, None, None, '', '', '', '', 'TT', '10 min', 5, 'published', False, None, None, None, None, 21)]])}, None) {} <django_redis.cache.RedisCache object at 0x7910e287a790>
/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in run(101)
  return _run_old_run_func()

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in _run_old_run_func(94)
  return old_run_func(self, *a, **kw)

/usr/local/lib/python3.11/concurrent/futures/thread.py in _worker(83)
  work_item.run()

/usr/local/lib/python3.11/concurrent/futures/thread.py in run(58)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/corsheaders/middleware.py in __call__(56)
  result = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in middleware(32)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/allauth/account/middleware.py in middleware(36)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/simple_history/middleware.py in middleware(41)
  return get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/django_htmx/middleware.py in __call__(43)
  return self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in __call__(168)
  response = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/panels.py in process_request(41)
  return super(CachalotPanel, self).process_request(request)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in __call__(244)
  current_executor.run_until_future(call_result)

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run_until_future(81)
  work_item.run()

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run(40)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_wrapped_callback(90)
  return callback(request, *args, **kwargs)

/app/project/utils/decorators.py in apply_cache(72)
  cache.set(CACHE_KEY, response.render(), ttl)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_patched_render(41)
  return old_render(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in render(114)
  self.content = self.rendered_content

/usr/local/lib/python3.11/site-packages/sentry_sdk/utils.py in runner(1788)
  return sentry_patched_function(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/templates.py in rendered_content(77)
  return real_rendered_content.fget(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in rendered_content(92)
  return template.render(context, self._request)

/usr/local/lib/python3.11/site-packages/django/template/backends/django.py in render(61)
  return self.template.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(175)
  return self._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py in render(541)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1064)
  output = self.filter_expression.resolve(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in resolve(715)
  obj = self.var.resolve(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in resolve(847)
  value = self._resolve_lookup(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in _resolve_lookup(914)
  current = current()

/app/project/lms_tales/models.py in get_step_number(118)
  step_list = list(self.chapter.published_steps.all().order_by("order"))

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(37)
  return original(compiler, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(96)
  return _get_result_or_execute_query(

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in _get_result_or_execute_query(71)
  cache.set_many(to_be_set, cachalot_settings.CACHALOT_TIMEOUT)

0,3372 get ('waffle:4.1.0e9e267545e7f919d987e2d016e67ed7e',) {} <django_redis.cache.RedisCache object at 0x7910e287a790>
/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in run(101)
  return _run_old_run_func()

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in _run_old_run_func(94)
  return old_run_func(self, *a, **kw)

/usr/local/lib/python3.11/concurrent/futures/thread.py in _worker(83)
  work_item.run()

/usr/local/lib/python3.11/concurrent/futures/thread.py in run(58)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/corsheaders/middleware.py in __call__(56)
  result = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in middleware(32)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/allauth/account/middleware.py in middleware(36)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/simple_history/middleware.py in middleware(41)
  return get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/django_htmx/middleware.py in __call__(43)
  return self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in __call__(168)
  response = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/panels.py in process_request(41)
  return super(CachalotPanel, self).process_request(request)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in __call__(244)
  current_executor.run_until_future(call_result)

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run_until_future(81)
  work_item.run()

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run(40)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_wrapped_callback(90)
  return callback(request, *args, **kwargs)

/app/project/utils/decorators.py in apply_cache(72)
  cache.set(CACHE_KEY, response.render(), ttl)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_patched_render(41)
  return old_render(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in render(114)
  self.content = self.rendered_content

/usr/local/lib/python3.11/site-packages/sentry_sdk/utils.py in runner(1788)
  return sentry_patched_function(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/templates.py in rendered_content(77)
  return real_rendered_content.fget(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in rendered_content(92)
  return template.render(context, self._request)

/usr/local/lib/python3.11/site-packages/django/template/backends/django.py in render(61)
  return self.template.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(175)
  return self._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py in render(541)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/waffle/templatetags/waffle_tags.py in render(36)
  if self.condition(context.get('request', None), name):

/usr/local/lib/python3.11/site-packages/waffle/__init__.py in flag_is_active(19)
  flag = get_waffle_flag_model().get(flag_name)

/usr/local/lib/python3.11/site-packages/waffle/models.py in get(52)
  cached = cache.get(cache_key)

0,3007 add ('waffle:4.1.0e9e267545e7f919d987e2d016e67ed7e', <Flag: comments_feature_is_active>) {} <django_redis.cache.RedisCache object at 0x7910e287a790>
/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in run(101)
  return _run_old_run_func()

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in _run_old_run_func(94)
  return old_run_func(self, *a, **kw)

/usr/local/lib/python3.11/concurrent/futures/thread.py in _worker(83)
  work_item.run()

/usr/local/lib/python3.11/concurrent/futures/thread.py in run(58)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/corsheaders/middleware.py in __call__(56)
  result = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in middleware(32)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/allauth/account/middleware.py in middleware(36)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/simple_history/middleware.py in middleware(41)
  return get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/django_htmx/middleware.py in __call__(43)
  return self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in __call__(168)
  response = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/panels.py in process_request(41)
  return super(CachalotPanel, self).process_request(request)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in __call__(244)
  current_executor.run_until_future(call_result)

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run_until_future(81)
  work_item.run()

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run(40)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_wrapped_callback(90)
  return callback(request, *args, **kwargs)

/app/project/utils/decorators.py in apply_cache(72)
  cache.set(CACHE_KEY, response.render(), ttl)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_patched_render(41)
  return old_render(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in render(114)
  self.content = self.rendered_content

/usr/local/lib/python3.11/site-packages/sentry_sdk/utils.py in runner(1788)
  return sentry_patched_function(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/templates.py in rendered_content(77)
  return real_rendered_content.fget(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in rendered_content(92)
  return template.render(context, self._request)

/usr/local/lib/python3.11/site-packages/django/template/backends/django.py in render(61)
  return self.template.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(175)
  return self._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py in render(541)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/waffle/templatetags/waffle_tags.py in render(36)
  if self.condition(context.get('request', None), name):

/usr/local/lib/python3.11/site-packages/waffle/__init__.py in flag_is_active(19)
  flag = get_waffle_flag_model().get(flag_name)

/usr/local/lib/python3.11/site-packages/waffle/models.py in get(64)
  cache.add(cache_key, obj)

0,2221 get_many (['138549f5508bbba7283d6a0625e51c589d845e8f', '4f1f0b4dfbd30463b5587753e6f3e6ca21ddbf60', '914850ebf80706581ba37746aabecb7cd88d8973'],) {} <django_redis.cache.RedisCache object at 0x7910e287a790>
/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in run(101)
  return _run_old_run_func()

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in _run_old_run_func(94)
  return old_run_func(self, *a, **kw)

/usr/local/lib/python3.11/concurrent/futures/thread.py in _worker(83)
  work_item.run()

/usr/local/lib/python3.11/concurrent/futures/thread.py in run(58)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/corsheaders/middleware.py in __call__(56)
  result = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in middleware(32)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/allauth/account/middleware.py in middleware(36)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/simple_history/middleware.py in middleware(41)
  return get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/django_htmx/middleware.py in __call__(43)
  return self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in __call__(168)
  response = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/panels.py in process_request(41)
  return super(CachalotPanel, self).process_request(request)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in __call__(244)
  current_executor.run_until_future(call_result)

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run_until_future(81)
  work_item.run()

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run(40)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_wrapped_callback(90)
  return callback(request, *args, **kwargs)

/app/project/utils/decorators.py in apply_cache(72)
  cache.set(CACHE_KEY, response.render(), ttl)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_patched_render(41)
  return old_render(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in render(114)
  self.content = self.rendered_content

/usr/local/lib/python3.11/site-packages/sentry_sdk/utils.py in runner(1788)
  return sentry_patched_function(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/templates.py in rendered_content(77)
  return real_rendered_content.fget(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in rendered_content(92)
  return template.render(context, self._request)

/usr/local/lib/python3.11/site-packages/django/template/backends/django.py in render(61)
  return self.template.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(175)
  return self._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py in render(541)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py in render(320)
  if match:

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(37)
  return original(compiler, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(96)
  return _get_result_or_execute_query(

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in _get_result_or_execute_query(46)
  data = cache.get_many(table_cache_keys + [cache_key])

0,2223 get_many (['76e323efd8711853e13c9f7cf976845908364eb2', '60712feda073c15a3803c02cda9d0e1a967758da'],) {} <django_redis.cache.RedisCache object at 0x7910e287a790>
/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in run(101)
  return _run_old_run_func()

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in _run_old_run_func(94)
  return old_run_func(self, *a, **kw)

/usr/local/lib/python3.11/concurrent/futures/thread.py in _worker(83)
  work_item.run()

/usr/local/lib/python3.11/concurrent/futures/thread.py in run(58)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/corsheaders/middleware.py in __call__(56)
  result = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in middleware(32)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/allauth/account/middleware.py in middleware(36)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/simple_history/middleware.py in middleware(41)
  return get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/django_htmx/middleware.py in __call__(43)
  return self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in __call__(168)
  response = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/panels.py in process_request(41)
  return super(CachalotPanel, self).process_request(request)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in __call__(244)
  current_executor.run_until_future(call_result)

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run_until_future(81)
  work_item.run()

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run(40)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_wrapped_callback(90)
  return callback(request, *args, **kwargs)

/app/project/utils/decorators.py in apply_cache(72)
  cache.set(CACHE_KEY, response.render(), ttl)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_patched_render(41)
  return old_render(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in render(114)
  self.content = self.rendered_content

/usr/local/lib/python3.11/site-packages/sentry_sdk/utils.py in runner(1788)
  return sentry_patched_function(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/templates.py in rendered_content(77)
  return real_rendered_content.fget(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in rendered_content(92)
  return template.render(context, self._request)

/usr/local/lib/python3.11/site-packages/django/template/backends/django.py in render(61)
  return self.template.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(175)
  return self._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py in render(541)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py in render(314)
  match = condition.eval(context)

/usr/local/lib/python3.11/site-packages/django/template/smartif.py in eval(60)
  return func(context, self.first, self.second)

/usr/local/lib/python3.11/site-packages/django/template/smartif.py in <lambda>(103)
  "is not": infix(10, lambda context, x, y: x.eval(context) is not y.eval(context)),

/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py in eval(877)
  return self.value.resolve(context, ignore_failures=True)

/usr/local/lib/python3.11/site-packages/django/template/base.py in resolve(715)
  obj = self.var.resolve(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in resolve(847)
  value = self._resolve_lookup(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in _resolve_lookup(914)
  current = current()

/app/project/lms_tales/models.py in get_absolute_url(96)
  str(self.chapter.course.slug),

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(37)
  return original(compiler, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(96)
  return _get_result_or_execute_query(

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in _get_result_or_execute_query(46)
  data = cache.get_many(table_cache_keys + [cache_key])

0,2350 get_many (['e3a5db5a670ad803efb866441f33de58309be2e2', '8de636776a198de6ec9a987a55b157e4712013cf'],) {} <django_redis.cache.RedisCache object at 0x7910e287a790>
/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in run(101)
  return _run_old_run_func()

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in _run_old_run_func(94)
  return old_run_func(self, *a, **kw)

/usr/local/lib/python3.11/concurrent/futures/thread.py in _worker(83)
  work_item.run()

/usr/local/lib/python3.11/concurrent/futures/thread.py in run(58)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/corsheaders/middleware.py in __call__(56)
  result = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in middleware(32)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/allauth/account/middleware.py in middleware(36)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/simple_history/middleware.py in middleware(41)
  return get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/django_htmx/middleware.py in __call__(43)
  return self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in __call__(168)
  response = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/panels.py in process_request(41)
  return super(CachalotPanel, self).process_request(request)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in __call__(244)
  current_executor.run_until_future(call_result)

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run_until_future(81)
  work_item.run()

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run(40)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_wrapped_callback(90)
  return callback(request, *args, **kwargs)

/app/project/utils/decorators.py in apply_cache(72)
  cache.set(CACHE_KEY, response.render(), ttl)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_patched_render(41)
  return old_render(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in render(114)
  self.content = self.rendered_content

/usr/local/lib/python3.11/site-packages/sentry_sdk/utils.py in runner(1788)
  return sentry_patched_function(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/templates.py in rendered_content(77)
  return real_rendered_content.fget(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in rendered_content(92)
  return template.render(context, self._request)

/usr/local/lib/python3.11/site-packages/django/template/backends/django.py in render(61)
  return self.template.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(175)
  return self._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py in render(541)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py in render(314)
  match = condition.eval(context)

/usr/local/lib/python3.11/site-packages/django/template/smartif.py in eval(60)
  return func(context, self.first, self.second)

/usr/local/lib/python3.11/site-packages/django/template/smartif.py in <lambda>(103)
  "is not": infix(10, lambda context, x, y: x.eval(context) is not y.eval(context)),

/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py in eval(877)
  return self.value.resolve(context, ignore_failures=True)

/usr/local/lib/python3.11/site-packages/django/template/base.py in resolve(715)
  obj = self.var.resolve(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in resolve(847)
  value = self._resolve_lookup(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in _resolve_lookup(914)
  current = current()

/app/project/lms_tales/models.py in get_absolute_url(96)
  str(self.chapter.course.slug),

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(37)
  return original(compiler, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(96)
  return _get_result_or_execute_query(

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in _get_result_or_execute_query(46)
  data = cache.get_many(table_cache_keys + [cache_key])

0,2234 get_many (['76e323efd8711853e13c9f7cf976845908364eb2', 'b331d72d6689ac0f229c8cf8d09681cf4ed61f0a'],) {} <django_redis.cache.RedisCache object at 0x7910e287a790>
/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in run(101)
  return _run_old_run_func()

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in _run_old_run_func(94)
  return old_run_func(self, *a, **kw)

/usr/local/lib/python3.11/concurrent/futures/thread.py in _worker(83)
  work_item.run()

/usr/local/lib/python3.11/concurrent/futures/thread.py in run(58)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/corsheaders/middleware.py in __call__(56)
  result = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in middleware(32)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/allauth/account/middleware.py in middleware(36)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/simple_history/middleware.py in middleware(41)
  return get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/django_htmx/middleware.py in __call__(43)
  return self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in __call__(168)
  response = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/panels.py in process_request(41)
  return super(CachalotPanel, self).process_request(request)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in __call__(244)
  current_executor.run_until_future(call_result)

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run_until_future(81)
  work_item.run()

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run(40)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_wrapped_callback(90)
  return callback(request, *args, **kwargs)

/app/project/utils/decorators.py in apply_cache(72)
  cache.set(CACHE_KEY, response.render(), ttl)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_patched_render(41)
  return old_render(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in render(114)
  self.content = self.rendered_content

/usr/local/lib/python3.11/site-packages/sentry_sdk/utils.py in runner(1788)
  return sentry_patched_function(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/templates.py in rendered_content(77)
  return real_rendered_content.fget(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in rendered_content(92)
  return template.render(context, self._request)

/usr/local/lib/python3.11/site-packages/django/template/backends/django.py in render(61)
  return self.template.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(175)
  return self._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py in render(541)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py in render(314)
  match = condition.eval(context)

/usr/local/lib/python3.11/site-packages/django/template/smartif.py in eval(60)
  return func(context, self.first, self.second)

/usr/local/lib/python3.11/site-packages/django/template/smartif.py in <lambda>(103)
  "is not": infix(10, lambda context, x, y: x.eval(context) is not y.eval(context)),

/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py in eval(877)
  return self.value.resolve(context, ignore_failures=True)

/usr/local/lib/python3.11/site-packages/django/template/base.py in resolve(715)
  obj = self.var.resolve(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in resolve(847)
  value = self._resolve_lookup(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in _resolve_lookup(914)
  current = current()

/app/project/lms_tales/models.py in get_absolute_url(96)
  str(self.chapter.course.slug),

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(37)
  return original(compiler, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(96)
  return _get_result_or_execute_query(

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in _get_result_or_execute_query(46)
  data = cache.get_many(table_cache_keys + [cache_key])

0,2372 get_many (['e3a5db5a670ad803efb866441f33de58309be2e2', '8de636776a198de6ec9a987a55b157e4712013cf'],) {} <django_redis.cache.RedisCache object at 0x7910e287a790>
/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in run(101)
  return _run_old_run_func()

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in _run_old_run_func(94)
  return old_run_func(self, *a, **kw)

/usr/local/lib/python3.11/concurrent/futures/thread.py in _worker(83)
  work_item.run()

/usr/local/lib/python3.11/concurrent/futures/thread.py in run(58)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/corsheaders/middleware.py in __call__(56)
  result = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in middleware(32)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/allauth/account/middleware.py in middleware(36)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/simple_history/middleware.py in middleware(41)
  return get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/django_htmx/middleware.py in __call__(43)
  return self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in __call__(168)
  response = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/panels.py in process_request(41)
  return super(CachalotPanel, self).process_request(request)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in __call__(244)
  current_executor.run_until_future(call_result)

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run_until_future(81)
  work_item.run()

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run(40)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_wrapped_callback(90)
  return callback(request, *args, **kwargs)

/app/project/utils/decorators.py in apply_cache(72)
  cache.set(CACHE_KEY, response.render(), ttl)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_patched_render(41)
  return old_render(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in render(114)
  self.content = self.rendered_content

/usr/local/lib/python3.11/site-packages/sentry_sdk/utils.py in runner(1788)
  return sentry_patched_function(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/templates.py in rendered_content(77)
  return real_rendered_content.fget(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in rendered_content(92)
  return template.render(context, self._request)

/usr/local/lib/python3.11/site-packages/django/template/backends/django.py in render(61)
  return self.template.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(175)
  return self._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py in render(541)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py in render(314)
  match = condition.eval(context)

/usr/local/lib/python3.11/site-packages/django/template/smartif.py in eval(60)
  return func(context, self.first, self.second)

/usr/local/lib/python3.11/site-packages/django/template/smartif.py in <lambda>(103)
  "is not": infix(10, lambda context, x, y: x.eval(context) is not y.eval(context)),

/usr/local/lib/python3.11/site-packages/django/template/defaulttags.py in eval(877)
  return self.value.resolve(context, ignore_failures=True)

/usr/local/lib/python3.11/site-packages/django/template/base.py in resolve(715)
  obj = self.var.resolve(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in resolve(847)
  value = self._resolve_lookup(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in _resolve_lookup(914)
  current = current()

/app/project/lms_tales/models.py in get_absolute_url(96)
  str(self.chapter.course.slug),

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(37)
  return original(compiler, *args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in inner(96)
  return _get_result_or_execute_query(

/usr/local/lib/python3.11/site-packages/cachalot/monkey_patch.py in _get_result_or_execute_query(46)
  data = cache.get_many(table_cache_keys + [cache_key])

0,2518 get ('waffle:4.1.0e9e267545e7f919d987e2d016e67ed7e',) {} <django_redis.cache.RedisCache object at 0x7910e287a790>
/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in run(101)
  return _run_old_run_func()

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in _run_old_run_func(94)
  return old_run_func(self, *a, **kw)

/usr/local/lib/python3.11/concurrent/futures/thread.py in _worker(83)
  work_item.run()

/usr/local/lib/python3.11/concurrent/futures/thread.py in run(58)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/corsheaders/middleware.py in __call__(56)
  result = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in middleware(32)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/allauth/account/middleware.py in middleware(36)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/simple_history/middleware.py in middleware(41)
  return get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/django_htmx/middleware.py in __call__(43)
  return self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in __call__(168)
  response = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/panels.py in process_request(41)
  return super(CachalotPanel, self).process_request(request)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in __call__(244)
  current_executor.run_until_future(call_result)

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run_until_future(81)
  work_item.run()

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run(40)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_wrapped_callback(90)
  return callback(request, *args, **kwargs)

/app/project/utils/decorators.py in apply_cache(72)
  cache.set(CACHE_KEY, response.render(), ttl)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_patched_render(41)
  return old_render(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in render(114)
  self.content = self.rendered_content

/usr/local/lib/python3.11/site-packages/sentry_sdk/utils.py in runner(1788)
  return sentry_patched_function(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/templates.py in rendered_content(77)
  return real_rendered_content.fget(self)

/usr/local/lib/python3.11/site-packages/django/template/response.py in rendered_content(92)
  return template.render(context, self._request)

/usr/local/lib/python3.11/site-packages/django/template/backends/django.py in render(61)
  return self.template.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(175)
  return self._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(157)
  return compiled_parent._render(context)

/usr/local/lib/python3.11/site-packages/django/test/utils.py in instrumented_test_render(112)
  return self.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/django/template/loader_tags.py in render(63)
  result = block.nodelist.render(context)

/usr/local/lib/python3.11/site-packages/django/template/base.py in render(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in <listcomp>(1005)
  return SafeString("".join([node.render_annotated(context) for node in self]))

/usr/local/lib/python3.11/site-packages/django/template/base.py in render_annotated(966)
  return self.render(context)

/usr/local/lib/python3.11/site-packages/waffle/templatetags/waffle_tags.py in render(36)
  if self.condition(context.get('request', None), name):

/usr/local/lib/python3.11/site-packages/waffle/__init__.py in flag_is_active(19)
  flag = get_waffle_flag_model().get(flag_name)

/usr/local/lib/python3.11/site-packages/waffle/models.py in get(52)
  cached = cache.get(cache_key)

0,9216 set ('view_cache_view_/de/conducting-psychological-research-6/writing-a-scientific-report-21/write-an-abstract-1029_anonymous', <TemplateResponse status_code=200, "text/html; charset=utf-8">, 600) {} <django_redis.cache.RedisCache object at 0x7910e287a790>
/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in run(101)
  return _run_old_run_func()

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/threading.py in _run_old_run_func(94)
  return old_run_func(self, *a, **kw)

/usr/local/lib/python3.11/concurrent/futures/thread.py in _worker(83)
  work_item.run()

/usr/local/lib/python3.11/concurrent/futures/thread.py in run(58)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/corsheaders/middleware.py in __call__(56)
  result = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in middleware(32)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/allauth/account/middleware.py in middleware(36)
  response = get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/simple_history/middleware.py in middleware(41)
  return get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/django_htmx/middleware.py in __call__(43)
  return self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/app/project/lms_tales/middleware.py in __call__(168)
  response = self.get_response(request)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/middleware.py in __call__(177)
  return f(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/cachalot/panels.py in process_request(41)
  return super(CachalotPanel, self).process_request(request)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in __call__(244)
  current_executor.run_until_future(call_result)

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run_until_future(81)
  work_item.run()

/usr/local/lib/python3.11/site-packages/asgiref/current_thread_executor.py in run(40)
  result = self.fn(*self.args, **self.kwargs)

/usr/local/lib/python3.11/site-packages/asgiref/sync.py in thread_handler(522)
  return func(*args, **kwargs)

/usr/local/lib/python3.11/site-packages/sentry_sdk/integrations/django/views.py in sentry_wrapped_callback(90)
  return callback(request, *args, **kwargs)

/app/project/utils/decorators.py in apply_cache(72)
  cache.set(CACHE_KEY, response.render(), ttl)

Cachalot

Database 'default'

Application Model Last invalidation
django_q Failure 5 Stunden, 52 Minuten
notifications Notification 5 Stunden, 52 Minuten
django_q Schedule 5 Stunden, 52 Minuten
reporting Report 8 Stunden, 15 Minuten
lms_tales CourseMetrics 15 Stunden, 22 Minuten
search FulltextSearchModel 17 Stunden, 22 Minuten
search TrigramSearchModel 1 Tag, 2 Stunden
lms_tales HistoricalTalesCourse 1 Tag, 2 Stunden
lms_tales TalesCourse 1 Tag, 2 Stunden
lms_tales TalesStep 1 Tag, 2 Stunden
lms_tales TalesChapter 1 Tag, 2 Stunden
lms_tales HistoricalTalesStep 1 Tag, 2 Stunden
lms_tales HistoricalTalesChapter 1 Tag, 2 Stunden
lms_roles CourseRole 1 Tag, 2 Stunden
auth Permission 1 Tag, 3 Stunden
contenttypes ContentType 1 Tag, 3 Stunden
startpage SliderItem 1 Tag, 3 Stunden
startpage CategoryCourse 1 Tag, 3 Stunden
tags Category 1 Tag, 3 Stunden
tags Tag 1 Tag, 3 Stunden
lms_static_texts StaticText 1 Tag, 3 Stunden
lms_static_texts HistoricalStaticText 1 Tag, 3 Stunden
lms_comments Comment 1 Tag, 3 Stunden
lms_comments Reply 1 Tag, 3 Stunden
lms_comments Reaction 1 Tag, 3 Stunden
lms_comments Flag 1 Tag, 3 Stunden
lms_tales TalesStepFileNew 1 Tag, 3 Stunden
lms_tales TalesStepFile 1 Tag, 3 Stunden
lms_tales TalesCourseFile 1 Tag, 3 Stunden
lms_tales TalesAuthor 1 Tag, 3 Stunden
lms_tales TalesPartner 1 Tag, 3 Stunden
lms_tales TalesGlossaryItem 1 Tag, 3 Stunden
lms_tales TalesPath 1 Tag, 3 Stunden
lms_tales TalesPathStep 1 Tag, 3 Stunden
lms_tales TalesCourseRun 1 Tag, 3 Stunden
lms_tales TalesCourseRunStep 1 Tag, 3 Stunden
lms_tales ScheduledMessage 1 Tag, 3 Stunden
lms_tales HistoricalTalesStepFile 1 Tag, 3 Stunden
lms_tales HistoricalTalesPath 1 Tag, 3 Stunden
lms_base GlossaryMixin 1 Tag, 3 Stunden
lms_base GlossaryItemMixin 1 Tag, 3 Stunden
users User 1 Tag, 3 Stunden
users UserSettings 1 Tag, 3 Stunden
auth Group 1 Tag, 3 Stunden
sessions Session 1 Tag, 3 Stunden
sites Site 1 Tag, 3 Stunden
flatpages FlatPage 1 Tag, 3 Stunden
admin LogEntry 1 Tag, 3 Stunden
redirects Redirect 1 Tag, 3 Stunden
account EmailAddress 1 Tag, 3 Stunden
account EmailConfirmation 1 Tag, 3 Stunden
socialaccount SocialApp 1 Tag, 3 Stunden
socialaccount SocialAccount 1 Tag, 3 Stunden
socialaccount SocialToken 1 Tag, 3 Stunden
waffle Flag 1 Tag, 3 Stunden
waffle Switch 1 Tag, 3 Stunden
waffle Sample 1 Tag, 3 Stunden
tos TermsOfService 1 Tag, 3 Stunden
tos UserAgreement 1 Tag, 3 Stunden
impersonate ImpersonationLog 1 Tag, 3 Stunden
django_q OrmQ 1 Tag, 3 Stunden

Signale

Signal Empfänger
class_prepared StatusField.prepare_class, add_status_query_managers, add_timeframed_query_manager, StatusField.prepare_class, StatusField.prepare_class, StatusField.prepare_class, StatusField.prepare_class, StatusField.prepare_class, StatusField.prepare_class, StatusField.prepare_class, StatusField.prepare_class, StatusField.prepare_class, StatusField.prepare_class
connection_created
got_request_exception _got_request_exception
m2m_changed flag_membership_changed, flag_membership_changed
post_delete HistoricalRecords.post_delete, HistoricalRecords.post_delete, HistoricalRecords.post_delete, HistoricalRecords.post_delete, HistoricalRecords.post_delete, HistoricalRecords.post_delete, delete_search_index, delete_search_index
post_init ModelSignalRouter.post_init_receiver, MonitorField._save_initial, MonitorField._save_initial, MonitorField._save_initial, MonitorField._save_initial, ImageField.update_dimension_fields, MonitorField._save_initial, ImageField.update_dimension_fields, MonitorField._save_initial, MonitorField._save_initial, ImageField.update_dimension_fields, ImageField.update_dimension_fields, ImageField.update_dimension_fields, MonitorField._save_initial, delete_mt_init, delete_mt_init, delete_mt_init, delete_mt_init, delete_mt_init, delete_mt_init, delete_mt_init, delete_mt_init, delete_mt_init, MonitorField._save_initial, MonitorField._save_initial, MonitorField._save_initial, delete_mt_init, delete_mt_init, delete_mt_init
post_migrate create_permissions, create_contenttypes, create_default_site, _invalidate_on_migration
post_save ModelSignalRouter.post_save_receiver, HistoricalRecords.post_save, HistoricalRecords.post_save, HistoricalRecords.post_save, HistoricalRecords.post_save, HistoricalRecords.post_save, HistoricalRecords.post_save, call_hook, create_user_settings, save_user_settings, update_search_index, update_search_index
pre_delete clear_site_cache
pre_init
pre_migrate inject_rename_contenttypes_operations
pre_save clear_site_cache
request_finished close_old_connections, close_caches, reset_urlconf
request_started reset_queries, close_old_connections
setting_changed reset_cache, reload_settings, clear_cache_handlers, update_installed_apps, update_connections_time_zone, clear_routers_cache, reset_template_engines, storages_changed, clear_serializers_cache, language_changed, localize_settings_changed, file_storage_changed, complex_setting_changed, root_urlconf_changed, static_storage_changed, static_finders_changed, auth_password_validators_changed, user_model_swapped, update_toolbar_config, reset_hashers, update_level_tags, clear_caches, FileSystemStorage._clear_cached_properties, StaticFilesStorage._clear_cached_properties, FileSystemStorage._clear_cached_properties, FileSystemStorage._clear_cached_properties, FileSystemStorage._clear_cached_properties, FileSystemStorage._clear_cached_properties, FileSystemStorage._clear_cached_properties, FileSystemStorage._clear_cached_properties, FileSystemStorage._clear_cached_properties, FileSystemStorage._clear_cached_properties, FileSystemStorage._clear_cached_properties