Sagemaker models (#3105)
* First failing test, and enough framework to run it.
* Rudimentary passing test.
* Sagemaker Notebook Support, take-1: create, describe, start, stop, delete.
* Added list_tags.
* Merged in model support from https://github.com/porthunt/moto/tree/sagemaker-support.
* Re-org'd
* Fixed up describe_model exception when no matching model.
* Segregated tests by Sagemaker entity. Model arn check by regex..
* Python2 compabitility changes.
* Added sagemaker to list of known backends. Corrected urls.
* Added sagemaker special case to moto.server.infer_service_region_host due to irregular url format (use of 'api' subdomain) to support server mode.
* Changes for PR 3105 comments of July 10, 2020
* PR3105 July 10, 2020, 8:55 AM EDT comment: dropped unnecessary re-addition of arn when formulating model list response.
* PR 3105 July 15, 2020 9:10 AM EDT Comment: clean-up SageMakerModelBackend.describe_models logic for finding the model in the dict.
* Optimized imports
Co-authored-by: Joseph Weitekamp <jweite@amazon.com>
2020-07-16 12:12:25 +00:00
|
|
|
# -*- coding: utf-8 -*-
|
|
|
|
from __future__ import unicode_literals
|
|
|
|
|
|
|
|
import datetime
|
|
|
|
import boto3
|
|
|
|
from botocore.exceptions import ClientError, ParamValidationError
|
|
|
|
import sure # noqa
|
|
|
|
|
|
|
|
from moto import mock_sagemaker
|
|
|
|
from moto.sts.models import ACCOUNT_ID
|
2020-10-06 05:54:49 +00:00
|
|
|
import pytest
|
Sagemaker models (#3105)
* First failing test, and enough framework to run it.
* Rudimentary passing test.
* Sagemaker Notebook Support, take-1: create, describe, start, stop, delete.
* Added list_tags.
* Merged in model support from https://github.com/porthunt/moto/tree/sagemaker-support.
* Re-org'd
* Fixed up describe_model exception when no matching model.
* Segregated tests by Sagemaker entity. Model arn check by regex..
* Python2 compabitility changes.
* Added sagemaker to list of known backends. Corrected urls.
* Added sagemaker special case to moto.server.infer_service_region_host due to irregular url format (use of 'api' subdomain) to support server mode.
* Changes for PR 3105 comments of July 10, 2020
* PR3105 July 10, 2020, 8:55 AM EDT comment: dropped unnecessary re-addition of arn when formulating model list response.
* PR 3105 July 15, 2020 9:10 AM EDT Comment: clean-up SageMakerModelBackend.describe_models logic for finding the model in the dict.
* Optimized imports
Co-authored-by: Joseph Weitekamp <jweite@amazon.com>
2020-07-16 12:12:25 +00:00
|
|
|
|
|
|
|
TEST_REGION_NAME = "us-east-1"
|
|
|
|
FAKE_SUBNET_ID = "subnet-012345678"
|
|
|
|
FAKE_SECURITY_GROUP_IDS = ["sg-0123456789abcdef0", "sg-0123456789abcdef1"]
|
|
|
|
FAKE_ROLE_ARN = "arn:aws:iam::{}:role/FakeRole".format(ACCOUNT_ID)
|
|
|
|
FAKE_KMS_KEY_ID = "62d4509a-9f96-446c-a9ba-6b1c353c8c58"
|
|
|
|
GENERIC_TAGS_PARAM = [
|
|
|
|
{"Key": "newkey1", "Value": "newval1"},
|
|
|
|
{"Key": "newkey2", "Value": "newval2"},
|
|
|
|
]
|
|
|
|
FAKE_LIFECYCLE_CONFIG_NAME = "FakeLifecycleConfigName"
|
|
|
|
FAKE_DEFAULT_CODE_REPO = "https://github.com/user/repo1"
|
|
|
|
FAKE_ADDL_CODE_REPOS = [
|
|
|
|
"https://github.com/user/repo2",
|
|
|
|
"https://github.com/user/repo2",
|
|
|
|
]
|
|
|
|
|
|
|
|
|
|
|
|
@mock_sagemaker
|
|
|
|
def test_create_notebook_instance_minimal_params():
|
|
|
|
|
|
|
|
sagemaker = boto3.client("sagemaker", region_name=TEST_REGION_NAME)
|
|
|
|
|
|
|
|
NAME_PARAM = "MyNotebookInstance"
|
|
|
|
INSTANCE_TYPE_PARAM = "ml.t2.medium"
|
|
|
|
|
|
|
|
args = {
|
|
|
|
"NotebookInstanceName": NAME_PARAM,
|
|
|
|
"InstanceType": INSTANCE_TYPE_PARAM,
|
|
|
|
"RoleArn": FAKE_ROLE_ARN,
|
|
|
|
}
|
|
|
|
resp = sagemaker.create_notebook_instance(**args)
|
2020-10-06 05:54:49 +00:00
|
|
|
assert resp["NotebookInstanceArn"].startswith("arn:aws:sagemaker")
|
|
|
|
assert resp["NotebookInstanceArn"].endswith(args["NotebookInstanceName"])
|
Sagemaker models (#3105)
* First failing test, and enough framework to run it.
* Rudimentary passing test.
* Sagemaker Notebook Support, take-1: create, describe, start, stop, delete.
* Added list_tags.
* Merged in model support from https://github.com/porthunt/moto/tree/sagemaker-support.
* Re-org'd
* Fixed up describe_model exception when no matching model.
* Segregated tests by Sagemaker entity. Model arn check by regex..
* Python2 compabitility changes.
* Added sagemaker to list of known backends. Corrected urls.
* Added sagemaker special case to moto.server.infer_service_region_host due to irregular url format (use of 'api' subdomain) to support server mode.
* Changes for PR 3105 comments of July 10, 2020
* PR3105 July 10, 2020, 8:55 AM EDT comment: dropped unnecessary re-addition of arn when formulating model list response.
* PR 3105 July 15, 2020 9:10 AM EDT Comment: clean-up SageMakerModelBackend.describe_models logic for finding the model in the dict.
* Optimized imports
Co-authored-by: Joseph Weitekamp <jweite@amazon.com>
2020-07-16 12:12:25 +00:00
|
|
|
|
|
|
|
resp = sagemaker.describe_notebook_instance(NotebookInstanceName=NAME_PARAM)
|
2020-10-06 05:54:49 +00:00
|
|
|
assert resp["NotebookInstanceArn"].startswith("arn:aws:sagemaker")
|
|
|
|
assert resp["NotebookInstanceArn"].endswith(args["NotebookInstanceName"])
|
|
|
|
assert resp["NotebookInstanceName"] == NAME_PARAM
|
|
|
|
assert resp["NotebookInstanceStatus"] == "InService"
|
|
|
|
assert resp["Url"] == \
|
|
|
|
"{}.notebook.{}.sagemaker.aws".format(NAME_PARAM, TEST_REGION_NAME)
|
|
|
|
assert resp["InstanceType"] == INSTANCE_TYPE_PARAM
|
|
|
|
assert resp["RoleArn"] == FAKE_ROLE_ARN
|
|
|
|
assert isinstance(resp["LastModifiedTime"], datetime.datetime)
|
|
|
|
assert isinstance(resp["CreationTime"], datetime.datetime)
|
|
|
|
assert resp["DirectInternetAccess"] == "Enabled"
|
|
|
|
assert resp["VolumeSizeInGB"] == 5
|
Sagemaker models (#3105)
* First failing test, and enough framework to run it.
* Rudimentary passing test.
* Sagemaker Notebook Support, take-1: create, describe, start, stop, delete.
* Added list_tags.
* Merged in model support from https://github.com/porthunt/moto/tree/sagemaker-support.
* Re-org'd
* Fixed up describe_model exception when no matching model.
* Segregated tests by Sagemaker entity. Model arn check by regex..
* Python2 compabitility changes.
* Added sagemaker to list of known backends. Corrected urls.
* Added sagemaker special case to moto.server.infer_service_region_host due to irregular url format (use of 'api' subdomain) to support server mode.
* Changes for PR 3105 comments of July 10, 2020
* PR3105 July 10, 2020, 8:55 AM EDT comment: dropped unnecessary re-addition of arn when formulating model list response.
* PR 3105 July 15, 2020 9:10 AM EDT Comment: clean-up SageMakerModelBackend.describe_models logic for finding the model in the dict.
* Optimized imports
Co-authored-by: Joseph Weitekamp <jweite@amazon.com>
2020-07-16 12:12:25 +00:00
|
|
|
|
|
|
|
|
2020-10-06 05:54:49 +00:00
|
|
|
# assert resp["RootAccess"] == True # ToDo: Not sure if this defaults...
|
Sagemaker models (#3105)
* First failing test, and enough framework to run it.
* Rudimentary passing test.
* Sagemaker Notebook Support, take-1: create, describe, start, stop, delete.
* Added list_tags.
* Merged in model support from https://github.com/porthunt/moto/tree/sagemaker-support.
* Re-org'd
* Fixed up describe_model exception when no matching model.
* Segregated tests by Sagemaker entity. Model arn check by regex..
* Python2 compabitility changes.
* Added sagemaker to list of known backends. Corrected urls.
* Added sagemaker special case to moto.server.infer_service_region_host due to irregular url format (use of 'api' subdomain) to support server mode.
* Changes for PR 3105 comments of July 10, 2020
* PR3105 July 10, 2020, 8:55 AM EDT comment: dropped unnecessary re-addition of arn when formulating model list response.
* PR 3105 July 15, 2020 9:10 AM EDT Comment: clean-up SageMakerModelBackend.describe_models logic for finding the model in the dict.
* Optimized imports
Co-authored-by: Joseph Weitekamp <jweite@amazon.com>
2020-07-16 12:12:25 +00:00
|
|
|
|
|
|
|
|
|
|
|
@mock_sagemaker
|
|
|
|
def test_create_notebook_instance_params():
|
|
|
|
|
|
|
|
sagemaker = boto3.client("sagemaker", region_name="us-east-1")
|
|
|
|
|
|
|
|
NAME_PARAM = "MyNotebookInstance"
|
|
|
|
INSTANCE_TYPE_PARAM = "ml.t2.medium"
|
|
|
|
DIRECT_INTERNET_ACCESS_PARAM = "Enabled"
|
|
|
|
VOLUME_SIZE_IN_GB_PARAM = 7
|
|
|
|
ACCELERATOR_TYPES_PARAM = ["ml.eia1.medium", "ml.eia2.medium"]
|
|
|
|
ROOT_ACCESS_PARAM = "Disabled"
|
|
|
|
|
|
|
|
args = {
|
|
|
|
"NotebookInstanceName": NAME_PARAM,
|
|
|
|
"InstanceType": INSTANCE_TYPE_PARAM,
|
|
|
|
"SubnetId": FAKE_SUBNET_ID,
|
|
|
|
"SecurityGroupIds": FAKE_SECURITY_GROUP_IDS,
|
|
|
|
"RoleArn": FAKE_ROLE_ARN,
|
|
|
|
"KmsKeyId": FAKE_KMS_KEY_ID,
|
|
|
|
"Tags": GENERIC_TAGS_PARAM,
|
|
|
|
"LifecycleConfigName": FAKE_LIFECYCLE_CONFIG_NAME,
|
|
|
|
"DirectInternetAccess": DIRECT_INTERNET_ACCESS_PARAM,
|
|
|
|
"VolumeSizeInGB": VOLUME_SIZE_IN_GB_PARAM,
|
|
|
|
"AcceleratorTypes": ACCELERATOR_TYPES_PARAM,
|
|
|
|
"DefaultCodeRepository": FAKE_DEFAULT_CODE_REPO,
|
|
|
|
"AdditionalCodeRepositories": FAKE_ADDL_CODE_REPOS,
|
|
|
|
"RootAccess": ROOT_ACCESS_PARAM,
|
|
|
|
}
|
|
|
|
resp = sagemaker.create_notebook_instance(**args)
|
2020-10-06 05:54:49 +00:00
|
|
|
assert resp["NotebookInstanceArn"].startswith("arn:aws:sagemaker")
|
|
|
|
assert resp["NotebookInstanceArn"].endswith(args["NotebookInstanceName"])
|
Sagemaker models (#3105)
* First failing test, and enough framework to run it.
* Rudimentary passing test.
* Sagemaker Notebook Support, take-1: create, describe, start, stop, delete.
* Added list_tags.
* Merged in model support from https://github.com/porthunt/moto/tree/sagemaker-support.
* Re-org'd
* Fixed up describe_model exception when no matching model.
* Segregated tests by Sagemaker entity. Model arn check by regex..
* Python2 compabitility changes.
* Added sagemaker to list of known backends. Corrected urls.
* Added sagemaker special case to moto.server.infer_service_region_host due to irregular url format (use of 'api' subdomain) to support server mode.
* Changes for PR 3105 comments of July 10, 2020
* PR3105 July 10, 2020, 8:55 AM EDT comment: dropped unnecessary re-addition of arn when formulating model list response.
* PR 3105 July 15, 2020 9:10 AM EDT Comment: clean-up SageMakerModelBackend.describe_models logic for finding the model in the dict.
* Optimized imports
Co-authored-by: Joseph Weitekamp <jweite@amazon.com>
2020-07-16 12:12:25 +00:00
|
|
|
|
|
|
|
resp = sagemaker.describe_notebook_instance(NotebookInstanceName=NAME_PARAM)
|
2020-10-06 05:54:49 +00:00
|
|
|
assert resp["NotebookInstanceArn"].startswith("arn:aws:sagemaker")
|
|
|
|
assert resp["NotebookInstanceArn"].endswith(args["NotebookInstanceName"])
|
|
|
|
assert resp["NotebookInstanceName"] == NAME_PARAM
|
|
|
|
assert resp["NotebookInstanceStatus"] == "InService"
|
|
|
|
assert resp["Url"] == \
|
|
|
|
"{}.notebook.{}.sagemaker.aws".format(NAME_PARAM, TEST_REGION_NAME)
|
|
|
|
assert resp["InstanceType"] == INSTANCE_TYPE_PARAM
|
|
|
|
assert resp["RoleArn"] == FAKE_ROLE_ARN
|
|
|
|
assert isinstance(resp["LastModifiedTime"], datetime.datetime)
|
|
|
|
assert isinstance(resp["CreationTime"], datetime.datetime)
|
|
|
|
assert resp["DirectInternetAccess"] == "Enabled"
|
|
|
|
assert resp["VolumeSizeInGB"] == VOLUME_SIZE_IN_GB_PARAM
|
|
|
|
# assert resp["RootAccess"] == True # ToDo: Not sure if this defaults...
|
|
|
|
assert resp["SubnetId"] == FAKE_SUBNET_ID
|
|
|
|
assert resp["SecurityGroups"] == FAKE_SECURITY_GROUP_IDS
|
|
|
|
assert resp["KmsKeyId"] == FAKE_KMS_KEY_ID
|
|
|
|
assert resp["NotebookInstanceLifecycleConfigName"] == \
|
|
|
|
FAKE_LIFECYCLE_CONFIG_NAME
|
|
|
|
assert resp["AcceleratorTypes"] == ACCELERATOR_TYPES_PARAM
|
|
|
|
assert resp["DefaultCodeRepository"] == FAKE_DEFAULT_CODE_REPO
|
|
|
|
assert resp["AdditionalCodeRepositories"] == FAKE_ADDL_CODE_REPOS
|
Sagemaker models (#3105)
* First failing test, and enough framework to run it.
* Rudimentary passing test.
* Sagemaker Notebook Support, take-1: create, describe, start, stop, delete.
* Added list_tags.
* Merged in model support from https://github.com/porthunt/moto/tree/sagemaker-support.
* Re-org'd
* Fixed up describe_model exception when no matching model.
* Segregated tests by Sagemaker entity. Model arn check by regex..
* Python2 compabitility changes.
* Added sagemaker to list of known backends. Corrected urls.
* Added sagemaker special case to moto.server.infer_service_region_host due to irregular url format (use of 'api' subdomain) to support server mode.
* Changes for PR 3105 comments of July 10, 2020
* PR3105 July 10, 2020, 8:55 AM EDT comment: dropped unnecessary re-addition of arn when formulating model list response.
* PR 3105 July 15, 2020 9:10 AM EDT Comment: clean-up SageMakerModelBackend.describe_models logic for finding the model in the dict.
* Optimized imports
Co-authored-by: Joseph Weitekamp <jweite@amazon.com>
2020-07-16 12:12:25 +00:00
|
|
|
|
|
|
|
resp = sagemaker.list_tags(ResourceArn=resp["NotebookInstanceArn"])
|
2020-10-06 05:54:49 +00:00
|
|
|
assert resp["Tags"] == GENERIC_TAGS_PARAM
|
Sagemaker models (#3105)
* First failing test, and enough framework to run it.
* Rudimentary passing test.
* Sagemaker Notebook Support, take-1: create, describe, start, stop, delete.
* Added list_tags.
* Merged in model support from https://github.com/porthunt/moto/tree/sagemaker-support.
* Re-org'd
* Fixed up describe_model exception when no matching model.
* Segregated tests by Sagemaker entity. Model arn check by regex..
* Python2 compabitility changes.
* Added sagemaker to list of known backends. Corrected urls.
* Added sagemaker special case to moto.server.infer_service_region_host due to irregular url format (use of 'api' subdomain) to support server mode.
* Changes for PR 3105 comments of July 10, 2020
* PR3105 July 10, 2020, 8:55 AM EDT comment: dropped unnecessary re-addition of arn when formulating model list response.
* PR 3105 July 15, 2020 9:10 AM EDT Comment: clean-up SageMakerModelBackend.describe_models logic for finding the model in the dict.
* Optimized imports
Co-authored-by: Joseph Weitekamp <jweite@amazon.com>
2020-07-16 12:12:25 +00:00
|
|
|
|
|
|
|
|
|
|
|
@mock_sagemaker
|
|
|
|
def test_create_notebook_instance_bad_volume_size():
|
|
|
|
|
|
|
|
sagemaker = boto3.client("sagemaker", region_name="us-east-1")
|
|
|
|
|
|
|
|
vol_size = 2
|
|
|
|
args = {
|
|
|
|
"NotebookInstanceName": "MyNotebookInstance",
|
|
|
|
"InstanceType": "ml.t2.medium",
|
|
|
|
"RoleArn": FAKE_ROLE_ARN,
|
|
|
|
"VolumeSizeInGB": vol_size,
|
|
|
|
}
|
2020-10-06 05:54:49 +00:00
|
|
|
with pytest.raises(ParamValidationError) as ex:
|
|
|
|
sagemaker.create_notebook_instance(**args)
|
|
|
|
assert \
|
2020-10-06 06:04:09 +00:00
|
|
|
ex.value.args[0] == \
|
2020-10-06 05:54:49 +00:00
|
|
|
"Parameter validation failed:\nInvalid range for parameter VolumeSizeInGB, value: {}, valid range: 5-inf".format(vol_size)
|
Sagemaker models (#3105)
* First failing test, and enough framework to run it.
* Rudimentary passing test.
* Sagemaker Notebook Support, take-1: create, describe, start, stop, delete.
* Added list_tags.
* Merged in model support from https://github.com/porthunt/moto/tree/sagemaker-support.
* Re-org'd
* Fixed up describe_model exception when no matching model.
* Segregated tests by Sagemaker entity. Model arn check by regex..
* Python2 compabitility changes.
* Added sagemaker to list of known backends. Corrected urls.
* Added sagemaker special case to moto.server.infer_service_region_host due to irregular url format (use of 'api' subdomain) to support server mode.
* Changes for PR 3105 comments of July 10, 2020
* PR3105 July 10, 2020, 8:55 AM EDT comment: dropped unnecessary re-addition of arn when formulating model list response.
* PR 3105 July 15, 2020 9:10 AM EDT Comment: clean-up SageMakerModelBackend.describe_models logic for finding the model in the dict.
* Optimized imports
Co-authored-by: Joseph Weitekamp <jweite@amazon.com>
2020-07-16 12:12:25 +00:00
|
|
|
|
|
|
|
|
|
|
|
@mock_sagemaker
|
|
|
|
def test_create_notebook_instance_invalid_instance_type():
|
|
|
|
|
|
|
|
sagemaker = boto3.client("sagemaker", region_name="us-east-1")
|
|
|
|
|
|
|
|
instance_type = "undefined_instance_type"
|
|
|
|
args = {
|
|
|
|
"NotebookInstanceName": "MyNotebookInstance",
|
|
|
|
"InstanceType": instance_type,
|
|
|
|
"RoleArn": FAKE_ROLE_ARN,
|
|
|
|
}
|
2020-10-06 05:54:49 +00:00
|
|
|
with pytest.raises(ClientError) as ex:
|
|
|
|
sagemaker.create_notebook_instance(**args)
|
2020-10-06 06:04:09 +00:00
|
|
|
assert ex.value.response["Error"]["Code"] == "ValidationException"
|
Sagemaker models (#3105)
* First failing test, and enough framework to run it.
* Rudimentary passing test.
* Sagemaker Notebook Support, take-1: create, describe, start, stop, delete.
* Added list_tags.
* Merged in model support from https://github.com/porthunt/moto/tree/sagemaker-support.
* Re-org'd
* Fixed up describe_model exception when no matching model.
* Segregated tests by Sagemaker entity. Model arn check by regex..
* Python2 compabitility changes.
* Added sagemaker to list of known backends. Corrected urls.
* Added sagemaker special case to moto.server.infer_service_region_host due to irregular url format (use of 'api' subdomain) to support server mode.
* Changes for PR 3105 comments of July 10, 2020
* PR3105 July 10, 2020, 8:55 AM EDT comment: dropped unnecessary re-addition of arn when formulating model list response.
* PR 3105 July 15, 2020 9:10 AM EDT Comment: clean-up SageMakerModelBackend.describe_models logic for finding the model in the dict.
* Optimized imports
Co-authored-by: Joseph Weitekamp <jweite@amazon.com>
2020-07-16 12:12:25 +00:00
|
|
|
expected_message = "Value '{}' at 'instanceType' failed to satisfy constraint: Member must satisfy enum value set: [".format(
|
|
|
|
instance_type
|
|
|
|
)
|
|
|
|
|
2020-10-06 06:04:09 +00:00
|
|
|
assert expected_message in ex.value.response["Error"]["Message"]
|
Sagemaker models (#3105)
* First failing test, and enough framework to run it.
* Rudimentary passing test.
* Sagemaker Notebook Support, take-1: create, describe, start, stop, delete.
* Added list_tags.
* Merged in model support from https://github.com/porthunt/moto/tree/sagemaker-support.
* Re-org'd
* Fixed up describe_model exception when no matching model.
* Segregated tests by Sagemaker entity. Model arn check by regex..
* Python2 compabitility changes.
* Added sagemaker to list of known backends. Corrected urls.
* Added sagemaker special case to moto.server.infer_service_region_host due to irregular url format (use of 'api' subdomain) to support server mode.
* Changes for PR 3105 comments of July 10, 2020
* PR3105 July 10, 2020, 8:55 AM EDT comment: dropped unnecessary re-addition of arn when formulating model list response.
* PR 3105 July 15, 2020 9:10 AM EDT Comment: clean-up SageMakerModelBackend.describe_models logic for finding the model in the dict.
* Optimized imports
Co-authored-by: Joseph Weitekamp <jweite@amazon.com>
2020-07-16 12:12:25 +00:00
|
|
|
|
|
|
|
|
|
|
|
@mock_sagemaker
|
|
|
|
def test_notebook_instance_lifecycle():
|
|
|
|
sagemaker = boto3.client("sagemaker", region_name=TEST_REGION_NAME)
|
|
|
|
|
|
|
|
NAME_PARAM = "MyNotebookInstance"
|
|
|
|
INSTANCE_TYPE_PARAM = "ml.t2.medium"
|
|
|
|
|
|
|
|
args = {
|
|
|
|
"NotebookInstanceName": NAME_PARAM,
|
|
|
|
"InstanceType": INSTANCE_TYPE_PARAM,
|
|
|
|
"RoleArn": FAKE_ROLE_ARN,
|
|
|
|
}
|
|
|
|
resp = sagemaker.create_notebook_instance(**args)
|
2020-10-06 05:54:49 +00:00
|
|
|
assert resp["NotebookInstanceArn"].startswith("arn:aws:sagemaker")
|
|
|
|
assert resp["NotebookInstanceArn"].endswith(args["NotebookInstanceName"])
|
Sagemaker models (#3105)
* First failing test, and enough framework to run it.
* Rudimentary passing test.
* Sagemaker Notebook Support, take-1: create, describe, start, stop, delete.
* Added list_tags.
* Merged in model support from https://github.com/porthunt/moto/tree/sagemaker-support.
* Re-org'd
* Fixed up describe_model exception when no matching model.
* Segregated tests by Sagemaker entity. Model arn check by regex..
* Python2 compabitility changes.
* Added sagemaker to list of known backends. Corrected urls.
* Added sagemaker special case to moto.server.infer_service_region_host due to irregular url format (use of 'api' subdomain) to support server mode.
* Changes for PR 3105 comments of July 10, 2020
* PR3105 July 10, 2020, 8:55 AM EDT comment: dropped unnecessary re-addition of arn when formulating model list response.
* PR 3105 July 15, 2020 9:10 AM EDT Comment: clean-up SageMakerModelBackend.describe_models logic for finding the model in the dict.
* Optimized imports
Co-authored-by: Joseph Weitekamp <jweite@amazon.com>
2020-07-16 12:12:25 +00:00
|
|
|
|
|
|
|
resp = sagemaker.describe_notebook_instance(NotebookInstanceName=NAME_PARAM)
|
|
|
|
notebook_instance_arn = resp["NotebookInstanceArn"]
|
|
|
|
|
2020-10-06 05:54:49 +00:00
|
|
|
with pytest.raises(ClientError) as ex:
|
Sagemaker models (#3105)
* First failing test, and enough framework to run it.
* Rudimentary passing test.
* Sagemaker Notebook Support, take-1: create, describe, start, stop, delete.
* Added list_tags.
* Merged in model support from https://github.com/porthunt/moto/tree/sagemaker-support.
* Re-org'd
* Fixed up describe_model exception when no matching model.
* Segregated tests by Sagemaker entity. Model arn check by regex..
* Python2 compabitility changes.
* Added sagemaker to list of known backends. Corrected urls.
* Added sagemaker special case to moto.server.infer_service_region_host due to irregular url format (use of 'api' subdomain) to support server mode.
* Changes for PR 3105 comments of July 10, 2020
* PR3105 July 10, 2020, 8:55 AM EDT comment: dropped unnecessary re-addition of arn when formulating model list response.
* PR 3105 July 15, 2020 9:10 AM EDT Comment: clean-up SageMakerModelBackend.describe_models logic for finding the model in the dict.
* Optimized imports
Co-authored-by: Joseph Weitekamp <jweite@amazon.com>
2020-07-16 12:12:25 +00:00
|
|
|
sagemaker.delete_notebook_instance(NotebookInstanceName=NAME_PARAM)
|
2020-10-06 06:04:09 +00:00
|
|
|
assert ex.value.response["Error"]["Code"] == "ValidationException"
|
Sagemaker models (#3105)
* First failing test, and enough framework to run it.
* Rudimentary passing test.
* Sagemaker Notebook Support, take-1: create, describe, start, stop, delete.
* Added list_tags.
* Merged in model support from https://github.com/porthunt/moto/tree/sagemaker-support.
* Re-org'd
* Fixed up describe_model exception when no matching model.
* Segregated tests by Sagemaker entity. Model arn check by regex..
* Python2 compabitility changes.
* Added sagemaker to list of known backends. Corrected urls.
* Added sagemaker special case to moto.server.infer_service_region_host due to irregular url format (use of 'api' subdomain) to support server mode.
* Changes for PR 3105 comments of July 10, 2020
* PR3105 July 10, 2020, 8:55 AM EDT comment: dropped unnecessary re-addition of arn when formulating model list response.
* PR 3105 July 15, 2020 9:10 AM EDT Comment: clean-up SageMakerModelBackend.describe_models logic for finding the model in the dict.
* Optimized imports
Co-authored-by: Joseph Weitekamp <jweite@amazon.com>
2020-07-16 12:12:25 +00:00
|
|
|
expected_message = "Status (InService) not in ([Stopped, Failed]). Unable to transition to (Deleting) for Notebook Instance ({})".format(
|
|
|
|
notebook_instance_arn
|
|
|
|
)
|
2020-10-06 06:04:09 +00:00
|
|
|
assert expected_message in ex.value.response["Error"]["Message"]
|
Sagemaker models (#3105)
* First failing test, and enough framework to run it.
* Rudimentary passing test.
* Sagemaker Notebook Support, take-1: create, describe, start, stop, delete.
* Added list_tags.
* Merged in model support from https://github.com/porthunt/moto/tree/sagemaker-support.
* Re-org'd
* Fixed up describe_model exception when no matching model.
* Segregated tests by Sagemaker entity. Model arn check by regex..
* Python2 compabitility changes.
* Added sagemaker to list of known backends. Corrected urls.
* Added sagemaker special case to moto.server.infer_service_region_host due to irregular url format (use of 'api' subdomain) to support server mode.
* Changes for PR 3105 comments of July 10, 2020
* PR3105 July 10, 2020, 8:55 AM EDT comment: dropped unnecessary re-addition of arn when formulating model list response.
* PR 3105 July 15, 2020 9:10 AM EDT Comment: clean-up SageMakerModelBackend.describe_models logic for finding the model in the dict.
* Optimized imports
Co-authored-by: Joseph Weitekamp <jweite@amazon.com>
2020-07-16 12:12:25 +00:00
|
|
|
|
|
|
|
sagemaker.stop_notebook_instance(NotebookInstanceName=NAME_PARAM)
|
|
|
|
|
|
|
|
resp = sagemaker.describe_notebook_instance(NotebookInstanceName=NAME_PARAM)
|
2020-10-06 05:54:49 +00:00
|
|
|
assert resp["NotebookInstanceStatus"] == "Stopped"
|
Sagemaker models (#3105)
* First failing test, and enough framework to run it.
* Rudimentary passing test.
* Sagemaker Notebook Support, take-1: create, describe, start, stop, delete.
* Added list_tags.
* Merged in model support from https://github.com/porthunt/moto/tree/sagemaker-support.
* Re-org'd
* Fixed up describe_model exception when no matching model.
* Segregated tests by Sagemaker entity. Model arn check by regex..
* Python2 compabitility changes.
* Added sagemaker to list of known backends. Corrected urls.
* Added sagemaker special case to moto.server.infer_service_region_host due to irregular url format (use of 'api' subdomain) to support server mode.
* Changes for PR 3105 comments of July 10, 2020
* PR3105 July 10, 2020, 8:55 AM EDT comment: dropped unnecessary re-addition of arn when formulating model list response.
* PR 3105 July 15, 2020 9:10 AM EDT Comment: clean-up SageMakerModelBackend.describe_models logic for finding the model in the dict.
* Optimized imports
Co-authored-by: Joseph Weitekamp <jweite@amazon.com>
2020-07-16 12:12:25 +00:00
|
|
|
|
|
|
|
sagemaker.start_notebook_instance(NotebookInstanceName=NAME_PARAM)
|
|
|
|
|
|
|
|
resp = sagemaker.describe_notebook_instance(NotebookInstanceName=NAME_PARAM)
|
2020-10-06 05:54:49 +00:00
|
|
|
assert resp["NotebookInstanceStatus"] == "InService"
|
Sagemaker models (#3105)
* First failing test, and enough framework to run it.
* Rudimentary passing test.
* Sagemaker Notebook Support, take-1: create, describe, start, stop, delete.
* Added list_tags.
* Merged in model support from https://github.com/porthunt/moto/tree/sagemaker-support.
* Re-org'd
* Fixed up describe_model exception when no matching model.
* Segregated tests by Sagemaker entity. Model arn check by regex..
* Python2 compabitility changes.
* Added sagemaker to list of known backends. Corrected urls.
* Added sagemaker special case to moto.server.infer_service_region_host due to irregular url format (use of 'api' subdomain) to support server mode.
* Changes for PR 3105 comments of July 10, 2020
* PR3105 July 10, 2020, 8:55 AM EDT comment: dropped unnecessary re-addition of arn when formulating model list response.
* PR 3105 July 15, 2020 9:10 AM EDT Comment: clean-up SageMakerModelBackend.describe_models logic for finding the model in the dict.
* Optimized imports
Co-authored-by: Joseph Weitekamp <jweite@amazon.com>
2020-07-16 12:12:25 +00:00
|
|
|
|
|
|
|
sagemaker.stop_notebook_instance(NotebookInstanceName=NAME_PARAM)
|
|
|
|
|
|
|
|
resp = sagemaker.describe_notebook_instance(NotebookInstanceName=NAME_PARAM)
|
2020-10-06 05:54:49 +00:00
|
|
|
assert resp["NotebookInstanceStatus"] == "Stopped"
|
Sagemaker models (#3105)
* First failing test, and enough framework to run it.
* Rudimentary passing test.
* Sagemaker Notebook Support, take-1: create, describe, start, stop, delete.
* Added list_tags.
* Merged in model support from https://github.com/porthunt/moto/tree/sagemaker-support.
* Re-org'd
* Fixed up describe_model exception when no matching model.
* Segregated tests by Sagemaker entity. Model arn check by regex..
* Python2 compabitility changes.
* Added sagemaker to list of known backends. Corrected urls.
* Added sagemaker special case to moto.server.infer_service_region_host due to irregular url format (use of 'api' subdomain) to support server mode.
* Changes for PR 3105 comments of July 10, 2020
* PR3105 July 10, 2020, 8:55 AM EDT comment: dropped unnecessary re-addition of arn when formulating model list response.
* PR 3105 July 15, 2020 9:10 AM EDT Comment: clean-up SageMakerModelBackend.describe_models logic for finding the model in the dict.
* Optimized imports
Co-authored-by: Joseph Weitekamp <jweite@amazon.com>
2020-07-16 12:12:25 +00:00
|
|
|
|
|
|
|
sagemaker.delete_notebook_instance(NotebookInstanceName=NAME_PARAM)
|
|
|
|
|
2020-10-06 05:54:49 +00:00
|
|
|
with pytest.raises(ClientError) as ex:
|
Sagemaker models (#3105)
* First failing test, and enough framework to run it.
* Rudimentary passing test.
* Sagemaker Notebook Support, take-1: create, describe, start, stop, delete.
* Added list_tags.
* Merged in model support from https://github.com/porthunt/moto/tree/sagemaker-support.
* Re-org'd
* Fixed up describe_model exception when no matching model.
* Segregated tests by Sagemaker entity. Model arn check by regex..
* Python2 compabitility changes.
* Added sagemaker to list of known backends. Corrected urls.
* Added sagemaker special case to moto.server.infer_service_region_host due to irregular url format (use of 'api' subdomain) to support server mode.
* Changes for PR 3105 comments of July 10, 2020
* PR3105 July 10, 2020, 8:55 AM EDT comment: dropped unnecessary re-addition of arn when formulating model list response.
* PR 3105 July 15, 2020 9:10 AM EDT Comment: clean-up SageMakerModelBackend.describe_models logic for finding the model in the dict.
* Optimized imports
Co-authored-by: Joseph Weitekamp <jweite@amazon.com>
2020-07-16 12:12:25 +00:00
|
|
|
sagemaker.describe_notebook_instance(NotebookInstanceName=NAME_PARAM)
|
2020-10-06 06:04:09 +00:00
|
|
|
assert ex.value.response["Error"]["Message"] == "RecordNotFound"
|
Sagemaker models (#3105)
* First failing test, and enough framework to run it.
* Rudimentary passing test.
* Sagemaker Notebook Support, take-1: create, describe, start, stop, delete.
* Added list_tags.
* Merged in model support from https://github.com/porthunt/moto/tree/sagemaker-support.
* Re-org'd
* Fixed up describe_model exception when no matching model.
* Segregated tests by Sagemaker entity. Model arn check by regex..
* Python2 compabitility changes.
* Added sagemaker to list of known backends. Corrected urls.
* Added sagemaker special case to moto.server.infer_service_region_host due to irregular url format (use of 'api' subdomain) to support server mode.
* Changes for PR 3105 comments of July 10, 2020
* PR3105 July 10, 2020, 8:55 AM EDT comment: dropped unnecessary re-addition of arn when formulating model list response.
* PR 3105 July 15, 2020 9:10 AM EDT Comment: clean-up SageMakerModelBackend.describe_models logic for finding the model in the dict.
* Optimized imports
Co-authored-by: Joseph Weitekamp <jweite@amazon.com>
2020-07-16 12:12:25 +00:00
|
|
|
|
|
|
|
|
|
|
|
@mock_sagemaker
|
|
|
|
def test_describe_nonexistent_model():
|
|
|
|
sagemaker = boto3.client("sagemaker", region_name=TEST_REGION_NAME)
|
|
|
|
|
2020-10-06 05:54:49 +00:00
|
|
|
with pytest.raises(ClientError) as e:
|
|
|
|
sagemaker.describe_model(ModelName="Nonexistent")
|
2020-10-06 06:04:09 +00:00
|
|
|
assert e.value.response["Error"]["Message"].startswith("Could not find model")
|
2020-10-30 21:05:06 +00:00
|
|
|
|
|
|
|
|
|
|
|
@mock_sagemaker
|
|
|
|
def test_notebook_instance_lifecycle_config():
|
|
|
|
sagemaker = boto3.client("sagemaker", region_name=TEST_REGION_NAME)
|
|
|
|
|
|
|
|
name = "MyLifeCycleConfig"
|
|
|
|
on_create = [{"Content": "Create Script Line 1"}]
|
|
|
|
on_start = [{"Content": "Start Script Line 1"}]
|
|
|
|
resp = sagemaker.create_notebook_instance_lifecycle_config(
|
|
|
|
NotebookInstanceLifecycleConfigName=name, OnCreate=on_create, OnStart=on_start
|
|
|
|
)
|
2020-10-06 05:54:49 +00:00
|
|
|
assert resp["NotebookInstanceLifecycleConfigArn"].startswith("arn:aws:sagemaker")
|
|
|
|
assert resp["NotebookInstanceLifecycleConfigArn"].endswith(name)
|
2020-10-30 21:05:06 +00:00
|
|
|
|
2020-10-06 05:54:49 +00:00
|
|
|
with pytest.raises(ClientError) as e:
|
2020-10-30 21:05:06 +00:00
|
|
|
resp = sagemaker.create_notebook_instance_lifecycle_config(
|
|
|
|
NotebookInstanceLifecycleConfigName=name,
|
|
|
|
OnCreate=on_create,
|
|
|
|
OnStart=on_start,
|
|
|
|
)
|
2020-10-06 05:54:49 +00:00
|
|
|
assert \
|
2020-10-06 06:04:09 +00:00
|
|
|
e.value.response["Error"]["Message"].endswith(
|
2020-10-30 21:05:06 +00:00
|
|
|
"Notebook Instance Lifecycle Config already exists.)"
|
|
|
|
)
|
|
|
|
|
|
|
|
resp = sagemaker.describe_notebook_instance_lifecycle_config(
|
|
|
|
NotebookInstanceLifecycleConfigName=name,
|
|
|
|
)
|
2020-10-06 05:54:49 +00:00
|
|
|
assert resp["NotebookInstanceLifecycleConfigName"] == name
|
|
|
|
assert \
|
2020-10-30 21:05:06 +00:00
|
|
|
resp["NotebookInstanceLifecycleConfigArn"].startswith("arn:aws:sagemaker")
|
2020-10-06 05:54:49 +00:00
|
|
|
assert resp["NotebookInstanceLifecycleConfigArn"].endswith(name)
|
|
|
|
assert resp["OnStart"] == on_start
|
|
|
|
assert resp["OnCreate"] == on_create
|
|
|
|
assert isinstance(resp["LastModifiedTime"], datetime.datetime)
|
|
|
|
assert isinstance(resp["CreationTime"], datetime.datetime)
|
2020-10-30 21:05:06 +00:00
|
|
|
|
|
|
|
sagemaker.delete_notebook_instance_lifecycle_config(
|
|
|
|
NotebookInstanceLifecycleConfigName=name,
|
|
|
|
)
|
|
|
|
|
2020-10-06 05:54:49 +00:00
|
|
|
with pytest.raises(ClientError) as e:
|
2020-10-30 21:05:06 +00:00
|
|
|
sagemaker.describe_notebook_instance_lifecycle_config(
|
|
|
|
NotebookInstanceLifecycleConfigName=name,
|
|
|
|
)
|
2020-10-06 05:54:49 +00:00
|
|
|
assert \
|
2020-10-06 06:04:09 +00:00
|
|
|
e.value.response["Error"]["Message"].endswith(
|
2020-10-30 21:05:06 +00:00
|
|
|
"Notebook Instance Lifecycle Config does not exist.)"
|
|
|
|
)
|
|
|
|
|
2020-10-06 05:54:49 +00:00
|
|
|
with pytest.raises(ClientError) as e:
|
2020-10-30 21:05:06 +00:00
|
|
|
sagemaker.delete_notebook_instance_lifecycle_config(
|
|
|
|
NotebookInstanceLifecycleConfigName=name,
|
|
|
|
)
|
2020-10-06 05:54:49 +00:00
|
|
|
assert \
|
2020-10-06 06:04:09 +00:00
|
|
|
e.value.response["Error"]["Message"].endswith(
|
2020-10-30 21:05:06 +00:00
|
|
|
"Notebook Instance Lifecycle Config does not exist.)"
|
|
|
|
)
|