win_feature - get tests working on psrp (#55353)

This commit is contained in:
Jordan Borean 2019-04-17 08:18:03 +10:00 committed by GitHub
parent aa8d23b42f
commit 15c331cb48
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
2 changed files with 132 additions and 123 deletions

View file

@ -18,128 +18,10 @@
- name: check whether servermanager module is available (windows 2008 r2 or later)
raw: PowerShell -Command Import-Module ServerManager
win_shell: if (Get-Command -Name Add-WindowsFeature -ErrorAction SilentlyContinue) { $true } else { $false }
changed_when: False
register: win_feature_has_servermanager
ignore_errors: true
- name: start with feature absent
win_feature:
name: "{{ test_win_feature_name }}"
state: absent
when: win_feature_has_servermanager is successful
- name: install feature
win_feature:
name: "{{ test_win_feature_name }}"
state: present
include_sub_features: yes
include_management_tools: yes
register: win_feature_install_result
when: win_feature_has_servermanager is successful
- name: check result of installing feature
assert:
that:
- "win_feature_install_result is changed"
- "win_feature_install_result.success"
- "win_feature_install_result.exitcode == 'Success'"
- "not win_feature_install_result.reboot_required"
- "win_feature_install_result.feature_result|length == 1"
- "win_feature_install_result.feature_result[0].id"
- "win_feature_install_result.feature_result[0].display_name"
- "win_feature_install_result.feature_result[0].message is defined"
- "win_feature_install_result.feature_result[0].reboot_required is defined"
- "win_feature_install_result.feature_result[0].skip_reason"
- "win_feature_install_result.feature_result[0].success is defined"
when: win_feature_has_servermanager is successful
- name: install feature again
win_feature:
name: "{{ test_win_feature_name }}"
state: present
include_sub_features: yes
include_management_tools: yes
register: win_feature_install_again_result
when: win_feature_has_servermanager is successful
- name: check result of installing feature again
assert:
that:
- "win_feature_install_again_result is not changed"
- "win_feature_install_again_result.success"
- "win_feature_install_again_result.exitcode == 'NoChangeNeeded'"
- "not win_feature_install_again_result.reboot_required"
- "win_feature_install_again_result.feature_result == []"
when: win_feature_has_servermanager is successful
- name: remove feature
win_feature:
name: "{{ test_win_feature_name }}"
state: absent
register: win_feature_remove_result
when: win_feature_has_servermanager is successful
- name: check result of removing feature
assert:
that:
- "win_feature_remove_result is changed"
- "win_feature_remove_result.success"
- "win_feature_remove_result.exitcode == 'Success'"
- "not win_feature_remove_result.reboot_required"
- "win_feature_remove_result.feature_result|length == 1"
- "win_feature_remove_result.feature_result[0].id"
- "win_feature_remove_result.feature_result[0].display_name"
- "win_feature_remove_result.feature_result[0].message is defined"
- "win_feature_remove_result.feature_result[0].reboot_required is defined"
- "win_feature_remove_result.feature_result[0].skip_reason"
- "win_feature_remove_result.feature_result[0].success is defined"
when: win_feature_has_servermanager is successful
- name: remove feature again
win_feature:
name: "{{ test_win_feature_name }}"
state: absent
register: win_feature_remove_again_result
when: win_feature_has_servermanager is successful
- name: check result of removing feature again
assert:
that:
- "win_feature_remove_again_result is not changed"
- "win_feature_remove_again_result.success"
- "win_feature_remove_again_result.exitcode == 'NoChangeNeeded'"
- "not win_feature_remove_again_result.reboot_required"
- "win_feature_remove_again_result.feature_result == []"
when: win_feature_has_servermanager is successful
- name: try to install an invalid feature name
win_feature:
name: "Microsoft-Bob"
state: present
register: win_feature_install_invalid_result
ignore_errors: true
when: win_feature_has_servermanager is successful
- name: check result of installing invalid feature name
assert:
that:
- "win_feature_install_invalid_result is failed"
- "win_feature_install_invalid_result is not changed"
- "'The name was not found' in win_feature_install_invalid_result.msg"
when: win_feature_has_servermanager is successful
- name: try to remove an invalid feature name
win_feature:
name: "Microsoft-Bob"
state: absent
register: win_feature_remove_invalid_result
ignore_errors: true
when: win_feature_has_servermanager is successful
- name: check result of removing invalid feature name
assert:
that:
- "win_feature_remove_invalid_result is failed"
- "win_feature_remove_invalid_result is not changed"
- "'The name was not found' in win_feature_remove_invalid_result.msg"
when: win_feature_has_servermanager is successful
- name: run tests
include_tasks: tests.yml
when: win_feature_has_servermanager.stdout | trim | bool

View file

@ -0,0 +1,127 @@
# test code for the win_feature module
# (c) 2014, Chris Church <chris@ninemoreminutes.com>
# This file is part of Ansible
#
# Ansible is free software: you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
#
# Ansible is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with Ansible. If not, see <http://www.gnu.org/licenses/>.
- name: start with feature absent
win_feature:
name: "{{ test_win_feature_name }}"
state: absent
- name: install feature
win_feature:
name: "{{ test_win_feature_name }}"
state: present
include_sub_features: yes
include_management_tools: yes
register: win_feature_install_result
- name: check result of installing feature
assert:
that:
- "win_feature_install_result is changed"
- "win_feature_install_result.success"
- "win_feature_install_result.exitcode == 'Success'"
- "not win_feature_install_result.reboot_required"
- "win_feature_install_result.feature_result|length == 1"
- "win_feature_install_result.feature_result[0].id"
- "win_feature_install_result.feature_result[0].display_name"
- "win_feature_install_result.feature_result[0].message is defined"
- "win_feature_install_result.feature_result[0].reboot_required is defined"
- "win_feature_install_result.feature_result[0].skip_reason"
- "win_feature_install_result.feature_result[0].success is defined"
- name: install feature again
win_feature:
name: "{{ test_win_feature_name }}"
state: present
include_sub_features: yes
include_management_tools: yes
register: win_feature_install_again_result
- name: check result of installing feature again
assert:
that:
- "win_feature_install_again_result is not changed"
- "win_feature_install_again_result.success"
- "win_feature_install_again_result.exitcode == 'NoChangeNeeded'"
- "not win_feature_install_again_result.reboot_required"
- "win_feature_install_again_result.feature_result == []"
- name: remove feature
win_feature:
name: "{{ test_win_feature_name }}"
state: absent
register: win_feature_remove_result
- name: check result of removing feature
assert:
that:
- "win_feature_remove_result is changed"
- "win_feature_remove_result.success"
- "win_feature_remove_result.exitcode == 'Success'"
- "not win_feature_remove_result.reboot_required"
- "win_feature_remove_result.feature_result|length == 1"
- "win_feature_remove_result.feature_result[0].id"
- "win_feature_remove_result.feature_result[0].display_name"
- "win_feature_remove_result.feature_result[0].message is defined"
- "win_feature_remove_result.feature_result[0].reboot_required is defined"
- "win_feature_remove_result.feature_result[0].skip_reason"
- "win_feature_remove_result.feature_result[0].success is defined"
when: win_feature_has_servermanager is successful
- name: remove feature again
win_feature:
name: "{{ test_win_feature_name }}"
state: absent
register: win_feature_remove_again_result
- name: check result of removing feature again
assert:
that:
- "win_feature_remove_again_result is not changed"
- "win_feature_remove_again_result.success"
- "win_feature_remove_again_result.exitcode == 'NoChangeNeeded'"
- "not win_feature_remove_again_result.reboot_required"
- "win_feature_remove_again_result.feature_result == []"
- name: try to install an invalid feature name
win_feature:
name: "Microsoft-Bob"
state: present
register: win_feature_install_invalid_result
ignore_errors: true
- name: check result of installing invalid feature name
assert:
that:
- "win_feature_install_invalid_result is failed"
- "win_feature_install_invalid_result is not changed"
- "'The name was not found' in win_feature_install_invalid_result.msg"
- name: try to remove an invalid feature name
win_feature:
name: "Microsoft-Bob"
state: absent
register: win_feature_remove_invalid_result
ignore_errors: true
- name: check result of removing invalid feature name
assert:
that:
- "win_feature_remove_invalid_result is failed"
- "win_feature_remove_invalid_result is not changed"
- "'The name was not found' in win_feature_remove_invalid_result.msg"