From c23b240585ae8bd70df21c199b250b423dc53cba Mon Sep 17 00:00:00 2001 From: Noah Negrey Date: Tue, 21 Jan 2020 15:19:01 -0700 Subject: [PATCH] vision: update samples to throw errors if one occurs [(#2725)](https://github.com/GoogleCloudPlatform/python-docs-samples/issues/2725) * vision: update samples to throw errors if one occurs * Add link to error page docs * Add link to error message Co-authored-by: Leah E. Cole <6719667+leahecole@users.noreply.github.com> Co-authored-by: Gus Class --- samples/snippets/detect/beta_snippets.py | 12 +++ samples/snippets/detect/detect.py | 132 +++++++++++++++++++++++ samples/snippets/detect/detect_test.py | 2 +- samples/snippets/detect/set_endpoint.py | 6 ++ 4 files changed, 151 insertions(+), 1 deletion(-) diff --git a/samples/snippets/detect/beta_snippets.py b/samples/snippets/detect/beta_snippets.py index 1a5ae27b..d5beb402 100644 --- a/samples/snippets/detect/beta_snippets.py +++ b/samples/snippets/detect/beta_snippets.py @@ -130,6 +130,12 @@ def detect_handwritten_ocr(path): for symbol in word.symbols: print('\tSymbol: {} (confidence: {})'.format( symbol.text, symbol.confidence)) + + if response.error.message: + raise Exception( + '{}\nFor more info on error messages, check: ' + 'https://cloud.google.com/apis/design/errors'.format( + response.error.message)) # [END vision_handwritten_ocr_beta] @@ -174,6 +180,12 @@ def detect_handwritten_ocr_uri(uri): for symbol in word.symbols: print('\tSymbol: {} (confidence: {})'.format( symbol.text, symbol.confidence)) + + if response.error.message: + raise Exception( + '{}\nFor more info on error messages, check: ' + 'https://cloud.google.com/apis/design/errors'.format( + response.error.message)) # [END vision_handwritten_ocr_gcs_beta] diff --git a/samples/snippets/detect/detect.py b/samples/snippets/detect/detect.py index 878e8a10..a7d3eca8 100644 --- a/samples/snippets/detect/detect.py +++ b/samples/snippets/detect/detect.py @@ -68,6 +68,12 @@ def detect_faces(path): for vertex in face.bounding_poly.vertices]) print('face bounds: {}'.format(','.join(vertices))) + + if response.error.message: + raise Exception( + '{}\nFor more info on error messages, check: ' + 'https://cloud.google.com/apis/design/errors'.format( + response.error.message)) # [END vision_python_migration_face_detection] # [END vision_face_detection] @@ -99,6 +105,12 @@ def detect_faces_uri(uri): for vertex in face.bounding_poly.vertices]) print('face bounds: {}'.format(','.join(vertices))) + + if response.error.message: + raise Exception( + '{}\nFor more info on error messages, check: ' + 'https://cloud.google.com/apis/design/errors'.format( + response.error.message)) # [END vision_face_detection_gcs] @@ -121,6 +133,12 @@ def detect_labels(path): for label in labels: print(label.description) + + if response.error.message: + raise Exception( + '{}\nFor more info on error messages, check: ' + 'https://cloud.google.com/apis/design/errors'.format( + response.error.message)) # [END vision_python_migration_label_detection] # [END vision_label_detection] @@ -140,6 +158,12 @@ def detect_labels_uri(uri): for label in labels: print(label.description) + + if response.error.message: + raise Exception( + '{}\nFor more info on error messages, check: ' + 'https://cloud.google.com/apis/design/errors'.format( + response.error.message)) # [END vision_label_detection_gcs] @@ -166,6 +190,12 @@ def detect_landmarks(path): lat_lng = location.lat_lng print('Latitude {}'.format(lat_lng.latitude)) print('Longitude {}'.format(lat_lng.longitude)) + + if response.error.message: + raise Exception( + '{}\nFor more info on error messages, check: ' + 'https://cloud.google.com/apis/design/errors'.format( + response.error.message)) # [END vision_python_migration_landmark_detection] # [END vision_landmark_detection] @@ -185,6 +215,12 @@ def detect_landmarks_uri(uri): for landmark in landmarks: print(landmark.description) + + if response.error.message: + raise Exception( + '{}\nFor more info on error messages, check: ' + 'https://cloud.google.com/apis/design/errors'.format( + response.error.message)) # [END vision_landmark_detection_gcs] @@ -207,6 +243,12 @@ def detect_logos(path): for logo in logos: print(logo.description) + + if response.error.message: + raise Exception( + '{}\nFor more info on error messages, check: ' + 'https://cloud.google.com/apis/design/errors'.format( + response.error.message)) # [END vision_python_migration_logo_detection] # [END vision_logo_detection] @@ -226,6 +268,12 @@ def detect_logos_uri(uri): for logo in logos: print(logo.description) + + if response.error.message: + raise Exception( + '{}\nFor more info on error messages, check: ' + 'https://cloud.google.com/apis/design/errors'.format( + response.error.message)) # [END vision_logo_detection_gcs] @@ -255,6 +303,12 @@ def detect_safe_search(path): print('spoofed: {}'.format(likelihood_name[safe.spoof])) print('violence: {}'.format(likelihood_name[safe.violence])) print('racy: {}'.format(likelihood_name[safe.racy])) + + if response.error.message: + raise Exception( + '{}\nFor more info on error messages, check: ' + 'https://cloud.google.com/apis/design/errors'.format( + response.error.message)) # [END vision_python_migration_safe_search_detection] # [END vision_safe_search_detection] @@ -281,6 +335,12 @@ def detect_safe_search_uri(uri): print('spoofed: {}'.format(likelihood_name[safe.spoof])) print('violence: {}'.format(likelihood_name[safe.violence])) print('racy: {}'.format(likelihood_name[safe.racy])) + + if response.error.message: + raise Exception( + '{}\nFor more info on error messages, check: ' + 'https://cloud.google.com/apis/design/errors'.format( + response.error.message)) # [END vision_safe_search_detection_gcs] @@ -308,6 +368,12 @@ def detect_text(path): for vertex in text.bounding_poly.vertices]) print('bounds: {}'.format(','.join(vertices))) + + if response.error.message: + raise Exception( + '{}\nFor more info on error messages, check: ' + 'https://cloud.google.com/apis/design/errors'.format( + response.error.message)) # [END vision_python_migration_text_detection] # [END vision_text_detection] @@ -332,6 +398,12 @@ def detect_text_uri(uri): for vertex in text.bounding_poly.vertices]) print('bounds: {}'.format(','.join(vertices))) + + if response.error.message: + raise Exception( + '{}\nFor more info on error messages, check: ' + 'https://cloud.google.com/apis/design/errors'.format( + response.error.message)) # [END vision_text_detection_gcs] @@ -358,6 +430,12 @@ def detect_properties(path): print('\tg: {}'.format(color.color.green)) print('\tb: {}'.format(color.color.blue)) print('\ta: {}'.format(color.color.alpha)) + + if response.error.message: + raise Exception( + '{}\nFor more info on error messages, check: ' + 'https://cloud.google.com/apis/design/errors'.format( + response.error.message)) # [END vision_python_migration_image_properties] # [END vision_image_property_detection] @@ -381,6 +459,12 @@ def detect_properties_uri(uri): print('\tg: {}'.format(color.color.green)) print('\tb: {}'.format(color.color.blue)) print('\ta: {}'.format(color.color.alpha)) + + if response.error.message: + raise Exception( + '{}\nFor more info on error messages, check: ' + 'https://cloud.google.com/apis/design/errors'.format( + response.error.message)) # [END vision_image_property_detection_gcs] @@ -439,6 +523,12 @@ def detect_web(path): for image in annotations.visually_similar_images: print('\tImage url : {}'.format(image.url)) + + if response.error.message: + raise Exception( + '{}\nFor more info on error messages, check: ' + 'https://cloud.google.com/apis/design/errors'.format( + response.error.message)) # [END vision_python_migration_web_detection] # [END vision_web_detection] @@ -493,6 +583,12 @@ def detect_web_uri(uri): for image in annotations.visually_similar_images: print('\tImage url : {}'.format(image.url)) + + if response.error.message: + raise Exception( + '{}\nFor more info on error messages, check: ' + 'https://cloud.google.com/apis/design/errors'.format( + response.error.message)) # [END vision_web_detection_gcs] @@ -519,6 +615,12 @@ def web_entities_include_geo_results(path): for entity in response.web_detection.web_entities: print('\n\tScore : {}'.format(entity.score)) print(u'\tDescription: {}'.format(entity.description)) + + if response.error.message: + raise Exception( + '{}\nFor more info on error messages, check: ' + 'https://cloud.google.com/apis/design/errors'.format( + response.error.message)) # [END vision_web_detection_include_geo] @@ -543,6 +645,12 @@ def web_entities_include_geo_results_uri(uri): for entity in response.web_detection.web_entities: print('\n\tScore : {}'.format(entity.score)) print(u'\tDescription: {}'.format(entity.description)) + + if response.error.message: + raise Exception( + '{}\nFor more info on error messages, check: ' + 'https://cloud.google.com/apis/design/errors'.format( + response.error.message)) # [END vision_web_detection_include_geo_gcs] @@ -572,6 +680,12 @@ def detect_crop_hints(path): for vertex in hint.bounding_poly.vertices]) print('bounds: {}'.format(','.join(vertices))) + + if response.error.message: + raise Exception( + '{}\nFor more info on error messages, check: ' + 'https://cloud.google.com/apis/design/errors'.format( + response.error.message)) # [END vision_python_migration_crop_hints] # [END vision_crop_hint_detection] @@ -598,6 +712,12 @@ def detect_crop_hints_uri(uri): for vertex in hint.bounding_poly.vertices]) print('bounds: {}'.format(','.join(vertices))) + + if response.error.message: + raise Exception( + '{}\nFor more info on error messages, check: ' + 'https://cloud.google.com/apis/design/errors'.format( + response.error.message)) # [END vision_crop_hint_detection_gcs] @@ -634,6 +754,12 @@ def detect_document(path): for symbol in word.symbols: print('\tSymbol: {} (confidence: {})'.format( symbol.text, symbol.confidence)) + + if response.error.message: + raise Exception( + '{}\nFor more info on error messages, check: ' + 'https://cloud.google.com/apis/design/errors'.format( + response.error.message)) # [END vision_python_migration_document_text_detection] # [END vision_fulltext_detection] @@ -667,6 +793,12 @@ def detect_document_uri(uri): for symbol in word.symbols: print('\tSymbol: {} (confidence: {})'.format( symbol.text, symbol.confidence)) + + if response.error.message: + raise Exception( + '{}\nFor more info on error messages, check: ' + 'https://cloud.google.com/apis/design/errors'.format( + response.error.message)) # [END vision_fulltext_detection_gcs] diff --git a/samples/snippets/detect/detect_test.py b/samples/snippets/detect/detect_test.py index b7649d59..f80b63ce 100644 --- a/samples/snippets/detect/detect_test.py +++ b/samples/snippets/detect/detect_test.py @@ -37,7 +37,7 @@ def test_labels(capsys): def test_labels_uri(capsys): - file_name = 'gs://{}/vision/wakeupcat.jpg'.format(ASSET_BUCKET) + file_name = 'gs://{}/vision/label/wakeupcat.jpg'.format(ASSET_BUCKET) detect.detect_labels_uri(file_name) out, _ = capsys.readouterr() assert 'Labels' in out diff --git a/samples/snippets/detect/set_endpoint.py b/samples/snippets/detect/set_endpoint.py index d721ffc6..44361436 100644 --- a/samples/snippets/detect/set_endpoint.py +++ b/samples/snippets/detect/set_endpoint.py @@ -37,6 +37,12 @@ def set_endpoint(): print('bounds: {}\n'.format(','.join(vertices))) + if response.error.message: + raise Exception( + '{}\nFor more info on error messages, check: ' + 'https://cloud.google.com/apis/design/errors'.format( + response.error.message)) + if __name__ == '__main__': set_endpoint()