mirror of
				https://github.com/django/django.git
				synced 2025-10-26 15:16:09 +00:00 
			
		
		
		
	[3.2.x] Fixed #32290 -- Fixed TemplateNotFound in {% include %} tag for relative path in variable.
Backport of c978dd93fd from master
			
			
This commit is contained in:
		
				
					committed by
					
						 Mariusz Felisiak
						Mariusz Felisiak
					
				
			
			
				
	
			
			
			
						parent
						
							4dbbe37479
						
					
				
				
					commit
					73e7bfc8f5
				
			| @@ -171,7 +171,10 @@ class IncludeNode(Node): | ||||
|             # If not, try the cache and select_template(). | ||||
|             template_name = template or () | ||||
|             if isinstance(template_name, str): | ||||
|                 template_name = (template_name,) | ||||
|                 template_name = (construct_relative_path( | ||||
|                     self.origin.template_name, | ||||
|                     template_name, | ||||
|                 ),) | ||||
|             else: | ||||
|                 template_name = tuple(template_name) | ||||
|             cache = context.render_context.dicts[0].setdefault(self, {}) | ||||
| @@ -226,7 +229,12 @@ def construct_relative_path(current_template_name, relative_name): | ||||
|     Convert a relative path (starting with './' or '../') to the full template | ||||
|     name based on the current_template_name. | ||||
|     """ | ||||
|     if not relative_name.startswith(("'./", "'../", '"./', '"../')): | ||||
|     has_quotes = ( | ||||
|         (relative_name.startswith('"') and relative_name.endswith('"')) or | ||||
|         (relative_name.startswith("'") and relative_name.endswith("'")) | ||||
|     ) | ||||
|     new_name = relative_name.strip('\'"') | ||||
|     if not new_name.startswith(('./', '../')): | ||||
|         # relative_name is a variable or a literal that doesn't contain a | ||||
|         # relative path. | ||||
|         return relative_name | ||||
| @@ -234,7 +242,7 @@ def construct_relative_path(current_template_name, relative_name): | ||||
|     new_name = posixpath.normpath( | ||||
|         posixpath.join( | ||||
|             posixpath.dirname(current_template_name.lstrip('/')), | ||||
|             relative_name.strip('\'"') | ||||
|             new_name, | ||||
|         ) | ||||
|     ) | ||||
|     if new_name.startswith('../'): | ||||
| @@ -248,7 +256,7 @@ def construct_relative_path(current_template_name, relative_name): | ||||
|             "same template in which the tag appears." | ||||
|             % (relative_name, current_template_name) | ||||
|         ) | ||||
|     return '"%s"' % new_name | ||||
|     return f'"{new_name}"' if has_quotes else new_name | ||||
|  | ||||
|  | ||||
| @register.tag('extends') | ||||
|   | ||||
| @@ -0,0 +1 @@ | ||||
| {% include tmpl %} | ||||
| @@ -64,6 +64,12 @@ class IncludeRelativeBehaviorTests(SimpleTestCase): | ||||
|         output = template.render(Context({})) | ||||
|         self.assertEqual(output.strip(), 'dir2 include') | ||||
|  | ||||
|     def test_normal_include_variable(self): | ||||
|         engine = Engine(dirs=[RELATIVE]) | ||||
|         template = engine.get_template('dir1/dir2/inc3.html') | ||||
|         output = template.render(Context({'tmpl': './include_content.html'})) | ||||
|         self.assertEqual(output.strip(), 'dir2 include') | ||||
|  | ||||
|     def test_dir2_include(self): | ||||
|         engine = Engine(dirs=[RELATIVE]) | ||||
|         template = engine.get_template('dir1/dir2/inc1.html') | ||||
|   | ||||
		Reference in New Issue
	
	Block a user