1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141
|
#######################################################
#
# Test package_commands_useshell works
#
#######################################################
body common control
{
inputs => { "../default.cf.sub" };
bundlesequence => { default("$(this.promise_filename)") };
version => "1.0";
}
#######################################################
bundle agent init
{
meta:
# Windows has its own mechanism to list packages, and doesn't use the package body.
"test_skip_needs_work" string => "windows";
vars:
"dummy" string => "dummy";
}
#######################################################
bundle agent test
{
packages:
"bash-1.0-amd64"
package_policy => "add",
package_method => mock_useshell_true,
classes => test_set_class("useshell_true_succ",
"useshell_true_fail");
"bash-1.0-i386"
package_policy => "add",
package_method => mock_useshell_false,
classes => test_set_class("useshell_false_succ",
"useshell_false_fail");
"bash-1.0-spark"
package_policy => "add",
package_method => mock_useshell_unset,
classes => test_set_class("useshell_unset_succ",
"useshell_unset_fail");
}
body package_method mock_useshell_true
{
package_changes => "individual";
package_name_regex => "^([^-]+)";
package_version_regex => "^[^-]+-([^-]+)";
package_arch_regex => "^[^-]+-[^-]+-(.*)";
package_list_command => "if true; then true; else false; fi";
package_list_name_regex => ".*";
package_list_version_regex => ".*";
package_list_arch_regex => ".*";
package_installed_regex => "^[^:]*";
package_add_command => "$(G.true)";
package_update_command => "$(G.true)";
package_delete_command => "$(G.true)";
package_verify_command => "$(G.true)";
package_commands_useshell => "true";
}
body package_method mock_useshell_false
{
package_changes => "individual";
package_name_regex => "^([^-]+)";
package_version_regex => "^[^-]+-([^-]+)";
package_arch_regex => "^[^-]+-[^-]+-(.*)";
package_list_command => "if true; then true; else false; fi";
package_list_name_regex => "^[^:]*";
package_list_version_regex => ":(?<=:).*(?=:)";
package_list_arch_regex => "[^:]\w+$";
package_installed_regex => "^[^:]*";
package_add_command => "$(G.true)";
package_update_command => "$(G.true)";
package_delete_command => "$(G.true)";
package_verify_command => "$(G.true)";
package_commands_useshell => "false";
}
body package_method mock_useshell_unset
{
package_changes => "individual";
package_name_regex => "^([^-]+)";
package_version_regex => "^[^-]+-([^-]+)";
package_arch_regex => "^[^-]+-[^-]+-(.*)";
package_list_command => "echo 'a:b:c\n'";
package_list_name_regex => "^[^:]*";
package_list_version_regex => ":(?<=:).*(?=:)";
package_list_arch_regex => "[^:]\w+$";
package_installed_regex => "^[^:]*";
package_add_command => "$(G.true)";
package_update_command => "$(G.true)";
package_delete_command => "$(G.true)";
package_verify_command => "$(G.true)";
}
body classes test_set_class(ok_class,notok_class)
{
promise_kept => { "$(ok_class)" };
promise_repaired => { "$(ok_class)" };
repair_failed => { "$(notok_class)" };
}
#######################################################
bundle agent check
{
classes:
"ok" and => { "useshell_true_succ", "!useshell_true_fail",
"!useshell_false_succ", "useshell_false_fail",
"useshell_unset_succ", "!useshell_unset_fail",
};
reports:
ok::
"$(this.promise_filename) Pass";
!ok::
"$(this.promise_filename) FAIL";
}
### PROJECT_ID: core
### CATEGORY_ID: 29
|