From 8d9c0e4e244111ea3839434d8812c8573cfbf00e Mon Sep 17 00:00:00 2001 From: Marc Gibbons <1726961+marcgibbons@users.noreply.github.com> Date: Thu, 19 Oct 2023 16:49:16 -0400 Subject: [PATCH] Doc'd writing integration tests for the system check framework. --- docs/ref/checks.txt | 2 ++ docs/topics/checks.txt | 64 ++++++++++++++++++++++++++++++++++++++++++ 2 files changed, 66 insertions(+) diff --git a/docs/ref/checks.txt b/docs/ref/checks.txt index 9170ff83a830..1bf6ce538355 100644 --- a/docs/ref/checks.txt +++ b/docs/ref/checks.txt @@ -894,6 +894,8 @@ fields: changed to* ``fields.E010`` *in Django 3.1*. * **postgres.W004**: Base field for array has warnings: ... +.. _sites-system-checks: + ``sites`` --------- diff --git a/docs/topics/checks.txt b/docs/topics/checks.txt index 3b3a02eef08f..9a91ceb46903 100644 --- a/docs/topics/checks.txt +++ b/docs/topics/checks.txt @@ -214,3 +214,67 @@ Messages are comparable. That allows you to easily write tests:: ) ] self.assertEqual(errors, expected_errors) + +Writing integration tests +~~~~~~~~~~~~~~~~~~~~~~~~~ + +Given the need to register certain checks when the application loads, it can be +useful to test their integration within the system checks framework. This can +be accomplished by using the :func:`~django.core.management.call_command` +function. + +For example, this test demonstrates that the :setting:`SITE_ID` setting must be +an integer, a built-in :ref:`check from the sites framework +`:: + + from django.core.management import call_command + from django.core.management.base import SystemCheckError + from django.test import SimpleTestCase, modify_settings, override_settings + + + class SystemCheckIntegrationTest(SimpleTestCase): + @override_settings(SITE_ID="non_integer") + @modify_settings(INSTALLED_APPS={"prepend": "django.contrib.sites"}) + def test_non_integer_site_id(self): + message = "(sites.E101) The SITE_ID setting must be an integer." + with self.assertRaisesMessage(SystemCheckError, message): + call_command("check") + +Consider the following check which issues a warning on deployment if a custom +setting named ``ENABLE_ANALYTICS`` is not set to ``True``:: + + from django.conf import settings + from django.core.checks import Warning, register + + + @register("myapp", deploy=True) + def check_enable_analytics_is_true_on_deploy(app_configs, **kwargs): + errors = [] + if getattr(settings, "ENABLE_ANALYTICS", None) is not True: + errors.append( + Warning( + "The ENABLE_ANALYTICS setting should be set to True in deployment.", + id="myapp.W001", + ) + ) + return errors + +Given that this check will not raise a ``SystemCheckError``, the presence of +the warning message in the ``stderr`` output can be asserted like so:: + + from io import StringIO + + from django.core.management import call_command + from django.test import SimpleTestCase, override_settings + + + class EnableAnalyticsDeploymentCheckTest(SimpleTestCase): + @override_settings(ENABLE_ANALYTICS=None) + def test_when_set_to_none(self): + stderr = StringIO() + call_command("check", "-t", "myapp", "--deploy", stderr=stderr) + message = ( + "(myapp.W001) The ENABLE_ANALYTICS setting should be set " + "to True in deployment." + ) + self.assertIn(message, stderr.getvalue())