diff --git a/dev-docs/source/Testing/ErrorReporter-ProjectRecovery/ProjectRecoveryTesting.rst b/dev-docs/source/Testing/ErrorReporter-ProjectRecovery/ProjectRecoveryTesting.rst index 6868de8397ab2443823659e892f69563376bcd59..df919c969e6fc2435ac30e4fd83b404ae38bd0d9 100644 --- a/dev-docs/source/Testing/ErrorReporter-ProjectRecovery/ProjectRecoveryTesting.rst +++ b/dev-docs/source/Testing/ErrorReporter-ProjectRecovery/ProjectRecoveryTesting.rst @@ -14,6 +14,7 @@ Project Recovery test - Before running these tests, set project recovery to run every 2 seconds. The instructions for this are on the `Project Recovery concepts page <http://docs.mantidproject.org/nightly/concepts/ProjectRecovery.html>`_. - Get the ISIS sample dataset from the `Downloads page <http://download.mantidproject.org/>`_. +- Get the file `TOPAZ_3132_event.nxs` - Put the data in a data directory, referred to as ``data_directory`` in the scripts below - Set up a directory to store output for comparison, referred to as ``testing_directory`` below @@ -77,9 +78,10 @@ Project Recovery test .. code-block:: python - SaveCSV(InputWorkspace='Sequential4', Filename=testing_directory + '/Sequence4.csv') - SaveCSV(InputWorkspace='Sequential5', Filename=testing_directory + '/Sequence5.csv') - SaveCSV(InputWorkspace='Sequential6', Filename=testing_directory + '/Sequence6.csv') + testing_directory=<path-to-test> + SaveCSV(InputWorkspace='Sequential4', Filename=testing_directory + '/Sequence4r.csv') + SaveCSV(InputWorkspace='Sequential5', Filename=testing_directory + '/Sequence5r.csv') + SaveCSV(InputWorkspace='Sequential6', Filename=testing_directory + '/Sequence6r.csv') - Compare the contents of the `SequenceX.csv` and `SequenceXr.csv` files, they should be the same @@ -92,12 +94,13 @@ Project Recovery test .. code-block:: python + testing_directory=<path-to-test> CreateWorkspace(DataX=range(12), DataY=range(12), DataE=range(12), NSpec=4, OutputWorkspace='0Rebinned') for i in range(100): RenameWorkspace(InputWorkspace='%sRebinned'%str(i), OutputWorkspace='%sRebinned'%str(i+1)) for i in range(3000): CloneWorkspace(InputWorkspace='100Rebinned', OutputWorkspace='%sClone'%str(i)) - SaveCSV(InputWorkspace='2999Clone', Filename='Clone.csv') + SaveCSV(InputWorkspace='2999Clone', Filename=testing_directory + 'Clone.csv') - Wait a few seconds, then provoke a crash by running `Segfault` - Re-start MantidPlot @@ -108,6 +111,114 @@ Project Recovery test .. code-block:: python - SaveCSV(InputWorkspace='2999Clone', Filename='Cloner.csv') + testing_directory=<path-to-test> + SaveCSV(InputWorkspace='2999Clone', Filename=testing_directory +'Cloner.csv') - Compare the contents of `Clone.csv` and `Cloner.csv`, they should be the same + +------ + +3. Testing workspaces of different types + +- Open up MantidPlot, ensure that only one instance is running +- Run the following script: + +.. code-block:: python + + data_directory=<path-to-data> + testing_directory=<path-to-test> + Load(Filename= data_directory + '/TOPAZ_3132_event.nxs', OutputWorkspace='TOPAZ_3132_event', LoadMonitors='1') + ConvertToMD(InputWorkspace='TOPAZ_3132_event', QDimensions='Q3D', dEAnalysisMode='Elastic', Q3DFrames='Q_sample', LorentzCorrection='1', OutputWorkspace='TOPAZ_3132_md',\ + MinValues='-25,-25,-25', MaxValues='25,25,25', SplitInto='2', SplitThreshold='50', MaxRecursionDepth='13', MinRecursionDepth='7') + DeleteWorkspace("TOPAZ_3132_event") + multi_d = RenameWorkspace('TOPAZ_3132_md') + peaks=FindPeaksMD(InputWorkspace='multi_d', PeakDistanceThreshold='0.37680', MaxPeaks='50', DensityThresholdFactor='100', OutputWorkspace='TOPAZ_3132_peaks') + + long1=CreateMDHistoWorkspace(Dimensionality=2, Extents='-3,3,-10,10', SignalInput=range(0,10000), ErrorInput=range(0,10000),\ + NumberOfBins='100,100', Names='Dim1,Dim2', Units='MomentumTransfer, EnergyTransfer') + + long2=CreateMDHistoWorkspace(Dimensionality=2, Extents='-3, 3, -10, 10', SignalInput=range(0, 10000), ErrorInput=range(0, 10000),\ + NumberOfBins='100, 100', Names='Dim1, Dim2', Units='MomentumTransfer, EnergyTransfer') + long3=long1+long2 + DeleteWorkspace("long1") + DeleteWorkspace("long2") + long4=long3.clone() + DeleteWorkspace("long3") + CloneWorkspace(InputWorkspace='long4', OutputWorkspace='Clone') + ConvertMDHistoToMatrixWorkspace(InputWorkspace='Clone', OutputWorkspace='Clone_matrix') + SaveCSV('Clone_matrix' , testing_directory + '/method_test.csv') + + DgsReduction(SampleInputFile=data_directory + 'MAR11001.raw', IncidentEnergyGuess=12, OutputWorkspace='ws') + Rebin(InputWorkspace='ws', OutputWorkspace='rebin', Params='0.5') + Rebin(InputWorkspace='rebin', OutputWorkspace='rebin', Params='0.6') + Rebin(InputWorkspace='rebin', OutputWorkspace='rebin', Params='0.7') + Rebin(InputWorkspace='rebin', OutputWorkspace='rebin', Params='0.8') + RenameWorkspace(InputWorkspace='rebin', OutputWorkspace='renamed') + SaveCSV('renamed', testing_directory + '/rebin_test.csv') + + + long4 *= 4 + long4 += 3.00 + ConvertMDHistoToMatrixWorkspace(InputWorkspace='long4', OutputWorkspace='long4_matrix') + SaveCSV('long4_matrix', testing_directory + '/test_binary_operators.csv') + +- Force a crash of Mantid with `Segfault` +- On re-loading Mantid choose a full recovery + +.. code-block:: python + + testing_directory=<path-to-test> + SaveCSV('Clone_matrix' , testing_directory + '/method_test_r.csv') + SaveCSV('long4_matrix', testing_directory + '/test_binary_operators_r.csv') + +- Compare the contents of ``/test_binary_operators_r.csv`` and ``/test_binary_operators.csv``, they should be the same +- Compare the contents of ``/method_test_r.csv`` and ``/method_test_r.csv``, they should be the same + +-------- + +4. Multiple instances of Mantid + +- Open up MantidPlot, ensure that only one instance is running +- Right-click in the Results Log and set `Log level` to `Debug` +- The Results Log should be printing `Nothing to save` +- Run the following script: + +.. code-block:: python + + CreateWorkspace(DataX=range(12), DataY=range(12), DataE=range(12), NSpec=4, OutputWorkspace='NewWorkspace') + +- The Results Log should now be printing `Project Recovery: Saving started` and `Project Recovery: Saving finished` on alternate lines +- Now start a second instance of Mantid - note on OSX this has to be done from the command line, as OSX will not allow two instances of an executable to be run using the `open` command +- Set `Log level` to `Debug` +- Watch the `Results log` for 30 seconds (or longer than your interval for project recovery saving, see the `Preparation` section) +- No message about saving should be printed +- Now, crash the first instance of Mantid with `Segfault` +- Start a new instance of Mantid +- This should also have no messages about saving +- Close both instances of Mantid gracefully +- Start a new instance of Mantid +- You should be presented with the Project Recovery dialog +- Choose `Yes` +- This should repopulate your workspace window + +-------- + +4. Recovering plots and windows + +- Open MantidPlot - make sure no other instances of MantidPlot are running +- Run the second script from test 1 +- In the workspace window right-click the ``Sequential3`` workspace and choose `Plot spectrum` +- Choose `Plot All` +- In the workspace window right-click the ``Sequential1`` workspace and choose `Plot advanced` +- Choose `Tiled plot` +- Drag workspace `Rename2` into the main window + +.. image:: + + ../../images/reporter-test-4.png + + +- Crash Mantid with `Segfault` +- Reopen Mantid +- You should be presented with the Project Recovery dialog +- Choose `Yes` diff --git a/dev-docs/source/images/reporter-test-4.png b/dev-docs/source/images/reporter-test-4.png new file mode 100644 index 0000000000000000000000000000000000000000..a4e0939d59453dbb1391efaf124682283bbfde83 Binary files /dev/null and b/dev-docs/source/images/reporter-test-4.png differ