From 0ad6ab17462ff80d3ae7b9c91593dba0997cfa02 Mon Sep 17 00:00:00 2001 From: Anders Albert <60234212+doctrino@users.noreply.github.com> Date: Thu, 30 May 2024 08:25:18 +0200 Subject: [PATCH] Fix type hint to transformations.preview (#1784) --- CHANGELOG.md | 4 +++ .../client/_api/transformations/__init__.py | 32 ++++++++++++++++--- cognite/client/_version.py | 2 +- pyproject.toml | 2 +- 4 files changed, 34 insertions(+), 6 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index d9b23245e3..4817913764 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -17,6 +17,10 @@ Changes are grouped as follows - `Fixed` for any bug fixes. - `Security` in case of vulnerabilities. +## [7.44.1] - 2024-05-24 +### Added +- Missing parameter `timeout` to `client.transformations.preview`. + ## [7.44.0] - 2024-05-24 ### Added - New utility function `datetime_to_ms_iso_timestamp` in `cognite.client.utils` to convert a datetime object to a string representing a timestamp in the format expected by the Cognite GraphQL API. diff --git a/cognite/client/_api/transformations/__init__.py b/cognite/client/_api/transformations/__init__.py index d57a94fae2..9087e46a66 100644 --- a/cognite/client/_api/transformations/__init__.py +++ b/cognite/client/_api/transformations/__init__.py @@ -502,18 +502,20 @@ def preview( self, query: str | None = None, convert_to_string: bool = False, - limit: int = 100, + limit: int | None = 100, source_limit: int | None = 100, - infer_schema_limit: int | None = 1000, + infer_schema_limit: int | None = 10_000, + timeout: int | None = 240, ) -> TransformationPreviewResult: """`Preview the result of a query. `_ Args: query (str | None): SQL query to run for preview. convert_to_string (bool): Stringify values in the query results, default is False. - limit (int): Maximum number of rows to return in the final result, default is 100. + limit (int | None): Maximum number of rows to return in the final result, default is 100. source_limit (int | None): Maximum number of items to read from the data source or None to run without limit, default is 100. - infer_schema_limit (int | None): Limit for how many rows that are used for inferring result schema, default is 1000. + infer_schema_limit (int | None): Limit for how many rows that are used for inferring result schema, default is 10 000. + timeout (int | None): Number of seconds to wait before cancelling a query. The default, and maximum, is 240. Returns: TransformationPreviewResult: Result of the executed query @@ -533,6 +535,27 @@ def preview( >>> client = CogniteClient() >>> >>> df = client.transformations.preview(query="select * from _cdf.assets").to_pandas() + + Notice that the results are limited both by the `limit` and `source_limit` parameters. If you have + a query that converts one source row to one result row, you may need to increase the `source_limit`. + For example, given that you have a query that reads from a raw table with 10,903 rows + + >>> from cognite.client import CogniteClient + >>> client = CogniteClient() + >>> + >>> result = client.transformations.preview(query="select * from my_raw_db.my_raw_table", limit=None) + >>> print(result.results) + 100 + + To get all rows, you also need to set the `source_limit` to None: + + >>> from cognite.client import CogniteClient + >>> client = CogniteClient() + >>> + >>> result = client.transformations.preview(query="select * from my_raw_db.my_raw_table", limit=None, source_limit=None) + >>> print(result.results) + 10903 + """ request_body = { "query": query, @@ -540,6 +563,7 @@ def preview( "limit": limit, "sourceLimit": source_limit, "inferSchemaLimit": infer_schema_limit, + "timeout": timeout, } response = self._post(url_path=self._RESOURCE_PATH + "/query/run", json=request_body) result = TransformationPreviewResult._load(response.json(), cognite_client=self._cognite_client) diff --git a/cognite/client/_version.py b/cognite/client/_version.py index fc8d726a68..7f93f0c66e 100644 --- a/cognite/client/_version.py +++ b/cognite/client/_version.py @@ -1,4 +1,4 @@ from __future__ import annotations -__version__ = "7.44.0" +__version__ = "7.44.1" __api_subversion__ = "20230101" diff --git a/pyproject.toml b/pyproject.toml index adacf30356..cd263d34e3 100644 --- a/pyproject.toml +++ b/pyproject.toml @@ -1,7 +1,7 @@ [tool.poetry] name = "cognite-sdk" -version = "7.44.0" +version = "7.44.1" description = "Cognite Python SDK" readme = "README.md" documentation = "https://cognite-sdk-python.readthedocs-hosted.com"