mirror of https://github.com/apache/kafka.git
				
				
				
			
		
			
				
	
	
		
			139 lines
		
	
	
		
			6.0 KiB
		
	
	
	
		
			Python
		
	
	
	
			
		
		
	
	
			139 lines
		
	
	
		
			6.0 KiB
		
	
	
	
		
			Python
		
	
	
	
| # Licensed to the Apache Software Foundation (ASF) under one
 | |
| # or more contributor license agreements.  See the NOTICE file
 | |
| # distributed with this work for additional information
 | |
| # regarding copyright ownership.  The ASF licenses this file
 | |
| # to you under the Apache License, Version 2.0 (the
 | |
| # "License"); you may not use this file except in compliance
 | |
| # with the License.  You may obtain a copy of the License at
 | |
| #
 | |
| #   http://www.apache.org/licenses/LICENSE-2.0
 | |
| #
 | |
| # Unless required by applicable law or agreed to in writing,
 | |
| # software distributed under the License is distributed on an
 | |
| # "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
 | |
| # KIND, either express or implied.  See the License for the
 | |
| # specific language governing permissions and limitations
 | |
| # under the License.
 | |
| #!/usr/bin/env python
 | |
| 
 | |
| # ===================================
 | |
| # system_test_env.py
 | |
| # ===================================
 | |
| 
 | |
| import copy
 | |
| import json
 | |
| import os
 | |
| import sys
 | |
| 
 | |
| from   utils import system_test_utils
 | |
| 
 | |
| class SystemTestEnv():
 | |
| 
 | |
|     # private:
 | |
|     _cwdFullPath              = os.getcwd()
 | |
|     _thisScriptFullPathName   = os.path.realpath(__file__)
 | |
|     _thisScriptBaseDir        = os.path.abspath(os.path.join(os.path.dirname(sys.argv[0])))
 | |
| 
 | |
|     # public:
 | |
|     SYSTEM_TEST_BASE_DIR      = os.path.abspath(_thisScriptBaseDir)
 | |
|     SYSTEM_TEST_UTIL_DIR      = os.path.abspath(SYSTEM_TEST_BASE_DIR + "/utils")
 | |
|     SYSTEM_TEST_SUITE_SUFFIX  = "_testsuite"
 | |
|     SYSTEM_TEST_CASE_PREFIX   = "testcase_"
 | |
|     SYSTEM_TEST_MODULE_EXT    = ".py"
 | |
|     CLUSTER_CONFIG_FILENAME   = "cluster_config.json"
 | |
|     CLUSTER_CONFIG_PATHNAME   = os.path.abspath(SYSTEM_TEST_BASE_DIR + "/" + CLUSTER_CONFIG_FILENAME)
 | |
|     METRICS_FILENAME          = "metrics.json"
 | |
|     METRICS_PATHNAME          = os.path.abspath(SYSTEM_TEST_BASE_DIR + "/" + METRICS_FILENAME)
 | |
|     TESTCASE_TO_RUN_FILENAME  = "testcase_to_run.json"
 | |
|     TESTCASE_TO_RUN_PATHNAME  = os.path.abspath(SYSTEM_TEST_BASE_DIR + "/" + TESTCASE_TO_RUN_FILENAME)
 | |
|     TESTCASE_TO_SKIP_FILENAME = "testcase_to_skip.json"
 | |
|     TESTCASE_TO_SKIP_PATHNAME = os.path.abspath(SYSTEM_TEST_BASE_DIR + "/" + TESTCASE_TO_SKIP_FILENAME)
 | |
| 
 | |
|     clusterEntityConfigDictList                      = []   # cluster entity config for current level
 | |
|     clusterEntityConfigDictListInSystemTestLevel     = []   # cluster entity config defined in system level
 | |
|     clusterEntityConfigDictListLastFoundInTestSuite  = []   # cluster entity config last found in testsuite level
 | |
|     clusterEntityConfigDictListLastFoundInTestCase   = []   # cluster entity config last found in testcase level
 | |
| 
 | |
|     systemTestResultsList        = []
 | |
|     testCaseToRunListDict        = {}
 | |
|     testCaseToSkipListDict       = {}
 | |
| 
 | |
|     printTestDescriptionsOnly    = False
 | |
|     doNotValidateRemoteHost      = False
 | |
| 
 | |
