importldif_properties_tests.xml revision 6858c16497a49284f9fcba5fa12093b121306ca6
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams<?xml version="1.0" encoding="UTF-8" standalone="no"?>
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams<!DOCTYPE stax SYSTEM "/shared/stax.dtd">
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams<!--
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams ! CDDL HEADER START
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams !
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams ! The contents of this file are subject to the terms of the
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams ! Common Development and Distribution License, Version 1.0 only
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams ! (the "License"). You may not use this file except in compliance
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams ! with the License.
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams !
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams ! You can obtain a copy of the license at
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams ! trunk/opends/resource/legal-notices/CDDLv1_0.txt
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams ! or http://forgerock.org/license/CDDLv1.0.html.
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams ! See the License for the specific language governing permissions
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams ! and limitations under the License.
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams !
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams ! When distributing Covered Code, include this CDDL HEADER in each
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams ! file and include the License file at
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams ! trunk/opends/resource/legal-notices/CDDLv1_0.txt. If applicable,
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams ! add the following below this CDDL HEADER, with the fields enclosed
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams ! by brackets "[]" replaced with your own identifying information:
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams ! Portions Copyright [yyyy] [name of copyright owner]
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams !
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams ! CDDL HEADER END
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams !
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams ! Copyright 2012 ForgeRock AS.
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams ! -->
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams<stax>
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams <!-- Definition of Test Cases -->
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams <!--- Test Cases : ImportLDIF: Binary Attributes -->
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams <!--- Test Case information
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams #@TestMarker ImportLDIF: Large Import Buffer
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams #@TestName ImportLDIF: Large Import Buffer
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams #@TestID importldif_properties_001
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams #@TestPurpose Verify import LDIF with Large Import Buffer
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams #@TestPreamble Common Setup
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams #@TestStep Make template for makeldif.
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams #@TestStep Create ldif file for import using makeldif.
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams #@TestStep Import the LDIF file.
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams #@TestStep Start the Directory Server.
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams #@TestStep Verify import LDIF operations.
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams #@TestPostamble Common Cleanup
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams #@TestResult Test is successful if the result code is 0
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams -->
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams <function name="importldif_properties_001" scope="local">
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams <testcase name="getTestCaseName('Large Import Buffer')">
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams <sequence>
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams <try>
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams <sequence>
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams <call function="'testCase_Preamble'"/>
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams <message>
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams 'Test Name = %s' % STAXCurrentTestcase
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams </message>
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams <message>
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams 'Import Ldif: Large Import Buffer: Preamble - Change import buffer size'
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams </message>
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams <call function="'dsconfig'">
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams { 'dsInstanceHost' : DIRECTORY_INSTANCE_HOST,
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams 'dsInstanceDn' : DIRECTORY_INSTANCE_DN ,
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams 'dsInstancePswd' : DIRECTORY_INSTANCE_PSWD ,
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams 'subcommand' : 'set-backend-prop' ,
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams 'objectType' : 'backend-name' ,
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams 'objectName' : 'userRoot',
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams 'optionsString' : '--set import-queue-size:1000' ,
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams 'expectedRC' : 0 }
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams </call>
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams <message>
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams 'Import Ldif: Large Import Buffer: Preamble - Stop DS running on port %s' % (DIRECTORY_INSTANCE_PORT)
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams </message>
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams <!-- StopDS -->
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams <call function="'StopDsWithScript'">
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams { 'location' : STAF_REMOTE_HOSTNAME }
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams </call>
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams <script>
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams numberOfEntries = 100000
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams totalEntries = numberOfEntries + 2
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams bin_attr_filename = '%s_entries.ldif' % numberOfEntries
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams import os.path
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams curr_filename=remote.temp + "/" + bin_attr_filename
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams curr_file_exists='0'
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams if os.path.exists(curr_filename):
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams curr_file_exists='1'
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams </script>
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams <message>
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams 'Import Ldif: Large Import Buffer: Looking for file, %s. File exists? (0=false, 1=true) %s' % (curr_filename, curr_file_exists)
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams </message>
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams <if expr="curr_file_exists=='0'">
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams <sequence>
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams <message>
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams 'Import Ldif: Large Import Buffer: Preamble - Make an make-ldif template file'
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams </message>
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams <call function="'MakeAMakeLdifTemplate'">
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams { 'numEntries' : numberOfEntries ,
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams 'templateFile' : '%s/import_Entries_100k.template' % (remote.temp) ,
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams 'extraLine' : 'jpegPhoto:: &lt;random:base64:38000&gt;'}
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams </call>
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams <message>
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams 'Import Ldif: Large Import Buffer: Preamble - Make the ldif file'
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams </message>
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams <call function="'MakeLdifWithScript'">
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams { 'templateFile' : '%s/import_Entries_100k.template' % (remote.temp) ,
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams 'ldifFile' : curr_filename }
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams </call>
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams </sequence>
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams </if>
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams <call function="'testStep'">
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams { 'stepMessage' : 'Import the LDIF file.' }
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams </call>
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams <call function="'ImportLdifWithScript'">
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams {
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams 'location' : STAF_REMOTE_HOSTNAME ,
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams 'ldifFile' : ldifFile ,
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams 'backEnd' : 'userRoot'
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams }
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams </call>
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams <script>
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams returnString = STAXResult[0][1]
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams msg = 'Processed %s entries, imported %s, skipped 0, rejected 0' \
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams % (totalEntries,totalEntries)
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams </script>
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams <call function="'checktestString'">
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams {
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams 'returnString' : returnString ,
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams 'expectedString' : msg
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams }
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams </call>
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams <call function="'testStep'">
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams { 'stepMessage' : 'Start the Directory Server.' }
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams </call>
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams <call function="'StartDsWithScript'">
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams { 'location' : STAF_REMOTE_HOSTNAME }
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams </call>
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams <script>
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams returnString = STAXResult[0][1]
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams msg = 'The database backend userRoot containing %s entries has started' \
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams % totalEntries
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams </script>
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams <call function="'checktestString'">
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams {
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams 'returnString' : returnString ,
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams 'expectedString' : msg
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams }
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams </call>
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams <!--- Check that DS started -->
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams <call function="'isAlive'">
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams {
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams 'noOfLoops' : 10 ,
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams 'noOfMilliSeconds' : 5000
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams }
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams </call>
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams <call function="'testStep'">
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams { 'stepMessage' : 'Verify import LDIF operations.' }
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams </call>
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams <call function="'checkImport'">
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams {
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams 'expectedEntries' : ['uid=user.0,ou=People,dc=com' ,
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams 'uid=user.10000,ou=People,dc=com' ,
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams 'uid=user.20000,ou=People,dc=com' ,
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams 'uid=user.30000,ou=People,dc=com' ,
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams 'uid=user.40000,ou=People,dc=com' ,
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams 'uid=user.50000,ou=People,dc=com' ,
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams 'uid=user.60000,ou=People,dc=com' ,
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams 'uid=user.70000,ou=People,dc=com' ,
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams 'uid=user.80000,ou=People,dc=com' ,
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams 'uid=user.90000,ou=People,dc=com' ,
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams 'uid=user.99999,ou=People,dc=com'] ,
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams 'startDS' : 'no'
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams }
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams </call>
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams </sequence>
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams <catch exception="'STAXException'" typevar="eType" var="eInfo">
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams <message log="1" level="'fatal'">
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams '%s: Test failed. eInfo(%s)' % (eType,eInfo)
6858c16497a49284f9fcba5fa12093b121306ca6gary.williams </message>
</catch>
<finally>
<sequence>
<call function="'testCase_Postamble'"/>
</sequence>
</finally>
</try>
</sequence>
</testcase>
</function>
<!--- Test Case information
#@TestMarker ImportLDIF: Many Threads
#@TestName ImportLDIF: Many Threads
#@TestID importldif_properties_002
#@TestPurpose Verify import LDIF with Many Threads
#@TestPreamble Common Setup
#@TestStep Make template for makeldif.
#@TestStep Create ldif file for import using makeldif.
#@TestStep Import the LDIF file.
#@TestStep Start the Directory Server.
#@TestStep Verify import LDIF operations.
#@TestPostamble Common Cleanup
#@TestResult Test is successful if the result code is 0
-->
<function name="importldif_properties_002" scope="local">
<testcase name="getTestCaseName('Many Threads')">
<sequence>
<try>
<sequence>
<call function="'testCase_Preamble'"/>
<message>'Update java.properties file %s/%s/config/java.properties' % (DIRECTORY_INSTANCE_DIR,OPENDSNAME)</message>
<script>
rc = java_properties('%s/%s/config/java.properties' % (DIRECTORY_INSTANCE_DIR,OPENDSNAME),
'import-ldif.offline',
[ "-server", "-Xms2048m" ])
</script>
<message>'RC %s' % rc</message>
<call function="'dsJavaPropertiesWithScript'">
{ 'location' : STAF_REMOTE_HOSTNAME }
</call>
<message>
'Import Ldif: Many Threads: Preamble - Change import thread count'
</message>
<call function="'dsconfig'">
{ 'dsInstanceHost' : DIRECTORY_INSTANCE_HOST,
'dsInstanceDn' : DIRECTORY_INSTANCE_DN ,
'dsInstancePswd' : DIRECTORY_INSTANCE_PSWD ,
'subcommand' : 'set-backend-prop' ,
'objectType' : 'backend-name' ,
'objectName' : 'userRoot',
'optionsString' : '--set import-thread-count:2048' ,
'expectedRC' : 0 }
</call>
<message>
'Import Ldif: Many Threads: Preamble - Stop DS running on port %s' % (DIRECTORY_INSTANCE_PORT)
</message>
<call function="'StopDsWithScript'">
{ 'location' : STAF_REMOTE_HOSTNAME,
'dsHost' : DIRECTORY_INSTANCE_HOST,
'dsAdminPort' : DIRECTORY_INSTANCE_ADMIN_PORT,
'dsBindDN' : DIRECTORY_INSTANCE_DN,
'dsBindPwd' : DIRECTORY_INSTANCE_PSWD }
</call>
<script>
numberOfEntries = 100000
totalEntries = numberOfEntries + 2
bin_attr_filename = '%s_entries.ldif' % numberOfEntries
import os.path
curr_filename=remote.temp + "/" + bin_attr_filename
curr_file_exists='0'
if os.path.exists(curr_filename):
curr_file_exists='1'
</script>
<message>
'Import Ldif: Many Threads: Looking for file, %s. File exists? (0=false, 1=true) %s' % (curr_filename, curr_file_exists)
</message>
<if expr="curr_file_exists=='0'">
<sequence>
<message>
'Import Ldif: Many Threads: Preamble - Make an make-ldif template file'
</message>
<call function="'MakeAMakeLdifTemplate'">
{ 'numEntries' : numberOfEntries ,
'templateFile' : '%s/import_Entries_100k.template' % (remote.temp) ,
'extraLine' : 'jpegPhoto:: &lt;random:base64:38000&gt;'}
</call>
<message>
'Import Ldif: Many Threads: Preamble - Make the ldif file'
</message>
<call function="'MakeLdifWithScript'">
{ 'templateFile' : '%s/import_Entries_100k.template' % (remote.temp) ,
'ldifFile' : curr_filename }
</call>
</sequence>
</if>
<message>
'Import Ldif: Many Threads: Import large ldif file'
</message>
<call function="'ImportLdifWithScript'">
{ 'location' : STAF_REMOTE_HOSTNAME ,
'difFile' : curr_filename ,
'backEnd' : 'userRoot'}
</call>
<script>
returnString = STAXResult[0][1]
</script>
<call function="'checktestString'">
{ 'returnString' : returnString ,
'expectedString' : 'Processed 100002 entries' }
</call>
<message>
'Import Ldif: Many Threads: Start DS running on port %s' % (DIRECTORY_INSTANCE_PORT)
</message>
<call function="'StartDsWithScript'">
{ 'location' : STAF_REMOTE_HOSTNAME }
</call>
<!--- Check that DS started -->
<call function="'isAlive'">
{ 'noOfLoops' : 10 ,
'noOfMilliSeconds' : 5000 }
</call>
<message>
'Import Ldif: Many Threads: Search for certain entries that were imported'
</message>
<call function="'checkImport'">
{ 'expectedEntries' : ['uid=user.1,ou=People,dc=com' ,
'uid=user.10000,ou=People,dc=com' ,
'uid=user.20000,ou=People,dc=com' ,
'uid=user.30000,ou=People,dc=com' ,
'uid=user.40000,ou=People,dc=com' ,
'uid=user.50000,ou=People,dc=com' ,
'uid=user.60000,ou=People,dc=com' ,
'uid=user.70000,ou=People,dc=com' ,
'uid=user.80000,ou=People,dc=com' ,
'uid=user.90000,ou=People,dc=com' ,
'uid=user.99999,ou=People,dc=com'] ,
'startDS' : 'no'
}
</call>
</sequence>
<catch exception="'STAXException'" typevar="eType" var="eInfo">
<message log="1" level="'fatal'">
'%s: Test failed. eInfo(%s)' % (eType,eInfo)
</message>
</catch>
<finally>
<sequence>
<call function="'testCase_Postamble'"/>
</sequence>
</finally>
</try>
</sequence>
</testcase>
</function>
<!--- Test Case information
#@TestMarker ImportLDIF: Low Index Entry Limit
#@TestName ImportLDIF: Low Index Entry Limit
#@TestID importldif_properties_003
#@TestPurpose Verify import LDIF with Low Index Entry Limit
#@TestPreamble Common Setup
#@TestStep Make template for makeldif.
#@TestStep Create ldif file for import using makeldif.
#@TestStep Import the LDIF file.
#@TestStep Start the Directory Server.
#@TestStep Verify import LDIF operations.
#@TestPostamble Common Cleanup
#@TestResult Test is successful if the result code is 0
-->
<function name="importldif_properties_003" scope="local">
<testcase name="getTestCaseName('Low Index Entry Limit')">
<sequence>
<try>
<sequence>
<call function="'testCase_Preamble'"/>
<message>
'Import Ldif: Low Index Entry Limit: Preamble - Change import thread count'
</message>
<call function="'dsconfig'">
{ 'dsInstanceHost' : DIRECTORY_INSTANCE_HOST,
'dsInstanceDn' : DIRECTORY_INSTANCE_DN ,
'dsInstancePswd' : DIRECTORY_INSTANCE_PSWD ,
'subcommand' : 'set-backend-prop' ,
'objectType' : 'backend-name' ,
'objectName' : 'userRoot',
'optionsString' : '--set index-entry-limit:4' ,
'expectedRC' : 0 }
</call>
<message>
'Import Ldif: Low Index Entry Limit: Preamble - Stop DS running on port %s' % (DIRECTORY_INSTANCE_PORT)
</message>
<call function="'StopDsWithScript'">
{ 'location' : STAF_REMOTE_HOSTNAME,
'dsHost' : DIRECTORY_INSTANCE_HOST,
'dsAdminPort' : DIRECTORY_INSTANCE_ADMIN_PORT,
'dsBindDN' : DIRECTORY_INSTANCE_DN,
'dsBindPwd' : DIRECTORY_INSTANCE_PSWD }
</call>
<script>
numberOfEntries = 100000
totalEntries = numberOfEntries + 2
bin_attr_filename = '%s_entries.ldif' % numberOfEntries
import os.path
curr_filename=remote.temp + "/" + bin_attr_filename
curr_file_exists='0'
if os.path.exists(curr_filename):
curr_file_exists='1'
</script>
<message>
'Import Ldif: Low Index Entry Limit: Looking for file, %s. File exists? (0=false, 1=true) %s' % (curr_filename, curr_file_exists)
</message>
<if expr="curr_file_exists=='0'">
<sequence>
<message>
'Import Ldif: Low Index Entry Limit: Preamble - Make an make-ldif template file'
</message>
<call function="'MakeAMakeLdifTemplate'">
{ 'numEntries' : numberOfEntries ,
'templateFile' : '%s/import_Entries_100k.template' % (remote.temp) ,
'extraLine' : 'jpegPhoto:: &lt;random:base64:38000&gt;'}
</call>
<message>
'Import Ldif: Low Index Entry Limit: Preamble - Make the ldif file'
</message>
<call function="'MakeLdifWithScript'">
{ 'templateFile' : '%s/import_Entries_100k.template' % (remote.temp) ,
'ldifFile' : curr_filename }
</call>
</sequence>
</if>
<message>
'Import Ldif: Low Index Entry Limit: Import large ldif file'
</message>
<call function="'ImportLdifWithScript'">
{ 'location' : STAF_REMOTE_HOSTNAME ,
'ldifFile' : curr_filename ,
'backEnd' : 'userRoot'}
</call>
<script>
returnString = STAXResult[0][1]
</script>
<call function="'checktestString'">
{ 'returnString' : returnString ,
'expectedString' : 'Processed 100002 entries' }
</call>
<message>
'Import Ldif: Low Index Entry Limit: Start DS running on port %s' % (DIRECTORY_INSTANCE_PORT)
</message>
<call function="'StartDsWithScript'">
{ 'location' : STAF_REMOTE_HOSTNAME }
</call>
<!--- Check that DS started -->
<call function="'isAlive'">
{ 'noOfLoops' : 10 ,
'noOfMilliSeconds' : 5000 }
</call>
<message>
'Import Ldif: Low Index Entry Limit: Search for certain entries that were imported'
</message>
<call function="'checkImport'">
{ 'expectedEntries' : ['uid=user.1,ou=People,dc=com' ,
'uid=user.10000,ou=People,dc=com' ,
'uid=user.20000,ou=People,dc=com' ,
'uid=user.30000,ou=People,dc=com' ,
'uid=user.40000,ou=People,dc=com' ,
'uid=user.50000,ou=People,dc=com' ,
'uid=user.60000,ou=People,dc=com' ,
'uid=user.70000,ou=People,dc=com' ,
'uid=user.80000,ou=People,dc=com' ,
'uid=user.90000,ou=People,dc=com' ,
'uid=user.99999,ou=People,dc=com'] ,
'startDS' : 'no'
}
</call>
</sequence>
<catch exception="'STAXException'" typevar="eType" var="eInfo">
<message log="1" level="'fatal'">
'%s: Test failed. eInfo(%s)' % (eType,eInfo)
</message>
</catch>
<finally>
<sequence>
<call function="'testCase_Postamble'"/>
</sequence>
</finally>
</try>
</sequence>
</testcase>
</function>
</stax>