mirror of
https://github.com/ansible-collections/community.general.git
synced 2024-09-14 20:13:21 +02:00
win_domain_membership: added better error handling and basic tests (#30674)
This commit is contained in:
parent
59187358ee
commit
fb628acb6e
4 changed files with 99 additions and 3 deletions
|
@ -125,7 +125,11 @@ Function Join-Domain {
|
|||
}
|
||||
$argstr = $add_args | Out-String
|
||||
Write-DebugLog "calling Add-Computer with args: $argstr"
|
||||
try {
|
||||
$add_result = Add-Computer @add_args
|
||||
} catch {
|
||||
Fail-Json -obj $result -message "failed to join domain: $($_.Exception.Message)"
|
||||
}
|
||||
|
||||
Write-DebugLog ("Add-Computer result was \n{0}" -f $add_result | Out-String)
|
||||
}
|
||||
|
@ -140,8 +144,16 @@ Function Set-Workgroup {
|
|||
)
|
||||
|
||||
Write-DebugLog ("Calling JoinDomainOrWorkgroup with workgroup {0}" -f $workgroup_name)
|
||||
try {
|
||||
$swg_result = (Get-WmiObject -ClassName Win32_ComputerSystem).JoinDomainOrWorkgroup($workgroup_name)
|
||||
} catch {
|
||||
Fail-Json -obj $result -message "failed to call Win32_ComputerSystem.JoinDomainOrWorkgroup($workgroup_name): $($_.Exception.Message)"
|
||||
}
|
||||
|
||||
return (Get-WmiObject Win32_ComputerSystem).JoinDomainOrWorkgroup($workgroup_name)
|
||||
if ($swg_result.ReturnValue -ne 0) {
|
||||
Fail-Json -obj $result -message "failed to set workgroup through WMI, return value: $($swg_result.ReturnValue)"
|
||||
|
||||
return $swg_result}
|
||||
}
|
||||
|
||||
Function Join-Workgroup {
|
||||
|
@ -155,7 +167,11 @@ Function Join-Workgroup {
|
|||
$domain_cred = Create-Credential $domain_admin_user $domain_admin_password
|
||||
|
||||
# 2012+ call the Workgroup arg WorkgroupName, but seem to accept
|
||||
try {
|
||||
$rc_result = Remove-Computer -Workgroup $workgroup_name -Credential $domain_cred -Force
|
||||
} catch {
|
||||
Fail-Json -obj $result -message "failed to remove computer from domain: $($_.Exception.Message)"
|
||||
}
|
||||
}
|
||||
|
||||
# we're already on a workgroup- change it.
|
||||
|
|
1
test/integration/targets/win_domain_membership/aliases
Normal file
1
test/integration/targets/win_domain_membership/aliases
Normal file
|
@ -0,0 +1 @@
|
|||
windows/ci/group2
|
|
@ -0,0 +1,20 @@
|
|||
---
|
||||
- name: get current workgroup
|
||||
win_shell: (Get-WmiObject Win32_ComputerSystem).Workgroup
|
||||
register: workgroup
|
||||
|
||||
- name: fail if workgroup result is empty (means test host is in a domain)
|
||||
fail:
|
||||
msg: Cannot run tests for win_domain_membership when host is a member of a domain
|
||||
when: workgroup.stdout == ""
|
||||
|
||||
- block:
|
||||
- include_tasks: tests.yml
|
||||
|
||||
always:
|
||||
- name: revert workgroup back to original before tests
|
||||
win_domain_membership:
|
||||
workgroup_name: '{{workgroup.stdout_lines[0]}}'
|
||||
state: workgroup
|
||||
domain_admin_user: fake user
|
||||
domain_admin_password: fake password
|
|
@ -0,0 +1,59 @@
|
|||
---
|
||||
- name: change workgroup (check mode)
|
||||
win_domain_membership:
|
||||
workgroup_name: ANSIBLETEST
|
||||
state: workgroup
|
||||
domain_admin_user: fake user
|
||||
domain_admin_password: fake password
|
||||
register: change_workgroup_check
|
||||
check_mode: yes
|
||||
|
||||
- name: get result of change workgroup (check mode)
|
||||
win_shell: (Get-WmiObject Win32_ComputerSystem).Workgroup
|
||||
register: change_workgroup_result_check
|
||||
|
||||
- name: assert result of change workgroup (check mode)
|
||||
assert:
|
||||
that:
|
||||
- change_workgroup_check|changed
|
||||
- change_workgroup_result_check.stdout == workgroup.stdout
|
||||
|
||||
- name: change workgroup
|
||||
win_domain_membership:
|
||||
workgroup_name: ANSIBLETEST
|
||||
state: workgroup
|
||||
domain_admin_user: fake user
|
||||
domain_admin_password: fake password
|
||||
register: change_workgroup
|
||||
|
||||
- name: get result of change workgroup
|
||||
win_shell: (Get-WmiObject Win32_ComputerSystem).Workgroup
|
||||
register: change_workgroup_result
|
||||
|
||||
- name: assert result of change workgroup
|
||||
assert:
|
||||
that:
|
||||
- change_workgroup|changed
|
||||
- change_workgroup_result.stdout_lines[0] == "ANSIBLETEST"
|
||||
|
||||
- name: change workgroup (idempotent)
|
||||
win_domain_membership:
|
||||
workgroup_name: ANSIBLETEST
|
||||
state: workgroup
|
||||
domain_admin_user: fake user
|
||||
domain_admin_password: fake password
|
||||
register: change_workgroup_again
|
||||
|
||||
- name: assert result of change workgroup (idempotent)
|
||||
assert:
|
||||
that:
|
||||
- not change_workgroup_again|changed
|
||||
|
||||
- name: change workgroup fail invalid name
|
||||
win_domain_membership:
|
||||
workgroup_name: ANSIBLELONGNAMEFAILURE
|
||||
state: workgroup
|
||||
domain_admin_user: fake user
|
||||
domain_admin_password: fake password
|
||||
register: fail_change_workgroup
|
||||
failed_when: "fail_change_workgroup.msg != 'failed to set workgroup through WMI, return value: 2695'"
|
Loading…
Reference in a new issue