mirror of
https://github.com/openjdk/jdk.git
synced 2025-09-22 03:54:33 +02:00
6610174: Improve CompositeDataSupport.toString when it includes arrays
Reviewed-by: dfuchs
This commit is contained in:
parent
49ad80cabb
commit
e2890ec21a
2 changed files with 105 additions and 2 deletions
|
@ -355,6 +355,7 @@ public class CompositeDataSupport
|
||||||
* @return <code>true</code> if the specified object is equal to this
|
* @return <code>true</code> if the specified object is equal to this
|
||||||
* <code>CompositeDataSupport</code> instance.
|
* <code>CompositeDataSupport</code> instance.
|
||||||
*/
|
*/
|
||||||
|
@Override
|
||||||
public boolean equals(Object obj) {
|
public boolean equals(Object obj) {
|
||||||
if (this == obj) {
|
if (this == obj) {
|
||||||
return true;
|
return true;
|
||||||
|
@ -419,6 +420,7 @@ public class CompositeDataSupport
|
||||||
*
|
*
|
||||||
* @return the hash code value for this <code>CompositeDataSupport</code> instance
|
* @return the hash code value for this <code>CompositeDataSupport</code> instance
|
||||||
*/
|
*/
|
||||||
|
@Override
|
||||||
public int hashCode() {
|
public int hashCode() {
|
||||||
int hashcode = compositeType.hashCode();
|
int hashcode = compositeType.hashCode();
|
||||||
|
|
||||||
|
@ -457,16 +459,28 @@ public class CompositeDataSupport
|
||||||
*
|
*
|
||||||
* @return a string representation of this <code>CompositeDataSupport</code> instance
|
* @return a string representation of this <code>CompositeDataSupport</code> instance
|
||||||
*/
|
*/
|
||||||
|
@Override
|
||||||
public String toString() {
|
public String toString() {
|
||||||
|
|
||||||
return new StringBuilder()
|
return new StringBuilder()
|
||||||
.append(this.getClass().getName())
|
.append(this.getClass().getName())
|
||||||
.append("(compositeType=")
|
.append("(compositeType=")
|
||||||
.append(compositeType.toString())
|
.append(compositeType.toString())
|
||||||
.append(",contents=")
|
.append(",contents=")
|
||||||
.append(contents.toString())
|
.append(contentString())
|
||||||
.append(")")
|
.append(")")
|
||||||
.toString();
|
.toString();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private String contentString() {
|
||||||
|
StringBuilder sb = new StringBuilder("{");
|
||||||
|
String sep = "";
|
||||||
|
for (Map.Entry<String, Object> entry : contents.entrySet()) {
|
||||||
|
sb.append(sep).append(entry.getKey()).append("=");
|
||||||
|
String s = Arrays.deepToString(new Object[] {entry.getValue()});
|
||||||
|
sb.append(s.substring(1, s.length() - 1));
|
||||||
|
sep = ", ";
|
||||||
|
}
|
||||||
|
sb.append("}");
|
||||||
|
return sb.toString();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1,89 @@
|
||||||
|
/*
|
||||||
|
* Copyright 2008 Sun Microsystems, Inc. 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 Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
|
||||||
|
* CA 95054 USA or visit www.sun.com if you need additional information or
|
||||||
|
* have any questions.
|
||||||
|
*/
|
||||||
|
|
||||||
|
import javax.management.openmbean.CompositeType;
|
||||||
|
import javax.management.openmbean.OpenType;
|
||||||
|
import javax.management.openmbean.SimpleType;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* @test
|
||||||
|
* @bug 6610174
|
||||||
|
* @summary Test that CompositeDataSupport.toString() represents arrays correctly
|
||||||
|
* @author Eamonn McManus
|
||||||
|
*/
|
||||||
|
import javax.management.openmbean.ArrayType;
|
||||||
|
import javax.management.openmbean.CompositeData;
|
||||||
|
import javax.management.openmbean.CompositeDataSupport;
|
||||||
|
|
||||||
|
public class CompositeDataStringTest {
|
||||||
|
public static void main(String[] args) throws Exception {
|
||||||
|
CompositeType basicCT = new CompositeType(
|
||||||
|
"basicCT", "basic CompositeType",
|
||||||
|
new String[] {"name", "value"},
|
||||||
|
new String[] {"name", "value"},
|
||||||
|
new OpenType<?>[] {SimpleType.STRING, SimpleType.INTEGER});
|
||||||
|
CompositeType ct = new CompositeType(
|
||||||
|
"noddy", "descr",
|
||||||
|
new String[] {"strings", "ints", "cds"},
|
||||||
|
new String[] {"string array", "int array", "composite data array"},
|
||||||
|
new OpenType<?>[] {
|
||||||
|
ArrayType.getArrayType(SimpleType.STRING),
|
||||||
|
ArrayType.getPrimitiveArrayType(int[].class),
|
||||||
|
ArrayType.getArrayType(basicCT)
|
||||||
|
});
|
||||||
|
CompositeData basicCD1 = new CompositeDataSupport(
|
||||||
|
basicCT, new String[] {"name", "value"}, new Object[] {"ceathar", 4});
|
||||||
|
CompositeData basicCD2 = new CompositeDataSupport(
|
||||||
|
basicCT, new String[] {"name", "value"}, new Object[] {"naoi", 9});
|
||||||
|
CompositeData cd = new CompositeDataSupport(
|
||||||
|
ct,
|
||||||
|
new String[] {"strings", "ints", "cds"},
|
||||||
|
new Object[] {
|
||||||
|
new String[] {"fred", "jim", "sheila"},
|
||||||
|
new int[] {2, 3, 5, 7},
|
||||||
|
new CompositeData[] {basicCD1, basicCD2}
|
||||||
|
});
|
||||||
|
String s = cd.toString();
|
||||||
|
System.out.println("CompositeDataSupport.toString(): " + s);
|
||||||
|
String[] expected = {
|
||||||
|
"fred, jim, sheila",
|
||||||
|
"2, 3, 5, 7",
|
||||||
|
"ceathar",
|
||||||
|
"naoi",
|
||||||
|
};
|
||||||
|
boolean ok = true;
|
||||||
|
for (String expect : expected) {
|
||||||
|
if (s.contains(expect))
|
||||||
|
System.out.println("OK: string contains <" + expect + ">");
|
||||||
|
else {
|
||||||
|
ok = false;
|
||||||
|
System.out.println("NOT OK: string does not contain <" +
|
||||||
|
expect + ">");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (ok)
|
||||||
|
System.out.println("TEST PASSED");
|
||||||
|
else
|
||||||
|
throw new Exception("TEST FAILED: string did not contain expected substrings");
|
||||||
|
}
|
||||||
|
}
|
Loading…
Add table
Add a link
Reference in a new issue