From e7b0da4e5b55d2b4c92614c65e8a1ff3af4afa53 Mon Sep 17 00:00:00 2001 From: Sergey Rybakov Date: Tue, 7 May 2024 18:32:39 +0300 Subject: [PATCH 1/4] CreateArrayLock removed --- deker/locks.py | 74 ------ deker/managers.py | 4 +- deker/subset.py | 23 +- poetry.lock | 233 +++++++++--------- pyproject.toml | 2 +- .../test_arrays/test_array_methods.py | 3 +- .../test_arrays/test_varray_methods.py | 2 +- .../test_concurrency/test_in_processes.py | 145 ----------- .../test_schemas/test_attributes_schema.py | 1 - 9 files changed, 135 insertions(+), 352 deletions(-) diff --git a/deker/locks.py b/deker/locks.py index 1aeca16..c17e3b2 100644 --- a/deker/locks.py +++ b/deker/locks.py @@ -417,80 +417,6 @@ def _inner_method_logic( return super()._inner_method_logic(lock, args, kwargs, func) -class CreateArrayLock(LockWithArrayMixin[Union["Array", "VArray", dict]], BaseLock): - """Lock that we set when we want to create an array.""" - - ALLOWED_TYPES = ["LocalArrayAdapter", "LocalVArrayAdapter"] - - path: Optional[Path] = None - - def get_path(self) -> Path: - """Return path to the file that should be locked.""" - # Get file directory path - dir_path = self.instance.collection_path - - # Create lock file - path = dir_path / _get_lock_filename(self.array.id, LocksExtensions.array_lock) - if not path.exists(): - path.open("w").close() - - self.path = path - self.logger.debug(f"got path for array.id {self.array.id} lock file: {path}") - return path - - def check_existing_lock(self, func_args: Sequence, func_kwargs: Dict) -> None: - """Check if there is currently lock for array creating. - - :param func_args: arguments for called method - :param func_kwargs: keyword arguments for called method - """ - from deker.arrays import Array, VArray - - array = self.array - # Check current read locks - if isinstance(array, dict): - adapter = array["adapter"].__class__.__name__ - if adapter not in self.ALLOWED_TYPES: - raise DekerLockError(f"Adapter {adapter} is not allowed to create locks for arrays") - - # TODO: figure out a way to avoid constructing Array object here - array_type = Array if adapter == self.ALLOWED_TYPES[0] else VArray - array = array_type(**array) - - dir_path = self.instance.collection_path - - # Pattern that has to find any create locks - glob_pattern = f"{array.id}:*{LocksExtensions.array_lock.value}" - for _ in dir_path.rglob(glob_pattern): - raise DekerLockError(f"Array {array.id} is locked for creating") - - func_kwargs["array"] = array - - def get_result(self, func: Callable, args: Any, kwargs: Any) -> Any: - """Call func, and get its result. - - :param func: decorated function - :param args: arguments of decorated function - :param kwargs: keyword arguments of decorated function - """ - if kw_array := kwargs.pop("array"): - args = list(args) - # First elem is self, so for functions with array, set array as next arg. - args[1] = kw_array - result = func(*tuple(args), **kwargs) - else: - result = func(*args, **kwargs) - return result - - def release(self, e: Optional[Exception] = None) -> None: - """Release Flock. - - :param e: exception that might have been raised - """ - self.path.unlink(missing_ok=True) - super().release(e) - - class UpdateMetaAttributeLock(LockWithArrayMixin[Union["Array", "VArray"]], BaseLock): """Lock for updating meta.""" diff --git a/deker/managers.py b/deker/managers.py index 32c8cf4..15559e2 100644 --- a/deker/managers.py +++ b/deker/managers.py @@ -132,9 +132,11 @@ def _create( # type: ignore "array_adapter": self.__array_adapter, # type: ignore[dict-item] } ) + array = VArray(**arr_params) # type: ignore[arg-type] else: arr_params.update({"adapter": self.__array_adapter}) # type: ignore[dict-item] - array = self._adapter.create(arr_params) + array = Array(**arr_params) # type: ignore[arg-type] + self._adapter.create(array) return array def create( diff --git a/deker/subset.py b/deker/subset.py index 850ff72..1bd2ba4 100644 --- a/deker/subset.py +++ b/deker/subset.py @@ -578,6 +578,7 @@ def update(self, data: Data) -> None: :param data: new data which shall match subset slicing """ + from deker.arrays import Array def _update(array_data: ArrayPositionedData) -> None: """If there is a need in the future to calculate Array's time dimension start value. # noqa: DAR101, D400 @@ -600,17 +601,17 @@ def _update(array_data: ArrayPositionedData) -> None: pos = array_data.vposition[n] custom_attributes[attr_name] = dim.start_value + dim.step * pos # type: ignore[operator] - array = self.__array_adapter.create( - { - "collection": self.__collection, - "adapter": self.__array_adapter, - "primary_attributes": { - "vid": self.__array.id, - "v_position": array_data.vposition, - }, - "custom_attributes": custom_attributes, - } - ) + kwargs = { + "collection": self.__collection, + "adapter": self.__array_adapter, + "primary_attributes": { + "vid": self.__array.id, + "v_position": array_data.vposition, + }, + "custom_attributes": custom_attributes, + } + array = Array(**kwargs) # type: ignore[arg-type] + self.__array_adapter.create(array) subset = array[array_data.bounds] subset.update(array_data.data) diff --git a/poetry.lock b/poetry.lock index 2ae9f50..a0ad07e 100644 --- a/poetry.lock +++ b/poetry.lock @@ -115,13 +115,13 @@ Sphinx = ">=2.2,<8.0" [[package]] name = "babel" -version = "2.14.0" +version = "2.15.0" description = "Internationalization utilities" optional = false -python-versions = ">=3.7" +python-versions = ">=3.8" files = [ - {file = "Babel-2.14.0-py3-none-any.whl", hash = "sha256:efb1a25b7118e67ce3a259bed20545c29cb68be8ad2c784c83689981b7a57287"}, - {file = "Babel-2.14.0.tar.gz", hash = "sha256:6919867db036398ba21eb5c7a0f6b28ab8cbc3ae7a73a44ebe34ae74a4e7d363"}, + {file = "Babel-2.15.0-py3-none-any.whl", hash = "sha256:08706bdad8d0a3413266ab61bd6c34d0c28d6e1e7badf40a2cebe67644e2e1fb"}, + {file = "babel-2.15.0.tar.gz", hash = "sha256:8daf0e265d05768bc6c7a314cf1321e9a123afc328cc635c18622a2f30a04413"}, ] [package.extras] @@ -499,12 +499,12 @@ optimize = ["orjson"] [[package]] name = "deker-local-adapters" -version = "1.1.0" +version = "1.1.1b0" description = "Plugin with local adapters for deker" optional = false python-versions = ">=3.9,<4.0" files = [ - {file = "deker_local_adapters-1.1.0.tar.gz", hash = "sha256:ddbc9197f687a6f2121471fb2a60bd951b37e331bce76471b1726cbe6c4e39b3"}, + {file = "deker_local_adapters-1.1.1b0.tar.gz", hash = "sha256:415e3d74410c0f8f04cea6ee72b289b261bcbf801565f7c79b68ef901c8de24e"}, ] [package.dependencies] @@ -513,14 +513,19 @@ h5py = ">=3.8.0,<4.0.0" hdf5plugin = ">=4.0.1,<5.0.0" numpy = ">=1.18,<2.0" +[package.source] +type = "legacy" +url = "https://test.pypi.org/simple" +reference = "testpypi" + [[package]] name = "deker-server-adapters" -version = "1.0.4" +version = "1.0.5" description = "Plugin with server adapters for Deker" optional = true -python-versions = ">=3.9,<4.0" +python-versions = "<4.0,>=3.9" files = [ - {file = "deker_server_adapters-1.0.4.tar.gz", hash = "sha256:08c067f4fff39896eede75b2c883d23250444b957d55d649946973e0748bf95a"}, + {file = "deker_server_adapters-1.0.5.tar.gz", hash = "sha256:4e3982a6236599e6c55c70cf42b105133c7c7b0eeab8c6cadb91774a141efad2"}, ] [package.dependencies] @@ -647,13 +652,13 @@ sphinx = ["sphinx (>=3.2.0)", "sphinx-jinja2-compat (>=0.1.1)", "sphinx-toolbox [[package]] name = "exceptiongroup" -version = "1.2.0" +version = "1.2.1" description = "Backport of PEP 654 (exception groups)" optional = false python-versions = ">=3.7" files = [ - {file = "exceptiongroup-1.2.0-py3-none-any.whl", hash = "sha256:4bfd3996ac73b41e9b9628b04e079f193850720ea5945fc96a08633c66912f14"}, - {file = "exceptiongroup-1.2.0.tar.gz", hash = "sha256:91f5c769735f051a4290d52edd0858999b57e5876e9f85937691bd4c9fa3ed68"}, + {file = "exceptiongroup-1.2.1-py3-none-any.whl", hash = "sha256:5258b9ed329c5bbdd31a309f53cbfb0b155341807f6ff7606a1e801a891b29ad"}, + {file = "exceptiongroup-1.2.1.tar.gz", hash = "sha256:a4785e48b045528f5bfe627b6ad554ff32def154f42372786903b7abcfe1aa16"}, ] [package.extras] @@ -661,13 +666,13 @@ test = ["pytest (>=6)"] [[package]] name = "filelock" -version = "3.13.3" +version = "3.14.0" description = "A platform independent file lock." optional = false python-versions = ">=3.8" files = [ - {file = "filelock-3.13.3-py3-none-any.whl", hash = "sha256:5ffa845303983e7a0b7ae17636509bc97997d58afeafa72fb141a17b152284cb"}, - {file = "filelock-3.13.3.tar.gz", hash = "sha256:a79895a25bbefdf55d1a2a0a80968f7dbb28edcd6d4234a0afb3f37ecde4b546"}, + {file = "filelock-3.14.0-py3-none-any.whl", hash = "sha256:43339835842f110ca7ae60f1e1c160714c5a6afd15a2873419ab185334975c0f"}, + {file = "filelock-3.14.0.tar.gz", hash = "sha256:6ea72da3be9b8c82afd3edcf99f2fffbb5076335a5ae4d03248bb5b6c3eae78a"}, ] [package.extras] @@ -841,36 +846,32 @@ hyperframe = ">=6.0,<7" [[package]] name = "h5py" -version = "3.10.0" +version = "3.11.0" description = "Read and write HDF5 files from Python" optional = false python-versions = ">=3.8" files = [ - {file = "h5py-3.10.0-cp310-cp310-macosx_10_9_x86_64.whl", hash = "sha256:b963fb772964fc1d1563c57e4e2e874022ce11f75ddc6df1a626f42bd49ab99f"}, - {file = "h5py-3.10.0-cp310-cp310-macosx_11_0_arm64.whl", hash = "sha256:012ab448590e3c4f5a8dd0f3533255bc57f80629bf7c5054cf4c87b30085063c"}, - {file = "h5py-3.10.0-cp310-cp310-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:781a24263c1270a62cd67be59f293e62b76acfcc207afa6384961762bb88ea03"}, - {file = "h5py-3.10.0-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:f42e6c30698b520f0295d70157c4e202a9e402406f50dc08f5a7bc416b24e52d"}, - {file = "h5py-3.10.0-cp310-cp310-win_amd64.whl", hash = "sha256:93dd840bd675787fc0b016f7a05fc6efe37312a08849d9dd4053fd0377b1357f"}, - {file = "h5py-3.10.0-cp311-cp311-macosx_10_9_x86_64.whl", hash = "sha256:2381e98af081b6df7f6db300cd88f88e740649d77736e4b53db522d8874bf2dc"}, - {file = "h5py-3.10.0-cp311-cp311-macosx_11_0_arm64.whl", hash = "sha256:667fe23ab33d5a8a6b77970b229e14ae3bb84e4ea3382cc08567a02e1499eedd"}, - {file = "h5py-3.10.0-cp311-cp311-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:90286b79abd085e4e65e07c1bd7ee65a0f15818ea107f44b175d2dfe1a4674b7"}, - {file = "h5py-3.10.0-cp311-cp311-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:6c013d2e79c00f28ffd0cc24e68665ea03ae9069e167087b2adb5727d2736a52"}, - {file = "h5py-3.10.0-cp311-cp311-win_amd64.whl", hash = "sha256:92273ce69ae4983dadb898fd4d3bea5eb90820df953b401282ee69ad648df684"}, - {file = "h5py-3.10.0-cp312-cp312-macosx_10_9_x86_64.whl", hash = "sha256:3c97d03f87f215e7759a354460fb4b0d0f27001450b18b23e556e7856a0b21c3"}, - {file = "h5py-3.10.0-cp312-cp312-macosx_11_0_arm64.whl", hash = "sha256:86df4c2de68257b8539a18646ceccdcf2c1ce6b1768ada16c8dcfb489eafae20"}, - {file = "h5py-3.10.0-cp312-cp312-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:ba9ab36be991119a3ff32d0c7cbe5faf9b8d2375b5278b2aea64effbeba66039"}, - {file = "h5py-3.10.0-cp312-cp312-win_amd64.whl", hash = "sha256:2c8e4fda19eb769e9a678592e67eaec3a2f069f7570c82d2da909c077aa94339"}, - {file = "h5py-3.10.0-cp38-cp38-macosx_10_9_x86_64.whl", hash = "sha256:492305a074327e8d2513011fa9fffeb54ecb28a04ca4c4227d7e1e9616d35641"}, - {file = "h5py-3.10.0-cp38-cp38-macosx_11_0_arm64.whl", hash = "sha256:9450464b458cca2c86252b624279115dcaa7260a40d3cb1594bf2b410a2bd1a3"}, - {file = "h5py-3.10.0-cp38-cp38-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:fd6f6d1384a9f491732cee233b99cd4bfd6e838a8815cc86722f9d2ee64032af"}, - {file = "h5py-3.10.0-cp38-cp38-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:3074ec45d3dc6e178c6f96834cf8108bf4a60ccb5ab044e16909580352010a97"}, - {file = "h5py-3.10.0-cp38-cp38-win_amd64.whl", hash = "sha256:212bb997a91e6a895ce5e2f365ba764debeaef5d2dca5c6fb7098d66607adf99"}, - {file = "h5py-3.10.0-cp39-cp39-macosx_10_9_x86_64.whl", hash = "sha256:5dfc65ac21fa2f630323c92453cadbe8d4f504726ec42f6a56cf80c2f90d6c52"}, - {file = "h5py-3.10.0-cp39-cp39-macosx_11_0_arm64.whl", hash = "sha256:d4682b94fd36ab217352be438abd44c8f357c5449b8995e63886b431d260f3d3"}, - {file = "h5py-3.10.0-cp39-cp39-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:aece0e2e1ed2aab076c41802e50a0c3e5ef8816d60ece39107d68717d4559824"}, - {file = "h5py-3.10.0-cp39-cp39-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:43a61b2c2ad65b1fabc28802d133eed34debcc2c8b420cb213d3d4ef4d3e2229"}, - {file = "h5py-3.10.0-cp39-cp39-win_amd64.whl", hash = "sha256:ae2f0201c950059676455daf92700eeb57dcf5caaf71b9e1328e6e6593601770"}, - {file = "h5py-3.10.0.tar.gz", hash = "sha256:d93adc48ceeb33347eb24a634fb787efc7ae4644e6ea4ba733d099605045c049"}, + {file = "h5py-3.11.0-cp310-cp310-macosx_10_9_x86_64.whl", hash = "sha256:1625fd24ad6cfc9c1ccd44a66dac2396e7ee74940776792772819fc69f3a3731"}, + {file = "h5py-3.11.0-cp310-cp310-macosx_11_0_arm64.whl", hash = "sha256:c072655ad1d5fe9ef462445d3e77a8166cbfa5e599045f8aa3c19b75315f10e5"}, + {file = "h5py-3.11.0-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:77b19a40788e3e362b54af4dcf9e6fde59ca016db2c61360aa30b47c7b7cef00"}, + {file = "h5py-3.11.0-cp310-cp310-win_amd64.whl", hash = "sha256:ef4e2f338fc763f50a8113890f455e1a70acd42a4d083370ceb80c463d803972"}, + {file = "h5py-3.11.0-cp311-cp311-macosx_10_9_x86_64.whl", hash = "sha256:bbd732a08187a9e2a6ecf9e8af713f1d68256ee0f7c8b652a32795670fb481ba"}, + {file = "h5py-3.11.0-cp311-cp311-macosx_11_0_arm64.whl", hash = "sha256:75bd7b3d93fbeee40860fd70cdc88df4464e06b70a5ad9ce1446f5f32eb84007"}, + {file = "h5py-3.11.0-cp311-cp311-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:52c416f8eb0daae39dabe71415cb531f95dce2d81e1f61a74537a50c63b28ab3"}, + {file = "h5py-3.11.0-cp311-cp311-win_amd64.whl", hash = "sha256:083e0329ae534a264940d6513f47f5ada617da536d8dccbafc3026aefc33c90e"}, + {file = "h5py-3.11.0-cp312-cp312-macosx_10_9_x86_64.whl", hash = "sha256:a76cae64080210389a571c7d13c94a1a6cf8cb75153044fd1f822a962c97aeab"}, + {file = "h5py-3.11.0-cp312-cp312-macosx_11_0_arm64.whl", hash = "sha256:f3736fe21da2b7d8a13fe8fe415f1272d2a1ccdeff4849c1421d2fb30fd533bc"}, + {file = "h5py-3.11.0-cp312-cp312-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:aa6ae84a14103e8dc19266ef4c3e5d7c00b68f21d07f2966f0ca7bdb6c2761fb"}, + {file = "h5py-3.11.0-cp312-cp312-win_amd64.whl", hash = "sha256:21dbdc5343f53b2e25404673c4f00a3335aef25521bd5fa8c707ec3833934892"}, + {file = "h5py-3.11.0-cp38-cp38-macosx_10_9_x86_64.whl", hash = "sha256:754c0c2e373d13d6309f408325343b642eb0f40f1a6ad21779cfa9502209e150"}, + {file = "h5py-3.11.0-cp38-cp38-macosx_11_0_arm64.whl", hash = "sha256:731839240c59ba219d4cb3bc5880d438248533366f102402cfa0621b71796b62"}, + {file = "h5py-3.11.0-cp38-cp38-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:8ec9df3dd2018904c4cc06331951e274f3f3fd091e6d6cc350aaa90fa9b42a76"}, + {file = "h5py-3.11.0-cp38-cp38-win_amd64.whl", hash = "sha256:55106b04e2c83dfb73dc8732e9abad69d83a436b5b82b773481d95d17b9685e1"}, + {file = "h5py-3.11.0-cp39-cp39-macosx_10_9_x86_64.whl", hash = "sha256:f4e025e852754ca833401777c25888acb96889ee2c27e7e629a19aee288833f0"}, + {file = "h5py-3.11.0-cp39-cp39-macosx_11_0_arm64.whl", hash = "sha256:6c4b760082626120031d7902cd983d8c1f424cdba2809f1067511ef283629d4b"}, + {file = "h5py-3.11.0-cp39-cp39-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:67462d0669f8f5459529de179f7771bd697389fcb3faab54d63bf788599a48ea"}, + {file = "h5py-3.11.0-cp39-cp39-win_amd64.whl", hash = "sha256:d9c944d364688f827dc889cf83f1fca311caf4fa50b19f009d1f2b525edd33a3"}, + {file = "h5py-3.11.0.tar.gz", hash = "sha256:7b7e8f78072a2edec87c9836f25f34203fd492a4475709a18b417a33cfb21fa9"}, ] [package.dependencies] @@ -988,13 +989,13 @@ files = [ [[package]] name = "identify" -version = "2.5.35" +version = "2.5.36" description = "File identification library for Python" optional = false python-versions = ">=3.8" files = [ - {file = "identify-2.5.35-py2.py3-none-any.whl", hash = "sha256:c4de0081837b211594f8e877a6b4fad7ca32bbfc1a9307fdd61c28bfe923f13e"}, - {file = "identify-2.5.35.tar.gz", hash = "sha256:10a7ca245cfcd756a554a7288159f72ff105ad233c7c4b9c6f0f4d108f5f6791"}, + {file = "identify-2.5.36-py2.py3-none-any.whl", hash = "sha256:37d93f380f4de590500d9dba7db359d0d3da95ffe7f9de1753faa159e71e7dfa"}, + {file = "identify-2.5.36.tar.gz", hash = "sha256:e5e00f54165f9047fbebeb4a560f9acfb8af4c88232be60a488e9b68d122745d"}, ] [package.extras] @@ -1002,13 +1003,13 @@ license = ["ukkonen"] [[package]] name = "idna" -version = "3.6" +version = "3.7" description = "Internationalized Domain Names in Applications (IDNA)" optional = false python-versions = ">=3.5" files = [ - {file = "idna-3.6-py3-none-any.whl", hash = "sha256:c05567e9c24a6b9faaa835c4821bad0590fbb9d5779e7caa6e1cc4978e7eb24f"}, - {file = "idna-3.6.tar.gz", hash = "sha256:9ecdbbd083b06798ae1e86adcbfe8ab1479cf864e4ee30fe4e46a003d12491ca"}, + {file = "idna-3.7-py3-none-any.whl", hash = "sha256:82fee1fc78add43492d3a1898bfa6d8a904cc97d8427f683ed8e798d07761aa0"}, + {file = "idna-3.7.tar.gz", hash = "sha256:028ff3aadf0609c1fd278d8ea3089299412a7a8b9bd005dd08b9f8285bcb5cfc"}, ] [[package]] @@ -1090,13 +1091,13 @@ testing = ["Django", "attrs", "colorama", "docopt", "pytest (<7.0.0)"] [[package]] name = "jinja2" -version = "3.1.3" +version = "3.1.4" description = "A very fast and expressive template engine." optional = false python-versions = ">=3.7" files = [ - {file = "Jinja2-3.1.3-py3-none-any.whl", hash = "sha256:7d6d50dd97d52cbc355597bd845fabfbac3f551e1f99619e39a35ce8c370b5fa"}, - {file = "Jinja2-3.1.3.tar.gz", hash = "sha256:ac8bd6544d4bb2c9792bf3a159e80bba8fda7f07e81bc3aed565432d5925ba90"}, + {file = "jinja2-3.1.4-py3-none-any.whl", hash = "sha256:bc5dd2abb727a5319567b7a813e6a2e7318c39f4f487cfe6c89c6f9c7d25197d"}, + {file = "jinja2-3.1.4.tar.gz", hash = "sha256:4a3aee7acbbe7303aede8e9648d13b8bf88a429282aa6122a993f0ac800cb369"}, ] [package.dependencies] @@ -1516,47 +1517,47 @@ files = [ [[package]] name = "pandas" -version = "2.2.1" +version = "2.2.2" description = "Powerful data structures for data analysis, time series, and statistics" optional = false python-versions = ">=3.9" files = [ - {file = "pandas-2.2.1-cp310-cp310-macosx_10_9_x86_64.whl", hash = "sha256:8df8612be9cd1c7797c93e1c5df861b2ddda0b48b08f2c3eaa0702cf88fb5f88"}, - {file = "pandas-2.2.1-cp310-cp310-macosx_11_0_arm64.whl", hash = "sha256:0f573ab277252ed9aaf38240f3b54cfc90fff8e5cab70411ee1d03f5d51f3944"}, - {file = "pandas-2.2.1-cp310-cp310-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:f02a3a6c83df4026e55b63c1f06476c9aa3ed6af3d89b4f04ea656ccdaaaa359"}, - {file = "pandas-2.2.1-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:c38ce92cb22a4bea4e3929429aa1067a454dcc9c335799af93ba9be21b6beb51"}, - {file = "pandas-2.2.1-cp310-cp310-musllinux_1_1_aarch64.whl", hash = "sha256:c2ce852e1cf2509a69e98358e8458775f89599566ac3775e70419b98615f4b06"}, - {file = "pandas-2.2.1-cp310-cp310-musllinux_1_1_x86_64.whl", hash = "sha256:53680dc9b2519cbf609c62db3ed7c0b499077c7fefda564e330286e619ff0dd9"}, - {file = "pandas-2.2.1-cp310-cp310-win_amd64.whl", hash = "sha256:94e714a1cca63e4f5939cdce5f29ba8d415d85166be3441165edd427dc9f6bc0"}, - {file = "pandas-2.2.1-cp311-cp311-macosx_10_9_x86_64.whl", hash = "sha256:f821213d48f4ab353d20ebc24e4faf94ba40d76680642fb7ce2ea31a3ad94f9b"}, - {file = "pandas-2.2.1-cp311-cp311-macosx_11_0_arm64.whl", hash = "sha256:c70e00c2d894cb230e5c15e4b1e1e6b2b478e09cf27cc593a11ef955b9ecc81a"}, - {file = "pandas-2.2.1-cp311-cp311-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:e97fbb5387c69209f134893abc788a6486dbf2f9e511070ca05eed4b930b1b02"}, - {file = "pandas-2.2.1-cp311-cp311-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:101d0eb9c5361aa0146f500773395a03839a5e6ecde4d4b6ced88b7e5a1a6403"}, - {file = "pandas-2.2.1-cp311-cp311-musllinux_1_1_aarch64.whl", hash = "sha256:7d2ed41c319c9fb4fd454fe25372028dfa417aacb9790f68171b2e3f06eae8cd"}, - {file = "pandas-2.2.1-cp311-cp311-musllinux_1_1_x86_64.whl", hash = "sha256:af5d3c00557d657c8773ef9ee702c61dd13b9d7426794c9dfeb1dc4a0bf0ebc7"}, - {file = "pandas-2.2.1-cp311-cp311-win_amd64.whl", hash = "sha256:06cf591dbaefb6da9de8472535b185cba556d0ce2e6ed28e21d919704fef1a9e"}, - {file = "pandas-2.2.1-cp312-cp312-macosx_10_9_x86_64.whl", hash = "sha256:88ecb5c01bb9ca927ebc4098136038519aa5d66b44671861ffab754cae75102c"}, - {file = "pandas-2.2.1-cp312-cp312-macosx_11_0_arm64.whl", hash = "sha256:04f6ec3baec203c13e3f8b139fb0f9f86cd8c0b94603ae3ae8ce9a422e9f5bee"}, - {file = "pandas-2.2.1-cp312-cp312-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:a935a90a76c44fe170d01e90a3594beef9e9a6220021acfb26053d01426f7dc2"}, - {file = "pandas-2.2.1-cp312-cp312-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:c391f594aae2fd9f679d419e9a4d5ba4bce5bb13f6a989195656e7dc4b95c8f0"}, - {file = "pandas-2.2.1-cp312-cp312-musllinux_1_1_aarch64.whl", hash = "sha256:9d1265545f579edf3f8f0cb6f89f234f5e44ba725a34d86535b1a1d38decbccc"}, - {file = "pandas-2.2.1-cp312-cp312-musllinux_1_1_x86_64.whl", hash = "sha256:11940e9e3056576ac3244baef2fedade891977bcc1cb7e5cc8f8cc7d603edc89"}, - {file = "pandas-2.2.1-cp312-cp312-win_amd64.whl", hash = "sha256:4acf681325ee1c7f950d058b05a820441075b0dd9a2adf5c4835b9bc056bf4fb"}, - {file = "pandas-2.2.1-cp39-cp39-macosx_10_9_x86_64.whl", hash = "sha256:9bd8a40f47080825af4317d0340c656744f2bfdb6819f818e6ba3cd24c0e1397"}, - {file = "pandas-2.2.1-cp39-cp39-macosx_11_0_arm64.whl", hash = "sha256:df0c37ebd19e11d089ceba66eba59a168242fc6b7155cba4ffffa6eccdfb8f16"}, - {file = "pandas-2.2.1-cp39-cp39-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:739cc70eaf17d57608639e74d63387b0d8594ce02f69e7a0b046f117974b3019"}, - {file = "pandas-2.2.1-cp39-cp39-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:f9d3558d263073ed95e46f4650becff0c5e1ffe0fc3a015de3c79283dfbdb3df"}, - {file = "pandas-2.2.1-cp39-cp39-musllinux_1_1_aarch64.whl", hash = "sha256:4aa1d8707812a658debf03824016bf5ea0d516afdea29b7dc14cf687bc4d4ec6"}, - {file = "pandas-2.2.1-cp39-cp39-musllinux_1_1_x86_64.whl", hash = "sha256:76f27a809cda87e07f192f001d11adc2b930e93a2b0c4a236fde5429527423be"}, - {file = "pandas-2.2.1-cp39-cp39-win_amd64.whl", hash = "sha256:1ba21b1d5c0e43416218db63037dbe1a01fc101dc6e6024bcad08123e48004ab"}, - {file = "pandas-2.2.1.tar.gz", hash = "sha256:0ab90f87093c13f3e8fa45b48ba9f39181046e8f3317d3aadb2fffbb1b978572"}, + {file = "pandas-2.2.2-cp310-cp310-macosx_10_9_x86_64.whl", hash = "sha256:90c6fca2acf139569e74e8781709dccb6fe25940488755716d1d354d6bc58bce"}, + {file = "pandas-2.2.2-cp310-cp310-macosx_11_0_arm64.whl", hash = "sha256:c7adfc142dac335d8c1e0dcbd37eb8617eac386596eb9e1a1b77791cf2498238"}, + {file = "pandas-2.2.2-cp310-cp310-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:4abfe0be0d7221be4f12552995e58723c7422c80a659da13ca382697de830c08"}, + {file = "pandas-2.2.2-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:8635c16bf3d99040fdf3ca3db669a7250ddf49c55dc4aa8fe0ae0fa8d6dcc1f0"}, + {file = "pandas-2.2.2-cp310-cp310-musllinux_1_1_aarch64.whl", hash = "sha256:40ae1dffb3967a52203105a077415a86044a2bea011b5f321c6aa64b379a3f51"}, + {file = "pandas-2.2.2-cp310-cp310-musllinux_1_1_x86_64.whl", hash = "sha256:8e5a0b00e1e56a842f922e7fae8ae4077aee4af0acb5ae3622bd4b4c30aedf99"}, + {file = "pandas-2.2.2-cp310-cp310-win_amd64.whl", hash = "sha256:ddf818e4e6c7c6f4f7c8a12709696d193976b591cc7dc50588d3d1a6b5dc8772"}, + {file = "pandas-2.2.2-cp311-cp311-macosx_10_9_x86_64.whl", hash = "sha256:696039430f7a562b74fa45f540aca068ea85fa34c244d0deee539cb6d70aa288"}, + {file = "pandas-2.2.2-cp311-cp311-macosx_11_0_arm64.whl", hash = "sha256:8e90497254aacacbc4ea6ae5e7a8cd75629d6ad2b30025a4a8b09aa4faf55151"}, + {file = "pandas-2.2.2-cp311-cp311-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:58b84b91b0b9f4bafac2a0ac55002280c094dfc6402402332c0913a59654ab2b"}, + {file = "pandas-2.2.2-cp311-cp311-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:6d2123dc9ad6a814bcdea0f099885276b31b24f7edf40f6cdbc0912672e22eee"}, + {file = "pandas-2.2.2-cp311-cp311-musllinux_1_1_aarch64.whl", hash = "sha256:2925720037f06e89af896c70bca73459d7e6a4be96f9de79e2d440bd499fe0db"}, + {file = "pandas-2.2.2-cp311-cp311-musllinux_1_1_x86_64.whl", hash = "sha256:0cace394b6ea70c01ca1595f839cf193df35d1575986e484ad35c4aeae7266c1"}, + {file = "pandas-2.2.2-cp311-cp311-win_amd64.whl", hash = "sha256:873d13d177501a28b2756375d59816c365e42ed8417b41665f346289adc68d24"}, + {file = "pandas-2.2.2-cp312-cp312-macosx_10_9_x86_64.whl", hash = "sha256:9dfde2a0ddef507a631dc9dc4af6a9489d5e2e740e226ad426a05cabfbd7c8ef"}, + {file = "pandas-2.2.2-cp312-cp312-macosx_11_0_arm64.whl", hash = "sha256:e9b79011ff7a0f4b1d6da6a61aa1aa604fb312d6647de5bad20013682d1429ce"}, + {file = "pandas-2.2.2-cp312-cp312-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:1cb51fe389360f3b5a4d57dbd2848a5f033350336ca3b340d1c53a1fad33bcad"}, + {file = "pandas-2.2.2-cp312-cp312-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:eee3a87076c0756de40b05c5e9a6069c035ba43e8dd71c379e68cab2c20f16ad"}, + {file = "pandas-2.2.2-cp312-cp312-musllinux_1_1_aarch64.whl", hash = "sha256:3e374f59e440d4ab45ca2fffde54b81ac3834cf5ae2cdfa69c90bc03bde04d76"}, + {file = "pandas-2.2.2-cp312-cp312-musllinux_1_1_x86_64.whl", hash = "sha256:43498c0bdb43d55cb162cdc8c06fac328ccb5d2eabe3cadeb3529ae6f0517c32"}, + {file = "pandas-2.2.2-cp312-cp312-win_amd64.whl", hash = "sha256:d187d355ecec3629624fccb01d104da7d7f391db0311145817525281e2804d23"}, + {file = "pandas-2.2.2-cp39-cp39-macosx_10_9_x86_64.whl", hash = "sha256:0ca6377b8fca51815f382bd0b697a0814c8bda55115678cbc94c30aacbb6eff2"}, + {file = "pandas-2.2.2-cp39-cp39-macosx_11_0_arm64.whl", hash = "sha256:9057e6aa78a584bc93a13f0a9bf7e753a5e9770a30b4d758b8d5f2a62a9433cd"}, + {file = "pandas-2.2.2-cp39-cp39-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:001910ad31abc7bf06f49dcc903755d2f7f3a9186c0c040b827e522e9cef0863"}, + {file = "pandas-2.2.2-cp39-cp39-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:66b479b0bd07204e37583c191535505410daa8df638fd8e75ae1b383851fe921"}, + {file = "pandas-2.2.2-cp39-cp39-musllinux_1_1_aarch64.whl", hash = "sha256:a77e9d1c386196879aa5eb712e77461aaee433e54c68cf253053a73b7e49c33a"}, + {file = "pandas-2.2.2-cp39-cp39-musllinux_1_1_x86_64.whl", hash = "sha256:92fd6b027924a7e178ac202cfbe25e53368db90d56872d20ffae94b96c7acc57"}, + {file = "pandas-2.2.2-cp39-cp39-win_amd64.whl", hash = "sha256:640cef9aa381b60e296db324337a554aeeb883ead99dc8f6c18e81a93942f5f4"}, + {file = "pandas-2.2.2.tar.gz", hash = "sha256:9e79019aba43cb4fda9e4d983f8e88ca0373adbb697ae9c6c43093218de28b54"}, ] [package.dependencies] numpy = [ - {version = ">=1.22.4,<2", markers = "python_version < \"3.11\""}, - {version = ">=1.23.2,<2", markers = "python_version == \"3.11\""}, - {version = ">=1.26.0,<2", markers = "python_version >= \"3.12\""}, + {version = ">=1.22.4", markers = "python_version < \"3.11\""}, + {version = ">=1.23.2", markers = "python_version == \"3.11\""}, + {version = ">=1.26.0", markers = "python_version >= \"3.12\""}, ] python-dateutil = ">=2.8.2" pytz = ">=2020.1" @@ -1589,18 +1590,18 @@ xml = ["lxml (>=4.9.2)"] [[package]] name = "parso" -version = "0.8.3" +version = "0.8.4" description = "A Python Parser" optional = true python-versions = ">=3.6" files = [ - {file = "parso-0.8.3-py2.py3-none-any.whl", hash = "sha256:c001d4636cd3aecdaf33cbb40aebb59b094be2a74c556778ef5576c175e19e75"}, - {file = "parso-0.8.3.tar.gz", hash = "sha256:8c07be290bb59f03588915921e29e8a50002acaf2cdc5fa0e0114f91709fafa0"}, + {file = "parso-0.8.4-py2.py3-none-any.whl", hash = "sha256:a418670a20291dacd2dddc80c377c5c3791378ee1e8d12bffc35420643d43f18"}, + {file = "parso-0.8.4.tar.gz", hash = "sha256:eb3a7b58240fb99099a345571deecc0f9540ea5f4dd2fe14c2a99d6b281ab92d"}, ] [package.extras] -qa = ["flake8 (==3.8.3)", "mypy (==0.782)"] -testing = ["docopt", "pytest (<6.0.0)"] +qa = ["flake8 (==5.0.4)", "mypy (==0.971)", "types-setuptools (==67.2.0.1)"] +testing = ["docopt", "pytest"] [[package]] name = "pathspec" @@ -1640,28 +1641,29 @@ flake8 = ">=5.0.0" [[package]] name = "platformdirs" -version = "4.2.0" -description = "A small Python package for determining appropriate platform-specific dirs, e.g. a \"user data dir\"." +version = "4.2.1" +description = "A small Python package for determining appropriate platform-specific dirs, e.g. a `user data dir`." optional = false python-versions = ">=3.8" files = [ - {file = "platformdirs-4.2.0-py3-none-any.whl", hash = "sha256:0614df2a2f37e1a662acbd8e2b25b92ccf8632929bc6d43467e17fe89c75e068"}, - {file = "platformdirs-4.2.0.tar.gz", hash = "sha256:ef0cc731df711022c174543cb70a9b5bd22e5a9337c8624ef2c2ceb8ddad8768"}, + {file = "platformdirs-4.2.1-py3-none-any.whl", hash = "sha256:17d5a1161b3fd67b390023cb2d3b026bbd40abde6fdb052dfbd3a29c3ba22ee1"}, + {file = "platformdirs-4.2.1.tar.gz", hash = "sha256:031cd18d4ec63ec53e82dceaac0417d218a6863f7745dfcc9efe7793b7039bdf"}, ] [package.extras] docs = ["furo (>=2023.9.10)", "proselint (>=0.13)", "sphinx (>=7.2.6)", "sphinx-autodoc-typehints (>=1.25.2)"] test = ["appdirs (==1.4.4)", "covdefaults (>=2.3)", "pytest (>=7.4.3)", "pytest-cov (>=4.1)", "pytest-mock (>=3.12)"] +type = ["mypy (>=1.8)"] [[package]] name = "pluggy" -version = "1.4.0" +version = "1.5.0" description = "plugin and hook calling mechanisms for python" optional = false python-versions = ">=3.8" files = [ - {file = "pluggy-1.4.0-py3-none-any.whl", hash = "sha256:7db9f7b503d67d1c5b95f59773ebb58a8c1c288129a88665838012cfb07b8981"}, - {file = "pluggy-1.4.0.tar.gz", hash = "sha256:8c85c2876142a764e5b7548e7d9a0e0ddb46f5185161049a79b7e974454223be"}, + {file = "pluggy-1.5.0-py3-none-any.whl", hash = "sha256:44e1ad92c8ca002de6377e165f3e0f1be63266ab4d554740532335b9d75ea669"}, + {file = "pluggy-1.5.0.tar.gz", hash = "sha256:2cffa88e94fdc978c4c574f15f9e59b7f4201d439195c3715ca9e2486f1d0cf1"}, ] [package.extras] @@ -1808,17 +1810,16 @@ files = [ [[package]] name = "pygments" -version = "2.17.2" +version = "2.18.0" description = "Pygments is a syntax highlighting package written in Python." optional = false -python-versions = ">=3.7" +python-versions = ">=3.8" files = [ - {file = "pygments-2.17.2-py3-none-any.whl", hash = "sha256:b27c2826c47d0f3219f29554824c30c5e8945175d888647acd804ddd04af846c"}, - {file = "pygments-2.17.2.tar.gz", hash = "sha256:da46cec9fd2de5be3a8a784f434e4c4ab670b4ff54d605c4c2717e9d49c4c367"}, + {file = "pygments-2.18.0-py3-none-any.whl", hash = "sha256:b8e6aca0523f3ab76fee51799c488e38782ac06eafcf95e7ba832985c8e7b13a"}, + {file = "pygments-2.18.0.tar.gz", hash = "sha256:786ff802f32e91311bff3889f6e9a86e81505fe99f2735bb6d60ae0c5004f199"}, ] [package.extras] -plugins = ["importlib-metadata"] windows-terminal = ["colorama (>=0.4.6)"] [[package]] @@ -2114,18 +2115,18 @@ files = [ [[package]] name = "setuptools" -version = "69.2.0" +version = "69.5.1" description = "Easily download, build, install, upgrade, and uninstall Python packages" optional = false python-versions = ">=3.8" files = [ - {file = "setuptools-69.2.0-py3-none-any.whl", hash = "sha256:c21c49fb1042386df081cb5d86759792ab89efca84cf114889191cd09aacc80c"}, - {file = "setuptools-69.2.0.tar.gz", hash = "sha256:0ff4183f8f42cd8fa3acea16c45205521a4ef28f73c6391d8a25e92893134f2e"}, + {file = "setuptools-69.5.1-py3-none-any.whl", hash = "sha256:c636ac361bc47580504644275c9ad802c50415c7522212252c033bd15f301f32"}, + {file = "setuptools-69.5.1.tar.gz", hash = "sha256:6c1fccdac05a97e598fb0ae3bbed5904ccb317337a51139dcd51453611bbb987"}, ] [package.extras] -docs = ["furo", "jaraco.packaging (>=9.3)", "jaraco.tidelift (>=1.4)", "pygments-github-lexers (==0.0.5)", "rst.linker (>=1.9)", "sphinx (<7.2.5)", "sphinx (>=3.5)", "sphinx-favicon", "sphinx-inline-tabs", "sphinx-lint", "sphinx-notfound-page (>=1,<2)", "sphinx-reredirects", "sphinxcontrib-towncrier"] -testing = ["build[virtualenv]", "filelock (>=3.4.0)", "importlib-metadata", "ini2toml[lite] (>=0.9)", "jaraco.develop (>=7.21)", "jaraco.envs (>=2.2)", "jaraco.path (>=3.2.0)", "mypy (==1.9)", "packaging (>=23.2)", "pip (>=19.1)", "pytest (>=6)", "pytest-checkdocs (>=2.4)", "pytest-cov", "pytest-enabler (>=2.2)", "pytest-home (>=0.5)", "pytest-mypy (>=0.9.1)", "pytest-perf", "pytest-ruff (>=0.2.1)", "pytest-timeout", "pytest-xdist (>=3)", "tomli", "tomli-w (>=1.0.0)", "virtualenv (>=13.0.0)", "wheel"] +docs = ["furo", "jaraco.packaging (>=9.3)", "jaraco.tidelift (>=1.4)", "pygments-github-lexers (==0.0.5)", "rst.linker (>=1.9)", "sphinx (>=3.5)", "sphinx-favicon", "sphinx-inline-tabs", "sphinx-lint", "sphinx-notfound-page (>=1,<2)", "sphinx-reredirects", "sphinxcontrib-towncrier"] +testing = ["build[virtualenv]", "filelock (>=3.4.0)", "importlib-metadata", "ini2toml[lite] (>=0.9)", "jaraco.develop (>=7.21)", "jaraco.envs (>=2.2)", "jaraco.path (>=3.2.0)", "mypy (==1.9)", "packaging (>=23.2)", "pip (>=19.1)", "pytest (>=6,!=8.1.1)", "pytest-checkdocs (>=2.4)", "pytest-cov", "pytest-enabler (>=2.2)", "pytest-home (>=0.5)", "pytest-mypy", "pytest-perf", "pytest-ruff (>=0.2.1)", "pytest-timeout", "pytest-xdist (>=3)", "tomli", "tomli-w (>=1.0.0)", "virtualenv (>=13.0.0)", "wheel"] testing-integration = ["build[virtualenv] (>=1.0.3)", "filelock (>=3.4.0)", "jaraco.envs (>=2.2)", "jaraco.path (>=3.2.0)", "packaging (>=23.2)", "pytest", "pytest-enabler", "pytest-xdist", "tomli", "virtualenv (>=13.0.0)", "wheel"] [[package]] @@ -2526,13 +2527,13 @@ files = [ [[package]] name = "tqdm" -version = "4.66.2" +version = "4.66.4" description = "Fast, Extensible Progress Meter" optional = false python-versions = ">=3.7" files = [ - {file = "tqdm-4.66.2-py3-none-any.whl", hash = "sha256:1ee4f8a893eb9bef51c6e35730cebf234d5d0b6bd112b0271e10ed7c24a02bd9"}, - {file = "tqdm-4.66.2.tar.gz", hash = "sha256:6cd52cdf0fef0e0f543299cfc96fec90d7b8a7e88745f411ec33eb44d5ed3531"}, + {file = "tqdm-4.66.4-py3-none-any.whl", hash = "sha256:b75ca56b413b030bc3f00af51fd2c1a1a5eac6a0c1cca83cbb37a5c52abce644"}, + {file = "tqdm-4.66.4.tar.gz", hash = "sha256:e4d936c9de8727928f3be6079590e97d9abfe8d39a590be678eb5919ffc186bb"}, ] [package.dependencies] @@ -2566,13 +2567,13 @@ test = ["black (>=22.3.0,<23.0.0)", "coverage (>=6.2,<7.0)", "isort (>=5.0.6,<6. [[package]] name = "typing-extensions" -version = "4.10.0" +version = "4.11.0" description = "Backported and Experimental Type Hints for Python 3.8+" optional = false python-versions = ">=3.8" files = [ - {file = "typing_extensions-4.10.0-py3-none-any.whl", hash = "sha256:69b1a937c3a517342112fb4c6df7e72fc39a38e7891a5730ed4985b5214b5475"}, - {file = "typing_extensions-4.10.0.tar.gz", hash = "sha256:b0abd7c89e8fb96f98db18d86106ff1d90ab692004eb746cf6eda2682f91b3cb"}, + {file = "typing_extensions-4.11.0-py3-none-any.whl", hash = "sha256:c1f94d72897edaf4ce775bb7558d5b79d8126906a14ea5ed1635921406c0387a"}, + {file = "typing_extensions-4.11.0.tar.gz", hash = "sha256:83f085bd5ca59c80295fc2a82ab5dac679cbe02b9f33f7d83af68e241bea51b0"}, ] [[package]] @@ -2620,13 +2621,13 @@ zstd = ["zstandard (>=0.18.0)"] [[package]] name = "virtualenv" -version = "20.25.1" +version = "20.26.1" description = "Virtual Python Environment builder" optional = false python-versions = ">=3.7" files = [ - {file = "virtualenv-20.25.1-py3-none-any.whl", hash = "sha256:961c026ac520bac5f69acb8ea063e8a4f071bcc9457b9c1f28f6b085c511583a"}, - {file = "virtualenv-20.25.1.tar.gz", hash = "sha256:e08e13ecdca7a0bd53798f356d5831434afa5b07b93f0abdf0797b7a06ffe197"}, + {file = "virtualenv-20.26.1-py3-none-any.whl", hash = "sha256:7aa9982a728ae5892558bff6a2839c00b9ed145523ece2274fad6f414690ae75"}, + {file = "virtualenv-20.26.1.tar.gz", hash = "sha256:604bfdceaeece392802e6ae48e69cec49168b9c5f4a44e483963f9242eb0e78b"}, ] [package.dependencies] @@ -2635,7 +2636,7 @@ filelock = ">=3.12.2,<4" platformdirs = ">=3.9.1,<5" [package.extras] -docs = ["furo (>=2023.7.26)", "proselint (>=0.13)", "sphinx (>=7.1.2)", "sphinx-argparse (>=0.4)", "sphinxcontrib-towncrier (>=0.2.1a0)", "towncrier (>=23.6)"] +docs = ["furo (>=2023.7.26)", "proselint (>=0.13)", "sphinx (>=7.1.2,!=7.3)", "sphinx-argparse (>=0.4)", "sphinxcontrib-towncrier (>=0.2.1a0)", "towncrier (>=23.6)"] test = ["covdefaults (>=2.3)", "coverage (>=7.2.7)", "coverage-enable-subprocess (>=1)", "flaky (>=3.7)", "packaging (>=23.1)", "pytest (>=7.4)", "pytest-env (>=0.8.2)", "pytest-freezer (>=0.4.8)", "pytest-mock (>=3.11.1)", "pytest-randomly (>=3.12)", "pytest-timeout (>=2.1)", "setuptools (>=68)", "time-machine (>=2.10)"] [[package]] @@ -2707,4 +2708,4 @@ xarray = ["xarray"] [metadata] lock-version = "2.0" python-versions = "^3.9" -content-hash = "d5be6ceef0a2525bbc779fe5809b7f395ee33a4628abb5e43e8564fba7b7c651" +content-hash = "3a5894b98d081188ff6c25d1b44a957bdda286119a0ce25e9c0818238d1b178a" diff --git a/pyproject.toml b/pyproject.toml index de50866..f2dbc4c 100644 --- a/pyproject.toml +++ b/pyproject.toml @@ -61,7 +61,7 @@ attrs = "^23.1.0" typing-extensions = "^4.4.0" tqdm = "^4.64.1" psutil = "^5.9.5" -deker-local-adapters = "^1.0.1" +deker-local-adapters = { version = "^1.1.1b", source = "testpypi" } deker-server-adapters = {version = "^1.0.0", optional = true} deker-shell = { version = "^1.0.0", optional = true } xarray = {version = "^2023.5.0", optional = true} diff --git a/tests/test_cases/test_arrays/test_array_methods.py b/tests/test_cases/test_arrays/test_array_methods.py index 080b8d2..b4370d2 100644 --- a/tests/test_cases/test_arrays/test_array_methods.py +++ b/tests/test_cases/test_arrays/test_array_methods.py @@ -1,6 +1,5 @@ import os import string -from copy import deepcopy from datetime import datetime, timedelta, timezone from pathlib import Path @@ -14,7 +13,6 @@ from deker_local_adapters.factory import AdaptersFactory from numpy import ndarray -from deker.types import ArrayMeta from tests.parameters.array_params import attributes_validation_params from tests.parameters.index_exp_params import invalid_index_params, valid_index_exp_params from tests.parameters.uri import embedded_uri @@ -26,6 +24,7 @@ from deker.errors import DekerCollectionAlreadyExistsError, DekerMemoryError, DekerValidationError from deker.schemas import ArraySchema, AttributeSchema, DimensionSchema from deker.tools import get_paths +from deker.types import ArrayMeta from deker.types.private.typings import FancySlice, NumericDtypes, Slice diff --git a/tests/test_cases/test_arrays/test_varray_methods.py b/tests/test_cases/test_arrays/test_varray_methods.py index 7fc6807..4c3d7e3 100644 --- a/tests/test_cases/test_arrays/test_varray_methods.py +++ b/tests/test_cases/test_arrays/test_varray_methods.py @@ -14,7 +14,6 @@ from deker_tools.path import is_empty from numpy import ndarray -from deker.types import ArrayMeta from tests.parameters.array_params import attributes_validation_params from tests.parameters.index_exp_params import invalid_index_params, valid_index_exp_params from tests.parameters.uri import embedded_uri @@ -26,6 +25,7 @@ from deker.errors import DekerMemoryError, DekerValidationError from deker.schemas import DimensionSchema, VArraySchema from deker.tools import get_paths +from deker.types import ArrayMeta from deker.types.private.typings import FancySlice, Slice diff --git a/tests/test_cases/test_concurrency/test_in_processes.py b/tests/test_cases/test_concurrency/test_in_processes.py index d83379a..50032a8 100644 --- a/tests/test_cases/test_concurrency/test_in_processes.py +++ b/tests/test_cases/test_concurrency/test_in_processes.py @@ -14,7 +14,6 @@ from typing import Callable, Dict, Literal from unittest.mock import patch -import h5py import numpy as np import pytest @@ -28,7 +27,6 @@ from deker.errors import DekerLockError from deker.locks import ( CollectionLock, - CreateArrayLock, Flock, ReadArrayLock, UpdateMetaAttributeLock, @@ -36,7 +34,6 @@ WriteVarrayLock, ) from deker.schemas import ArraySchema, DimensionSchema, VArraySchema -from deker.tools import get_paths from deker.types import LocksExtensions, Numeric @@ -100,21 +97,6 @@ def call_array_method( subset_slice = slice_converter[subset_slice] # Get Array object - if method == "create": - with patch.object( - CreateArrayLock, - "release", - wait_unlock(CreateArrayLock.release, lock_set, funcs_finished, wait), - ): - with patch("deker.ABC.base_array.get_id", lambda *a: id_): - try: - array = collection.create(primary_attributes, custom_attributes) - except DekerLockError: - return DekerLockError - except Exception: - traceback.print_exc() - return None - return try: array = collection.filter({"id": id_}).last() except DekerLockError: @@ -551,60 +533,6 @@ def test_varray_update_meta_lock( finally: proc.kill() - def test_varray_with_attributes_create_lock( - self, - client: Client, - array_schema_with_attributes: ArraySchema, - root_path, - varray_with_attributes: VArray, - ): - """Test create lock.""" - manager = Manager() - lock_set = manager.Event() - func_finished = manager.Event() - proc = Process( - target=call_array_method, - args=( - varray_with_attributes.collection, - str(embedded_uri(root_path)), - varray_with_attributes.id, - "create", - lock_set, - func_finished, - True, - True, - varray_with_attributes.primary_attributes, - varray_with_attributes.custom_attributes, - ), - ) - proc.start() - lock_set.wait() - try: - methods = ["create"] * 3 - with Pool(WORKERS) as pool: - result = pool.starmap( - call_array_method, - [ - ( - varray_with_attributes.collection, - str(embedded_uri(root_path)), - varray_with_attributes.id, - method, - lock_set, - func_finished, - False, - True, - varray_with_attributes.primary_attributes, - varray_with_attributes.custom_attributes, - ) - for method in methods - ], - ) - assert result.count(DekerLockError) == len(methods) - func_finished.set() - finally: - proc.kill() - def test_collection_create(self, client: Client, root_path): """Test if collection is locked on creation.""" manager = Manager() @@ -640,78 +568,5 @@ def test_collection_create(self, client: Client, root_path): proc.kill() -class TestMethods: - """Test if methods work correctly with multiple processes.""" - - def test_array_with_attributes_create_multiple_processes( - self, - client: Client, - array_schema_with_attributes: ArraySchema, - root_path, - array_with_attributes: Array, - array_data: np.ndarray, - storage_adapter, - ctx, - ): - manager = Manager() - lock_set = manager.Event() - func_finished = manager.Event() - proc = Process( - target=call_array_method, - args=( - array_with_attributes.collection, - str(embedded_uri(root_path)), - array_with_attributes.id, - "create", - lock_set, - func_finished, - True, - False, - array_with_attributes.primary_attributes, - array_with_attributes.custom_attributes, - ), - ) - proc.start() - lock_set.wait() - - methods = ["create"] * 3 - with Pool(WORKERS - 1) as pool: - result = pool.starmap( - call_array_method, - [ - ( - array_with_attributes.collection, - str(embedded_uri(root_path)), - array_with_attributes.id, - method, - lock_set, - func_finished, - False, - False, - array_with_attributes.primary_attributes, - array_with_attributes.custom_attributes, - ) - for method in methods - ], - ) - lock_set.wait() - assert result.count(DekerLockError) == len(methods) - func_finished.set() - - paths = get_paths( - array_with_attributes, - root_path / ctx.config.collections_directory / array_with_attributes.collection, - ) - filename = str(array_with_attributes.id) + storage_adapter.file_ext - file_path = paths.main / filename - symlink = paths.symlink / filename - assert file_path.exists() - assert symlink.exists() - array_with_attributes[:].update(array_data) - - with h5py.File(file_path) as f: - assert np.allclose(f["data"][:], np.asarray(array_data), equal_nan=True) - - if __name__ == "__main__": pytest.main() diff --git a/tests/test_cases/test_schemas/test_attributes_schema.py b/tests/test_cases/test_schemas/test_attributes_schema.py index 1a4e981..247ea53 100644 --- a/tests/test_cases/test_schemas/test_attributes_schema.py +++ b/tests/test_cases/test_schemas/test_attributes_schema.py @@ -4,7 +4,6 @@ from datetime import datetime from typing import FrozenSet -import numpy as np import pytest from deker_local_adapters import LocalArrayAdapter From 8255e275c7bfd272a757d3f8c1c2f4fc01e77943 Mon Sep 17 00:00:00 2001 From: Sergey Rybakov Date: Tue, 7 May 2024 18:35:18 +0300 Subject: [PATCH 2/4] CreateArrayLock removed --- deker/managers.py | 6 +++--- deker/subset.py | 3 +-- 2 files changed, 4 insertions(+), 5 deletions(-) diff --git a/deker/managers.py b/deker/managers.py index 15559e2..855401c 100644 --- a/deker/managers.py +++ b/deker/managers.py @@ -132,11 +132,11 @@ def _create( # type: ignore "array_adapter": self.__array_adapter, # type: ignore[dict-item] } ) - array = VArray(**arr_params) # type: ignore[arg-type] + obj = VArray else: arr_params.update({"adapter": self.__array_adapter}) # type: ignore[dict-item] - array = Array(**arr_params) # type: ignore[arg-type] - self._adapter.create(array) + obj = Array + array = self._adapter.create(obj(**arr_params)) # type: ignore[arg-type] return array def create( diff --git a/deker/subset.py b/deker/subset.py index 1bd2ba4..de7b1aa 100644 --- a/deker/subset.py +++ b/deker/subset.py @@ -610,8 +610,7 @@ def _update(array_data: ArrayPositionedData) -> None: }, "custom_attributes": custom_attributes, } - array = Array(**kwargs) # type: ignore[arg-type] - self.__array_adapter.create(array) + array = self.__array_adapter.create(Array(**kwargs)) # type: ignore[arg-type] subset = array[array_data.bounds] subset.update(array_data.data) From 3104a746fb5ec3a9fde6a519c2818e40de6d7341 Mon Sep 17 00:00:00 2001 From: Sergey Rybakov Date: Wed, 8 May 2024 11:04:22 +0300 Subject: [PATCH 3/4] no return from adapters' create methods --- deker/managers.py | 6 +++--- deker/subset.py | 3 ++- poetry.lock | 6 +++--- pyproject.toml | 2 +- 4 files changed, 9 insertions(+), 8 deletions(-) diff --git a/deker/managers.py b/deker/managers.py index 855401c..15559e2 100644 --- a/deker/managers.py +++ b/deker/managers.py @@ -132,11 +132,11 @@ def _create( # type: ignore "array_adapter": self.__array_adapter, # type: ignore[dict-item] } ) - obj = VArray + array = VArray(**arr_params) # type: ignore[arg-type] else: arr_params.update({"adapter": self.__array_adapter}) # type: ignore[dict-item] - obj = Array - array = self._adapter.create(obj(**arr_params)) # type: ignore[arg-type] + array = Array(**arr_params) # type: ignore[arg-type] + self._adapter.create(array) return array def create( diff --git a/deker/subset.py b/deker/subset.py index de7b1aa..1bd2ba4 100644 --- a/deker/subset.py +++ b/deker/subset.py @@ -610,7 +610,8 @@ def _update(array_data: ArrayPositionedData) -> None: }, "custom_attributes": custom_attributes, } - array = self.__array_adapter.create(Array(**kwargs)) # type: ignore[arg-type] + array = Array(**kwargs) # type: ignore[arg-type] + self.__array_adapter.create(array) subset = array[array_data.bounds] subset.update(array_data.data) diff --git a/poetry.lock b/poetry.lock index a0ad07e..4ee79d8 100644 --- a/poetry.lock +++ b/poetry.lock @@ -499,12 +499,12 @@ optimize = ["orjson"] [[package]] name = "deker-local-adapters" -version = "1.1.1b0" +version = "1.1.1b1" description = "Plugin with local adapters for deker" optional = false python-versions = ">=3.9,<4.0" files = [ - {file = "deker_local_adapters-1.1.1b0.tar.gz", hash = "sha256:415e3d74410c0f8f04cea6ee72b289b261bcbf801565f7c79b68ef901c8de24e"}, + {file = "deker_local_adapters-1.1.1b1.tar.gz", hash = "sha256:532c0f732fb0f47b4a14ecc7dbbb2ec32761fb00e322262e39fcdddd525fc86d"}, ] [package.dependencies] @@ -2708,4 +2708,4 @@ xarray = ["xarray"] [metadata] lock-version = "2.0" python-versions = "^3.9" -content-hash = "3a5894b98d081188ff6c25d1b44a957bdda286119a0ce25e9c0818238d1b178a" +content-hash = "f68067cb2c72456d22a10c64da6512d49d0c29e11569cd22a6b97b158d9ab09f" diff --git a/pyproject.toml b/pyproject.toml index f2dbc4c..246b7c8 100644 --- a/pyproject.toml +++ b/pyproject.toml @@ -61,7 +61,7 @@ attrs = "^23.1.0" typing-extensions = "^4.4.0" tqdm = "^4.64.1" psutil = "^5.9.5" -deker-local-adapters = { version = "^1.1.1b", source = "testpypi" } +deker-local-adapters = { version = "^1.1.1b-1", source = "testpypi" } deker-server-adapters = {version = "^1.0.0", optional = true} deker-shell = { version = "^1.0.0", optional = true } xarray = {version = "^2023.5.0", optional = true} From 7874452ee56f9d17dcc735516a1237a48423063b Mon Sep 17 00:00:00 2001 From: Sergey Rybakov Date: Wed, 8 May 2024 11:34:16 +0300 Subject: [PATCH 4/4] actions/download-artifact upgraded to v4; poetry locked --- .github/workflows/on_release.yml | 2 +- .github/workflows/on_test_release.yml | 2 +- poetry.lock | 13 ++++--------- pyproject.toml | 2 +- 4 files changed, 7 insertions(+), 12 deletions(-) diff --git a/.github/workflows/on_release.yml b/.github/workflows/on_release.yml index 5efecad..e440ae0 100644 --- a/.github/workflows/on_release.yml +++ b/.github/workflows/on_release.yml @@ -38,7 +38,7 @@ jobs: url: https://pypi.org/p/${{ vars.PACKAGE_NAME }} steps: - - uses: actions/download-artifact@v3 + - uses: actions/download-artifact@v4 with: # unpacks default artifact into dist/ # if `name: artifact` is omitted, the action will create extra parent dir diff --git a/.github/workflows/on_test_release.yml b/.github/workflows/on_test_release.yml index 7472e6c..446324c 100644 --- a/.github/workflows/on_test_release.yml +++ b/.github/workflows/on_test_release.yml @@ -21,7 +21,7 @@ jobs: url: https://test.pypi.org/p/${{ vars.PACKAGE_NAME }} steps: - - uses: actions/download-artifact@v3 + - uses: actions/download-artifact@v4 with: # unpacks default artifact into dist/ # if `name: artifact` is omitted, the action will create extra parent dir diff --git a/poetry.lock b/poetry.lock index 4ee79d8..47dc925 100644 --- a/poetry.lock +++ b/poetry.lock @@ -499,12 +499,12 @@ optimize = ["orjson"] [[package]] name = "deker-local-adapters" -version = "1.1.1b1" +version = "1.1.1" description = "Plugin with local adapters for deker" optional = false -python-versions = ">=3.9,<4.0" +python-versions = "<4.0,>=3.9" files = [ - {file = "deker_local_adapters-1.1.1b1.tar.gz", hash = "sha256:532c0f732fb0f47b4a14ecc7dbbb2ec32761fb00e322262e39fcdddd525fc86d"}, + {file = "deker_local_adapters-1.1.1.tar.gz", hash = "sha256:c3d5ec08bf479e5c7852a263f127e6896b38507ec34f7337eb6bc41305cb1143"}, ] [package.dependencies] @@ -513,11 +513,6 @@ h5py = ">=3.8.0,<4.0.0" hdf5plugin = ">=4.0.1,<5.0.0" numpy = ">=1.18,<2.0" -[package.source] -type = "legacy" -url = "https://test.pypi.org/simple" -reference = "testpypi" - [[package]] name = "deker-server-adapters" version = "1.0.5" @@ -2708,4 +2703,4 @@ xarray = ["xarray"] [metadata] lock-version = "2.0" python-versions = "^3.9" -content-hash = "f68067cb2c72456d22a10c64da6512d49d0c29e11569cd22a6b97b158d9ab09f" +content-hash = "a94291f635fab7ce16a9164c854bd3150468072cc9c9d400da90b204bc05595d" diff --git a/pyproject.toml b/pyproject.toml index 246b7c8..761d030 100644 --- a/pyproject.toml +++ b/pyproject.toml @@ -61,7 +61,7 @@ attrs = "^23.1.0" typing-extensions = "^4.4.0" tqdm = "^4.64.1" psutil = "^5.9.5" -deker-local-adapters = { version = "^1.1.1b-1", source = "testpypi" } +deker-local-adapters = "^1.1.1" deker-server-adapters = {version = "^1.0.0", optional = true} deker-shell = { version = "^1.0.0", optional = true } xarray = {version = "^2023.5.0", optional = true}