Skip to content

Commit

Permalink
Add factories to ease creation of array / struct parameter types. (#3700
Browse files Browse the repository at this point in the history
)

Closes: #3364
  • Loading branch information
tseaver authored Jul 28, 2017
1 parent b94a326 commit 78e51d9
Show file tree
Hide file tree
Showing 3 changed files with 108 additions and 0 deletions.
6 changes: 6 additions & 0 deletions spanner/google/cloud/spanner/__init__.py
Original file line number Diff line number Diff line change
Expand Up @@ -27,18 +27,22 @@
from google.cloud.spanner.pool import BurstyPool
from google.cloud.spanner.pool import FixedSizePool

from google.cloud.spanner.types import ArrayParamType
from google.cloud.spanner.types import BOOL_PARAM_TYPE
from google.cloud.spanner.types import BYTES_PARAM_TYPE
from google.cloud.spanner.types import DATE_PARAM_TYPE
from google.cloud.spanner.types import FLOAT64_PARAM_TYPE
from google.cloud.spanner.types import INT64_PARAM_TYPE
from google.cloud.spanner.types import STRING_PARAM_TYPE
from google.cloud.spanner.types import StructField
from google.cloud.spanner.types import StructParamType
from google.cloud.spanner.types import TIMESTAMP_PARAM_TYPE


__all__ = [
'__version__',
'AbstractSessionPool',
'ArrayParamType',
'BOOL_PARAM_TYPE',
'BYTES_PARAM_TYPE',
'BurstyPool',
Expand All @@ -50,5 +54,7 @@
'KeyRange',
'KeySet',
'STRING_PARAM_TYPE',
'StructField',
'StructParamType',
'TIMESTAMP_PARAM_TYPE',
]
41 changes: 41 additions & 0 deletions spanner/google/cloud/spanner/types.py
Original file line number Diff line number Diff line change
Expand Up @@ -25,3 +25,44 @@
FLOAT64_PARAM_TYPE = type_pb2.Type(code=type_pb2.FLOAT64)
DATE_PARAM_TYPE = type_pb2.Type(code=type_pb2.DATE)
TIMESTAMP_PARAM_TYPE = type_pb2.Type(code=type_pb2.TIMESTAMP)


def ArrayParamType(element_type): # pylint: disable=invalid-name
"""Construct an array paramter type description protobuf.
:type element_type: :class:`type_pb2.Type`
:param element_type: the type of elements of the array
:rtype: :class:`type_pb2.Type`
:returns: the appropriate array-type protobuf
"""
return type_pb2.Type(code=type_pb2.ARRAY, array_element_type=element_type)


def StructField(name, field_type): # pylint: disable=invalid-name
"""Construct a field description protobuf.
:type name: str
:param name: the name of the field
:type field_type: :class:`type_pb2.Type`
:param field_type: the type of the field
:rtype: :class:`type_pb2.StructType.Field`
:returns: the appropriate array-type protobuf
"""
return type_pb2.StructType.Field(name=name, type=field_type)


def StructParamType(fields): # pylint: disable=invalid-name
"""Construct a struct paramter type description protobuf.
:type fields: list of :class:`type_pb2.StructType.Field`
:param fields: the fields of the struct
:rtype: :class:`type_pb2.Type`
:returns: the appropriate struct-type protobuf
"""
return type_pb2.Type(
code=type_pb2.STRUCT,
struct_type=type_pb2.StructType(fields=fields))
61 changes: 61 additions & 0 deletions spanner/tests/unit/test_types.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,61 @@
# Copyright 2017 Google Inc. All rights reserved.
#
# 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
#
# http://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.


import unittest


class Test_ArrayParamType(unittest.TestCase):

def test_it(self):
from google.cloud.proto.spanner.v1 import type_pb2
from google.cloud.spanner.types import ArrayParamType
from google.cloud.spanner.types import INT64_PARAM_TYPE

expected = type_pb2.Type(
code=type_pb2.ARRAY,
array_element_type=type_pb2.Type(code=type_pb2.INT64))

found = ArrayParamType(INT64_PARAM_TYPE)

self.assertEqual(found, expected)


class Test_Struct(unittest.TestCase):

def test_it(self):
from google.cloud.proto.spanner.v1 import type_pb2
from google.cloud.spanner.types import INT64_PARAM_TYPE
from google.cloud.spanner.types import STRING_PARAM_TYPE
from google.cloud.spanner.types import StructParamType
from google.cloud.spanner.types import StructField

struct_type = type_pb2.StructType(fields=[
type_pb2.StructType.Field(
name='name',
type=type_pb2.Type(code=type_pb2.STRING)),
type_pb2.StructType.Field(
name='count',
type=type_pb2.Type(code=type_pb2.INT64)),
])
expected = type_pb2.Type(
code=type_pb2.STRUCT,
struct_type=struct_type)

found = StructParamType([
StructField('name', STRING_PARAM_TYPE),
StructField('count', INT64_PARAM_TYPE),
])

self.assertEqual(found, expected)

0 comments on commit 78e51d9

Please sign in to comment.