mirror of
				https://github.com/ansible-collections/community.general.git
				synced 2025-10-25 21:44:00 -07:00 
			
		
		
		
	Add executable option to cargo (#7352)
		
	* Add `executable` option to cargo Add `executable` option to cargo to make the module easier to use with cargo installed by rustup. * Add changelog fragment * Add license to integration test * Do not test on CentOS 6 CentOS 6 cannot even validate the certificate in https://sh.rustup.rs. * Fix condition to skip tests on CentOS 6 * Add version_added to path Co-authored-by: Felix Fontein <felix@fontein.de> * Update plugins/modules/cargo.py Co-authored-by: Felix Fontein <felix@fontein.de> * shell → command --------- Co-authored-by: Felix Fontein <felix@fontein.de>
This commit is contained in:
		
					parent
					
						
							
								6c9713b36c
							
						
					
				
			
			
				commit
				
					
						0ca07b0b05
					
				
			
		
					 5 changed files with 51 additions and 6 deletions
				
			
		|  | @ -0,0 +1,2 @@ | |||
| minor_changes: | ||||
|   - "cargo - add option ``executable``, which allows user to specify path to the cargo binary (https://github.com/ansible-collections/community.general/pull/7352)." | ||||
|  | @ -25,6 +25,12 @@ attributes: | |||
|   diff_mode: | ||||
|     support: none | ||||
| options: | ||||
|   executable: | ||||
|     description: | ||||
|       - Path to the C(cargo) installed in the system. | ||||
|       - If not specified, the module will look C(cargo) in E(PATH). | ||||
|     type: path | ||||
|     version_added: 7.5.0 | ||||
|   name: | ||||
|     description: | ||||
|       - The name of a Rust package to install. | ||||
|  | @ -60,7 +66,7 @@ options: | |||
|     default: present | ||||
|     choices: [ "present", "absent", "latest" ] | ||||
| requirements: | ||||
|     - cargo installed in bin path (recommended /usr/local/bin) | ||||
|     - cargo installed | ||||
| """ | ||||
| 
 | ||||
| EXAMPLES = r""" | ||||
|  | @ -103,14 +109,13 @@ from ansible.module_utils.basic import AnsibleModule | |||
| class Cargo(object): | ||||
|     def __init__(self, module, **kwargs): | ||||
|         self.module = module | ||||
|         self.executable = [kwargs["executable"] or module.get_bin_path("cargo", True)] | ||||
|         self.name = kwargs["name"] | ||||
|         self.path = kwargs["path"] | ||||
|         self.state = kwargs["state"] | ||||
|         self.version = kwargs["version"] | ||||
|         self.locked = kwargs["locked"] | ||||
| 
 | ||||
|         self.executable = [module.get_bin_path("cargo", True)] | ||||
| 
 | ||||
|     @property | ||||
|     def path(self): | ||||
|         return self._path | ||||
|  | @ -176,6 +181,7 @@ class Cargo(object): | |||
| 
 | ||||
| def main(): | ||||
|     arg_spec = dict( | ||||
|         executable=dict(default=None, type="path"), | ||||
|         name=dict(required=True, type="list", elements="str"), | ||||
|         path=dict(default=None, type="path"), | ||||
|         state=dict(default="present", choices=["present", "absent", "latest"]), | ||||
|  | @ -185,10 +191,8 @@ def main(): | |||
|     module = AnsibleModule(argument_spec=arg_spec, supports_check_mode=True) | ||||
| 
 | ||||
|     name = module.params["name"] | ||||
|     path = module.params["path"] | ||||
|     state = module.params["state"] | ||||
|     version = module.params["version"] | ||||
|     locked = module.params["locked"] | ||||
| 
 | ||||
|     if not name: | ||||
|         module.fail_json(msg="Package name must be specified") | ||||
|  | @ -198,7 +202,7 @@ def main(): | |||
|         LANG="C", LC_ALL="C", LC_MESSAGES="C", LC_CTYPE="C" | ||||
|     ) | ||||
| 
 | ||||
|     cargo = Cargo(module, name=name, path=path, state=state, version=version, locked=locked) | ||||
|     cargo = Cargo(module, **module.params) | ||||
|     changed, out, err = False, None, None | ||||
|     installed_packages = cargo.get_installed() | ||||
|     if state == "present": | ||||
|  |  | |||
|  | @ -18,3 +18,5 @@ | |||
|   - import_tasks: test_version.yml | ||||
|   environment: "{{ cargo_environment }}" | ||||
|   when: has_cargo | default(false) | ||||
| - import_tasks: test_rustup_cargo.yml | ||||
|   when: rustup_cargo_bin | default(false) | ||||
|  |  | |||
|  | @ -26,3 +26,17 @@ | |||
|       has_cargo: true | ||||
|   when: | ||||
|     - ansible_system == 'FreeBSD' and ansible_distribution_version is version('13.0', '>') | ||||
| 
 | ||||
| - block: | ||||
|   - name: Download rustup | ||||
|     get_url: | ||||
|       url: https://sh.rustup.rs | ||||
|       dest: /tmp/sh.rustup.rs | ||||
|       mode: "0750" | ||||
|       force: true | ||||
|   - name: Install rustup cargo | ||||
|     command: /tmp/sh.rustup.rs -y | ||||
|   - set_fact: | ||||
|       rustup_cargo_bin: "{{ lookup('env', 'HOME') }}/.cargo/bin/cargo" | ||||
|   when: | ||||
|     - ansible_distribution != 'CentOS' or ansible_distribution_version is version('7.0', '>=') | ||||
|  |  | |||
							
								
								
									
										23
									
								
								tests/integration/targets/cargo/tasks/test_rustup_cargo.yml
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										23
									
								
								tests/integration/targets/cargo/tasks/test_rustup_cargo.yml
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,23 @@ | |||
| --- | ||||
| # Copyright (c) Ansible Project | ||||
| # GNU General Public License v3.0+ (see LICENSES/GPL-3.0-or-later.txt or https://www.gnu.org/licenses/gpl-3.0.txt) | ||||
| # SPDX-License-Identifier: GPL-3.0-or-later | ||||
| # | ||||
| - name: Install application helloworld | ||||
|   community.general.cargo: | ||||
|     executable: "{{ rustup_cargo_bin }}" | ||||
|     name: helloworld | ||||
|   register: rustup_install_absent_helloworld | ||||
| 
 | ||||
| - name: Uninstall application helloworld | ||||
|   community.general.cargo: | ||||
|     executable: "{{ rustup_cargo_bin }}" | ||||
|     state: absent | ||||
|     name: helloworld | ||||
|   register: rustup_uninstall_present_helloworld | ||||
| 
 | ||||
| - name: Check assertions helloworld | ||||
|   assert: | ||||
|     that: | ||||
|         - rustup_install_absent_helloworld is changed | ||||
|         - rustup_uninstall_present_helloworld is changed | ||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue