From 93b8d26fcbf35c891cc28876058bb94f73687cd9 Mon Sep 17 00:00:00 2001
From: Duc Le <duc.le@stfc.ac.uk>
Date: Wed, 7 Sep 2016 07:44:55 +0100
Subject: [PATCH] Re #10147 - Modified unit tests

---
 scripts/test/PyChopTest.py | 64 +++++++++++++++++++++++++-------------
 1 file changed, 43 insertions(+), 21 deletions(-)

diff --git a/scripts/test/PyChopTest.py b/scripts/test/PyChopTest.py
index 9f45ee4c7a0..1238a21663e 100644
--- a/scripts/test/PyChopTest.py
+++ b/scripts/test/PyChopTest.py
@@ -9,43 +9,65 @@ from PyChop import PyChop2
 
 class PyChop2Tests(unittest.TestCase):
 
-    def test_pychop2(self):
-        instnames = ['let', 'maps', 'mari', 'merlin']
-        modulenames = ['ISISDisk', 'ISISFermi', 'ISISFermi', 'ISISFermi']
+    # Tests the Fermi chopper instruments
+    def test_pychop_fermi(self):
+        instnames = ['maps', 'mari', 'merlin']
         res = []
         flux = []
         for inc, instname in enumerate(instnames):
             chopobj = PyChop2(instname)
             # Checks that initialisations instanciates the correct submodule
             # which does the actual calculations. PyChop2 is just a wrapper.
-            self.assertTrue(modulenames[inc] in chopobj.getObject().__module__)
+            self.assertTrue('ISISFermi' in chopobj.getObject().__module__)
             # Code should give an error if the chopper settings and Ei have
             # not been set.
             self.assertRaises(ValueError, chopobj.getResolution)
-            if 'Fermi' in modulenames[inc]:
-                chopobj.setChopper('s', 200)
-            else:
-                chopobj.setFrequency(200)
+            chopobj.setChopper('s', 200)
             chopobj.setEi(18)
             rr, ff = chopobj.getResFlux(np.linspace(0,17,10))
             res.append(rr)
             flux.append(ff)
-        # Checks that the flux should be highest for LET, then MERLIN, MARI
-        # and MAPS in that order
-        self.assertTrue(flux[0] > flux[3])
-        self.assertTrue(flux[3] > flux[2])
+        # Checks that the flux should be highest for MERLIN, MARI and MAPS in that order
         self.assertTrue(flux[2] > flux[1])
-        # Checks that the resolution should be best for LET, then MARI, MAPS
-        # and MERLIN in that order
-        self.assertTrue(res[0][0] < res[2][0])
-        self.assertTrue(res[2][0] < res[1][0])
-        self.assertTrue(res[1][0] < res[3][0]) 
+        self.assertTrue(flux[1] > flux[0])
+        # Checks that the resolution should be best for MARI, MAPS and MERLIN in that order
+        self.assertTrue(res[1][0] < res[0][0])
+        self.assertTrue(res[0][0] < res[2][0]) 
         # Now tests the standalone function
         for inc, instname in enumerate(instnames):
-            if 'Fermi' in modulenames[inc]:
-                rr, ff = PyChop2.calculate(instname, 's', 200, 18, 0)
-            else:
-                rr, ff = PyChop2.calculate(instname, 200, 18, 0)
+            rr, ff = PyChop2.calculate(instname, 's', 200, 18, 0)
+            self.assertAlmostEqual(rr[0], res[inc][0], places=7)
+            self.assertAlmostEqual(ff, flux[inc], places=7)
+
+    # Tests the different variants of LET
+    def test_pychop_let(self):
+        variants = ['High flux', 'Medium flux', 'Low flux']
+        res = []
+        flux = []
+        for inc, variant in enumerate(variants):
+            chopobj = PyChop2('LET', variant)
+            # Checks that initialisations instanciates the correct submodule
+            # which does the actual calculations. PyChop2 is just a wrapper.
+            self.assertTrue('ISISDisk' in chopobj.getObject().__module__)
+            # Checks that it instanciates the correct variant
+            self.assertTrue(variant in chopobj.getChopper())
+            # Code should give an error if the chopper settings and Ei have
+            # not been set.
+            self.assertRaises(ValueError, chopobj.getResolution)
+            chopobj.setFrequency(200)
+            chopobj.setEi(18)
+            rr, ff = chopobj.getResFlux(np.linspace(0,17,10))
+            res.append(rr)
+            flux.append(ff)
+        # Checks that the flux should be highest for 'High flux', then 'Medium flux' then 'Low flux'
+        self.assertTrue(flux[0] > flux[1])
+        self.assertTrue(flux[1] >= flux[2])
+        # Checks that the resolution should be best for 'Low flux', then 'Medium flux' then 'High flux'
+        self.assertTrue(res[2][0] <= res[1][0])
+        self.assertTrue(res[1][0] <= res[0][0]) 
+        # Now tests the standalone function
+        for inc, variant in enumerate(variants):
+            rr, ff = PyChop2.calculate('LET', variant, 200, 18, 0)
             self.assertAlmostEqual(rr[0], res[inc][0], places=7)
             self.assertAlmostEqual(ff, flux[inc], places=7)
 
-- 
GitLab