json-tck/src/main/java/org/netbeans/html/json/tck/KnockoutTCK.java
author Jaroslav Tulach <jtulach@netbeans.org>
Tue, 26 Aug 2014 18:13:30 +0200
changeset 838 bdc3d696dd4a
parent 790 json-tck/src/main/java/org/apidesign/html/json/tck/KnockoutTCK.java@30f20d9c0986
child 867 6ed4df4c1e29
child 882 0faee341d5b5
permissions -rw-r--r--
During the API review process (bug 246133) the reviewers decided that in order to include html4j to NetBeans Platform, we need to stop using org.apidesign namespace and switch to NetBeans one. Repackaging all SPI packages into org.netbeans.html.smthng.spi.
jaroslav@34
     1
/**
jaroslav@358
     2
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER.
jaroslav@34
     3
 *
jaroslav@551
     4
 * Copyright 2013-2014 Oracle and/or its affiliates. All rights reserved.
jaroslav@34
     5
 *
jaroslav@358
     6
 * Oracle and Java are registered trademarks of Oracle and/or its affiliates.
jaroslav@358
     7
 * Other names may be trademarks of their respective owners.
jaroslav@34
     8
 *
jaroslav@358
     9
 * The contents of this file are subject to the terms of either the GNU
jaroslav@358
    10
 * General Public License Version 2 only ("GPL") or the Common
jaroslav@358
    11
 * Development and Distribution License("CDDL") (collectively, the
jaroslav@358
    12
 * "License"). You may not use this file except in compliance with the
jaroslav@358
    13
 * License. You can obtain a copy of the License at
jaroslav@358
    14
 * http://www.netbeans.org/cddl-gplv2.html
jaroslav@358
    15
 * or nbbuild/licenses/CDDL-GPL-2-CP. See the License for the
jaroslav@358
    16
 * specific language governing permissions and limitations under the
jaroslav@358
    17
 * License.  When distributing the software, include this License Header
jaroslav@358
    18
 * Notice in each file and include the License file at
jaroslav@358
    19
 * nbbuild/licenses/CDDL-GPL-2-CP.  Oracle designates this
jaroslav@358
    20
 * particular file as subject to the "Classpath" exception as provided
jaroslav@358
    21
 * by Oracle in the GPL Version 2 section of the License file that
jaroslav@358
    22
 * accompanied this code. If applicable, add the following below the
jaroslav@358
    23
 * License Header, with the fields enclosed by brackets [] replaced by
jaroslav@358
    24
 * your own identifying information:
jaroslav@358
    25
 * "Portions Copyrighted [year] [name of copyright owner]"
jaroslav@358
    26
 *
jaroslav@358
    27
 * Contributor(s):
jaroslav@358
    28
 *
jaroslav@358
    29
 * The Original Software is NetBeans. The Initial Developer of the Original
jaroslav@551
    30
 * Software is Oracle. Portions Copyright 2013-2014 Oracle. All Rights Reserved.
jaroslav@358
    31
 *
jaroslav@358
    32
 * If you wish your version of this file to be governed by only the CDDL
jaroslav@358
    33
 * or only the GPL Version 2, indicate your decision by adding
jaroslav@358
    34
 * "[Contributor] elects to include this software in this distribution
jaroslav@358
    35
 * under the [CDDL or GPL Version 2] license." If you do not indicate a
jaroslav@358
    36
 * single choice of license, a recipient has the option to distribute
jaroslav@358
    37
 * your version of this file under either the CDDL, the GPL Version 2 or
jaroslav@358
    38
 * to extend the choice of license to its licensees as provided above.
jaroslav@358
    39
 * However, if you add GPL Version 2 code and therefore, elected the GPL
jaroslav@358
    40
 * Version 2 license, then the option applies only if the new code is
jaroslav@358
    41
 * made subject to such option by the copyright holder.
jaroslav@34
    42
 */
jtulach@838
    43
package org.netbeans.html.json.tck;
jaroslav@34
    44
jaroslav@138
    45
import java.net.URI;
jaroslav@35
    46
import java.util.Map;
jaroslav@110
    47
import net.java.html.BrwsrCtx;
jaroslav@34
    48
import net.java.html.json.tests.ConvertTypesTest;
jaroslav@393
    49
import net.java.html.json.tests.JSONTest;
jaroslav@34
    50
import net.java.html.json.tests.KnockoutTest;
jaroslav@585
    51
import net.java.html.json.tests.MinesTest;
jaroslav@240
    52
import net.java.html.json.tests.OperationsTest;
jaroslav@393
    53
import net.java.html.json.tests.Utils;
jaroslav@247
    54
import net.java.html.json.tests.WebSocketTest;
jtulach@838
    55
import org.netbeans.html.context.spi.Contexts.Builder;
jaroslav@34
    56
import org.openide.util.lookup.ServiceProvider;
jaroslav@34
    57
jaroslav@34
    58
