lmnr 0.4.27__tar.gz → 0.4.28__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 (51) hide show
  1. {lmnr-0.4.27 → lmnr-0.4.28}/PKG-INFO +1 -1
  2. {lmnr-0.4.27 → lmnr-0.4.28}/pyproject.toml +2 -2
  3. {lmnr-0.4.27 → lmnr-0.4.28}/src/lmnr/sdk/datasets.py +1 -1
  4. {lmnr-0.4.27 → lmnr-0.4.28}/src/lmnr/traceloop_sdk/tracing/attributes.py +1 -0
  5. {lmnr-0.4.27 → lmnr-0.4.28}/src/lmnr/traceloop_sdk/tracing/tracing.py +11 -6
  6. {lmnr-0.4.27 → lmnr-0.4.28}/LICENSE +0 -0
  7. {lmnr-0.4.27 → lmnr-0.4.28}/README.md +0 -0
  8. {lmnr-0.4.27 → lmnr-0.4.28}/src/lmnr/__init__.py +0 -0
  9. {lmnr-0.4.27 → lmnr-0.4.28}/src/lmnr/cli.py +0 -0
  10. {lmnr-0.4.27 → lmnr-0.4.28}/src/lmnr/sdk/__init__.py +0 -0
  11. {lmnr-0.4.27 → lmnr-0.4.28}/src/lmnr/sdk/decorators.py +0 -0
  12. {lmnr-0.4.27 → lmnr-0.4.28}/src/lmnr/sdk/evaluations.py +0 -0
  13. {lmnr-0.4.27 → lmnr-0.4.28}/src/lmnr/sdk/laminar.py +0 -0
  14. {lmnr-0.4.27 → lmnr-0.4.28}/src/lmnr/sdk/log.py +0 -0
  15. {lmnr-0.4.27 → lmnr-0.4.28}/src/lmnr/sdk/types.py +0 -0
  16. {lmnr-0.4.27 → lmnr-0.4.28}/src/lmnr/sdk/utils.py +0 -0
  17. {lmnr-0.4.27 → lmnr-0.4.28}/src/lmnr/traceloop_sdk/.flake8 +0 -0
  18. {lmnr-0.4.27 → lmnr-0.4.28}/src/lmnr/traceloop_sdk/.python-version +0 -0
  19. {lmnr-0.4.27 → lmnr-0.4.28}/src/lmnr/traceloop_sdk/__init__.py +0 -0
  20. {lmnr-0.4.27 → lmnr-0.4.28}/src/lmnr/traceloop_sdk/config/__init__.py +0 -0
  21. {lmnr-0.4.27 → lmnr-0.4.28}/src/lmnr/traceloop_sdk/decorators/__init__.py +0 -0
  22. {lmnr-0.4.27 → lmnr-0.4.28}/src/lmnr/traceloop_sdk/decorators/base.py +0 -0
  23. {lmnr-0.4.27 → lmnr-0.4.28}/src/lmnr/traceloop_sdk/instruments.py +0 -0
  24. {lmnr-0.4.27 → lmnr-0.4.28}/src/lmnr/traceloop_sdk/tests/__init__.py +0 -0
  25. {lmnr-0.4.27 → lmnr-0.4.28}/src/lmnr/traceloop_sdk/tests/cassettes/test_association_properties/test_langchain_and_external_association_properties.yaml +0 -0
  26. {lmnr-0.4.27 → lmnr-0.4.28}/src/lmnr/traceloop_sdk/tests/cassettes/test_association_properties/test_langchain_association_properties.yaml +0 -0
  27. {lmnr-0.4.27 → lmnr-0.4.28}/src/lmnr/traceloop_sdk/tests/cassettes/test_manual/test_manual_report.yaml +0 -0
  28. {lmnr-0.4.27 → lmnr-0.4.28}/src/lmnr/traceloop_sdk/tests/cassettes/test_manual/test_resource_attributes.yaml +0 -0
  29. {lmnr-0.4.27 → lmnr-0.4.28}/src/lmnr/traceloop_sdk/tests/cassettes/test_privacy_no_prompts/test_simple_workflow.yaml +0 -0
  30. {lmnr-0.4.27 → lmnr-0.4.28}/src/lmnr/traceloop_sdk/tests/cassettes/test_prompt_management/test_prompt_management.yaml +0 -0
  31. {lmnr-0.4.27 → lmnr-0.4.28}/src/lmnr/traceloop_sdk/tests/cassettes/test_sdk_initialization/test_resource_attributes.yaml +0 -0
  32. {lmnr-0.4.27 → lmnr-0.4.28}/src/lmnr/traceloop_sdk/tests/cassettes/test_tasks/test_task_io_serialization_with_langchain.yaml +0 -0
  33. {lmnr-0.4.27 → lmnr-0.4.28}/src/lmnr/traceloop_sdk/tests/cassettes/test_workflows/test_simple_aworkflow.yaml +0 -0
  34. {lmnr-0.4.27 → lmnr-0.4.28}/src/lmnr/traceloop_sdk/tests/cassettes/test_workflows/test_simple_workflow.yaml +0 -0
  35. {lmnr-0.4.27 → lmnr-0.4.28}/src/lmnr/traceloop_sdk/tests/cassettes/test_workflows/test_streaming_workflow.yaml +0 -0
  36. {lmnr-0.4.27 → lmnr-0.4.28}/src/lmnr/traceloop_sdk/tests/conftest.py +0 -0
  37. {lmnr-0.4.27 → lmnr-0.4.28}/src/lmnr/traceloop_sdk/tests/test_association_properties.py +0 -0
  38. {lmnr-0.4.27 → lmnr-0.4.28}/src/lmnr/traceloop_sdk/tests/test_manual.py +0 -0
  39. {lmnr-0.4.27 → lmnr-0.4.28}/src/lmnr/traceloop_sdk/tests/test_nested_tasks.py +0 -0
  40. {lmnr-0.4.27 → lmnr-0.4.28}/src/lmnr/traceloop_sdk/tests/test_privacy_no_prompts.py +0 -0
  41. {lmnr-0.4.27 → lmnr-0.4.28}/src/lmnr/traceloop_sdk/tests/test_sdk_initialization.py +0 -0
  42. {lmnr-0.4.27 → lmnr-0.4.28}/src/lmnr/traceloop_sdk/tests/test_tasks.py +0 -0
  43. {lmnr-0.4.27 → lmnr-0.4.28}/src/lmnr/traceloop_sdk/tests/test_workflows.py +0 -0
  44. {lmnr-0.4.27 → lmnr-0.4.28}/src/lmnr/traceloop_sdk/tracing/__init__.py +0 -0
  45. {lmnr-0.4.27 → lmnr-0.4.28}/src/lmnr/traceloop_sdk/tracing/content_allow_list.py +0 -0
  46. {lmnr-0.4.27 → lmnr-0.4.28}/src/lmnr/traceloop_sdk/tracing/context_manager.py +0 -0
  47. {lmnr-0.4.27 → lmnr-0.4.28}/src/lmnr/traceloop_sdk/utils/__init__.py +0 -0
  48. {lmnr-0.4.27 → lmnr-0.4.28}/src/lmnr/traceloop_sdk/utils/in_memory_span_exporter.py +0 -0
  49. {lmnr-0.4.27 → lmnr-0.4.28}/src/lmnr/traceloop_sdk/utils/json_encoder.py +0 -0
  50. {lmnr-0.4.27 → lmnr-0.4.28}/src/lmnr/traceloop_sdk/utils/package_check.py +0 -0
  51. {lmnr-0.4.27 → lmnr-0.4.28}/src/lmnr/traceloop_sdk/version.py +0 -0
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: lmnr
3
- Version: 0.4.27
3
+ Version: 0.4.28
4
4
  Summary: Python SDK for Laminar AI
