2018-07-14 18:35:37 +00:00
|
|
|
from __future__ import unicode_literals
|
|
|
|
|
|
|
|
import boto3
|
2019-05-25 09:20:19 +00:00
|
|
|
import json
|
|
|
|
import six
|
2018-07-14 18:35:37 +00:00
|
|
|
import sure # noqa
|
2018-07-20 20:54:53 +00:00
|
|
|
from botocore.exceptions import ClientError
|
|
|
|
from nose.tools import assert_raises
|
2018-07-14 18:35:37 +00:00
|
|
|
|
|
|
|
from moto import mock_organizations
|
2018-07-20 20:54:53 +00:00
|
|
|
from moto.organizations import utils
|
2018-07-19 18:50:24 +00:00
|
|
|
from .organizations_test_utils import (
|
|
|
|
validate_organization,
|
|
|
|
validate_roots,
|
|
|
|
validate_organizational_unit,
|
|
|
|
validate_account,
|
|
|
|
validate_create_account_status,
|
2019-05-25 09:20:19 +00:00
|
|
|
validate_service_control_policy,
|
|
|
|
validate_policy_summary,
|
2018-07-14 18:35:37 +00:00
|
|
|
)
|
2018-07-14 20:23:15 +00:00
|
|
|
|
2018-07-14 18:35:37 +00:00
|
|
|
|
|
|
|
@mock_organizations
|
|
|
|
def test_create_organization():
|
|
|
|
client = boto3.client('organizations', region_name='us-east-1')
|
|
|
|
response = client.create_organization(FeatureSet='ALL')
|
|
|
|
validate_organization(response)
|
|
|
|
response['Organization']['FeatureSet'].should.equal('ALL')
|
|
|
|
|
2018-07-14 20:23:15 +00:00
|
|
|
|
2018-07-14 18:35:37 +00:00
|
|
|
@mock_organizations
|
|
|
|
def test_describe_organization():
|
|
|
|
client = boto3.client('organizations', region_name='us-east-1')
|
|
|
|
client.create_organization(FeatureSet='ALL')
|
|
|
|
response = client.describe_organization()
|
|
|
|
validate_organization(response)
|
|
|
|
|
|
|
|
|
2018-10-08 22:27:19 +00:00
|
|
|
@mock_organizations
|
|
|
|
def test_describe_organization_exception():
|
|
|
|
client = boto3.client('organizations', region_name='us-east-1')
|
|
|
|
with assert_raises(ClientError) as e:
|
|
|
|
response = client.describe_organization()
|
|
|
|
ex = e.exception
|
|
|
|
ex.operation_name.should.equal('DescribeOrganization')
|
|
|
|
ex.response['Error']['Code'].should.equal('400')
|
|
|
|
ex.response['Error']['Message'].should.contain('AWSOrganizationsNotInUseException')
|
|
|
|
|
|
|
|
|
2018-07-15 18:49:26 +00:00
|
|
|
# Organizational Units
|
|
|
|
|
2018-07-15 17:31:16 +00:00
|
|
|
@mock_organizations
|
|
|
|
def test_list_roots():
|
|
|
|
client = boto3.client('organizations', region_name='us-east-1')
|
|
|
|
org = client.create_organization(FeatureSet='ALL')['Organization']
|
|
|
|
response = client.list_roots()
|
2018-07-19 18:50:24 +00:00
|
|
|
validate_roots(org, response)
|
2018-07-15 17:31:16 +00:00
|
|
|
|
|
|
|
|
2018-07-15 18:49:26 +00:00
|
|
|
@mock_organizations
|
|
|
|
def test_create_organizational_unit():
|
|
|
|
client = boto3.client('organizations', region_name='us-east-1')
|
|
|
|
org = client.create_organization(FeatureSet='ALL')['Organization']
|
|
|
|
root_id = client.list_roots()['Roots'][0]['Id']
|
2018-07-15 20:58:27 +00:00
|
|
|
ou_name = 'ou01'
|
2018-07-15 18:49:26 +00:00
|
|
|
response = client.create_organizational_unit(
|
|
|
|
ParentId=root_id,
|
|
|
|
Name=ou_name,
|
|
|
|
)
|
2018-07-15 20:58:27 +00:00
|
|
|
validate_organizational_unit(org, response)
|
|
|
|
response['OrganizationalUnit']['Name'].should.equal(ou_name)
|
2018-07-15 18:49:26 +00:00
|
|
|
|
|
|
|
|
|
|
|
@mock_organizations
|
|
|
|
def test_describe_organizational_unit():
|
|
|
|
client = boto3.client('organizations', region_name='us-east-1')
|
|
|
|
org = client.create_organization(FeatureSet='ALL')['Organization']
|
|
|
|
root_id = client.list_roots()['Roots'][0]['Id']
|
|
|
|
ou_id = client.create_organizational_unit(
|
|
|
|
ParentId=root_id,
|
2018-07-15 20:58:27 +00:00
|
|
|
Name='ou01',
|
2018-07-15 18:49:26 +00:00
|
|
|
)['OrganizationalUnit']['Id']
|
2018-07-15 20:58:27 +00:00
|
|
|
response = client.describe_organizational_unit(OrganizationalUnitId=ou_id)
|
|
|
|
validate_organizational_unit(org, response)
|
|
|
|
|
|
|
|
|
2018-07-20 20:54:53 +00:00
|
|
|
@mock_organizations
|
|
|
|
def test_describe_organizational_unit_exception():
|
|
|
|
client = boto3.client('organizations', region_name='us-east-1')
|
|
|
|
org = client.create_organization(FeatureSet='ALL')['Organization']
|
|
|
|
with assert_raises(ClientError) as e:
|
|
|
|
response = client.describe_organizational_unit(
|
|
|
|
OrganizationalUnitId=utils.make_random_root_id()
|
|
|
|
)
|
|
|
|
ex = e.exception
|
|
|
|
ex.operation_name.should.equal('DescribeOrganizationalUnit')
|
|
|
|
ex.response['Error']['Code'].should.equal('400')
|
|
|
|
ex.response['Error']['Message'].should.contain('OrganizationalUnitNotFoundException')
|
|
|
|
|
|
|
|
|
2018-07-15 20:58:27 +00:00
|
|
|
@mock_organizations
|
|
|
|
def test_list_organizational_units_for_parent():
|
|
|
|
client = boto3.client('organizations', region_name='us-east-1')
|
|
|
|
org = client.create_organization(FeatureSet='ALL')['Organization']
|
|
|
|
root_id = client.list_roots()['Roots'][0]['Id']
|
|
|
|
client.create_organizational_unit(ParentId=root_id, Name='ou01')
|
|
|
|
client.create_organizational_unit(ParentId=root_id, Name='ou02')
|
|
|
|
client.create_organizational_unit(ParentId=root_id, Name='ou03')
|
|
|
|
response = client.list_organizational_units_for_parent(ParentId=root_id)
|
|
|
|
response.should.have.key('OrganizationalUnits').should.be.a(list)
|
|
|
|
for ou in response['OrganizationalUnits']:
|
|
|
|
validate_organizational_unit(org, dict(OrganizationalUnit=ou))
|
|
|
|
|
|
|
|
|
2018-07-20 20:54:53 +00:00
|
|
|
@mock_organizations
|
|
|
|
def test_list_organizational_units_for_parent_exception():
|
|
|
|
client = boto3.client('organizations', region_name='us-east-1')
|
|
|
|
with assert_raises(ClientError) as e:
|
|
|
|
response = client.list_organizational_units_for_parent(
|
|
|
|
ParentId=utils.make_random_root_id()
|
|
|
|
)
|
|
|
|
ex = e.exception
|
|
|
|
ex.operation_name.should.equal('ListOrganizationalUnitsForParent')
|
|
|
|
ex.response['Error']['Code'].should.equal('400')
|
|
|
|
ex.response['Error']['Message'].should.contain('ParentNotFoundException')
|
|
|
|
|
|
|
|
|
2018-07-15 18:49:26 +00:00
|
|
|
# Accounts
|
2018-07-14 18:35:37 +00:00
|
|
|
mockname = 'mock-account'
|
|
|
|
mockdomain = 'moto-example.org'
|
|
|
|
mockemail = '@'.join([mockname, mockdomain])
|
|
|
|
|
2018-07-14 20:23:15 +00:00
|
|
|
|
2018-07-14 18:35:37 +00:00
|
|
|
@mock_organizations
|
|
|
|
def test_create_account():
|
|
|
|
client = boto3.client('organizations', region_name='us-east-1')
|
|
|
|
client.create_organization(FeatureSet='ALL')
|
|
|
|
create_status = client.create_account(
|
2018-07-14 20:23:15 +00:00
|
|
|
AccountName=mockname, Email=mockemail
|
|
|
|
)['CreateAccountStatus']
|
2018-07-14 18:35:37 +00:00
|
|
|
validate_create_account_status(create_status)
|
|
|
|
create_status['AccountName'].should.equal(mockname)
|
|
|
|
|
2018-07-14 20:23:15 +00:00
|
|
|
|
2018-07-14 18:35:37 +00:00
|
|
|
@mock_organizations
|
|
|
|
def test_describe_account():
|
|
|
|
client = boto3.client('organizations', region_name='us-east-1')
|
|
|
|
org = client.create_organization(FeatureSet='ALL')['Organization']
|
|
|
|
account_id = client.create_account(
|
2018-07-14 20:23:15 +00:00
|
|
|
AccountName=mockname, Email=mockemail
|
|
|
|
)['CreateAccountStatus']['AccountId']
|
2018-07-14 18:35:37 +00:00
|
|
|
response = client.describe_account(AccountId=account_id)
|
|
|
|
validate_account(org, response['Account'])
|
|
|
|
response['Account']['Name'].should.equal(mockname)
|
|
|
|
response['Account']['Email'].should.equal(mockemail)
|
|
|
|
|
2018-07-14 20:23:15 +00:00
|
|
|
|
2018-07-20 20:54:53 +00:00
|
|
|
@mock_organizations
|
|
|
|
def test_describe_account_exception():
|
|
|
|
client = boto3.client('organizations', region_name='us-east-1')
|
|
|
|
with assert_raises(ClientError) as e:
|
|
|
|
response = client.describe_account(AccountId=utils.make_random_account_id())
|
|
|
|
ex = e.exception
|
|
|
|
ex.operation_name.should.equal('DescribeAccount')
|
|
|
|
ex.response['Error']['Code'].should.equal('400')
|
|
|
|
ex.response['Error']['Message'].should.contain('AccountNotFoundException')
|
|
|
|
|
|
|
|
|
2018-07-14 18:35:37 +00:00
|
|
|
@mock_organizations
|
|
|
|
def test_list_accounts():
|
|
|
|
client = boto3.client('organizations', region_name='us-east-1')
|
|
|
|
org = client.create_organization(FeatureSet='ALL')['Organization']
|
|
|
|
for i in range(5):
|
|
|
|
name = mockname + str(i)
|
|
|
|
email = name + '@' + mockdomain
|
|
|
|
client.create_account(AccountName=name, Email=email)
|
|
|
|
response = client.list_accounts()
|
|
|
|
response.should.have.key('Accounts')
|
|
|
|
accounts = response['Accounts']
|
|
|
|
len(accounts).should.equal(5)
|
|
|
|
for account in accounts:
|
|
|
|
validate_account(org, account)
|
|
|
|
accounts[3]['Name'].should.equal(mockname + '3')
|
|
|
|
accounts[2]['Email'].should.equal(mockname + '2' + '@' + mockdomain)
|
2018-07-15 22:25:34 +00:00
|
|
|
|
|
|
|
|
|
|
|
@mock_organizations
|
|
|
|
def test_list_accounts_for_parent():
|
|
|
|
client = boto3.client('organizations', region_name='us-east-1')
|
|
|
|
org = client.create_organization(FeatureSet='ALL')['Organization']
|
|
|
|
root_id = client.list_roots()['Roots'][0]['Id']
|
|
|
|
account_id = client.create_account(
|
|
|
|
AccountName=mockname,
|
|
|
|
Email=mockemail,
|
|
|
|
)['CreateAccountStatus']['AccountId']
|
|
|
|
response = client.list_accounts_for_parent(ParentId=root_id)
|
|
|
|
account_id.should.be.within([account['Id'] for account in response['Accounts']])
|
|
|
|
|
|
|
|
|
|
|
|
@mock_organizations
|
|
|
|
def test_move_account():
|
|
|
|
client = boto3.client('organizations', region_name='us-east-1')
|
|
|
|
org = client.create_organization(FeatureSet='ALL')['Organization']
|
|
|
|
root_id = client.list_roots()['Roots'][0]['Id']
|
|
|
|
account_id = client.create_account(
|
|
|
|
AccountName=mockname, Email=mockemail
|
|
|
|
)['CreateAccountStatus']['AccountId']
|
|
|
|
ou01 = client.create_organizational_unit(ParentId=root_id, Name='ou01')
|
|
|
|
ou01_id = ou01['OrganizationalUnit']['Id']
|
|
|
|
client.move_account(
|
|
|
|
AccountId=account_id,
|
|
|
|
SourceParentId=root_id,
|
|
|
|
DestinationParentId=ou01_id,
|
|
|
|
)
|
|
|
|
response = client.list_accounts_for_parent(ParentId=ou01_id)
|
|
|
|
account_id.should.be.within([account['Id'] for account in response['Accounts']])
|
2018-07-16 03:39:13 +00:00
|
|
|
|
|
|
|
|
|
|
|
@mock_organizations
|
|
|
|
def test_list_parents_for_ou():
|
|
|
|
client = boto3.client('organizations', region_name='us-east-1')
|
|
|
|
org = client.create_organization(FeatureSet='ALL')['Organization']
|
|
|
|
root_id = client.list_roots()['Roots'][0]['Id']
|
|
|
|
ou01 = client.create_organizational_unit(ParentId=root_id, Name='ou01')
|
|
|
|
ou01_id = ou01['OrganizationalUnit']['Id']
|
|
|
|
response01 = client.list_parents(ChildId=ou01_id)
|
|
|
|
response01.should.have.key('Parents').should.be.a(list)
|
|
|
|
response01['Parents'][0].should.have.key('Id').should.equal(root_id)
|
|
|
|
response01['Parents'][0].should.have.key('Type').should.equal('ROOT')
|
|
|
|
ou02 = client.create_organizational_unit(ParentId=ou01_id, Name='ou02')
|
|
|
|
ou02_id = ou02['OrganizationalUnit']['Id']
|
|
|
|
response02 = client.list_parents(ChildId=ou02_id)
|
|
|
|
response02.should.have.key('Parents').should.be.a(list)
|
|
|
|
response02['Parents'][0].should.have.key('Id').should.equal(ou01_id)
|
|
|
|
response02['Parents'][0].should.have.key('Type').should.equal('ORGANIZATIONAL_UNIT')
|
|
|
|
|
|
|
|
|
|
|
|
@mock_organizations
|
|
|
|
def test_list_parents_for_accounts():
|
|
|
|
client = boto3.client('organizations', region_name='us-east-1')
|
|
|
|
org = client.create_organization(FeatureSet='ALL')['Organization']
|
|
|
|
root_id = client.list_roots()['Roots'][0]['Id']
|
|
|
|
ou01 = client.create_organizational_unit(ParentId=root_id, Name='ou01')
|
|
|
|
ou01_id = ou01['OrganizationalUnit']['Id']
|
|
|
|
account01_id = client.create_account(
|
|
|
|
AccountName='account01',
|
|
|
|
Email='account01@moto-example.org'
|
|
|
|
)['CreateAccountStatus']['AccountId']
|
|
|
|
account02_id = client.create_account(
|
|
|
|
AccountName='account02',
|
|
|
|
Email='account02@moto-example.org'
|
|
|
|
)['CreateAccountStatus']['AccountId']
|
|
|
|
client.move_account(
|
|
|
|
AccountId=account02_id,
|
|
|
|
SourceParentId=root_id,
|
|
|
|
DestinationParentId=ou01_id,
|
|
|
|
)
|
|
|
|
response01 = client.list_parents(ChildId=account01_id)
|
|
|
|
response01.should.have.key('Parents').should.be.a(list)
|
|
|
|
response01['Parents'][0].should.have.key('Id').should.equal(root_id)
|
|
|
|
response01['Parents'][0].should.have.key('Type').should.equal('ROOT')
|
|
|
|
response02 = client.list_parents(ChildId=account02_id)
|
|
|
|
response02.should.have.key('Parents').should.be.a(list)
|
|
|
|
response02['Parents'][0].should.have.key('Id').should.equal(ou01_id)
|
|
|
|
response02['Parents'][0].should.have.key('Type').should.equal('ORGANIZATIONAL_UNIT')
|
2018-07-16 05:19:42 +00:00
|
|
|
|
|
|
|
|
|
|
|
@mock_organizations
|
2018-07-20 20:54:53 +00:00
|
|
|
def test_list_children():
|
2018-07-16 05:19:42 +00:00
|
|
|
client = boto3.client('organizations', region_name='us-east-1')
|
|
|
|
org = client.create_organization(FeatureSet='ALL')['Organization']
|
|
|
|
root_id = client.list_roots()['Roots'][0]['Id']
|
|
|
|
ou01 = client.create_organizational_unit(ParentId=root_id, Name='ou01')
|
|
|
|
ou01_id = ou01['OrganizationalUnit']['Id']
|
|
|
|
ou02 = client.create_organizational_unit(ParentId=ou01_id, Name='ou02')
|
|
|
|
ou02_id = ou02['OrganizationalUnit']['Id']
|
|
|
|
account01_id = client.create_account(
|
|
|
|
AccountName='account01',
|
|
|
|
Email='account01@moto-example.org'
|
|
|
|
)['CreateAccountStatus']['AccountId']
|
|
|
|
account02_id = client.create_account(
|
|
|
|
AccountName='account02',
|
|
|
|
Email='account02@moto-example.org'
|
|
|
|
)['CreateAccountStatus']['AccountId']
|
|
|
|
client.move_account(
|
|
|
|
AccountId=account02_id,
|
|
|
|
SourceParentId=root_id,
|
|
|
|
DestinationParentId=ou01_id,
|
|
|
|
)
|
|
|
|
response01 = client.list_children(ParentId=root_id, ChildType='ACCOUNT')
|
|
|
|
response02 = client.list_children(ParentId=root_id, ChildType='ORGANIZATIONAL_UNIT')
|
|
|
|
response03 = client.list_children(ParentId=ou01_id, ChildType='ACCOUNT')
|
|
|
|
response04 = client.list_children(ParentId=ou01_id, ChildType='ORGANIZATIONAL_UNIT')
|
|
|
|
response01['Children'][0]['Id'].should.equal(account01_id)
|
|
|
|
response01['Children'][0]['Type'].should.equal('ACCOUNT')
|
|
|
|
response02['Children'][0]['Id'].should.equal(ou01_id)
|
|
|
|
response02['Children'][0]['Type'].should.equal('ORGANIZATIONAL_UNIT')
|
|
|
|
response03['Children'][0]['Id'].should.equal(account02_id)
|
|
|
|
response03['Children'][0]['Type'].should.equal('ACCOUNT')
|
|
|
|
response04['Children'][0]['Id'].should.equal(ou02_id)
|
|
|
|
response04['Children'][0]['Type'].should.equal('ORGANIZATIONAL_UNIT')
|
2018-07-20 20:54:53 +00:00
|
|
|
|
|
|
|
|
|
|
|
@mock_organizations
|
|
|
|
def test_list_children_exception():
|
|
|
|
client = boto3.client('organizations', region_name='us-east-1')
|
|
|
|
org = client.create_organization(FeatureSet='ALL')['Organization']
|
|
|
|
root_id = client.list_roots()['Roots'][0]['Id']
|
|
|
|
with assert_raises(ClientError) as e:
|
|
|
|
response = client.list_children(
|
|
|
|
ParentId=utils.make_random_root_id(),
|
|
|
|
ChildType='ACCOUNT'
|
|
|
|
)
|
|
|
|
ex = e.exception
|
|
|
|
ex.operation_name.should.equal('ListChildren')
|
|
|
|
ex.response['Error']['Code'].should.equal('400')
|
|
|
|
ex.response['Error']['Message'].should.contain('ParentNotFoundException')
|
|
|
|
with assert_raises(ClientError) as e:
|
|
|
|
response = client.list_children(
|
|
|
|
ParentId=root_id,
|
|
|
|
ChildType='BLEE'
|
|
|
|
)
|
|
|
|
ex = e.exception
|
|
|
|
ex.operation_name.should.equal('ListChildren')
|
|
|
|
ex.response['Error']['Code'].should.equal('400')
|
|
|
|
ex.response['Error']['Message'].should.contain('InvalidInputException')
|
2019-05-25 09:20:19 +00:00
|
|
|
|
|
|
|
|
|
|
|
# Service Control Policies
|
|
|
|
policy_doc01 = dict(
|
|
|
|
Version='2012-10-17',
|
|
|
|
Statement=[dict(
|
|
|
|
Sid='MockPolicyStatement',
|
|
|
|
Effect='Allow',
|
|
|
|
Action='s3:*',
|
|
|
|
Resource='*',
|
|
|
|
)]
|
|
|
|
)
|
|
|
|
|
|
|
|
@mock_organizations
|
|
|
|
def test_create_policy():
|
|
|
|
client = boto3.client('organizations', region_name='us-east-1')
|
|
|
|
org = client.create_organization(FeatureSet='ALL')['Organization']
|
|
|
|
policy = client.create_policy(
|
|
|
|
Content=json.dumps(policy_doc01),
|
|
|
|
Description='A dummy service control policy',
|
|
|
|
Name='MockServiceControlPolicy',
|
|
|
|
Type='SERVICE_CONTROL_POLICY'
|
|
|
|
)['Policy']
|
|
|
|
validate_service_control_policy(org, policy)
|
|
|
|
policy['PolicySummary']['Name'].should.equal('MockServiceControlPolicy')
|
|
|
|
policy['PolicySummary']['Description'].should.equal('A dummy service control policy')
|
|
|
|
policy['Content'].should.equal(json.dumps(policy_doc01))
|
|
|
|
|
|
|
|
|
|
|
|
@mock_organizations
|
|
|
|
def test_describe_policy():
|
|
|
|
client = boto3.client('organizations', region_name='us-east-1')
|
|
|
|
org = client.create_organization(FeatureSet='ALL')['Organization']
|
|
|
|
policy_id = client.create_policy(
|
|
|
|
Content=json.dumps(policy_doc01),
|
|
|
|
Description='A dummy service control policy',
|
|
|
|
Name='MockServiceControlPolicy',
|
|
|
|
Type='SERVICE_CONTROL_POLICY'
|
|
|
|
)['Policy']['PolicySummary']['Id']
|
|
|
|
policy = client.describe_policy(PolicyId=policy_id)['Policy']
|
|
|
|
validate_service_control_policy(org, policy)
|
|
|
|
policy['PolicySummary']['Name'].should.equal('MockServiceControlPolicy')
|
|
|
|
policy['PolicySummary']['Description'].should.equal('A dummy service control policy')
|
|
|
|
policy['Content'].should.equal(json.dumps(policy_doc01))
|
|
|
|
|
|
|
|
|
|
|
|
@mock_organizations
|
|
|
|
def test_describe_policy_exception():
|
|
|
|
client = boto3.client('organizations', region_name='us-east-1')
|
|
|
|
client.create_organization(FeatureSet='ALL')['Organization']
|
|
|
|
policy_id = 'p-47fhe9s3'
|
|
|
|
with assert_raises(ClientError) as e:
|
|
|
|
response = client.describe_policy(PolicyId=policy_id)
|
|
|
|
ex = e.exception
|
|
|
|
ex.operation_name.should.equal('DescribePolicy')
|
|
|
|
ex.response['Error']['Code'].should.equal('400')
|
|
|
|
ex.response['Error']['Message'].should.contain('PolicyNotFoundException')
|
|
|
|
with assert_raises(ClientError) as e:
|
|
|
|
response = client.describe_policy(PolicyId='meaninglessstring')
|
|
|
|
ex = e.exception
|
|
|
|
ex.operation_name.should.equal('DescribePolicy')
|
|
|
|
ex.response['Error']['Code'].should.equal('400')
|
|
|
|
ex.response['Error']['Message'].should.contain('InvalidInputException')
|
|
|
|
|
|
|
|
|
|
|
|
@mock_organizations
|
|
|
|
def test_attach_policy():
|
|
|
|
client = boto3.client('organizations', region_name='us-east-1')
|
|
|
|
org = client.create_organization(FeatureSet='ALL')['Organization']
|
|
|
|
root_id = client.list_roots()['Roots'][0]['Id']
|
|
|
|
ou_id = client.create_organizational_unit(
|
|
|
|
ParentId=root_id,
|
|
|
|
Name='ou01',
|
|
|
|
)['OrganizationalUnit']['Id']
|
|
|
|
account_id = client.create_account(
|
|
|
|
AccountName=mockname,
|
|
|
|
Email=mockemail,
|
|
|
|
)['CreateAccountStatus']['AccountId']
|
|
|
|
policy_id = client.create_policy(
|
|
|
|
Content=json.dumps(policy_doc01),
|
|
|
|
Description='A dummy service control policy',
|
|
|
|
Name='MockServiceControlPolicy',
|
|
|
|
Type='SERVICE_CONTROL_POLICY'
|
|
|
|
)['Policy']['PolicySummary']['Id']
|
|
|
|
response = client.attach_policy(PolicyId=policy_id, TargetId=root_id)
|
|
|
|
response['ResponseMetadata']['HTTPStatusCode'].should.equal(200)
|
|
|
|
response = client.attach_policy(PolicyId=policy_id, TargetId=ou_id)
|
|
|
|
response['ResponseMetadata']['HTTPStatusCode'].should.equal(200)
|
|
|
|
response = client.attach_policy(PolicyId=policy_id, TargetId=account_id)
|
|
|
|
response['ResponseMetadata']['HTTPStatusCode'].should.equal(200)
|
|
|
|
|
|
|
|
|
|
|
|
@mock_organizations
|
|
|
|
def test_attach_policy_exception():
|
|
|
|
client = boto3.client('organizations', region_name='us-east-1')
|
|
|
|
client.create_organization(FeatureSet='ALL')['Organization']
|
|
|
|
root_id='r-dj873'
|
|
|
|
ou_id='ou-gi99-i7r8eh2i2'
|
|
|
|
account_id='126644886543'
|
|
|
|
policy_id = client.create_policy(
|
|
|
|
Content=json.dumps(policy_doc01),
|
|
|
|
Description='A dummy service control policy',
|
|
|
|
Name='MockServiceControlPolicy',
|
|
|
|
Type='SERVICE_CONTROL_POLICY'
|
|
|
|
)['Policy']['PolicySummary']['Id']
|
|
|
|
with assert_raises(ClientError) as e:
|
|
|
|
response = client.attach_policy(PolicyId=policy_id, TargetId=root_id)
|
|
|
|
ex = e.exception
|
|
|
|
ex.operation_name.should.equal('AttachPolicy')
|
|
|
|
ex.response['Error']['Code'].should.equal('400')
|
|
|
|
ex.response['Error']['Message'].should.contain('OrganizationalUnitNotFoundException')
|
|
|
|
with assert_raises(ClientError) as e:
|
|
|
|
response = client.attach_policy(PolicyId=policy_id, TargetId=ou_id)
|
|
|
|
ex = e.exception
|
|
|
|
ex.operation_name.should.equal('AttachPolicy')
|
|
|
|
ex.response['Error']['Code'].should.equal('400')
|
|
|
|
ex.response['Error']['Message'].should.contain('OrganizationalUnitNotFoundException')
|
|
|
|
with assert_raises(ClientError) as e:
|
|
|
|
response = client.attach_policy(PolicyId=policy_id, TargetId=account_id)
|
|
|
|
ex = e.exception
|
|
|
|
ex.operation_name.should.equal('AttachPolicy')
|
|
|
|
ex.response['Error']['Code'].should.equal('400')
|
|
|
|
ex.response['Error']['Message'].should.contain('AccountNotFoundException')
|
|
|
|
with assert_raises(ClientError) as e:
|
|
|
|
response = client.attach_policy(PolicyId=policy_id, TargetId='meaninglessstring')
|
|
|
|
ex = e.exception
|
|
|
|
ex.operation_name.should.equal('AttachPolicy')
|
|
|
|
ex.response['Error']['Code'].should.equal('400')
|
|
|
|
ex.response['Error']['Message'].should.contain('InvalidInputException')
|
|
|
|
|
|
|
|
|
|
|
|
@mock_organizations
|
|
|
|
def test_list_polices():
|
|
|
|
client = boto3.client('organizations', region_name='us-east-1')
|
|
|
|
org = client.create_organization(FeatureSet='ALL')['Organization']
|
|
|
|
for i in range(0,4):
|
|
|
|
client.create_policy(
|
|
|
|
Content=json.dumps(policy_doc01),
|
|
|
|
Description='A dummy service control policy',
|
|
|
|
Name='MockServiceControlPolicy' + str(i),
|
|
|
|
Type='SERVICE_CONTROL_POLICY'
|
|
|
|
)
|
|
|
|
response = client.list_policies(Filter='SERVICE_CONTROL_POLICY')
|
|
|
|
for policy in response['Policies']:
|
|
|
|
validate_policy_summary(org, policy)
|
|
|
|
|
|
|
|
|
|
|
|
@mock_organizations
|
|
|
|
def test_list_policies_for_target():
|
|
|
|
client = boto3.client('organizations', region_name='us-east-1')
|
|
|
|
org = client.create_organization(FeatureSet='ALL')['Organization']
|
|
|
|
root_id = client.list_roots()['Roots'][0]['Id']
|
|
|
|
ou_id = client.create_organizational_unit(
|
|
|
|
ParentId=root_id,
|
|
|
|
Name='ou01',
|
|
|
|
)['OrganizationalUnit']['Id']
|
|
|
|
account_id = client.create_account(
|
|
|
|
AccountName=mockname,
|
|
|
|
Email=mockemail,
|
|
|
|
)['CreateAccountStatus']['AccountId']
|
|
|
|
policy_id = client.create_policy(
|
|
|
|
Content=json.dumps(policy_doc01),
|
|
|
|
Description='A dummy service control policy',
|
|
|
|
Name='MockServiceControlPolicy',
|
|
|
|
Type='SERVICE_CONTROL_POLICY'
|
|
|
|
)['Policy']['PolicySummary']['Id']
|
|
|
|
client.attach_policy(PolicyId=policy_id, TargetId=ou_id)
|
|
|
|
response = client.list_policies_for_target(
|
|
|
|
TargetId=ou_id,
|
|
|
|
Filter='SERVICE_CONTROL_POLICY',
|
|
|
|
)
|
|
|
|
for policy in response['Policies']:
|
|
|
|
validate_policy_summary(org, policy)
|
|
|
|
client.attach_policy(PolicyId=policy_id, TargetId=account_id)
|
|
|
|
response = client.list_policies_for_target(
|
|
|
|
TargetId=account_id,
|
|
|
|
Filter='SERVICE_CONTROL_POLICY',
|
|
|
|
)
|
|
|
|
for policy in response['Policies']:
|
|
|
|
validate_policy_summary(org, policy)
|
|
|
|
|
|
|
|
|
|
|
|
@mock_organizations
|
|
|
|
def test_list_policies_for_target_exception():
|
|
|
|
client = boto3.client('organizations', region_name='us-east-1')
|
|
|
|
client.create_organization(FeatureSet='ALL')['Organization']
|
|
|
|
ou_id='ou-gi99-i7r8eh2i2'
|
|
|
|
account_id='126644886543'
|
|
|
|
with assert_raises(ClientError) as e:
|
|
|
|
response = client.list_policies_for_target(
|
|
|
|
TargetId=ou_id,
|
|
|
|
Filter='SERVICE_CONTROL_POLICY',
|
|
|
|
)
|
|
|
|
ex = e.exception
|
|
|
|
ex.operation_name.should.equal('ListPoliciesForTarget')
|
|
|
|
ex.response['Error']['Code'].should.equal('400')
|
|
|
|
ex.response['Error']['Message'].should.contain('OrganizationalUnitNotFoundException')
|
|
|
|
with assert_raises(ClientError) as e:
|
|
|
|
response = client.list_policies_for_target(
|
|
|
|
TargetId=account_id,
|
|
|
|
Filter='SERVICE_CONTROL_POLICY',
|
|
|
|
)
|
|
|
|
ex = e.exception
|
|
|
|
ex.operation_name.should.equal('ListPoliciesForTarget')
|
|
|
|
ex.response['Error']['Code'].should.equal('400')
|
|
|
|
ex.response['Error']['Message'].should.contain('AccountNotFoundException')
|
|
|
|
with assert_raises(ClientError) as e:
|
|
|
|
response = client.list_policies_for_target(
|
|
|
|
TargetId='meaninglessstring',
|
|
|
|
Filter='SERVICE_CONTROL_POLICY',
|
|
|
|
)
|
|
|
|
ex = e.exception
|
|
|
|
ex.operation_name.should.equal('ListPoliciesForTarget')
|
|
|
|
ex.response['Error']['Code'].should.equal('400')
|
|
|
|
ex.response['Error']['Message'].should.contain('InvalidInputException')
|
|
|
|
|
|
|
|
|
|
|
|
@mock_organizations
|
|
|
|
def test_list_targets_for_policy():
|
|
|
|
client = boto3.client('organizations', region_name='us-east-1')
|
|
|
|
org = client.create_organization(FeatureSet='ALL')['Organization']
|
|
|
|
root_id = client.list_roots()['Roots'][0]['Id']
|
|
|
|
ou_id = client.create_organizational_unit(
|
|
|
|
ParentId=root_id,
|
|
|
|
Name='ou01',
|
|
|
|
)['OrganizationalUnit']['Id']
|
|
|
|
account_id = client.create_account(
|
|
|
|
AccountName=mockname,
|
|
|
|
Email=mockemail,
|
|
|
|
)['CreateAccountStatus']['AccountId']
|
|
|
|
policy_id = client.create_policy(
|
|
|
|
Content=json.dumps(policy_doc01),
|
|
|
|
Description='A dummy service control policy',
|
|
|
|
Name='MockServiceControlPolicy',
|
|
|
|
Type='SERVICE_CONTROL_POLICY'
|
|
|
|
)['Policy']['PolicySummary']['Id']
|
|
|
|
client.attach_policy(PolicyId=policy_id, TargetId=root_id)
|
|
|
|
client.attach_policy(PolicyId=policy_id, TargetId=ou_id)
|
|
|
|
client.attach_policy(PolicyId=policy_id, TargetId=account_id)
|
|
|
|
response = client.list_targets_for_policy(PolicyId=policy_id)
|
|
|
|
for target in response['Targets']:
|
|
|
|
target.should.be.a(dict)
|
|
|
|
target.should.have.key('Name').should.be.a(six.string_types)
|
|
|
|
target.should.have.key('Arn').should.be.a(six.string_types)
|
|
|
|
target.should.have.key('TargetId').should.be.a(six.string_types)
|
|
|
|
target.should.have.key('Type').should.be.within(
|
|
|
|
['ROOT', 'ORGANIZATIONAL_UNIT', 'ACCOUNT']
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
@mock_organizations
|
|
|
|
def test_list_targets_for_policy_exception():
|
|
|
|
client = boto3.client('organizations', region_name='us-east-1')
|
|
|
|
client.create_organization(FeatureSet='ALL')['Organization']
|
|
|
|
policy_id = 'p-47fhe9s3'
|
|
|
|
with assert_raises(ClientError) as e:
|
|
|
|
response = client.list_targets_for_policy(PolicyId=policy_id)
|
|
|
|
ex = e.exception
|
|
|
|
ex.operation_name.should.equal('ListTargetsForPolicy')
|
|
|
|
ex.response['Error']['Code'].should.equal('400')
|
|
|
|
ex.response['Error']['Message'].should.contain('PolicyNotFoundException')
|
|
|
|
with assert_raises(ClientError) as e:
|
|
|
|
response = client.list_targets_for_policy(PolicyId='meaninglessstring')
|
|
|
|
ex = e.exception
|
|
|
|
ex.operation_name.should.equal('ListTargetsForPolicy')
|
|
|
|
ex.response['Error']['Code'].should.equal('400')
|
|
|
|
ex.response['Error']['Message'].should.contain('InvalidInputException')
|
|
|
|
|