All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.nflabs.zeppelin.driver.mock.MockDriverConnection Maven / Gradle / Ivy

Go to download

Zengine is java framework for data analysis on Hadoop. see http://nflabs.github.io/zeppelin/#/zengine

There is a newer version: 0.3.3
Show newest version
package com.nflabs.zeppelin.driver.mock;

import java.net.URI;
import java.util.LinkedList;
import java.util.List;
import java.util.Map;

import org.apache.log4j.Logger;

import com.nflabs.zeppelin.driver.ZeppelinConnection;
import com.nflabs.zeppelin.driver.ZeppelinDriverException;
import com.nflabs.zeppelin.result.Result;

public class MockDriverConnection implements ZeppelinConnection{
	Logger logger = Logger.getLogger(MockDriverConnection.class);
	
	private Map queries;
	private Map views;
	private Map tables;
	private List loadedResources;

	public MockDriverConnection(Map queries, Map views, Map tables, List loadedResources) {
		this.queries = queries;
		this.views = views;
		this.tables = tables;
		this.loadedResources = loadedResources;
	}

	@Override
	public boolean isConnected() throws ZeppelinDriverException {
		return true;
	}

	@Override
	public void close() throws ZeppelinDriverException {
	}

	@Override
	public void abort() throws ZeppelinDriverException {
	}

	@Override
	public Result query(String query) throws ZeppelinDriverException {
		logger.info("TestDriver query("+query+")");
		Result r = queries.get(query);
		if (r==null) {
			return new Result();
		} else {
			return r;
		}
	}

	@Override
	public Result addResource(URI resourceLocation)
			throws ZeppelinDriverException {
		loadedResources.add(resourceLocation);
		return null;
	}

	@Override
	public Result select(String tableName, int limit)
			throws ZeppelinDriverException {
		logger.info("select "+tableName);
		if (views.containsKey(tableName)) {
			return views.get(tableName);
		} else if (tables.containsKey(tableName)) {
			return tables.get(tableName);
		} else {
			return query("select * from "+tableName);
		}
	}

	@Override
	public Result createViewFromQuery(String viewName, String query)
			throws ZeppelinDriverException {
		logger.info("createView "+viewName);
		views.put(viewName, queries.get(query));
		return new Result();
	}

	@Override
	public Result createTableFromQuery(String tableName, String query)
			throws ZeppelinDriverException {
		logger.info("createTable "+tableName);
		tables.put(tableName, queries.get(query));
		return new Result();
	}

	@Override
	public Result dropView(String viewName) throws ZeppelinDriverException {
		logger.info("dropTable "+viewName);
		views.remove(viewName);
		return new Result();
	}

	@Override
	public Result dropTable(String tableName) throws ZeppelinDriverException {
		logger.info("dropTable "+tableName);
		tables.remove(tableName);
		return new Result();
	}

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy