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
|
|
|
import boto3
|
|
|
|
from botocore.exceptions import ClientError
|
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
|
|
|
from moto import mock_sagemaker
|
|
|
|
|
2021-10-18 19:44:29 +00:00
|
|
|
import sure # noqa # pylint: disable=unused-import
|
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
|
|
|
|
|
|
|
from moto.sagemaker.models import VpcConfig
|
|
|
|
|
|
|
|
|
|
|
|
class MySageMakerModel(object):
|
|
|
|
def __init__(self, name, arn, container=None, vpc_config=None):
|
|
|
|
self.name = name
|
|
|
|
self.arn = arn
|
2021-09-02 12:45:47 +00:00
|
|
|
self.container = container or {}
|
|
|
|
self.vpc_config = vpc_config or {"sg-groups": ["sg-123"], "subnets": ["123"]}
|
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
|
|
|
|
|
|
|
def save(self):
|
|
|
|
client = boto3.client("sagemaker", region_name="us-east-1")
|
|
|
|
vpc_config = VpcConfig(
|
|
|
|
self.vpc_config.get("sg-groups"), self.vpc_config.get("subnets")
|
|
|
|
)
|
|
|
|
client.create_model(
|
|
|
|
ModelName=self.name,
|
|
|
|
ExecutionRoleArn=self.arn,
|
|
|
|
VpcConfig=vpc_config.response_object,
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
@mock_sagemaker
|
|
|
|
def test_describe_model():
|
|
|
|
client = boto3.client("sagemaker", region_name="us-east-1")
|
|
|
|
test_model = MySageMakerModel(
|
|
|
|
name="blah",
|
|
|
|
arn="arn:aws:sagemaker:eu-west-1:000000000000:x-x/foobar",
|
|
|
|
vpc_config={"sg-groups": ["sg-123"], "subnets": ["123"]},
|
|
|
|
)
|
|
|
|
test_model.save()
|
|
|
|
model = client.describe_model(ModelName="blah")
|
|
|
|
assert model.get("ModelName").should.equal("blah")
|
|
|
|
|
|
|
|
|
2021-02-02 16:31:26 +00:00
|
|
|
@mock_sagemaker
|
|
|
|
def test_describe_model_not_found():
|
|
|
|
client = boto3.client("sagemaker", region_name="us-east-1")
|
|
|
|
with pytest.raises(ClientError) as err:
|
|
|
|
client.describe_model(ModelName="unknown")
|
|
|
|
assert err.value.response["Error"]["Message"].should.contain("Could not find model")
|
|
|
|
|
|
|
|
|
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_model():
|
|
|
|
client = boto3.client("sagemaker", region_name="us-east-1")
|
|
|
|
vpc_config = VpcConfig(["sg-foobar"], ["subnet-xxx"])
|
|
|
|
exec_role_arn = "arn:aws:sagemaker:eu-west-1:000000000000:x-x/foobar"
|
|
|
|
name = "blah"
|
|
|
|
model = client.create_model(
|
|
|
|
ModelName=name,
|
|
|
|
ExecutionRoleArn=exec_role_arn,
|
|
|
|
VpcConfig=vpc_config.response_object,
|
|
|
|
)
|
|
|
|
|
|
|
|
model["ModelArn"].should.match(r"^arn:aws:sagemaker:.*:.*:model/{}$".format(name))
|
|
|
|
|
|
|
|
|
|
|
|
@mock_sagemaker
|
|
|
|
def test_delete_model():
|
|
|
|
client = boto3.client("sagemaker", region_name="us-east-1")
|
|
|
|
name = "blah"
|
|
|
|
arn = "arn:aws:sagemaker:eu-west-1:000000000000:x-x/foobar"
|
|
|
|
test_model = MySageMakerModel(name=name, arn=arn)
|
|
|
|
test_model.save()
|
|
|
|
|
|
|
|
assert len(client.list_models()["Models"]).should.equal(1)
|
|
|
|
client.delete_model(ModelName=name)
|
|
|
|
assert len(client.list_models()["Models"]).should.equal(0)
|
|
|
|
|
|
|
|
|
|
|
|
@mock_sagemaker
|
|
|
|
def test_delete_model_not_found():
|
2020-10-06 05:54:49 +00:00
|
|
|
with pytest.raises(ClientError) as err:
|
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
|
|
|
boto3.client("sagemaker", region_name="us-east-1").delete_model(
|
|
|
|
ModelName="blah"
|
|
|
|
)
|
2020-10-06 06:04:09 +00:00
|
|
|
assert err.value.response["Error"]["Code"].should.equal("404")
|
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_list_models():
|
|
|
|
client = boto3.client("sagemaker", region_name="us-east-1")
|
|
|
|
name = "blah"
|
|
|
|
arn = "arn:aws:sagemaker:eu-west-1:000000000000:x-x/foobar"
|
|
|
|
test_model = MySageMakerModel(name=name, arn=arn)
|
|
|
|
test_model.save()
|
|
|
|
models = client.list_models()
|
|
|
|
assert len(models["Models"]).should.equal(1)
|
|
|
|
assert models["Models"][0]["ModelName"].should.equal(name)
|
|
|
|
assert models["Models"][0]["ModelArn"].should.match(
|
|
|
|
r"^arn:aws:sagemaker:.*:.*:model/{}$".format(name)
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
@mock_sagemaker
|
|
|
|
def test_list_models_multiple():
|
|
|
|
client = boto3.client("sagemaker", region_name="us-east-1")
|
|
|
|
|
|
|
|
name_model_1 = "blah"
|
|
|
|
arn_model_1 = "arn:aws:sagemaker:eu-west-1:000000000000:x-x/foobar"
|
|
|
|
test_model_1 = MySageMakerModel(name=name_model_1, arn=arn_model_1)
|
|
|
|
test_model_1.save()
|
|
|
|
|
|
|
|
name_model_2 = "blah2"
|
|
|
|
arn_model_2 = "arn:aws:sagemaker:eu-west-1:000000000000:x-x/foobar2"
|
|
|
|
test_model_2 = MySageMakerModel(name=name_model_2, arn=arn_model_2)
|
|
|
|
test_model_2.save()
|
|
|
|
models = client.list_models()
|
|
|
|
assert len(models["Models"]).should.equal(2)
|
|
|
|
|
|
|
|
|
|
|
|
@mock_sagemaker
|
|
|
|
def test_list_models_none():
|
|
|
|
client = boto3.client("sagemaker", region_name="us-east-1")
|
|
|
|
models = client.list_models()
|
|
|
|
assert len(models["Models"]).should.equal(0)
|