5
5
  License: Apache-2.0
6
6
  Author: lmnr.ai
@@ -1,6 +1,6 @@
1
1
  [project]
2
2
  name = "lmnr"
3
- version = "0.4.27"
3
+ version = "0.4.28"
4
4
  description = "Python SDK for Laminar AI"
5
5
  authors = [
6
6
  { name = "lmnr.ai", email = "founders@lmnr.ai" }
@@ -11,7 +11,7 @@ license = "Apache-2.0"
11
11
 
12
12
  [tool.poetry]
13
13
  name = "lmnr"
14
- version = "0.4.27"
14
+ version = "0.4.28"
15
15
  description = "Python SDK for Laminar AI"
16
16
  authors = ["lmnr.ai"]
17
17
  readme = "README.md"
@@ -34,7 +34,7 @@ class LaminarDataset(EvaluationDataset):
34
34
  self._fetched_items = []
35
35
  self._offset = 0
36
36
  self._fetch_size = fetch_size
37
- self._logger = get_default_logger(self.__class__.__name__, level=logging.DEBUG)
37
+ self._logger = get_default_logger(self.__class__.__name__)
38
38
 
39
39
  def _fetch_batch(self):
40
40
  self._logger.debug(
@@ -5,6 +5,7 @@ SPAN_INPUT = "lmnr.span.input"
5
5
  SPAN_OUTPUT = "lmnr.span.output"
6
6
  SPAN_TYPE = "lmnr.span.type"
7
7
  SPAN_PATH = "lmnr.span.path"
8
+ SPAN_INSTRUMENTATION_SOURCE = "lmnr.span.instrumentation_source"
8
9
 
9
10
  ASSOCIATION_PROPERTIES = "lmnr.association.properties"
10
11
  SESSION_ID = "session_id"
@@ -25,7 +25,11 @@ from opentelemetry.instrumentation.threading import ThreadingInstrumentor
25
25
 
26
26
  # from lmnr.traceloop_sdk import Telemetry
27
27
  from lmnr.traceloop_sdk.instruments import Instruments
28
- from lmnr.traceloop_sdk.tracing.attributes import ASSOCIATION_PROPERTIES, SPAN_PATH
28
+ from lmnr.traceloop_sdk.tracing.attributes import (
29
+ ASSOCIATION_PROPERTIES,
30
+ SPAN_INSTRUMENTATION_SOURCE,
31
+ SPAN_PATH,
32
+ )
29
33
  from lmnr.traceloop_sdk.tracing.content_allow_list import ContentAllowList
30
34
  from lmnr.traceloop_sdk.utils import is_notebook
31
35
  from lmnr.traceloop_sdk.utils.package_check import is_package_installed
@@ -235,6 +239,8 @@ class TracerWrapper(object):
235
239
  # the final part of the name to the span on the backend.
236
240
  span.set_attribute(SPAN_PATH, span_path)
237
241
 
242
+ span.set_attribute(SPAN_INSTRUMENTATION_SOURCE, "python")
243
+
238
244
  association_properties = get_value("association_properties")
239
245
  if association_properties is not None:
240
246
  _set_association_properties_attributes(span, association_properties)
@@ -266,10 +272,7 @@ class TracerWrapper(object):
266
272
  if hasattr(cls, "instance"):
267
273
  return True
268
274
 
269
- if (os.getenv("TRACELOOP_SUPPRESS_WARNINGS") or "false").lower() == "true":
270
- return False
271
-
272
- print("Warning: Laminar not initialized, make sure to initialize")
275
+ logging.warning("Warning: Laminar not initialized, make sure to initialize")
273
276
  return False
274
277
 
275
278
  def flush(self):
@@ -557,7 +560,9 @@ def init_langchain_instrumentor():
557
560
  instrumentor.instrument()
558
561
  return True
559
562
  except Exception as e:
560
- logging.error(f"Error initializing LangChain instrumentor: {e}")
563
+ # FIXME: silence this error temporarily, it appears to not be critical
564
+ if str(e) != "No module named 'langchain_community'":
565
+ logging.error(f"Error initializing LangChain instrumentor: {e}")
561
566
  # Telemetry().log_exception(e)
562
567
  return False
563
568
 
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes