FileDocCategorySizeDatePackage
TestSuiteReference.javaAPI DocAndroid 1.5 API2243Wed May 06 22:41:10 BST 2009com.android.ide.eclipse.adt.launch.junit.runtime

TestSuiteReference.java

/*
 * Copyright (C) 2009 The Android Open Source Project
 *
 * Licensed under the Eclipse Public License, Version 1.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *      http://www.eclipse.org/org/documents/epl-v10.php
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

package com.android.ide.eclipse.adt.launch.junit.runtime;

import org.eclipse.jdt.internal.junit.runner.IVisitsTestTrees;

import java.util.List;
import java.util.ArrayList;

/**
 * Reference for an Android test suite aka class.
 */
@SuppressWarnings("restriction")
class TestSuiteReference extends AndroidTestReference {

    private final String mClassName;
    private List<TestCaseReference> mTests;

    /**
     * Creates a TestSuiteReference
     * 
     * @param className the fully qualified name of the test class
     */
    TestSuiteReference(String className) {
         mClassName = className; 
         mTests = new ArrayList<TestCaseReference>();
    }

    /**
     * Returns a count of the number of test cases included in this suite. 
     */
    public int countTestCases() {
        return mTests.size();
    }

    /**
     * Sends test identifier and test count information for this test class, and all its included
     * test methods.
     * 
     * @param notified the {@link IVisitsTestTrees} to send test info too
     */
    public void sendTree(IVisitsTestTrees notified) {
        notified.visitTreeEntry(getIdentifier(), true, countTestCases());
        for (TestCaseReference ref : mTests) {
            ref.sendTree(notified);
        }
    }

    /**
     * Return the name of this test class.
     */
    public String getName() {
        return mClassName;
    }

    /**
     * Adds a test method to this suite.
     * 
     * @param testRef the {@link TestCaseReference} to add
     */
    void addTest(TestCaseReference testRef) {
        mTests.add(testRef);
    }
}