Add tests and implement proper behavior for arrays

This commit is contained in:
Mike Poindexter 2015-07-20 23:00:32 -07:00
parent a2a679b2e3
commit d86c424aad
2 changed files with 18 additions and 1 deletions

View File

@ -77,11 +77,15 @@ public class TClass<T> extends TObject implements TAnnotatedElement {
public TString getSimpleName() { public TString getSimpleName() {
if (simpleName == null) { if (simpleName == null) {
if (isArray()) {
simpleName = getComponentType().getSimpleName().concat(TString.wrap("[]"));
return simpleName;
}
String name = platformClass.getMetadata().getName(); String name = platformClass.getMetadata().getName();
int lastDollar = name.lastIndexOf('$'); int lastDollar = name.lastIndexOf('$');
if (lastDollar != -1) { if (lastDollar != -1) {
name = name.substring(lastDollar + 1); name = name.substring(lastDollar + 1);
if (name.charAt(0) >= 0 && name.charAt(0) <= 9) { if (name.charAt(0) >= '0' && name.charAt(0) <= '9') {
name = ""; name = "";
} }
} else { } else {

View File

@ -38,6 +38,16 @@ public class ClassTest {
assertEquals("[I", int[].class.getName()); assertEquals("[I", int[].class.getName());
} }
@Test
public void classSimpleNameEvaluated() {
assertEquals("Object", Object.class.getSimpleName());
assertEquals("Object[]", Object[].class.getSimpleName());
assertEquals("int", int.class.getSimpleName());
assertEquals("int[]", int[].class.getSimpleName());
assertEquals("InnerClass", InnerClass.class.getSimpleName());
assertEquals("", new Object(){}.getClass().getSimpleName());
}
@Test @Test
public void objectClassNameEvaluated() { public void objectClassNameEvaluated() {
assertEquals("java.lang.Object", new Object().getClass().getName()); assertEquals("java.lang.Object", new Object().getClass().getName());
@ -205,4 +215,7 @@ public class ClassTest {
Class<?> n(); Class<?> n();
} }
static class InnerClass {
}
} }