forked from rework-space-com/terraform-provider-freeipa
-
Notifications
You must be signed in to change notification settings - Fork 0
/
resource_sudo_rule_test.go
88 lines (80 loc) · 2.48 KB
/
resource_sudo_rule_test.go
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
package main
import (
"fmt"
"os"
"testing"
"github.com/hashicorp/terraform-plugin-sdk/v2/helper/resource"
)
func TestAccFreeIPASudoRule(t *testing.T) {
testSudoRule := map[string]string{
"name": "sudo-rule-test",
"description": "Test sudo rule",
"enabled": "true",
"usercategory": "all",
"hostcategory": "all",
"commandcategory": "all",
"runasusercategory": "all",
"runasgroupcategory": "all",
"order": "2",
}
resource.Test(t, resource.TestCase{
PreCheck: func() { testAccPreCheck(t) },
Providers: testAccProviders,
Steps: []resource.TestStep{
{
Config: testAccFreeIPASudoRuleResource_basic(testSudoRule),
Check: resource.ComposeTestCheckFunc(
resource.TestCheckResourceAttr("freeipa_sudo_rule.test_rule", "name", testSudoRule["name"]),
),
},
{
Config: testAccFreeIPASudoRuleResource_full(testSudoRule),
Check: resource.ComposeTestCheckFunc(
resource.TestCheckResourceAttr("freeipa_sudo_rule.test_rule", "name", testSudoRule["name"]),
resource.TestCheckResourceAttr("freeipa_sudo_rule.test_rule", "description", testSudoRule["description"]),
),
},
},
})
}
func testAccFreeIPASudoRuleResource_basic(dataset map[string]string) string {
provider_host := os.Getenv("FREEIPA_HOST")
provider_user := os.Getenv("FREEIPA_USERNAME")
provider_pass := os.Getenv("FREEIPA_PASSWORD")
return fmt.Sprintf(`
provider "freeipa" {
host = "%s"
username = "%s"
password = "%s"
insecure = true
}
resource "freeipa_sudo_rule" "test_rule" {
name = "%s"
}
`, provider_host, provider_user, provider_pass, dataset["name"])
}
func testAccFreeIPASudoRuleResource_full(dataset map[string]string) string {
provider_host := os.Getenv("FREEIPA_HOST")
provider_user := os.Getenv("FREEIPA_USERNAME")
provider_pass := os.Getenv("FREEIPA_PASSWORD")
return fmt.Sprintf(`
provider "freeipa" {
host = "%s"
username = "%s"
password = "%s"
insecure = true
}
resource "freeipa_sudo_rule" "test_rule" {
name = "%s"
description = "%s"
enabled = %s
usercategory = "%s"
hostcategory = "%s"
commandcategory = "%s"
runasusercategory = "%s"
runasgroupcategory = "%s"
order = %s
}
`, provider_host, provider_user, provider_pass, dataset["name"], dataset["description"], dataset["enabled"], dataset["usercategory"], dataset["hostcategory"],
dataset["commandcategory"], dataset["runasusercategory"], dataset["runasgroupcategory"], dataset["order"])
}