mirror of
				https://github.com/ansible-collections/community.general.git
				synced 2025-10-25 21:44:00 -07:00 
			
		
		
		
	
		
			Some checks are pending
		
		
	
	EOL CI / EOL Sanity (Ⓐ2.17) (push) Waiting to run
				
			EOL CI / EOL Units (Ⓐ2.17+py3.10) (push) Waiting to run
				
			EOL CI / EOL Units (Ⓐ2.17+py3.12) (push) Waiting to run
				
			EOL CI / EOL Units (Ⓐ2.17+py3.7) (push) Waiting to run
				
			EOL CI / EOL I (Ⓐ2.17+alpine319+py:azp/posix/1/) (push) Waiting to run
				
			EOL CI / EOL I (Ⓐ2.17+alpine319+py:azp/posix/2/) (push) Waiting to run
				
			EOL CI / EOL I (Ⓐ2.17+alpine319+py:azp/posix/3/) (push) Waiting to run
				
			EOL CI / EOL I (Ⓐ2.17+fedora39+py:azp/posix/1/) (push) Waiting to run
				
			EOL CI / EOL I (Ⓐ2.17+fedora39+py:azp/posix/2/) (push) Waiting to run
				
			EOL CI / EOL I (Ⓐ2.17+fedora39+py:azp/posix/3/) (push) Waiting to run
				
			EOL CI / EOL I (Ⓐ2.17+ubuntu2004+py:azp/posix/1/) (push) Waiting to run
				
			EOL CI / EOL I (Ⓐ2.17+ubuntu2004+py:azp/posix/2/) (push) Waiting to run
				
			EOL CI / EOL I (Ⓐ2.17+ubuntu2004+py:azp/posix/3/) (push) Waiting to run
				
			nox / Run extra sanity tests (push) Waiting to run
				
			* Adjust all __future__ imports: for i in $(grep -REl "__future__.*absolute_import" plugins/ tests/); do sed -e 's/from __future__ import .*/from __future__ import annotations/g' -i $i; done * Remove all UTF-8 encoding specifications for Python source files: for i in $(grep -REl '[-][*]- coding: utf-8 -[*]-' plugins/ tests/); do sed -e '/^# -\*- coding: utf-8 -\*-/d' -i $i; done * Remove __metaclass__ = type: for i in $(grep -REl '__metaclass__ = type' plugins/ tests/); do sed -e '/^__metaclass__ = type/d' -i $i; done
		
			
				
	
	
		
			115 lines
		
	
	
	
		
			3.2 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			115 lines
		
	
	
	
		
			3.2 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| # Copyright (c) 2020 Justin Bronn <jbronn@gmail.com>
 | |
| # 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
 | |
| 
 | |
| from __future__ import annotations
 | |
| 
 | |
| import json
 | |
| import platform
 | |
| 
 | |
| import pytest
 | |
| from ansible.module_utils.basic import AnsibleModule
 | |
| from ansible_collections.community.general.plugins.modules import (
 | |
|     solaris_zone
 | |
| )
 | |
| from ansible_collections.community.internal_test_tools.tests.unit.plugins.modules.utils import (
 | |
|     set_module_args,
 | |
| )
 | |
| 
 | |
| 
 | |
| ZONEADM = "/usr/sbin/zoneadm"
 | |
| 
 | |
| 
 | |
| def mocker_zone_set(mocker, rc=0, out="", err="", zone_exists=False, zone_status=None):
 | |
|     """
 | |
|     Configure common mocker object for Solaris Zone tests
 | |
|     """
 | |
|     exists = mocker.patch.object(solaris_zone.Zone, "exists")
 | |
|     exists.return_value = zone_exists
 | |
|     get_bin_path = mocker.patch.object(AnsibleModule, "get_bin_path")
 | |
|     get_bin_path.return_value = ZONEADM
 | |
|     run_command = mocker.patch.object(AnsibleModule, "run_command")
 | |
|     run_command.return_value = (rc, out, err)
 | |
|     platform_release = mocker.patch.object(platform, "release")
 | |
|     platform_release.return_value = "5.11"
 | |
|     platform_system = mocker.patch.object(platform, "system")
 | |
|     platform_system.return_value = "SunOS"
 | |
|     if zone_status is not None:
 | |
|         status = mocker.patch.object(solaris_zone.Zone, "status")
 | |
|         status.return_value = zone_status
 | |
| 
 | |
| 
 | |
| @pytest.fixture
 | |
| def mocked_zone_create(mocker):
 | |
|     mocker_zone_set(mocker)
 | |
| 
 | |
| 
 | |
| @pytest.fixture
 | |
| def mocked_zone_delete(mocker):
 | |
|     mocker_zone_set(mocker, zone_exists=True, zone_status="running")
 | |
| 
 | |
| 
 | |
| def test_zone_create(mocked_zone_create, capfd):
 | |
|     """
 | |
|     test zone creation
 | |
|     """
 | |
|     with set_module_args(
 | |
|         {
 | |
|             "name": "z1",
 | |
|             "state": "installed",
 | |
|             "path": "/zones/z1",
 | |
|             "_ansible_check_mode": False,
 | |
|         }
 | |
|     ):
 | |
|         with pytest.raises(SystemExit):
 | |
|             solaris_zone.main()
 | |
| 
 | |
|     out, err = capfd.readouterr()
 | |
|     results = json.loads(out)
 | |
|     assert not results.get("failed")
 | |
|     assert results["changed"]
 | |
| 
 | |
| 
 | |
| def test_zone_delete(mocked_zone_delete, capfd):
 | |
|     """
 | |
|     test zone deletion
 | |
|     """
 | |
|     with set_module_args(
 | |
|         {
 | |
|             "name": "z1",
 | |
|             "state": "absent",
 | |
|             "path": "/zones/z1",
 | |
|             "_ansible_check_mode": False,
 | |
|         }
 | |
|     ):
 | |
|         with pytest.raises(SystemExit):
 | |
|             solaris_zone.main()
 | |
| 
 | |
|     out, err = capfd.readouterr()
 | |
|     results = json.loads(out)
 | |
|     assert not results.get("failed")
 | |
|     assert results["changed"]
 | |
| 
 | |
| 
 | |
| def test_zone_create_invalid_names(mocked_zone_create, capfd):
 | |
|     """
 | |
|     test zone creation with invalid names
 | |
|     """
 | |
|     # 1. Invalid character ('!').
 | |
|     # 2. Zone name > 64 characters.
 | |
|     # 3. Zone name beginning with non-alphanumeric character.
 | |
|     for invalid_name in ('foo!bar', 'z' * 65, '_zone'):
 | |
|         with set_module_args(
 | |
|             {
 | |
|                 "name": invalid_name,
 | |
|                 "state": "installed",
 | |
|                 "path": "/zones/" + invalid_name,
 | |
|                 "_ansible_check_mode": False,
 | |
|             }
 | |
|         ):
 | |
|             with pytest.raises(SystemExit):
 | |
|                 solaris_zone.main()
 | |
| 
 | |
|         out, err = capfd.readouterr()
 | |
|         results = json.loads(out)
 | |
|         assert results.get("failed")
 |