a00eff193f
Reviewed-by: vtewari, rriggs
160 lines
5.5 KiB
Java
160 lines
5.5 KiB
Java
/*
|
|
* Copyright (c) 2018, Oracle and/or its affiliates. All rights reserved.
|
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
|
*
|
|
* This code is free software; you can redistribute it and/or modify it
|
|
* under the terms of the GNU General Public License version 2 only, as
|
|
* published by the Free Software Foundation.
|
|
*
|
|
* This code is distributed in the hope that it will be useful, but WITHOUT
|
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
|
* version 2 for more details (a copy is included in the LICENSE file that
|
|
* accompanied this code).
|
|
*
|
|
* You should have received a copy of the GNU General Public License version
|
|
* 2 along with this work; if not, write to the Free Software Foundation,
|
|
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
|
*
|
|
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
|
* or visit www.oracle.com if you need additional information or have any
|
|
* questions.
|
|
*/
|
|
|
|
import javax.naming.Context;
|
|
import javax.naming.NamingException;
|
|
import javax.naming.directory.Attributes;
|
|
import java.util.Hashtable;
|
|
|
|
/**
|
|
* Abstract test base for most of Env Tests, this class extends DNSTestBase.
|
|
*
|
|
* @see DNSTestBase
|
|
* @see TestBase
|
|
*/
|
|
abstract class EnvTestBase extends DNSTestBase {
|
|
private static final String[] MANDATORY_ATTRIBUTES = { "A", "MX", "HINFO",
|
|
"TXT", "29" };
|
|
private static final String[] OPTIONAL_ATTRIBUTES = {};
|
|
|
|
private String key;
|
|
private String fqdnUrl;
|
|
private String foreignFqdnUrl;
|
|
|
|
public EnvTestBase() {
|
|
// set default test data
|
|
setKey("host1");
|
|
}
|
|
|
|
/**
|
|
* Setup test before real test run, it overrides the method of TestBase.
|
|
*/
|
|
@Override public void setupTest() {
|
|
super.setupTest();
|
|
String fqdn = DNSTestUtils.buildFqdn(key, env(), true);
|
|
|
|
String foreignLeaf = (String) env().get("FOREIGN_LEAF");
|
|
String foreignFqdn = DNSTestUtils.buildFqdn(foreignLeaf, env(), false);
|
|
|
|
fqdnUrl = DNSTestUtils.getRootUrl(env()) + "/" + fqdn;
|
|
foreignFqdnUrl = DNSTestUtils.getRootUrl(env()) + "/" + foreignFqdn;
|
|
}
|
|
|
|
/**
|
|
* Overload method of addToEnvAndVerifyOldValIsNull, use context() as
|
|
* context.
|
|
*
|
|
* @param propName given property name
|
|
* @param propVal given property value
|
|
* @throws NamingException if a naming exception is encountered
|
|
*/
|
|
public void addToEnvAndVerifyOldValIsNull(String propName, Object propVal)
|
|
throws NamingException {
|
|
addToEnvAndVerifyOldValIsNull(context(), propName, propVal);
|
|
}
|
|
|
|
/**
|
|
* Add given property name/value to the environment of given context and
|
|
* verify the previous old property value is null which means the property
|
|
* was not in the environment before.
|
|
*
|
|
* @param context given context
|
|
* @param propName given property name
|
|
* @param propVal given property value
|
|
* @throws NamingException if a naming exception is encountered
|
|
*/
|
|
public void addToEnvAndVerifyOldValIsNull(Context context, String propName,
|
|
Object propVal) throws NamingException {
|
|
Object oldValue = context.addToEnvironment(propName, propVal);
|
|
DNSTestUtils.debug("Old Value for " + propName + " : " + oldValue);
|
|
if (oldValue != null) {
|
|
throw new RuntimeException(
|
|
"Failed: old value expected to be null for " + propName
|
|
+ " but actual is : " + oldValue);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Verify the value of specified property in given environment matched with
|
|
* given expected value. If property not exist and given expected value is
|
|
* null, we think verify passed. RuntimeException will be thrown if verify
|
|
* failed.
|
|
*
|
|
* @param env given environment
|
|
* @param propName given property name to verify
|
|
* @param expectedVal expected property value
|
|
*/
|
|
public void verifyEnvProperty(Hashtable<?, ?> env, String propName,
|
|
Object expectedVal) {
|
|
boolean equals = true;
|
|
Object actualVal = env.get(propName);
|
|
if (actualVal != null && expectedVal != null) {
|
|
if (!expectedVal.equals(actualVal)) {
|
|
equals = false;
|
|
}
|
|
} else {
|
|
if (actualVal != null || expectedVal != null) {
|
|
equals = false;
|
|
}
|
|
}
|
|
|
|
if (!equals) {
|
|
throw new RuntimeException(
|
|
"Failed: value not match for " + propName + " expected: "
|
|
+ expectedVal + " actual: " + actualVal);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Retrieve attributes by given name and attributes ids and verify
|
|
* attributes contains the mandatory attributes and the right
|
|
* objectclass attribute, will throw RuntimeException if verify failed.
|
|
*
|
|
* @param name given name
|
|
* @param attrIds given attribute ids
|
|
* @throws NamingException if a naming exception is encountered
|
|
*/
|
|
public void retrieveAndVerifyData(String name, String[] attrIds)
|
|
throws NamingException {
|
|
Attributes retAttrs = context().getAttributes(name, attrIds);
|
|
DNSTestUtils.verifySchema(retAttrs, MANDATORY_ATTRIBUTES,
|
|
OPTIONAL_ATTRIBUTES);
|
|
}
|
|
|
|
public String getKey() {
|
|
return key;
|
|
}
|
|
|
|
public void setKey(String key) {
|
|
this.key = key;
|
|
}
|
|
|
|
public String getFqdnUrl() {
|
|
return fqdnUrl;
|
|
}
|
|
|
|
public String getForeignFqdnUrl() {
|
|
return foreignFqdnUrl;
|
|
}
|
|
}
|