/** Entry point for providers of different HTML binding technologies (like
jaroslav@151
    59
 * Knockout.js in JavaFX's WebView). Sample usage:
jaroslav@546
    60
 * 
jaroslav@546
    61
<pre>
jaroslav@34
    62
{@link ServiceProvider @ServiceProvider}(service = KnockoutTCK.class)
jaroslav@154
    63
public final class MyKnockoutBindingTest extends KnockoutTCK {
jaroslav@34
    64
    {@link Override @Override}
jaroslav@154
    65
    protected BrwsrCtx createContext() {
jaroslav@534
    66
        // use {@link Builder}.{@link Builder#build() build}();
jaroslav@34
    67
    }
jaroslav@34
    68
jaroslav@547
    69
    {@code @}{@link org.testng.annotations.Factory} public static Object[] create() {
jaroslav@45
    70
        return VMTest.newTests().withClasses({@link KnockoutTCK#testClasses}()).build();
jaroslav@34
    71
    }
jaroslav@34
    72
}
jaroslav@34
    73
 * </pre>
jaroslav@34
    74
 *
jtulach@790
    75
 * @author Jaroslav Tulach
jaroslav@34
    76
 */
jaroslav@34
    77
public abstract class KnockoutTCK {
jaroslav@34
    78
    protected KnockoutTCK() {
jaroslav@393
    79
        Utils.registerTCK(this);
jaroslav@34
    80
    }
jaroslav@34
    81
    
jaroslav@34
    82
    /** Implement to create new context for the test. 
jaroslav@534
    83
     * Use {@link Builder} to set context for your technology up.
jaroslav@534
    84
     * @return the final context for the test
jaroslav@34
    85
     */
jaroslav@110
    86
    public abstract BrwsrCtx createContext();
jaroslav@35
    87
    
jaroslav@35
    88
    /** Create a JSON object as seen by the technology
jaroslav@35
    89
     * @param values mapping from names to values of properties
jaroslav@534
    90
     * @return the JSON object with filled in values
jaroslav@35
    91
     */
jaroslav@35
    92
    public abstract Object createJSON(Map<String,Object> values);
jaroslav@36
    93
jaroslav@36
    94
    /** Executes script in the context of current window
jaroslav@36
    95
     * 
jaroslav@36
    96
     * @param script the JavaScript code to execute
jaroslav@36
    97
     * @param arguments arguments sent to the script (can be referenced as <code>arguments[0]</code>)
jaroslav@36
    98
     * @return the output of the execution
jaroslav@36
    99
     */
jaroslav@36
   100
    public abstract Object executeScript(String script, Object[] arguments);
jaroslav@138
   101
jaroslav@138
   102
    /** Creates a URL which later returns content with given
jaroslav@138
   103
     * <code>mimeType</code> and <code>content</code>. The 
jaroslav@138
   104
     * content may be processed by the provided <code>parameters</code>.
jaroslav@138
   105
     * 
jaroslav@534
   106
     * @param content what should be available on the URL. Can contain <code>$0</code>
jaroslav@534
   107
     *   <code>$1</code> to reference <code>parameters</code> by their position
jaroslav@534
   108
     * @param mimeType the type of the resource
jaroslav@534
   109
     * @param parameters names of parameters as reference by <code>content</code>
jaroslav@534
   110
     * @return URI the test can connect to to obtain the (processed) content
jaroslav@138
   111
     */
jaroslav@138
   112
    public abstract URI prepareURL(String content, String mimeType, String[] parameters);
jaroslav@34
   113
    
jaroslav@137
   114
    /** Gives you list of classes included in the TCK. Their test methods
jaroslav@137
   115
     * are annotated by {@link KOTest} annotation. The methods are public
jaroslav@137
   116
     * instance methods that take no arguments.
jaroslav@34
   117
     * 
jaroslav@424
   118
     * @return classes with methods annotated by {@link KOTest} annotation
jaroslav@34
   119
     */
jaroslav@34
   120
    protected static Class<?>[] testClasses() {
jaroslav@34
   121
        return new Class[] { 
jaroslav@34
   122
            ConvertTypesTest.class,
jaroslav@34
   123
            JSONTest.class,
jaroslav@240
   124
            KnockoutTest.class,
jaroslav@585
   125
            MinesTest.class,
jaroslav@247
   126
            OperationsTest.class,
jaroslav@247
   127
            WebSocketTest.class
jaroslav@34
   128
        };
jaroslav@34
   129
    }
jaroslav@36
   130
jaroslav@260
   131
    /** Some implementations cannot fully support web sockets and fail.
jaroslav@260
   132
     * 
jaroslav@260
   133
     * @return true, if UnsupportedOperationException reported from a web
jaroslav@260
   134
     *    socket open operation is acceptable reply
jaroslav@260
   135
     */
jaroslav@260
   136
    public boolean canFailWebSocketTest() {
jaroslav@260
   137
        return false;
jaroslav@260
   138
    }
jaroslav@260
   139
jaroslav@138
   140
jaroslav@34
   141
}