common.py revision 945930ece8ea73e5184836bf0bf3efad2e3e6c36
0N/A#!/usr/bin/python
0N/A
0N/A# CDDL HEADER START
0N/A#
0N/A# The contents of this file are subject to the terms of the
0N/A# Common Development and Distribution License, Version 1.0 only
0N/A# (the "License"). You may not use this file except in compliance
0N/A# with the License.
0N/A#
0N/A# You can obtain a copy of the license at
0N/A# trunk/opends/resource/legal-notices/OpenDS.LICENSE
0N/A# or https://OpenDS.dev.java.net/OpenDS.LICENSE.
0N/A# See the License for the specific language governing permissions
0N/A# and limitations under the License.
0N/A#
0N/A# When distributing Covered Code, include this CDDL HEADER in each
0N/A# file and include the License file at
0N/A# trunk/opends/resource/legal-notices/OpenDS.LICENSE. If applicable,
873N/A# add the following below this CDDL HEADER, with the fields enclosed
0N/A# information:
0N/A# Portions Copyright [yyyy] [name of copyright owner]
0N/A#
0N/A# CDDL HEADER END
0N/A#
3215N/A#
0N/A# Copyright 2007-2009 Sun Microsystems, Inc.
0N/A# Portions Copyright 2011 ForgeRock AS.
2086N/A
0N/A__version__ = "$Revision$"
0N/A# $Source$
0N/A
2086N/A# public symbols
2086N/A__all__ = [ "format_testcase",
1242N/A "directory_server_information",
1242N/A "test_time",
1242N/A "report_generation",
0N/A "compare_file",
1787N/A "is_windows_platform",
0N/A "create_property_table",
0N/A "compare_property_table",
0N/A "exception_thrown",
1242N/A "directory_server",
1242N/A "test_env",
1242N/A "staf_service",
1242N/A "get_test_name",
1242N/A "parse_stax_result",
1242N/A "dn2list",
1242N/A "list2dn",
1242N/A "dn2rfcmailaddr",
0N/A "java_properties",
0N/A "xmldoc_service" ,
0N/A "xml_create_report" ,
0N/A "group_to_run" ,
338N/A "get_last_attr_from_entry" ,
0N/A "list_matches" ,
0N/A "count_attr" ,
0N/A "host_is_localhost"]
0N/A
0N/Aclass format_testcase:
0N/A 'Format the Test name objects'
0N/A def group(self,string):
0N/A self.group=string.lower()
0N/A self.group=self.group.strip()
0N/A return '%s' % self.group
0N/A def suite(self,string):
1242N/A self.suite=string.lower()
1242N/A self.suite=self.suite.strip()
1242N/A self.suite=self.suite.replace(' ','-')
1242N/A return '%s' % self.suite
0N/A def name(self,string):
0N/A self.name=string.strip()
0N/A self.name=self.name.replace(' ','-')
0N/A return '%s' % self.name
0N/A
0N/Aclass directory_server_information:
0N/A 'Container for Information about Directory Servers'
0N/A def __init__(self):
0N/A self.line=''
0N/A self.key=''
0N/A self.value=''
0N/A self.VersionList=[]
0N/A self.SystemList=[]
0N/A self.ServerDict={}
0N/A self.SystemDict={}
0N/A
0N/A def getServerVersion(self,string,productname):
0N/A return string.replace("%s " % productname,"")
0N/A
0N/A def getServerBuildId(self,string):
0N/A return string.replace("Build ","")
0N/A
0N/A def getServerOSName(self,string):
0N/A return string[0:string.find(' ')].strip()
0N/A
0N/A def getServerArch(self,string):
0N/A return string[string.rfind(' ') +1:len(string)].strip()
0N/A
0N/A def getServerJavaMajorMinor(self,string):
0N/A return string[0:string.rfind('.')]
0N/A
1242N/A def getServerValueFromString(self,string):
1242N/A return string[string.find(':') +1:len(string)].strip()
1242N/A
1242N/A def getServerValueFromKey(self,string,result):
1242N/A return result[string]
0N/A
1242N/Aclass test_time:
1242N/A 'Simple time related manipulation objects'
1242N/A def __init__(self):
1242N/A self.seconds=0
0N/A self.minutes=0
1242N/A self.hours=0
1242N/A
0N/A def timeToSeconds(self,clocktime):
1242N/A self.hours,self.minutes,self.seconds=clocktime.split(':')
1242N/A return int(self.hours)*7200+int(self.minutes)*60+int(self.seconds)
1242N/A
0N/Aclass basic_utils:
1242N/A 'Some simple basic utilities'
1242N/A def printKey(self,keypair):
1242N/A self.key=keypair.keys()[0]
1242N/A return self.key
0N/A def printKeyValue(self,keypair):
1242N/A self.key=keypair.keys()[0]
1242N/A self.keyvalue=keypair[self.key]
0N/A return self.keyvalue
1242N/A
2624N/Aclass report_generation:
1242N/A 'Test Report Generation'
0N/A
0N/A def transformReport(self,stylesheet,xml,output,params):
0N/A from java.io import FileInputStream
0N/A from java.io import FileOutputStream
0N/A from java.io import ByteArrayOutputStream
0N/A
0N/A from javax.xml.transform import TransformerFactory
1242N/A from javax.xml.transform.stream import StreamSource
0N/A from javax.xml.transform.stream import StreamResult
1242N/A
1242N/A self.xsl = FileInputStream("%s" % stylesheet)
2086N/A self.xml = FileInputStream("%s" % xml)
1242N/A self.html = FileOutputStream("%s" % output)
0N/A
1242N/A try:
1242N/A self.xslSource = StreamSource(self.xsl)
0N/A self.tfactory = TransformerFactory.newInstance()
1242N/A self.xslTemplate = self.tfactory.newTemplates(self.xslSource)
0N/A self.transformer = self.xslTemplate.newTransformer()
1242N/A
1242N/A self.source = StreamSource(self.xml)
2624N/A self.result = StreamResult(self.html)
1242N/A
0N/A for self.key,self.value in params.items():
1242N/A self.transformer.setParameter(self.key, self.value)
1787N/A
0N/A self.transformer.transform(self.source, self.result)
1242N/A
868N/A finally:
2086N/A self.xsl.close()
1242N/A self.xml.close()
868N/A self.html.close()
0N/A
0N/Aclass exception_thrown:
1242N/A 'User defined exceptions handlers'
0N/A def __init__(self):
0N/A self.message = ''
0N/A self.flag = ''
0N/A
0N/Aclass compare_file:
1242N/A 'Compare two files'
0N/A
1242N/A def __init__(self, file1, file2, diffFile):
1242N/A self.file1 = file1
1242N/A self.file2 = file2
0N/A self.diffFile = diffFile
1242N/A
1242N/A def genDiff(self):
2086N/A from org.tmatesoft.svn.core.wc import *
1242N/A from java.io import File
0N/A from java.io import FileOutputStream
1242N/A
1242N/A diff = DefaultSVNDiffGenerator()
1242N/A diff.displayFileDiff("",
1242N/A File("%s" % self.file1),
1242N/A File("%s" % self.file2),
1242N/A self.file1,
0N/A self.file2,
1242N/A "text/plain",
1242N/A "text/plain",
1242N/A FileOutputStream(File("%s" % self.diffFile)))
0N/A
1242N/A try:
0N/A ret_str = ""
1242N/A diff_file = open(self.diffFile, "r")
0N/A for line in diff_file.readlines():
0N/A ret_str = ret_str + line
1242N/A return ret_str
0N/A finally:
0N/A diff_file.close()
1242N/A
1242N/Adef is_windows_platform(host):
1242N/A from java.lang import Boolean
1242N/A from com.ibm.staf import STAFHandle
2624N/A from com.ibm.staf import STAFResult
1242N/A
1242N/A handle = STAFHandle("varHandle")
1242N/A res = handle.submit2(host, "VAR", "GET SYSTEM VAR STAF/Config/OS/Name")
1242N/A
1242N/A winLower = res.result.lower()
1242N/A winNdx = winLower.find("win")
1242N/A if winNdx != -1:
1242N/A return res.result[winNdx:]
1242N/A else:
1242N/A return Boolean.FALSE
0N/A
1242N/Adef create_property_table(output, separator):
1242N/A 'Create a table from an output'
0N/A
0N/A table = {}
1242N/A
0N/A for line in output.splitlines():
1242N/A key = line.split(separator)[0].strip()
0N/A try:
2086N/A value = line.split(separator)[1].strip()
1242N/A except IndexError:
1242N/A value = ''
0N/A table[key] = value
0N/A
1242N/A return table
0N/A
0N/Adef compare_property_table(refTable, newTable):
0N/A 'Compare two tables'
0N/A
0N/A import re
1242N/A
0N/A result = ''
1242N/A
1242N/A refKeys = newTable.keys()
2086N/A for refKey in refKeys:
1242N/A if not refTable.has_key(refKey):
0N/A result = result + 'ERROR: Entry ' + refKey + ' does not exists'
1242N/A result = result + ' in the reference table.\n'
1242N/A
1242N/A refKeys = refTable.keys()
0N/A for refKey in refKeys:
1242N/A if not newTable.has_key(refKey):
0N/A result = result + 'ERROR: Entry ' + refKey + ' does not exists'
0N/A result = result + ' in the new table.\n'
2086N/A else:
2086N/A result = result + refKey + '=> expected: ' + refTable[refKey]
1242N/A result = result + ' , result: ' + newTable[refKey] + '\n'
1242N/A
0N/A if refTable[refKey] != newTable[refKey]:
1242N/A result = result + 'ERROR: Value for ' + refKey
1242N/A result = result + ' should be the same.\n'
1242N/A
0N/A return result
1242N/A
1242N/Aclass directory_server:
2624N/A 'Container to hold DS instance objects'
1242N/A def __init__(self):
868N/A self.location=''
1242N/A self.host=''
1787N/A self.port=''
868N/A self.dn=''
1242N/A self.password=''
0N/A self.suffix=''
2086N/A self.backend=''
1242N/A
0N/A def location(self,location):
0N/A return location
0N/A
1242N/A def host(self,name):
0N/A return name
0N/A
0N/A def port(self,port):
0N/A return port
0N/A
1242N/A def adminport(self,port):
0N/A return adminport
1242N/A
1242N/A def dn(self,dn):
1242N/A return dn
0N/A
1242N/A def password(self,pswd):
1242N/A return pswd
2086N/A
1242N/A def suffix(self,sfx):
0N/A return sfx
1242N/A
1242N/A def backend(self,be):
1242N/A return be
0N/A
1242N/Aclass staf_service:
0N/A 'Container to hold staf service instance objects'
1242N/A def __init__(self,host,name):
1242N/A from com.ibm.staf import STAFHandle
2624N/A from com.ibm.staf import STAFResult
1242N/A from com.ibm.staf import STAFMarshallingContext
0N/A
1242N/A self.name=name
0N/A self.library='Unknown'
1242N/A self.executable='Unknown'
868N/A self.options='Unknown'
2086N/A self.params='Unknown'
1242N/A
1242N/A try:
868N/A __handle = STAFHandle("varHandle")
0N/A except STAFException, e:
0N/A pass
1242N/A
0N/A __cmd = 'QUERY SERVICE %s' % name
0N/A __res = __handle.submit2(host, "SERVICE", __cmd)
0N/A
0N/A if (__res.rc == 0):
0N/A
1242N/A __context = STAFMarshallingContext.unmarshall(__res.result)
0N/A __entryMap = __context.getRootObject()
1242N/A
1242N/A self.name=__entryMap['name']
2086N/A self.library=__entryMap['library']
1242N/A self.executable=__entryMap['executable']
0N/A self.options=__entryMap['options']
0N/A self.params=__entryMap['parameters']
0N/A
0N/A def get_library(self):
0N/A return self.library
0N/A
0N/A def get_name(self):
0N/A return self.name
1242N/A
1242N/A def get_executable(self):
1242N/A return self.executable
1242N/A
1242N/A def get_options(self):
1242N/A return self.options
1242N/A
1242N/A def get_params(self):
2086N/A return self.params
1242N/A
1242N/Aclass test_env:
1242N/A 'Container to hold test environment instance objects'
1242N/A def __init__(self):
1242N/A self.environment=''
1242N/A
1242N/A class staf:
1242N/A 'Container to hold staf objects'
1242N/A def __init__(self,host):
1242N/A from com.ibm.staf import STAFHandle
1242N/A from com.ibm.staf import STAFResult
1242N/A
1242N/A __handle = STAFHandle("varHandle")
0N/A __cmd = 'Version'
1242N/A __res = __handle.submit2(host, "MISC", __cmd)
1242N/A self.version=__res.result
1242N/A
1242N/A self.name='STAF'
1242N/A
1242N/A __cmd = 'GET SYSTEM VAR STAF/Config/STAFRoot'
1242N/A __res = __handle.submit2(host, "VAR", __cmd)
1242N/A self.root=__res.result
0N/A
1242N/A def get_version(self):
1242N/A return self.version
1242N/A
1242N/A def get_name(self):
1242N/A return self.name
0N/A
1242N/A def get_root(self):
1242N/A return self.version
1242N/A
1787N/A class stax(staf_service):
1242N/A 'Container to hold stax service objects'
1242N/A def __init__(self,host,name='STAX'):
1242N/A from com.ibm.staf import STAFHandle
1242N/A from com.ibm.staf import STAFResult
2414N/A
1242N/A if hasattr(staf_service, '__init__'):
0N/A staf_service.__init__(self,host,name)
0N/A
1242N/A __handle = STAFHandle("varHandle")
1242N/A
1242N/A __cmd = 'Version'
1242N/A __res = __handle.submit2(host, "STAX", __cmd)
1242N/A self.version=__res.result
1242N/A
1242N/A def get_version(self):
1787N/A return self.version
1787N/A
1787N/A class event(staf_service):
1242N/A 'Container to hold event service objects'
1242N/A def __init__(self,host,name='EVENT'):
1242N/A from com.ibm.staf import STAFHandle
1242N/A from com.ibm.staf import STAFResult
1242N/A
1242N/A if hasattr(staf_service, '__init__'):
1242N/A staf_service.__init__(self,host,name)
1242N/A
1242N/A __handle = STAFHandle("varHandle")
1787N/A __cmd = 'Version'
1787N/A __res = __handle.submit2(host, "EVENT", __cmd)
1242N/A self.version=__res.result
1242N/A
1242N/A def get_version(self):
0N/A return self.version
1242N/A
1242N/A class eventmanager(staf_service):
1242N/A 'Container to hold event manager service objects'
1242N/A def __init__(self,host,name='EVENTMANAGER'):
1242N/A from com.ibm.staf import STAFHandle
1242N/A from com.ibm.staf import STAFResult
1242N/A
2624N/A if hasattr(staf_service, '__init__'):
1242N/A staf_service.__init__(self,host,name)
1242N/A
1242N/A __handle = STAFHandle("varHandle")
1242N/A __cmd = 'Version'
1242N/A __res = __handle.submit2(host, "EVENTMANAGER", __cmd)
1242N/A self.version=__res.result
1242N/A
0N/A def get_version(self):
1787N/A return self.version
1242N/A
1242N/A class email(staf_service):
1242N/A 'Container to hold email service objects'
3065N/A def __init__(self,host,name='EMAIL'):
1242N/A from com.ibm.staf import STAFHandle
1242N/A from com.ibm.staf import STAFResult
1787N/A from com.ibm.staf import STAFMarshallingContext
1787N/A
1787N/A if hasattr(staf_service, '__init__'):
1787N/A staf_service.__init__(self,host,name)
1787N/A
1787N/A __handle = STAFHandle("varHandle")
2086N/A __cmd = 'Version'
1787N/A __res = __handle.submit2(host, "EMAIL", __cmd)
1787N/A self.version=__res.result
1787N/A self.recipients= 'TODO: get from config.py'
1787N/A
1787N/A __res = __handle.submit2(host, "EMAIL", "LIST SETTINGS")
1787N/A __context = STAFMarshallingContext.unmarshall(__res.result)
1787N/A __entryMap = __context.getRootObject()
1787N/A
2086N/A self.server=__entryMap['mailServer']
1787N/A self.port=__entryMap['port']
1787N/A
1787N/A def get_version(self):
1787N/A return self.version
1787N/A
1787N/A def get_recipients(self):
1787N/A return self.recipients
1787N/A
2086N/A def get_server(self):
2086N/A return self.server
2086N/A
1787N/A def get_port(self):
1787N/A return self.port
1242N/A
1242N/A class http(staf_service):
0N/A 'Container to hold http service objects'
1242N/A def __init__(self,host,name='HTTP'):
1242N/A from com.ibm.staf import STAFHandle
2086N/A from com.ibm.staf import STAFResult
1242N/A
1242N/A if hasattr(staf_service, '__init__'):
1242N/A staf_service.__init__(self,host,name)
2086N/A
1242N/A __handle = STAFHandle("varHandle")
1242N/A __res = __handle.submit2(host, "HTTP", "Version")
0N/A self.version=__res.result
0N/A
1242N/A def get_version(self):
1242N/A return self.version
1242N/A
1242N/A class dsml(staf_service):
1242N/A 'Container to hold dsml service objects'
1242N/A def __init__(self,host,name='DSML'):
1242N/A from com.ibm.staf import STAFHandle
1242N/A from com.ibm.staf import STAFResult
1242N/A
1242N/A if hasattr(staf_service, '__init__'):
1242N/A staf_service.__init__(self,host,name)
1242N/A
1242N/A __handle = STAFHandle("varHandle")
1242N/A
2414N/A self.version='Unknown'
1242N/A
1242N/A def get_version(self):
0N/A return self.version
0N/A
0N/A class source:
'Container to hold source data instance objects'
def __init__(self,dir,tests_type):
self.directory=dir
self.data='%s/%s/shared/data' % (dir,tests_type)
self.common='%s/shared' % dir
self.java='%s/java' % self.common
def get_directory(self):
return self.directory
def get_data(self):
return self.data
def get_common(self):
return self.common
def get_java(self):
return self.java
class logs:
'Container to hold test log instance objects'
def __init__(self,dir):
self.directory=dir
self.tests='%s/testlogs' % dir
self.reports='%s/reports' % dir
self.sut='%s/sutlogs' % dir
def get_directory(self):
return self.directory
def get_tests(self):
return self.tests
def get_reports(self):
return self.reports
def get_sut(self):
return self.sut
class data:
'Container to hold local and remote test data instance objects'
def __init__(self,dir):
self.directory=dir
self.testdata='%s/testdata' % dir
self.java='%s/java' % self.testdata
self.data='%s/data' % self.testdata
self.temp='%s/temp' % dir
self.reldatadir='testdata/data'
self.reljavadir='testdata/java'
def get_directory(self):
return self.directory
def get_testdata(self):
return self.testdata
def get_java(self):
return self.java
def get_data(self):
return self.data
def get_temp(self):
return self.temp
def get_reldatadir(self):
return self.directory
def get_reljavadir(self):
return self.directory
def set_data(self,dir):
self.data=dir
def get_test_name(name):
i=2
__name=''
__tn=name.split(':')
while i < len(__tn):
__name += '%s:' % __tn[i]
i=i+1
return __name[0:-1].strip()
def parse_stax_result(result):
import org.python.core
if result.__class__ is org.python.core.PyList:
_unwrapResult=result[1][0]
try:
_functionString=_unwrapResult[1]
except AttributeError:
_functionString='Unable to parse result.'
elif result.__class__ is org.python.core.PyString:
_functionString=STAXResult
else:
_functionString='Unable to parse result.'
return _functionString
def dn2list(dn):
__list=dn.split(',')
return __list
def list2dn(list):
return ",".join(list)
def dn2rfcmailaddr(dn):
__addr=[]
__list=dn.split(',')
for __rdn in __list:
__rhside=__rdn.split('=')[1]
__addr.append(__rhside)
return ".".join(__addr).lower()
def java_properties(propFile, toolsName, optionList):
'Update java.properties file'
import fileinput
import string
import sys
try:
file = open(propFile, "r")
content = file.read()
file.close()
newfile = open(propFile, "w")
for line in content.splitlines():
if line.startswith(toolsName):
newline = line.split("=")[0] + "="
for item in optionList:
newline = newline + item + " "
newfile.write("%s\n" % newline)
else:
newfile.write("%s\n" % line)
newfile.close()
return 0
except:
print "Exception:", sys.exc_info()[0]
return 1
class xmldoc_service:
def __init__(self):
self.testgroup=''
self.testsuite=''
self.testcase=''
self.issues=''
self.issue=''
def createBlankDocument(self):
try:
import sys, traceback
from javax.xml.parsers import DocumentBuilderFactory
builderFactory=DocumentBuilderFactory.newInstance()
return builderFactory.newDocumentBuilder()
except:
print "exception: %s" % traceback.format_exception(*sys.exc_info())
def writeXMLfile(self,doc,xmlfile):
try:
import sys, traceback
from java.io import File
from javax.xml.transform import TransformerFactory
from javax.xml.transform import OutputKeys
from javax.xml.transform.stream import StreamResult
from javax.xml.transform.dom import DOMSource
tranFactory = TransformerFactory.newInstance();
aTransformer = tranFactory.newTransformer();
aTransformer.setOutputProperty(OutputKeys.ENCODING, "ISO-8859-1")
aTransformer.setOutputProperty(OutputKeys.INDENT, "yes")
src = DOMSource(doc);
dest = StreamResult(File(xmlfile));
aTransformer.transform(src, dest);
except:
print "exception: %s" % traceback.format_exception(*sys.exc_info())
def parseXMLfile(self,xmlfile):
try:
import sys, traceback
from java.io import FileInputStream
self.builder= self.createBlankDocument()
self.input = FileInputStream(xmlfile)
self.doc = self.builder.parse(self.input)
self.input.close()
return self.doc
except:
print "exception: %s" % traceback.format_exception(*sys.exc_info())
def createAttr(self,doc,tag,attr,value):
try:
import sys, traceback
newAttribute= doc.createAttribute(attr)
newAttribute.setValue('%s' % value)
tag.setAttributeNode(newAttribute)
except:
print "exception: %s" % traceback.format_exception(*sys.exc_info())
def xml_add_text_node(doc,parent,name,ntext):
node = doc.createElement(name)
text = doc.createTextNode('%s' % ntext)
node.appendChild(text)
parent.appendChild(node)
def xml_create_report(pname,type,path,info,misc,testdir,report):
xml=xmldoc_service()
builder = xml.createBlankDocument()
doc = builder.newDocument()
root = doc.createElement("qa")
doc.appendChild(root)
ft = doc.createElement("%s" % type)
root.appendChild(ft);
# Identification
id = doc.createElement("identification")
ft.appendChild(id)
sut = doc.createElement("sut")
xml.createAttr(doc,sut,"product","opends")
id.appendChild(sut)
xml_add_text_node(doc,sut,'name',pname)
xml_add_text_node(doc,sut,'path',path)
xml_add_text_node(doc,sut,'version',info['server version'])
xml_add_text_node(doc,sut,'buildid',info['server buildid'])
xml_add_text_node(doc,sut,'revision',info['svn revision'])
xml_add_text_node(doc,sut,'hostname',info['system name'])
xml_add_text_node(doc,sut,'platform',info['system os'])
xml_add_text_node(doc,sut,'jvm-version',info['jvm version'])
xml_add_text_node(doc,sut,'jvm-label',misc['jvm label'])
xml_add_text_node(doc,sut,'jvm-vendor',info['jvm vendor'])
xml_add_text_node(doc,sut,'jvm-arch',info['jvm architecture'])
xml_add_text_node(doc,sut,'jvm-args','TBD')
xml_add_text_node(doc,sut,'jvm-home','TBD')
xml_add_text_node(doc,sut,'jvm-bin','TDB')
xml_add_text_node(doc,sut,'os-label',misc['os label'])
xml_add_text_node(doc,sut,'server-package',misc['server package'])
xml_add_text_node(doc,sut,'snmp-jarfile',misc['snmp jarfile'])
xml_add_text_node(doc,sut,'md5-sum','TBD')
xml_add_text_node(doc,id,'tests-dir',testdir)
# Test Results
results = doc.createElement("results")
ft.appendChild(results)
xml.writeXMLfile(doc,report)
class group_to_run:
def __init__(self, name):
self.name = name
def getName(self):
return self.name
def get_last_attr_from_entry(result,attribute):
changeEntry=result[0][1].split("\n")
attrVal=''
for changeAttr in changeEntry:
#print changeAttr
if changeAttr.startswith(attribute):
#print 'get_last_attr_from_entry: %s' % changeAttr
attrVal = changeAttr.replace('%s: ' % attribute,'')
if attrVal != '' and attrVal[len(attrVal)-1] == ';' :
lastAttr = attrVal[0:len(attrVal)-1]
else:
lastAttr = attrVal
print 'get_last_attr_from_entry: %s' % lastAttr
return lastAttr
def list_matches(mylist):
mycomp = 'True'
itemnum = 0
for item in mylist:
if not item:
# TODO: list item is empty do WARNING or ERROR
print "list_matches: WARNING: list item %s is empty." % itemnum
if item != mylist[0]:
print "list_matches: False. Match=(%s), Item=(%s)" % (mylist[0],item)
mycomp = 'False'
itemnum += 1
return mycomp
def count_attr(result):
attrnum = 0
if result != None:
for attr in result[0][1].split('\n'):
if attr.startswith('dn:'):
print "Hit: attr (%s)" % attr
attrnum += 1
return attrnum
def host_is_localhost(hostname):
from socket import gethostbyname
if gethostbyname(hostname).startswith('127.0'):
return 1
else:
return 0
def hosts_are_same(hostname1,hostname2):
from socket import gethostbyname
if hostname1 == hostname2:
return 1
else:
return 0