Skip to content

Commit 7716db9

Browse files
committed
iam_tests
1 parent ac31e72 commit 7716db9

1 file changed

Lines changed: 63 additions & 0 deletions

File tree

Lines changed: 63 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,63 @@
1+
import pytest
2+
3+
from linode_api4.objects import EntityAccess, LinodeEntity
4+
5+
6+
@pytest.mark.smoke
7+
def test_get_role_permissions(test_linode_client):
8+
client = test_linode_client
9+
iam = client.iam
10+
11+
permissions = iam.role_permissions()
12+
13+
assert "account_access" in permissions
14+
assert isinstance(permissions["account_access"], list)
15+
16+
17+
@pytest.mark.smoke
18+
def test_get_user_role_permissions(test_linode_client):
19+
client = test_linode_client
20+
iam = client.iam
21+
22+
username = client.profile().username
23+
user_permissions = iam.role_permissions_user_get(username)
24+
25+
assert "account_access" in user_permissions
26+
assert isinstance(user_permissions["account_access"], list)
27+
28+
29+
@pytest.mark.skip(
30+
reason="Updating IAM role permissions may require elevated privileges."
31+
)
32+
def test_set_user_role_permissions(test_linode_client):
33+
client = test_linode_client
34+
iam = client.iam
35+
36+
username = client.profile().username
37+
entity_access = [EntityAccess(id=1, type="linode", roles=["read_only"])]
38+
39+
updated = iam.role_permissions_user_set(
40+
username,
41+
account_access=["read_only"],
42+
entity_access=entity_access,
43+
)
44+
45+
assert "account_access" in updated
46+
assert "entity_access" in updated
47+
48+
49+
@pytest.mark.smoke
50+
def test_list_entities(test_linode_client):
51+
client = test_linode_client
52+
iam = client.iam
53+
54+
entities = iam.entities()
55+
56+
if len(entities) > 0:
57+
entity = entities[0]
58+
assert isinstance(entity, LinodeEntity)
59+
assert hasattr(entity, "id")
60+
assert hasattr(entity, "label")
61+
assert hasattr(entity, "type")
62+
else:
63+
pytest.skip("No entities found in IAM response.")

0 commit comments

Comments
 (0)