openmodule 18.1.1__tar.gz → 18.1.2__tar.gz

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.
Files changed (106) hide show
  1. {openmodule-18.1.1 → openmodule-18.1.2}/PKG-INFO +1 -1
  2. {openmodule-18.1.1 → openmodule-18.1.2}/openmodule/core.py +8 -7
  3. {openmodule-18.1.1 → openmodule-18.1.2}/openmodule/database/database.py +6 -6
  4. {openmodule-18.1.1 → openmodule-18.1.2}/openmodule/health.py +1 -0
  5. {openmodule-18.1.1 → openmodule-18.1.2}/openmodule.egg-info/PKG-INFO +1 -1
  6. {openmodule-18.1.1 → openmodule-18.1.2}/LICENSE +0 -0
  7. {openmodule-18.1.1 → openmodule-18.1.2}/README.md +0 -0
  8. {openmodule-18.1.1 → openmodule-18.1.2}/openmodule/__init__.py +0 -0
  9. {openmodule-18.1.1 → openmodule-18.1.2}/openmodule/alert.py +0 -0
  10. {openmodule-18.1.1 → openmodule-18.1.2}/openmodule/config.py +0 -0
  11. {openmodule-18.1.1 → openmodule-18.1.2}/openmodule/connection_status.py +0 -0
  12. {openmodule-18.1.1 → openmodule-18.1.2}/openmodule/database/__init__.py +0 -0
  13. {openmodule-18.1.1 → openmodule-18.1.2}/openmodule/database/custom_types.py +0 -0
  14. {openmodule-18.1.1 → openmodule-18.1.2}/openmodule/database/env.py +0 -0
  15. {openmodule-18.1.1 → openmodule-18.1.2}/openmodule/database/migration.py +0 -0
  16. {openmodule-18.1.1 → openmodule-18.1.2}/openmodule/dispatcher.py +0 -0
  17. {openmodule-18.1.1 → openmodule-18.1.2}/openmodule/logging.py +0 -0
  18. {openmodule-18.1.1 → openmodule-18.1.2}/openmodule/messaging.py +0 -0
  19. {openmodule-18.1.1 → openmodule-18.1.2}/openmodule/models/__init__.py +0 -0
  20. {openmodule-18.1.1 → openmodule-18.1.2}/openmodule/models/access_service.py +0 -0
  21. {openmodule-18.1.1 → openmodule-18.1.2}/openmodule/models/alert.py +0 -0
  22. {openmodule-18.1.1 → openmodule-18.1.2}/openmodule/models/base.py +0 -0
  23. {openmodule-18.1.1 → openmodule-18.1.2}/openmodule/models/io.py +0 -0
  24. {openmodule-18.1.1 → openmodule-18.1.2}/openmodule/models/kv_store.py +0 -0
  25. {openmodule-18.1.1 → openmodule-18.1.2}/openmodule/models/pagination.py +0 -0
  26. {openmodule-18.1.1 → openmodule-18.1.2}/openmodule/models/presence.py +0 -0
  27. {openmodule-18.1.1 → openmodule-18.1.2}/openmodule/models/privacy.py +0 -0
  28. {openmodule-18.1.1 → openmodule-18.1.2}/openmodule/models/rpc.py +0 -0
  29. {openmodule-18.1.1 → openmodule-18.1.2}/openmodule/models/settings.py +0 -0
  30. {openmodule-18.1.1 → openmodule-18.1.2}/openmodule/models/signals.py +0 -0
  31. {openmodule-18.1.1 → openmodule-18.1.2}/openmodule/models/validation.py +0 -0
  32. {openmodule-18.1.1 → openmodule-18.1.2}/openmodule/models/vehicle.py +0 -0
  33. {openmodule-18.1.1 → openmodule-18.1.2}/openmodule/models/vehicle_listener.py +0 -0
  34. {openmodule-18.1.1 → openmodule-18.1.2}/openmodule/rpc/__init__.py +0 -0
  35. {openmodule-18.1.1 → openmodule-18.1.2}/openmodule/rpc/client.py +0 -0
  36. {openmodule-18.1.1 → openmodule-18.1.2}/openmodule/rpc/common.py +0 -0
  37. {openmodule-18.1.1 → openmodule-18.1.2}/openmodule/rpc/server.py +0 -0
  38. {openmodule-18.1.1 → openmodule-18.1.2}/openmodule/sentry.py +0 -0
  39. {openmodule-18.1.1 → openmodule-18.1.2}/openmodule/threading.py +0 -0
  40. {openmodule-18.1.1 → openmodule-18.1.2}/openmodule/utils/__init__.py +0 -0
  41. {openmodule-18.1.1 → openmodule-18.1.2}/openmodule/utils/access_service.py +0 -0
  42. {openmodule-18.1.1 → openmodule-18.1.2}/openmodule/utils/charset.py +0 -0
  43. {openmodule-18.1.1 → openmodule-18.1.2}/openmodule/utils/cleanup.py +0 -0
  44. {openmodule-18.1.1 → openmodule-18.1.2}/openmodule/utils/csv_export.py +0 -0
  45. {openmodule-18.1.1 → openmodule-18.1.2}/openmodule/utils/databox.py +0 -0
  46. {openmodule-18.1.1 → openmodule-18.1.2}/openmodule/utils/db_helper.py +0 -0
  47. {openmodule-18.1.1 → openmodule-18.1.2}/openmodule/utils/eventlog.py +0 -0
  48. {openmodule-18.1.1 → openmodule-18.1.2}/openmodule/utils/io.py +0 -0
  49. {openmodule-18.1.1 → openmodule-18.1.2}/openmodule/utils/kv_store.py +0 -0
  50. {openmodule-18.1.1 → openmodule-18.1.2}/openmodule/utils/matching.py +0 -0
  51. {openmodule-18.1.1 → openmodule-18.1.2}/openmodule/utils/misc_functions.py +0 -0
  52. {openmodule-18.1.1 → openmodule-18.1.2}/openmodule/utils/package_reader.py +0 -0
  53. {openmodule-18.1.1 → openmodule-18.1.2}/openmodule/utils/pagination.py +0 -0
  54. {openmodule-18.1.1 → openmodule-18.1.2}/openmodule/utils/presence.py +0 -0
  55. {openmodule-18.1.1 → openmodule-18.1.2}/openmodule/utils/schedule.py +0 -0
  56. {openmodule-18.1.1 → openmodule-18.1.2}/openmodule/utils/settings.py +0 -0
  57. {openmodule-18.1.1 → openmodule-18.1.2}/openmodule/utils/signal_listener.py +0 -0
  58. {openmodule-18.1.1 → openmodule-18.1.2}/openmodule/utils/translation.py +0 -0
  59. {openmodule-18.1.1 → openmodule-18.1.2}/openmodule/utils/validation.py +0 -0
  60. {openmodule-18.1.1 → openmodule-18.1.2}/openmodule/utils/vehicle_listener.py +0 -0
  61. {openmodule-18.1.1 → openmodule-18.1.2}/openmodule.egg-info/SOURCES.txt +0 -0
  62. {openmodule-18.1.1 → openmodule-18.1.2}/openmodule.egg-info/dependency_links.txt +0 -0
  63. {openmodule-18.1.1 → openmodule-18.1.2}/openmodule.egg-info/not-zip-safe +0 -0
  64. {openmodule-18.1.1 → openmodule-18.1.2}/openmodule.egg-info/requires.txt +0 -0
  65. {openmodule-18.1.1 → openmodule-18.1.2}/openmodule.egg-info/top_level.txt +0 -0
  66. {openmodule-18.1.1 → openmodule-18.1.2}/setup.cfg +0 -0
  67. {openmodule-18.1.1 → openmodule-18.1.2}/setup.py +0 -0
  68. {openmodule-18.1.1 → openmodule-18.1.2}/tests/test_alembic_migrations.py +0 -0
  69. {openmodule-18.1.1 → openmodule-18.1.2}/tests/test_alert.py +0 -0
  70. {openmodule-18.1.1 → openmodule-18.1.2}/tests/test_checks.py +0 -0
  71. {openmodule-18.1.1 → openmodule-18.1.2}/tests/test_config.py +0 -0
  72. {openmodule-18.1.1 → openmodule-18.1.2}/tests/test_connection_status.py +0 -0
  73. {openmodule-18.1.1 → openmodule-18.1.2}/tests/test_core.py +0 -0
  74. {openmodule-18.1.1 → openmodule-18.1.2}/tests/test_database.py +0 -0
  75. {openmodule-18.1.1 → openmodule-18.1.2}/tests/test_dispatcher.py +0 -0
  76. {openmodule-18.1.1 → openmodule-18.1.2}/tests/test_health.py +0 -0
  77. {openmodule-18.1.1 → openmodule-18.1.2}/tests/test_interrupt.py +0 -0
  78. {openmodule-18.1.1 → openmodule-18.1.2}/tests/test_io_listen.py +0 -0
  79. {openmodule-18.1.1 → openmodule-18.1.2}/tests/test_logging.py +0 -0
  80. {openmodule-18.1.1 → openmodule-18.1.2}/tests/test_messaging.py +0 -0
  81. {openmodule-18.1.1 → openmodule-18.1.2}/tests/test_mockrpcclient.py +0 -0
  82. {openmodule-18.1.1 → openmodule-18.1.2}/tests/test_model.py +0 -0
  83. {openmodule-18.1.1 → openmodule-18.1.2}/tests/test_rpc.py +0 -0
  84. {openmodule-18.1.1 → openmodule-18.1.2}/tests/test_sentry.py +0 -0
  85. {openmodule-18.1.1 → openmodule-18.1.2}/tests/test_test_alert.py +0 -0
  86. {openmodule-18.1.1 → openmodule-18.1.2}/tests/test_test_gate.py +0 -0
  87. {openmodule-18.1.1 → openmodule-18.1.2}/tests/test_test_zeromq.py +0 -0
  88. {openmodule-18.1.1 → openmodule-18.1.2}/tests/test_utils_access_service.py +0 -0
  89. {openmodule-18.1.1 → openmodule-18.1.2}/tests/test_utils_charset.py +0 -0
  90. {openmodule-18.1.1 → openmodule-18.1.2}/tests/test_utils_cleanup.py +0 -0
  91. {openmodule-18.1.1 → openmodule-18.1.2}/tests/test_utils_csv_export.py +0 -0
  92. {openmodule-18.1.1 → openmodule-18.1.2}/tests/test_utils_databox.py +0 -0
  93. {openmodule-18.1.1 → openmodule-18.1.2}/tests/test_utils_eventlog.py +0 -0
  94. {openmodule-18.1.1 → openmodule-18.1.2}/tests/test_utils_kv_store.py +0 -0
  95. {openmodule-18.1.1 → openmodule-18.1.2}/tests/test_utils_kv_store_multiple.py +0 -0
  96. {openmodule-18.1.1 → openmodule-18.1.2}/tests/test_utils_matching.py +0 -0
  97. {openmodule-18.1.1 → openmodule-18.1.2}/tests/test_utils_misc_functions.py +0 -0
  98. {openmodule-18.1.1 → openmodule-18.1.2}/tests/test_utils_package_reader.py +0 -0
  99. {openmodule-18.1.1 → openmodule-18.1.2}/tests/test_utils_pagination.py +0 -0
  100. {openmodule-18.1.1 → openmodule-18.1.2}/tests/test_utils_presence.py +0 -0
  101. {openmodule-18.1.1 → openmodule-18.1.2}/tests/test_utils_schedule.py +0 -0
  102. {openmodule-18.1.1 → openmodule-18.1.2}/tests/test_utils_settings.py +0 -0
  103. {openmodule-18.1.1 → openmodule-18.1.2}/tests/test_utils_signal.py +0 -0
  104. {openmodule-18.1.1 → openmodule-18.1.2}/tests/test_utils_validation.py +0 -0
  105. {openmodule-18.1.1 → openmodule-18.1.2}/tests/test_utils_vehicle.py +0 -0
  106. {openmodule-18.1.1 → openmodule-18.1.2}/tests/test_vehicle_listener.py +0 -0
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: openmodule
3
- Version: 18.1.1
3
+ Version: 18.1.2
4
4
  Summary: Libraries for developing the arivo openmodule
