From e128322f17224657884b025b857867bfed5110c4 Mon Sep 17 00:00:00 2001
From: maudj <maudj@localhost>
Date: Wed, 02 Sep 2009 07:52:54 +0000
Subject: [PATCH] backup improvements/new tests - maudj
---
opendj-sdk/opends/tests/staf-tests/functional-tests/testcases/backends/backup/backup_tests.xml | 522 +++++++++++++++++++++++++++++++++++++++++++
opendj-sdk/opends/tests/staf-tests/functional-tests/testcases/backends/backup/backup.xml | 143 +++++++++++
opendj-sdk/opends/tests/staf-tests/functional-tests/testcases/backends/backends.xml | 2
3 files changed, 666 insertions(+), 1 deletions(-)
diff --git a/opendj-sdk/opends/tests/staf-tests/functional-tests/testcases/backends/backends.xml b/opendj-sdk/opends/tests/staf-tests/functional-tests/testcases/backends/backends.xml
index 5ad08a1..ee8546f 100644
--- a/opendj-sdk/opends/tests/staf-tests/functional-tests/testcases/backends/backends.xml
+++ b/opendj-sdk/opends/tests/staf-tests/functional-tests/testcases/backends/backends.xml
@@ -56,6 +56,7 @@
suiteList.append('import-tasks')
suiteList.append('export')
suiteList.append('export-tasks')
+ suiteList.append('backup')
</script>
<!-- Run the test suites -->
@@ -89,7 +90,6 @@
<!-- List of backends test suites to run -->
<script>
suiteList = []
- suiteList.append('backup')
suiteList.append('backup-tasks')
suiteList.append('restore')
suiteList.append('restore-tasks')
diff --git a/opendj-sdk/opends/tests/staf-tests/functional-tests/testcases/backends/backup/backup.xml b/opendj-sdk/opends/tests/staf-tests/functional-tests/testcases/backends/backup/backup.xml
new file mode 100644
index 0000000..f863432
--- /dev/null
+++ b/opendj-sdk/opends/tests/staf-tests/functional-tests/testcases/backends/backup/backup.xml
@@ -0,0 +1,143 @@
+<?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, exclude this CDDL HEADER in each
+ ! file and exclude 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 2009 Sun Microsystems, Inc.
+ ! -->
+<stax>
+ <defaultcall function="main_backup"/>
+ <function name="main_backup" scope="local">
+ <sequence>
+ <block name="'main_backup'">
+ <try>
+ <sequence>
+ <script>
+ CurrentTestPath['group']='backends'
+ CurrentTestPath['suite']='backup'
+
+ __group=CurrentTestPath['group']
+ __groupdir='%s/testcases/%s' % (TESTS_DIR,__group)
+ </script>
+
+
+ <!--- Test Suite information
+ #@TestSuiteName Backend Backup Tests
+ #@TestSuitePurpose Verify that the basic backup functionality is working in the Directory Server.
+ #@TestSuiteID Backup Tests
+ #@TestSuiteGroup Backup
+ #@TestGroup Backend
+ #@TestScript backup.xml
+ #@TestHTMLLink http://opends.dev.java.net/
+ -->
+
+ <call function="'testSuite_Preamble'" />
+
+ <try>
+ <sequence>
+
+ <call function="'common_setup'">
+ {
+ 'quickStart' : False ,
+ 'startServer' : True ,
+ 'loadData' : True ,
+ 'ldifFile' : '%s/backends/backend_start.ldif' % remote.data ,
+ 'stopServer' : False
+ }
+ </call>
+
+ <!-- List of Backup of Test Functions -->
+ <script>
+ backupList=[]
+ backupList.append('backup/backup_tests')
+ </script>
+
+ <!-- Import the files for this test suite -->
+ <iterate var="__backup" in="backupList">
+ <import machine="STAF_LOCAL_HOSTNAME"
+ file="'%s/%s.xml' % (__groupdir,__backup)"/>
+ </iterate>
+
+ <!-- List of Test Cases -->
+ <script>
+ testsList=[]
+ testsList.append('backends_backup_001')
+ testsList.append('backends_backup_002')
+ testsList.append('backends_backup_003')
+ testsList.append('backends_backup_004')
+ testsList.append('backends_backup_005')
+ testsList.append('backends_backup_006')
+ testsList.append('backends_backup_007')
+ testsList.append('backends_backup_008')
+ testsList.append('backends_backup_009')
+ testsList.append('backends_backup_010')
+ </script>
+
+ <!-- Execute the Tests -->
+ <iterate var="__test" in="testsList">
+ <sequence>
+ <call function="'%s' % (__test)" />
+ </sequence>
+ </iterate>
+
+ </sequence>
+ <catch exception="'STAFException.TestSuite.SetupException'">
+ <sequence>
+ <message log="1" level="'fatal'">
+ 'Setup of test suite failed.'
+ </message>
+ <rethrow/>
+ </sequence>
+ </catch>
+
+ <finally>
+ <message>'Test Cases Completed.'</message>
+ </finally>
+
+ </try>
+
+ </sequence>
+
+ <finally>
+ <sequence>
+ <!-- Test Suite Cleanup -->
+ <message>'Finally: Global Backup Cleanup.'</message>
+ <try>
+ <call function="'common_cleanup'" />
+ <catch exception="'STAFException'">
+ <sequence>
+ <message log="1" level="'fatal'">'Cleanup of test suite failed.'</message>
+ </sequence>
+ </catch>
+ <finally>
+ <call function="'testSuite_Postamble'"/>
+ </finally>
+ </try>
+ </sequence>
+ </finally>
+
+ </try>
+ </block>
+ </sequence>
+ </function>
+</stax>
diff --git a/opendj-sdk/opends/tests/staf-tests/functional-tests/testcases/backends/backup/backup_tests.xml b/opendj-sdk/opends/tests/staf-tests/functional-tests/testcases/backends/backup/backup_tests.xml
new file mode 100644
index 0000000..a06033b
--- /dev/null
+++ b/opendj-sdk/opends/tests/staf-tests/functional-tests/testcases/backends/backup/backup_tests.xml
@@ -0,0 +1,522 @@
+<?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, exclude this CDDL HEADER in each
+ ! file and exclude 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 2009 Sun Microsystems, Inc.
+ ! -->
+<stax>
+ <!--- Test Case information
+ #@TestMarker Backend Backup Tests
+ #@TestName Backup: Backup 001
+ #@TestID Backup 001
+ #@TestPurpose Backup the data in OpenDS.
+ #@TestPreamble
+ #@TestSteps Client calls backup with the parameters
+ default backendID, and backupDirectory
+ #@TestPostamble
+ #@TestResult Success if backup returns 0
+ -->
+
+ <function name="backends_backup_001" scope="local">
+ <testcase name="getTestCaseName('Create a backup')">
+ <try>
+ <sequence>
+
+ <call function="'testCase_Preamble'"/>
+
+ <message>
+ 'Backend Backup 001: Create a backup of the data in OpenDS'
+ </message>
+
+ <call function="'backup'">
+ { 'backupDir' : '%s/backends/backup1' % remote.data }
+ </call>
+
+ </sequence>
+
+ <catch exception="'STAXException.*'" typevar="eType" var="eInfo">
+ <message log="1" level="'fatal'">
+ '%s: Test failed. eInfo(%s)' % (eType,eInfo)
+ </message>
+ </catch>
+
+ <finally>
+ <call function="'testCase_Postamble'"/>
+ </finally>
+ </try>
+ </testcase>
+ </function>
+
+ <!--- Test Case information
+ #@TestMarker Backend Backup Tests
+ #@TestName Backup: Backup 002
+ #@TestID Backup 002
+ #@TestPurpose Create an incremental backup of the data in OpenDS.
+ #@TestPreamble
+ #@TestSteps Client calls backup with the parameters
+ default backendID, backupDir, and incremental
+ #@TestPostamble
+ #@TestResult Success if backup returns 0
+ -->
+ <function name="backends_backup_002" scope="local">
+ <testcase name="getTestCaseName('Create an incremental backup')">
+ <try>
+ <sequence>
+ <call function="'testCase_Preamble'"/>
+ <message>
+ 'Backend Backup 002 Create an incremental backup of the data in OpenDS'
+ </message>
+ <call function="'backup'">
+ { 'backupDir' : '%s/backends/backup1' % remote.data,
+ 'extraParams' : '-i'
+ }
+ </call>
+
+ </sequence>
+
+ <catch exception="'STAXException.*'" typevar="eType" var="eInfo">
+ <message log="1" level="'fatal'">
+ '%s: Test failed. eInfo(%s)' % (eType,eInfo)
+ </message>
+ </catch>
+
+ <finally>
+ <call function="'testCase_Postamble'" />
+ </finally>
+ </try>
+ </testcase>
+ </function>
+
+ <!--- Test Case information
+ #@TestMarker Backend Backup Tests
+ #@TestName Backup: Backup 003
+ #@TestID Backup 003
+ #@TestPurpose Create a backup of the data in OpenDS with a backup id.
+ #@TestPreamble
+ #@TestSteps Client calls backup with the parameters
+ default backendID, backupDir, and backupID
+ #@TestPostamble
+ #@TestResult Success if backup returns 0
+ -->
+ <function name="backends_backup_003" scope="local">
+ <testcase name="getTestCaseName('Create a backup with a backupID')">
+ <try>
+ <sequence>
+ <call function="'testCase_Preamble'"/>
+ <message>
+ 'Backend Backup 003: Create a backup of the data in OpenDS with a backup id'
+ </message>
+
+ <call function="'backup'">
+ { 'backupDir' : '%s/backends/backup2' % remote.data,
+ 'extraParams' : '-I 20070714142807Z'
+ }
+ </call>
+
+ </sequence>
+
+ <catch exception="'STAXException.*'" typevar="eType" var="eInfo">
+ <message log="1" level="'fatal'">
+ '%s: Test failed. eInfo(%s)' % (eType,eInfo)
+ </message>
+ </catch>
+
+ <finally>
+ <call function="'testCase_Postamble'" />
+ </finally>
+
+ </try>
+ </testcase>
+ </function>
+
+ <!--- Test Case information
+ #@TestMarker Backend Backup Tests
+ #@TestName Backup: Backup 004
+ #@TestID Backup 004
+ #@TestPurpose Create an incremental backup of the data in OpenDS with a backup id.
+ #@TestPreamble
+ #@TestSteps Client calls backup with the parameters
+ default backendID, backupDir, incremental, and backupID
+ #@TestPostamble
+ #@TestResult Success if backup returns 0
+ -->
+ <function name="backends_backup_004" scope="local">
+ <testcase name="getTestCaseName('Create an incremental backup with a backupID')">
+ <try>
+ <sequence>
+ <call function="'testCase_Preamble'" />
+ <message>
+ 'Backend Backup 004: Create an incremental backup of the data in OpenDS with a backup id'
+ </message>
+ <call function="'backup'">
+ { 'backupDir' : '%s/backends/backup2' % remote.data,
+ 'extraParams' : '-B 20070714142807Z -i'
+ }
+ </call>
+
+ </sequence>
+
+ <catch exception="'STAXException.*'" typevar="eType" var="eInfo">
+ <message log="1" level="'fatal'">
+ '%s: Test failed. eInfo(%s)' % (eType,eInfo)
+ </message>
+ </catch>
+
+ <finally>
+ <call function="'testCase_Postamble'"/>
+ </finally>
+
+ </try>
+ </testcase>
+ </function>
+
+
+ <!--- Test Case information
+ #@TestMarker Backend Backup Tests
+ #@TestName Backup: Backup 005
+ #@TestID Backup 005
+ #@TestPurpose Create a compressed backup of the data in OpenDS.
+ #@TestPreamble
+ #@TestSteps Client calls backup with the parameters
+ default backendID, backupDir, and compress
+ #@TestPostamble
+ #@TestResult Success if backup returns 0
+ -->
+ <function name="backends_backup_005" scope="local">
+ <testcase name="getTestCaseName('Create a compressed backup')">
+ <try>
+ <sequence>
+ <call function="'testCase_Preamble'"/>
+ <message>
+ 'Backend Backup 005: Create a compressed backup of the data in OpenDS'
+ </message>
+ <call function="'backup'">
+ { 'backupDir' : '%s/backends/backup1' % remote.data,
+ 'extraParams' : '-c'
+ }
+ </call>
+
+ </sequence>
+
+ <catch exception="'STAXException.*'" typevar="eType" var="eInfo">
+ <message log="1" level="'fatal'">
+ '%s: Test failed. eInfo(%s)' % (eType,eInfo)
+ </message>
+ </catch>
+
+ <finally>
+ <call function="'testCase_Postamble'"/>
+ </finally>
+
+ </try>
+ </testcase>
+ </function>
+
+
+ <!--- Test Case information
+ #@TestMarker Backend Backup Tests
+ #@TestName Backup: Backup 006
+ #@TestID Backup 006
+ #@TestPurpose Run backupAll with backendID, should fail.
+ #@TestPreamble
+ #@TestSteps Client calls backup with the parameters
+ #@TestSteps backUpAll with backendID
+ #@TestPostamble
+ #@TestResult Success if backup returns 1
+ -->
+ <function name="backends_backup_006" scope="local">
+ <testcase name="getTestCaseName('Create a backup with -n and -a')">
+ <try>
+ <sequence>
+ <call function="'testCase_Preamble'"/>
+ <message>
+ 'Backend Backup 006: Create a backup with -n and -a'
+ </message>
+ <call function="'backup'">
+ { 'backupDir' : '%s/backends/backup1' % remote.data,
+ 'extraParams' : '-n dc=com' ,
+ 'extraParams' : '-a' ,
+ 'expectedRC' : 1
+ }
+ </call>
+
+ <script>
+ returnString = STAXResult[0][1]
+ </script>
+
+ <call function="'checktestString'">
+ {
+ 'returnString' : returnString ,
+ 'expectedString' : 'The backUpAll and backendID arguments may not be used together'
+ }
+ </call>
+
+ </sequence>
+
+ <catch exception="'STAXException.*'" typevar="eType" var="eInfo">
+ <message log="1" level="'fatal'">
+ '%s: Test failed. eInfo(%s)' % (eType,eInfo)
+ </message>
+ </catch>
+
+ <finally>
+ <call function="'testCase_Postamble'"/>
+ </finally>
+
+ </try>
+ </testcase>
+ </function>
+
+ <!--- Test Case information
+ #@TestMarker Backend Backup Tests
+ #@TestName Backup: Backup 007
+ #@TestID Backup 007
+ #@TestPurpose Run backupAll with -A generate a hash of the
+ #@TestPurpose contents of the backup archive.
+ #@TestPreamble
+ #@TestSteps Client calls backup with the parameter -A
+ #@TestSteps Verify with restore -n the archive is valid
+ #@TestPostamble
+ #@TestResult Success if backup returns 0
+ -->
+ <function name="backends_backup_007" scope="local">
+ <testcase name="getTestCaseName('Create a backup with -A')">
+ <try>
+ <sequence>
+ <call function="'testCase_Preamble'"/>
+ <message>
+ 'Backend Backup 007: Create a backup with -A '
+ </message>
+ <call function="'backup'">
+ { 'backupDir' : '%s/backends/backup1' % remote.data,
+ 'extraParams' : '-A'
+ }
+ </call>
+
+ <!-- Stop DS -->
+ <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>
+
+ <!-- restore with -n to validate the archive -->
+ <call function="'restore'">
+ { 'backupDir' : '%s/backends/backup1' % remote.data,
+ 'extraParams' : '-n'
+ }
+ </call>
+
+ </sequence>
+
+ <catch exception="'STAXException.*'" typevar="eType" var="eInfo">
+ <message log="1" level="'fatal'">
+ '%s: Test failed. eInfo(%s)' % (eType,eInfo)
+ </message>
+ </catch>
+
+ <finally>
+ <call function="'testCase_Postamble'"/>
+ </finally>
+
+ </try>
+ </testcase>
+ </function>
+
+ <!--- Test Case information
+ #@TestMarker Backend Backup Tests
+ #@TestName Backup: Backup 008
+ #@TestID Backup 008
+ #@TestPurpose Create a backup with a backup id that exists
+ #@TestPreamble
+ #@TestSteps backup should fail as backup id already exists
+ #@TestPostamble
+ #@TestResult Success if backup returns 0
+ -->
+ <function name="backends_backup_008" scope="local">
+ <testcase name="getTestCaseName('Create a backup with an existing backupid')">
+ <try>
+ <sequence>
+ <call function="'testCase_Preamble'"/>
+ <message>
+ 'Backend Backup 008: Create a backup with a backup id'
+ </message>
+ <call function="'backup'">
+ { 'backupDir' : '%s/backends/backup2' % remote.data,
+ 'extraParams' : '-I unique-backupid'
+ }
+ </call>
+
+ <message>
+ 'Backend Backup 008: Create a backup with an existing backup id'
+ </message>
+ <call function="'backup'">
+ { 'backupDir' : '%s/backends/backup2' % remote.data,
+ 'extraParams' : '-I unique-backupid' ,
+ 'expectedRC' : 1
+ }
+ </call>
+
+ <script>
+ returnString = STAXResult[0][1]
+ </script>
+
+ <call function="'checktestString'">
+ {
+ 'returnString' : returnString ,
+ 'expectedString' : 'because another backup already exists with that ID'
+ }
+ </call>
+
+ </sequence>
+
+ <catch exception="'STAXException.*'" typevar="eType" var="eInfo">
+ <message log="1" level="'fatal'">
+ '%s: Test failed. eInfo(%s)' % (eType,eInfo)
+ </message>
+ </catch>
+
+ <finally>
+ <call function="'testCase_Postamble'"/>
+ </finally>
+
+
+ </try>
+ </testcase>
+ </function>
+
+
+ <!--- Test Case information
+ #@TestMarker Backend Backup Tests
+ #@TestName Backup: Backup 009
+ #@TestID Backup 009
+ #@TestPurpose Run backup with -B but without -i
+ #@TestPreamble
+ #@TestSteps Client calls backup with the parameter
+ #@TestSteps incrementalBaseID but without incremental
+ #@TestPostamble
+ #@TestResult Success if backup returns 1
+ -->
+ <function name="backends_backup_009" scope="local">
+ <testcase name="getTestCaseName('Create a backup with -B but without -i')">
+ <try>
+ <sequence>
+ <call function="'testCase_Preamble'"/>
+ <message>
+ 'Backend Backup 009: Create a backup with -B but without -i '
+ </message>
+ <call function="'backup'">
+ { 'backupDir' : '%s/backends/backup2' % remote.data,
+ 'extraParams' : '-B 20070714142807Z' ,
+ 'expectedRC' : 1
+ }
+ </call>
+
+ <script>
+ returnString = STAXResult[0][1]
+ </script>
+
+ <call function="'checktestString'">
+ {
+ 'returnString' : returnString ,
+ 'expectedString' : 'The use of the incrementalBaseID argument requires that the incremental'
+ }
+ </call>
+
+ <call function="'testCase_Postamble'" />
+
+ </sequence>
+
+ <catch exception="'STAXException.*'" typevar="eType" var="eInfo">
+ <message log="1" level="'fatal'">
+ '%s: Test failed. eInfo(%s)' % (eType,eInfo)
+ </message>
+ </catch>
+
+ <finally>
+ <call function="'testCase_Postamble'"/>
+ </finally>
+
+ </try>
+ </testcase>
+ </function>
+
+ <!--- Test Case information
+ #@TestMarker Backend Backup Tests
+ #@TestName Backup: Backup 010
+ #@TestID Backup 010
+ #@TestPurpose Create an incremental backup when the backup dir doesn't exist yet.
+ #@TestPreamble
+ #@TestSteps Client calls backup with the parameters
+ #@TestSteps incremental and a non existing backup dir
+ #@TestSteps A full backup should be executed
+ #@TestPostamble
+ #@TestResult Success if backup returns 0
+ -->
+ <function name="backends_backup_010" scope="local">
+ <testcase name="getTestCaseName('Create an incremental backup with a non existing backup dir')">
+ <try>
+ <sequence>
+ <call function="'testCase_Preamble'"/>
+ <message>
+ 'Backend Backup 010: Create an incremental backup with a non existing backup dir'
+ </message>
+ <call function="'backup'">
+ { 'backupDir' : '%s/backends/backup3' % remote.data,
+ 'extraParams' : '-i'
+ }
+ </call>
+
+ <script>
+ returnString = STAXResult[0][1]
+ </script>
+
+ <call function="'checktestString'">
+ {
+ 'returnString' : returnString ,
+ 'expectedString' : 'A full backup will be executed'
+ }
+ </call>
+
+ </sequence>
+
+ <catch exception="'STAXException.*'" typevar="eType" var="eInfo">
+ <message log="1" level="'fatal'">
+ '%s: Test failed. eInfo(%s)' % (eType,eInfo)
+ </message>
+ </catch>
+
+ <finally>
+ <call function="'testCase_Postamble'"/>
+ </finally>
+
+ </try>
+ </testcase>
+ </function>
+
+
+</stax>
--
Gitblit v1.10.0