tomwer 1.2.8__py3-none-any.whl → 1.3.0a0__py3-none-any.whl
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- orangecontrib/tomwer/tutorials/icat_publication.ows +58 -0
- orangecontrib/tomwer/widgets/__init__.py +1 -0
- orangecontrib/tomwer/widgets/control/DataDiscoveryOW.py +2 -2
- orangecontrib/tomwer/widgets/control/DataListOW.py +9 -7
- orangecontrib/tomwer/widgets/control/DataSelectorOW.py +21 -10
- orangecontrib/tomwer/widgets/control/EDF2NXTomomillOW.py +11 -5
- orangecontrib/tomwer/widgets/control/EmailOW.py +4 -4
- orangecontrib/tomwer/widgets/control/NXTomomillOW.py +31 -18
- orangecontrib/tomwer/widgets/control/NXtomoConcatenate.py +14 -7
- orangecontrib/tomwer/widgets/control/NotifierOW.py +1 -0
- orangecontrib/tomwer/widgets/control/VolumeSelector.py +7 -4
- orangecontrib/tomwer/widgets/control/VolumeSymLinkOW.py +182 -182
- orangecontrib/tomwer/widgets/debugtools/DatasetGeneratorOW.py +4 -4
- orangecontrib/tomwer/widgets/edit/DarkFlatPatchOW.py +4 -4
- orangecontrib/tomwer/widgets/edit/ImageKeyEditorOW.py +3 -3
- orangecontrib/tomwer/widgets/edit/ImageKeyUpgraderOW.py +2 -0
- orangecontrib/tomwer/widgets/edit/NXtomoEditorOW.py +3 -3
- orangecontrib/tomwer/widgets/edit/test/test_nxtomo_editor.py +3 -3
- orangecontrib/tomwer/widgets/icat/PublishProcessedDataOW.py +115 -0
- orangecontrib/tomwer/widgets/icat/RawDataScreenshotCreatorOW.py +98 -0
- orangecontrib/tomwer/widgets/icat/SaveToGalleryAndPublishOW.py +129 -0
- orangecontrib/tomwer/widgets/icat/__init__.py +13 -0
- orangecontrib/tomwer/widgets/icat/icons/add_gallery.png +0 -0
- orangecontrib/tomwer/widgets/icat/icons/add_gallery.svg +82 -0
- orangecontrib/tomwer/widgets/icat/icons/publish_processed_data.png +0 -0
- orangecontrib/tomwer/widgets/icat/icons/publish_processed_data.svg +95 -0
- orangecontrib/tomwer/widgets/icat/icons/raw_screenshots.png +0 -0
- orangecontrib/tomwer/widgets/icat/icons/raw_screenshots.svg +143 -0
- orangecontrib/tomwer/widgets/icons/tomwer_data_portal.png +0 -0
- orangecontrib/tomwer/widgets/icons/tomwer_data_portal.svg +76 -0
- orangecontrib/tomwer/widgets/reconstruction/AxisOW.py +9 -8
- orangecontrib/tomwer/widgets/reconstruction/CastNabuVolumeOW.py +3 -3
- orangecontrib/tomwer/widgets/reconstruction/NabuHelicalPrepareWeightsDoubleOW.py +179 -169
- orangecontrib/tomwer/widgets/reconstruction/NabuOW.py +23 -0
- orangecontrib/tomwer/widgets/reconstruction/NabuVolumeOW.py +39 -5
- orangecontrib/tomwer/widgets/reconstruction/SAAxisOW.py +7 -13
- orangecontrib/tomwer/widgets/reconstruction/SADeltaBetaOW.py +7 -17
- orangecontrib/tomwer/widgets/reconstruction/SinoNormOW.py +3 -4
- orangecontrib/tomwer/widgets/visualization/LivesliceOW.py +1 -1
- orangecontrib/tomwer/widgets/visualization/NXtomoMetadataViewerOW.py +3 -3
- orangecontrib/tomwer/widgets/visualization/VolumeViewerOW.py +3 -29
- tomwer/__main__.py +11 -58
- tomwer/app/canvas.py +8 -0
- tomwer/app/canvas_launcher/config.py +13 -11
- tomwer/app/darkref.py +1 -1
- tomwer/app/darkrefpatch.py +1 -1
- tomwer/app/imagekeyeditor.py +5 -5
- tomwer/app/imagekeyupgrader.py +5 -5
- tomwer/app/intensitynormalization.py +2 -2
- tomwer/app/radiostack.py +2 -2
- tomwer/app/zstitching.py +74 -3
- tomwer/core/cluster/cluster.py +26 -0
- tomwer/core/log/logger.py +7 -5
- tomwer/core/process/conditions/filters.py +1 -1
- tomwer/core/process/control/datalistener/datalistener.py +3 -3
- tomwer/core/process/control/nxtomoconcatenate.py +13 -13
- tomwer/core/process/control/nxtomomill.py +83 -25
- tomwer/core/process/control/scantransfer.py +11 -10
- tomwer/core/process/control/scanvalidator.py +3 -2
- tomwer/core/process/control/test/test_concatenate_nxtomos.py +9 -9
- tomwer/core/process/control/test/test_email.py +4 -4
- tomwer/core/process/control/test/test_h52nx_process.py +59 -7
- tomwer/core/process/control/test/test_volume_link.py +64 -64
- tomwer/core/process/control/timer.py +1 -1
- tomwer/core/process/control/volumesymlink.py +200 -200
- tomwer/core/process/edit/darkflatpatch.py +6 -6
- tomwer/core/process/edit/imagekeyeditor.py +17 -18
- tomwer/core/process/icat/__init__.py +0 -0
- tomwer/core/process/icat/createscreenshots.py +100 -0
- tomwer/core/process/icat/gallery.py +377 -0
- tomwer/core/process/icat/icatbase.py +36 -0
- tomwer/core/process/icat/publish.py +228 -0
- tomwer/core/process/icat/screenshots.py +26 -0
- tomwer/core/process/output.py +52 -0
- tomwer/core/process/reconstruction/axis/axis.py +17 -10
- tomwer/core/process/reconstruction/axis/mode.py +4 -0
- tomwer/core/process/reconstruction/axis/params.py +9 -4
- tomwer/core/process/reconstruction/darkref/darkrefs.py +8 -6
- tomwer/core/process/reconstruction/darkref/darkrefscopy.py +1 -1
- tomwer/core/process/reconstruction/darkref/params.py +1 -1
- tomwer/core/process/reconstruction/lamino/tofu.py +4 -4
- tomwer/core/process/reconstruction/nabu/castvolume.py +1 -1
- tomwer/core/process/reconstruction/nabu/helical.py +9 -5
- tomwer/core/process/reconstruction/nabu/nabucommon.py +32 -62
- tomwer/core/process/reconstruction/nabu/nabuscores.py +387 -61
- tomwer/core/process/reconstruction/nabu/nabuslices.py +33 -21
- tomwer/core/process/reconstruction/nabu/nabuvolume.py +37 -14
- tomwer/core/process/reconstruction/nabu/settings.py +2 -2
- tomwer/core/process/reconstruction/nabu/utils.py +129 -24
- tomwer/core/process/reconstruction/output.py +108 -0
- tomwer/core/process/reconstruction/saaxis/saaxis.py +233 -263
- tomwer/core/process/reconstruction/sadeltabeta/sadeltabeta.py +140 -86
- tomwer/core/process/reconstruction/scores/params.py +4 -1
- tomwer/core/process/reconstruction/scores/scores.py +13 -0
- tomwer/core/process/reconstruction/test/test_axis_params.py +2 -2
- tomwer/core/process/reconstruction/test/test_darkref.py +3 -3
- tomwer/core/process/reconstruction/test/test_darkref_copy.py +3 -3
- tomwer/core/process/reconstruction/test/test_saaxis.py +3 -4
- tomwer/core/process/reconstruction/test/test_sadeltabeta.py +2 -2
- tomwer/core/process/stitching/nabustitcher.py +2 -2
- tomwer/core/process/test/test_axis.py +6 -6
- tomwer/core/process/test/test_dark_and_flat.py +10 -7
- tomwer/core/process/test/test_data_transfer.py +7 -6
- tomwer/core/process/test/test_nabu.py +4 -4
- tomwer/core/process/test/test_normalization.py +2 -2
- tomwer/core/scan/edfscan.py +4 -1
- tomwer/core/scan/hdf5scan.py +19 -500
- tomwer/core/scan/nxtomoscan.py +532 -0
- tomwer/core/scan/scanbase.py +42 -20
- tomwer/core/scan/scanfactory.py +13 -13
- tomwer/core/scan/test/test_future_scan.py +2 -2
- tomwer/core/scan/test/test_h5.py +12 -10
- tomwer/core/scan/test/test_process_registration.py +2 -2
- tomwer/core/scan/test/test_scan.py +4 -3
- tomwer/core/settings.py +20 -0
- tomwer/core/test/test_scanutils.py +8 -7
- tomwer/core/test/test_utils.py +33 -26
- tomwer/core/utils/__init__.py +0 -466
- tomwer/core/utils/deprecation.py +1 -1
- tomwer/core/utils/dictutils.py +14 -0
- tomwer/core/utils/lbsram.py +35 -0
- tomwer/core/utils/nxtomoutils.py +1 -1
- tomwer/core/utils/scanutils.py +6 -6
- tomwer/core/utils/spec.py +263 -0
- tomwer/core/volume/volumefactory.py +2 -2
- tomwer/gui/cluster/slurm.py +260 -60
- tomwer/gui/cluster/test/test_cluster.py +13 -0
- tomwer/gui/cluster/test/test_supervisor.py +2 -2
- tomwer/gui/configuration/__init__.py +0 -0
- tomwer/gui/{reconstruction/nabu → configuration}/action.py +1 -32
- tomwer/gui/configuration/level.py +22 -0
- tomwer/gui/control/actions.py +54 -0
- tomwer/gui/control/datalist.py +78 -16
- tomwer/gui/control/datalistener.py +4 -16
- tomwer/gui/control/{email.py → emailnotifier.py} +9 -18
- tomwer/gui/control/history.py +2 -2
- tomwer/gui/control/observations.py +2 -2
- tomwer/gui/control/reducedarkflatselector.py +1 -1
- tomwer/gui/control/selectorwidgetbase.py +36 -9
- tomwer/gui/control/serie/seriecreator.py +5 -22
- tomwer/gui/control/test/test_email.py +1 -1
- tomwer/gui/control/test/test_scanvalidator.py +6 -5
- tomwer/gui/control/test/test_single_tomo_obj.py +2 -2
- tomwer/gui/control/tomoobjdisplaymode.py +8 -0
- tomwer/gui/debugtools/datasetgenerator.py +3 -3
- tomwer/gui/edit/dkrfpatch.py +16 -22
- tomwer/gui/edit/imagekeyeditor.py +8 -11
- tomwer/gui/edit/nxtomoeditor.py +111 -44
- tomwer/gui/edit/nxtomowarmer.py +4 -4
- tomwer/gui/edit/test/test_dkrf_patch.py +7 -7
- tomwer/gui/edit/test/test_image_key_editor.py +3 -3
- tomwer/gui/edit/test/test_nx_editor.py +40 -16
- tomwer/gui/icat/__init__.py +0 -0
- tomwer/gui/icat/createscreenshots.py +80 -0
- tomwer/gui/icat/gallery.py +214 -0
- tomwer/gui/icat/publish.py +187 -0
- tomwer/gui/reconstruction/axis/axis.py +171 -57
- tomwer/gui/reconstruction/axis/radioaxis.py +80 -95
- tomwer/gui/reconstruction/darkref/darkrefcopywidget.py +3 -2
- tomwer/gui/reconstruction/lamino/tofu/projections.py +1 -1
- tomwer/gui/reconstruction/lamino/tofu/tofuoutput.py +3 -6
- tomwer/gui/reconstruction/nabu/castvolume.py +1 -1
- tomwer/gui/reconstruction/nabu/check.py +9 -9
- tomwer/gui/reconstruction/nabu/helical.py +29 -12
- tomwer/gui/reconstruction/nabu/nabuconfig/base.py +2 -4
- tomwer/gui/reconstruction/nabu/nabuconfig/output.py +110 -33
- tomwer/gui/reconstruction/nabu/nabuconfig/phase.py +9 -12
- tomwer/gui/reconstruction/nabu/nabuconfig/preprocessing.py +219 -29
- tomwer/gui/reconstruction/nabu/nabuconfig/reconstruction.py +3 -6
- tomwer/gui/reconstruction/nabu/nabuflow.py +12 -20
- tomwer/gui/reconstruction/nabu/slices.py +6 -7
- tomwer/gui/reconstruction/nabu/volume.py +22 -10
- tomwer/gui/reconstruction/normalization/intensity.py +15 -23
- tomwer/gui/reconstruction/saaxis/corrangeselector.py +7 -23
- tomwer/gui/reconstruction/saaxis/dimensionwidget.py +1 -1
- tomwer/gui/reconstruction/saaxis/saaxis.py +7 -9
- tomwer/gui/reconstruction/sadeltabeta/saadeltabeta.py +2 -1
- tomwer/gui/reconstruction/scores/control.py +2 -9
- tomwer/gui/reconstruction/scores/scoreplot.py +11 -5
- tomwer/gui/reconstruction/test/test_axis.py +23 -12
- tomwer/gui/reconstruction/test/test_lamino.py +8 -3
- tomwer/gui/reconstruction/test/test_nabu.py +28 -9
- tomwer/gui/reconstruction/test/test_saaxis.py +3 -3
- tomwer/gui/reconstruction/test/test_sadeltabeta.py +2 -2
- tomwer/gui/settings.py +5 -28
- tomwer/gui/stackplot.py +2 -5
- tomwer/gui/stitching/action.py +49 -0
- tomwer/gui/stitching/config/axisparams.py +7 -24
- tomwer/gui/stitching/config/output.py +10 -8
- tomwer/gui/stitching/config/positionoveraxis.py +22 -23
- tomwer/gui/stitching/normalization.py +117 -0
- tomwer/gui/stitching/stitchandbackground.py +4 -6
- tomwer/gui/stitching/stitching.py +265 -43
- tomwer/gui/stitching/stitching_preview.py +62 -5
- tomwer/gui/stitching/stitching_raw.py +2 -5
- tomwer/gui/stitching/z_stitching/fineestimation.py +0 -60
- tomwer/gui/utils/buttons.py +112 -29
- tomwer/gui/utils/inputwidget.py +33 -25
- tomwer/gui/utils/scandescription.py +4 -0
- tomwer/gui/utils/step.py +144 -0
- tomwer/gui/utils/unitsystem.py +2 -5
- tomwer/gui/utils/vignettes.py +176 -15
- tomwer/gui/visualization/dataviewer.py +1 -18
- tomwer/gui/visualization/diffviewer/diffviewer.py +7 -16
- tomwer/gui/visualization/diffviewer/shiftwidget.py +2 -5
- tomwer/gui/visualization/scanoverview.py +1 -1
- tomwer/gui/visualization/sinogramviewer.py +1 -10
- tomwer/gui/visualization/test/test_diffviewer.py +3 -3
- tomwer/gui/visualization/test/test_nx_tomo_metadata_viewer.py +4 -4
- tomwer/gui/visualization/test/test_sinogramviewer.py +2 -2
- tomwer/gui/visualization/test/test_stacks.py +3 -3
- tomwer/gui/visualization/test/test_volumeviewer.py +2 -2
- tomwer/io/utils/raw_and_processed_data.py +84 -0
- tomwer/io/utils/tomoobj.py +4 -6
- tomwer/resources/gui/icons/ruler.png +0 -0
- tomwer/resources/gui/icons/ruler.svg +273 -0
- tomwer/resources/gui/icons/short_description.png +0 -0
- tomwer/resources/gui/icons/short_description.svg +58 -0
- tomwer/resources/gui/icons/url.png +0 -0
- tomwer/resources/gui/icons/url.svg +58 -0
- tomwer/synctools/stacks/edit/darkflatpatch.py +2 -2
- tomwer/synctools/stacks/edit/imagekeyeditor.py +2 -2
- tomwer/synctools/stacks/reconstruction/axis.py +4 -4
- tomwer/synctools/stacks/reconstruction/castvolume.py +2 -2
- tomwer/synctools/stacks/reconstruction/dkrefcopy.py +4 -10
- tomwer/synctools/stacks/reconstruction/nabu.py +2 -2
- tomwer/synctools/stacks/reconstruction/normalization.py +2 -2
- tomwer/synctools/stacks/reconstruction/saaxis.py +2 -2
- tomwer/synctools/stacks/reconstruction/sadeltabeta.py +2 -2
- tomwer/synctools/test/test_darkRefs.py +7 -58
- tomwer/synctools/test/test_foldertransfer.py +6 -6
- tomwer/synctools/utils/scanstages.py +6 -6
- tomwer/tests/conftest.py +34 -0
- tomwer/tests/datasets.py +13 -0
- tomwer/tests/test_scripts.py +92 -39
- tomwer/tests/utils.py +5 -0
- tomwer/version.py +3 -3
- {tomwer-1.2.8.dist-info → tomwer-1.3.0a0.dist-info}/METADATA +39 -44
- {tomwer-1.2.8.dist-info → tomwer-1.3.0a0.dist-info}/RECORD +248 -209
- tomwer/resources/gui/icons/esrf_1.svg +0 -307
- tomwer/resources/gui/icons/triangle.svg +0 -80
- tomwer/synctools/test/test_scanstages.py +0 -162
- tomwer/tests/utils/__init__.py +0 -247
- tomwer/tests/utils/utilstest.py +0 -220
- /tomwer/app/{saaxis.py → multicor.py} +0 -0
- /tomwer/app/{sadeltabeta.py → multipag.py} +0 -0
- /tomwer/core/process/control/{email.py → emailnotifier.py} +0 -0
- /tomwer-1.2.8-py3.11-nspkg.pth → /tomwer-1.3.0a0-py3.11-nspkg.pth +0 -0
- {tomwer-1.2.8.dist-info → tomwer-1.3.0a0.dist-info}/LICENSE +0 -0
- {tomwer-1.2.8.dist-info → tomwer-1.3.0a0.dist-info}/WHEEL +0 -0
- {tomwer-1.2.8.dist-info → tomwer-1.3.0a0.dist-info}/entry_points.txt +0 -0
- {tomwer-1.2.8.dist-info → tomwer-1.3.0a0.dist-info}/namespace_packages.txt +0 -0
- {tomwer-1.2.8.dist-info → tomwer-1.3.0a0.dist-info}/top_level.txt +0 -0
@@ -5,15 +5,15 @@ from tomwer.core.process.control.nxtomoconcatenate import (
|
|
5
5
|
ConcatenateNXtomoTask,
|
6
6
|
format_output_location,
|
7
7
|
)
|
8
|
-
from tomwer.core.scan.
|
9
|
-
from tomwer.core.utils.scanutils import
|
8
|
+
from tomwer.core.scan.nxtomoscan import NXtomoScan
|
9
|
+
from tomwer.core.utils.scanutils import MockNXtomo
|
10
10
|
|
11
11
|
|
12
12
|
def test_concatenate_nx_tomo_task(tmp_path):
|
13
13
|
"""
|
14
|
-
test execution of ConcatenateNXtomoTask with two
|
14
|
+
test execution of ConcatenateNXtomoTask with two NXtomoScan
|
15
15
|
"""
|
16
|
-
scan_1 =
|
16
|
+
scan_1 = MockNXtomo(
|
17
17
|
scan_path=os.path.join(tmp_path, "scan1"),
|
18
18
|
n_proj=10,
|
19
19
|
n_ini_proj=10,
|
@@ -21,7 +21,7 @@ def test_concatenate_nx_tomo_task(tmp_path):
|
|
21
21
|
dim=20,
|
22
22
|
energy=12.3,
|
23
23
|
).scan
|
24
|
-
scan_2 =
|
24
|
+
scan_2 = MockNXtomo(
|
25
25
|
scan_path=os.path.join(tmp_path, "scan2"),
|
26
26
|
n_proj=10,
|
27
27
|
n_ini_proj=10,
|
@@ -42,18 +42,18 @@ def test_concatenate_nx_tomo_task(tmp_path):
|
|
42
42
|
}
|
43
43
|
)
|
44
44
|
task.run()
|
45
|
-
assert isinstance(task.outputs.data,
|
45
|
+
assert isinstance(task.outputs.data, NXtomoScan)
|
46
46
|
assert os.path.exists(output_scan_file)
|
47
47
|
# note: correct processing of the concatenation is done at nxtomomill
|
48
48
|
|
49
49
|
|
50
50
|
def test_format_output_location():
|
51
51
|
"""test behavior of format_output_location"""
|
52
|
-
scan1 =
|
52
|
+
scan1 = NXtomoScan(
|
53
53
|
"/path/to/scan_1.nx",
|
54
54
|
entry="entry0000",
|
55
55
|
)
|
56
|
-
scan2 =
|
56
|
+
scan2 = NXtomoScan(
|
57
57
|
"/path/to/scan_2.nx",
|
58
58
|
entry="entry0001",
|
59
59
|
)
|
@@ -65,7 +65,7 @@ def test_format_output_location():
|
|
65
65
|
)
|
66
66
|
|
67
67
|
assert format_output_location(
|
68
|
-
"concatenate.nx", Serie([scan1, scan2])
|
68
|
+
"concatenate.nx", Serie("my_serie", [scan1, scan2])
|
69
69
|
) == os.path.abspath("concatenate.nx")
|
70
70
|
|
71
71
|
assert (
|
@@ -1,7 +1,7 @@
|
|
1
1
|
import os
|
2
2
|
import numpy
|
3
|
-
from tomwer.core.process.control.
|
4
|
-
from tomwer.core.scan.
|
3
|
+
from tomwer.core.process.control.emailnotifier import format_email_info, _ls_tomo_obj
|
4
|
+
from tomwer.core.scan.nxtomoscan import NXtomoScan
|
5
5
|
from tomwer.core.volume.hdf5volume import HDF5Volume
|
6
6
|
from tomwer.core.utils.scanutils import HDF5MockContext
|
7
7
|
|
@@ -11,11 +11,11 @@ def test__ls_tomo_obj(tmp_path):
|
|
11
11
|
for i in range(2):
|
12
12
|
open(os.path.join(tmp_path, f"{i}.nx"), "a").close()
|
13
13
|
|
14
|
-
scan =
|
14
|
+
scan = NXtomoScan(
|
15
15
|
scan=os.path.join(tmp_path, "1.nx"),
|
16
16
|
entry="entry0000",
|
17
17
|
)
|
18
|
-
assert isinstance(scan,
|
18
|
+
assert isinstance(scan, NXtomoScan)
|
19
19
|
|
20
20
|
assert len(_ls_tomo_obj(scan)) == 2
|
21
21
|
|
@@ -1,11 +1,12 @@
|
|
1
1
|
import os
|
2
2
|
from tomwer.core.scan.edfscan import EDFTomoScan
|
3
|
+
from tomwer.core.process.output import ProcessDataOutputDirMode
|
3
4
|
from tomwer.core.process.control.nxtomomill import (
|
4
5
|
EDFToNxProcess,
|
5
6
|
H5ToNxProcess,
|
6
|
-
|
7
|
+
get_default_raw_data_output_file,
|
7
8
|
)
|
8
|
-
from tomwer.core.utils.scanutils import
|
9
|
+
from tomwer.core.utils.scanutils import MockNXtomo, MockEDF
|
9
10
|
from nxtomomill.converter.hdf5.utils import PROCESSED_DATA_DIR_NAME, RAW_DATA_DIR_NAME
|
10
11
|
|
11
12
|
|
@@ -14,14 +15,14 @@ def test_h52nx_process_deduce_output_file_path(tmp_path):
|
|
14
15
|
scan_path = str(tmp_path / "path" / RAW_DATA_DIR_NAME / "my_scan")
|
15
16
|
os.makedirs(scan_path)
|
16
17
|
|
17
|
-
scan =
|
18
|
+
scan = MockNXtomo(scan_path=scan_path, n_proj=0).scan
|
18
19
|
|
19
20
|
# test H52NXDefaultOutput.PROCESSED_DATA
|
20
21
|
assert H5ToNxProcess.deduce_output_file_path(
|
21
22
|
master_file_name=scan.master_file,
|
22
23
|
scan=scan,
|
23
24
|
entry=scan.entry,
|
24
|
-
outputdir=
|
25
|
+
outputdir=ProcessDataOutputDirMode.PROCESSED_DATA_FOLDER.value,
|
25
26
|
) == str(
|
26
27
|
tmp_path
|
27
28
|
/ "path"
|
@@ -35,7 +36,7 @@ def test_h52nx_process_deduce_output_file_path(tmp_path):
|
|
35
36
|
master_file_name=scan.master_file,
|
36
37
|
scan=scan,
|
37
38
|
entry=scan.entry,
|
38
|
-
outputdir=
|
39
|
+
outputdir=ProcessDataOutputDirMode.IN_SCAN_FOLDER.value,
|
39
40
|
) == str(
|
40
41
|
tmp_path / "path" / RAW_DATA_DIR_NAME / "my_scan" / f"my_scan_{scan.entry}.nx"
|
41
42
|
)
|
@@ -77,14 +78,14 @@ def test_edf2nx_process_deduce_output_file_path(tmp_path):
|
|
77
78
|
# test NEAR_INPUT_FILE
|
78
79
|
assert EDFToNxProcess.deduce_output_file_path(
|
79
80
|
folder_path=scan_path,
|
80
|
-
output_dir=
|
81
|
+
output_dir=ProcessDataOutputDirMode.IN_SCAN_FOLDER.value,
|
81
82
|
scan=scan,
|
82
83
|
) == os.path.join(tmp_path, "path", RAW_DATA_DIR_NAME, "my_edf_scan.nx")
|
83
84
|
|
84
85
|
# test PROCESSED_DATA
|
85
86
|
assert EDFToNxProcess.deduce_output_file_path(
|
86
87
|
folder_path=scan_path,
|
87
|
-
output_dir=
|
88
|
+
output_dir=ProcessDataOutputDirMode.PROCESSED_DATA_FOLDER.value,
|
88
89
|
scan=scan,
|
89
90
|
) == os.path.join(tmp_path, "path", PROCESSED_DATA_DIR_NAME, "my_edf_scan.nx")
|
90
91
|
|
@@ -104,3 +105,54 @@ def test_edf2nx_process_deduce_output_file_path(tmp_path):
|
|
104
105
|
)
|
105
106
|
== "/tmp/output/my_edf_scan.nx"
|
106
107
|
)
|
108
|
+
|
109
|
+
|
110
|
+
def test_get_default_raw_data_output_file():
|
111
|
+
"""test 'get_default_raw_data_output_file' function"""
|
112
|
+
assert get_default_raw_data_output_file("/tmp/path/file.h5") == "/tmp/path/file.nx"
|
113
|
+
assert (
|
114
|
+
get_default_raw_data_output_file(f"/tmp/{PROCESSED_DATA_DIR_NAME}/file.h5")
|
115
|
+
== f"/tmp/{RAW_DATA_DIR_NAME}/file.nx"
|
116
|
+
)
|
117
|
+
|
118
|
+
assert (
|
119
|
+
get_default_raw_data_output_file(
|
120
|
+
f"/tmp/path/{PROCESSED_DATA_DIR_NAME}/toto/file.h5"
|
121
|
+
)
|
122
|
+
== f"/tmp/path/{RAW_DATA_DIR_NAME}/toto/file.nx"
|
123
|
+
)
|
124
|
+
# note: _RAW_DATA_DIR_NAME part of the path but not a folder
|
125
|
+
assert (
|
126
|
+
get_default_raw_data_output_file(f"/tmp/path_{RAW_DATA_DIR_NAME}/toto/file.h5")
|
127
|
+
== f"/tmp/path_{RAW_DATA_DIR_NAME}/toto/file.nx"
|
128
|
+
)
|
129
|
+
|
130
|
+
# 2. advance test
|
131
|
+
# 2.1 use case: '_RAW_DATA_DIR_NAME' is present twice in the path -> replace the deeper one
|
132
|
+
assert (
|
133
|
+
get_default_raw_data_output_file(
|
134
|
+
f"/tmp/{PROCESSED_DATA_DIR_NAME}/path/{RAW_DATA_DIR_NAME}/toto/file.h5"
|
135
|
+
)
|
136
|
+
== f"/tmp/{PROCESSED_DATA_DIR_NAME}/path/{RAW_DATA_DIR_NAME}/toto/file.nx"
|
137
|
+
)
|
138
|
+
|
139
|
+
# 2.2 use case: contains both '_RAW_DATA_DIR_NAME' and '_PROCESSED_DATA_DIR_NAME' in the path
|
140
|
+
assert (
|
141
|
+
get_default_raw_data_output_file(
|
142
|
+
f"/tmp/{PROCESSED_DATA_DIR_NAME}/path/{RAW_DATA_DIR_NAME}/toto/file.h5"
|
143
|
+
)
|
144
|
+
== f"/tmp/{PROCESSED_DATA_DIR_NAME}/path/{RAW_DATA_DIR_NAME}/toto/file.nx"
|
145
|
+
)
|
146
|
+
|
147
|
+
assert (
|
148
|
+
get_default_raw_data_output_file(
|
149
|
+
f"/tmp/{RAW_DATA_DIR_NAME}/path/{PROCESSED_DATA_DIR_NAME}/toto/file.h5"
|
150
|
+
)
|
151
|
+
== f"/tmp/{RAW_DATA_DIR_NAME}/path/{RAW_DATA_DIR_NAME}/toto/file.nx"
|
152
|
+
)
|
153
|
+
|
154
|
+
# 2.3 use case: expected output file is the input file. Make sure append '_nxtomo'
|
155
|
+
assert (
|
156
|
+
get_default_raw_data_output_file("/tmp/path/file.nx")
|
157
|
+
== "/tmp/path/file_nxtomo.nx"
|
158
|
+
)
|
@@ -1,74 +1,74 @@
|
|
1
|
-
# coding: utf-8
|
2
|
-
# /*##########################################################################
|
3
|
-
#
|
4
|
-
# Copyright (c) 2016-2017 European Synchrotron Radiation Facility
|
5
|
-
#
|
6
|
-
# Permission is hereby granted, free of charge, to any person obtaining a copy
|
7
|
-
# of this software and associated documentation files (the "Software"), to deal
|
8
|
-
# in the Software without restriction, including without limitation the rights
|
9
|
-
# to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
10
|
-
# copies of the Software, and to permit persons to whom the Software is
|
11
|
-
# furnished to do so, subject to the following conditions:
|
12
|
-
#
|
13
|
-
# The above copyright notice and this permission notice shall be included in
|
14
|
-
# all copies or substantial portions of the Software.
|
15
|
-
#
|
16
|
-
# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
17
|
-
# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
18
|
-
# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
19
|
-
# AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
20
|
-
# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
21
|
-
# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
22
|
-
# THE SOFTWARE.
|
23
|
-
#
|
24
|
-
# ###########################################################################*/
|
1
|
+
# # coding: utf-8
|
2
|
+
# # /*##########################################################################
|
3
|
+
# #
|
4
|
+
# # Copyright (c) 2016-2017 European Synchrotron Radiation Facility
|
5
|
+
# #
|
6
|
+
# # Permission is hereby granted, free of charge, to any person obtaining a copy
|
7
|
+
# # of this software and associated documentation files (the "Software"), to deal
|
8
|
+
# # in the Software without restriction, including without limitation the rights
|
9
|
+
# # to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
10
|
+
# # copies of the Software, and to permit persons to whom the Software is
|
11
|
+
# # furnished to do so, subject to the following conditions:
|
12
|
+
# #
|
13
|
+
# # The above copyright notice and this permission notice shall be included in
|
14
|
+
# # all copies or substantial portions of the Software.
|
15
|
+
# #
|
16
|
+
# # THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
17
|
+
# # IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
18
|
+
# # FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
19
|
+
# # AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
20
|
+
# # LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
21
|
+
# # OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
22
|
+
# # THE SOFTWARE.
|
23
|
+
# #
|
24
|
+
# # ###########################################################################*/
|
25
25
|
|
26
|
-
__authors__ = ["H. Payno"]
|
27
|
-
__license__ = "MIT"
|
28
|
-
__date__ = "16/06/2021"
|
26
|
+
# __authors__ = ["H. Payno"]
|
27
|
+
# __license__ = "MIT"
|
28
|
+
# __date__ = "16/06/2021"
|
29
29
|
|
30
30
|
|
31
|
-
import os
|
32
|
-
import shutil
|
33
|
-
import tempfile
|
34
|
-
import unittest
|
31
|
+
# import os
|
32
|
+
# import shutil
|
33
|
+
# import tempfile
|
34
|
+
# import unittest
|
35
35
|
|
36
|
-
from tomwer.core.process.control.volumesymlink import VolumeSymbolicLinkTask
|
37
|
-
from tomwer.core.scan.edfscan import EDFTomoScan
|
38
|
-
from tomwer.core.utils.scanutils import MockEDF
|
36
|
+
# from tomwer.core.process.control.volumesymlink import VolumeSymbolicLinkTask
|
37
|
+
# from tomwer.core.scan.edfscan import EDFTomoScan
|
38
|
+
# from tomwer.core.utils.scanutils import MockEDF
|
39
39
|
|
40
40
|
|
41
|
-
class TestVolumeSymbolicLink(unittest.TestCase):
|
42
|
-
|
41
|
+
# class TestVolumeSymbolicLink(unittest.TestCase):
|
42
|
+
# """Simple test of the VolumeSymbolicLink"""
|
43
43
|
|
44
|
-
|
45
|
-
|
46
|
-
|
47
|
-
|
48
|
-
|
49
|
-
|
50
|
-
|
51
|
-
|
52
|
-
|
44
|
+
# def setUp(self) -> None:
|
45
|
+
# self._scan_folder = tempfile.mkdtemp()
|
46
|
+
# self._output_folder = tempfile.mkdtemp()
|
47
|
+
# MockEDF.fastMockAcquisition(self._scan_folder)
|
48
|
+
# MockEDF.mockReconstruction(self._scan_folder, nRecons=2, nPagRecons=2)
|
49
|
+
# self._scan = EDFTomoScan(self._scan_folder)
|
50
|
+
# # here we simply estimate that the slice reconstruction will be
|
51
|
+
# # volume reconstruction but the mechanism is the same.
|
52
|
+
# self._scan.set_latest_vol_reconstructions(self._scan.get_reconstructions_urls())
|
53
53
|
|
54
|
-
|
55
|
-
|
56
|
-
|
54
|
+
# def tearDown(self) -> None:
|
55
|
+
# for folder in (self._scan_folder, self._output_folder):
|
56
|
+
# shutil.rmtree(folder)
|
57
57
|
|
58
|
-
|
59
|
-
|
60
|
-
|
61
|
-
|
62
|
-
|
63
|
-
|
64
|
-
|
65
|
-
|
66
|
-
|
67
|
-
|
68
|
-
|
69
|
-
|
70
|
-
|
58
|
+
# def test(self):
|
59
|
+
# """simple test that the creation of a symbolic link works"""
|
60
|
+
# vlink_process = VolumeSymbolicLinkTask(
|
61
|
+
# inputs={
|
62
|
+
# "data": self._scan,
|
63
|
+
# "serialize_output_data": False,
|
64
|
+
# "output_type": "static",
|
65
|
+
# "output_folder": self._output_folder,
|
66
|
+
# }
|
67
|
+
# )
|
68
|
+
# self.assertEqual(len(os.listdir(self._output_folder)), 0)
|
69
|
+
# vlink_process.run()
|
70
|
+
# self.assertEqual(len(os.listdir(self._output_folder)), 4)
|
71
71
|
|
72
|
-
|
73
|
-
|
74
|
-
|
72
|
+
# self.assertTrue(isinstance(vlink_process.program_name(), str))
|
73
|
+
# self.assertTrue(isinstance(vlink_process.program_version(), str))
|
74
|
+
# self.assertTrue(isinstance(vlink_process.definition(), str))
|
@@ -35,7 +35,7 @@ from tomwer.core.process.task import Task
|
|
35
35
|
from tomwer.core.scan.scanbase import TomwerScanBase
|
36
36
|
from tomwer.core.scan.scanfactory import ScanFactory
|
37
37
|
from tomwer.core.utils.scanutils import data_identifier_to_scan
|
38
|
-
from
|
38
|
+
from tomwer.core.utils.deprecation import deprecated_warning, deprecated
|
39
39
|
|
40
40
|
_logger = logging.getLogger(__name__)
|
41
41
|
|