/* * 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 * * * Portions Copyright 2006-2007 Sun Microsystems, Inc. */ package org.opends.server.integration.quickstart; import static org.testng.Assert.*; import org.testng.annotations.*; import org.opends.server.tools.*; /* Place suite-specific test information here. #@TestSuiteName Quickstart Setup #@TestSuitePurpose Perform basic tests to ensure that OpenDS is ready. #@TestSuiteID Quickstart #@TestSuiteGroup Quickstart #@TestGroup Quickstart #@TestScript QuickstartAddTests.java #@TestHTMLLink */ /** * This class contains the TestNG tests for the QuickstartAdd startup. */ @Test public class QuickstartAddTests extends QuickstartTests { /* Place test-specific test information here. The tag, TestMarker, must be present and must be the same as the marker, TestSuiteName. #@TestMarker Quickstart Setup #@TestName Quickstart Setup 1 #@TestID Quickstart Add 1 #@TestPreamble #@TestSteps Client calls checklogdir.sh on unix systems and checklogdir.bat on Windows systems with the java Runtime method, exec(). #@TestPostamble #@TestResult Success if OpenDS returns 0 */ /** * To make the directory for the OpenDS output that will be generated * during the rest of the Integration Tests. * * @param integration_test_home The home directory for the Integration * Test Suites. * @param logDir The directory for the log files that are * generated during the Integration Tests. */ @Parameters({ "integration_test_home", "logDir" }) @Test public void testQuickstartAdd1(String integration_test_home, String logDir) throws Exception { System.out.println("*********************************************"); System.out.println("QuickstartAdd test 1"); String osName = new String(System.getProperty("os.name")); if (osName.indexOf("Windows") >= 0) // For Windows { String exec_cmd = "CMD /C " + integration_test_home + "\\quickstart\\checklogdir " + logDir; Runtime rtime = Runtime.getRuntime(); Process child = rtime.exec(exec_cmd); child.waitFor(); } else // all other unix systems { String exec_cmd = integration_test_home + "/quickstart/checklogdir.sh " + logDir; Runtime rtime = Runtime.getRuntime(); Process child = rtime.exec(exec_cmd); child.waitFor(); } ds_output.redirectOutput(logDir, "QuickstartAdd1.txt"); System.out.println("Operating system is " + osName.toString()); System.out.println(logDir + " exists and is ready to receive log files."); ds_output.resetOutput(); compareExitCode(0, 0); } /* Place test-specific test information here. The tag, TestMarker, must be present and must be the same as the marker, TestSuiteName. #@TestMarker Quickstart Setup #@TestName Quickstart Setup 2 #@TestID Quickstart Add 2 #@TestPreamble #@TestSteps Client calls static method LDAPModify.mainModify() with the filename to the appropriate ldif file. #@TestPostamble #@TestResult Success if OpenDS returns 0 */ /** * To add "dc=example,dc=com" and several entries under that dn. * * @param hostname The hostname for the server where OpenDS * is installed. * @param port The port number for OpenDS. * @param bindDN The bind DN. * @param bindPW The password for the bind DN. * @param integration_test_home The home directory for the Integration * Test Suites. * @param logDir The directory for the log files that are * generated during the Integration Tests. */ @Parameters({ "hostname", "port", "bindDN", "bindPW", "integration_test_home", "logDir" }) @Test(alwaysRun=true, dependsOnMethods = { "org.opends.server.integration.quickstart.QuickstartAddTests.testQuickstartAdd1" }) public void testQuickstartAdd2(String hostname, String port, String bindDN, String bindPW, String integration_test_home, String logDir) throws Exception { System.out.println("*********************************************"); System.out.println("QuickstartAdd test 2"); String datafile = integration_test_home + "/quickstart/data/quickstart.ldif"; String quickstartadd_args[] = {"-a", "-h", hostname, "-p", port, "-D", bindDN, "-w", bindPW, "-f", datafile}; ds_output.redirectOutput(logDir, "QuickstartAdd2.txt"); int retCode = LDAPModify.mainModify(quickstartadd_args); ds_output.resetOutput(); int expCode = 0; compareExitCode(retCode, expCode); } }