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 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278
|
package iam_test
import (
"github.com/AdRoll/goamz/aws"
"github.com/AdRoll/goamz/iam"
"github.com/AdRoll/goamz/testutil"
"gopkg.in/check.v1"
"strings"
"testing"
)
func Test(t *testing.T) {
check.TestingT(t)
}
type S struct {
iam *iam.IAM
}
var _ = check.Suite(&S{})
var testServer = testutil.NewHTTPServer()
func (s *S) SetUpSuite(c *check.C) {
testServer.Start()
auth := aws.Auth{AccessKey: "abc", SecretKey: "123"}
s.iam = iam.New(auth, aws.Region{IAMEndpoint: testServer.URL})
}
func (s *S) TearDownTest(c *check.C) {
testServer.Flush()
}
func (s *S) TestCreateUser(c *check.C) {
testServer.Response(200, nil, CreateUserExample)
resp, err := s.iam.CreateUser("Bob", "/division_abc/subdivision_xyz/")
values := testServer.WaitRequest().URL.Query()
c.Assert(values.Get("Action"), check.Equals, "CreateUser")
c.Assert(values.Get("UserName"), check.Equals, "Bob")
c.Assert(values.Get("Path"), check.Equals, "/division_abc/subdivision_xyz/")
c.Assert(err, check.IsNil)
c.Assert(resp.RequestId, check.Equals, "7a62c49f-347e-4fc4-9331-6e8eEXAMPLE")
expected := iam.User{
Path: "/division_abc/subdivision_xyz/",
Name: "Bob",
Id: "AIDACKCEVSQ6C2EXAMPLE",
Arn: "arn:aws:iam::123456789012:user/division_abc/subdivision_xyz/Bob",
}
c.Assert(resp.User, check.DeepEquals, expected)
}
func (s *S) TestCreateUserConflict(c *check.C) {
testServer.Response(409, nil, DuplicateUserExample)
resp, err := s.iam.CreateUser("Bob", "/division_abc/subdivision_xyz/")
testServer.WaitRequest()
c.Assert(resp, check.IsNil)
c.Assert(err, check.NotNil)
e, ok := err.(*iam.Error)
c.Assert(ok, check.Equals, true)
c.Assert(e.Message, check.Equals, "User with name Bob already exists.")
c.Assert(e.Code, check.Equals, "EntityAlreadyExists")
}
func (s *S) TestGetUser(c *check.C) {
testServer.Response(200, nil, GetUserExample)
resp, err := s.iam.GetUser("Bob")
values := testServer.WaitRequest().URL.Query()
c.Assert(values.Get("Action"), check.Equals, "GetUser")
c.Assert(values.Get("UserName"), check.Equals, "Bob")
c.Assert(err, check.IsNil)
c.Assert(resp.RequestId, check.Equals, "7a62c49f-347e-4fc4-9331-6e8eEXAMPLE")
expected := iam.User{
Path: "/division_abc/subdivision_xyz/",
Name: "Bob",
Id: "AIDACKCEVSQ6C2EXAMPLE",
Arn: "arn:aws:iam::123456789012:user/division_abc/subdivision_xyz/Bob",
}
c.Assert(resp.User, check.DeepEquals, expected)
}
func (s *S) TestDeleteUser(c *check.C) {
testServer.Response(200, nil, RequestIdExample)
resp, err := s.iam.DeleteUser("Bob")
values := testServer.WaitRequest().URL.Query()
c.Assert(values.Get("Action"), check.Equals, "DeleteUser")
c.Assert(values.Get("UserName"), check.Equals, "Bob")
c.Assert(err, check.IsNil)
c.Assert(resp.RequestId, check.Equals, "7a62c49f-347e-4fc4-9331-6e8eEXAMPLE")
}
func (s *S) TestCreateGroup(c *check.C) {
testServer.Response(200, nil, CreateGroupExample)
resp, err := s.iam.CreateGroup("Admins", "/admins/")
values := testServer.WaitRequest().URL.Query()
c.Assert(values.Get("Action"), check.Equals, "CreateGroup")
c.Assert(values.Get("GroupName"), check.Equals, "Admins")
c.Assert(values.Get("Path"), check.Equals, "/admins/")
c.Assert(err, check.IsNil)
c.Assert(resp.Group.Path, check.Equals, "/admins/")
c.Assert(resp.Group.Name, check.Equals, "Admins")
c.Assert(resp.Group.Id, check.Equals, "AGPACKCEVSQ6C2EXAMPLE")
c.Assert(resp.RequestId, check.Equals, "7a62c49f-347e-4fc4-9331-6e8eEXAMPLE")
}
func (s *S) TestCreateGroupWithoutPath(c *check.C) {
testServer.Response(200, nil, CreateGroupExample)
_, err := s.iam.CreateGroup("Managers", "")
values := testServer.WaitRequest().URL.Query()
c.Assert(values.Get("Action"), check.Equals, "CreateGroup")
c.Assert(err, check.IsNil)
_, ok := map[string][]string(values)["Path"]
c.Assert(ok, check.Equals, false)
}
func (s *S) TestDeleteGroup(c *check.C) {
testServer.Response(200, nil, RequestIdExample)
resp, err := s.iam.DeleteGroup("Admins")
values := testServer.WaitRequest().URL.Query()
c.Assert(values.Get("Action"), check.Equals, "DeleteGroup")
c.Assert(values.Get("GroupName"), check.Equals, "Admins")
c.Assert(err, check.IsNil)
c.Assert(resp.RequestId, check.Equals, "7a62c49f-347e-4fc4-9331-6e8eEXAMPLE")
}
func (s *S) TestListGroups(c *check.C) {
testServer.Response(200, nil, ListGroupsExample)
resp, err := s.iam.Groups("/division_abc/")
values := testServer.WaitRequest().URL.Query()
c.Assert(values.Get("Action"), check.Equals, "ListGroups")
c.Assert(values.Get("PathPrefix"), check.Equals, "/division_abc/")
c.Assert(err, check.IsNil)
c.Assert(resp.RequestId, check.Equals, "7a62c49f-347e-4fc4-9331-6e8eEXAMPLE")
expected := []iam.Group{
{
Path: "/division_abc/subdivision_xyz/",
Name: "Admins",
Id: "AGPACKCEVSQ6C2EXAMPLE",
Arn: "arn:aws:iam::123456789012:group/Admins",
},
{
Path: "/division_abc/subdivision_xyz/product_1234/engineering/",
Name: "Test",
Id: "AGP2MAB8DPLSRHEXAMPLE",
Arn: "arn:aws:iam::123456789012:group/division_abc/subdivision_xyz/product_1234/engineering/Test",
},
{
Path: "/division_abc/subdivision_xyz/product_1234/",
Name: "Managers",
Id: "AGPIODR4TAW7CSEXAMPLE",
Arn: "arn:aws:iam::123456789012:group/division_abc/subdivision_xyz/product_1234/Managers",
},
}
c.Assert(resp.Groups, check.DeepEquals, expected)
}
func (s *S) TestListGroupsWithoutPathPrefix(c *check.C) {
testServer.Response(200, nil, ListGroupsExample)
_, err := s.iam.Groups("")
values := testServer.WaitRequest().URL.Query()
c.Assert(values.Get("Action"), check.Equals, "ListGroups")
c.Assert(err, check.IsNil)
_, ok := map[string][]string(values)["PathPrefix"]
c.Assert(ok, check.Equals, false)
}
func (s *S) TestCreateAccessKey(c *check.C) {
testServer.Response(200, nil, CreateAccessKeyExample)
resp, err := s.iam.CreateAccessKey("Bob")
values := testServer.WaitRequest().URL.Query()
c.Assert(values.Get("Action"), check.Equals, "CreateAccessKey")
c.Assert(values.Get("UserName"), check.Equals, "Bob")
c.Assert(err, check.IsNil)
c.Assert(resp.AccessKey.UserName, check.Equals, "Bob")
c.Assert(resp.AccessKey.Id, check.Equals, "AKIAIOSFODNN7EXAMPLE")
c.Assert(resp.AccessKey.Secret, check.Equals, "wJalrXUtnFEMI/K7MDENG/bPxRfiCYzEXAMPLEKEY")
c.Assert(resp.AccessKey.Status, check.Equals, "Active")
}
func (s *S) TestDeleteAccessKey(c *check.C) {
testServer.Response(200, nil, RequestIdExample)
resp, err := s.iam.DeleteAccessKey("ysa8hasdhasdsi", "Bob")
values := testServer.WaitRequest().URL.Query()
c.Assert(values.Get("Action"), check.Equals, "DeleteAccessKey")
c.Assert(values.Get("AccessKeyId"), check.Equals, "ysa8hasdhasdsi")
c.Assert(values.Get("UserName"), check.Equals, "Bob")
c.Assert(err, check.IsNil)
c.Assert(resp.RequestId, check.Equals, "7a62c49f-347e-4fc4-9331-6e8eEXAMPLE")
}
func (s *S) TestDeleteAccessKeyBlankUserName(c *check.C) {
testServer.Response(200, nil, RequestIdExample)
_, err := s.iam.DeleteAccessKey("ysa8hasdhasdsi", "")
c.Assert(err, check.IsNil)
values := testServer.WaitRequest().URL.Query()
c.Assert(values.Get("Action"), check.Equals, "DeleteAccessKey")
c.Assert(values.Get("AccessKeyId"), check.Equals, "ysa8hasdhasdsi")
_, ok := map[string][]string(values)["UserName"]
c.Assert(ok, check.Equals, false)
}
func (s *S) TestAccessKeys(c *check.C) {
testServer.Response(200, nil, ListAccessKeyExample)
resp, err := s.iam.AccessKeys("Bob")
values := testServer.WaitRequest().URL.Query()
c.Assert(values.Get("Action"), check.Equals, "ListAccessKeys")
c.Assert(values.Get("UserName"), check.Equals, "Bob")
c.Assert(err, check.IsNil)
c.Assert(resp.RequestId, check.Equals, "7a62c49f-347e-4fc4-9331-6e8eEXAMPLE")
c.Assert(resp.AccessKeys, check.HasLen, 2)
c.Assert(resp.AccessKeys[0].Id, check.Equals, "AKIAIOSFODNN7EXAMPLE")
c.Assert(resp.AccessKeys[0].UserName, check.Equals, "Bob")
c.Assert(resp.AccessKeys[0].Status, check.Equals, "Active")
c.Assert(resp.AccessKeys[1].Id, check.Equals, "AKIAI44QH8DHBEXAMPLE")
c.Assert(resp.AccessKeys[1].UserName, check.Equals, "Bob")
c.Assert(resp.AccessKeys[1].Status, check.Equals, "Inactive")
}
func (s *S) TestAccessKeysBlankUserName(c *check.C) {
testServer.Response(200, nil, ListAccessKeyExample)
_, err := s.iam.AccessKeys("")
c.Assert(err, check.IsNil)
values := testServer.WaitRequest().URL.Query()
c.Assert(values.Get("Action"), check.Equals, "ListAccessKeys")
_, ok := map[string][]string(values)["UserName"]
c.Assert(ok, check.Equals, false)
}
func (s *S) TestGetUserPolicy(c *check.C) {
testServer.Response(200, nil, GetUserPolicyExample)
resp, err := s.iam.GetUserPolicy("Bob", "AllAccessPolicy")
values := testServer.WaitRequest().URL.Query()
c.Assert(values.Get("Action"), check.Equals, "GetUserPolicy")
c.Assert(values.Get("UserName"), check.Equals, "Bob")
c.Assert(values.Get("PolicyName"), check.Equals, "AllAccessPolicy")
c.Assert(err, check.IsNil)
c.Assert(resp.Policy.UserName, check.Equals, "Bob")
c.Assert(resp.Policy.Name, check.Equals, "AllAccessPolicy")
c.Assert(strings.TrimSpace(resp.Policy.Document), check.Equals, `{"Statement":[{"Effect":"Allow","Action":"*","Resource":"*"}]}`)
c.Assert(resp.RequestId, check.Equals, "7a62c49f-347e-4fc4-9331-6e8eEXAMPLE")
}
func (s *S) TestPutUserPolicy(c *check.C) {
document := `{
"Statement": [
{
"Action": [
"s3:*"
],
"Effect": "Allow",
"Resource": [
"arn:aws:s3:::8shsns19s90ajahadsj/*",
"arn:aws:s3:::8shsns19s90ajahadsj"
]
}]
}`
testServer.Response(200, nil, RequestIdExample)
resp, err := s.iam.PutUserPolicy("Bob", "AllAccessPolicy", document)
req := testServer.WaitRequest()
c.Assert(req.Method, check.Equals, "POST")
c.Assert(req.FormValue("Action"), check.Equals, "PutUserPolicy")
c.Assert(req.FormValue("PolicyName"), check.Equals, "AllAccessPolicy")
c.Assert(req.FormValue("UserName"), check.Equals, "Bob")
c.Assert(req.FormValue("PolicyDocument"), check.Equals, document)
c.Assert(req.FormValue("Version"), check.Equals, "2010-05-08")
c.Assert(err, check.IsNil)
c.Assert(resp.RequestId, check.Equals, "7a62c49f-347e-4fc4-9331-6e8eEXAMPLE")
}
func (s *S) TestDeleteUserPolicy(c *check.C) {
testServer.Response(200, nil, RequestIdExample)
resp, err := s.iam.DeleteUserPolicy("Bob", "AllAccessPolicy")
values := testServer.WaitRequest().URL.Query()
c.Assert(values.Get("Action"), check.Equals, "DeleteUserPolicy")
c.Assert(values.Get("PolicyName"), check.Equals, "AllAccessPolicy")
c.Assert(values.Get("UserName"), check.Equals, "Bob")
c.Assert(err, check.IsNil)
c.Assert(resp.RequestId, check.Equals, "7a62c49f-347e-4fc4-9331-6e8eEXAMPLE")
}
|