/*
* 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;
}
}
Messung V0.5 in Prozent C=94 H=89 G=91
¤ Dauer der Verarbeitung: 0.5 Sekunden
¤
*© Formatika GbR, Deutschland