<?
xml version="1.0" encoding="UTF-8" standalone="no"?>
! The contents of this file are subject to the terms of the ! Common Development and Distribution License, Version 1.0 only ! (the "License"). You may not use this file except in compliance ! You can obtain a copy of the license at ! See the License for the specific language governing permissions ! and limitations under the License. ! When distributing Covered Code, include this CDDL HEADER in each ! file and include the License file at ! add the following below this CDDL HEADER, with the fields enclosed ! by brackets "[]" replaced with your own identifying information: ! Portions Copyright [yyyy] [name of copyright owner] ! Copyright 2007-2009 Sun Microsystems, Inc. <
defaultcall function="logging_rotation"/>
<
function name="logging_rotation" scope="local">
<
block name="STAXCurrentFunction">
CurrentTestPath['suite']=STAXCurrentFunction
<
call function="'testSuite_Preamble'" />
<
call function="'common_setup'">
<!--- Test Suite information #@TestSuiteName Rotation Policy Tests #@TestSuitePurpose Verify the Rotation Policy #@TestMarker Rotation Policy Tests #@TestName Size limit rotation #@TestPurpose Check the size limit rotation policy #@TestStep Create a new size limit rotation policy #@TestStep Configure the Size Limit rotation policy with a Max size to 64kb #@TestStep Execute ldapsearch request until the log are rotate #@TestResult the logs size must match the rotation size <
testcase name="getTestCaseName('size limit')">
<
call function="'testCase_Preamble'"/>
'---- Check the size limit rotation -----'
'-- create a new size limit rotation policy --'
<
call function="'dsconfig'">
{ 'dsInstanceHost' : DIRECTORY_INSTANCE_HOST,
'dsInstanceDn' : DIRECTORY_INSTANCE_DN,
'dsInstancePswd' : DIRECTORY_INSTANCE_PSWD,
'subcommand' : 'create-log-rotation-policy',
'objectType' : 'policy-name',
'objectName' : 'my size Limit Rotation Policy',
'optionsString' : '--type size-limit --set file-size-limit:4kb',
'------ Add this rotation policy to the Access log publisher --'
<
call function="'dsconfig'">
{ 'dsInstanceHost' : DIRECTORY_INSTANCE_HOST,
'dsInstanceDn' : DIRECTORY_INSTANCE_DN,
'dsInstancePswd' : DIRECTORY_INSTANCE_PSWD ,
'subcommand' : 'set-log-publisher-prop',
'objectType' : 'publisher-name',
'objectName' : 'File-Based Access Logger',
'optionsString' : '--add rotation-policy:"my size Limit Rotation Policy"',
<
call function="'dsconfig'">
{ 'dsInstanceHost' : DIRECTORY_INSTANCE_HOST,
'dsInstanceDn' : DIRECTORY_INSTANCE_DN,
'dsInstancePswd' : DIRECTORY_INSTANCE_PSWD,
'subcommand' : 'set-log-publisher-prop',
'objectType' : 'publisher-name',
'objectName' : 'File-Based Access Logger',
'optionsString' : '--add auto-flush:true --set append:true --set asynchronous:false --set buffer-size:64kb',
<
call function="'dsconfigGet'">
{ 'dsInstanceHost' : DIRECTORY_INSTANCE_HOST,
'dsInstanceDn' : DIRECTORY_INSTANCE_DN,
'dsInstancePswd' : DIRECTORY_INSTANCE_PSWD,
'objectName' : 'log-publisher',
'propertyType' : 'publisher',
'propertyName' : 'File-Based Access Logger',
'attributeName' : 'rotation-policy'
<!-- Execute ldapsearch until we detect a log rotation --> <!-- Stop when the first rotation is done --> <
loop from="1" to="50" until="RC != 0">
<
message>'###########################'</
message>
<
message>' LOOP %s :' % cpt </
message>
<
message>'###########################'</
message>
<
message>'--- Execute a Search request ---'</
message>
<
call function="'ldapSearchWithScript'">
{ 'dsInstanceHost' : DIRECTORY_INSTANCE_HOST,
'dsInstancePort' : DIRECTORY_INSTANCE_PORT ,
'dsBaseDN' : DIRECTORY_INSTANCE_SFX,
'dsInstanceDn' : DIRECTORY_INSTANCE_DN,
'dsInstancePswd' : DIRECTORY_INSTANCE_PSWD,
'dsFilter' : 'objectclass=*',
<
call function="'dsconfigGet'">
{ 'dsInstanceHost' : DIRECTORY_INSTANCE_HOST,
'dsInstanceDn' : DIRECTORY_INSTANCE_DN,
'dsInstancePswd' : DIRECTORY_INSTANCE_PSWD,
'objectName' : 'log-publisher',
'propertyType' : 'publisher',
'propertyName' : 'File-Based Access Logger',
'attributeName' : 'rotation-policy'
<
message>'--- Check log files ---'</
message>
<
call function="'listFolder'">
{ 'location' : DIRECTORY_INSTANCE_HOST,
'foldername' : '%s/%
s/
logs' % (DIRECTORY_INSTANCE_DIR,OPENDSNAME),
<
if expr="len(cmdResult) > 0">
<
iterate var="result" in="cmdResult">
'the log file status for file "%s" is %s ' % (logname,logsize)
for currentLog in listName:
if currentLog == logname:
currentSize=listSize[currentIndex]
if currentSize != logsize:
listSize[currentIndex]=logsize
<!-- set nbLog when we find a log file --> 'The new log file status is : %s : %s' % (listName,listSize)
<!-- ############################### --> <!-- Check log file size --> <!-- all the log file size must be around 4kb --> <!-- ############################### --> 'A log rotation has been done. The new rotation file is "%s" (size = %s) ' % (newlogName,newlogSize)
<
if expr="int(newlogSize) < 4100 and int(newlogSize) > 3800" >
'SUCCESS. The rotation based on size limit is successfull. The file "%s" (size = %s) ' % (newlogName,newlogSize)
<
call function="'testPassed'"/>
'ERROR in the rotation. The file "%s" (size = %s) does not match the rotation size ' % (newlogName,newlogSize)
<
call function="'testFailed'"/>
<
message>'ERROR. The rotation process didn t work.'</
message>
<
call function="'testFailed'"/>
<!-- ############################### --> <!-- clean rotation policy --> <!-- ############################### --> '------ remove this rotation policy to the Access log publisher --'
<
call function="'dsconfig'">
{ 'dsInstanceHost' : DIRECTORY_INSTANCE_HOST,
'dsInstanceDn' : DIRECTORY_INSTANCE_DN,
'dsInstancePswd' : DIRECTORY_INSTANCE_PSWD,
'subcommand' : 'set-log-publisher-prop',
'objectType' : 'publisher-name',
'objectName' : 'File-Based Access Logger',
'optionsString' : '--remove rotation-policy:"my size Limit Rotation Policy"',
'-- delete a new size limit rotation policy --'
<
call function="'dsconfig'">
{ 'dsInstanceHost' : DIRECTORY_INSTANCE_HOST,
'dsInstanceDn' : DIRECTORY_INSTANCE_DN,
'dsInstancePswd' : DIRECTORY_INSTANCE_PSWD,
'subcommand' : 'delete-log-rotation-policy',
'objectType' : 'policy-name',
'objectName' : 'my size Limit Rotation Policy',
<
call function="'testCase_Postamble'" />
<!-- Test Suite Cleanup --> <
message>'Finally: Global Log Rotation Cleanup.'</
message>
<
call function="'common_cleanup'" />
<
catch exception="'STAFException'">
<
message log="1" level="'fatal'">'Cleanup of test suite failed.'</
message>
<
call function="'testSuite_Postamble'"/>