parent
f389d507e8
commit
eb3da8f91d
@ -514,15 +514,16 @@ class OrganizationsBackend(BaseBackend):
|
|||||||
accounts = sorted(accounts, key=lambda x: x["JoinedTimestamp"])
|
accounts = sorted(accounts, key=lambda x: x["JoinedTimestamp"])
|
||||||
return accounts
|
return accounts
|
||||||
|
|
||||||
|
@paginate(pagination_model=PAGINATION_MODEL)
|
||||||
def list_accounts_for_parent(self, **kwargs):
|
def list_accounts_for_parent(self, **kwargs):
|
||||||
parent_id = self.validate_parent_id(kwargs["ParentId"])
|
parent_id = self.validate_parent_id(kwargs["parent_id"])
|
||||||
return dict(
|
accounts = [
|
||||||
Accounts=[
|
|
||||||
account.describe()
|
account.describe()
|
||||||
for account in self.accounts
|
for account in self.accounts
|
||||||
if account.parent_id == parent_id
|
if account.parent_id == parent_id
|
||||||
]
|
]
|
||||||
)
|
accounts = sorted(accounts, key=lambda x: x["JoinedTimestamp"])
|
||||||
|
return accounts
|
||||||
|
|
||||||
def move_account(self, **kwargs):
|
def move_account(self, **kwargs):
|
||||||
new_parent_id = self.validate_parent_id(kwargs["DestinationParentId"])
|
new_parent_id = self.validate_parent_id(kwargs["DestinationParentId"])
|
||||||
|
@ -109,9 +109,16 @@ class OrganizationsResponse(BaseResponse):
|
|||||||
return json.dumps(response)
|
return json.dumps(response)
|
||||||
|
|
||||||
def list_accounts_for_parent(self):
|
def list_accounts_for_parent(self):
|
||||||
return json.dumps(
|
max_results = self._get_int_param("MaxResults")
|
||||||
self.organizations_backend.list_accounts_for_parent(**self.request_params)
|
next_token = self._get_param("NextToken")
|
||||||
|
parent_id = self._get_param("ParentId")
|
||||||
|
accounts, next_token = self.organizations_backend.list_accounts_for_parent(
|
||||||
|
max_results=max_results, next_token=next_token, parent_id=parent_id
|
||||||
)
|
)
|
||||||
|
response = {"Accounts": accounts}
|
||||||
|
if next_token:
|
||||||
|
response["NextToken"] = next_token
|
||||||
|
return json.dumps(response)
|
||||||
|
|
||||||
def move_account(self):
|
def move_account(self):
|
||||||
return json.dumps(
|
return json.dumps(
|
||||||
|
@ -41,6 +41,13 @@ PAGINATION_MODEL = {
|
|||||||
"result_key": "Accounts",
|
"result_key": "Accounts",
|
||||||
"unique_attribute": "JoinedTimestamp",
|
"unique_attribute": "JoinedTimestamp",
|
||||||
},
|
},
|
||||||
|
"list_accounts_for_parent": {
|
||||||
|
"input_token": "next_token",
|
||||||
|
"limit_key": "max_results",
|
||||||
|
"limit_default": 20,
|
||||||
|
"result_key": "Accounts",
|
||||||
|
"unique_attribute": "JoinedTimestamp",
|
||||||
|
},
|
||||||
"list_organizational_units_for_parent": {
|
"list_organizational_units_for_parent": {
|
||||||
"input_token": "next_token",
|
"input_token": "next_token",
|
||||||
"limit_key": "max_results",
|
"limit_key": "max_results",
|
||||||
|
@ -327,6 +327,28 @@ def test_list_accounts_for_parent():
|
|||||||
account_id.should.be.within([account["Id"] for account in response["Accounts"]])
|
account_id.should.be.within([account["Id"] for account in response["Accounts"]])
|
||||||
|
|
||||||
|
|
||||||
|
@mock_organizations
|
||||||
|
def test_list_accounts_for_parent_pagination():
|
||||||
|
client = boto3.client("organizations", region_name="us-east-1")
|
||||||
|
client.create_organization(FeatureSet="ALL")
|
||||||
|
root_id = client.list_roots()["Roots"][0]["Id"]
|
||||||
|
response = client.list_accounts_for_parent(ParentId=root_id)
|
||||||
|
response.should_not.have.key("NextToken")
|
||||||
|
num_existing_accounts = len(response["Accounts"])
|
||||||
|
for i in range(num_existing_accounts, 21):
|
||||||
|
name = mockname + str(i)
|
||||||
|
email = name + "@" + mockdomain
|
||||||
|
client.create_account(AccountName=name, Email=email)
|
||||||
|
response = client.list_accounts_for_parent(ParentId=root_id)
|
||||||
|
len(response["Accounts"]).should.be.greater_than_or_equal_to(i)
|
||||||
|
|
||||||
|
paginator = client.get_paginator("list_accounts_for_parent")
|
||||||
|
page_iterator = paginator.paginate(MaxResults=5, ParentId=root_id)
|
||||||
|
for page in page_iterator:
|
||||||
|
len(page["Accounts"]).should.be.lower_than_or_equal_to(5)
|
||||||
|
page["Accounts"][-1]["Name"].should.contain("20")
|
||||||
|
|
||||||
|
|
||||||
@mock_organizations
|
@mock_organizations
|
||||||
def test_move_account():
|
def test_move_account():
|
||||||
client = boto3.client("organizations", region_name="us-east-1")
|
client = boto3.client("organizations", region_name="us-east-1")
|
||||||
|
Loading…
Reference in New Issue
Block a user