omnata-plugin-runtime 0.4.0a88__py3-none-any.whl → 0.4.0a90__py3-none-any.whl
Sign up to get free protection for your applications and to get access to all the features.
- omnata_plugin_runtime/omnata_plugin.py +108 -59
- {omnata_plugin_runtime-0.4.0a88.dist-info → omnata_plugin_runtime-0.4.0a90.dist-info}/METADATA +1 -1
- {omnata_plugin_runtime-0.4.0a88.dist-info → omnata_plugin_runtime-0.4.0a90.dist-info}/RECORD +5 -5
- {omnata_plugin_runtime-0.4.0a88.dist-info → omnata_plugin_runtime-0.4.0a90.dist-info}/LICENSE +0 -0
- {omnata_plugin_runtime-0.4.0a88.dist-info → omnata_plugin_runtime-0.4.0a90.dist-info}/WHEEL +0 -0
@@ -690,19 +690,34 @@ class OutboundSyncRequest(SyncRequest):
|
|
690
690
|
logger.info("applying results to table")
|
691
691
|
# use a random table name with a random string to avoid collisions
|
692
692
|
with self._snowflake_query_lock:
|
693
|
-
|
694
|
-
|
695
|
-
|
696
|
-
|
697
|
-
|
698
|
-
|
699
|
-
|
700
|
-
|
701
|
-
|
702
|
-
|
703
|
-
|
704
|
-
|
705
|
-
|
693
|
+
attempts_remaining = 12
|
694
|
+
while attempts_remaining > 0:
|
695
|
+
try:
|
696
|
+
success, nchunks, nrows, _ = write_pandas(
|
697
|
+
conn=self._session._conn._cursor.connection, # pylint: disable=protected-access
|
698
|
+
df=self._preprocess_results_dataframe(results_df),
|
699
|
+
quote_identifiers=False,
|
700
|
+
table_name=self._full_results_table_name,
|
701
|
+
auto_create_table=False
|
702
|
+
)
|
703
|
+
if not success:
|
704
|
+
raise ValueError(
|
705
|
+
f"Failed to write results to table {self._full_results_table_name}"
|
706
|
+
)
|
707
|
+
logger.info(
|
708
|
+
f"Wrote {nrows} rows and {nchunks} chunks to table {self._full_results_table_name}"
|
709
|
+
)
|
710
|
+
return
|
711
|
+
except Exception as e:
|
712
|
+
if 'is being committed' not in str(e):
|
713
|
+
raise e
|
714
|
+
logger.error(
|
715
|
+
f"Transaction clash writing results to table {self._full_results_table_name}: {e}"
|
716
|
+
)
|
717
|
+
attempts_remaining -= 1
|
718
|
+
time.sleep(5)
|
719
|
+
raise ValueError(
|
720
|
+
f"Failed to write results to table {self._full_results_table_name} after {attempts_remaining} attempts"
|
706
721
|
)
|
707
722
|
|
708
723
|
def __dataframe_wrapper(
|
@@ -948,8 +963,6 @@ class InboundSyncRequest(SyncRequest):
|
|
948
963
|
for stream_name in stream_names:
|
949
964
|
self._apply_results[stream_name] = None
|
950
965
|
self._apply_results = {}
|
951
|
-
# update the inbound stream record counts, so we can see progress
|
952
|
-
self.apply_progress_updates()
|
953
966
|
|
954
967
|
# also take care of uploading delete requests
|
955
968
|
if hasattr(self,'_apply_results_criteria_deletes') and self._apply_results_criteria_deletes is not None:
|
@@ -969,6 +982,12 @@ class InboundSyncRequest(SyncRequest):
|
|
969
982
|
self._apply_criteria_deletes_dataframe(all_dfs)
|
970
983
|
# clear the delete requests
|
971
984
|
self._apply_results_criteria_deletes = {}
|
985
|
+
|
986
|
+
|
987
|
+
# update the inbound stream record counts, so we can see progress
|
988
|
+
# we do this last, because marking a stream as completed will cause the sync engine to process it
|
989
|
+
# so we need to make sure all the results are applied first
|
990
|
+
self.apply_progress_updates()
|
972
991
|
|
973
992
|
def apply_progress_updates(self):
|
974
993
|
"""
|
@@ -1308,34 +1327,49 @@ class InboundSyncRequest(SyncRequest):
|
|
1308
1327
|
"""
|
1309
1328
|
if len(results_df) > 0:
|
1310
1329
|
with self._snowflake_query_lock:
|
1311
|
-
|
1312
|
-
|
1313
|
-
|
1314
|
-
|
1315
|
-
|
1316
|
-
|
1317
|
-
|
1318
|
-
|
1319
|
-
|
1320
|
-
|
1321
|
-
|
1322
|
-
|
1323
|
-
|
1324
|
-
|
1325
|
-
|
1326
|
-
|
1327
|
-
|
1328
|
-
|
1330
|
+
attempts_remaining = 12
|
1331
|
+
while attempts_remaining > 0:
|
1332
|
+
try:
|
1333
|
+
logger.info(
|
1334
|
+
f"Applying {len(results_df)} results to {self._full_results_table_name}"
|
1335
|
+
)
|
1336
|
+
# try setting parquet engine here, since the engine parameter does not seem to make it through to the write_pandas function
|
1337
|
+
success, nchunks, nrows, _ = write_pandas(
|
1338
|
+
conn=self._session._conn._cursor.connection, # pylint: disable=protected-access
|
1339
|
+
df=results_df,
|
1340
|
+
table_name=self._full_results_table_name,
|
1341
|
+
quote_identifiers=False, # already done in get_temp_table_name
|
1342
|
+
# schema='INBOUND_RAW', # it seems to be ok to provide schema in the table name
|
1343
|
+
table_type="transient"
|
1344
|
+
)
|
1345
|
+
if not success:
|
1346
|
+
raise ValueError(
|
1347
|
+
f"Failed to write results to table {self._full_results_table_name}"
|
1348
|
+
)
|
1349
|
+
logger.info(
|
1350
|
+
f"Wrote {nrows} rows and {nchunks} chunks to table {self._full_results_table_name}"
|
1351
|
+
)
|
1352
|
+
# temp tables aren't allowed
|
1353
|
+
# snowflake_df = self._session.create_dataframe(results_df)
|
1354
|
+
# snowflake_df.write.save_as_table(table_name=temp_table,
|
1355
|
+
# mode='append',
|
1356
|
+
# column_order='index',
|
1357
|
+
# #create_temp_table=True
|
1358
|
+
# )
|
1359
|
+
for stream_name in stream_names:
|
1360
|
+
self._results_exist[stream_name] = True
|
1361
|
+
return
|
1362
|
+
except Exception as e:
|
1363
|
+
if 'is being committed' not in str(e):
|
1364
|
+
raise e
|
1365
|
+
logger.error(
|
1366
|
+
f"Transaction clash writing results to table {self._full_results_table_name}: {e}"
|
1367
|
+
)
|
1368
|
+
attempts_remaining -= 1
|
1369
|
+
time.sleep(5)
|
1370
|
+
raise ValueError(
|
1371
|
+
f"Failed to write results to table {self._full_results_table_name} after {attempts_remaining} attempts"
|
1329
1372
|
)
|
1330
|
-
# temp tables aren't allowed
|
1331
|
-
# snowflake_df = self._session.create_dataframe(results_df)
|
1332
|
-
# snowflake_df.write.save_as_table(table_name=temp_table,
|
1333
|
-
# mode='append',
|
1334
|
-
# column_order='index',
|
1335
|
-
# #create_temp_table=True
|
1336
|
-
# )
|
1337
|
-
for stream_name in stream_names:
|
1338
|
-
self._results_exist[stream_name] = True
|
1339
1373
|
else:
|
1340
1374
|
logger.info("Results dataframe is empty, not applying")
|
1341
1375
|
|
@@ -1353,23 +1387,38 @@ class InboundSyncRequest(SyncRequest):
|
|
1353
1387
|
"""
|
1354
1388
|
if len(results_df) > 0:
|
1355
1389
|
with self._snowflake_query_lock:
|
1356
|
-
|
1357
|
-
|
1358
|
-
|
1359
|
-
|
1360
|
-
|
1361
|
-
|
1362
|
-
|
1363
|
-
|
1364
|
-
|
1365
|
-
|
1366
|
-
|
1367
|
-
|
1368
|
-
|
1369
|
-
|
1370
|
-
|
1371
|
-
|
1372
|
-
|
1390
|
+
attempts_remaining = 12
|
1391
|
+
while attempts_remaining > 0:
|
1392
|
+
try:
|
1393
|
+
logger.info(
|
1394
|
+
f"Applying {len(results_df)} criteria deletes to {self._criteria_deletes_table_name}"
|
1395
|
+
)
|
1396
|
+
# try setting parquet engine here, since the engine parameter does not seem to make it through to the write_pandas function
|
1397
|
+
success, nchunks, nrows, _ = write_pandas(
|
1398
|
+
conn=self._session._conn._cursor.connection, # pylint: disable=protected-access
|
1399
|
+
df=results_df,
|
1400
|
+
table_name=self._criteria_deletes_table_name,
|
1401
|
+
quote_identifiers=False, # already done in get_temp_table_name
|
1402
|
+
table_type="transient"
|
1403
|
+
)
|
1404
|
+
if not success:
|
1405
|
+
raise ValueError(
|
1406
|
+
f"Failed to write results to table {self._criteria_deletes_table_name}"
|
1407
|
+
)
|
1408
|
+
logger.info(
|
1409
|
+
f"Wrote {nrows} rows and {nchunks} chunks to table {self._criteria_deletes_table_name}"
|
1410
|
+
)
|
1411
|
+
return
|
1412
|
+
except Exception as e:
|
1413
|
+
if 'is being committed' not in str(e):
|
1414
|
+
raise e
|
1415
|
+
logger.error(
|
1416
|
+
f"Transaction clash writing results to table {self._full_results_table_name}: {e}"
|
1417
|
+
)
|
1418
|
+
attempts_remaining -= 1
|
1419
|
+
time.sleep(5)
|
1420
|
+
raise ValueError(
|
1421
|
+
f"Failed to write results to table {self._full_results_table_name} after {attempts_remaining} attempts"
|
1373
1422
|
)
|
1374
1423
|
else:
|
1375
1424
|
logger.info("Results dataframe is empty, not applying")
|
{omnata_plugin_runtime-0.4.0a88.dist-info → omnata_plugin_runtime-0.4.0a90.dist-info}/RECORD
RENAMED
@@ -3,10 +3,10 @@ omnata_plugin_runtime/api.py,sha256=W79CsAcl127Dzy-XVS9CzvzsbS3IigVH4QAhFFDkaXg,
|
|
3
3
|
omnata_plugin_runtime/configuration.py,sha256=7cMekoY8CeZAJHpASU6tCMidF55Hzfr7CD74jtebqIY,35742
|
4
4
|
omnata_plugin_runtime/forms.py,sha256=pw_aKVsXSz47EP8PFBI3VDwdSN5IjvZxp8JTjO1V130,18421
|
5
5
|
omnata_plugin_runtime/logging.py,sha256=bn7eKoNWvtuyTk7RTwBS9UARMtqkiICtgMtzq3KA2V0,3272
|
6
|
-
omnata_plugin_runtime/omnata_plugin.py,sha256=
|
6
|
+
omnata_plugin_runtime/omnata_plugin.py,sha256=mJ5NHtenbLpkN0w9JSfb3jQVFShi8RDnsePAoF75b5E,108444
|
7
7
|
omnata_plugin_runtime/plugin_entrypoints.py,sha256=D2f0Qih7KTJNXIDYkA-E55RTEK_7Jtv9ySqspWxERVA,28272
|
8
8
|
omnata_plugin_runtime/rate_limiting.py,sha256=29Hjsr0i1rE8jERVdIFGINfQfp_kI3PDft-IM_ZxvCA,21509
|
9
|
-
omnata_plugin_runtime-0.4.
|
10
|
-
omnata_plugin_runtime-0.4.
|
11
|
-
omnata_plugin_runtime-0.4.
|
12
|
-
omnata_plugin_runtime-0.4.
|
9
|
+
omnata_plugin_runtime-0.4.0a90.dist-info/LICENSE,sha256=IMF9i4xIpgCADf0U-V1cuf9HBmqWQd3qtI3FSuyW4zE,26526
|
10
|
+
omnata_plugin_runtime-0.4.0a90.dist-info/METADATA,sha256=WxKUgmiDnEV4ytmWaB6uHuSi1hA9tFXSnxIIuKta2hI,1603
|
11
|
+
omnata_plugin_runtime-0.4.0a90.dist-info/WHEEL,sha256=sP946D7jFCHeNz5Iq4fL4Lu-PrWrFsgfLXbbkciIZwg,88
|
12
|
+
omnata_plugin_runtime-0.4.0a90.dist-info/RECORD,,
|
{omnata_plugin_runtime-0.4.0a88.dist-info → omnata_plugin_runtime-0.4.0a90.dist-info}/LICENSE
RENAMED
File without changes
|
File without changes
|