tomwer 1.2.9__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.
Files changed (253) hide show
  1. orangecontrib/tomwer/tutorials/icat_publication.ows +58 -0
  2. orangecontrib/tomwer/widgets/__init__.py +1 -0
  3. orangecontrib/tomwer/widgets/control/DataDiscoveryOW.py +2 -2
  4. orangecontrib/tomwer/widgets/control/DataListOW.py +9 -7
  5. orangecontrib/tomwer/widgets/control/DataSelectorOW.py +21 -10
  6. orangecontrib/tomwer/widgets/control/EDF2NXTomomillOW.py +11 -5
  7. orangecontrib/tomwer/widgets/control/EmailOW.py +4 -4
  8. orangecontrib/tomwer/widgets/control/NXTomomillOW.py +31 -18
  9. orangecontrib/tomwer/widgets/control/NXtomoConcatenate.py +14 -7
  10. orangecontrib/tomwer/widgets/control/NotifierOW.py +1 -0
  11. orangecontrib/tomwer/widgets/control/VolumeSelector.py +7 -4
  12. orangecontrib/tomwer/widgets/control/VolumeSymLinkOW.py +182 -182
  13. orangecontrib/tomwer/widgets/debugtools/DatasetGeneratorOW.py +4 -4
  14. orangecontrib/tomwer/widgets/edit/DarkFlatPatchOW.py +4 -4
  15. orangecontrib/tomwer/widgets/edit/ImageKeyEditorOW.py +3 -3
  16. orangecontrib/tomwer/widgets/edit/ImageKeyUpgraderOW.py +2 -0
  17. orangecontrib/tomwer/widgets/edit/NXtomoEditorOW.py +3 -3
  18. orangecontrib/tomwer/widgets/edit/test/test_nxtomo_editor.py +3 -3
  19. orangecontrib/tomwer/widgets/icat/PublishProcessedDataOW.py +115 -0
  20. orangecontrib/tomwer/widgets/icat/RawDataScreenshotCreatorOW.py +98 -0
  21. orangecontrib/tomwer/widgets/icat/SaveToGalleryAndPublishOW.py +129 -0
  22. orangecontrib/tomwer/widgets/icat/__init__.py +13 -0
  23. orangecontrib/tomwer/widgets/icat/icons/add_gallery.png +0 -0
  24. orangecontrib/tomwer/widgets/icat/icons/add_gallery.svg +82 -0
  25. orangecontrib/tomwer/widgets/icat/icons/publish_processed_data.png +0 -0
  26. orangecontrib/tomwer/widgets/icat/icons/publish_processed_data.svg +95 -0
  27. orangecontrib/tomwer/widgets/icat/icons/raw_screenshots.png +0 -0
  28. orangecontrib/tomwer/widgets/icat/icons/raw_screenshots.svg +143 -0
  29. orangecontrib/tomwer/widgets/icons/tomwer_data_portal.png +0 -0
  30. orangecontrib/tomwer/widgets/icons/tomwer_data_portal.svg +76 -0
  31. orangecontrib/tomwer/widgets/reconstruction/AxisOW.py +9 -8
  32. orangecontrib/tomwer/widgets/reconstruction/CastNabuVolumeOW.py +3 -3
  33. orangecontrib/tomwer/widgets/reconstruction/NabuHelicalPrepareWeightsDoubleOW.py +179 -169
  34. orangecontrib/tomwer/widgets/reconstruction/NabuOW.py +23 -0
  35. orangecontrib/tomwer/widgets/reconstruction/NabuVolumeOW.py +39 -5
  36. orangecontrib/tomwer/widgets/reconstruction/SAAxisOW.py +7 -13
  37. orangecontrib/tomwer/widgets/reconstruction/SADeltaBetaOW.py +7 -17
  38. orangecontrib/tomwer/widgets/reconstruction/SinoNormOW.py +3 -4
  39. orangecontrib/tomwer/widgets/visualization/LivesliceOW.py +1 -1
  40. orangecontrib/tomwer/widgets/visualization/NXtomoMetadataViewerOW.py +3 -3
  41. orangecontrib/tomwer/widgets/visualization/VolumeViewerOW.py +3 -29
  42. tomwer/__main__.py +11 -58
  43. tomwer/app/canvas.py +8 -0
  44. tomwer/app/canvas_launcher/config.py +13 -11
  45. tomwer/app/darkref.py +1 -1
  46. tomwer/app/darkrefpatch.py +1 -1
  47. tomwer/app/imagekeyeditor.py +5 -5
  48. tomwer/app/imagekeyupgrader.py +5 -5
  49. tomwer/app/intensitynormalization.py +2 -2
  50. tomwer/app/radiostack.py +2 -2
  51. tomwer/app/zstitching.py +74 -3
  52. tomwer/core/cluster/cluster.py +26 -0
  53. tomwer/core/log/logger.py +7 -5
  54. tomwer/core/process/conditions/filters.py +1 -1
  55. tomwer/core/process/control/datalistener/datalistener.py +3 -3
  56. tomwer/core/process/control/nxtomoconcatenate.py +13 -13
  57. tomwer/core/process/control/nxtomomill.py +83 -25
  58. tomwer/core/process/control/scantransfer.py +11 -10
  59. tomwer/core/process/control/scanvalidator.py +3 -2
  60. tomwer/core/process/control/test/test_concatenate_nxtomos.py +9 -9
  61. tomwer/core/process/control/test/test_email.py +4 -4
  62. tomwer/core/process/control/test/test_h52nx_process.py +59 -7
  63. tomwer/core/process/control/test/test_volume_link.py +64 -64
  64. tomwer/core/process/control/timer.py +1 -1
  65. tomwer/core/process/control/volumesymlink.py +200 -200
  66. tomwer/core/process/edit/darkflatpatch.py +6 -6
  67. tomwer/core/process/edit/imagekeyeditor.py +17 -18
  68. tomwer/core/process/icat/__init__.py +0 -0
  69. tomwer/core/process/icat/createscreenshots.py +100 -0
  70. tomwer/core/process/icat/gallery.py +377 -0
  71. tomwer/core/process/icat/icatbase.py +36 -0
  72. tomwer/core/process/icat/publish.py +228 -0
  73. tomwer/core/process/icat/screenshots.py +26 -0
  74. tomwer/core/process/output.py +52 -0
  75. tomwer/core/process/reconstruction/axis/axis.py +17 -10
  76. tomwer/core/process/reconstruction/axis/mode.py +4 -0
  77. tomwer/core/process/reconstruction/axis/params.py +9 -4
  78. tomwer/core/process/reconstruction/darkref/darkrefs.py +8 -6
  79. tomwer/core/process/reconstruction/darkref/darkrefscopy.py +1 -1
  80. tomwer/core/process/reconstruction/darkref/params.py +1 -1
  81. tomwer/core/process/reconstruction/lamino/tofu.py +4 -4
  82. tomwer/core/process/reconstruction/nabu/castvolume.py +1 -1
  83. tomwer/core/process/reconstruction/nabu/helical.py +9 -5
  84. tomwer/core/process/reconstruction/nabu/nabucommon.py +32 -62
  85. tomwer/core/process/reconstruction/nabu/nabuscores.py +387 -61
  86. tomwer/core/process/reconstruction/nabu/nabuslices.py +33 -21
  87. tomwer/core/process/reconstruction/nabu/nabuvolume.py +37 -14
  88. tomwer/core/process/reconstruction/nabu/settings.py +2 -2
  89. tomwer/core/process/reconstruction/nabu/utils.py +129 -24
  90. tomwer/core/process/reconstruction/output.py +108 -0
  91. tomwer/core/process/reconstruction/saaxis/saaxis.py +233 -263
  92. tomwer/core/process/reconstruction/sadeltabeta/sadeltabeta.py +140 -86
  93. tomwer/core/process/reconstruction/scores/params.py +4 -1
  94. tomwer/core/process/reconstruction/scores/scores.py +13 -0
  95. tomwer/core/process/reconstruction/test/test_axis_params.py +2 -2
  96. tomwer/core/process/reconstruction/test/test_darkref.py +3 -3
  97. tomwer/core/process/reconstruction/test/test_darkref_copy.py +3 -3
  98. tomwer/core/process/reconstruction/test/test_saaxis.py +3 -4
  99. tomwer/core/process/reconstruction/test/test_sadeltabeta.py +2 -2
  100. tomwer/core/process/stitching/nabustitcher.py +2 -2
  101. tomwer/core/process/test/test_axis.py +6 -6
  102. tomwer/core/process/test/test_dark_and_flat.py +10 -7
  103. tomwer/core/process/test/test_data_transfer.py +7 -6
  104. tomwer/core/process/test/test_nabu.py +4 -4
  105. tomwer/core/process/test/test_normalization.py +2 -2
  106. tomwer/core/scan/edfscan.py +4 -1
  107. tomwer/core/scan/hdf5scan.py +19 -500
  108. tomwer/core/scan/nxtomoscan.py +532 -0
  109. tomwer/core/scan/scanbase.py +42 -20
  110. tomwer/core/scan/scanfactory.py +13 -13
  111. tomwer/core/scan/test/test_future_scan.py +2 -2
  112. tomwer/core/scan/test/test_h5.py +12 -10
  113. tomwer/core/scan/test/test_process_registration.py +2 -2
  114. tomwer/core/scan/test/test_scan.py +4 -3
  115. tomwer/core/settings.py +20 -0
  116. tomwer/core/test/test_scanutils.py +8 -7
  117. tomwer/core/test/test_utils.py +33 -26
  118. tomwer/core/utils/__init__.py +0 -466
  119. tomwer/core/utils/deprecation.py +1 -1
  120. tomwer/core/utils/dictutils.py +14 -0
  121. tomwer/core/utils/lbsram.py +35 -0
  122. tomwer/core/utils/nxtomoutils.py +1 -1
  123. tomwer/core/utils/scanutils.py +6 -6
  124. tomwer/core/utils/spec.py +263 -0
  125. tomwer/core/volume/volumefactory.py +2 -2
  126. tomwer/gui/cluster/slurm.py +260 -60
  127. tomwer/gui/cluster/test/test_cluster.py +13 -0
  128. tomwer/gui/cluster/test/test_supervisor.py +2 -2
  129. tomwer/gui/configuration/__init__.py +0 -0
  130. tomwer/gui/{reconstruction/nabu → configuration}/action.py +1 -32
  131. tomwer/gui/configuration/level.py +22 -0
  132. tomwer/gui/control/actions.py +54 -0
  133. tomwer/gui/control/datalist.py +78 -16
  134. tomwer/gui/control/datalistener.py +4 -16
  135. tomwer/gui/control/{email.py → emailnotifier.py} +9 -18
  136. tomwer/gui/control/history.py +2 -2
  137. tomwer/gui/control/observations.py +2 -2
  138. tomwer/gui/control/reducedarkflatselector.py +1 -1
  139. tomwer/gui/control/selectorwidgetbase.py +36 -9
  140. tomwer/gui/control/serie/seriecreator.py +5 -22
  141. tomwer/gui/control/test/test_email.py +1 -1
  142. tomwer/gui/control/test/test_scanvalidator.py +6 -5
  143. tomwer/gui/control/test/test_single_tomo_obj.py +2 -2
  144. tomwer/gui/control/tomoobjdisplaymode.py +8 -0
  145. tomwer/gui/debugtools/datasetgenerator.py +3 -3
  146. tomwer/gui/edit/dkrfpatch.py +16 -22
  147. tomwer/gui/edit/imagekeyeditor.py +8 -11
  148. tomwer/gui/edit/nxtomoeditor.py +111 -44
  149. tomwer/gui/edit/nxtomowarmer.py +4 -4
  150. tomwer/gui/edit/test/test_dkrf_patch.py +7 -7
  151. tomwer/gui/edit/test/test_image_key_editor.py +3 -3
  152. tomwer/gui/edit/test/test_nx_editor.py +40 -16
  153. tomwer/gui/icat/__init__.py +0 -0
  154. tomwer/gui/icat/createscreenshots.py +80 -0
  155. tomwer/gui/icat/gallery.py +214 -0
  156. tomwer/gui/icat/publish.py +187 -0
  157. tomwer/gui/reconstruction/axis/axis.py +171 -57
  158. tomwer/gui/reconstruction/axis/radioaxis.py +80 -95
  159. tomwer/gui/reconstruction/darkref/darkrefcopywidget.py +3 -2
  160. tomwer/gui/reconstruction/lamino/tofu/projections.py +1 -1
  161. tomwer/gui/reconstruction/lamino/tofu/tofuoutput.py +3 -6
  162. tomwer/gui/reconstruction/nabu/castvolume.py +1 -1
  163. tomwer/gui/reconstruction/nabu/check.py +9 -9
  164. tomwer/gui/reconstruction/nabu/helical.py +29 -12
  165. tomwer/gui/reconstruction/nabu/nabuconfig/base.py +2 -4
  166. tomwer/gui/reconstruction/nabu/nabuconfig/output.py +110 -33
  167. tomwer/gui/reconstruction/nabu/nabuconfig/phase.py +9 -12
  168. tomwer/gui/reconstruction/nabu/nabuconfig/preprocessing.py +219 -29
  169. tomwer/gui/reconstruction/nabu/nabuconfig/reconstruction.py +3 -6
  170. tomwer/gui/reconstruction/nabu/nabuflow.py +12 -20
  171. tomwer/gui/reconstruction/nabu/slices.py +6 -7
  172. tomwer/gui/reconstruction/nabu/volume.py +22 -10
  173. tomwer/gui/reconstruction/normalization/intensity.py +15 -23
  174. tomwer/gui/reconstruction/saaxis/corrangeselector.py +7 -23
  175. tomwer/gui/reconstruction/saaxis/dimensionwidget.py +1 -1
  176. tomwer/gui/reconstruction/saaxis/saaxis.py +7 -9
  177. tomwer/gui/reconstruction/sadeltabeta/saadeltabeta.py +2 -1
  178. tomwer/gui/reconstruction/scores/control.py +2 -9
  179. tomwer/gui/reconstruction/scores/scoreplot.py +11 -5
  180. tomwer/gui/reconstruction/test/test_axis.py +23 -12
  181. tomwer/gui/reconstruction/test/test_lamino.py +8 -3
  182. tomwer/gui/reconstruction/test/test_nabu.py +28 -9
  183. tomwer/gui/reconstruction/test/test_saaxis.py +3 -3
  184. tomwer/gui/reconstruction/test/test_sadeltabeta.py +2 -2
  185. tomwer/gui/settings.py +5 -28
  186. tomwer/gui/stackplot.py +2 -5
  187. tomwer/gui/stitching/action.py +49 -0
  188. tomwer/gui/stitching/config/axisparams.py +7 -24
  189. tomwer/gui/stitching/config/output.py +10 -8
  190. tomwer/gui/stitching/config/positionoveraxis.py +22 -23
  191. tomwer/gui/stitching/normalization.py +117 -0
  192. tomwer/gui/stitching/stitchandbackground.py +4 -6
  193. tomwer/gui/stitching/stitching.py +265 -43
  194. tomwer/gui/stitching/stitching_preview.py +62 -5
  195. tomwer/gui/stitching/stitching_raw.py +2 -5
  196. tomwer/gui/stitching/z_stitching/fineestimation.py +0 -60
  197. tomwer/gui/utils/buttons.py +112 -29
  198. tomwer/gui/utils/inputwidget.py +33 -25
  199. tomwer/gui/utils/scandescription.py +4 -0
  200. tomwer/gui/utils/step.py +144 -0
  201. tomwer/gui/utils/unitsystem.py +2 -5
  202. tomwer/gui/utils/vignettes.py +176 -15
  203. tomwer/gui/visualization/dataviewer.py +1 -4
  204. tomwer/gui/visualization/diffviewer/diffviewer.py +7 -16
  205. tomwer/gui/visualization/diffviewer/shiftwidget.py +2 -5
  206. tomwer/gui/visualization/scanoverview.py +1 -1
  207. tomwer/gui/visualization/sinogramviewer.py +1 -10
  208. tomwer/gui/visualization/test/test_diffviewer.py +3 -3
  209. tomwer/gui/visualization/test/test_nx_tomo_metadata_viewer.py +4 -4
  210. tomwer/gui/visualization/test/test_sinogramviewer.py +2 -2
  211. tomwer/gui/visualization/test/test_stacks.py +3 -3
  212. tomwer/gui/visualization/test/test_volumeviewer.py +2 -2
  213. tomwer/io/utils/raw_and_processed_data.py +84 -0
  214. tomwer/io/utils/tomoobj.py +4 -6
  215. tomwer/resources/gui/icons/ruler.png +0 -0
  216. tomwer/resources/gui/icons/ruler.svg +273 -0
  217. tomwer/resources/gui/icons/short_description.png +0 -0
  218. tomwer/resources/gui/icons/short_description.svg +58 -0
  219. tomwer/resources/gui/icons/url.png +0 -0
  220. tomwer/resources/gui/icons/url.svg +58 -0
  221. tomwer/synctools/stacks/edit/darkflatpatch.py +2 -2
  222. tomwer/synctools/stacks/edit/imagekeyeditor.py +2 -2
  223. tomwer/synctools/stacks/reconstruction/axis.py +4 -4
  224. tomwer/synctools/stacks/reconstruction/castvolume.py +2 -2
  225. tomwer/synctools/stacks/reconstruction/dkrefcopy.py +4 -10
  226. tomwer/synctools/stacks/reconstruction/nabu.py +2 -2
  227. tomwer/synctools/stacks/reconstruction/normalization.py +2 -2
  228. tomwer/synctools/stacks/reconstruction/saaxis.py +2 -2
  229. tomwer/synctools/stacks/reconstruction/sadeltabeta.py +2 -2
  230. tomwer/synctools/test/test_darkRefs.py +7 -58
  231. tomwer/synctools/test/test_foldertransfer.py +6 -6
  232. tomwer/synctools/utils/scanstages.py +6 -6
  233. tomwer/tests/conftest.py +34 -0
  234. tomwer/tests/datasets.py +13 -0
  235. tomwer/tests/test_scripts.py +92 -39
  236. tomwer/tests/utils.py +5 -0
  237. tomwer/version.py +3 -3
  238. {tomwer-1.2.9.dist-info → tomwer-1.3.0a0.dist-info}/METADATA +39 -39
  239. {tomwer-1.2.9.dist-info → tomwer-1.3.0a0.dist-info}/RECORD +248 -209
  240. tomwer/resources/gui/icons/esrf_1.svg +0 -307
  241. tomwer/resources/gui/icons/triangle.svg +0 -80
  242. tomwer/synctools/test/test_scanstages.py +0 -162
  243. tomwer/tests/utils/__init__.py +0 -247
  244. tomwer/tests/utils/utilstest.py +0 -220
  245. /tomwer/app/{saaxis.py → multicor.py} +0 -0
  246. /tomwer/app/{sadeltabeta.py → multipag.py} +0 -0
  247. /tomwer/core/process/control/{email.py → emailnotifier.py} +0 -0
  248. /tomwer-1.2.9-py3.11-nspkg.pth → /tomwer-1.3.0a0-py3.11-nspkg.pth +0 -0
  249. {tomwer-1.2.9.dist-info → tomwer-1.3.0a0.dist-info}/LICENSE +0 -0
  250. {tomwer-1.2.9.dist-info → tomwer-1.3.0a0.dist-info}/WHEEL +0 -0
  251. {tomwer-1.2.9.dist-info → tomwer-1.3.0a0.dist-info}/entry_points.txt +0 -0
  252. {tomwer-1.2.9.dist-info → tomwer-1.3.0a0.dist-info}/namespace_packages.txt +0 -0
  253. {tomwer-1.2.9.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.hdf5scan import HDF5TomoScan
9
- from tomwer.core.utils.scanutils import MockHDF5
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 HDF5TomoScan
14
+ test execution of ConcatenateNXtomoTask with two NXtomoScan
15
15
  """
16
- scan_1 = MockHDF5(
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 = MockHDF5(
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, HDF5TomoScan)
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 = HDF5TomoScan(
52
+ scan1 = NXtomoScan(
53
53
  "/path/to/scan_1.nx",
54
54
  entry="entry0000",
55
55
  )
56
- scan2 = HDF5TomoScan(
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.email import format_email_info, _ls_tomo_obj
4
- from tomwer.core.scan.hdf5scan import HDF5TomoScan
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 = HDF5TomoScan(
14
+ scan = NXtomoScan(
15
15
  scan=os.path.join(tmp_path, "1.nx"),
16
16
  entry="entry0000",
17
17
  )
18
- assert isinstance(scan, HDF5TomoScan)
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
- NXtomomillNXDefaultOutput,
7
+ get_default_raw_data_output_file,
7
8
  )
8
- from tomwer.core.utils.scanutils import MockHDF5, MockEDF
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 = MockHDF5(scan_path=scan_path, n_proj=0).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=NXtomomillNXDefaultOutput.PROCESSED_DATA.value,
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=NXtomomillNXDefaultOutput.NEAR_INPUT_FILE.value,
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=NXtomomillNXDefaultOutput.NEAR_INPUT_FILE.value,
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=NXtomomillNXDefaultOutput.PROCESSED_DATA.value,
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
- """Simple test of the VolumeSymbolicLink"""
41
+ # class TestVolumeSymbolicLink(unittest.TestCase):
42
+ # """Simple test of the VolumeSymbolicLink"""
43
43
 
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())
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
- def tearDown(self) -> None:
55
- for folder in (self._scan_folder, self._output_folder):
56
- shutil.rmtree(folder)
54
+ # def tearDown(self) -> None:
55
+ # for folder in (self._scan_folder, self._output_folder):
56
+ # shutil.rmtree(folder)
57
57
 
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)
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
- 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))
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 silx.utils.deprecation import deprecated_warning, deprecated
38
+ from tomwer.core.utils.deprecation import deprecated_warning, deprecated
39
39
 
40
40
  _logger = logging.getLogger(__name__)
41
41