Skip to content
This repository has been archived by the owner on Feb 3, 2021. It is now read-only.

Commit

Permalink
Internal: verify code formatting in build (#633)
Browse files Browse the repository at this point in the history
* format all files, enforce formatting in travis build

* add yapf to vsts build

* update vsts build

* fix

* fix

* fix

* change queue to ubuntu

* revert

* temporarily enable builds on pushes to this branch

* change to non preview

* revert

* update yapf version, rerun

* update pytest parallelism

* add retry to arm call to avoid failures

* remove non-master trigger

* update builds, formatting style
  • Loading branch information
jafreck authored Aug 6, 2018
1 parent b18eb69 commit 7730c46
Show file tree
Hide file tree
Showing 127 changed files with 1,052 additions and 1,226 deletions.
3 changes: 2 additions & 1 deletion .style.yapf
Original file line number Diff line number Diff line change
@@ -1,7 +1,8 @@
[style]
based_on_style=pep8
based_on_style=google
spaces_before_comment=4
split_before_logical_operator=True
indent_width=4
column_limit=120
split_arguments_when_comma_terminated=True
blank_line_before_nested_class_or_def=False
1 change: 1 addition & 0 deletions .travis.yml
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,7 @@ install:
- pip install -e .

script:
- yapf -dpr aztk/ aztk_cli/
- pylint -E aztk
- pytest --ignore=tests/integration_tests

Expand Down
6 changes: 5 additions & 1 deletion .vscode/settings.json
Original file line number Diff line number Diff line change
Expand Up @@ -15,4 +15,8 @@
"python.venvPath": "${workspaceFolder}/.venv/",
"python.pythonPath": "${workspaceFolder}/.venv/Scripts/python.exe",
"python.unitTest.pyTestEnabled": true,
}
"editor.formatOnSave": true,
"editor.codeActionsOnSave": {
"source.organizeImports": true
}
}
39 changes: 24 additions & 15 deletions .vsts-ci.yml
Original file line number Diff line number Diff line change
@@ -1,20 +1,29 @@
trigger:
- master

steps:
- task: UsePythonVersion@0
inputs:
versionSpec: '>= 3.5'
addToPath: true
architecture: 'x64'

- script: |
pip install -r requirements.txt
pip install -e .
condition: and(succeeded(), eq(variables['agent.os'], 'linux'))
displayName: install aztk
phases:
- phase: Test
queue: Hosted Linux Preview
steps:
- task: UsePythonVersion@0
inputs:
versionSpec: '>= 3.5'
addToPath: true
architecture: 'x64'

- script: |
pytest -n 50
condition: and(succeeded(), in(variables['agent.os'], 'linux'))
displayName: pytest
- script: |
pip install -r requirements.txt
pip install -e .
condition: succeeded()
displayName: install aztk
- script: |
yapf -dpr aztk/ aztk_cli/
condition: succeeded()
displayName: yapf
- script: |
pytest -n 102
condition: succeeded()
displayName: pytest
127 changes: 49 additions & 78 deletions account_setup.py
Original file line number Diff line number Diff line change
Expand Up @@ -56,12 +56,11 @@ def create_resource_group(credentials, subscription_id, **kwargs):
resource_group_name=kwargs.get("resource_group", DefaultSettings.resource_group),
parameters={
'location': kwargs.get("region", DefaultSettings.region),
}
)
})
except CloudError as e:
if i == 2:
raise AccountSetupError(
"Unable to create resource group in region {}".format(kwargs.get("region", DefaultSettings.region)))
raise AccountSetupError("Unable to create resource group in region {}".format(
kwargs.get("region", DefaultSettings.region)))
print(e.message)
print("Please try again.")
kwargs["resource_group"] = prompt_with_default("Azure Region", DefaultSettings.region)
Expand All @@ -82,15 +81,10 @@ def create_storage_account(credentials, subscription_id, **kwargs):
resource_group_name=kwargs.get("resource_group", DefaultSettings.resource_group),
account_name=kwargs.get("storage_account", DefaultSettings.storage_account),
parameters=StorageAccountCreateParameters(
sku=Sku(SkuName.standard_lrs),
kind=Kind.storage,
location=kwargs.get('region', DefaultSettings.region)
)
)
sku=Sku(SkuName.standard_lrs), kind=Kind.storage, location=kwargs.get('region', DefaultSettings.region)))
return storage_account.result().id



