Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Wfbench #189

Merged
merged 6 commits into from
Dec 20, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
3 changes: 3 additions & 0 deletions .github/workflows/create-release-n-publish.yml
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,9 @@ jobs:
build:
name: Create Release and Publish
runs-on: ubuntu-latest
env:
MONGO_ENABLED: false
LMDB_ENABLED: true
timeout-minutes: 60
steps:
- name: Checkout code
Expand Down
Original file line number Diff line number Diff line change
@@ -1,11 +1,14 @@
name: (With and Without Mongo) Tests on py11
name: With and Without Mongo at the same time
on: [pull_request]

jobs:

build:
runs-on: ubuntu-latest
timeout-minutes: 40
strategy:
matrix:
python-version: [ "3.10", "3.11", "3.12" ]
env:
MONGO_ENABLED: true
LMDB_ENABLED: true
Expand All @@ -17,10 +20,10 @@ jobs:
with:
fetch-depth: 1

- name: Set up Python 3.11
- name: Set up Python ${{ matrix.python-version }}
uses: actions/setup-python@v5
with:
python-version: "3.11"
python-version: ${{ matrix.python-version }}
cache: "pip"

- name: Show OS Info
Expand Down
2 changes: 1 addition & 1 deletion .github/workflows/run-tests-in-container.yml
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
name: (With and Without Mongo) Tests inside a Container Tests inside a Container
name: (With and Without Mongo) Inside a Container
on: [pull_request]

jobs:
Expand Down
7 changes: 5 additions & 2 deletions .github/workflows/run-tests-kafka.yml
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,9 @@ jobs:

build:
runs-on: ubuntu-latest
strategy:
matrix:
python-version: [ "3.10", "3.11", "3.12" ]
env:
MONGO_ENABLED: true
LMDB_ENABLED: false
Expand All @@ -21,10 +24,10 @@ jobs:
with:
fetch-depth: 1

- name: Set up Python 3.10
- name: Set up Python ${{ matrix.python-version }}
uses: actions/setup-python@v5
with:
python-version: "3.10"
python-version: ${{ matrix.python-version }}
cache: "pip"

- name: Run docker compose
Expand Down
56 changes: 0 additions & 56 deletions .github/workflows/run-tests-py11-simple.yml

This file was deleted.

90 changes: 0 additions & 90 deletions .github/workflows/run-tests-py11.yml

This file was deleted.

7 changes: 5 additions & 2 deletions .github/workflows/run-tests-simple.yml
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,9 @@ jobs:

build:
runs-on: ubuntu-latest
strategy:
matrix:
python-version: [ "3.10", "3.11", "3.12" ]
env:
MONGO_ENABLED: false
LMDB_ENABLED: true
Expand All @@ -19,10 +22,10 @@ jobs:
with:
fetch-depth: 1

- name: Set up Python 3.10
- name: Set up Python ${{ matrix.python-version }}
uses: actions/setup-python@v5
with:
python-version: "3.10"
python-version: ${{ matrix.python-version }}
cache: "pip"

- name: Show OS Info
Expand Down
9 changes: 6 additions & 3 deletions .github/workflows/run-tests.yml
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
name: (With Mongo) Unit, integration, and notebook tests
name: Main Tests
on:
push:
schedule:
Expand All @@ -8,6 +8,9 @@ jobs:

build:
runs-on: ubuntu-latest
strategy:
matrix:
python-version: [ "3.10", "3.11", "3.12" ]
env:
MONGO_ENABLED: true
LMDB_ENABLED: false
Expand All @@ -19,10 +22,10 @@ jobs:
with:
fetch-depth: 1

- name: Set up Python 3.10
- name: Set up Python ${{ matrix.python-version }}
uses: actions/setup-python@v5
with:
python-version: "3.10"
python-version: ${{ matrix.python-version }}
cache: "pip"

- name: Show OS Info
Expand Down
2 changes: 1 addition & 1 deletion Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -25,7 +25,7 @@ checks:
ruff format --check src

reformat:
ruff check src --fix
ruff check src --fix --unsafe-fixes
ruff format src

# Remove cache directories and Sphinx build output
Expand Down
2 changes: 1 addition & 1 deletion pyproject.toml
Original file line number Diff line number Diff line change
Expand Up @@ -101,7 +101,7 @@ line-length = 100

[tool.ruff.lint]
extend-select = ["E501", "D"]
ignore = ["D200", "D212", "D105", "D401"]
ignore = ["D200", "D212", "D105", "D401", "D205", "D100"]

