Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

fyi: datasets created with version v0.14.25 are not backward compatible with v0.14.24 #1142

Closed
erjel opened this issue Jul 22, 2024 · 1 comment
Labels

Comments

@erjel
Copy link
Contributor

erjel commented Jul 22, 2024

I cannot read datasets created with version 0.14.25 onward with version 0.14.24.

Error message:

>>> import webknossos as wk
>>> wk.Dataset.open('my_newer_dataset')
  + Exception Group Traceback (most recent call last):
  |   File "<stdin>", line 1, in <module>
  |   File "$HOME/src/webknossos-libs-test/webknossos/webknossos/dataset/dataset.py", line 386, in open
  |     return cls(dataset_path, voxel_size=_UNSPECIFIED_SCALE_FROM_OPEN, exist_ok=True)
  |   File "$HOME/src/webknossos-libs-test/webknossos/webknossos/dataset/dataset.py", line 322, in __init__
  |     self._properties: DatasetProperties = self._load_properties()
  |   File "$HOME/src/webknossos-libs-test/webknossos/webknossos/dataset/dataset.py", line 1845, in _load_properties
  |     return dataset_converter.structure(data, DatasetProperties)
  |   File "$HOME/.cache/pypoetry/virtualenvs/webknossos-lsrBp02S-py3.10/lib/python3.10/site-packages/cattrs/converters.py", line 334, in structure
  |     return self._structure_func.dispatch(cl)(obj, cl)
  |   File "<cattrs generated structure webknossos.dataset.properties.DatasetProperties>", line 25, in structure_DatasetProperties
  |     if errors: raise __c_cve('While structuring ' + 'DatasetProperties', errors, __cl)
  | cattrs.errors.ClassValidationError: While structuring DatasetProperties (1 sub-exception)
  +-+---------------- 1 ----------------
    | Exception Group Traceback (most recent call last):
    |   File "<cattrs generated structure webknossos.dataset.properties.DatasetProperties>", line 10, in structure_DatasetProperties
    |     res['scale'] = __c_structure_scale(o['scale'], __c_type_scale)
    |   File "$HOME/.cache/pypoetry/virtualenvs/webknossos-lsrBp02S-py3.10/lib/python3.10/site-packages/cattrs/converters.py", line 721, in _structure_tuple
    |     raise IterableValidationError(
    | cattrs.errors.IterableValidationError: While structuring typing.Tuple[float, float, float] (3 sub-exceptions)
    | Structuring class DatasetProperties @ attribute scale
    +-+---------------- 1 ----------------
      | Traceback (most recent call last):
      |   File "$HOME/.cache/pypoetry/virtualenvs/webknossos-lsrBp02S-py3.10/lib/python3.10/site-packages/cattrs/converters.py", line 705, in _structure_tuple
      |     res.append(conv(e, t))
      |   File "$HOME/.cache/pypoetry/virtualenvs/webknossos-lsrBp02S-py3.10/lib/python3.10/site-packages/cattrs/converters.py", line 440, in _structure_call
      |     return cl(obj)
      | ValueError: could not convert string to float: 'factor'
      | Structuring typing.Tuple[float, float, float] @ index 0
      +---------------- 2 ----------------
      | Traceback (most recent call last):
      |   File "$HOME/.cache/pypoetry/virtualenvs/webknossos-lsrBp02S-py3.10/lib/python3.10/site-packages/cattrs/converters.py", line 705, in _structure_tuple
      |     res.append(conv(e, t))
      |   File "$HOME/.cache/pypoetry/virtualenvs/webknossos-lsrBp02S-py3.10/lib/python3.10/site-packages/cattrs/converters.py", line 440, in _structure_call
      |     return cl(obj)
      | ValueError: could not convert string to float: 'unit'
      | Structuring typing.Tuple[float, float, float] @ index 1
      +---------------- 3 ----------------
      | ValueError: Not enough values in {'factor': [9.8, 9.8, 30.0], 'unit': 'nanometer'} to structure as typing.Tuple[float, float, float]
      | Structuring typing.Tuple[float, float, float]
      +------------------------------------

I will update my environments to the newer versions now, I just want to make you aware of the breaking change.

Best wishes,
Eric

@erjel erjel added the bug label Jul 22, 2024
@erjel erjel changed the title fyi: datasets create with version v0.14.25 is not backward compatible with v0.14.24 fyi: datasets created with version v0.14.25 are not backward compatible with v0.14.24 Jul 22, 2024
@erjel erjel closed this as completed Oct 25, 2024
@hotzenklotz
Copy link
Member

hotzenklotz commented Oct 25, 2024

@erjel Thanks for letting us know.

On an unrelated note, we recently switched from poetry to uv for Python package and environment management. Maybe you would like to check it out as well. PR

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Projects
None yet
Development

No branches or pull requests

2 participants