port-ocean 0.22.0__py3-none-any.whl → 0.22.1__py3-none-any.whl

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.

Potentially problematic release.


This version of port-ocean might be problematic. Click here for more details.

@@ -133,7 +133,7 @@ class EntityClientMixin:
133
133
  request_options: RequestOptions,
134
134
  user_agent_type: UserAgentType | None = None,
135
135
  should_raise: bool = True,
136
- ) -> list[Entity]:
136
+ ) -> list[tuple[bool, Entity]]:
137
137
  modified_entities_results = await asyncio.gather(
138
138
  *(
139
139
  self.upsert_entity(
@@ -146,17 +146,17 @@ class EntityClientMixin:
146
146
  ),
147
147
  return_exceptions=True,
148
148
  )
149
- entity_results = [
150
- entity for entity in modified_entities_results if isinstance(entity, Entity)
151
- ]
152
- if not should_raise:
153
- return entity_results
154
149
 
155
- for entity_result in modified_entities_results:
156
- if isinstance(entity_result, Exception):
157
- raise entity_result
150
+ entities_results: list[tuple[bool, Entity]] = []
151
+ for original_entity, result in zip(entities, modified_entities_results):
152
+ if isinstance(result, Exception) and should_raise:
153
+ raise result
154
+ elif isinstance(result, Entity):
155
+ entities_results.append((True, result))
156
+ elif result is False:
157
+ entities_results.append((False, original_entity))
158
158
 
159
- return entity_results
159
+ return entities_results
160
160
 
161
161
  async def delete_entity(
162
162
  self,
@@ -68,6 +68,7 @@ def deconstruct_blueprints_to_creation_steps(
68
68
  with_relations.append(blueprint.copy())
69
69
 
70
70
  blueprint.pop("teamInheritance", {})
71
+ blueprint.pop("ownership", {})
71
72
  blueprint.pop("relations", {})
72
73
  bare_blueprint.append(blueprint)
73
74
 
@@ -42,8 +42,8 @@ def deconstruct_blueprints_to_creation_steps(
42
42
  blueprint.pop("mirrorProperties", {})
43
43
  blueprint.pop("aggregationProperties", {})
44
44
  with_relations.append(blueprint.copy())
45
-
46
45
  blueprint.pop("teamInheritance", {})
46
+ blueprint.pop("ownership", {})
47
47
  blueprint.pop("relations", {})
48
48
  bare_blueprint.append(blueprint)
49
49
 
@@ -121,26 +121,20 @@ class HttpEntitiesStateApplier(BaseEntitiesStateApplier):
121
121
  ) -> list[Entity]:
122
122
  logger.info(f"Upserting {len(entities)} entities")
123
123
  modified_entities: list[Entity] = []
124
- if event.port_app_config.create_missing_related_entities:
125
- modified_entities = await self.context.port_client.batch_upsert_entities(
126
- entities,
127
- event.port_app_config.get_port_request_options(),
128
- user_agent_type,
129
- should_raise=False,
130
- )
131
- else:
132
- for entity in entities:
133
- upsertedEntity = await self.context.port_client.upsert_entity(
134
- entity,
135
- event.port_app_config.get_port_request_options(),
136
- user_agent_type,
137
- should_raise=False,
138
- )
139
- if upsertedEntity:
140
- modified_entities.append(upsertedEntity)
141
- # condition to false to differentiate from `result_entity.is_using_search_identifier`
142
- if upsertedEntity is False:
143
- event.entity_topological_sorter.register_entity(entity)
124
+ upserted_entities: list[tuple[bool, Entity]] = []
125
+
126
+ upserted_entities = await self.context.port_client.batch_upsert_entities(
127
+ entities,
128
+ event.port_app_config.get_port_request_options(),
129
+ user_agent_type,
130
+ should_raise=False,
131
+ )
132
+
133
+ for is_upserted, entity in upserted_entities:
134
+ if is_upserted:
135
+ modified_entities.append(entity)
136
+ else:
137
+ event.entity_topological_sorter.register_entity(entity)
144
138
  return modified_entities
145
139
 
146
140
  async def delete(
@@ -22,7 +22,7 @@ class EntityMapping(BaseModel):
22
22
  identifier: str | IngestSearchQuery
23
23
  title: str | None
24
24
  blueprint: str
25
- team: str | None
25
+ team: str | IngestSearchQuery | None
26
26
  properties: dict[str, str] = Field(default_factory=dict)
27
27
  relations: dict[str, str | IngestSearchQuery] = Field(default_factory=dict)
28
28
 
port_ocean/core/models.py CHANGED
@@ -40,7 +40,7 @@ class Entity(BaseModel):
40
40
  identifier: Any
41
41
  blueprint: Any
42
42
  title: Any
43
- team: str | None | list[Any] = []
43
+ team: str | None | list[Any] | dict[str, Any] = []
44
44
  properties: dict[str, Any] = {}
45
45
  relations: dict[str, Any] = {}
46
46
 
@@ -50,7 +50,11 @@ class Entity(BaseModel):
50
50
 
51
51
  @property
52
52
  def is_using_search_relation(self) -> bool:
53
- return any(isinstance(relation, dict) for relation in self.relations.values())
53
+ return any(
54
+ isinstance(relation, dict) for relation in self.relations.values()
55
+ ) or (
56
+ self.team is not None and any(isinstance(team, dict) for team in self.team)
57
+ )
54
58
 
55
59
 
56
60
  class BlueprintRelation(BaseModel):
@@ -110,7 +110,8 @@ def get_port_diff(before: Iterable[Entity], after: Iterable[Entity]) -> EntityPo
110
110
 
111
111
 
112
112
  def are_teams_different(
113
- first_team: str | None | list[Any], second_team: str | None | list[Any]
113
+ first_team: str | None | list[Any] | dict[str, Any],
114
+ second_team: str | None | list[Any] | dict[str, Any],
114
115
  ) -> bool:
115
116
  if isinstance(first_team, list) and isinstance(second_team, list):
116
117
  return sorted(first_team) != sorted(second_team)
@@ -122,6 +123,7 @@ def are_entities_fields_equal(
122
123
  ) -> bool:
123
124
  """
124
125
  Compare two entity fields by serializing them to JSON and comparing their SHA-256 hashes.
126
+ Removes keys with None values before comparison if the corresponding key doesn't exist in the other dict.
125
127
 
126
128
  Args:
127
129
  first_entity_field: First entity field dictionary to compare
@@ -130,7 +132,13 @@ def are_entities_fields_equal(
130
132
  Returns:
131
133
  bool: True if the entity fields have identical content
132
134
  """
133
- first_props = json.dumps(first_entity_field, sort_keys=True)
135
+ first_entity_field_copy = first_entity_field.copy()
136
+
137
+ for key in list(first_entity_field.keys()):
138
+ if first_entity_field[key] is None and key not in second_entity_field:
139
+ del first_entity_field_copy[key]
140
+
141
+ first_props = json.dumps(first_entity_field_copy, sort_keys=True)
134
142
  second_props = json.dumps(second_entity_field, sort_keys=True)
135
143
  first_hash = hashlib.sha256(first_props.encode()).hexdigest()
136
144
  second_hash = hashlib.sha256(second_props.encode()).hexdigest()
@@ -41,8 +41,9 @@ async def test_batch_upsert_entities_read_timeout_should_raise_false(
41
41
  result_entities = await entity_client.batch_upsert_entities(
42
42
  entities=all_entities, request_options=MagicMock(), should_raise=False
43
43
  )
44
+ entities_only = [entity for _, entity in result_entities]
44
45
 
45
- assert result_entities == expected_result_entities
46
+ assert entities_only == expected_result_entities
46
47
 
47
48
 
48
49
  async def test_batch_upsert_entities_read_timeout_should_raise_true(
@@ -177,10 +177,11 @@ def create_entity(
177
177
  blueprint: str,
178
178
  relation: dict[str, str] | None = None,
179
179
  is_to_fail: bool = False,
180
+ team: str | list[str] | dict[str, Any] | None = None,
180
181
  ) -> Entity:
181
182
  if relation is None:
182
183
  relation = {}
183
- entity = Entity(identifier=id, blueprint=blueprint)
184
+ entity = Entity(identifier=id, blueprint=blueprint, team=team)
184
185
  entity.relations = relation
185
186
  entity.properties = {"mock_is_to_fail": is_to_fail}
186
187
  return entity
@@ -130,6 +130,74 @@ async def test_applier_with_mock_context(
130
130
  assert result[0].identifier == "test_entity"
131
131
 
132
132
 
133
+ @pytest.mark.asyncio
134
+ async def test_applier_one_not_upserted(
135
+ mock_ocean: Ocean,
136
+ mock_context: PortOceanContext,
137
+ mock_port_app_config: PortAppConfig,
138
+ ) -> None:
139
+ # Create an applier using the mock_context fixture
140
+ applier = HttpEntitiesStateApplier(mock_context)
141
+
142
+ # Create test entities
143
+ entity = Entity(identifier="test_entity", blueprint="test_blueprint")
144
+
145
+ async with event_context(EventType.RESYNC, trigger_type="machine") as event:
146
+ # Mock the register_entity method
147
+ event.entity_topological_sorter.register_entity = Mock() # type: ignore
148
+ event.port_app_config = mock_port_app_config
149
+
150
+ # Test the upsert method with mocked client
151
+ with patch.object(mock_ocean.port_client.client, "post") as mock_post:
152
+ mock_post.return_value = Mock(
153
+ status_code=404,
154
+ json=lambda: {"ok": False, "error": "not_found"},
155
+ )
156
+
157
+ result = await applier.upsert([entity], UserAgentType.exporter)
158
+
159
+ # Assert that the post method was called
160
+ mock_post.assert_called_once()
161
+ assert len(result) == 0
162
+ event.entity_topological_sorter.register_entity.assert_called_once_with(
163
+ entity
164
+ )
165
+
166
+
167
+ @pytest.mark.asyncio
168
+ async def test_applier_error_upserting(
169
+ mock_ocean: Ocean,
170
+ mock_context: PortOceanContext,
171
+ mock_port_app_config: PortAppConfig,
172
+ ) -> None:
173
+ # Create an applier using the mock_context fixture
174
+ applier = HttpEntitiesStateApplier(mock_context)
175
+
176
+ # Create test entities
177
+ entity = Entity(identifier="test_entity", blueprint="test_blueprint")
178
+
179
+ async with event_context(EventType.RESYNC, trigger_type="machine") as event:
180
+ # Mock the register_entity method
181
+ event.entity_topological_sorter.register_entity = Mock() # type: ignore
182
+ event.port_app_config = mock_port_app_config
183
+
184
+ # Test the upsert method with mocked client
185
+ with patch.object(mock_ocean.port_client.client, "post") as mock_post:
186
+ mock_post.return_value = Mock(
187
+ status_code=404,
188
+ json=lambda: {"ok": False, "error": "not_found"},
189
+ )
190
+
191
+ result = await applier.upsert([entity], UserAgentType.exporter)
192
+
193
+ # Assert that the post method was called
194
+ mock_post.assert_called_once()
195
+ assert len(result) == 0
196
+ event.entity_topological_sorter.register_entity.assert_called_once_with(
197
+ entity
198
+ )
199
+
200
+
133
201
  @pytest.mark.asyncio
134
202
  async def test_using_create_entity_helper(
135
203
  mock_ocean: Ocean,
@@ -417,6 +417,30 @@ async def test_map_entities_compared_with_port_no_port_entities_all_entities_are
417
417
  assert "entity_2" in [e.identifier for e in changed_entities]
418
418
 
419
419
 
420
+ @pytest.mark.asyncio
421
+ async def test_map_entities_compared_with_port_returns_original_entities_when_using_team_search_query(
422
+ mock_sync_raw_mixin: SyncRawMixin,
423
+ mock_resource_config: ResourceConfig,
424
+ ) -> None:
425
+
426
+ team_search_query = {
427
+ "combinator": "and",
428
+ "rules": [{"property": "$team", "operator": "=", "value": "my-team"}],
429
+ }
430
+
431
+ entities = [
432
+ create_entity("entity_1", "service", {}, False, team=team_search_query),
433
+ create_entity("entity_2", "service", {}, False, team=team_search_query),
434
+ ]
435
+
436
+ changed_entities = await mock_sync_raw_mixin._map_entities_compared_with_port(
437
+ entities, mock_resource_config, UserAgentType.exporter
438
+ )
439
+
440
+ assert len(changed_entities) == 2
441
+ assert changed_entities == entities
442
+
443
+
420
444
  @pytest.mark.asyncio
421
445
  async def test_map_entities_compared_with_port_with_existing_entities_only_changed_third_party_entities_are_mapped(
422
446
  mock_sync_raw_mixin: SyncRawMixin,
@@ -246,6 +246,58 @@ def test_are_entities_fields_equal_different_nested_relations_should_be_false()
246
246
  )
247
247
 
248
248
 
249
+ def test_are_entities_fields_equal_null_properties_should_be_true() -> None:
250
+ assert (
251
+ are_entities_fields_equal(
252
+ {
253
+ "team": None,
254
+ "members": ["user1", "user2"],
255
+ "metadata": {"role": "admin"},
256
+ },
257
+ {"members": ["user1", "user2"], "metadata": {"role": "admin"}},
258
+ )
259
+ is True
260
+ )
261
+
262
+
263
+ def test_are_entities_fields_equal_null_properties_and_real_data_in_other_entity_should_be_false() -> (
264
+ None
265
+ ):
266
+ assert (
267
+ are_entities_fields_equal(
268
+ {
269
+ "team": None,
270
+ "members": ["user1", "user2"],
271
+ "metadata": {"role": "admin"},
272
+ },
273
+ {
274
+ "team": "team_id1",
275
+ "members": ["user1", "user2"],
276
+ "metadata": {"role": "admin"},
277
+ },
278
+ )
279
+ is False
280
+ )
281
+
282
+
283
+ def test_are_entities_fields_equal_null_properties_in_both_should_be_true() -> None:
284
+ assert (
285
+ are_entities_fields_equal(
286
+ {
287
+ "team": None,
288
+ "members": ["user1", "user2"],
289
+ "metadata": {"role": "admin"},
290
+ },
291
+ {
292
+ "team": None,
293
+ "members": ["user1", "user2"],
294
+ "metadata": {"role": "admin"},
295
+ },
296
+ )
297
+ is True
298
+ )
299
+
300
+
249
301
  def test_are_entities_different_identical_entities_should_be_false() -> None:
250
302
  entity1 = create_test_entity(
251
303
  "",
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: port-ocean
3
- Version: 0.22.0
3
+ Version: 0.22.1
4
4
  Summary: Port Ocean is a CLI tool for managing your Port projects.
5
5
  Home-page: https://app.getport.io
6
6
  Keywords: ocean,port-ocean,port
@@ -52,7 +52,7 @@ port_ocean/clients/port/authentication.py,sha256=6-uDMWsJ0xLe1-9IoYXHWmwtufj8rJR
52
52
  port_ocean/clients/port/client.py,sha256=OaNeN3U7Hw0tK4jYE6ESJEPKbTf9nGp2jcJVq00gnf8,3546
53
53
  port_ocean/clients/port/mixins/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
54
54
  port_ocean/clients/port/mixins/blueprints.py,sha256=POBl4uDocrgJBw4rvCAzwRcD4jk-uBL6pDAuKMTajdg,4633
55
- port_ocean/clients/port/mixins/entities.py,sha256=ACBq99r2ssc-8ybr6THE3bE4jRx7d_loAPeq1BfnZBQ,10769
55
+ port_ocean/clients/port/mixins/entities.py,sha256=se1RudWS2R1WXyZvvkFgSiLejra91gl79zPY8QsRHeQ,10881
56
56
  port_ocean/clients/port/mixins/integrations.py,sha256=nqz1gvQnR6Nzv62ZfbXEyli7FTKW5DCFpI1x1KoJJ_E,9341
57
57
  port_ocean/clients/port/mixins/migrations.py,sha256=A6896oJF6WbFL2WroyTkMzr12yhVyWqGoq9dtLNSKBY,1457
58
58
  port_ocean/clients/port/mixins/organization.py,sha256=fCo_ZS8UlQXsyIx-odTuWkbnfcYmVnQfIsSyJuPOPjM,1031
@@ -72,8 +72,8 @@ port_ocean/context/resource.py,sha256=WQlPzplxWic0hvvMxWKu8xPfQQC0VjrsJVeA6yZytw
72
72
  port_ocean/core/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
73
73
  port_ocean/core/defaults/__init__.py,sha256=8qCZg8n06WAdMu9s_FiRtDYLGPGHbOuS60vapeUoAks,142
74
74
  port_ocean/core/defaults/clean.py,sha256=_rL-NCl6Q_x3lUxDW5ACOM27IYilTCWl6ISUfRleuL0,2891
75
- port_ocean/core/defaults/common.py,sha256=zJsj7jvlqIMLGXhdASUlbKS8GIAf-FDKKB0O7jB6nx0,4166
76
- port_ocean/core/defaults/initialize.py,sha256=wdc3UdhRTu_tRZuCnt9ZRtqbl4dSLa8u6E_dyiAuEWg,10980
75
+ port_ocean/core/defaults/common.py,sha256=FGB6sshNsU5tD1JLX1C__RiN7tJgQYZhUUxEQzK0sKE,4205
76
+ port_ocean/core/defaults/initialize.py,sha256=1-Yx1XcjENkoxC3-Yh2XIhXupEzZeGjqkKjsmexiWY8,11018
77
77
  port_ocean/core/event_listener/__init__.py,sha256=T3E52MKs79fNEW381p7zU9F2vOMvIiiTYWlqRUqnsg0,1135
78
78
  port_ocean/core/event_listener/base.py,sha256=GFBTHiYhCzps50phzopQFUlTGAluQkCRlyaRqOG4g1Y,2995
79
79
  port_ocean/core/event_listener/factory.py,sha256=M4Qi05pI840sjDIbdjUEgYe9Gp5ckoCkX-KgLBxUpZg,4096
@@ -87,7 +87,7 @@ port_ocean/core/handlers/base.py,sha256=cTarblazu8yh8xz2FpB-dzDKuXxtoi143XJgPbV_
87
87
  port_ocean/core/handlers/entities_state_applier/__init__.py,sha256=kgLZDCeCEzi4r-0nzW9k78haOZNf6PX7mJOUr34A4c8,173
88
88
  port_ocean/core/handlers/entities_state_applier/base.py,sha256=5wHL0icfFAYRPqk8iV_wN49GdJ3aRUtO8tumSxBi4Wo,2268
89
89
  port_ocean/core/handlers/entities_state_applier/port/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
90
- port_ocean/core/handlers/entities_state_applier/port/applier.py,sha256=hgZyFuJab-WNQfSLHwGHtKarxMVrvLkFXoiZsLmAGQA,6703
90
+ port_ocean/core/handlers/entities_state_applier/port/applier.py,sha256=CcYSTMa4nA-fDX_9ZswthoyK8jMkupS1v-LMB-XxYBk,6254
91
91
  port_ocean/core/handlers/entities_state_applier/port/get_related_entities.py,sha256=1zncwCbE-Gej0xaWKlzZgoXxOBe9bgs_YxlZ8QW3NdI,1751
92
92
  port_ocean/core/handlers/entities_state_applier/port/order_by_entities_dependencies.py,sha256=lyv6xKzhYfd6TioUgR3AVRSJqj7JpAaj1LxxU2xAqeo,1720
93
93
  port_ocean/core/handlers/entity_processor/__init__.py,sha256=FvFCunFg44wNQoqlybem9MthOs7p1Wawac87uSXz9U8,156
@@ -96,7 +96,7 @@ port_ocean/core/handlers/entity_processor/jq_entity_processor.py,sha256=C6zJbS3m
96
96
  port_ocean/core/handlers/port_app_config/__init__.py,sha256=8AAT5OthiVM7KCcM34iEgEeXtn2pRMrT4Dze5r1Ixbk,134
97
97
  port_ocean/core/handlers/port_app_config/api.py,sha256=r_Th66NEw38IpRdnXZcRvI8ACfvxW_A6V62WLwjWXlQ,1044
98
98
  port_ocean/core/handlers/port_app_config/base.py,sha256=4Nxt2g8voEIHJ4Y1Km5NJcaG2iSbCklw5P8-Kus7Y9k,3007
99
- port_ocean/core/handlers/port_app_config/models.py,sha256=5Tt2BWHOJ4nnkh4xVrwyVG4KO5Tp4e64Cu_eFF-9jBg,2449
99
+ port_ocean/core/handlers/port_app_config/models.py,sha256=dzX1t-9BLiIm-_wI_vse3bl5HA4BSwWtcJOoe8EpZZQ,2469
100
100
  port_ocean/core/handlers/queue/__init__.py,sha256=1fICM0ZLATmmj6f7cdq_eV2kmw0_jy7y2INuLQIpzIE,121
101
101
  port_ocean/core/handlers/queue/abstract_queue.py,sha256=q_gpaWFFZHxM3XovEbgsDn8jEOLM45iAZWVC81Paxto,620
102
102
  port_ocean/core/handlers/queue/local_queue.py,sha256=EzqsGIX43xbVAcePwTcCg5QDrXATQpy-VzWxxN_OyAM,574
@@ -115,10 +115,10 @@ port_ocean/core/integrations/mixins/live_events.py,sha256=8HklZmlyffYY_LeDe8xbt3
115
115
  port_ocean/core/integrations/mixins/sync.py,sha256=GHiFbnw0XrBfl7aCTH_w67f_N7EZbcUgssc-0fPujNU,4047
116
116
  port_ocean/core/integrations/mixins/sync_raw.py,sha256=eUupD__avxQZKsgEvGWa7ibTidYShwsKWBq_wakiQAc,27481
117
117
  port_ocean/core/integrations/mixins/utils.py,sha256=oN4Okz6xlaefpid1_Pud8HPSw9BwwjRohyNsknq-Myg,2309
118
- port_ocean/core/models.py,sha256=FvTp-BlpbvLbMbngE0wsiimsCfmIhUR1PvsE__Z--1I,2206
118
+ port_ocean/core/models.py,sha256=YpJ2XOB3Zt9_M-rcMrMjugFNzBDg2hCUKgqvEt7now0,2348
119
119
  port_ocean/core/ocean_types.py,sha256=4VipWFOHEh_d9LmWewQccwx1p2dtrRYW0YURVgNsAjo,1398
120
120
  port_ocean/core/utils/entity_topological_sorter.py,sha256=MDUjM6OuDy4Xj68o-7InNN0w1jqjxeDfeY8U02vySNI,3081
121
- port_ocean/core/utils/utils.py,sha256=HmumOeH27N0NX1_OP3t4oGKt074ht9XyXhvfZ5I05s4,6474
121
+ port_ocean/core/utils/utils.py,sha256=XJ6ZZBR5hols19TcX4Bh49ygSNhPt3MLncLR-g41GTA,6858
122
122
  port_ocean/debug_cli.py,sha256=gHrv-Ey3cImKOcGZpjoHlo4pa_zfmyOl6TUM4o9VtcA,96
123
123
  port_ocean/exceptions/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
124
124
  port_ocean/exceptions/api.py,sha256=1JcA-H12lhSgolMEA6dM4JMbDrh9sYDcE7oydPSTuK8,649
@@ -147,15 +147,15 @@ port_ocean/tests/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,
147
147
  port_ocean/tests/clients/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
148
148
  port_ocean/tests/clients/oauth/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
149
149
  port_ocean/tests/clients/oauth/test_oauth_client.py,sha256=2XVMQUalDpiD539Z7_dk5BK_ngXQzsTmb2lNBsfEm9c,3266
150
- port_ocean/tests/clients/port/mixins/test_entities.py,sha256=vm2COG5pFC4mbJis9fjWE1zvGuNKD2kskPbcDEMxF2w,1751
150
+ port_ocean/tests/clients/port/mixins/test_entities.py,sha256=Zq_wKTymxJ0R8lHKztvEV6lN__3FZk8uTSIVpKCE6NA,1815
151
151
  port_ocean/tests/clients/port/mixins/test_organization_mixin.py,sha256=-8iHM33Oe8PuyEfj3O_6Yob8POp4fSmB0hnIT0Gv-8Y,868
152
152
  port_ocean/tests/conftest.py,sha256=JXASSS0IY0nnR6bxBflhzxS25kf4iNaABmThyZ0mZt8,101
153
- port_ocean/tests/core/conftest.py,sha256=2MNOmQ3C8rNAOlkryiV604_S7FmcpVNApHrpY378OPU,5448
153
+ port_ocean/tests/core/conftest.py,sha256=BHfi7egDVNRpg61lHZlWj81_ohUG7DEVMdFe9yX-vkc,5517
154
154
  port_ocean/tests/core/defaults/test_common.py,sha256=sR7RqB3ZYV6Xn6NIg-c8k5K6JcGsYZ2SCe_PYX5vLYM,5560
155
- port_ocean/tests/core/handlers/entities_state_applier/test_applier.py,sha256=nx2apKGDzKbckJQV-if8XzNSaldZwbzDBlZBNdVtMGg,5705
155
+ port_ocean/tests/core/handlers/entities_state_applier/test_applier.py,sha256=s_n8w08rt8fDbaAe-xVAFAq-PsLn9ecgal4JALsJLk0,8230
156
156
  port_ocean/tests/core/handlers/entity_processor/test_jq_entity_processor.py,sha256=FnEnaDjuoAbKvKyv6xJ46n3j0ZcaT70Sg2zc7oy7HAA,13596
157
157
  port_ocean/tests/core/handlers/mixins/test_live_events.py,sha256=iAwVpr3n3PIkXQLw7hxd-iB_SR_vyfletVXJLOmyz28,12480
158
- port_ocean/tests/core/handlers/mixins/test_sync_raw.py,sha256=91H2GfHqxIDFd4zbmv8WWp8rR6SVy1Sm0IvhqTvm7p0,32783
158
+ port_ocean/tests/core/handlers/mixins/test_sync_raw.py,sha256=RTkHU2QS9f-Lt3u0OCBPPEeiaM2_9h5vOQxqLnrbQro,33560
159
159
  port_ocean/tests/core/handlers/port_app_config/test_api.py,sha256=eJZ6SuFBLz71y4ca3DNqKag6d6HUjNJS0aqQPwiLMTI,1999
160
160
  port_ocean/tests/core/handlers/port_app_config/test_base.py,sha256=tdjpFUnUZ6TNMxc3trKkzmMTGTb7oKIeu3rRXv_fV3g,6872
161
161
  port_ocean/tests/core/handlers/queue/test_local_queue.py,sha256=9Ly0HzZXbs6Rbl_bstsIdInC3h2bgABU3roP9S_PnJM,2582
@@ -164,7 +164,7 @@ port_ocean/tests/core/handlers/webhook/test_processor_manager.py,sha256=6Zap3rKB
164
164
  port_ocean/tests/core/handlers/webhook/test_webhook_event.py,sha256=oR4dEHLO65mp6rkfNfszZcfFoRZlB8ZWee4XetmsuIk,3181
165
165
  port_ocean/tests/core/test_utils.py,sha256=Z3kdhb5V7Svhcyy3EansdTpgHL36TL6erNtU-OPwAcI,2647
166
166
  port_ocean/tests/core/utils/test_entity_topological_sorter.py,sha256=zuq5WSPy_88PemG3mOUIHTxWMR_js1R7tOzUYlgBd68,3447
167
- port_ocean/tests/core/utils/test_resolve_entities_diff.py,sha256=4kTey1c0dWKbLXjJ-9m2GXrHyAWZeLQ2asdtYRRUdRs,16573
167
+ port_ocean/tests/core/utils/test_resolve_entities_diff.py,sha256=nSB0H87Gk6iFw7RMq9YfiZtC_u6X20ao5vmvywP5HsE,17945
168
168
  port_ocean/tests/helpers/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
169
169
  port_ocean/tests/helpers/fake_port_api.py,sha256=9rtjC6iTQMfzWK6WipkDzzG0b1IIaRmvdJLOyV613vE,6479
170
170
  port_ocean/tests/helpers/fixtures.py,sha256=IQEplbHhRgjrAsZlnXrgSYA5YQEn25I9HgO3_Fjibxg,1481
@@ -188,8 +188,8 @@ port_ocean/utils/repeat.py,sha256=U2OeCkHPWXmRTVoPV-VcJRlQhcYqPWI5NfmPlb1JIbc,32
188
188
  port_ocean/utils/signal.py,sha256=mMVq-1Ab5YpNiqN4PkiyTGlV_G0wkUDMMjTZp5z3pb0,1514
189
189
  port_ocean/utils/time.py,sha256=pufAOH5ZQI7gXvOvJoQXZXZJV-Dqktoj9Qp9eiRwmJ4,1939
190
190
  port_ocean/version.py,sha256=UsuJdvdQlazzKGD3Hd5-U7N69STh8Dq9ggJzQFnu9fU,177
191
- port_ocean-0.22.0.dist-info/LICENSE.md,sha256=WNHhf_5RCaeuKWyq_K39vmp9F28LxKsB4SpomwSZ2L0,11357
192
- port_ocean-0.22.0.dist-info/METADATA,sha256=Dm3UD58bqEM3h5bX-Oeb7sjzKViKWfrN9sH-jl8AxUE,6721
193
- port_ocean-0.22.0.dist-info/WHEEL,sha256=Nq82e9rUAnEjt98J6MlVmMCZb-t9cYE2Ir1kpBmnWfs,88
194
- port_ocean-0.22.0.dist-info/entry_points.txt,sha256=F_DNUmGZU2Kme-8NsWM5LLE8piGMafYZygRYhOVtcjA,54
195
- port_ocean-0.22.0.dist-info/RECORD,,
191
+ port_ocean-0.22.1.dist-info/LICENSE.md,sha256=WNHhf_5RCaeuKWyq_K39vmp9F28LxKsB4SpomwSZ2L0,11357
192
+ port_ocean-0.22.1.dist-info/METADATA,sha256=i1afU-Np0jz3idI3hspGcRwWHGolswzvs7pI6mBHpBs,6721
193
+ port_ocean-0.22.1.dist-info/WHEEL,sha256=Nq82e9rUAnEjt98J6MlVmMCZb-t9cYE2Ir1kpBmnWfs,88
194
+ port_ocean-0.22.1.dist-info/entry_points.txt,sha256=F_DNUmGZU2Kme-8NsWM5LLE8piGMafYZygRYhOVtcjA,54
195
+ port_ocean-0.22.1.dist-info/RECORD,,