<?xml version="1.0" encoding="UTF-8" standalone="no"?>
|
<!DOCTYPE stax SYSTEM "../../../../shared/stax.dtd">
|
<!--
|
! CDDL HEADER START
|
!
|
! 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
|
! with the License.
|
!
|
! You can obtain a copy of the license at
|
! trunk/opends/resource/legal-notices/OpenDS.LICENSE
|
! or https://OpenDS.dev.java.net/OpenDS.LICENSE.
|
! 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
|
! trunk/opends/resource/legal-notices/OpenDS.LICENSE. If applicable,
|
! 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]
|
!
|
! CDDL HEADER END
|
!
|
! Copyright 2007-2008 Sun Microsystems, Inc.
|
! -->
|
<stax>
|
|
<defaultcall function="replication_schema"/>
|
|
<function name="replication_schema">
|
|
<sequence>
|
|
<block name="'schema'">
|
|
<sequence>
|
|
<script>
|
if not CurrentTestPath.has_key('group'):
|
CurrentTestPath['group']='replication'
|
CurrentTestPath['suite']=STAXCurrentBlock
|
</script>
|
|
<call function="'testSuite_Preamble'"/>
|
|
<!--- Test Suite information
|
#@TestSuiteName Replication Schema Replication Tests
|
#@TestSuitePurpose Verify that the schema is replicated as any
|
other suffix in a replicated topology.
|
#@TestSuiteID Schema Replication Tests
|
#@TestSuiteGroup Schema Replication
|
#@TestGroup Replication
|
#@TestScript replication_schema.xml
|
#@TestHTMLLink http://opends.dev.java.net/
|
-->
|
|
|
<import machine="STAF_LOCAL_HOSTNAME"
|
file="'%s/testcases/replication/replication_setup.xml' % TESTS_DIR"/>
|
<call function="'replication_setup'" />
|
|
<script>
|
synchroSuffix = master.getSynchronizedSuffixList()[0].getSuffixDn()
|
|
currentSchemaFile = '%s/config/schema/99-user.ldif' % masterPath
|
provSchemaFile = '%s/../last-99-user.ldif' % masterPath
|
|
consumer = consumerList[0]
|
consumerHost = consumer.getHostname()
|
</script>
|
|
|
<!--- Test Case information
|
#@TestMarker Replication Schema Replication Tests
|
#@TestName Replication: Schema Replication: Add objectclass
|
#@TestID Add objectclass
|
#@TestPurpose Check schema replication when a new objectclass
|
is added
|
#@TestPreamble Load entries
|
#@TestSteps Add new objectclass definition on server1
|
#@TestSteps Add entry of new objectclass on server2
|
#@TestPostamble
|
#@TestResult Success if schema add and entry add replicated
|
-->
|
<testcase name="getTestCaseName('Add objectclass')">
|
<sequence>
|
<call function="'testCase_Preamble'"/>
|
<message>
|
'Replication: Schema Replication: Add objectclass. \
|
Check schema replication when a new objectclass is added'
|
</message>
|
|
<!-- Load entries into "master" server -->
|
<call function="'addEntry'">
|
{ 'location' : clientHost,
|
'dsPath' : clientPath,
|
'dsInstanceHost' : masterHost,
|
'dsInstancePort' : master.getPort(),
|
'dsInstanceDn' : master.getRootDn(),
|
'dsInstancePswd' : master.getRootPwd(),
|
'entryToBeAdded' : '%s/replication/Example.ldif' % \
|
clientDataDir
|
}
|
</call>
|
|
<script>
|
newObjectclass = '( testobjectclass-oid NAME \'testobjectclass-0\' SUP person MAY ( street $ c ) X-ORIGIN \'user defined\' )'
|
</script>
|
|
<!-- Modify schema in "master" server -->
|
<call function="'modifyAnAttribute'">
|
{ 'dsPath' : masterPath,
|
'dsInstanceHost' : masterHost ,
|
'dsInstancePort' : master.getPort(),
|
'dsInstanceDn' : master.getRootDn(),
|
'dsInstancePswd' : master.getRootPwd(),
|
'DNToModify' : 'cn=schema',
|
'attributeName' : 'objectClasses',
|
'newAttributeValue' : newObjectclass,
|
'changetype' : 'add'
|
}
|
</call>
|
|
<!-- Add entry to "consumer" server -->
|
<call function="'addEntry'">
|
{ 'location' : clientHost,
|
'dsPath' : clientPath,
|
'dsInstanceHost' : consumerHost,
|
'dsInstancePort' : consumer.getPort(),
|
'dsInstanceDn' : consumer.getRootDn(),
|
'dsInstancePswd' : consumer.getRootPwd(),
|
'entryToBeAdded' : '%s/replication/testuser-0.ldif' % \
|
clientDataDir
|
}
|
</call>
|
|
<!-- Verify the synchronization of the schema among the servers
|
in the topology -->
|
<call function="'verifySchemas'">
|
[ clientHost, clientPath, master, consumerList, '99-user.ldif' ]
|
</call>
|
|
<!-- Verify the synchronization of the trees among the servers in
|
the topology -->
|
<call function="'verifyTrees'">
|
[ clientHost, clientPath, master, consumerList, synchroSuffix ]
|
</call>
|
|
<call function="'testCase_Postamble'"/>
|
</sequence>
|
</testcase>
|
|
|
|
|
<!--- Test Case information
|
#@TestMarker Replication Schema Replication Tests
|
#@TestName Replication: Schema Replication:
|
Add attributetype
|
#@TestID Add attributetype
|
#@TestPurpose Check schema replication when a new
|
attributetype is added
|
#@TestPreamble
|
#@TestSteps Add new attributeType and new objectclass
|
definition on server1
|
#@TestSteps Add new entry containing new objectclass and
|
new attributeType on server2
|
#@TestPostamble
|
#@TestResult Success if schema add and entry adds replicated
|
-->
|
<testcase name="getTestCaseName('Add attributetype')">
|
<sequence>
|
<call function="'testCase_Preamble'"/>
|
<message>
|
'Replication: Schema Replication: Add attributetype Check \
|
schema replication when a new attributetype is added'
|
</message>
|
|
<script>
|
newObjectclass = '( testobjectclass1-oid NAME \'testobjectclass-1\' SUP person MAY ( street $ testattribute-1 $ c ) X-ORIGIN \'user defined\' )'
|
newAttributetype = '( testattribute1-oid NAME \'testattribute-1\' SYNTAX 1.3.6.1.4.1.1466.115.121.1.15 X-ORIGIN \'user defined\' )'
|
</script>
|
|
<!-- Modify schema in "master" server -->
|
<call function="'modifyAnAttribute'">
|
{ 'dsPath' : masterPath,
|
'dsInstanceHost' : masterHost ,
|
'dsInstancePort' : master.getPort(),
|
'dsInstanceDn' : master.getRootDn(),
|
'dsInstancePswd' : master.getRootPwd(),
|
'DNToModify' : 'cn=schema',
|
'attributeName' : 'attributeTypes',
|
'newAttributeValue' : newAttributetype,
|
'changetype' : 'add'
|
}
|
</call>
|
<call function="'modifyAnAttribute'">
|
{ 'dsPath' : masterPath,
|
'dsInstanceHost' : masterHost ,
|
'dsInstancePort' : master.getPort(),
|
'dsInstanceDn' : master.getRootDn(),
|
'dsInstancePswd' : master.getRootPwd(),
|
'DNToModify' : 'cn=schema',
|
'attributeName' : 'objectClasses',
|
'newAttributeValue' : newObjectclass,
|
'changetype' : 'add'
|
}
|
</call>
|
|
<!-- Add entry to "consumer" server -->
|
<call function="'addEntry'">
|
{ 'location' : clientHost,
|
'dsPath' : clientPath,
|
'dsInstanceHost' : consumerHost,
|
'dsInstancePort' : consumer.getPort(),
|
'dsInstanceDn' : consumer.getRootDn(),
|
'dsInstancePswd' : consumer.getRootPwd(),
|
'entryToBeAdded' : '%s/replication/testuser-1.ldif' % \
|
clientDataDir
|
}
|
</call>
|
|
<!-- Verify the synchronization of the schema among the servers in
|
the topology -->
|
<call function="'verifySchemas'">
|
[ clientHost, clientPath, master, consumerList, '99-user.ldif' ]
|
</call>
|
|
<!-- Verify the synchronization of the trees among the servers in
|
the topology -->
|
<call function="'verifyTrees'">
|
[ clientHost, clientPath, master, consumerList, synchroSuffix ]
|
</call>
|
|
<call function="'testCase_Postamble'"/>
|
</sequence>
|
</testcase>
|
|
|
|
<!-- Test Case information
|
#@TestMarker Replication Schema Replication Tests
|
#@TestName Replication: Schema Replication:
|
Delete objectclass
|
#@TestID Delete objectclass
|
#@TestPurpose Check schema replication when an objectclass
|
is deleted
|
#@TestPreamble
|
#@TestSteps Remove user-defined objectclass definition on
|
server1
|
#@TestSteps Delete entry on server1
|
#@TestSteps Add entry containing removed objectclass on
|
every server
|
#@TestPostamble
|
#@TestResult Success if schema remove replicated and last
|
entry add rejected on all servers (error 65:
|
objectclass violation)
|
-->
|
<testcase name="getTestCaseName('Delete objectclass')">
|
<sequence>
|
<call function="'testCase_Preamble'"/>
|
<message>
|
'Replication: Schema Replication: Delete objectclass Check \
|
schema replication when an objectclass is deleted'
|
</message>
|
|
<script>
|
newObjectclass = '( testobjectclass-oid NAME \'testobjectclass-0\' SUP person MAY ( street $ c ) X-ORIGIN \'user defined\' )'
|
</script>
|
|
<!-- Modify schema in "master" server -->
|
<call function="'modifyAnAttribute'">
|
{ 'dsPath' : masterPath,
|
'dsInstanceHost' : masterHost ,
|
'dsInstancePort' : master.getPort(),
|
'dsInstanceDn' : master.getRootDn(),
|
'dsInstancePswd' : master.getRootPwd(),
|
'DNToModify' : 'cn=schema',
|
'attributeName' : 'objectClasses',
|
'newAttributeValue' : newObjectclass,
|
'changetype' : 'delete'
|
}
|
</call>
|
|
<!-- Delete previously added entry -->
|
<call function="'ldapDeleteWithScript'">
|
{ 'location' : clientHost,
|
'dsPath' : clientPath,
|
'dsInstanceHost' : master.getHostname(),
|
'dsInstancePort' : master.getPort(),
|
'dsInstanceDn' : master.getRootDn(),
|
'dsInstancePswd' : master.getRootPwd(),
|
'dsDn' : ['cn=testuser-0,ou=People,%s' % synchroSuffix]
|
}
|
</call>
|
|
<!-- Try to add entry to servers; should be rejected with error 65
|
(objectclass violation) -->
|
<iterate var="server" in="_topologyServerList">
|
<call function="'addEntry'">
|
{ 'location' : clientHost,
|
'dsPath' : clientPath,
|
'dsInstanceHost' : server.getHostname(),
|
'dsInstancePort' : server.getPort(),
|
'dsInstanceDn' : server.getRootDn(),
|
'dsInstancePswd' : server.getRootPwd(),
|
'entryToBeAdded' : '%s/replication/testuser-0.ldif' % \
|
clientDataDir,
|
'expectedRC' : 65
|
}
|
</call>
|
</iterate>
|
|
<!-- Verify the synchronization of the schema among the servers in
|
the topology -->
|
<call function="'verifySchemas'">
|
[ clientHost, clientPath, master, consumerList, '99-user.ldif' ]
|
</call>
|
|
<!-- Verify the synchronization of the trees among the servers in
|
the topology -->
|
<call function="'verifyTrees'">
|
[ clientHost, clientPath, master, consumerList, synchroSuffix ]
|
</call>
|
|
<call function="'testCase_Postamble'"/>
|
</sequence>
|
</testcase>
|
|
|
|
<!-- Test Case information
|
#@TestMarker Replication Schema Replication Tests
|
#@TestName Replication: Schema Replication:
|
Modify objectclass
|
#@TestID Modify objectclass
|
#@TestPurpose Check schema replication when an objectclass is
|
modified
|
#@TestPreamble
|
#@TestSteps Remove user-defined objectclass definition on
|
server1
|
#@TestSteps Add modified version of removed user-defined
|
objectclass on server1 (make attributes
|
MANDATORY)
|
#@TestSteps Add entry containing newly added objectclass but
|
without required attributes on every server
|
#@TestPostamble
|
#@TestResult Success if schema modify replicated and entry
|
add rejected with error 65 (objectclass
|
violation) on all servers
|
-->
|
<testcase name="getTestCaseName('Modify objectclass')">
|
<sequence>
|
<call function="'testCase_Preamble'"/>
|
<message>
|
'Replication: Schema Replication: Modify objectclass Check \
|
schema replication when an objectclass is modified'
|
</message>
|
|
<script>
|
oldObjectclass = '( testobjectclass1-oid NAME \'testobjectclass-1\' SUP person MAY ( street $ testattribute-1 $ c ) X-ORIGIN \'user defined\' )'
|
newObjectclass = '( testobjectclass1-oid NAME \'testobjectclass-1\' SUP person MUST ( street $ testattribute-1 $ c ) X-ORIGIN \'user defined\' )'
|
</script>
|
|
<!-- Modify schema in "master" server -->
|
<call function="'modifyAnAttribute'">
|
{ 'dsPath' : masterPath,
|
'dsInstanceHost' : masterHost ,
|
'dsInstancePort' : master.getPort(),
|
'dsInstanceDn' : master.getRootDn(),
|
'dsInstancePswd' : master.getRootPwd(),
|
'DNToModify' : 'cn=schema',
|
'attributeName' : 'objectClasses',
|
'newAttributeValue' : oldObjectclass,
|
'changetype' : 'delete'
|
}
|
</call>
|
<call function="'modifyAnAttribute'">
|
{ 'dsPath' : masterPath,
|
'dsInstanceHost' : masterHost ,
|
'dsInstancePort' : master.getPort(),
|
'dsInstanceDn' : master.getRootDn(),
|
'dsInstancePswd' : master.getRootPwd(),
|
'DNToModify' : 'cn=schema',
|
'attributeName' : 'objectClasses',
|
'newAttributeValue' : newObjectclass,
|
'changetype' : 'add'
|
}
|
</call>
|
|
<!-- Try to add entry to servers; should be rejected with error 65
|
(objectclass violation) -->
|
<iterate var="server" in="_topologyServerList">
|
<call function="'addEntry'">
|
{ 'location' : clientHost,
|
'dsPath' : clientPath,
|
'dsInstanceHost' : server.getHostname(),
|
'dsInstancePort' : server.getPort(),
|
'dsInstanceDn' : server.getRootDn(),
|
'dsInstancePswd' : server.getRootPwd(),
|
'entryToBeAdded' : '%s/replication/testuser-2.ldif' % \
|
clientDataDir,
|
'expectedRC' : 65
|
}
|
</call>
|
</iterate>
|
|
<!-- Verify the synchronization of the schema among the servers in
|
the topology -->
|
<call function="'verifySchemas'">
|
[ clientHost, clientPath, master, consumerList, '99-user.ldif' ]
|
</call>
|
|
<!-- Verify the synchronization of the trees among the servers in
|
the topology -->
|
<call function="'verifyTrees'">
|
[ clientHost, clientPath, master, consumerList, synchroSuffix ]
|
</call>
|
|
<call function="'testCase_Postamble'"/>
|
</sequence>
|
</testcase>
|
|
|
|
<!--- Test Case information
|
#@TestMarker Replication Schema Replication Tests
|
#@TestName Replication: Schema Replication: Add objectclass
|
(edit schema file)
|
#@TestID Add objectclass (edit schema file)
|
#@TestPurpose Check schema replication when a new objectclass
|
is added manually
|
#@TestPreamble
|
#@TestSteps Stop servers
|
#@TestSteps Edit 99-user.ldif to add new objectclass
|
definition on server1
|
#@TestSteps Start servers
|
#@TestSteps Add entry of new objectclass on server2
|
#@TestPostamble
|
#@TestResult Success if schema add and entry add replicated
|
-->
|
<testcase name="getTestCaseName
|
('Add objectclass (edit schema file)')">
|
<sequence>
|
<call function="'testCase_Preamble'"/>
|
<message>
|
'Replication: Schema Replication: Add objectclass (edit \
|
schema file). Check schema replication when a new objectclass \
|
is added manually'
|
</message>
|
|
<!-- Stop the servers in the topology -->
|
<call function="'stopServers'">
|
[_topologyServerList]
|
</call>
|
|
<!-- Modify schema in "master" server -->
|
<call function="'copyFile'">
|
{ 'location' : masterHost,
|
'remotehost' : masterHost,
|
'srcfile' : currentSchemaFile,
|
'destfile' : provSchemaFile
|
}
|
</call>
|
<call function="'LdifModifyWithScript'">
|
{ 'location' : masterHost,
|
'dsPath' : masterPath,
|
'sourceLdif' : provSchemaFile,
|
'changesLdif' : '%s/replication/schemamods-0.ldif' % \
|
masterDataDir,
|
'targetLdif' : currentSchemaFile
|
}
|
</call>
|
|
<!-- Start the servers in the topology -->
|
<call function="'startServers'">
|
[_topologyServerList]
|
</call>
|
|
<call function="'Sleep'">
|
{ 'location' : masterHost,
|
'sleepForMilliSeconds' : 1000
|
}
|
</call>
|
|
<!-- Add entry to "consumer" server -->
|
<call function="'addEntry'">
|
{ 'location' : clientHost,
|
'dsPath' : clientPath,
|
'dsInstanceHost' : consumerHost,
|
'dsInstancePort' : consumer.getPort(),
|
'dsInstanceDn' : consumer.getRootDn(),
|
'dsInstancePswd' : consumer.getRootPwd(),
|
'entryToBeAdded' : '%s/replication/newtestuser-0.ldif' % \
|
clientDataDir
|
}
|
</call>
|
|
<!-- Verify the synchronization of the schema among the servers in
|
the topology -->
|
<call function="'verifySchemas'">
|
[ clientHost, clientPath, master, consumerList, '99-user.ldif' ]
|
</call>
|
|
<!-- Verify the synchronization of the trees among the servers in
|
the topology -->
|
<call function="'verifyTrees'">
|
[ clientHost, clientPath, master, consumerList, synchroSuffix ]
|
</call>
|
|
<call function="'testCase_Postamble'"/>
|
</sequence>
|
</testcase>
|
|
|
|
|
<!--- Test Case information
|
#@TestMarker Replication Schema Replication Tests
|
#@TestName Replication: Schema Replication: Add
|
attributetype (edit schema file)
|
#@TestID Add attributetype (edit schema file)
|
#@TestPurpose Check schema replication when a new
|
attributetype is added manually
|
#@TestPreamble
|
#@TestSteps Stop servers
|
#@TestSteps Edit 99-user.ldif to add new objectclass and
|
new attributeType definition on server1
|
#@TestSteps Start servers
|
#@TestSteps Add new entry containing new objectclass and
|
new attributeType on server2
|
#@TestPostamble
|
#@TestResult Success if schema add and entry adds replicated
|
-->
|
<testcase name="getTestCaseName
|
('Add attributetype (edit schema file)')">
|
<sequence>
|
<call function="'testCase_Preamble'"/>
|
<message>
|
'Replication: Schema Replication: Add attributetype (edit \
|
schema file). Check schema replication when a new \
|
attributetype is added manually'
|
</message>
|
|
<!-- Stop the servers in the topology -->
|
<call function="'stopServers'">
|
[_topologyServerList]
|
</call>
|
|
<!-- Modify schema in "master" server -->
|
<call function="'copyFile'">
|
{ 'location' : masterHost,
|
'remotehost' : masterHost,
|
'srcfile' : currentSchemaFile,
|
'destfile' : provSchemaFile
|
}
|
</call>
|
<call function="'LdifModifyWithScript'">
|
{ 'location' : masterHost,
|
'dsPath' : masterPath,
|
'sourceLdif' : provSchemaFile,
|
'changesLdif' : '%s/replication/schemamods-1.ldif' % \
|
masterDataDir,
|
'targetLdif' : currentSchemaFile
|
}
|
</call>
|
|
<!-- Start the servers in the topology -->
|
<call function="'startServers'">
|
[_topologyServerList]
|
</call>
|
|
<call function="'Sleep'">
|
{ 'location' : masterHost,
|
'sleepForMilliSeconds' : 1000
|
}
|
</call>
|
|
<!-- Add entry to "consumer" server -->
|
<call function="'addEntry'">
|
{ 'location' : clientHost,
|
'dsPath' : clientPath,
|
'dsInstanceHost' : consumerHost,
|
'dsInstancePort' : consumer.getPort(),
|
'dsInstanceDn' : consumer.getRootDn(),
|
'dsInstancePswd' : consumer.getRootPwd(),
|
'entryToBeAdded' : '%s/replication/newtestuser-1.ldif' % \
|
clientDataDir
|
}
|
</call>
|
|
<!-- Verify the synchronization of the schema among the servers in
|
the topology -->
|
<call function="'verifySchemas'">
|
[ clientHost, clientPath, master, consumerList, '99-user.ldif' ]
|
</call>
|
|
<!-- Verify the synchronization of the trees among the servers in
|
the topology -->
|
<call function="'verifyTrees'">
|
[ clientHost, clientPath, master, consumerList, synchroSuffix ]
|
</call>
|
|
<call function="'testCase_Postamble'"/>
|
</sequence>
|
</testcase>
|
|
|
|
|
<!-- Test Case information
|
#@TestMarker Replication Schema Replication Tests
|
#@TestName Replication: Schema Replication: Delete
|
objectclass (edit schema file)
|
#@TestID Delete objectclass (edit schema file)
|
#@TestPurpose Check schema replication when an objectclass is
|
deleted manually
|
#@TestPreamble
|
#@TestSteps Stop servers
|
#@TestSteps Edit 99-user.ldif to remove user-defined
|
objectclass definition on server1
|
#@TestSteps Start servers
|
#@TestSteps Delete entry on server1
|
#@TestSteps Add entry containing removed objectclass on
|
every server
|
#@TestPostamble
|
#@TestResult Success if schema remove replicated and last
|
entry add rejected on all servers (error 65:
|
objectclass violation)
|
-->
|
<testcase name="getTestCaseName
|
('Delete objectclass (edit schema file)')">
|
<sequence>
|
<call function="'testCase_Preamble'"/>
|
<message>
|
'Replication: Schema Replication: Delete objectclass (edit \
|
schema file). Check schema replication when an objectclass is \
|
deleted manually'
|
</message>
|
|
<!-- Stop the servers in the topology -->
|
<call function="'stopServers'">
|
[_topologyServerList]
|
</call>
|
|
<!-- Modify schema in "master" server -->
|
<call function="'copyFile'">
|
{ 'location' : masterHost,
|
'remotehost' : masterHost,
|
'srcfile' : currentSchemaFile,
|
'destfile' : provSchemaFile
|
}
|
</call>
|
<call function="'LdifModifyWithScript'">
|
{ 'location' : masterHost,
|
'dsPath' : masterPath,
|
'sourceLdif' : provSchemaFile,
|
'changesLdif' : '%s/replication/schemamods-2.ldif' % \
|
masterDataDir,
|
'targetLdif' : currentSchemaFile
|
}
|
</call>
|
|
<!-- Start the servers in the topology -->
|
<call function="'startServers'">
|
[_topologyServerList]
|
</call>
|
|
|
<!-- Delete previously added entry -->
|
<call function="'ldapDeleteWithScript'">
|
{ 'location' : clientHost,
|
'dsPath' : clientPath,
|
'dsInstanceHost' : master.getHostname(),
|
'dsInstancePort' : master.getPort(),
|
'dsInstanceDn' : master.getRootDn(),
|
'dsInstancePswd' : master.getRootPwd(),
|
'dsDn' : ['cn=newtestuser-0,ou=People,%s' % synchroSuffix]
|
}
|
</call>
|
|
<call function="'Sleep'">
|
{ 'location' : masterHost,
|
'sleepForMilliSeconds' : 1000
|
}
|
</call>
|
|
<!-- Try to add entry to servers; should be rejected with error 65
|
(objectclass violation) -->
|
<iterate var="server" in="_topologyServerList">
|
<call function="'addEntry'">
|
{ 'location' : clientHost,
|
'dsPath' : clientPath,
|
'dsInstanceHost' : server.getHostname(),
|
'dsInstancePort' : server.getPort(),
|
'dsInstanceDn' : server.getRootDn(),
|
'dsInstancePswd' : server.getRootPwd(),
|
'entryToBeAdded' : '%s/replication/newtestuser-0.ldif' % \
|
clientDataDir,
|
'expectedRC' : 65
|
}
|
</call>
|
</iterate>
|
|
<!-- Verify the synchronization of the schema among the servers in
|
the topology -->
|
<call function="'verifySchemas'">
|
[ clientHost, clientPath, master, consumerList, '99-user.ldif' ]
|
</call>
|
|
<!-- Verify the synchronization of the trees among the servers in
|
the topology -->
|
<call function="'verifyTrees'">
|
[ clientHost, clientPath, master, consumerList, synchroSuffix ]
|
</call>
|
|
|
<script>
|
knownIssue(2355)
|
</script>
|
|
<call function="'testCase_Postamble'"/>
|
</sequence>
|
</testcase>
|
|
|
|
<!-- Test Case information
|
#@TestMarker Replication Schema Replication Tests
|
#@TestName Replication: Schema Replication: Modify
|
objectclass (edit schema file)
|
#@TestID Modify objectclass (edit schema file)
|
#@TestPurpose Check schema replication when an objectclass is
|
modified manually
|
#@TestPreamble
|
#@TestSteps Stop servers
|
#@TestSteps Edit 99-user.ldif to modify user-defined
|
objectclass (make attributes MANDATORY) on
|
server1
|
#@TestSteps Start servers
|
#@TestSteps Add entry containing newly added objectclass but
|
without required attributes on every server
|
#@TestPostamble
|
#@TestResult Success if schema modify replicated and entry
|
add rejected with error 65 (objectclass
|
violation) on all servers
|
-->
|
<testcase name="getTestCaseName
|
('Modify objectclass (edit schema file)')">
|
<sequence>
|
<call function="'testCase_Preamble'"/>
|
<message>
|
'Replication: Schema Replication: Modify objectclass (edit \
|
schema file). Check schema replication when an objectclass is \
|
modified manually'
|
</message>
|
|
<!-- Stop the servers in the topology -->
|
<call function="'stopServers'">
|
[_topologyServerList]
|
</call>
|
|
<!-- Modify schema in "master" server -->
|
<call function="'copyFile'">
|
{ 'location' : masterHost,
|
'remotehost' : masterHost,
|
'srcfile' : currentSchemaFile,
|
'destfile' : provSchemaFile
|
}
|
</call>
|
<call function="'LdifModifyWithScript'">
|
{ 'location' : masterHost,
|
'dsPath' : masterPath,
|
'sourceLdif' : provSchemaFile,
|
'changesLdif' : '%s/replication/schemamods-3.ldif' % \
|
masterDataDir,
|
'targetLdif' : currentSchemaFile
|
}
|
</call>
|
|
<!-- Start the servers in the topology -->
|
<call function="'startServers'">
|
[_topologyServerList]
|
</call>
|
|
<call function="'Sleep'">
|
{ 'location' : masterHost,
|
'sleepForMilliSeconds' : 1000
|
}
|
</call>
|
|
<!-- Try to add entry to servers; should be rejected with error 65
|
(objectclass violation) -->
|
<iterate var="server" in="_topologyServerList">
|
<call function="'addEntry'">
|
{ 'location' : clientHost,
|
'dsPath' : clientPath,
|
'dsInstanceHost' : server.getHostname(),
|
'dsInstancePort' : server.getPort(),
|
'dsInstanceDn' : server.getRootDn(),
|
'dsInstancePswd' : server.getRootPwd(),
|
'entryToBeAdded' : '%s/replication/newtestuser-2.ldif' % \
|
clientDataDir,
|
'expectedRC' : 65
|
}
|
</call>
|
</iterate>
|
|
<!-- Verify the synchronization of the schema among the servers in
|
the topology -->
|
<call function="'verifySchemas'">
|
[ clientHost, clientPath, master, consumerList, '99-user.ldif' ]
|
</call>
|
|
<!-- Verify the synchronization of the trees among the servers in
|
the topology -->
|
<call function="'verifyTrees'">
|
[ clientHost, clientPath, master, consumerList, synchroSuffix ]
|
</call>
|
|
|
<script>
|
knownIssue(2355)
|
</script>
|
|
<call function="'testCase_Postamble'"/>
|
</sequence>
|
</testcase>
|
|
|
<import machine="STAF_LOCAL_HOSTNAME"
|
file="'%s/testcases/replication/replication_cleanup.xml' % TESTS_DIR"/>
|
<call function="'replication_cleanup'" />
|
|
<call function="'testSuite_Postamble'"/>
|
|
</sequence>
|
|
</block>
|
|
</sequence>
|
|
</function>
|
|
</stax>
|