From e717557f729156607e6bd8c62f882be14b99832c Mon Sep 17 00:00:00 2001 From: Agisilaos Kounelis <36283973+kounelisagis@users.noreply.github.com> Date: Thu, 29 Aug 2024 17:35:49 +0300 Subject: [PATCH] Remove deprecations (#2050) --- tiledb/__init__.py | 1 - tiledb/filestore.py | 23 ------ tiledb/fragment.py | 76 ------------------ tiledb/libtiledb.pyx | 107 ++------------------------ tiledb/multirange_indexing.py | 7 -- tiledb/query_condition.py | 21 ----- tiledb/tests/test_filestore.py | 16 ---- tiledb/tests/test_pandas_dataframe.py | 20 ----- tiledb/tests/test_query_condition.py | 36 ++------- tiledb/vfs.py | 8 -- 10 files changed, 11 insertions(+), 304 deletions(-) diff --git a/tiledb/__init__.py b/tiledb/__init__.py index 8b430cc4c5..8ba220bc21 100644 --- a/tiledb/__init__.py +++ b/tiledb/__init__.py @@ -65,7 +65,6 @@ from .fragment import ( FragmentInfo, FragmentInfoList, - FragmentsInfo, copy_fragments_to_existing_array, create_array_from_fragments, ) diff --git a/tiledb/filestore.py b/tiledb/filestore.py index ced8561459..ffe0de7660 100644 --- a/tiledb/filestore.py +++ b/tiledb/filestore.py @@ -142,29 +142,6 @@ def copy_to( lt.Filestore._uri_export(ctx, filestore_array_uri, file_uri) - def uri_import(self, file_uri: str, mime_type: str = "AUTODETECT") -> None: - warnings.warn( - "Filestore.uri_import is deprecated; please use Filestore.copy_from", - DeprecationWarning, - ) - - if not isinstance(file_uri, str): - raise TypeError( - f"Unexpected file_uri type '{type(file_uri)}': expected str" - ) - - if not isinstance(mime_type, str): - raise TypeError( - f"Unexpected mime_type type '{type(mime_type)}': expected str" - ) - - lt.Filestore._uri_import( - self._ctx, - self._filestore_uri, - file_uri, - lt.Filestore._mime_type_from_str(mime_type), - ) - def __len__(self) -> int: """ :rtype: int diff --git a/tiledb/fragment.py b/tiledb/fragment.py index db9ae0cdb5..04be4021ad 100644 --- a/tiledb/fragment.py +++ b/tiledb/fragment.py @@ -131,38 +131,6 @@ def __init__(self, array_uri, include_mbrs=False, ctx=None): if libtiledb_version() >= (2, 5, 0): self.array_schema_name = fi.get_array_schema_name() - @property - def non_empty_domain(self): - raise tiledb.TileDBError( - "FragmentInfoList.non_empty_domain is deprecated; " - "you must use FragmentInfoList.nonempty_domain", - "This message will be removed in 0.21.0.", - ) - - @property - def to_vacuum_num(self): - raise tiledb.TileDBError( - "FragmentInfoList.to_vacuum_num is deprecated; " - "you must use len(FragmentInfoList.to_vacuum)", - "This message will be removed in 0.21.0.", - ) - - @property - def to_vacuum_uri(self): - raise tiledb.TileDBError( - "FragmentInfoList.to_vacuum_uri is deprecated; " - "you must use FragmentInfoList.to_vacuum", - "This message will be removed in 0.21.0.", - ) - - @property - def dense(self): - raise tiledb.TileDBError( - "FragmentInfoList.dense is deprecated; " - "you must use FragmentInfoList.sparse", - "This message will be removed in 0.21.0.", - ) - def __getattr__(self, name): if name == "mbrs": raise AttributeError( @@ -297,50 +265,6 @@ def __getattr__(self, name): ) return self.__getattribute__(name) - @property - def non_empty_domain(self): - raise tiledb.TileDBError( - "FragmentInfo.non_empty_domain is deprecated; " - "you must use FragmentInfo.nonempty_domain. ", - "This message will be removed in 0.21.0.", - ) - - @property - def to_vacuum_num(self): - raise tiledb.TileDBError( - "FragmentInfo.to_vacuum_num is deprecated; " - "you must use len(FragmentInfoList.to_vacuum).", - "This message will be removed in 0.21.0.", - ) - - @property - def to_vacuum_uri(self): - raise tiledb.TileDBError( - "FragmentInfo.to_vacuum_uri is deprecated; " - "you must use FragmentInfoList.to_vacuum.", - "This message will be removed in 0.21.0.", - ) - - @property - def dense(self): - raise tiledb.TileDBError( - "FragmentInfo.dense is deprecated; you must use FragmentInfo.sparse", - "This message will be removed in 0.21.0.", - ) - - -def FragmentsInfo(array_uri, ctx=None): - """ - Deprecated in 0.8.8. - - Renamed to FragmentInfoList to make name more distinguishable from FragmentInfo. - """ - - raise tiledb.TileDBError( - "FragmentsInfo is deprecated; you must use FragmentInfoList. " - "This message will be removed in 0.21.0.", - ) - def create_array_from_fragments( src_uri, diff --git a/tiledb/libtiledb.pyx b/tiledb/libtiledb.pyx index 0a20b112ff..f23670ff49 100644 --- a/tiledb/libtiledb.pyx +++ b/tiledb/libtiledb.pyx @@ -1188,17 +1188,6 @@ cdef class Array(object): """The view attribute of this array.""" return self.view_attr - @property - def timestamp(self): - """Deprecated in 0.9.2. - - Use `timestamp_range` - """ - raise TileDBError( - "timestamp is deprecated; you must use timestamp_range. " - "This message will be removed in 0.21.0.", - ) - @property def timestamp_range(self): """Returns the timestamp range the array is opened at @@ -1223,16 +1212,6 @@ cdef class Array(object): return (int(timestamp_start), int(timestamp_end)) - @property - def coords_dtype(self): - """ - Deprecated in 0.8.10 - """ - raise TileDBError( - "`coords_dtype` is deprecated because combined coords have been " - "removed from libtiledb. This message will be removed in 0.21.0.", - ) - @property def uri(self): """Returns the URI of the array""" @@ -1913,14 +1892,6 @@ cdef class Aggregation(object): if isinstance(cond, str): q.set_cond(QueryCondition(cond)) - elif isinstance(cond, QueryCondition): - raise TileDBError( - "Passing `tiledb.QueryCondition` to `cond` is no longer " - "supported as of 0.19.0. Instead of " - "`cond=tiledb.QueryCondition('expression')` " - "you must use `cond='expression'`. This message will be " - "removed in 0.21.0.", - ) else: raise TypeError("`cond` expects type str.") @@ -2103,13 +2074,6 @@ cdef class Query(object): """List of attributes to include in Query.""" return self.attrs - @property - def attr_cond(self): - raise TileDBError( - "`attr_cond` is no longer supported. You must use `cond`. " - "This message will be removed in 0.21.0." - ) - @property def cond(self): """QueryCondition used to filter attributes or dimensions in Query.""" @@ -2288,9 +2252,8 @@ cdef class DenseArrayImpl(Array): else: return "DenseArray(uri={0!r}, mode=closed)".format(self.uri) - def query(self, attrs=None, attr_cond=None, cond=None, dims=None, - coords=False, order='C', use_arrow=None, return_arrow=False, - return_incomplete=False): + def query(self, attrs=None, cond=None, dims=None, coords=False, order='C', + use_arrow=None, return_arrow=False, return_incomplete=False): """Construct a proxy Query object for easy subarray queries of cells for an item or region of the array across one or more attributes. @@ -2341,24 +2304,12 @@ cdef class DenseArrayImpl(Array): if not self.isopen or self.mode != 'r': raise TileDBError("DenseArray must be opened in read mode") - if attr_cond is not None: - if cond is not None: - raise TileDBError("Both `attr_cond` and `cond` were passed. " - "Only use `cond`." - ) - - raise TileDBError( - "`attr_cond` is no longer supported. You must use `cond`. " - "This message will be removed in 0.21.0." - ) - return Query(self, attrs=attrs, cond=cond, dims=dims, coords=coords, order=order, use_arrow=use_arrow, return_arrow=return_arrow, return_incomplete=return_incomplete) - def subarray(self, selection, attrs=None, cond=None, attr_cond=None, - coords=False, order=None): + def subarray(self, selection, attrs=None, cond=None, coords=False, order=None): """Retrieve data cells for an item or region of the array. Optionally subselect over attributes, return dense result coordinate values, @@ -2398,12 +2349,6 @@ cdef class DenseArrayImpl(Array): if not self.isopen or self.mode != 'r': raise TileDBError("DenseArray must be opened in read mode") - if attr_cond is not None: - if cond is not None: - raise TileDBError("Both `attr_cond` and `cond` were passed. " - "Only use `cond`." - ) - cdef tiledb_layout_t layout = TILEDB_UNORDERED if order is None or order == 'C': layout = TILEDB_ROW_MAJOR @@ -2475,14 +2420,6 @@ cdef class DenseArrayImpl(Array): if isinstance(cond, str): q.set_cond(QueryCondition(cond)) - elif isinstance(cond, QueryCondition): - raise TileDBError( - "Passing `tiledb.QueryCondition` to `cond` is no longer " - "supported as of 0.19.0. Instead of " - "`cond=tiledb.QueryCondition('expression')` " - "you must use `cond='expression'`. This message will be " - "removed in 0.21.0.", - ) else: raise TypeError("`cond` expects type str.") @@ -3362,9 +3299,8 @@ cdef class SparseArrayImpl(Array): return result - def query(self, attrs=None, cond=None, attr_cond=None, dims=None, - index_col=True, coords=None, order='U', use_arrow=None, - return_arrow=None, return_incomplete=False): + def query(self, attrs=None, cond=None, dims=None, index_col=True, coords=None, + order='U', use_arrow=None, return_arrow=None, return_incomplete=False): """ Construct a proxy Query object for easy subarray queries of cells for an item or region of the array across one or more attributes. @@ -3415,17 +3351,6 @@ cdef class SparseArrayImpl(Array): if not self.isopen or self.mode not in ('r', 'd'): raise TileDBError("SparseArray must be opened in read or delete mode") - if attr_cond is not None: - if cond is not None: - raise TileDBError("Both `attr_cond` and `cond` were passed. " - "Only use `cond`." - ) - - raise TileDBError( - "`attr_cond` is no longer supported. You must use `cond`. " - "This message will be removed in 0.21.0." - ) - # backwards compatibility _coords = coords if dims is False: @@ -3480,8 +3405,7 @@ cdef class SparseArrayImpl(Array): return result_dict - def subarray(self, selection, coords=True, attrs=None, cond=None, - attr_cond=None, order=None): + def subarray(self, selection, coords=True, attrs=None, cond=None, order=None): """ Retrieve dimension and data cells for an item or region of the array. @@ -3529,17 +3453,6 @@ cdef class SparseArrayImpl(Array): if not self.isopen or self.mode not in ('r', 'd'): raise TileDBError("SparseArray is not opened in read or delete mode") - if attr_cond is not None: - if cond is not None: - raise TileDBError("Both `attr_cond` and `cond` were passed. " - "`attr_cond` is no longer supported. You must use `cond`. " - ) - - raise TileDBError( - "`attr_cond` is no longer supported. You must use `cond`. " - "This message will be removed in 0.21.0.", - ) - cdef tiledb_layout_t layout = TILEDB_UNORDERED if order is None or order == 'U': layout = TILEDB_UNORDERED @@ -3607,14 +3520,6 @@ cdef class SparseArrayImpl(Array): if isinstance(cond, str): q.set_cond(QueryCondition(cond)) - elif isinstance(cond, QueryCondition): - raise TileDBError( - "Passing `tiledb.QueryCondition` to `cond` is no longer " - "supported as of 0.19.0. Instead of " - "`cond=tiledb.QueryCondition('expression')` " - "you must use `cond='expression'`. This message will be " - "removed in 0.21.0.", - ) else: raise TypeError("`cond` expects type str.") diff --git a/tiledb/multirange_indexing.py b/tiledb/multirange_indexing.py index dbbe32788a..27e5725fcd 100644 --- a/tiledb/multirange_indexing.py +++ b/tiledb/multirange_indexing.py @@ -649,13 +649,6 @@ def _get_pyquery( if query and query.cond is not None: if isinstance(query.cond, str): pyquery.set_cond(QueryCondition(query.cond)) - elif isinstance(query.cond, QueryCondition): - raise TileDBError( - "Passing `tiledb.QueryCondition` to `cond` is no longer supported " - "as of 0.19.0. Instead of `cond=tiledb.QueryCondition('expression')` " - "you must use `cond='expression'`. This message will be " - "removed in 0.21.0.", - ) else: raise TypeError("`cond` expects type str.") diff --git a/tiledb/query_condition.py b/tiledb/query_condition.py index 39e722f242..baf4c9f0c6 100644 --- a/tiledb/query_condition.py +++ b/tiledb/query_condition.py @@ -321,11 +321,6 @@ def get_variable_from_node(self, node: QueryConditionNodeElem) -> Any: variable = variable_node.id elif isinstance(variable_node, ast.Constant): variable = variable_node.value - elif isinstance(variable_node, ast.Constant) or isinstance( - variable_node, ast.Constant - ): - # deprecated in 3.8 - variable = variable_node.s else: raise TileDBError( f"Incorrect type for variable name: {ast.dump(variable_node)}" @@ -492,19 +487,3 @@ def visit_UnaryOp(self, node: ast.UnaryOp, sign: int = 1): ) return node.operand - - def visit_Num(self, node: ast.Constant) -> ast.Constant: - # deprecated in 3.8 - return node - - def visit_Str(self, node: ast.Constant) -> ast.Constant: - # deprecated in 3.8 - return node - - def visit_Bytes(self, node: ast.Constant) -> ast.Constant: - # deprecated in 3.8 - return node - - def visit_NameConstant(self, node: ast.Constant) -> ast.Constant: - # deprecated in 3.8 - return node diff --git a/tiledb/tests/test_filestore.py b/tiledb/tests/test_filestore.py index bde45452aa..9d352ff27f 100644 --- a/tiledb/tests/test_filestore.py +++ b/tiledb/tests/test_filestore.py @@ -74,22 +74,6 @@ def test_uri(self, text_fname): assert data == fs.read(0, len(data)) assert len(fs) == len(data) - def test_deprecated_uri(self, text_fname): - path = self.path("test_uri") - schema = tiledb.ArraySchema.from_file(text_fname) - tiledb.Array.create(path, schema) - - fs = tiledb.Filestore(path) - with pytest.warns( - DeprecationWarning, match="Filestore.uri_import is deprecated" - ): - fs.uri_import(text_fname) - - with open(text_fname, "rb") as text: - data = text.read() - assert data == fs.read(0, len(data)) - assert len(fs) == len(data) - def test_multiple_writes(self): path = self.path("test_buffer") schema = tiledb.ArraySchema.from_file() diff --git a/tiledb/tests/test_pandas_dataframe.py b/tiledb/tests/test_pandas_dataframe.py index 72a22f00a8..9811144c7d 100644 --- a/tiledb/tests/test_pandas_dataframe.py +++ b/tiledb/tests/test_pandas_dataframe.py @@ -482,10 +482,6 @@ def test_dataframe_categorical(self): with tiledb.open(uri) as B: tm.assert_frame_equal(df, B.df[:]) - @pytest.mark.skipif( - sys.version_info < (3, 8), - reason="requires Python 3.8 or higher. date_format argument is not supported in 3.7 and below", - ) def test_dataframe_csv_rt1(self): def rand_dtype(dtype, size): nbytes = size * np.dtype(dtype).itemsize @@ -793,10 +789,6 @@ def test_csv_dense(self): tmp_array2 = os.path.join(tmp_dir, "array2") tiledb.from_csv(tmp_array2, tmp_csv, sparse=False) - @pytest.mark.skipif( - sys.version_info < (3, 8), - reason="requires Python 3.8 or higher. date_format argument is not supported in 3.7 and below", - ) def test_csv_col_to_sparse_dims(self): df = make_dataframe_basic3(20) @@ -870,10 +862,6 @@ def test_csv_col_to_sparse_dims(self): cmp_df = df.set_index("int_vals").sort_values(by="time") tm.assert_frame_equal(res_df, cmp_df) - @pytest.mark.skipif( - sys.version_info < (3, 8), - reason="requires Python 3.8 or higher. date_format argument is not supported in 3.7 and below", - ) def test_dataframe_csv_schema_only(self): col_size = 10 df = make_dataframe_basic3(col_size) @@ -983,10 +971,6 @@ def test_dataframe_csv_schema_only(self): df_bk.sort_index(level="time", inplace=True) tm.assert_frame_equal(df_bk, df_combined) - @pytest.mark.skipif( - sys.version_info < (3, 8), - reason="requires Python 3.8 or higher. date_format argument is not supported in 3.7 and below", - ) def test_dataframe_csv_chunked(self): col_size = 200 df = make_dataframe_basic3(col_size) @@ -1069,10 +1053,6 @@ def test_dataframe_csv_chunked(self): df_idx_res = A.query(coords=False).df[int(ned[0]) : int(ned[1])] tm.assert_frame_equal(df_idx_res, df.reset_index(drop=True)) - @pytest.mark.skipif( - sys.version_info < (3, 8), - reason="requires Python 3.8 or higher. date_format argument is not supported in 3.7 and below", - ) def test_csv_fillna(self): if pytest.tiledb_vfs == "s3": pytest.skip( diff --git a/tiledb/tests/test_query_condition.py b/tiledb/tests/test_query_condition.py index 07549482cc..a3c3f157aa 100644 --- a/tiledb/tests/test_query_condition.py +++ b/tiledb/tests/test_query_condition.py @@ -119,12 +119,7 @@ def test_qc_dense(self): def test_unsigned_sparse(self): with tiledb.open(self.create_input_array_UIDSA(sparse=True)) as A: - with pytest.raises(tiledb.TileDBError) as exc_info: - A.query(cond=tiledb.QueryCondition("U < 5"), attrs=["U"])[:] - assert ( - "Passing `tiledb.QueryCondition` to `cond` is no longer supported" - in str(exc_info.value) - ) + A.query(cond="U < 5", attrs=["U"])[:] result = A.query(cond="U < 5", attrs=["U"])[:] assert all(result["U"] < 5) @@ -133,12 +128,7 @@ def test_unsigned_dense(self): with tiledb.open(self.create_input_array_UIDSA(sparse=False)) as A: mask = A.attr("U").fill - with pytest.raises(tiledb.TileDBError) as exc_info: - A.query(cond=tiledb.QueryCondition("U < 5"), attrs=["U"])[:] - assert ( - "Passing `tiledb.QueryCondition` to `cond` is no longer supported" - in str(exc_info.value) - ) + A.query(cond="U < 5", attrs=["U"])[:] result = A.query(cond="U < 5", attrs=["U"])[:] assert all(self.filter_dense(result["U"], mask) < 5) @@ -699,25 +689,9 @@ def test_deprecate_attr_cond(self): with tiledb.open(self.create_input_array_UIDSA(sparse=True)) as A: qc = "U < 3" - with pytest.raises(tiledb.TileDBError) as exc_info: - A.query(cond=qc, attr_cond=qc) - assert "Both `attr_cond` and `cond` were passed." in str(exc_info.value) - - with pytest.raises(tiledb.TileDBError) as exc_info: - A.query(attr_cond=qc) - assert "`attr_cond` is no longer supported" in str(exc_info.value) - - with pytest.raises(tiledb.TileDBError) as exc_info: - A.query(cond=qc).attr_cond - assert "`attr_cond` is no longer supported" in str(exc_info.value) - - with pytest.raises(tiledb.TileDBError) as exc_info: - A.subarray(1, cond=qc, attr_cond=qc) - assert "Both `attr_cond` and `cond` were passed." in str(exc_info.value) - - with pytest.raises(tiledb.TileDBError) as exc_info: - A.subarray(1, attr_cond=qc) - assert "`attr_cond` is no longer supported" in str(exc_info.value) + A.query(cond=qc) + A.query(cond=qc).cond + A.subarray(1, cond=qc) def test_on_dense_dimensions(self): with tiledb.open(self.create_input_array_UIDSA(sparse=False)) as A: diff --git a/tiledb/vfs.py b/tiledb/vfs.py index d95c4d52c9..0cdc745d87 100644 --- a/tiledb/vfs.py +++ b/tiledb/vfs.py @@ -111,15 +111,7 @@ def read(self, file: lt.FileHandle, offset: int, nbytes: int) -> bytes: :rtype: :py:func:`bytes` :return: read bytes :raises: :py:exc:`tiledb.TileDBError` - """ - if isinstance(file, FileIO): - raise lt.TileDBError( - "`tiledb.VFS().open` now returns a FileIO object. Use " - "`FileIO.seek` and `FileIO.read`. This message will be removed " - "in 0.21.0." - ) - if nbytes == 0: return b""