|     def __init__(self):
 | |
|         "Create an object with this system test session environment"
 | |
| 
 | |
|         # load the system level cluster config
 | |
|         system_test_utils.load_cluster_config(self.CLUSTER_CONFIG_PATHNAME, self.clusterEntityConfigDictList)
 | |
| 
 | |
|         # save the system level cluster config
 | |
|         self.clusterEntityConfigDictListInSystemTestLevel = copy.deepcopy(self.clusterEntityConfigDictList)
 | |
| 
 | |
|         # retrieve testcases to run from testcase_to_run.json
 | |
|         try:
 | |
|             testcaseToRunFileContent  = open(self.TESTCASE_TO_RUN_PATHNAME, "r").read()
 | |
|             testcaseToRunData        = json.loads(testcaseToRunFileContent)
 | |
|             for testClassName, caseList in testcaseToRunData.items():
 | |
|                 self.testCaseToRunListDict[testClassName] = caseList
 | |
|         except:
 | |
|             pass
 | |
| 
 | |
|         # retrieve testcases to skip from testcase_to_skip.json
 | |
|         try:
 | |
|             testcaseToSkipFileContent = open(self.TESTCASE_TO_SKIP_PATHNAME, "r").read()
 | |
|             testcaseToSkipData        = json.loads(testcaseToSkipFileContent)
 | |
|             for testClassName, caseList in testcaseToSkipData.items():
 | |
|                 self.testCaseToSkipListDict[testClassName] = caseList
 | |
|         except:
 | |
|             pass
 | |
| 
 | |
|     def isTestCaseToSkip(self, testClassName, testcaseDirName):
 | |
|         testCaseToRunList  = {}
 | |
|         testCaseToSkipList = {}
 | |
| 
 | |
|         try:
 | |
|             testCaseToRunList  = self.testCaseToRunListDict[testClassName]
 | |
|         except:
 | |
|             # no 'testClassName' found => no need to run any cases for this test class
 | |
|             return True
 | |
| 
 | |
|         try:
 | |
|             testCaseToSkipList = self.testCaseToSkipListDict[testClassName]
 | |
|         except:
 | |
|             pass
 | |
| 
 | |
|         # if testCaseToRunList has elements, it takes precedence:
 | |
|         if len(testCaseToRunList) > 0:
 | |
|             #print "#### testClassName => ", testClassName
 | |
|             #print "#### testCaseToRunList => ", testCaseToRunList
 | |
|             #print "#### testcaseDirName => ", testcaseDirName
 | |
|             if not testcaseDirName in testCaseToRunList:
 | |
|                 #self.log_message("Skipping : " + testcaseDirName)
 | |
|                 return True
 | |
|         elif len(testCaseToSkipList) > 0:
 | |
|             #print "#### testClassName => ", testClassName
 | |
|             #print "#### testCaseToSkipList => ", testCaseToSkipList
 | |
|             #print "#### testcaseDirName => ", testcaseDirName
 | |
|             if testcaseDirName in testCaseToSkipList:
 | |
|                 #self.log_message("Skipping : " + testcaseDirName)
 | |
|                 return True
 | |
| 
 | |
|         return False
 | |
| 
 | |
| 
 | |
|     def getSystemTestEnvDict(self):
 | |
|         envDict = {}
 | |
|         envDict["system_test_base_dir"]             = self.SYSTEM_TEST_BASE_DIR
 | |
|         envDict["system_test_util_dir"]             = self.SYSTEM_TEST_UTIL_DIR
 | |
|         envDict["cluster_config_pathname"]          = self.CLUSTER_CONFIG_PATHNAME
 | |
|         envDict["system_test_suite_suffix"]         = self.SYSTEM_TEST_SUITE_SUFFIX
 | |
|         envDict["system_test_case_prefix"]          = self.SYSTEM_TEST_CASE_PREFIX
 | |
|         envDict["system_test_module_ext"]           = self.SYSTEM_TEST_MODULE_EXT
 | |
|         envDict["cluster_config_pathname"]          = self.CLUSTER_CONFIG_PATHNAME
 | |
|         envDict["cluster_entity_config_dict_list"]  = self.clusterEntityConfigDictList
 | |
|         envDict["system_test_results_list"]         = self.systemTestResultsList
 | |
|         return envDict
 | |
| 
 | |
| 
 |