mirror of
				https://github.com/django/django.git
				synced 2025-10-26 07:06:08 +00:00 
			
		
		
		
	Fixed #21702 -- get_model('app_label.ModelName').
Also added tests for get_model.
This commit is contained in:
		| @@ -170,16 +170,22 @@ class Apps(object): | |||||||
|                 include_auto_created, include_deferred, include_swapped))) |                 include_auto_created, include_deferred, include_swapped))) | ||||||
|         return result |         return result | ||||||
|  |  | ||||||
|     def get_model(self, app_label, model_name): |     def get_model(self, app_label, model_name=None): | ||||||
|         """ |         """ | ||||||
|         Returns the model matching the given app_label and model_name. |         Returns the model matching the given app_label and model_name. | ||||||
|  |  | ||||||
|  |         As a shortcut, this function also accepts a single argument in the | ||||||
|  |         form <app_label>.<model_name>. | ||||||
|  |  | ||||||
|         model_name is case-insensitive. |         model_name is case-insensitive. | ||||||
|  |  | ||||||
|         Raises LookupError if no application exists with this label, or no |         Raises LookupError if no application exists with this label, or no | ||||||
|         model exists with this name in the application. |         model exists with this name in the application. Raises ValueError if | ||||||
|  |         called with a single argument that doesn't contain exactly one dot. | ||||||
|         """ |         """ | ||||||
|         self.check_ready() |         self.check_ready() | ||||||
|  |         if model_name is None: | ||||||
|  |             app_label, model_name = app_label.split('.') | ||||||
|         return self.get_app_config(app_label).get_model(model_name.lower()) |         return self.get_app_config(app_label).get_model(model_name.lower()) | ||||||
|  |  | ||||||
|     def register_model(self, app_label, model): |     def register_model(self, app_label, model): | ||||||
|   | |||||||
| @@ -274,5 +274,10 @@ Application registry | |||||||
| .. method:: apps.get_model(app_label, model_name) | .. method:: apps.get_model(app_label, model_name) | ||||||
|  |  | ||||||
|     Returns the :class:`~django.db.models.Model` with the given ``app_label`` |     Returns the :class:`~django.db.models.Model` with the given ``app_label`` | ||||||
|     and ``model_name``. Raises :exc:`~exceptions.LookupError` if no such |     and ``model_name``. As a shortcut, this method also accepts a single | ||||||
|     application or model exists. ``model_name`` is case-insensitive. |     argument in the form ``app_label.model_name``. ``model_name`` is case- | ||||||
|  |     insensitive. | ||||||
|  |  | ||||||
|  |     Raises :exc:`~exceptions.LookupError` if no such application or model | ||||||
|  |     exists. Raises :exc:`~exceptions.ValueError` when called with a single | ||||||
|  |     argument that doesn't contain exactly one dot. | ||||||
|   | |||||||
| @@ -6,6 +6,7 @@ from unittest import skipUnless | |||||||
|  |  | ||||||
| from django.apps import apps | from django.apps import apps | ||||||
| from django.apps.registry import Apps | from django.apps.registry import Apps | ||||||
|  | from django.contrib.admin.models import LogEntry | ||||||
| from django.core.exceptions import ImproperlyConfigured | from django.core.exceptions import ImproperlyConfigured | ||||||
| from django.db import models | from django.db import models | ||||||
| from django.test import TestCase, override_settings | from django.test import TestCase, override_settings | ||||||
| @@ -99,7 +100,7 @@ class AppsTests(TestCase): | |||||||
|     @override_settings(INSTALLED_APPS=SOME_INSTALLED_APPS) |     @override_settings(INSTALLED_APPS=SOME_INSTALLED_APPS) | ||||||
|     def test_get_app_configs(self): |     def test_get_app_configs(self): | ||||||
|         """ |         """ | ||||||
|         Tests get_app_configs(). |         Tests apps.get_app_configs(). | ||||||
|         """ |         """ | ||||||
|         app_configs = apps.get_app_configs() |         app_configs = apps.get_app_configs() | ||||||
|         self.assertListEqual( |         self.assertListEqual( | ||||||
| @@ -109,7 +110,7 @@ class AppsTests(TestCase): | |||||||
|     @override_settings(INSTALLED_APPS=SOME_INSTALLED_APPS) |     @override_settings(INSTALLED_APPS=SOME_INSTALLED_APPS) | ||||||
|     def test_get_app_config(self): |     def test_get_app_config(self): | ||||||
|         """ |         """ | ||||||
|         Tests get_app_config(). |         Tests apps.get_app_config(). | ||||||
|         """ |         """ | ||||||
|         app_config = apps.get_app_config('admin') |         app_config = apps.get_app_config('admin') | ||||||
|         self.assertEqual(app_config.name, 'django.contrib.admin') |         self.assertEqual(app_config.name, 'django.contrib.admin') | ||||||
| @@ -122,11 +123,35 @@ class AppsTests(TestCase): | |||||||
|  |  | ||||||
|     @override_settings(INSTALLED_APPS=SOME_INSTALLED_APPS) |     @override_settings(INSTALLED_APPS=SOME_INSTALLED_APPS) | ||||||
|     def test_is_installed(self): |     def test_is_installed(self): | ||||||
|  |         """ | ||||||
|  |         Tests apps.is_installed(). | ||||||
|  |         """ | ||||||
|         self.assertTrue(apps.is_installed('django.contrib.admin')) |         self.assertTrue(apps.is_installed('django.contrib.admin')) | ||||||
|         self.assertTrue(apps.is_installed('django.contrib.auth')) |         self.assertTrue(apps.is_installed('django.contrib.auth')) | ||||||
|         self.assertTrue(apps.is_installed('django.contrib.staticfiles')) |         self.assertTrue(apps.is_installed('django.contrib.staticfiles')) | ||||||
|         self.assertFalse(apps.is_installed('django.contrib.webdesign')) |         self.assertFalse(apps.is_installed('django.contrib.webdesign')) | ||||||
|  |  | ||||||
|  |     @override_settings(INSTALLED_APPS=SOME_INSTALLED_APPS) | ||||||
|  |     def test_get_model(self): | ||||||
|  |         """ | ||||||
|  |         Tests apps.get_model(). | ||||||
|  |         """ | ||||||
|  |         self.assertEqual(apps.get_model('admin', 'LogEntry'), LogEntry) | ||||||
|  |         with self.assertRaises(LookupError): | ||||||
|  |             apps.get_model('admin', 'LogExit') | ||||||
|  |  | ||||||
|  |         # App label is case-sensitive, Model name is case-insensitive. | ||||||
|  |         self.assertEqual(apps.get_model('admin', 'loGentrY'), LogEntry) | ||||||
|  |         with self.assertRaises(LookupError): | ||||||
|  |             apps.get_model('Admin', 'LogEntry') | ||||||
|  |  | ||||||
|  |         # A single argument is accepted. | ||||||
|  |         self.assertEqual(apps.get_model('admin.LogEntry'), LogEntry) | ||||||
|  |         with self.assertRaises(LookupError): | ||||||
|  |             apps.get_model('admin.LogExit') | ||||||
|  |         with self.assertRaises(ValueError): | ||||||
|  |             apps.get_model('admin_LogEntry') | ||||||
|  |  | ||||||
|     @override_settings(INSTALLED_APPS=['apps.apps.RelabeledAppsConfig']) |     @override_settings(INSTALLED_APPS=['apps.apps.RelabeledAppsConfig']) | ||||||
|     def test_relabeling(self): |     def test_relabeling(self): | ||||||
|         self.assertEqual(apps.get_app_config('relabeled').name, 'apps') |         self.assertEqual(apps.get_app_config('relabeled').name, 'apps') | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user