omnata-plugin-runtime 0.3.24a73__tar.gz → 0.3.24a74__tar.gz

Sign up to get free protection for your applications and to get access to all the features.
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: omnata-plugin-runtime
3
- Version: 0.3.24a73
3
+ Version: 0.3.24a74
4
4
  Summary: Classes and common runtime components for building and running Omnata Plugins
5
5
  Author: James Weakley
6
6
  Author-email: james.weakley@omnata.com
@@ -1,6 +1,6 @@
1
1
  [tool.poetry]
2
2
  name = "omnata-plugin-runtime"
3
- version = "0.3.24-a73"
3
+ version = "0.3.24-a74"
4
4
  description = "Classes and common runtime components for building and running Omnata Plugins"
5
5
  authors = ["James Weakley <james.weakley@omnata.com>"]
6
6
  readme = "README.md"
@@ -215,6 +215,7 @@ class SyncRequest(ABC):
215
215
  self._apply_results_task = None
216
216
  self._cancel_checking_task = None
217
217
  self._rate_limit_update_task = None
218
+ self._last_stream_progress_update = None
218
219
 
219
220
  threading.excepthook = self.thread_exception_hook
220
221
  if self.development_mode is False:
@@ -301,7 +302,7 @@ class SyncRequest(ABC):
301
302
  self.apply_cancellation()
302
303
  except Exception as e:
303
304
  logger.error(f"Error checking cancellation: {e}")
304
- cancellation_token.wait(10)
305
+ cancellation_token.wait(20)
305
306
  logger.info("cancel checking worker exiting")
306
307
 
307
308
  @abstractmethod
@@ -949,16 +950,18 @@ class InboundSyncRequest(SyncRequest):
949
950
 
950
951
  def apply_progress_updates(self):
951
952
  """
952
- Sends a message to the plugin with the current progress of the sync run.
953
+ Sends a message to the plugin with the current progress of the sync run, if it has changed since last time.
953
954
  """
954
- # TODO: Only send them if they have changed since last time
955
- self._plugin_message(
956
- message=PluginMessageStreamProgressUpdate(
955
+ new_progress_update = PluginMessageStreamProgressUpdate(
957
956
  stream_total_counts=self._stream_record_counts,
958
957
  completed_streams=self._completed_streams,
959
958
  stream_errors=self._omnata_log_handler.stream_global_errors
960
959
  )
961
- )
960
+ if self._last_stream_progress_update is None or new_progress_update != self._last_stream_progress_update:
961
+ self._plugin_message(
962
+ message=new_progress_update
963
+ )
964
+ self._last_stream_progress_update = new_progress_update
962
965
 
963
966
  def apply_cancellation(self):
964
967
  """
@@ -1223,8 +1226,6 @@ class InboundSyncRequest(SyncRequest):
1223
1226
  raise ValueError(
1224
1227
  f"Primary key field '{primary_key_field}' was not present in all records for stream {stream_name}"
1225
1228
  )
1226
- # TODO: handle the scenario where the primary key field is a list, and concatenate the values to form the APP_IDENTIFIER
1227
- # Currently this is only implemented in the java runtime, since it's typically databases that use composite keys
1228
1229
  results_df["APP_IDENTIFIER"] = results_df["RECORD_DATA"].apply(lambda x: get_nested_value(dict(x),primary_key_field))
1229
1230
  # ensure APP_IDENTIFIER is a string
1230
1231
  results_df["APP_IDENTIFIER"] = results_df["APP_IDENTIFIER"].apply(str)