File: methodselection2.bsh

package info (click to toggle)
bsh 2.0b4-20
  • links: PTS, VCS
  • area: main
  • in suites: bookworm, bullseye, forky, sid, trixie
  • size: 4,224 kB
  • sloc: java: 23,431; xml: 4,500; sh: 139; makefile: 24
file content (71 lines) | stat: -rw-r--r-- 2,188 bytes parent folder | download | duplicates (10)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
#!/bin/java bsh.Interpreter

source("TestHarness.bsh");

import bsh.*;

/**
	Make sure that overloaded method resolution knows whether it's looking
	for a static only or a dynamic/static method
*/

m=new MethodSelection();
// repetition here to check for obscure old bug
assert( m.staticVsDynamic1( new Object() ) == Object.class );
assert( m.staticVsDynamic1( new Object() ) == Object.class );
assert( m.staticVsDynamic1( new String() ) == String.class );
assert( m.staticVsDynamic1( new String() ) == String.class );

assert( MethodSelection.staticVsDynamic1( new Object() ) == Object.class );
assert( MethodSelection.staticVsDynamic1( new Object() ) == Object.class );

// the best match is the static String form... javac would error on this
// rather than select the overloaded form, so so will we...
assert( isEvalError("MethodSelection.staticVsDynamic1( new String() )"  ) );

al=new ArrayList();
al.add("foo");
assert( isEvalError("ArrayList.add(\"foo\")") );
assert( isEvalError("java.util.ArrayList.add(\"foo\")"));

// various null argument problems that used to throw internal errors should now
// just be eval errors
try { 
	eval("new Character(null)");
} catch ( EvalError e ) {
	// as long as it's not an InterpreterError or worse
}
try { 
	eval("new java.net.URL(null, new Integer(0))");
} catch ( EvalError e ) {
	// as long as it's not an InterpreterError or worse
}

// should add our own test, but for now try a real situation...
if ( Capabilities.classExists("java.util.Map") )
{
	map = new HashMap();
	umap = Collections.unmodifiableMap( map);
	try {
		umap.put("foo", "bar");
	} catch ( UnsupportedOperationException e ) {
		flag();
	}
	assert( flag() == 1 );
}
else
	warning("Can't test method selection on package private impl...");

/*
	Can we see a concrete public method in a package-private abstract 
	base class?  The method is *not* be overridden in the public concrete
	class... 
	This seems to be a Java core reflection deficiency... There appears to
	be no wy to access such a method.
*/
mpc=new mypackage.Concrete();
if ( isEvalError("mpc.visible()") )
	warning("Java Reflection bug: can't access package private abstract public method");

complete();