5
5
  Home-page: https://gitlab.com/arivo-public/device-python/openmodule.git
6
6
  Author: ARIVO
@@ -55,12 +55,13 @@ class OpenModuleCore(threading.Thread):
55
55
  self._messages_internal.register_handler("healthz", HealthPingMessage, self.health.process_message,
56
56
  match_type=True)
57
57
 
58
- def init_database(self):
58
+ def init_database(self, migration_timeout: float = 300):
59
59
  from openmodule.database.database import Database
60
60
  if self.config.TESTING:
61
- self.database = Database(self.config.DATABASE_FOLDER, self.config.NAME, alembic_path="../src/database")
61
+ self.database = Database(self.config.DATABASE_FOLDER, self.config.NAME, alembic_path="../src/database",
62
+ migration_timeout=migration_timeout)
62
63
  else:
63
- self.database = Database(self.config.DATABASE_FOLDER, self.config.NAME)
64
+ self.database = Database(self.config.DATABASE_FOLDER, self.config.NAME, migration_timeout=migration_timeout)
64
65
 
65
66
  def start(self) -> None:
66
67
  super().start()
@@ -153,9 +154,9 @@ def wait_for_misc(core: OpenModuleCore, timeout: float = 120, retry_time: float
153
154
 
154
155
 
155
156
  def init_openmodule(config, *, dsn: str = None, sentry=None, logging=True, dsgvo=True,
156
- health_handler: HealthHandlerType | None = None,
157
- context=None, database=False, catch_sigterm=True,
158
- dispatcher_max_threads=1, wait_for_broker=True, **sentry_kwargs) -> OpenModuleCore:
157
+ health_handler: HealthHandlerType | None = None, context=None, database=False, catch_sigterm=True,
158
+ dispatcher_max_threads=1, wait_for_broker=True, migration_timeout=300.0, **sentry_kwargs) \
159
+ -> OpenModuleCore:
159
160
  if health_handler:
