Package org.apache.spark.sql.api.java

Source Code of org.apache.spark.sql.api.java.JavaAPISuite

/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements.  See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You under the Apache License, Version 2.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.apache.org/licenses/LICENSE-2.0
*
* 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 org.apache.spark.sql.api.java;

import java.io.Serializable;

import org.apache.spark.sql.api.java.UDF1;
import org.junit.After;
import org.junit.Assert;
import org.junit.Before;
import org.junit.Test;
import org.junit.runners.Suite;
import org.junit.runner.RunWith;

import org.apache.spark.api.java.JavaSparkContext;

// The test suite itself is Serializable so that anonymous Function implementations can be
// serialized, as an alternative to converting these anonymous classes to static inner classes;
// see http://stackoverflow.com/questions/758570/.
public class JavaAPISuite implements Serializable {
  private transient JavaSparkContext sc;
  private transient JavaSQLContext sqlContext;

  @Before
  public void setUp() {
    sc = new JavaSparkContext("local", "JavaAPISuite");
    sqlContext = new JavaSQLContext(sc);
  }

  @After
  public void tearDown() {
    sc.stop();
    sc = null;
  }

  @SuppressWarnings("unchecked")
  @Test
  public void udf1Test() {
    // With Java 8 lambdas:
    // sqlContext.registerFunction(
    //   "stringLengthTest", (String str) -> str.length(), DataType.IntegerType);

    sqlContext.registerFunction("stringLengthTest", new UDF1<String, Integer>() {
      @Override
      public Integer call(String str) throws Exception {
        return str.length();
      }
    }, DataType.IntegerType);

    // TODO: Why do we need this cast?
    Row result = (Row) sqlContext.sql("SELECT stringLengthTest('test')").first();
    assert(result.getInt(0) == 4);
  }

  @SuppressWarnings("unchecked")
  @Test
  public void udf2Test() {
    // With Java 8 lambdas:
    // sqlContext.registerFunction(
    //   "stringLengthTest",
    //   (String str1, String str2) -> str1.length() + str2.length,
    //   DataType.IntegerType);

    sqlContext.registerFunction("stringLengthTest", new UDF2<String, String, Integer>() {
      @Override
      public Integer call(String str1, String str2) throws Exception {
        return str1.length() + str2.length();
      }
    }, DataType.IntegerType);

    // TODO: Why do we need this cast?
    Row result = (Row) sqlContext.sql("SELECT stringLengthTest('test', 'test2')").first();
    assert(result.getInt(0) == 9);
  }
}
TOP

Related Classes of org.apache.spark.sql.api.java.JavaAPISuite

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.