forked from feast-dev/feast
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathtest_entity.py
More file actions
95 lines (72 loc) · 2.96 KB
/
test_entity.py
File metadata and controls
95 lines (72 loc) · 2.96 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
# Copyright 2020 The Feast Authors
#
# 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.
import socket
from concurrent import futures
from contextlib import closing
import grpc
import pytest
from feast.client import Client
from feast.entity import Entity
from feast.protos.feast.core import CoreService_pb2_grpc as Core
from feast.value_type import ValueType
from feast_core_server import CoreServicer
def find_free_port():
with closing(socket.socket(socket.AF_INET, socket.SOCK_STREAM)) as s:
s.bind(("", 0))
s.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, 1)
return s.getsockname()[1]
free_port = find_free_port()
class TestEntity:
@pytest.fixture(scope="function")
def server(self):
server = grpc.server(futures.ThreadPoolExecutor(max_workers=10))
Core.add_CoreServiceServicer_to_server(CoreServicer(), server)
server.add_insecure_port(f"[::]:{free_port}")
server.start()
yield server
server.stop(0)
@pytest.fixture
def client(self, server):
return Client(core_url=f"localhost:{free_port}")
def test_entity_import_export_yaml(self):
test_entity = Entity(
name="car_driver_entity",
description="Driver entity for car rides",
value_type=ValueType.STRING,
labels={"team": "matchmaking"},
)
# Create a string YAML representation of the entity
string_yaml = test_entity.to_yaml()
# Create a new entity object from the YAML string
actual_entity_from_string = Entity.from_yaml(string_yaml)
# Ensure equality is upheld to original entity
assert test_entity == actual_entity_from_string
def test_join_key_default():
entity = Entity("my-entity", description="My entity", value_type=ValueType.STRING)
assert entity.join_key == "my-entity"
def test_entity_class_contains_labels():
entity = Entity(
"my-entity",
description="My entity",
value_type=ValueType.STRING,
labels={"key1": "val1", "key2": "val2"},
)
assert "key1" in entity.labels.keys() and entity.labels["key1"] == "val1"
assert "key2" in entity.labels.keys() and entity.labels["key2"] == "val2"
def test_entity_without_labels_empty_dict():
entity = Entity("my-entity", description="My entity", value_type=ValueType.STRING)
assert entity.labels == dict()
assert len(entity.labels) == 0
def test_entity_without_description():
Entity("my-entity", value_type=ValueType.STRING)