| 12
 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
 
 | # pip install -r eng/ml_sample_tools.txt before invoking
import argparse
import glob
import os
import re
from azure.storage.blob import BlobServiceClient
from azure.identity import AzurePowerShellCredential, ChainedTokenCredential, AzureCliCredential
UPLOAD_PATTERN = "python/distributions/ml-sample/{build_id}/{filename}"
BLOB_CONTAINER = "$web"
TEST_INSTALL_TEMPLATE = """# <az_ml_sdk_test_install>
{install_command}
# </az_ml_sdk_test_install>"""
DISABLE_PREVIEW_INSTALL_TEMPLATE = """# <az_ml_sdk_install>
# </az_ml_sdk_install>"""
# I am fully aware that regex isn't fully compatible with traditional tagging. That being said, it is not necessary here.
def replace_preview_install(content):
    regex = r"^# \<az_ml_sdk_install\>[\s\S]*\<\/az_ml_sdk_install\>"
    return re.sub(regex, DISABLE_PREVIEW_INSTALL_TEMPLATE, content, flags=re.MULTILINE)
def replace_test_install_command(content, targeted_urls):
    regex = r"^# \<az_ml_sdk_test_install\>[\s\S]*\<\/az_ml_sdk_test_install\>"
    install_commands = ["pip install {}".format(url) for url in targeted_urls]
    install_lines = "\n".join(install_commands)
    return re.sub(regex, TEST_INSTALL_TEMPLATE.format(install_command=install_lines), content, flags=re.MULTILINE)
if __name__ == "__main__":
    parser = argparse.ArgumentParser(
        description="This python script modifies build.sh files for the azure ml samples repository. Inputs are a "
        + "folder containing the azure-ml whl, the root of a cloned azureml-samples repo, and an optional build id. "
    )
    parser.add_argument(
        "--ml-repo",
        dest="ml_root",
        help=("The root of a fresh clone of the ml samples repo."),
    )
    parser.add_argument(
        "--ml-wheel-folder",
        dest="wheel_folder",
        help=("The folder from where the the azure ml wheel will reside."),
    )
    parser.add_argument(
        "--build-id",
        dest="build_id",
        default="a-manual-run",
        help=("The folder from where the the azure ml wheel will reside."),
    )
    parser.add_argument(
        "--storage-account-name",
        dest="storage_account_name",
        help=("The name of the storage account"),
    )
    args = parser.parse_args()
    print("Input repo {}".format(args.ml_root))
    print("Folder for search {}".format(args.wheel_folder))
    target_glob = os.path.join(os.path.abspath(args.wheel_folder), "*.whl")
    sdk_setup_sh = os.path.join(os.path.abspath(args.ml_root), "sdk", "python", "setup.sh")
    credential_chain = ChainedTokenCredential(AzureCliCredential(), AzurePowerShellCredential())
    blob_service_client = BlobServiceClient(account_url=f"https://{args.storage_account_name}.blob.core.windows.net", credential=credential_chain)
    container_client = blob_service_client.get_container_client(BLOB_CONTAINER)
    to_be_installed = []
    whls = glob.glob(target_glob)
    for whl in whls:
        if os.path.isfile(whl):
            upload_path = UPLOAD_PATTERN.format(build_id=args.build_id, filename=os.path.basename(whl))
            blob_client = container_client.get_blob_client(blob=upload_path)
            with open(whl, "rb") as data:
                result = blob_client.upload_blob(data=data, overwrite=True)
                url = blob_client.primary_endpoint
                # replace the original blob uri with the static website style uri
                # this is such that the install command can be invoked directly without needing to authenticate to the storage account
                url = url.replace(f"https://{args.storage_account_name}.blob.core.windows.net/%24web/", f"https://{args.storage_account_name}.z5.web.core.windows.net/")
                to_be_installed.append(url)
        else:
            print("Operated on non-whl file or folder {}".format(whl))
            exit(1)
    with open(sdk_setup_sh, "r", encoding="utf-8") as f:
        original_content = f.read()
    content = replace_preview_install(original_content)
    content = replace_test_install_command(content, to_be_installed)
    if content != original_content:
        with open(sdk_setup_sh, "w", encoding="utf-8") as f:
            f.write(content)
 |