def create_batch_account(credentials, subscription_id, **kwargs):
"""
Create a Batch account
Expand All @@ -108,10 +102,7 @@ def create_batch_account(credentials, subscription_id, **kwargs):
parameters=BatchAccountCreateParameters(
location=kwargs.get('region', DefaultSettings.region),
auto_storage=AutoStorageBaseProperties(
storage_account_id=kwargs.get('storage_account_id', DefaultSettings.region)
)
)
)
storage_account_id=kwargs.get('storage_account_id', DefaultSettings.region))))
return batch_account.result().id


Expand Down Expand Up @@ -151,19 +142,13 @@ def create_vnet(credentials, subscription_id, **kwargs):
resource_group_name=resource_group_name,
virtual_network_name=kwargs.get("virtual_network_name", DefaultSettings.virtual_network_name),
parameters=VirtualNetwork(
location=kwargs.get("region", DefaultSettings.region),
address_space=AddressSpace(["10.0.0.0/24"])
)
)
location=kwargs.get("region", DefaultSettings.region), address_space=AddressSpace(["10.0.0.0/24"])))
virtual_network = virtual_network.result()
subnet = network_client.subnets.create_or_update(
resource_group_name=resource_group_name,
virtual_network_name=virtual_network_name,
subnet_name=subnet_name,
subnet_parameters=Subnet(
address_prefix='10.0.0.0/24'
)
)
subnet_parameters=Subnet(address_prefix='10.0.0.0/24'))
return subnet.result().id


Expand All @@ -175,10 +160,7 @@ def create_aad_user(credentials, tenant_id, **kwargs):
:param **application_name: str
"""
graph_rbac_client = GraphRbacManagementClient(
credentials,
tenant_id,
base_url=AZURE_PUBLIC_CLOUD.endpoints.active_directory_graph_resource_id
)
credentials, tenant_id, base_url=AZURE_PUBLIC_CLOUD.endpoints.active_directory_graph_resource_id)
application_credential = uuid.uuid4()
try:
display_name = kwargs.get("application_name", DefaultSettings.application_name)
Expand All @@ -192,42 +174,32 @@ def create_aad_user(credentials, tenant_id, **kwargs):
start_date=datetime(2000, 1, 1, 0, 0, 0, 0, tzinfo=timezone.utc),
end_date=datetime(2299, 12, 31, 0, 0, 0, 0, tzinfo=timezone.utc),
value=application_credential,
key_id=uuid.uuid4()
)
]
)
)
key_id=uuid.uuid4())
]))
service_principal = graph_rbac_client.service_principals.create(
ServicePrincipalCreateParameters(
app_id=application.app_id,
account_enabled=True
)
)
ServicePrincipalCreateParameters(app_id=application.app_id, account_enabled=True))
except GraphErrorException as e:
if e.inner_exception.code == "Request_BadRequest":
application = next(graph_rbac_client.applications.list(
filter="identifierUris/any(c:c eq 'http://{}.com')".format(display_name)))
application = next(
graph_rbac_client.applications.list(
filter="identifierUris/any(c:c eq 'http://{}.com')".format(display_name)))

