Mercurial > repos > yufei-luo > s_mart
diff commons/pyRepetUnit/hmmer/check/test/Test_OldDetectFeaturesConfigChecker.py @ 18:94ab73e8a190
Uploaded
author | m-zytnicki |
---|---|
date | Mon, 29 Apr 2013 03:20:15 -0400 |
parents | |
children |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/commons/pyRepetUnit/hmmer/check/test/Test_OldDetectFeaturesConfigChecker.py Mon Apr 29 03:20:15 2013 -0400 @@ -0,0 +1,138 @@ +import unittest +import re +import os +from commons.pyRepetUnit.hmmer.check.OldDetectFeatureConfigChecker import DetectFeatureConfigChecker +from commons.core.checker.ConfigException import ConfigException + +class Test_DetectFeaturesConfigChecker(unittest.TestCase): + + def setUp(self): + self._detectFeatureConfigChecker = DetectFeatureConfigChecker() + + def testWithDefaultLogger (self): + lineFound = False + try: + self._detectFeatureConfigChecker.check("dummyConfig") + except ConfigException, e: + for msg in e.messages: + if (re.match("CONFIG FILE not found.*", msg)): + lineFound = True + self.assertTrue(lineFound) + + def testWithNoConfigFile(self): + lineFound = False + try: + self._detectFeatureConfigChecker.check("dummyConfig") + except ConfigException, e: + for msg in e.messages: + if (re.match("CONFIG FILE not found.*", msg)): + lineFound = True + self.assertTrue(lineFound) + + def testWithNoSectionInConfigFile(self): + config = open("config.cfg", "w"); + config.close() + lineFound = False + try: + self._detectFeatureConfigChecker.check("config.cfg") + except ConfigException, e: + for msg in e.messages: + if (re.match("\[detect_features\] section not found.*", msg)): + lineFound = True + self.assertTrue(lineFound) + os.remove("config.cfg") + + def testMissingOptionsInConfig (self): + dict = {} + MockConfigFile("config.cfg", dict) + hmmProfilsFound = False + TE_BLRnFound = False + try : + self._detectFeatureConfigChecker.check("config.cfg") + except ConfigException, e: + for msg in e.messages: + if (re.match("\[detect_features\] - No option 'te_hmmer' in section: 'detect_features'", msg)): + hmmProfilsFound = True + if (re.match("\[detect_features\] - No option 'te_blrn' in section: 'detect_features'", msg)): + TE_BLRnFound = True + self.assertTrue(hmmProfilsFound) + self.assertTrue(TE_BLRnFound) + os.remove("config.cfg") + + def testOptionsIfHmmProfilsSetAtYESInConfig (self): + + dict = { + "TE_HMMER" : "yes", + "TE_BLRn" : "no" + } + + profilDatabankFound = False + evalueFound = False + MockConfigFile("config.cfg", dict) + try : + self._detectFeatureConfigChecker.check("config.cfg") + except ConfigException, e: + for msg in e.messages: + print msg + if (re.match("\[detect_features\] - No option 'te_hmm_profiles' in section: 'detect_features' whereas te_hmmer is set", msg)): + profilDatabankFound = True + if (re.match("\[detect_features\] - No option 'te_hmmer_evalue' in section: 'detect_features' whereas te_hmmer is set - Default value will be set", msg)): + evalueFound = True + self.assertTrue(profilDatabankFound) + self.assertTrue(evalueFound) + os.remove("config.cfg") + + + def testOptionsIfHmmProfilsSetAtNOInConfig (self): + profilDatabankFound = False + inputFormatFound = False + evalueFound = False + dict = { + "TE_HMMER" : "no" + } + MockConfigFile("config.cfg", dict) + try : + self._detectFeatureConfigChecker.check("config.cfg") + except ConfigException, e: + for msg in e.messages: + if (re.match(".+INFO \[detect_features\] - No option 'te_hmm_profiles' in section: 'detect_features' whereas te_hmmer is set", msg)): + profilDatabankFound = True + if (re.match(".+INFO \[detect_features\] - No option 'te_hmmer_evalue' in section: 'detect_features' whereas te_hmmer is set - Default value will be set", msg)): + evalueFound = True + self.assertFalse(profilDatabankFound) + self.assertFalse(inputFormatFound) + self.assertFalse(evalueFound) + os.remove("config.cfg") + + def testTE_BLRnAndTE_hmmerAtNoInConfig (self): + + dict = { + "TE_HMMER" : "no", + "TE_BLRn" : "no" + } + + exceptionNotRaised = True + MockConfigFile("config.cfg", dict) + try : + self._detectFeatureConfigChecker.check("config.cfg") + except ConfigException: + exceptionNotRaised = False + + self.assertTrue(exceptionNotRaised) + + os.remove("config.cfg") + +class MockConfigFile: + + def __init__ (self, fileName, optionsDict): + + self._fileName = fileName + config = open(fileName, "w"); + config.write("[detect_features]\n") + for key in optionsDict.keys(): + config.write(key + ":" + optionsDict[key] + "\n") + config.close() + + +if __name__ == "__main__": + unittest.main()