Skip to content

Commit

Permalink
fix: module names can no longer collide with keywords or builtinsg
Browse files Browse the repository at this point in the history
E.g. protobuf/any.proto will be imported as

from google.protobuf import any_pb2 as gp_any # Was previously 'as any'
  • Loading branch information
software-dov committed Sep 15, 2020
1 parent b5279ef commit e17d88e
Show file tree
Hide file tree
Showing 3 changed files with 30 additions and 3 deletions.
4 changes: 4 additions & 0 deletions gapic/schema/metadata.py
Original file line number Diff line number Diff line change
Expand Up @@ -34,6 +34,7 @@
from gapic.schema import imp
from gapic.schema import naming
from gapic.utils import cached_property
from gapic.utils import RESERVED_NAMES


@dataclasses.dataclass(frozen=True)
Expand All @@ -48,6 +49,9 @@ class Address:
)
collisions: FrozenSet[str] = dataclasses.field(default_factory=frozenset)

def __post_init__(self):
super().__setattr__("collisions", self.collisions | RESERVED_NAMES)

def __eq__(self, other) -> bool:
return all([getattr(self, i) == getattr(other, i) for i
in ('name', 'module', 'module_path', 'package', 'parent')])
Expand Down
4 changes: 3 additions & 1 deletion gapic/utils/reserved_names.py
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,9 @@
# See the License for the specific language governing permissions and
# limitations under the License.

import builtins
import itertools
import keyword


RESERVED_NAMES = frozenset(keyword.kwlist)
RESERVED_NAMES = frozenset(itertools.chain(keyword.kwlist, dir(builtins)))
25 changes: 23 additions & 2 deletions tests/unit/schema/test_metadata.py
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,7 @@

from gapic.schema import metadata
from gapic.schema import naming
from gapic.utils import RESERVED_NAMES


def test_address_str():
Expand Down Expand Up @@ -160,11 +161,31 @@ def test_address_subpackage_empty():

def test_metadata_with_context():
meta = metadata.Metadata()
assert meta.with_context(
collisions = meta.with_context(
collisions={'foo', 'bar'},
).address.collisions == {'foo', 'bar'}
).address.collisions - RESERVED_NAMES
assert collisions == {'foo', 'bar'}



def test_address_name_builtin_keyword():
addr_builtin = metadata.Address(
name="Any",
module="any",
package=("google", "protobuf"),
api_naming=naming.NewNaming(proto_package="foo.bar.baz.v1"),
)
assert addr_builtin.module_alias == "gp_any"

addr_kword = metadata.Address(
name="Class",
module="class",
package=("google", "protobuf"),
api_naming=naming.NewNaming(proto_package="foo.bar.baz.v1"),
)
assert addr_kword.module_alias == "gp_class"


def test_doc_nothing():
meta = metadata.Metadata()
assert meta.doc == ''
Expand Down

0 comments on commit e17d88e

Please sign in to comment.