160
161
  warnings.warn(
161
162
  "health_handler is deprecated, and will simply be ignored. Please use metrics "
@@ -208,7 +209,7 @@ def init_openmodule(config, *, dsn: str = None, sentry=None, logging=True, dsgvo
208
209
  _core_thread.health.health_handler = health_handler
209
210
 
210
211
  if database:
211
- _core_thread.init_database()
212
+ _core_thread.init_database(migration_timeout)
212
213
 
213
214
  if catch_sigterm and threading.current_thread().__class__.__name__ == "_MainThread":
214
215
  signal.signal(signal.SIGTERM, sigterm_handler)
@@ -47,7 +47,7 @@ def set_sqlite_pragma(dbapi_connection, connection_record):
47
47
  active_databases = {}
48
48
 
49
49
 
50
- def execute_migration(engine: Engine, alembic_path: Optional[str] = None):
50
+ def execute_migration(engine: Engine, alembic_path: Optional[str] = None, migration_timeout: float = 300):
51
51
  def isolated_migration_process():
52
52
  nonlocal engine, alembic_path
53
53
  from openmodule.database.migration import migrate_database
@@ -56,7 +56,7 @@ def execute_migration(engine: Engine, alembic_path: Optional[str] = None):
56
56
  p = MigrationProcess(target=isolated_migration_process)
57
57
  try:
58
58
  p.start()
59
- p.join(timeout=5 * 60) # default 5 min timeout -> exception/sentry in service
59
+ p.join(timeout=migration_timeout) # default 5 min timeout -> exception/sentry in service
60
60
  except ProcessError:
61
61
  raise
62
62
  finally:
@@ -78,7 +78,7 @@ def database_path(db_folder, db_name):
78
78
  return os.path.join(db_folder, db_name) + ".sqlite3"
79
79
 
80
80
 
81
- def get_database(db_folder: str, name: str, alembic_path: Optional[str] = None):
81
+ def get_database(db_folder: str, name: str, alembic_path: Optional[str] = None, migration_timeout: float = 300):
82
82
  global active_databases
83
83
  tmp = database_path(db_folder, name)
84
84
  assert active_databases.get(tmp) is None, f"database {tmp} already exists," \
@@ -88,7 +88,7 @@ def get_database(db_folder: str, name: str, alembic_path: Optional[str] = None):
88
88
  engine = create_engine(path, poolclass=StaticPool, connect_args={'check_same_thread': False})
89
89
 
90
90
  # migration executed in a separate process -> no alembic import in main process
91
- execute_migration(engine, alembic_path)
91
+ execute_migration(engine, alembic_path, migration_timeout)
92
92
 
93
93
  active_databases[tmp] = engine
94
94
 
@@ -124,10 +124,10 @@ class SessionWrapper(Session):
124
124
  class Database:
125
125
  active_session: Optional[Session]
126
126
 
127
- def __init__(self, database_folder, name="database", alembic_path=None):
127
+ def __init__(self, database_folder, name="database", alembic_path=None, migration_timeout: float = 300):
128
128
  self.db_folder = database_folder
129
129
  self.name = name
130
- self._engine = get_database(database_folder, name, alembic_path)
130
+ self._engine = get_database(database_folder, name, alembic_path, migration_timeout)
131
131
  self._session = sessionmaker(bind=self._engine, class_=SessionWrapper)
132
132
  self.active_session = None
133
133
  self.lock = threading.RLock()
@@ -249,6 +249,7 @@ class Healthz:
249
249
  metric = self.metrics.get(key)
250
250
  if not metric:
251
251
  self._metric_log_or_raise("Metric %s not found, the metric will not be set", key)
252
+ return
252
253
  if value is None:
253
254
  metric.values.pop(self._labels_string(labels), None)
254
255
  elif metric.type == HealthMetricType.count:
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: openmodule
3
- Version: 18.1.1
3
+ Version: 18.1.2
4
4
  Summary: Libraries for developing the arivo openmodule
5
5
  Home-page: https://gitlab.com/arivo-public/device-python/openmodule.git
6
6
  Author: ARIVO
File without changes
File without changes
File without changes
File without changes