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 142 143 144 145
|
package unit
import (
"context"
"testing"
"github.com/linode/linodego"
"github.com/stretchr/testify/assert"
)
func TestAccountUserGrants_Get(t *testing.T) {
fixtureData, err := fixtures.GetFixture("account_user_grants_get")
assert.NoError(t, err)
var base ClientBaseCase
base.SetUp(t)
defer base.TearDown(t)
base.MockGet("account/users/example-user/grants", fixtureData)
grants, err := base.Client.GetUserGrants(context.Background(), "example-user")
if err != nil {
t.Fatalf("Error getting grants: %v", err)
}
assert.Equal(t, 123, grants.Database[0].ID)
assert.Equal(t, "example-entity", grants.Database[0].Label)
assert.Equal(t, linodego.GrantPermissionLevel("read_only"), grants.Database[0].Permissions)
assert.Equal(t, 123, grants.Domain[0].ID)
assert.Equal(t, "example-entity", grants.Domain[0].Label)
assert.Equal(t, linodego.GrantPermissionLevel("read_only"), grants.Domain[0].Permissions)
assert.Equal(t, 123, grants.Firewall[0].ID)
assert.Equal(t, "example-entity", grants.Firewall[0].Label)
assert.Equal(t, linodego.GrantPermissionLevel("read_only"), grants.Firewall[0].Permissions)
assert.Equal(t, 123, grants.Image[0].ID)
assert.Equal(t, "example-entity", grants.Image[0].Label)
assert.Equal(t, linodego.GrantPermissionLevel("read_only"), grants.Image[0].Permissions)
assert.Equal(t, 123, grants.Linode[0].ID)
assert.Equal(t, "example-entity", grants.Linode[0].Label)
assert.Equal(t, linodego.GrantPermissionLevel("read_only"), grants.Linode[0].Permissions)
assert.Equal(t, 123, grants.Longview[0].ID)
assert.Equal(t, "example-entity", grants.Longview[0].Label)
assert.Equal(t, linodego.GrantPermissionLevel("read_only"), grants.Longview[0].Permissions)
assert.Equal(t, 123, grants.NodeBalancer[0].ID)
assert.Equal(t, "example-entity", grants.NodeBalancer[0].Label)
assert.Equal(t, linodego.GrantPermissionLevel("read_only"), grants.NodeBalancer[0].Permissions)
assert.Equal(t, 123, grants.PlacementGroup[0].ID)
assert.Equal(t, "example-entity", grants.PlacementGroup[0].Label)
assert.Equal(t, linodego.GrantPermissionLevel("read_only"), grants.PlacementGroup[0].Permissions)
assert.Equal(t, 123, grants.StackScript[0].ID)
assert.Equal(t, "example-entity", grants.StackScript[0].Label)
assert.Equal(t, linodego.GrantPermissionLevel("read_only"), grants.StackScript[0].Permissions)
assert.Equal(t, 123, grants.Volume[0].ID)
assert.Equal(t, "example-entity", grants.Volume[0].Label)
assert.Equal(t, linodego.GrantPermissionLevel("read_only"), grants.Volume[0].Permissions)
assert.Equal(t, 123, grants.VPC[0].ID)
assert.Equal(t, "example-entity", grants.VPC[0].Label)
assert.Equal(t, linodego.GrantPermissionLevel("read_only"), grants.VPC[0].Permissions)
assert.Equal(t, linodego.GrantPermissionLevel("read_only"), *grants.Global.AccountAccess)
assert.Equal(t, true, grants.Global.AddDatabases)
assert.Equal(t, true, grants.Global.AddDomains)
assert.Equal(t, true, grants.Global.AddFirewalls)
assert.Equal(t, true, grants.Global.AddImages)
assert.Equal(t, true, grants.Global.AddLinodes)
assert.Equal(t, true, grants.Global.AddLongview)
assert.Equal(t, true, grants.Global.AddNodeBalancers)
assert.Equal(t, true, grants.Global.AddPlacementGroups)
assert.Equal(t, true, grants.Global.AddStackScripts)
assert.Equal(t, true, grants.Global.AddVolumes)
assert.Equal(t, true, grants.Global.AddVPCs)
assert.Equal(t, false, grants.Global.CancelAccount)
assert.Equal(t, true, grants.Global.ChildAccountAccess)
assert.Equal(t, true, grants.Global.LongviewSubscription)
}
func TestAccountGrants_Update(t *testing.T) {
fixtureData, err := fixtures.GetFixture("account_user_grants_update")
assert.NoError(t, err)
var base ClientBaseCase
base.SetUp(t)
defer base.TearDown(t)
globalGrants := linodego.GlobalUserGrants{
AccountAccess: nil,
}
requestData := linodego.UserGrantsUpdateOptions{
Global: globalGrants,
}
base.MockPut("account/users/example-user/grants", fixtureData)
grants, err := base.Client.UpdateUserGrants(context.Background(), "example-user", requestData)
assert.NoError(t, err)
assert.Equal(t, 123, grants.Database[0].ID)
assert.Equal(t, "example-entity", grants.Database[0].Label)
assert.Equal(t, linodego.GrantPermissionLevel("read_only"), grants.Database[0].Permissions)
assert.Equal(t, 123, grants.Domain[0].ID)
assert.Equal(t, "example-entity", grants.Domain[0].Label)
assert.Equal(t, linodego.GrantPermissionLevel("read_only"), grants.Domain[0].Permissions)
assert.Equal(t, 123, grants.Firewall[0].ID)
assert.Equal(t, "example-entity", grants.Firewall[0].Label)
assert.Equal(t, linodego.GrantPermissionLevel("read_only"), grants.Firewall[0].Permissions)
assert.Equal(t, 123, grants.Image[0].ID)
assert.Equal(t, "example-entity", grants.Image[0].Label)
assert.Equal(t, linodego.GrantPermissionLevel("read_only"), grants.Image[0].Permissions)
assert.Equal(t, 123, grants.Linode[0].ID)
assert.Equal(t, "example-entity", grants.Linode[0].Label)
assert.Equal(t, linodego.GrantPermissionLevel("read_only"), grants.Linode[0].Permissions)
assert.Equal(t, 123, grants.Longview[0].ID)
assert.Equal(t, "example-entity", grants.Longview[0].Label)
assert.Equal(t, linodego.GrantPermissionLevel("read_only"), grants.Longview[0].Permissions)
assert.Equal(t, 123, grants.NodeBalancer[0].ID)
assert.Equal(t, "example-entity", grants.NodeBalancer[0].Label)
assert.Equal(t, linodego.GrantPermissionLevel("read_only"), grants.NodeBalancer[0].Permissions)
assert.Equal(t, 123, grants.PlacementGroup[0].ID)
assert.Equal(t, "example-entity", grants.PlacementGroup[0].Label)
assert.Equal(t, linodego.GrantPermissionLevel("read_only"), grants.PlacementGroup[0].Permissions)
assert.Equal(t, 123, grants.StackScript[0].ID)
assert.Equal(t, "example-entity", grants.StackScript[0].Label)
assert.Equal(t, linodego.GrantPermissionLevel("read_only"), grants.StackScript[0].Permissions)
assert.Equal(t, 123, grants.Volume[0].ID)
assert.Equal(t, "example-entity", grants.Volume[0].Label)
assert.Equal(t, linodego.GrantPermissionLevel("read_only"), grants.Volume[0].Permissions)
assert.Equal(t, 123, grants.VPC[0].ID)
assert.Equal(t, "example-entity", grants.VPC[0].Label)
assert.Equal(t, linodego.GrantPermissionLevel("read_only"), grants.VPC[0].Permissions)
assert.Equal(t, linodego.GrantPermissionLevel("read_write"), *grants.Global.AccountAccess)
assert.Equal(t, true, grants.Global.AddDatabases)
assert.Equal(t, true, grants.Global.AddDomains)
assert.Equal(t, true, grants.Global.AddFirewalls)
assert.Equal(t, true, grants.Global.AddImages)
assert.Equal(t, true, grants.Global.AddLinodes)
assert.Equal(t, true, grants.Global.AddLongview)
assert.Equal(t, true, grants.Global.AddNodeBalancers)
assert.Equal(t, true, grants.Global.AddPlacementGroups)
assert.Equal(t, true, grants.Global.AddStackScripts)
assert.Equal(t, true, grants.Global.AddVolumes)
assert.Equal(t, true, grants.Global.AddVPCs)
assert.Equal(t, false, grants.Global.CancelAccount)
assert.Equal(t, true, grants.Global.ChildAccountAccess)
assert.Equal(t, true, grants.Global.LongviewSubscription)
}
|