From a1d1573df63be0c978bfd2c0d98f4b68562a3499 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Brigitta=20Sip=C5=91cz?= Date: Mon, 25 Nov 2024 08:48:58 +0100 Subject: [PATCH 1/5] BUG: f-strings should be robust enough to create a SQL string --- pyvo/registry/rtcons.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/pyvo/registry/rtcons.py b/pyvo/registry/rtcons.py index 262e94d6..95d64846 100644 --- a/pyvo/registry/rtcons.py +++ b/pyvo/registry/rtcons.py @@ -106,7 +106,7 @@ def make_sql_literal(value): return "{:d}".format(value) elif isinstance(value, (float, numpy.floating)): - return repr(value) + return f'{value}' elif isinstance(value, datetime.datetime): return "'{}'".format(value.isoformat()) From 25864aacca469472583b1cc7a8ed5c5c8d05024b Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Brigitta=20Sip=C5=91cz?= Date: Mon, 25 Nov 2024 08:53:05 +0100 Subject: [PATCH 2/5] MAINT: further cleanup in string generation --- pyvo/registry/rtcons.py | 5 +---- 1 file changed, 1 insertion(+), 4 deletions(-) diff --git a/pyvo/registry/rtcons.py b/pyvo/registry/rtcons.py index 95d64846..0f37db65 100644 --- a/pyvo/registry/rtcons.py +++ b/pyvo/registry/rtcons.py @@ -102,10 +102,7 @@ def make_sql_literal(value): elif isinstance(value, bytes): return "'{}'".format(value.decode("ascii").replace("'", "''")) - elif isinstance(value, (int, numpy.integer)): - return "{:d}".format(value) - - elif isinstance(value, (float, numpy.floating)): + elif isinstance(value, (int, numpy.integer, float, numpy.floating)): return f'{value}' elif isinstance(value, datetime.datetime): From 6fd8eff62bea2e36ab89315b6c9d39cc3cc48905 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Brigitta=20Sip=C5=91cz?= Date: Mon, 25 Nov 2024 10:42:37 +0100 Subject: [PATCH 3/5] TST: make sure we trigger bug 623 in tests --- pyvo/registry/tests/test_rtcons.py | 8 ++++++-- 1 file changed, 6 insertions(+), 2 deletions(-) diff --git a/pyvo/registry/tests/test_rtcons.py b/pyvo/registry/tests/test_rtcons.py index 86467d05..79e78a21 100644 --- a/pyvo/registry/tests/test_rtcons.py +++ b/pyvo/registry/tests/test_rtcons.py @@ -11,7 +11,7 @@ from astropy.coordinates import SkyCoord from astropy.utils.exceptions import AstropyDeprecationWarning -import numpy +import numpy as np import pytest from pyvo import registry @@ -21,6 +21,10 @@ from .commonfixtures import messenger_vocabulary, FAKE_GAVO, FAKE_PLAIN # noqa: F401 +# We should make sure non-legacy numpy works as expected for string literal generation +np.set_printoptions(legacy=False) + + def _build_regtap_query_with_fake( *args, service=FAKE_GAVO, @@ -52,7 +56,7 @@ class _WithFillers(rtcons.Constraint): "bytes": b"keep this ascii for now", "anInt": 210, "aFloat": 5e7, - "numpyStuff": numpy.float64(23.7), + "numpyStuff": np.float64(23.7), "timestamp": datetime.datetime(2021, 6, 30, 9, 1), } return _WithFillers()._get_sql_literals() From 2c71ad5f9a4f5d5ed9d292338c600f323d3bd41c Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Brigitta=20Sip=C5=91cz?= Date: Mon, 25 Nov 2024 10:46:21 +0100 Subject: [PATCH 4/5] DOC: adding changelog --- CHANGES.rst | 2 ++ 1 file changed, 2 insertions(+) diff --git a/CHANGES.rst b/CHANGES.rst index ce227a9d..fef5c8da 100644 --- a/CHANGES.rst +++ b/CHANGES.rst @@ -17,6 +17,8 @@ Bug Fixes - Fix propagating some previously swallowed exceptions. [#614] +- Fix string literal generation for SQL query when using numpy >=2.0. [#624] + 1.6 (2024-11-01) ================ From eba8c6f79722834ba4eed79ac58f32829160215d Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Brigitta=20Sip=C5=91cz?= Date: Mon, 25 Nov 2024 12:57:10 +0100 Subject: [PATCH 5/5] MAINT: addressing np 2.0 repr changes --- conftest.py | 5 ----- pyvo/dal/query.py | 2 +- pyvo/dal/tests/test_query.py | 2 +- 3 files changed, 2 insertions(+), 7 deletions(-) diff --git a/conftest.py b/conftest.py index b81c77d8..2c83886e 100644 --- a/conftest.py +++ b/conftest.py @@ -40,11 +40,6 @@ iers_conf.auto_download = False -# Keep this until we require numpy to be >=2.0 -if minversion(np, "2.0.0.dev0+git20230726"): - np.set_printoptions(legacy="1.25") - - def pytest_configure(config): """Configure Pytest with Astropy. diff --git a/pyvo/dal/query.py b/pyvo/dal/query.py index beedd97f..2bb187ad 100644 --- a/pyvo/dal/query.py +++ b/pyvo/dal/query.py @@ -695,7 +695,7 @@ def __len__(self): return len(self._mapping) def __repr__(self): - return repr(tuple(self.values())) + return repr(tuple(f'{val}' for val in self.values())) def get(self, key, default=None, decode=False): """ diff --git a/pyvo/dal/tests/test_query.py b/pyvo/dal/tests/test_query.py index 177d4d53..bed62bf5 100644 --- a/pyvo/dal/tests/test_query.py +++ b/pyvo/dal/tests/test_query.py @@ -461,7 +461,7 @@ def test_repr(self): record = DALResults.from_result_url( 'http://example.com/query/basic')[0] truth = 'Illuminatus' - assert repr(record) == repr((23, truth)) + assert repr(record) == repr(('23', truth)) def test_get(self): record = DALResults.from_result_url(