mirror of
				https://github.com/ansible-collections/community.general.git
				synced 2025-10-25 05:23:58 -07:00 
			
		
		
		
	[PR #10539/3de073fb backport][stable-10] json_query: extend list of type aliases for compatibility with ansible-core 2.19 (#10559)
json_query: extend list of type aliases for compatibility with ansible-core 2.19 (#10539)
* Extend list of type aliases for json_query.
* Improve tests.
---------
(cherry picked from commit 3de073fb6f)
Co-authored-by: Felix Fontein <felix@fontein.de>
Co-authored-by: Abhijeet Kasurde <akasurde@redhat.com>
	
	
This commit is contained in:
		
					parent
					
						
							
								24789f86fa
							
						
					
				
			
			
				commit
				
					
						8b259f8bc1
					
				
			
		
					 3 changed files with 33 additions and 5 deletions
				
			
		
							
								
								
									
										2
									
								
								changelogs/fragments/10539-json_query.yml
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										2
									
								
								changelogs/fragments/10539-json_query.yml
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,2 @@ | ||||||
|  | bugfixes: | ||||||
|  |   - "json_query filter plugin - make compatible with lazy evaluation list and dictionary types of ansible-core 2.19 (https://github.com/ansible-collections/community.general/pull/10539)." | ||||||
|  | @ -124,10 +124,17 @@ def json_query(data, expr): | ||||||
|                            'json_query filter') |                            'json_query filter') | ||||||
| 
 | 
 | ||||||
|     # Hack to handle Ansible Unsafe text, AnsibleMapping and AnsibleSequence |     # Hack to handle Ansible Unsafe text, AnsibleMapping and AnsibleSequence | ||||||
|     # See issue: https://github.com/ansible-collections/community.general/issues/320 |     # See issues https://github.com/ansible-collections/community.general/issues/320 | ||||||
|     jmespath.functions.REVERSE_TYPES_MAP['string'] = jmespath.functions.REVERSE_TYPES_MAP['string'] + ('AnsibleUnicode', 'AnsibleUnsafeText', ) |     # and https://github.com/ansible/ansible/issues/85600. | ||||||
|     jmespath.functions.REVERSE_TYPES_MAP['array'] = jmespath.functions.REVERSE_TYPES_MAP['array'] + ('AnsibleSequence', ) |     jmespath.functions.REVERSE_TYPES_MAP['string'] = jmespath.functions.REVERSE_TYPES_MAP['string'] + ( | ||||||
|     jmespath.functions.REVERSE_TYPES_MAP['object'] = jmespath.functions.REVERSE_TYPES_MAP['object'] + ('AnsibleMapping', ) |         'AnsibleUnicode', 'AnsibleUnsafeText', '_AnsibleTaggedStr', | ||||||
|  |     ) | ||||||
|  |     jmespath.functions.REVERSE_TYPES_MAP['array'] = jmespath.functions.REVERSE_TYPES_MAP['array'] + ( | ||||||
|  |         'AnsibleSequence', '_AnsibleLazyTemplateList', | ||||||
|  |     ) | ||||||
|  |     jmespath.functions.REVERSE_TYPES_MAP['object'] = jmespath.functions.REVERSE_TYPES_MAP['object'] + ( | ||||||
|  |         'AnsibleMapping', '_AnsibleLazyTemplateDict', | ||||||
|  |     ) | ||||||
|     try: |     try: | ||||||
|         return jmespath.search(expr, data) |         return jmespath.search(expr, data) | ||||||
|     except jmespath.exceptions.JMESPathError as e: |     except jmespath.exceptions.JMESPathError as e: | ||||||
|  |  | ||||||
|  | @ -11,4 +11,23 @@ | ||||||
| - name: Test json_query filter | - name: Test json_query filter | ||||||
|   assert: |   assert: | ||||||
|     that: |     that: | ||||||
|       - "users | community.general.json_query('[*].hosts[].host') == ['host_a', 'host_b', 'host_c', 'host_d']" |       - >- | ||||||
|  |         users | community.general.json_query('[*].hosts[].host') == ['host_a', 'host_b', 'host_c', 'host_d'] | ||||||
|  |       - >- | ||||||
|  |         ports | json_query("[?contains(ports, `22`)]") == [ports[0]] | ||||||
|  |       - >- | ||||||
|  |         ports | json_query("[?contains(rule_desc, `ssh`)]") == [ports[0]] | ||||||
|  |       - >- | ||||||
|  |         my_complex_data | json_query('users[?id==`1`]') == [my_complex_data['users'][0]] | ||||||
|  |   vars: | ||||||
|  |     my_complex_data: | ||||||
|  |       users: | ||||||
|  |         - id: 1 | ||||||
|  |           name: Alice | ||||||
|  |           roles: ["admin", "dev"] | ||||||
|  |           status: active | ||||||
|  |     ports: | ||||||
|  |       - ports: [22] | ||||||
|  |         rule_desc: "ssh" | ||||||
|  |       - ports: [80] | ||||||
|  |         rule_desc: "http" | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue