Skip to content

Commit

Permalink
Merge pull request #831 from dyvenia/dev
Browse files Browse the repository at this point in the history
Release 0.4.24 PR
  • Loading branch information
Rafalz13 authored Dec 8, 2023
2 parents b4e3156 + aace238 commit 48c14c0
Show file tree
Hide file tree
Showing 6 changed files with 37 additions and 20 deletions.
5 changes: 5 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,11 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0

### Changed

## [0.4.24] - 2023-12-08
### Fixed
- `task_utils/get_nested_value` fixed issue with non dict parameter passed without level(1st workflow)


## [0.4.23] - 2023-12-07
### Added
- Added tests for new functionalities in SAPRFC and SAPRFCV2 regarding passing credentials.
Expand Down
27 changes: 15 additions & 12 deletions tests/integration/flows/test_sharepoint_to_adls.py
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
import os
from unittest import mock

import logging
import pandas as pd
import pendulum
import pytest
Expand Down Expand Up @@ -224,23 +225,25 @@ def test_sharepoint_list_to_adls_run_flow_success_on_no_data_returned(mocked_cla
)
@pytest.mark.run
def test_sharepoint_list_to_adls_run_flow_success_warn_on_no_data_returned(
mocked_class,
mocked_class, caplog
):
"""
Test will check if flow is failing when empty DF is passed
with the given parameter if_no_data_returned = "warn"
CSV file should not be generated!
"""
# Get prefect client instance
flow = SharepointListToADLS(
"test_sharepoint_to_adls_run_flow",
output_file_extension=".csv",
adls_sp_credentials_secret=CREDENTIALS_SECRET,
adls_dir_path=ADLS_DIR_PATH,
file_name=ADLS_FILE_NAME_LIST,
list_title="",
site_url="",
if_no_data_returned="warn",
)
result = flow.run()
with caplog.at_level(logging.WARNING):
flow = SharepointListToADLS(
"test_sharepoint_to_adls_run_flow",
output_file_extension=".csv",
adls_sp_credentials_secret=CREDENTIALS_SECRET,
adls_dir_path=ADLS_DIR_PATH,
file_name=ADLS_FILE_NAME_LIST,
list_title="",
site_url="",
if_no_data_returned="warn",
)
result = flow.run()
assert "No data in the source response. Df empty." in caplog.text
assert result.is_successful()
2 changes: 1 addition & 1 deletion tests/test_viadot.py
Original file line number Diff line number Diff line change
Expand Up @@ -2,4 +2,4 @@


def test_version():
assert __version__ == "0.4.23"
assert __version__ == "0.4.24"
6 changes: 6 additions & 0 deletions tests/unit/test_utils.py
Original file line number Diff line number Diff line change
Expand Up @@ -315,3 +315,9 @@ def test_get_nested_value_without_levels(nested_dict):
"searched_phrase_3": "Found it!",
}
assert result_2 == {"searched_phrase_2": "Found it_2!"}


def test_get_nested_value_non_dict_passed():
"""Sample test checking the correctness of the function when non dict value (int) is provided."""

assert get_nested_value(nested_dict=5) == None
2 changes: 1 addition & 1 deletion viadot/__init__.py
Original file line number Diff line number Diff line change
@@ -1 +1 @@
__version__ = "0.4.23"
__version__ = "0.4.24"
15 changes: 9 additions & 6 deletions viadot/utils.py
Original file line number Diff line number Diff line change
Expand Up @@ -491,13 +491,16 @@ def get_nested_value(
else:
return nested_dict[lvl]
else:
for lvl in nested_dict.values():
if isinstance(lvl, dict):
return get_nested_value(nested_dict=lvl)
else:
return nested_dict
if isinstance(nested_dict, dict):
for lvl in nested_dict.values():
if isinstance(lvl, dict):
return get_nested_value(nested_dict=lvl)
else:
return nested_dict
else:
return None
except KeyError as e:
return None
except TypeError as e:
except (TypeError, AttributeError) as e:
logger.error(f"The 'nested_dict' must be a dictionary. {e}")
return None

0 comments on commit 48c14c0

Please sign in to comment.