|
| 1 | +//go:build tf_acc_sysdig_monitor || tf_acc_sysdig_secure || tf_acc_onprem_monitor || tf_acc_onprem_secure |
| 2 | + |
| 3 | +package sysdig_test |
| 4 | + |
| 5 | +import ( |
| 6 | + "testing" |
| 7 | + |
| 8 | + "github.com/hashicorp/terraform-plugin-sdk/v2/helper/resource" |
| 9 | + "github.com/hashicorp/terraform-plugin-sdk/v2/helper/schema" |
| 10 | + |
| 11 | + "github.com/draios/terraform-provider-sysdig/sysdig" |
| 12 | +) |
| 13 | + |
| 14 | +func TestAccDataSourceSysdigBuiltinRole(t *testing.T) { |
| 15 | + resource.ParallelTest(t, resource.TestCase{ |
| 16 | + PreCheck: preCheckAnyEnv(t, SysdigMonitorApiTokenEnv, SysdigSecureApiTokenEnv), |
| 17 | + ProviderFactories: map[string]func() (*schema.Provider, error){ |
| 18 | + "sysdig": func() (*schema.Provider, error) { |
| 19 | + return sysdig.Provider(), nil |
| 20 | + }, |
| 21 | + }, |
| 22 | + Steps: []resource.TestStep{ |
| 23 | + { |
| 24 | + Config: `data "sysdig_builtin_role" "advanced" { |
| 25 | + name = "Advanced User" |
| 26 | +}`, |
| 27 | + Check: resource.ComposeTestCheckFunc( |
| 28 | + resource.TestCheckResourceAttr("data.sysdig_builtin_role.advanced", "name", "Advanced User"), |
| 29 | + // Verify both permission sets are non-empty |
| 30 | + resource.TestCheckResourceAttrSet("data.sysdig_builtin_role.advanced", "monitor_permissions.#"), |
| 31 | + resource.TestCheckResourceAttrSet("data.sysdig_builtin_role.advanced", "secure_permissions.#"), |
| 32 | + // Verify well-known monitor permissions are present |
| 33 | + resource.TestCheckTypeSetElemAttr("data.sysdig_builtin_role.advanced", "monitor_permissions.*", "alerts.read"), |
| 34 | + resource.TestCheckTypeSetElemAttr("data.sysdig_builtin_role.advanced", "monitor_permissions.*", "dashboards.read"), |
| 35 | + resource.TestCheckTypeSetElemAttr("data.sysdig_builtin_role.advanced", "monitor_permissions.*", "token.view"), |
| 36 | + // Verify well-known secure permissions are present |
| 37 | + resource.TestCheckTypeSetElemAttr("data.sysdig_builtin_role.advanced", "secure_permissions.*", "scanning.read"), |
| 38 | + resource.TestCheckTypeSetElemAttr("data.sysdig_builtin_role.advanced", "secure_permissions.*", "secure.policy.read"), |
| 39 | + resource.TestCheckTypeSetElemAttr("data.sysdig_builtin_role.advanced", "secure_permissions.*", "policies.read"), |
| 40 | + ), |
| 41 | + }, |
| 42 | + }, |
| 43 | + }) |
| 44 | +} |
0 commit comments