rt/vmtest/src/main/java/org/apidesign/bck2brwsr/vmtest/VMTest.java
author Jaroslav Tulach <jaroslav.tulach@apidesign.org>
Wed, 24 Apr 2013 20:22:19 +0200
branchmodel
changeset 1018 49eb825c87b7
parent 797 7b5a053c6763
child 1050 6415da7d00b6
permissions -rw-r--r--
javaquery.api is now implementation of net.java.html.json API
jaroslav@273
     1
/**
jaroslav@273
     2
 * Back 2 Browser Bytecode Translator
jaroslav@273
     3
 * Copyright (C) 2012 Jaroslav Tulach <jaroslav.tulach@apidesign.org>
jaroslav@273
     4
 *
jaroslav@273
     5
 * This program is free software: you can redistribute it and/or modify
jaroslav@273
     6
 * it under the terms of the GNU General Public License as published by
jaroslav@273
     7
 * the Free Software Foundation, version 2 of the License.
jaroslav@273
     8
 *
jaroslav@273
     9
 * This program is distributed in the hope that it will be useful,
jaroslav@273
    10
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
jaroslav@273
    11
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
jaroslav@273
    12
 * GNU General Public License for more details.
jaroslav@273
    13
 *
jaroslav@273
    14
 * You should have received a copy of the GNU General Public License
jaroslav@273
    15
 * along with this program. Look for COPYING file in the top folder.
jaroslav@273
    16
 * If not, see http://opensource.org/licenses/GPL-2.0.
jaroslav@273
    17
 */
jaroslav@346
    18
package org.apidesign.bck2brwsr.vmtest;
jaroslav@273
    19
jaroslav@797
    20
import org.apidesign.bck2brwsr.launcher.Launcher;
jaroslav@372
    21
import org.apidesign.bck2brwsr.vmtest.impl.CompareCase;
jaroslav@273
    22
import org.testng.annotations.Factory;
jaroslav@273
    23
jaroslav@797
    24
/** A TestNG {@link Factory} that seeks for {@link Compare} and {@link BrwsrTest} annotations
jaroslav@797
    25
 * in provided class and builds set of tests that verify the functionality of <b>Bck2Brwsr</b> 
jaroslav@797
    26
 * based system. Use as:
jaroslav@797
    27
 * <pre>
jaroslav@273
    28
 * {@code @}{@link Factory} public static create() {
jaroslav@797
    29
 *   return @{link VMTest}.{@link #create(java.lang.Class) create}(YourClass.class);
jaroslav@273
    30
 * }</pre>
jaroslav@797
    31
 * where <code>YourClass</code> contains methods annotated with
jaroslav@797
    32
 * {@link Compare} and {@link BrwsrTest} annotations.
jaroslav@797
    33
 * 
jaroslav@273
    34
 * @author Jaroslav Tulach <jtulach@netbeans.org>
jaroslav@273
    35
 */
jaroslav@372
    36
public final class VMTest {
jaroslav@797
    37
    private VMTest() {
jaroslav@797
    38
    }
jaroslav@797
    39
    
jaroslav@797
    40
    /** Inspects <code>clazz</code> and for each method annotated by
jaroslav@797
    41
     * {@link Compare} or {@link BrwsrTest} creates
jaroslav@797
    42
     * instances of tests. 
jaroslav@797
    43
     * <p>
jaroslav@797
    44
     * Each {@link Compare} instance runs the test in different virtual
jaroslav@346
    45
     * machine and at the end they compare the results.
jaroslav@797
    46
     * <p>
jaroslav@797
    47
     * Each {@link BrwsrTest} annotated method is executed once in {@link Launcher started
jaroslav@797
    48
     * browser}.
jaroslav@346
    49
     * 
jaroslav@1018
    50
     * @param clazz the class (or classes) to inspect
jaroslav@346
    51
     * @return the set of created tests
jaroslav@346
    52
     */
jaroslav@1018
    53
    public static Object[] create(Class... clazz) {
jaroslav@372
    54
        return CompareCase.create(clazz);
jaroslav@346
    55
    }
jaroslav@273
    56
}