Skip to content

Commit

Permalink
Feat: add mbsdk video dataset samples (#307)
Browse files Browse the repository at this point in the history
* fix: rebase and resolve conflict

* fix: lint
  • Loading branch information
morgandu committed May 3, 2021
1 parent 12c5be4 commit 24d6920
Show file tree
Hide file tree
Showing 9 changed files with 361 additions and 5 deletions.
14 changes: 9 additions & 5 deletions samples/model-builder/conftest.py
Expand Up @@ -130,11 +130,15 @@ def mock_import_text_dataset(mock_text_dataset):
yield mock


"""
----------------------------------------------------------------------------
TrainingJob Fixtures
----------------------------------------------------------------------------
"""
@pytest.fixture
def mock_import_video_data(mock_video_dataset):
with patch.object(mock_video_dataset, "import_data") as mock:
yield mock


# ----------------------------------------------------------------------------
# TrainingJob Fixtures
# ----------------------------------------------------------------------------


@pytest.fixture
Expand Down
44 changes: 44 additions & 0 deletions samples/model-builder/create_and_import_dataset_video_sample.py
@@ -0,0 +1,44 @@
# Copyright 2021 Google LLC
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# https://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.

from typing import List, Union

from google.cloud import aiplatform


# [START aiplatform_sdk_create_and_import_dataset_video_sample]
def create_and_import_dataset_video_sample(
project: str,
location: str,
display_name: str,
src_uris: Union[str, List[str]],
sync: bool = True,
):
aiplatform.init(project=project, location=location)

ds = aiplatform.VideoDataset.create(
display_name=display_name,
gcs_source=src_uris,
import_schema_uri=aiplatform.schema.dataset.ioformat.video.classification,
sync=sync,
)

ds.wait()

print(ds.display_name)
print(ds.resource_name)
return ds


# [END aiplatform_sdk_create_and_import_dataset_video_sample]
@@ -0,0 +1,42 @@
# Copyright 2021 Google LLC
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# https://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.


from google.cloud.aiplatform import schema

import create_and_import_dataset_video_sample

import test_constants as constants


def test_create_and_import_dataset_video_sample(
mock_sdk_init, mock_create_video_dataset
):

create_and_import_dataset_video_sample.create_and_import_dataset_video_sample(
project=constants.PROJECT,
location=constants.LOCATION,
src_uris=constants.GCS_SOURCES,
display_name=constants.DISPLAY_NAME,
)

mock_sdk_init.assert_called_once_with(
project=constants.PROJECT, location=constants.LOCATION
)
mock_create_video_dataset.assert_called_once_with(
display_name=constants.DISPLAY_NAME,
gcs_source=constants.GCS_SOURCES,
import_schema_uri=schema.dataset.ioformat.video.classification,
sync=True,
)
@@ -0,0 +1,45 @@
# Copyright 2021 Google LLC
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# https://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.

from typing import List, Union

from google.cloud import aiplatform


# [START aiplatform_sdk_import_data_video_action_recognition_sample]
def import_data_video_action_recognition_sample(
project: str,
location: str,
dataset_name: str,
src_uris: Union[str, List[str]],
sync: bool = True,
):
aiplatform.init(project=project, location=location)

ds = aiplatform.VideoDataset(dataset_name=dataset_name)

ds.import_data(
gcs_source=src_uris,
import_schema_uri=aiplatform.schema.dataset.ioformat.video.action_recognition,
sync=sync,
)

ds.wait()

print(ds.display_name)
print(ds.resource_name)
return ds


# [END aiplatform_sdk_import_data_video_action_recognition_sample]
@@ -0,0 +1,44 @@
# Copyright 2021 Google LLC
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# https://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.

from google.cloud.aiplatform import schema

import pytest

import import_data_video_action_recognition_sample

import test_constants as constants


@pytest.mark.usefixtures("mock_get_video_dataset")
def test_import_data_video_action_recognition_sample(
mock_sdk_init, mock_import_video_data
):

import_data_video_action_recognition_sample.import_data_video_action_recognition_sample(
project=constants.PROJECT,
location=constants.LOCATION,
dataset_name=constants.DATASET_NAME,
src_uris=constants.GCS_SOURCES,
)

mock_sdk_init.assert_called_once_with(
project=constants.PROJECT, location=constants.LOCATION
)

mock_import_video_data.assert_called_once_with(
gcs_source=constants.GCS_SOURCES,
import_schema_uri=schema.dataset.ioformat.video.action_recognition,
sync=True,
)
46 changes: 46 additions & 0 deletions samples/model-builder/import_data_video_classification_sample.py
@@ -0,0 +1,46 @@
# Copyright 2021 Google LLC
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# https://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.

from typing import List, Union

from google.cloud import aiplatform


# [START aiplatform_sdk_import_data_video_classification_sample]
def import_data_video_classification_sample(
project: str,
location: str,
dataset_name: str,
src_uris: Union[str, List[str]],
sync: bool = True,
):
aiplatform.init(project=project, location=location)

ds = aiplatform.VideoDataset(dataset_name=dataset_name)

print(ds.display_name)
print(ds.resource_name)

ds.import_data(
gcs_source=src_uris,
import_schema_uri=aiplatform.schema.dataset.ioformat.video.classification,
sync=sync,
)

ds.wait()

return ds


# [END aiplatform_sdk_import_data_video_classification_sample]
@@ -0,0 +1,42 @@
# Copyright 2021 Google LLC
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# https://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.

from google.cloud.aiplatform import schema

import pytest

import import_data_video_classification_sample

import test_constants as constants


@pytest.mark.usefixtures("mock_get_video_dataset")
def test_import_data_video_classification_sample(mock_sdk_init, mock_import_video_data):

import_data_video_classification_sample.import_data_video_classification_sample(
project=constants.PROJECT,
location=constants.LOCATION,
dataset_name=constants.DATASET_NAME,
src_uris=constants.GCS_SOURCES,
)

mock_sdk_init.assert_called_once_with(
project=constants.PROJECT, location=constants.LOCATION
)

mock_import_video_data.assert_called_once_with(
gcs_source=constants.GCS_SOURCES,
import_schema_uri=schema.dataset.ioformat.video.classification,
sync=True,
)
45 changes: 45 additions & 0 deletions samples/model-builder/import_data_video_object_tracking_sample.py
@@ -0,0 +1,45 @@
# Copyright 2021 Google LLC
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# https://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.

from typing import List, Union

from google.cloud import aiplatform


# [START aiplatform_sdk_import_data_video_object_tracking_sample]
def import_data_video_object_tracking_sample(
project: str,
location: str,
dataset_name: str,
src_uris: Union[str, List[str]],
sync: bool = True,
):
aiplatform.init(project=project, location=location)

ds = aiplatform.VideoDataset(dataset_name=dataset_name)

ds.import_data(
gcs_source=src_uris,
import_schema_uri=aiplatform.schema.dataset.ioformat.video.object_tracking,
sync=sync,
)

ds.wait()

print(ds.display_name)
print(ds.resource_name)
return ds


# [END aiplatform_sdk_import_data_video_object_tracking_sample]
@@ -0,0 +1,44 @@
# Copyright 2021 Google LLC
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# https://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.

from google.cloud.aiplatform import schema

import pytest

import import_data_video_object_tracking_sample

import test_constants as constants


@pytest.mark.usefixtures("mock_get_video_dataset")
def test_import_data_video_object_tracking_sample(
mock_sdk_init, mock_import_video_data
):

import_data_video_object_tracking_sample.import_data_video_object_tracking_sample(
project=constants.PROJECT,
location=constants.LOCATION,
dataset_name=constants.DATASET_NAME,
src_uris=constants.GCS_SOURCES,
)

mock_sdk_init.assert_called_once_with(
project=constants.PROJECT, location=constants.LOCATION
)

mock_import_video_data.assert_called_once_with(
gcs_source=constants.GCS_SOURCES,
import_schema_uri=schema.dataset.ioformat.video.object_tracking,
sync=True,
)

0 comments on commit 24d6920

Please sign in to comment.