FileDocCategorySizeDatePackage
InstrumentationCoreTestRunner.javaAPI DocAndroid 1.5 API6636Wed May 06 22:42:02 BST 2009android.test

InstrumentationCoreTestRunner

public class InstrumentationCoreTestRunner extends InstrumentationTestRunner
This test runner extends the default InstrumentationTestRunner. It overrides the {@code onCreate(Bundle)} method and sets the system properties necessary for many core tests to run. This is needed because there are some core tests that need writing access to the file system. We also need to set the harness Thread's context ClassLoader. Otherwise some classes and resources will not be found. Finally, we add a means to free memory allocated by a TestCase after its execution.
hide

Fields Summary
private static final String
TAG
private boolean
singleTest
Constructors Summary
Methods Summary
protected AndroidTestRunnergetAndroidTestRunner()

        AndroidTestRunner runner = super.getAndroidTestRunner();

        runner.addTestListener(new TestListener() {
            private Class<?> lastClass;
            
            public void startTest(Test test) {
                if (test.getClass() != lastClass) {
                    printMemory(test.getClass());
                }
                
                Thread.currentThread().setContextClassLoader(
                        test.getClass().getClassLoader());
            }
            
            public void endTest(Test test) {
                if (test instanceof TestCase) {
                    if (lastClass == null) {
                        lastClass = test.getClass();
                    } else {
                        if (test.getClass() != lastClass) {
                            cleanup(lastClass);
                            lastClass = test.getClass();
                        }
                    }
                }
            }
            
            public void addError(Test test, Throwable t) {
            }
            
            public void addFailure(Test test, AssertionFailedError t) {
            }
            
            /**
             * Dumps some memory info.
             */
            private void printMemory(Class<? extends Test> testClass) {
                Runtime runtime = Runtime.getRuntime();

                long total = runtime.totalMemory();
                long free = runtime.freeMemory();
                long used = total - free;
                
                Log.d(TAG, "Total memory  : " + total);
                Log.d(TAG, "Used memory   : " + used);
                Log.d(TAG, "Free memory   : " + free);
                Log.d(TAG, "Now executing : " + testClass.getName());
            }

            /**
             * Nulls all static reference fields in the given test class. This
             * method helps us with those test classes that don't have an
             * explicit tearDown() method. Normally the garbage collector should
             * take care of everything, but since JUnit keeps references to all
             * test cases, a little help might be a good idea.
             */
            private void cleanup(Class<?> clazz) {
                if (clazz != TestCase.class) {
                    Field[] fields = clazz.getDeclaredFields();
                    for (int i = 0; i < fields.length; i++) {
                        Field f = fields[i];
                        if (!f.getType().isPrimitive() &&
                                Modifier.isStatic(f.getModifiers())) {
                            try {
                                f.setAccessible(true);
                                f.set(null, null);
                            } catch (Exception ignored) {
                                // Nothing we can do about it.
                            }
                        }
                    }
                    
                    // don't cleanup the superclass for now
                    //cleanup(clazz.getSuperclass());
                }
            }
            
        });
        
        return runner;
    
java.util.ListgetBuilderRequirements()

        List<Predicate<TestMethod>> builderRequirements =
                super.getBuilderRequirements();
        Predicate<TestMethod> brokenTestPredicate =
                Predicates.not(new HasAnnotation(BrokenTest.class));
        builderRequirements.add(brokenTestPredicate);
        if (!singleTest) {
            Predicate<TestMethod> sideEffectPredicate =
                    Predicates.not(new HasAnnotation(SideEffect.class));
            builderRequirements.add(sideEffectPredicate);
        }
        return builderRequirements;
    
public voidonCreate(android.os.Bundle arguments)

    
    
        
        // We might want to move this to /sdcard, if is is mounted/writable.
        File cacheDir = getTargetContext().getCacheDir();

        System.setProperty("user.language", "en");
        System.setProperty("user.region", "US");
        
        System.setProperty("java.home", cacheDir.getAbsolutePath());
        System.setProperty("user.home", cacheDir.getAbsolutePath());
        System.setProperty("java.io.tmpdir", cacheDir.getAbsolutePath());
        System.setProperty("javax.net.ssl.trustStore",
                "/etc/security/cacerts.bks");
        
        if (arguments != null) {
            String classArg = arguments.getString(ARGUMENT_TEST_CLASS);
            singleTest = classArg != null && classArg.contains("#"); 
        }
        
        super.onCreate(arguments);