From c0a0c4769db8269b94a5a9434fc36cfb2cdf9dc4 Mon Sep 17 00:00:00 2001 From: Nikita Rushmanov Date: Sat, 23 Nov 2024 23:29:05 +0000 Subject: [PATCH 1/2] Upgrade streamlit to >=1.30 --- setup.py | 2 +- streamlit_parameters/demos/parameters.py | 2 +- streamlit_parameters/parameters.py | 4 ++-- tests/test_parameters.py | 24 ++++++++++++------------ 4 files changed, 16 insertions(+), 16 deletions(-) diff --git a/setup.py b/setup.py index d0aeed7..ef7ff33 100755 --- a/setup.py +++ b/setup.py @@ -4,7 +4,7 @@ install_requires = [ - 'streamlit>=1.12,<2' + 'streamlit>=1.30,<2' ] tests_require = ['pytest', 'pytest-mock', 'tox'] diff --git a/streamlit_parameters/demos/parameters.py b/streamlit_parameters/demos/parameters.py index f4f1720..94ee3f1 100644 --- a/streamlit_parameters/demos/parameters.py +++ b/streamlit_parameters/demos/parameters.py @@ -214,7 +214,7 @@ def main(): streamlit.write("## Debugging") streamlit.write("#### Query String") - query_string: typing.Dict[str, str] = streamlit.experimental_get_query_params() + query_string: typing.Dict[str, str] = streamlit.query_params.get_all() streamlit.write(query_string) streamlit.write("#### Parameters") diff --git a/streamlit_parameters/parameters.py b/streamlit_parameters/parameters.py index c3395d3..acad3d0 100644 --- a/streamlit_parameters/parameters.py +++ b/streamlit_parameters/parameters.py @@ -483,7 +483,7 @@ def set_url_fields(): for key, parameter in streamlit.session_state._parameters.items(): if Parameters.is_set_all() or parameter.touched: values[key] = parameter.to_str(parameter.value) - streamlit.experimental_set_query_params(**values) + streamlit.query_params.from_dict(values) @staticmethod def _already_registered(key: str) -> bool: @@ -505,4 +505,4 @@ def _fetch_url_field(key: str) -> str: KeyError: if the field does not exist """ # TODO: raise error if multiple values in the query_string exist - return streamlit.experimental_get_query_params()[key][0] # always a list, get the first + return streamlit.query_params[key] diff --git a/tests/test_parameters.py b/tests/test_parameters.py index 251569e..b51a54a 100644 --- a/tests/test_parameters.py +++ b/tests/test_parameters.py @@ -19,10 +19,10 @@ def mock_session_state(mocker): def mock_query_params(mocker): """Add a pytest fixture that returns a function that mocks query params.""" def func(key: str, value: str): - get_query_params = mocker.patch( - sut + ".streamlit.experimental_get_query_params" + get_query_params = mocker.patch.dict( + sut + ".streamlit.query_params", + {key: value} ) - get_query_params.return_value = {key: [value]} return func @@ -176,9 +176,9 @@ def test_register_string_parameter( assert parameter.default == "G'day!" assert parameter.value == "Hello" assert repr(parameter) == "Parameter(default=G'day!,value=Hello,touched=True)" - set_query_params = mocker.patch(sut + ".streamlit.experimental_set_query_params") + set_query_params = mocker.patch(sut + ".streamlit.runtime.state.query_params_proxy.QueryParamsProxy.from_dict") Parameters.set_url_fields() - set_query_params.assert_called_with(foo="Hello") + set_query_params.assert_called_with({"foo": "Hello"}) def test_register_string_parameter_not_in_url( @@ -223,14 +223,14 @@ def test_register_string_list_parameter( repr(parameter) == "Parameter(default=['flying', 'spaghetti', 'monster'],value=['flying', 'spaghetti', 'monster'],touched=True)" ) - set_query_params = mocker.patch(sut + ".streamlit.experimental_set_query_params") + set_query_params = mocker.patch(sut + ".streamlit.runtime.state.query_params_proxy.QueryParamsProxy.from_dict") Parameters.set_url_fields() - set_query_params.assert_called_with(foo="['flying', 'spaghetti', 'monster']") + set_query_params.assert_called_with({"foo":"['flying', 'spaghetti', 'monster']"}) # Now update value and make sure new value properly serialized in query params parameters.foo.update(new_value=["Hello", "world"]) Parameters.set_url_fields() - set_query_params.assert_called_with(foo="['Hello', 'world']") + set_query_params.assert_called_with({"foo":"['Hello', 'world']"}) def test_register_string_list_parameter_not_in_url( @@ -278,9 +278,9 @@ def test_register_date_parameter( parameter = st.session_state._parameters["foo"] assert parameter.default == datetime.date(2021, 11, 1) assert parameter.value == datetime.date(2021, 11, 1) - set_query_params = mocker.patch(sut + ".streamlit.experimental_set_query_params") + set_query_params = mocker.patch(sut + ".streamlit.runtime.state.query_params_proxy.QueryParamsProxy.from_dict") Parameters.set_url_fields() - set_query_params.assert_called_with(foo="2021-11-01") + set_query_params.assert_called_with({"foo":"2021-11-01"}) def test_register_date_parameter_not_in_url( @@ -307,10 +307,10 @@ def test_register_date_range_parameter( assert parameter.value == (datetime.date(2021, 11, 1), datetime.date(2021, 11, 3)) # Now update value and make sure new value properly serialized in query params - set_query_params = mocker.patch(sut + ".streamlit.experimental_set_query_params") + set_query_params = mocker.patch(sut + ".streamlit.runtime.state.query_params_proxy.QueryParamsProxy.from_dict") parameters.foo.update(new_value=(datetime.date(2023, 11, 1), datetime.date(2023, 11, 3))) Parameters.set_url_fields() - set_query_params.assert_called_with(foo='(2023-11-01,2023-11-03)') + set_query_params.assert_called_with({"foo":'(2023-11-01,2023-11-03)'}) def test_as_dict( From e8f9b0e651160c4617c81f084700d29372852827 Mon Sep 17 00:00:00 2001 From: Nikita Rushmanov Date: Sat, 23 Nov 2024 23:35:27 +0000 Subject: [PATCH 2/2] Lint --- tests/test_parameters.py | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/tests/test_parameters.py b/tests/test_parameters.py index b51a54a..f620d56 100644 --- a/tests/test_parameters.py +++ b/tests/test_parameters.py @@ -19,7 +19,7 @@ def mock_session_state(mocker): def mock_query_params(mocker): """Add a pytest fixture that returns a function that mocks query params.""" def func(key: str, value: str): - get_query_params = mocker.patch.dict( + mocker.patch.dict( sut + ".streamlit.query_params", {key: value} ) @@ -225,12 +225,12 @@ def test_register_string_list_parameter( ) set_query_params = mocker.patch(sut + ".streamlit.runtime.state.query_params_proxy.QueryParamsProxy.from_dict") Parameters.set_url_fields() - set_query_params.assert_called_with({"foo":"['flying', 'spaghetti', 'monster']"}) + set_query_params.assert_called_with({"foo": "['flying', 'spaghetti', 'monster']"}) # Now update value and make sure new value properly serialized in query params parameters.foo.update(new_value=["Hello", "world"]) Parameters.set_url_fields() - set_query_params.assert_called_with({"foo":"['Hello', 'world']"}) + set_query_params.assert_called_with({"foo": "['Hello', 'world']"}) def test_register_string_list_parameter_not_in_url( @@ -280,7 +280,7 @@ def test_register_date_parameter( assert parameter.value == datetime.date(2021, 11, 1) set_query_params = mocker.patch(sut + ".streamlit.runtime.state.query_params_proxy.QueryParamsProxy.from_dict") Parameters.set_url_fields() - set_query_params.assert_called_with({"foo":"2021-11-01"}) + set_query_params.assert_called_with({"foo": "2021-11-01"}) def test_register_date_parameter_not_in_url( @@ -310,7 +310,7 @@ def test_register_date_range_parameter( set_query_params = mocker.patch(sut + ".streamlit.runtime.state.query_params_proxy.QueryParamsProxy.from_dict") parameters.foo.update(new_value=(datetime.date(2023, 11, 1), datetime.date(2023, 11, 3))) Parameters.set_url_fields() - set_query_params.assert_called_with({"foo":'(2023-11-01,2023-11-03)'}) + set_query_params.assert_called_with({"foo": '(2023-11-01,2023-11-03)'}) def test_as_dict(