def test_create_user_shell_bash(self, *args): access = [{'name': 'all', 'role': 'admin'}] set_module_args( dict(username_credential='someuser', password_credential='testpass', partition_access=access, password='******', server='localhost', update_password='******', user='******', shell='bash')) client = AnsibleF5Client( argument_spec=self.spec.argument_spec, supports_check_mode=self.spec.supports_check_mode, f5_product_name=self.spec.f5_product_name) # Override methods to force specific logic in the module to happen mm = ModuleManager(client) mm.is_version_less_than_13 = Mock(return_value=True) upm = UnparitionedManager(client) upm.create_on_device = Mock(return_value=True) upm.exists = Mock(return_value=False) results = upm.exec_module() assert results['changed'] is True assert results['partition_access'] == access
def test_create_user_shell_not_permitted_raises(self, *args): access = [{'name': 'Common', 'role': 'guest'}] set_module_args( dict(username_credential='someuser', password_credential='testpass', partition_access=access, update_password='******', password='******', server='localhost', user='******', shell='bash')) client = AnsibleF5Client( argument_spec=self.spec.argument_spec, supports_check_mode=self.spec.supports_check_mode, f5_product_name=self.spec.f5_product_name) # Override methods to force specific logic in the module to happen mm = ModuleManager(client) mm.is_version_less_than_13 = Mock(return_value=True) upm = UnparitionedManager(client) upm.create_on_device = Mock(return_value=True) upm.exists = Mock(return_value=False) msg = "Shell access is only available to 'admin' or " \ "'resource-admin' roles" with pytest.raises(F5ModuleError) as ex: upm.exec_module() assert str(ex.value) == msg
def test_create_user_partition_access_raises(self, *args): set_module_args( dict(username_credential='someuser', password='******', server='localhost', user='******')) client = AnsibleF5Client( argument_spec=self.spec.argument_spec, supports_check_mode=self.spec.supports_check_mode, f5_product_name=self.spec.f5_product_name) # Override methods to force specific logic in the module to happen mm = ModuleManager(client) mm.is_version_less_than_13 = Mock(return_value=True) upm = UnparitionedManager(client) upm.create_on_device = Mock(return_value=True) upm.exists = Mock(return_value=False) msg = "The 'partition_access' option " \ "is required when creating a resource." with pytest.raises(F5ModuleError) as ex: upm.exec_module() assert str(ex.value) == msg
def test_create_user_raises(self, *args): access = [{'name': 'Common', 'role': 'guest'}] set_module_args( dict(username_credential='someuser', password_credential='testpass', partition_access=access, password='******', server='localhost', user='******')) client = AnsibleF5Client( argument_spec=self.spec.argument_spec, supports_check_mode=self.spec.supports_check_mode, f5_product_name=self.spec.f5_product_name) # Override methods to force specific logic in the module to happen mm = ModuleManager(client) mm.is_version_less_than_13 = lambda: True mm.exit_json = lambda x: False upm = UnparitionedManager(client) upm.create_on_device = lambda: True upm.exists = lambda: False msg = "The 'update_password' option " \ "needs to be set to 'on_create' when creating " \ "a resource with a password." with pytest.raises(F5ModuleError) as ex: upm.exec_module() assert str(ex.value) == msg
def test_create_user_no_password(self, *args): access = [{'name': 'Common', 'role': 'guest'}] set_module_args( dict(username_credential='someuser', partition_access=access, server='localhost', password='******', user='******')) client = AnsibleF5Client( argument_spec=self.spec.argument_spec, supports_check_mode=self.spec.supports_check_mode, f5_product_name=self.spec.f5_product_name) # Override methods to force specific logic in the module to happen mm = ModuleManager(client) mm.is_version_less_than_13 = lambda: True mm.exit_json = lambda x: False upm = UnparitionedManager(client) upm.create_on_device = lambda: True upm.exists = lambda: False results = upm.exec_module() assert results['changed'] is True assert results['partition_access'] == access
def test_create_user_raises(self, *args): access = [{'name': 'Common', 'role': 'guest'}] set_module_args( dict(username_credential='someuser', password_credential='testpass', partition_access=access, password='******', server='localhost', user='******')) module = AnsibleModule( argument_spec=self.spec.argument_spec, supports_check_mode=self.spec.supports_check_mode) # Override methods to force specific logic in the module to happen upm = UnparitionedManager(module=module, params=module.params) upm.create_on_device = Mock(return_value=True) upm.exists = Mock(return_value=False) mm = ModuleManager(module=module) mm.is_version_less_than_13 = Mock(return_value=True) mm.get_manager = Mock(return_value=upm) msg = "The 'update_password' option " \ "needs to be set to 'on_create' when creating " \ "a resource with a password." with pytest.raises(F5ModuleError) as ex: mm.exec_module() assert str(ex.value) == msg
def test_create_user_no_password(self, *args): access = [{'name': 'Common', 'role': 'guest'}] set_module_args( dict(username_credential='someuser', partition_access=access, server='localhost', password='******', user='******')) module = AnsibleModule( argument_spec=self.spec.argument_spec, supports_check_mode=self.spec.supports_check_mode) # Override methods to force specific logic in the module to happen upm = UnparitionedManager(module=module, params=module.params) upm.create_on_device = Mock(return_value=True) upm.exists = Mock(return_value=False) mm = ModuleManager(module=module) mm.is_version_less_than_13 = Mock(return_value=True) mm.get_manager = Mock(return_value=upm) results = mm.exec_module() assert results['changed'] is True assert results['partition_access'] == access