[tool.ruff.lint.pydocstyle]
convention = "numpy"
Expand Down
21 changes: 15 additions & 6 deletions src/flowcept/__init__.py
Original file line number Diff line number Diff line change
@@ -1,6 +1,5 @@
"""Flowcept package."""

from flowcept.configs import SETTINGS_PATH
from flowcept.version import __version__

from flowcept.commons.flowcept_dataclasses.workflow_object import (
Expand All @@ -19,6 +18,11 @@ def __getattr__(name):

return flowcept_task

elif name == "FlowceptTask":
from flowcept.instrumentation.task_capture import FlowceptTask

return FlowceptTask

elif name == "flowcept_torch":
from flowcept.instrumentation.flowcept_torch import flowcept_torch

Expand All @@ -34,6 +38,11 @@ def __getattr__(name):

return telemetry_flowcept_task

elif name == "lightweight_flowcept_task":
from flowcept.instrumentation.flowcept_task import lightweight_flowcept_task

return lightweight_flowcept_task

if name == "MLFlowInterceptor":
from flowcept.flowceptor.adapters.mlflow.mlflow_interceptor import (
MLFlowInterceptor,
Expand All @@ -58,12 +67,10 @@ def __getattr__(name):
)

return TensorboardInterceptor
elif name == "ZambezeInterceptor":
from flowcept.flowceptor.adapters.zambeze.zambeze_interceptor import (
ZambezeInterceptor,
)
elif name == "SETTINGS_PATH":
from configs import SETTINGS_PATH

return ZambezeInterceptor
return SETTINGS_PATH
elif name == "TaskQueryAPI":
from flowcept.flowcept_api.task_query_api import TaskQueryAPI

Expand All @@ -80,7 +87,9 @@ def __getattr__(name):
"TaskQueryAPI",
"flowcept_task",
"FlowceptLoop",
"FlowceptTask",
"telemetry_flowcept_task",
"lightweight_flowcept_task",
"Flowcept",
"flowcept_torch",
"WorkflowObject",
Expand Down
4 changes: 2 additions & 2 deletions src/flowcept/commons/daos/docdb_dao/lmdb_dao.py
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,7 @@

from flowcept import WorkflowObject
from flowcept.commons.daos.docdb_dao.docdb_dao_base import DocumentDBDAO
from flowcept.configs import PERF_LOG, DATABASES
from flowcept.configs import PERF_LOG, LMDB_SETTINGS
from flowcept.flowceptor.consumers.consumer_utils import curate_dict_task_messages


Expand All @@ -36,7 +36,7 @@ def __init__(self):

def _open(self):
"""Open LMDB environment and databases."""
_path = DATABASES.get("lmdb").get("path", "lmdb")
_path = LMDB_SETTINGS.get("path", "flowcept_lmdb")
self._env = lmdb.open(_path, map_size=10**12, max_dbs=2)
self._tasks_db = self._env.open_db(b"tasks")
self._workflows_db = self._env.open_db(b"workflows")
Expand Down
13 changes: 10 additions & 3 deletions src/flowcept/commons/flowcept_dataclasses/workflow_object.py
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@

from typing import Dict, AnyStr, List
import msgpack
from omegaconf import OmegaConf
from omegaconf import OmegaConf, DictConfig

from flowcept.version import __version__
from flowcept.commons.utils import get_utc_now
Expand Down Expand Up @@ -70,7 +70,9 @@ def to_dict(self):
def enrich(self, adapter_key=None):
"""Enrich it."""
self.utc_timestamp = get_utc_now()
self.flowcept_settings = OmegaConf.to_container(settings)
self.flowcept_settings = (
OmegaConf.to_container(settings) if isinstance(settings, DictConfig) else settings
)

if adapter_key is not None:
# TODO :base-interceptor-refactor: :code-reorg: :usability:
Expand All @@ -90,7 +92,12 @@ def enrich(self, adapter_key=None):
self.sys_name = SYS_NAME

if self.extra_metadata is None and EXTRA_METADATA is not None:
self.extra_metadata = OmegaConf.to_container(EXTRA_METADATA)
_extra_metadata = (
OmegaConf.to_container(EXTRA_METADATA)
if isinstance(EXTRA_METADATA, DictConfig)
else EXTRA_METADATA
)
self.extra_metadata = _extra_metadata

if self.flowcept_version is None:
self.flowcept_version = __version__
Expand Down
Loading
Loading