confirmation_prompt = "Previously created application with name {} found. "\
"Would you like to use it? (y/n): ".format(application.display_name)
prompt_for_confirmation(confirmation_prompt, e, ValueError("Response not recognized. Please try again."))
password_credentials = list(graph_rbac_client.applications.list_password_credentials(application_object_id=application.object_id))
password_credentials = list(
graph_rbac_client.applications.list_password_credentials(application_object_id=application.object_id))
password_credentials.append(
PasswordCredential(
start_date=datetime(2000, 1, 1, 0, 0, 0, 0, tzinfo=timezone.utc),
end_date=datetime(2299, 12, 31, 0, 0, 0, 0, tzinfo=timezone.utc),
value=application_credential,
key_id=uuid.uuid4()
)
)
key_id=uuid.uuid4()))
graph_rbac_client.applications.patch(
application_object_id=application.object_id,
parameters=ApplicationUpdateParameters(
password_credentials=password_credentials
)
)
service_principal = next(graph_rbac_client.service_principals.list(
filter="appId eq '{}'".format(application.app_id)))
parameters=ApplicationUpdateParameters(password_credentials=password_credentials))
service_principal = next(
graph_rbac_client.service_principals.list(filter="appId eq '{}'".format(application.app_id)))
else:
raise e

Expand All @@ -244,21 +216,15 @@ def create_role_assignment(credentials, subscription_id, scope, principal_id):
"""
authorization_client = AuthorizationManagementClient(credentials, subscription_id)
role_name = 'Contributor'
roles = list(authorization_client.role_definitions.list(
scope,
filter="roleName eq '{}'".format(role_name)
))
roles = list(authorization_client.role_definitions.list(scope, filter="roleName eq '{}'".format(role_name)))
contributor_role = roles[0]
for i in range(10):
try:
authorization_client.role_assignments.create(
scope,
uuid.uuid4(),
{
'role_definition_id': contributor_role.id,
'principal_id': principal_id
}
)
authorization_client.role_assignments.create(scope, uuid.uuid4(),
{
'role_definition_id': contributor_role.id,
'principal_id': principal_id
})
break
except CloudError as e:
# ignore error if service principal has not yet been created
Expand Down Expand Up @@ -321,15 +287,15 @@ def prompt_tenant_selection(tenant_ids):
raise AccountSetupError("Tenant selection not recognized after 3 attempts.")



class Spinner:
busy = False
delay = 0.1

@staticmethod
def spinning_cursor():
while 1:
for cursor in '|/-\\': yield cursor
for cursor in '|/-\\':
yield cursor

def __init__(self, delay=None):
self.spinner_generator = self.spinning_cursor()
Expand Down Expand Up @@ -358,7 +324,6 @@ def stop(self):
time.sleep(self.delay)



if __name__ == "__main__":
print("\nGetting credentials.")
# get credentials and tenant_id
Expand All @@ -374,15 +339,22 @@ def stop(self):
"Default values are provided in the brackets. "\
"Hit enter to use default.")
kwargs = {
"region": prompt_with_default("Azure Region", DefaultSettings.region),
"resource_group": prompt_with_default("Resource Group Name", DefaultSettings.resource_group),
"storage_account": prompt_with_default("Storage Account Name", DefaultSettings.storage_account),
"batch_account": prompt_with_default("Batch Account Name", DefaultSettings.batch_account),
# "virtual_network_name": prompt_with_default("Virtual Network Name", DefaultSettings.virtual_network_name),
# "subnet_name": prompt_with_default("Subnet Name", DefaultSettings.subnet_name),
"application_name": prompt_with_default("Active Directory Application Name", DefaultSettings.application_name),
"application_credential_name": prompt_with_default("Active Directory Application Credential Name", DefaultSettings.resource_group),
"service_principal": prompt_with_default("Service Principal Name", DefaultSettings.service_principal)
"region":
prompt_with_default("Azure Region", DefaultSettings.region),
"resource_group":
prompt_with_default("Resource Group Name", DefaultSettings.resource_group),
"storage_account":
prompt_with_default("Storage Account Name", DefaultSettings.storage_account),
"batch_account":
prompt_with_default("Batch Account Name", DefaultSettings.batch_account),
# "virtual_network_name": prompt_with_default("Virtual Network Name", DefaultSettings.virtual_network_name),
# "subnet_name": prompt_with_default("Subnet Name", DefaultSettings.subnet_name),
"application_name":
prompt_with_default("Active Directory Application Name", DefaultSettings.application_name),
"application_credential_name":
prompt_with_default("Active Directory Application Credential Name", DefaultSettings.resource_group),
"service_principal":
prompt_with_default("Service Principal Name", DefaultSettings.service_principal)
}
print("Creating the Azure resources.")

Expand Down Expand Up @@ -410,9 +382,9 @@ def stop(self):
with Spinner():
profile = credentials.get_cli_profile()
aad_cred, subscription_id, tenant_id = profile.get_login_credentials(
resource=AZURE_PUBLIC_CLOUD.endpoints.active_directory_graph_resource_id
)
application_id, service_principal_object_id, application_credential = create_aad_user(aad_cred, tenant_id, **kwargs)
resource=AZURE_PUBLIC_CLOUD.endpoints.active_directory_graph_resource_id)
application_id, service_principal_object_id, application_credential = create_aad_user(
aad_cred, tenant_id, **kwargs)

print("Created Azure Active Directory service principal.")

Expand All @@ -425,10 +397,9 @@ def stop(self):
"tenant_id": tenant_id,
"client_id": application_id,
"credential": application_credential,
# "subnet_id": subnet_id,
# "subnet_id": subnet_id,
"batch_account_resource_id": batch_account_id,
"storage_account_resource_id": storage_account_id
}
)
})

print("\n# Copy the following into your .aztk/secrets.yaml file\n{}".format(secrets))
3 changes: 1 addition & 2 deletions aztk/client/base/helpers/create_user_on_node.py
Original file line number Diff line number Diff line change
Expand Up @@ -32,8 +32,7 @@ def __create_user(self, id: str, node_id: str, username: str, password: str = No

def create_user_on_node(base_client, id, node_id, username, ssh_key=None, password=None):
try:
__create_user(
base_client, id=id, node_id=node_id, username=username, ssh_key=ssh_key, password=password)
__create_user(base_client, id=id, node_id=node_id, username=username, ssh_key=ssh_key, password=password)
except batch_error.BatchErrorException as error:
try:
base_client.delete_user_on_node(id, node_id, username)
Expand Down
1 change: 1 addition & 0 deletions aztk/client/base/helpers/delete_user_on_cluster.py
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
import concurrent.futures


#TODO: remove nodes param
def delete_user_on_cluster(base_client, id, nodes, username):
with concurrent.futures.ThreadPoolExecutor() as executor:
Expand Down
10 changes: 3 additions & 7 deletions aztk/client/base/helpers/get_application_log.py
Original file line number Diff line number Diff line change
Expand Up @@ -102,13 +102,9 @@ def get_log(batch_client, blob_client, cluster_id: str, application_name: str, t
exit_code=task.execution_info.exit_code)


def get_application_log(base_operations,
cluster_id: str,
application_name: str,
tail=False,
current_bytes: int = 0):
def get_application_log(base_operations, cluster_id: str, application_name: str, tail=False, current_bytes: int = 0):
try:
return get_log(base_operations.batch_client, base_operations.blob_client, cluster_id,
application_name, tail, current_bytes)
return get_log(base_operations.batch_client, base_operations.blob_client, cluster_id, application_name, tail,
current_bytes)
except batch_error.BatchErrorException as e:
raise error.AztkError(helpers.format_batch_exception(e))
9 changes: 8 additions & 1 deletion aztk/client/base/helpers/ssh_into_node.py
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,14 @@
from aztk.utils import ssh as ssh_lib


def ssh_into_node(base_client, pool_id, node_id, username, ssh_key=None, password=None, port_forward_list=None, internal=False):
def ssh_into_node(base_client,
pool_id,
node_id,
username,
ssh_key=None,
password=None,
port_forward_list=None,
internal=False):
if internal:
result = base_client.batch_client.compute_node.get(pool_id=pool_id, node_id=node_id)
rls = models.RemoteLogin(ip_address=result.ip_address, port="22")
Expand Down
Loading

0 comments on commit 7730c46

Please sign in to comment.