summaryrefslogtreecommitdiffstats
path: root/test/integration/targets/win_module_utils
diff options
context:
space:
mode:
Diffstat (limited to 'test/integration/targets/win_module_utils')
-rw-r--r--test/integration/targets/win_module_utils/aliases2
-rw-r--r--test/integration/targets/win_module_utils/library/csharp_util.ps112
-rw-r--r--test/integration/targets/win_module_utils/library/legacy_only_new_way.ps15
-rw-r--r--test/integration/targets/win_module_utils/library/legacy_only_new_way_win_line_ending.ps16
-rw-r--r--test/integration/targets/win_module_utils/library/legacy_only_old_way.ps15
-rw-r--r--test/integration/targets/win_module_utils/library/legacy_only_old_way_win_line_ending.ps14
-rw-r--r--test/integration/targets/win_module_utils/library/recursive_requires.ps113
-rw-r--r--test/integration/targets/win_module_utils/library/uses_bogus_utils.ps16
-rw-r--r--test/integration/targets/win_module_utils/library/uses_local_utils.ps19
-rw-r--r--test/integration/targets/win_module_utils/module_utils/Ansible.ModuleUtils.Recursive1.psm19
-rw-r--r--test/integration/targets/win_module_utils/module_utils/Ansible.ModuleUtils.Recursive2.psm112
-rw-r--r--test/integration/targets/win_module_utils/module_utils/Ansible.ModuleUtils.Recursive3.psm120
-rw-r--r--test/integration/targets/win_module_utils/module_utils/Ansible.ModuleUtils.ValidTestModule.psm13
-rw-r--r--test/integration/targets/win_module_utils/module_utils/Ansible.Test.cs26
-rw-r--r--test/integration/targets/win_module_utils/tasks/main.yml71
15 files changed, 203 insertions, 0 deletions
diff --git a/test/integration/targets/win_module_utils/aliases b/test/integration/targets/win_module_utils/aliases
new file mode 100644
index 0000000..1eed2ec
--- /dev/null
+++ b/test/integration/targets/win_module_utils/aliases
@@ -0,0 +1,2 @@
+shippable/windows/group1
+shippable/windows/smoketest
diff --git a/test/integration/targets/win_module_utils/library/csharp_util.ps1 b/test/integration/targets/win_module_utils/library/csharp_util.ps1
new file mode 100644
index 0000000..cf2dc45
--- /dev/null
+++ b/test/integration/targets/win_module_utils/library/csharp_util.ps1
@@ -0,0 +1,12 @@
+#1powershell
+
+#Requires -Module Ansible.ModuleUtils.Legacy
+#AnsibleRequires -CSharpUtil Ansible.Test
+
+$result = @{
+ res = [Ansible.Test.OutputTest]::GetString()
+ changed = $false
+}
+
+Exit-Json -obj $result
+
diff --git a/test/integration/targets/win_module_utils/library/legacy_only_new_way.ps1 b/test/integration/targets/win_module_utils/library/legacy_only_new_way.ps1
new file mode 100644
index 0000000..045ca75
--- /dev/null
+++ b/test/integration/targets/win_module_utils/library/legacy_only_new_way.ps1
@@ -0,0 +1,5 @@
+#!powershell
+
+#Requires -Module Ansible.ModuleUtils.Legacy
+
+Exit-Json @{ data = "success" }
diff --git a/test/integration/targets/win_module_utils/library/legacy_only_new_way_win_line_ending.ps1 b/test/integration/targets/win_module_utils/library/legacy_only_new_way_win_line_ending.ps1
new file mode 100644
index 0000000..837a516
--- /dev/null
+++ b/test/integration/targets/win_module_utils/library/legacy_only_new_way_win_line_ending.ps1
@@ -0,0 +1,6 @@
+#!powershell
+
+#Requires -Module Ansible.ModuleUtils.Legacy
+
+Exit-Json @{ data = "success" }
+
diff --git a/test/integration/targets/win_module_utils/library/legacy_only_old_way.ps1 b/test/integration/targets/win_module_utils/library/legacy_only_old_way.ps1
new file mode 100644
index 0000000..3c6b083
--- /dev/null
+++ b/test/integration/targets/win_module_utils/library/legacy_only_old_way.ps1
@@ -0,0 +1,5 @@
+#!powershell
+
+# POWERSHELL_COMMON
+
+Exit-Json @{ data = "success" }
diff --git a/test/integration/targets/win_module_utils/library/legacy_only_old_way_win_line_ending.ps1 b/test/integration/targets/win_module_utils/library/legacy_only_old_way_win_line_ending.ps1
new file mode 100644
index 0000000..afe7548
--- /dev/null
+++ b/test/integration/targets/win_module_utils/library/legacy_only_old_way_win_line_ending.ps1
@@ -0,0 +1,4 @@
+#!powershell
+# POWERSHELL_COMMON
+
+Exit-Json @{ data = "success" }
diff --git a/test/integration/targets/win_module_utils/library/recursive_requires.ps1 b/test/integration/targets/win_module_utils/library/recursive_requires.ps1
new file mode 100644
index 0000000..db8c23e
--- /dev/null
+++ b/test/integration/targets/win_module_utils/library/recursive_requires.ps1
@@ -0,0 +1,13 @@
+#!powershell
+
+#Requires -Module Ansible.ModuleUtils.Legacy
+#Requires -Module Ansible.ModuleUtils.Recursive3
+#Requires -Version 2
+
+$ErrorActionPreference = "Stop"
+
+$result = @{
+ changed = $false
+ value = Get-Test3
+}
+Exit-Json -obj $result
diff --git a/test/integration/targets/win_module_utils/library/uses_bogus_utils.ps1 b/test/integration/targets/win_module_utils/library/uses_bogus_utils.ps1
new file mode 100644
index 0000000..3886aec
--- /dev/null
+++ b/test/integration/targets/win_module_utils/library/uses_bogus_utils.ps1
@@ -0,0 +1,6 @@
+#!powershell
+
+# this should fail
+#Requires -Module Ansible.ModuleUtils.BogusModule
+
+Exit-Json @{ data = "success" }
diff --git a/test/integration/targets/win_module_utils/library/uses_local_utils.ps1 b/test/integration/targets/win_module_utils/library/uses_local_utils.ps1
new file mode 100644
index 0000000..48c2757
--- /dev/null
+++ b/test/integration/targets/win_module_utils/library/uses_local_utils.ps1
@@ -0,0 +1,9 @@
+#!powershell
+
+# use different cases, spacing and plural of 'module' to exercise flexible powershell dialect
+#ReQuiReS -ModUleS Ansible.ModuleUtils.Legacy
+#Requires -Module Ansible.ModuleUtils.ValidTestModule
+
+$o = CustomFunction
+
+Exit-Json @{data = $o }
diff --git a/test/integration/targets/win_module_utils/module_utils/Ansible.ModuleUtils.Recursive1.psm1 b/test/integration/targets/win_module_utils/module_utils/Ansible.ModuleUtils.Recursive1.psm1
new file mode 100644
index 0000000..a63ece3
--- /dev/null
+++ b/test/integration/targets/win_module_utils/module_utils/Ansible.ModuleUtils.Recursive1.psm1
@@ -0,0 +1,9 @@
+Function Get-Test1 {
+ <#
+ .SYNOPSIS
+ Test function
+ #>
+ return "Get-Test1"
+}
+
+Export-ModuleMember -Function Get-Test1
diff --git a/test/integration/targets/win_module_utils/module_utils/Ansible.ModuleUtils.Recursive2.psm1 b/test/integration/targets/win_module_utils/module_utils/Ansible.ModuleUtils.Recursive2.psm1
new file mode 100644
index 0000000..f9c07ca
--- /dev/null
+++ b/test/integration/targets/win_module_utils/module_utils/Ansible.ModuleUtils.Recursive2.psm1
@@ -0,0 +1,12 @@
+#Requires -Module Ansible.ModuleUtils.Recursive1
+#Requires -Module Ansible.ModuleUtils.Recursive3
+
+Function Get-Test2 {
+ <#
+ .SYNOPSIS
+ Test function
+ #>
+ return "Get-Test2, 1: $(Get-Test1), 3: $(Get-NewTest3)"
+}
+
+Export-ModuleMember -Function Get-Test2
diff --git a/test/integration/targets/win_module_utils/module_utils/Ansible.ModuleUtils.Recursive3.psm1 b/test/integration/targets/win_module_utils/module_utils/Ansible.ModuleUtils.Recursive3.psm1
new file mode 100644
index 0000000..ce6e70c
--- /dev/null
+++ b/test/integration/targets/win_module_utils/module_utils/Ansible.ModuleUtils.Recursive3.psm1
@@ -0,0 +1,20 @@
+#Requires -Module Ansible.ModuleUtils.Recursive2
+#Requires -Version 3.0
+
+Function Get-Test3 {
+ <#
+ .SYNOPSIS
+ Test function
+ #>
+ return "Get-Test3: 2: $(Get-Test2)"
+}
+
+Function Get-NewTest3 {
+ <#
+ .SYNOPSIS
+ Test function
+ #>
+ return "Get-NewTest3"
+}
+
+Export-ModuleMember -Function Get-Test3, Get-NewTest3
diff --git a/test/integration/targets/win_module_utils/module_utils/Ansible.ModuleUtils.ValidTestModule.psm1 b/test/integration/targets/win_module_utils/module_utils/Ansible.ModuleUtils.ValidTestModule.psm1
new file mode 100644
index 0000000..a60b799
--- /dev/null
+++ b/test/integration/targets/win_module_utils/module_utils/Ansible.ModuleUtils.ValidTestModule.psm1
@@ -0,0 +1,3 @@
+Function CustomFunction {
+ return "ValueFromCustomFunction"
+}
diff --git a/test/integration/targets/win_module_utils/module_utils/Ansible.Test.cs b/test/integration/targets/win_module_utils/module_utils/Ansible.Test.cs
new file mode 100644
index 0000000..9556d9a
--- /dev/null
+++ b/test/integration/targets/win_module_utils/module_utils/Ansible.Test.cs
@@ -0,0 +1,26 @@
+//AssemblyReference -Name System.Web.Extensions.dll
+
+using System;
+using System.Collections.Generic;
+using System.Web.Script.Serialization;
+
+namespace Ansible.Test
+{
+ public class OutputTest
+ {
+ public static string GetString()
+ {
+ Dictionary<string, object> obj = new Dictionary<string, object>();
+ obj["a"] = "a";
+ obj["b"] = 1;
+ return ToJson(obj);
+ }
+
+ private static string ToJson(object obj)
+ {
+ JavaScriptSerializer jss = new JavaScriptSerializer();
+ return jss.Serialize(obj);
+ }
+ }
+}
+
diff --git a/test/integration/targets/win_module_utils/tasks/main.yml b/test/integration/targets/win_module_utils/tasks/main.yml
new file mode 100644
index 0000000..87f2592
--- /dev/null
+++ b/test/integration/targets/win_module_utils/tasks/main.yml
@@ -0,0 +1,71 @@
+- name: call old WANTS_JSON module
+ legacy_only_old_way:
+ register: old_way
+
+- assert:
+ that:
+ - old_way.data == 'success'
+
+- name: call module with only legacy requires
+ legacy_only_new_way:
+ register: new_way
+
+- assert:
+ that:
+ - new_way.data == 'success'
+
+- name: call old WANTS_JSON module with windows line endings
+ legacy_only_old_way_win_line_ending:
+ register: old_way_win
+
+- assert:
+ that:
+ - old_way_win.data == 'success'
+
+- name: call module with only legacy requires and windows line endings
+ legacy_only_new_way_win_line_ending:
+ register: new_way_win
+
+- assert:
+ that:
+ - new_way_win.data == 'success'
+
+- name: call module with local module_utils
+ uses_local_utils:
+ register: local_utils
+
+- assert:
+ that:
+ - local_utils.data == "ValueFromCustomFunction"
+
+- name: call module that imports bogus Ansible-named module_utils
+ uses_bogus_utils:
+ ignore_errors: true
+ register: bogus_utils
+
+- assert:
+ that:
+ - bogus_utils is failed
+ - bogus_utils.msg is search("Could not find")
+
+- name: call module that imports module_utils with further imports
+ recursive_requires:
+ register: recursive_requires
+ vars:
+ # Our coverage runner does not work with recursive required. This is a limitation on PowerShell so we need to
+ # disable coverage for this task
+ _ansible_coverage_remote_output: ''
+
+- assert:
+ that:
+ - 'recursive_requires.value == "Get-Test3: 2: Get-Test2, 1: Get-Test1, 3: Get-NewTest3"'
+
+- name: call module with C# reference
+ csharp_util:
+ register: csharp_res
+
+- name: assert call module with C# reference
+ assert:
+ that:
+ - not csharp_res is failed
+ - csharp_res.res == '{"a":"a","b":1}'