cloudpulse/cloudpulse/scenario/plugins/security_pulse/testcase/remote_logmode_check.py

125 lines
5.4 KiB
Python

# Copyright 2010-2011 OpenStack Foundation
# Copyright (c) 2013 Hewlett-Packard Development Company, L.P.
#
# Licensed 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.
import ConfigParser
import os
class LogModeCheck(object):
def log_mode_check(self, dir_list):
try:
result = []
final_result = {}
overall_status = True
if dir_list is None or not dir_list:
res = {'message': 'Directory list is empty',
'status': 'Fail', 'test_case_name': 'Log Mode Check'}
result.append(res)
final_result.update(
{'OverallStatus': False})
final_result.update({'result': result})
print(final_result)
return
config = ConfigParser.ConfigParser()
for dir_name in dir_list:
for dirName, subdirList, files in os.walk(dir_name):
files = [file for file in files if file.
endswith(('.conf', '.ini'))]
for f1 in files:
debug_msg = {}
verbose_msg = {}
abspath = ''
if dirName.endswith("/"):
abspath = dirName + f1
else:
abspath = dirName + "/" + f1
case_name = "Debug Mode check for '" + abspath + "'"
debug_msg.update(
{'test_case_name': case_name})
verbose_msg.update({'test_case_name': "Verbose Mode" +
" check for '" + abspath + "'"})
try:
config.read(abspath)
except Exception:
continue
try:
config.get("DEFAULT", "debug")
except ConfigParser.NoOptionError as e:
msg = 'Debug option is not enabled'
debug_msg.update(
{'message': msg})
debug_msg.update({'status': 'Pass'})
else:
debug = config.get("DEFAULT", "debug")
if debug.lower() == 'false':
msg = "Debug option is enabled with 'false'"
debug_msg.update(
{'message': msg})
debug_msg.update({'status': 'Pass'})
else:
msg = 'Debug option is enabled'
debug_msg.update(
{'message': msg})
debug_msg.update({'status': 'Fail'})
overall_status = False
result.append(debug_msg)
try:
config.get("DEFAULT", "verbose")
except ConfigParser.NoOptionError:
msg = 'Verbose option is not enabled'
verbose_msg.update(
{'message': msg})
verbose_msg.update({'status': 'Pass'})
else:
verbose = config.get("DEFAULT", "verbose")
if verbose.lower() == 'false':
msg = "Verbose option is enabled with 'false'"
verbose_msg.update(
{'message': msg})
verbose_msg.update({'status': 'Pass'})
else:
msg = 'Verbose option is enabled'
verbose_msg.update(
{'message': msg})
verbose_msg.update({'status': 'Fail'})
overall_status = False
result.append(verbose_msg)
final_result.update(
{'OverallStatus': overall_status})
final_result.update({'result': result})
print(final_result)
return
except Exception as e:
final_result.update(
{'OverallStatus': False})
result = {}
result.update({'test_case_name': 'Log Mode Check'})
result.update({'status': 'Fail'})
result.update(
{'message': 'Exception in log mode check' + str(e)})
final_result.update({'result': [result]})
print(final_result)
return
if __name__ == '__main__':
file_dir = '/var/sec_hc/'
dirs = []
with open(file_dir + 'dir_list') as f:
dirs = f.read().splitlines()
sec = LogModeCheck()
sec.log_mode_check(dirs)