You are viewing a plain text version of this content. The canonical link for it is here.
Posted to commits@ambari.apache.org by ni...@apache.org on 2016/12/28 09:33:01 UTC

[01/23] ambari git commit: AMBARI-19302 : removed contrib/views/hive folder and made necessary changes in pom.xml files (nitirajrathore)

Repository: ambari
Updated Branches:
  refs/heads/branch-2.5 ff9eb72a9 -> c0f9621f2


http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/resources/upload/OpenCSVTest.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/resources/upload/OpenCSVTest.java b/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/resources/upload/OpenCSVTest.java
deleted file mode 100644
index 0bdf5cf..0000000
--- a/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/resources/upload/OpenCSVTest.java
+++ /dev/null
@@ -1,259 +0,0 @@
-/**
- * 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
- * <p/>
- * http://www.apache.org/licenses/LICENSE-2.0
- * <p/>
- * 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.ambari.view.hive.resources.upload;
-
-import com.opencsv.CSVParser;
-import com.opencsv.CSVReader;
-import com.opencsv.CSVWriter;
-import org.junit.Assert;
-import org.junit.Test;
-
-import java.io.IOException;
-import java.io.StringReader;
-import java.io.StringWriter;
-
-public class OpenCSVTest {
-
-  /**
-   * no exception in creating csvParser with emtpy stream
-   *
-   * @throws IOException
-   */
-  @Test
-  public void testEmptyStream() throws Exception {
-    String csv = "";
-
-    CSVParser jp = new CSVParser();
-    String[] columns = jp.parseLine(csv);
-    Assert.assertEquals("Should detect one column.", 1, columns.length);
-    Assert.assertEquals("Should detect one column with empty value.", new String[]{""}, columns);
-  }
-
-  /**
-   * in case of csv an empty line is still considered as row
-   *
-   * @throws IOException
-   */
-  @Test
-  public void testEmptyRow() throws Exception {
-    String csv = "       ";
-    CSVParser jp = new CSVParser();
-
-    String[] columns = jp.parseLine(csv);
-    Assert.assertEquals("One column not detected.", 1, columns.length);
-    Assert.assertArrayEquals("Row should not be empty", new String[]{"       "}, columns);
-  }
-
-  @Test
-  public void testParse1Row() throws Exception {
-    String csv = "value1,c,10,10.1";
-
-    String[] cols = csv.split(",");
-    CSVParser jp = new CSVParser();
-    String[] columns = jp.parseLine(csv);
-    Assert.assertEquals("4 columns not detect", 4, columns.length);
-    Assert.assertArrayEquals("Row not equal!", cols, columns);
-  }
-
-  @Test
-  public void testParseMultipleRow() throws Exception {
-
-    String csv = "value1,c,10,10.1\n" +
-      "value2,c2,102,true";
-
-    try(
-      StringReader sr = new StringReader(csv);
-      CSVReader csvReader = new CSVReader(sr,',','"','\\');
-    ) {
-      String[] row1 = csvReader.readNext();
-      String[] row2 = csvReader.readNext();
-
-      Assert.assertArrayEquals("Failed to match 1st row!",new String[]{"value1", "c", "10", "10.1"}, row1);
-
-      Assert.assertArrayEquals("Failed to match 2nd row!",new String[]{"value2", "c2", "102", "true"}, row2);
-    }
-  }
-
-  @Test
-  public void testParseCustomSeparator() throws Exception {
-
-    String csv = "value1#c#10#10.1\n" +
-      "value2#c2#102#true";
-
-    try(
-      StringReader sr = new StringReader(csv);
-      CSVReader csvReader = new CSVReader(sr,'#','"','\\');
-    ) {
-      String[] row1 = csvReader.readNext();
-      String[] row2 = csvReader.readNext();
-
-      Assert.assertArrayEquals("Failed to match 1st row!",new String[]{"value1", "c", "10", "10.1"}, row1);
-
-      Assert.assertArrayEquals("Failed to match 2nd row!",new String[]{"value2", "c2", "102", "true"}, row2);
-    }
-  }
-
-
-  @Test
-  public void testParseCustomSeparatorAndQuote() throws Exception {
-
-    String csv = "\"valu#e1\"#c#10#10.1\n" +
-      "value2#c2#102#true";
-
-    try(
-      StringReader sr = new StringReader(csv);
-      CSVReader csvReader = new CSVReader(sr,'#','"','\\');
-    ) {
-      String[] row1 = csvReader.readNext();
-      String[] row2 = csvReader.readNext();
-
-      Assert.assertArrayEquals("Failed to match 1st row!",new String[]{"valu#e1", "c", "10", "10.1"}, row1);
-
-      Assert.assertArrayEquals("Failed to match 2nd row!",new String[]{"value2", "c2", "102", "true"}, row2);
-    }
-  }
-
-  @Test
-  public void testMultipleEscape() throws Exception {
-
-    String csv = "BBAABBKMAABB";
-
-    try(
-      StringReader sr = new StringReader(csv);
-      CSVReader csvReader = new CSVReader(sr,'M','"','B');
-    ) {
-      String[] row1 = csvReader.readNext();
-      Assert.assertArrayEquals("Failed to match 1st row!",new String[]{"AABK", "AAB"}, row1);
-    }
-  }
-
-  @Test
-  public void testParseCustomSeparatorAndCustomQuote() throws Exception {
-
-    String csv = "\'valu#e1\'#c#10#10.1\n" +
-      "value2#c2#102#true";
-
-    try(
-      StringReader sr = new StringReader(csv);
-      CSVReader csvReader = new CSVReader(sr,'#','\'','\\');
-    ) {
-      String[] row1 = csvReader.readNext();
-      String[] row2 = csvReader.readNext();
-      String[] row3 = csvReader.readNext();
-
-      Assert.assertArrayEquals("Failed to match 1st row!",new String[]{"valu#e1", "c", "10", "10.1"}, row1);
-
-      Assert.assertArrayEquals("Failed to match 2nd row!",new String[]{"value2", "c2", "102", "true"}, row2);
-
-      Assert.assertArrayEquals("should match Null", null, row3);
-    }
-  }
-
-  @Test
-  public void testWriter() throws Exception {
-
-    String csv = "\'valu#e1\'#c#10#10.1\n" +
-      "value2#c2#102#true";
-
-    try(
-      StringReader sr = new StringReader(csv);
-      CSVReader csvReader = new CSVReader(sr,'#','\'','\\');
-      StringWriter sw = new StringWriter();
-      CSVWriter csvWriter = new CSVWriter(sw);
-    ) {
-      String[] row1 = csvReader.readNext();
-      csvWriter.writeNext(row1);
-      String[] row2 = csvReader.readNext();
-      csvWriter.writeNext(row2);
-
-      Assert.assertEquals("CSVWriter failed.","\"valu#e1\",\"c\",\"10\",\"10.1\"\n" +
-        "\"value2\",\"c2\",\"102\",\"true\"\n", sw.getBuffer().toString());
-    }
-  }
-
-  @Test
-  public void testWriterCustomSeparator() throws Exception {
-
-    String csv = "\'valu#e1\'#c#10#10.1\n" +
-      "value2#c2#102#true";
-
-    try(
-      StringReader sr = new StringReader(csv);
-      CSVReader csvReader = new CSVReader(sr,'#','\'','\\');
-      StringWriter sw = new StringWriter();
-      CSVWriter csvWriter = new CSVWriter(sw,'$');
-    ) {
-      String[] row1 = csvReader.readNext();
-      csvWriter.writeNext(row1);
-      String[] row2 = csvReader.readNext();
-      csvWriter.writeNext(row2);
-
-      Assert.assertEquals("CSVWriter failed.","\"valu#e1\"$\"c\"$\"10\"$\"10.1\"\n" +
-        "\"value2\"$\"c2\"$\"102\"$\"true\"\n", sw.getBuffer().toString());
-    }
-  }
-
-  @Test
-  public void testWriterCustomSeparatorAndEnline() throws Exception {
-
-    String csv = "value1,c,10,10.1\n" +
-      "value2,c2,102,true";
-
-    try(
-      StringReader sr = new StringReader(csv);
-      CSVReader csvReader = new CSVReader(sr,',','\'','\\');
-      StringWriter sw = new StringWriter();
-      CSVWriter csvWriter = new CSVWriter(sw,'\002',',',"\003");
-    ) {
-      String[] row1 = csvReader.readNext();
-      csvWriter.writeNext(row1,false);
-      String[] row2 = csvReader.readNext();
-      csvWriter.writeNext(row2,false);
-
-      Assert.assertEquals("CSVWriter failed.","value1\002c\00210\00210.1\003" +
-        "value2\002c2\002102\002true\003", sw.getBuffer().toString());
-    }
-  }
-
-  @Test
-  public void testWriterQuote() throws Exception {
-
-    String csv = "val#ue1,c,10,10.1\n" +
-      "'val,ue2',c2,102,true\n" +
-      "val\002ue3,c\0033,103,false";
-
-    try(
-      StringReader sr = new StringReader(csv);
-      CSVReader csvReader = new CSVReader(sr,',','\'','\\');
-      StringWriter sw = new StringWriter();
-      CSVWriter csvWriter = new CSVWriter(sw,'\002','\'',"\003");
-    ) {
-      String[] row1 = csvReader.readNext();
-      csvWriter.writeNext(row1,false);
-      String[] row2 = csvReader.readNext();
-      csvWriter.writeNext(row2,false);
-      String[] row3 = csvReader.readNext();
-      csvWriter.writeNext(row3,false);
-
-      Assert.assertEquals("CSVWriter failed.","val#ue1\u0002c\u000210\u000210.1\u0003" +
-        "val,ue2\u0002c2\u0002102\u0002true\u0003" +
-        "'val\u0002ue3'\u0002c\u00033\u0002103\u0002false\u0003", sw.getBuffer().toString());
-    }
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/resources/upload/ParseUtilsTest.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/resources/upload/ParseUtilsTest.java b/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/resources/upload/ParseUtilsTest.java
deleted file mode 100644
index d1ce211..0000000
--- a/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/resources/upload/ParseUtilsTest.java
+++ /dev/null
@@ -1,56 +0,0 @@
-/**
- * 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
- * <p/>
- * http://www.apache.org/licenses/LICENSE-2.0
- * <p/>
- * 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.ambari.view.hive.resources.upload;
-
-import org.apache.ambari.view.hive.resources.uploads.parsers.ParseUtils;
-import org.junit.Assert;
-import org.junit.Test;
-
-public class ParseUtilsTest {
-  @Test
-  public void testDateFormats() {
-    Assert.assertTrue(ParseUtils.isDate("1970-01-01"));
-    Assert.assertTrue(ParseUtils.isDate("1970-01-01 "));
-    Assert.assertTrue(ParseUtils.isDate("0001-1-3"));
-    Assert.assertTrue(ParseUtils.isDate("1996-1-03"));
-    Assert.assertTrue(ParseUtils.isDate("1996-01-3"));
-    Assert.assertTrue(ParseUtils.isDate("1996-10-3"));
-    Assert.assertFalse(ParseUtils.isDate("1970-01-01 01:01:01"));
-    Assert.assertFalse(ParseUtils.isDate("1970-01-01 23:59:59.999999"));
-    Assert.assertFalse(ParseUtils.isDate("1970/01/01"));
-    Assert.assertFalse(ParseUtils.isDate("01-01-1970"));
-    Assert.assertFalse(ParseUtils.isDate("1970-13-01"));
-    Assert.assertFalse(ParseUtils.isDate("1970-01-32"));
-    Assert.assertFalse(ParseUtils.isDate("01/01/1970"));
-    Assert.assertFalse(ParseUtils.isDate("001-1-3"));
-  }
-
-  @Test
-  public void testTimestampFormats() {
-    Assert.assertFalse(ParseUtils.isTimeStamp("1999-11-30"));
-    Assert.assertFalse(ParseUtils.isTimeStamp("1999-12-31 23:59"));
-    Assert.assertTrue(ParseUtils.isTimeStamp("1999-12-31 23:59:59"));
-    Assert.assertTrue(ParseUtils.isTimeStamp("1999-12-31 23:59:59.100"));
-    Assert.assertTrue(ParseUtils.isTimeStamp("1999-12-31 23:59:59.999999"));
-    Assert.assertTrue(ParseUtils.isTimeStamp("1999-12-31 23:59:59.99999999"));
-    Assert.assertTrue(ParseUtils.isTimeStamp("1999-12-31 23:59:59.999999999"));
-    Assert.assertTrue(ParseUtils.isTimeStamp("1999-10-31 23:59:59.999999999"));
-    Assert.assertFalse(ParseUtils.isTimeStamp("1999-12-31 23:59:59.9999999999"));
-    Assert.assertFalse(ParseUtils.isTimeStamp("1999/12/31 23:59:59.9999999999"));
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/resources/upload/QueryGeneratorTest.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/resources/upload/QueryGeneratorTest.java b/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/resources/upload/QueryGeneratorTest.java
deleted file mode 100644
index 4c4a03a..0000000
--- a/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/resources/upload/QueryGeneratorTest.java
+++ /dev/null
@@ -1,108 +0,0 @@
-/**
- * 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
- * <p/>
- * http://www.apache.org/licenses/LICENSE-2.0
- * <p/>
- * 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.ambari.view.hive.resources.upload;
-
-import org.apache.ambari.view.hive.client.ColumnDescription;
-import org.apache.ambari.view.hive.resources.uploads.ColumnDescriptionImpl;
-import org.apache.ambari.view.hive.resources.uploads.HiveFileType;
-import org.apache.ambari.view.hive.resources.uploads.query.DeleteQueryInput;
-import org.apache.ambari.view.hive.resources.uploads.query.InsertFromQueryInput;
-import org.apache.ambari.view.hive.resources.uploads.query.QueryGenerator;
-import org.apache.ambari.view.hive.resources.uploads.query.RowFormat;
-import org.apache.ambari.view.hive.resources.uploads.query.TableInfo;
-import org.junit.Assert;
-import org.junit.Test;
-
-import java.util.ArrayList;
-import java.util.List;
-
-public class QueryGeneratorTest {
-  @Test
-  public void testCreateTextFile() {
-
-    List<ColumnDescriptionImpl> cdl = new ArrayList<>(4);
-    cdl.add(new ColumnDescriptionImpl("col1", ColumnDescription.DataTypes.CHAR.toString(), 0, 10));
-    cdl.add(new ColumnDescriptionImpl("col2", ColumnDescription.DataTypes.STRING.toString(), 1));
-    cdl.add(new ColumnDescriptionImpl("col3", ColumnDescription.DataTypes.DECIMAL.toString(), 2, 10, 5));
-    cdl.add(new ColumnDescriptionImpl("col4", ColumnDescription.DataTypes.VARCHAR.toString(), 3, 40));
-    cdl.add(new ColumnDescriptionImpl("col5", ColumnDescription.DataTypes.INT.toString(), 4));
-
-    TableInfo ti = new TableInfo("databaseName", "tableName", cdl, HiveFileType.TEXTFILE, new RowFormat(',', '\\'));
-
-    QueryGenerator qg = new QueryGenerator();
-    Assert.assertEquals("Create query for text file not correct ","CREATE TABLE tableName (col1 CHAR(10), col2 STRING," +
-      " col3 DECIMAL(10,5), col4 VARCHAR(40), col5 INT) ROW FORMAT DELIMITED FIELDS TERMINATED BY ','" +
-      " ESCAPED BY '\\\\' STORED AS TEXTFILE;",qg.generateCreateQuery(ti));
-  }
-
-  @Test
-  public void testCreateORC() {
-
-    List<ColumnDescriptionImpl> cdl = new ArrayList<>(4);
-    cdl.add(new ColumnDescriptionImpl("col1", ColumnDescription.DataTypes.CHAR.toString(), 0, 10));
-    cdl.add(new ColumnDescriptionImpl("col2", ColumnDescription.DataTypes.STRING.toString(), 1));
-    cdl.add(new ColumnDescriptionImpl("col3", ColumnDescription.DataTypes.DECIMAL.toString(), 2, 10, 5));
-    cdl.add(new ColumnDescriptionImpl("col4", ColumnDescription.DataTypes.VARCHAR.toString(), 3, 40));
-    cdl.add(new ColumnDescriptionImpl("col5", ColumnDescription.DataTypes.INT.toString(), 4));
-
-    TableInfo ti = new TableInfo("databaseName", "tableName", cdl, HiveFileType.ORC, new RowFormat(',', '\\'));
-
-    QueryGenerator qg = new QueryGenerator();
-    Assert.assertEquals("Create query for text file not correct ","CREATE TABLE tableName (col1 CHAR(10), col2 STRING, col3 DECIMAL(10,5), col4 VARCHAR(40), col5 INT) STORED AS ORC;",qg.generateCreateQuery(ti));
-  }
-
-  @Test
-  public void testInsertWithoutUnhexFromQuery() {
-    List<ColumnDescriptionImpl> cdl = new ArrayList<>(4);
-    cdl.add(new ColumnDescriptionImpl("col1", ColumnDescription.DataTypes.CHAR.toString(), 0, 10));
-    cdl.add(new ColumnDescriptionImpl("col2", ColumnDescription.DataTypes.STRING.toString(), 1));
-    cdl.add(new ColumnDescriptionImpl("col3", ColumnDescription.DataTypes.DECIMAL.toString(), 2, 10, 5));
-    cdl.add(new ColumnDescriptionImpl("col4", ColumnDescription.DataTypes.VARCHAR.toString(), 3, 40));
-    cdl.add(new ColumnDescriptionImpl("col5", ColumnDescription.DataTypes.INT.toString(), 4));
-
-    InsertFromQueryInput ifqi = new InsertFromQueryInput("fromDB","fromTable","toDB","toTable", cdl, Boolean.FALSE);
-
-    QueryGenerator qg = new QueryGenerator();
-    Assert.assertEquals("insert from one table to another not correct ","INSERT INTO TABLE toDB.toTable SELECT col1, col2, col3, col4, col5 FROM fromDB.fromTable;",qg.generateInsertFromQuery(ifqi));
-  }
-
-  @Test
-  public void testInsertWithUnhexFromQuery() {
-    List<ColumnDescriptionImpl> cdl = new ArrayList<>(4);
-    cdl.add(new ColumnDescriptionImpl("col1", ColumnDescription.DataTypes.CHAR.toString(), 0, 10));
-    cdl.add(new ColumnDescriptionImpl("col2", ColumnDescription.DataTypes.STRING.toString(), 1));
-    cdl.add(new ColumnDescriptionImpl("col3", ColumnDescription.DataTypes.DECIMAL.toString(), 2, 10, 5));
-    cdl.add(new ColumnDescriptionImpl("col4", ColumnDescription.DataTypes.VARCHAR.toString(), 3, 40));
-    cdl.add(new ColumnDescriptionImpl("col5", ColumnDescription.DataTypes.INT.toString(), 4));
-
-    InsertFromQueryInput ifqi = new InsertFromQueryInput("fromDB","fromTable","toDB","toTable", cdl, Boolean.TRUE);
-
-    QueryGenerator qg = new QueryGenerator();
-    Assert.assertEquals("insert from one table to another not correct ","INSERT INTO TABLE toDB.toTable SELECT UNHEX(col1), UNHEX(col2), col3, UNHEX(col4), col5 FROM fromDB.fromTable;",qg.generateInsertFromQuery(ifqi));
-  }
-
-  @Test
-  public void testDropTableQuery() {
-
-    DeleteQueryInput deleteQueryInput = new DeleteQueryInput("dbName","tableName");
-
-    QueryGenerator qg = new QueryGenerator();
-    Assert.assertEquals("drop table query not correct ","DROP TABLE dbName.tableName;",qg.generateDropTableQuery(deleteQueryInput ));
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/resources/upload/TableDataReaderTest.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/resources/upload/TableDataReaderTest.java b/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/resources/upload/TableDataReaderTest.java
deleted file mode 100644
index 2e9c2b0..0000000
--- a/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/resources/upload/TableDataReaderTest.java
+++ /dev/null
@@ -1,127 +0,0 @@
-/**
- * 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
- * <p/>
- * http://www.apache.org/licenses/LICENSE-2.0
- * <p/>
- * 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.ambari.view.hive.resources.upload;
-
-import org.apache.ambari.view.hive.client.ColumnDescription;
-import org.apache.ambari.view.hive.client.Row;
-import org.apache.ambari.view.hive.resources.uploads.ColumnDescriptionImpl;
-import org.apache.ambari.view.hive.resources.uploads.TableDataReader;
-import org.junit.Assert;
-import org.junit.Test;
-
-import java.io.IOException;
-import java.util.ArrayList;
-import java.util.Iterator;
-import java.util.LinkedList;
-import java.util.List;
-
-public class TableDataReaderTest {
-
-  private class RowIter implements Iterator<Row> {
-    int numberOfRows;
-    int numberOfCols;
-    int index = 0 ;
-    ArrayList<Row> rows = new ArrayList<Row>();
-    public RowIter(int numberOfRows, int numberOfCols){
-      this.numberOfRows = numberOfRows;
-      this.numberOfCols = numberOfCols;
-      int x = 0 ;
-      for(int i = 0; i < this.numberOfRows; i++ ){
-        Object [] objArray = new Object[10];
-        for(int j = 0; j < this.numberOfCols; j++ ){
-          objArray[j] = x++ + "" ;
-        }
-        Row row = new Row(objArray);
-        rows.add(row);
-      }
-    }
-    @Override
-    public boolean hasNext() {
-      return index < numberOfRows;
-    }
-
-    @Override
-    public Row next() {
-      return rows.get(index++);
-    }
-
-    @Override
-    public void remove() {
-      throw new RuntimeException("Operation not supported.");
-    }
-
-    @Override
-    public String toString() {
-      return "RowIter{" +
-              "index=" + index +
-              ", rows=" + rows +
-              '}';
-    }
-  }
-
-  @Test
-  public void testCSVReader() throws IOException {
-    RowIter rowIter = new RowIter(10,10);
-    List<ColumnDescriptionImpl> colDescs = new LinkedList<>();
-    for(int i = 0 ; i < 10 ; i++ ) {
-      ColumnDescriptionImpl cd = new ColumnDescriptionImpl("col" + (i+1) , ColumnDescription.DataTypes.STRING.toString(), i);
-      colDescs.add(cd);
-    }
-
-    TableDataReader tableDataReader = new TableDataReader(rowIter, colDescs, false);
-
-    char del = TableDataReader.CSV_DELIMITER;
-    char[] first10 = {'0', del, '1', del, '2', del, '3', del, '4', del};
-    char [] buf = new char[10];
-    tableDataReader.read(buf,0,10);
-
-    Assert.assertArrayEquals(first10,buf);
-
-    char[] next11 = {'5', del, '6', del, '7', del, '8', del, '9', '\n', '1'}; //"5,6,7,8,9\n1".toCharArray();
-    char [] buf1 = new char[11];
-    tableDataReader.read(buf1,0,11);
-
-    Assert.assertArrayEquals(next11,buf1);
-
-    // read it fully
-    while( tableDataReader.read(buf,0,10) != -1 );
-
-    char [] last10 = {'9', '7', del, '9', '8', del, '9', '9', '\n', del}; //"97,98,99\n,".toCharArray(); // last comma is the left over of previous read.
-
-    Assert.assertArrayEquals(last10,buf);
-  }
-
-  @Test
-  public void testEmptyCSVReader() throws IOException {
-    RowIter rowIter = new RowIter(0,0);
-
-    TableDataReader tableDataReader = new TableDataReader(rowIter, null, false);
-
-    char[] first10 = new char [10];
-    char [] buf = new char[10];
-    for( int i = 0 ; i < 10 ; i++ ){
-      first10[i] = '\0';
-      buf[i] = '\0';
-    }
-
-    tableDataReader.read(buf,0,10);
-
-    Assert.assertArrayEquals(first10,buf);
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/resources/upload/XMLParserTest.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/resources/upload/XMLParserTest.java b/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/resources/upload/XMLParserTest.java
deleted file mode 100644
index 1bdf031..0000000
--- a/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/resources/upload/XMLParserTest.java
+++ /dev/null
@@ -1,138 +0,0 @@
-/**
- * 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
- * <p/>
- * http://www.apache.org/licenses/LICENSE-2.0
- * <p/>
- * 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.ambari.view.hive.resources.upload;
-
-import com.google.gson.JsonArray;
-import com.google.gson.JsonObject;
-import org.apache.ambari.view.hive.client.Row;
-import org.apache.ambari.view.hive.resources.uploads.parsers.json.JSONParser;
-import org.apache.ambari.view.hive.resources.uploads.parsers.xml.XMLParser;
-import org.junit.Assert;
-import org.junit.Test;
-
-import java.io.IOException;
-import java.io.StringReader;
-import java.util.Iterator;
-
-public class XMLParserTest {
-
-  @Test(expected = IOException.class)
-  public void testEmptyStream() throws Exception {
-    String xml = "";
-
-    try(
-      StringReader sr = new StringReader(xml);
-      XMLParser jp = new XMLParser(sr, null);
-      ) {
-        // creation of XMLParser will throw exception.
-    }
-  }
-
-  @Test
-  public void testEmptyRow() throws Exception {
-    String xml = "<table><row></row></table>";
-    try(
-      StringReader sr = new StringReader(xml);
-      XMLParser jp = new XMLParser(sr, null);
-      ) {
-      Iterator<Row> iterator = jp.iterator();
-
-      Assert.assertEquals("Iterator should not be Empty", true, iterator.hasNext());
-      Assert.assertArrayEquals("Row should be empty",new Object[]{},iterator.next().getRow());
-    }
-  }
-
-
-  @Test
-  public void testEmptyTable() throws Exception {
-    String xml = "<table></table>";
-
-    try(
-      StringReader sr = new StringReader(xml);
-      XMLParser jp = new XMLParser(sr, null);
-      ) {
-      Iterator<Row> iterator = jp.iterator();
-
-      Assert.assertEquals("Iterator Empty!", false, iterator.hasNext());
-    }
-  }
-
-  @Test
-  public void testParse1Row() throws Exception {
-
-    String xml =
-    "<table>"
-    + "<row>"
-    + "<col name=\"key1\">value1</col>"
-    + "<col name=\"key2\">c</col>"
-    + "<col name=\"key3\">10</col>"
-    + "<col name=\"key4\">10.1</col>"
-    + "</row>"
-    + "</table>"  ;
-
-    try(
-      StringReader sr = new StringReader(xml);
-      XMLParser jp = new XMLParser(sr, null)
-    ) {
-      Iterator<Row> iterator = jp.iterator();
-
-      Assert.assertEquals("Iterator Empty!", true, iterator.hasNext());
-      Row row = iterator.next();
-      Row expected = new Row(new Object[]{"value1", "c", "10", "10.1"});
-      Assert.assertEquals("Row not equal!", expected, row);
-
-      Assert.assertEquals("Should report no more rows!", false, iterator.hasNext());
-    }
-  }
-
-  @Test
-  public void testParseMultipleRow() throws Exception {
-    String xml =
-    "<table>"
-    + "<row>"
-    + "<col name=\"key1\">value1</col>"
-    + "<col name=\"key2\">c</col>"
-    + "<col name=\"key3\">10</col>"
-    + "<col name=\"key4\">10.1</col>"
-    + "</row>"
-    + "<row>"
-    + "<col name=\"key1\">value2</col>"
-    + "<col name=\"key2\">c2</col>"
-    + "<col name=\"key3\">102</col>"
-    + "<col name=\"key4\">true</col>"
-    + "</row>"
-    + "</table>"  ;
-
-    try(
-      StringReader sr = new StringReader(xml);
-      XMLParser jp = new XMLParser(sr, null)
-    ) {
-      Iterator<Row> iterator = jp.iterator();
-
-      Assert.assertEquals("Failed to detect 1st row!", true, iterator.hasNext());
-      Assert.assertEquals("Failed to match 1st row!", new Row(new Object[]{"value1", "c", "10", "10.1"}), iterator.next());
-
-      Assert.assertEquals("Failed to detect 2nd row!", true, iterator.hasNext());
-      Assert.assertEquals("Failed to match 2nd row!", new Row(new Object[]{"value2", "c2", "102", Boolean.TRUE.toString()}), iterator.next());
-
-      Assert.assertEquals("Failed to detect end of rows!", false, iterator.hasNext());
-      Assert.assertEquals("Failed to detect end of rows 2nd time!", false, iterator.hasNext());
-    }
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/utils/HdfsApiMock.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/utils/HdfsApiMock.java b/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/utils/HdfsApiMock.java
deleted file mode 100644
index 8eae827..0000000
--- a/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/utils/HdfsApiMock.java
+++ /dev/null
@@ -1,86 +0,0 @@
-/**
- * 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.ambari.view.hive.utils;
-
-import org.apache.ambari.view.utils.hdfs.HdfsApi;
-import org.apache.ambari.view.utils.hdfs.HdfsApiException;
-import org.apache.hadoop.fs.FSDataInputStream;
-import org.apache.hadoop.fs.FSDataOutputStream;
-
-import java.io.ByteArrayOutputStream;
-import java.io.IOException;
-
-import static org.easymock.EasyMock.*;
-
-/**
-* Created by roma on 2/6/15.
-*/
-public class HdfsApiMock {
-  private ByteArrayOutputStream fsQueryOutputStream;
-  private ByteArrayOutputStream fsLogsOutputStream;
-  private HdfsApi hdfsApi;
-
-  public HdfsApiMock(String inputFileContent) throws IOException, InterruptedException, HdfsApiException {
-    setupHdfsApi(inputFileContent);
-  }
-
-  protected void setupHdfsApi(String inputFileContent) throws IOException, InterruptedException, HdfsApiException {
-    hdfsApi = createNiceMock(HdfsApi.class);
-
-    hdfsApi.copy(anyString(), anyString());
-
-    fsQueryOutputStream = setupQueryOutputStream(hdfsApi);
-    fsLogsOutputStream = setupLogsOutputStream(hdfsApi);
-    setupQueryInputStream(hdfsApi, inputFileContent);
-
-    expect(hdfsApi.mkdir(anyString())).andReturn(true).anyTimes();
-  }
-
-  protected SeekableByteArrayInputStream setupQueryInputStream(HdfsApi hdfsApi, String query) throws IOException, InterruptedException {
-    SeekableByteArrayInputStream inputStreamHQL = new SeekableByteArrayInputStream(query.getBytes());
-    expect(hdfsApi.open(endsWith(".hql"))).andReturn(new FSDataInputStream(inputStreamHQL)).anyTimes();
-    return inputStreamHQL;
-  }
-
-  protected ByteArrayOutputStream setupQueryOutputStream(HdfsApi hdfsApi) throws IOException, InterruptedException {
-    ByteArrayOutputStream queryOutputStream = new ByteArrayOutputStream();
-    FSDataOutputStream fsQueryOutputStream = new FSDataOutputStream(queryOutputStream);
-    expect(hdfsApi.create(endsWith(".hql"), anyBoolean())).andReturn(fsQueryOutputStream);
-    return queryOutputStream;
-  }
-
-  protected ByteArrayOutputStream setupLogsOutputStream(HdfsApi hdfsApi) throws IOException, InterruptedException {
-    ByteArrayOutputStream logsOutputStream = new ByteArrayOutputStream();
-    FSDataOutputStream fsLogsOutputStream = new FSDataOutputStream(logsOutputStream);
-    expect(hdfsApi.create(endsWith("logs"), anyBoolean())).andReturn(fsLogsOutputStream).anyTimes();
-    return logsOutputStream;
-  }
-
-  public HdfsApi getHdfsApi() {
-    return hdfsApi;
-  }
-
-  public ByteArrayOutputStream getQueryOutputStream() {
-    return fsQueryOutputStream;
-  }
-
-  public ByteArrayOutputStream getLogsOutputStream() {
-    return fsLogsOutputStream;
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/utils/SeekableByteArrayInputStream.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/utils/SeekableByteArrayInputStream.java b/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/utils/SeekableByteArrayInputStream.java
deleted file mode 100644
index 332dc5d..0000000
--- a/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/utils/SeekableByteArrayInputStream.java
+++ /dev/null
@@ -1,71 +0,0 @@
-/**
- * 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.ambari.view.hive.utils;
-
-import org.apache.hadoop.fs.PositionedReadable;
-import org.apache.hadoop.fs.Seekable;
-
-import java.io.ByteArrayInputStream;
-import java.io.IOException;
-
-/**
-* Created by roma on 2/6/15.
-*/
-public class SeekableByteArrayInputStream extends ByteArrayInputStream
-    implements Seekable, PositionedReadable {
-  public SeekableByteArrayInputStream(byte[] buf) {
-    super(buf);
-  }
-
-  public SeekableByteArrayInputStream(byte buf[], int offset, int length) {
-    super(buf, offset, length);
-    throw new UnsupportedOperationException("Seek code assumes offset is zero");
-  }
-
-  public void seek(long position) {
-    if (position < 0 || position >= buf.length)
-      throw new IllegalArgumentException("pos = " + position + " buf.lenght = " + buf.length);
-    this.pos = (int) position;
-  }
-
-  public long getPos() {
-    return this.pos;
-  }
-
-  @Override
-  public boolean seekToNewSource(long l) throws IOException {
-    throw new UnsupportedOperationException("seekToNewSource is not supported");
-  }
-
-  @Override
-  public int read(long l, byte[] buffer, int offset, int length) throws IOException {
-    this.seek(l);
-    return this.read(buffer, offset, length);
-  }
-
-  @Override
-  public void readFully(long l, byte[] bytes, int i, int i1) throws IOException {
-    throw new UnsupportedOperationException("readFully is not supported");
-  }
-
-  @Override
-  public void readFully(long l, byte[] bytes) throws IOException {
-    throw new UnsupportedOperationException("readFully is not supported");
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/pom.xml
----------------------------------------------------------------------
diff --git a/contrib/views/pom.xml b/contrib/views/pom.xml
index 440274b..fdc2320 100644
--- a/contrib/views/pom.xml
+++ b/contrib/views/pom.xml
@@ -48,7 +48,6 @@
     <module>storm</module>
     <module>hueambarimigration</module>
     <module>hive-next</module>
-    <module>hive</module>
     <module>wfmanager</module>
     <!--ambari-views-package should be last in the module list for it to function properly-->
     <module>ambari-views-package</module>
@@ -172,9 +171,6 @@
           <family>unix</family>
         </os>
       </activation>
-      <modules>
-        <module>hive</module>
-      </modules>
     </profile>
   </profiles>
   <dependencyManagement>

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/pom.xml
----------------------------------------------------------------------
diff --git a/pom.xml b/pom.xml
index b400268..a774f0c 100644
--- a/pom.xml
+++ b/pom.xml
@@ -317,8 +317,6 @@
             <exclude>contrib/views/commons/src/main/resources/ui/*/vendor/**</exclude>
             <exclude>contrib/views/commons/src/main/resources/ui/*/tests/**/public/**</exclude>
             <exclude>contrib/views/commons/src/main/resources/ui/*/tests/**/vendor/**</exclude>
-            <exclude>contrib/views/hive/src/main/resources/ui/hive-web/vendor/codemirror/**</exclude>
-            <exclude>contrib/views/hive/src/main/resources/ui/hive-web/.bowerrc</exclude>
             <exclude>contrib/views/hive-next/src/main/resources/ui/hive-web/vendor/codemirror/**</exclude>
             <exclude>contrib/views/hive-next/src/main/resources/ui/hive-web/.bowerrc</exclude>
             <exclude>contrib/views/files/src/main/resources/ui/.bowerrc</exclude>


[18/23] ambari git commit: AMBARI-19302 : removed contrib/views/hive folder and made necessary changes in pom.xml files (nitirajrathore)

Posted by ni...@apache.org.
http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/viewJobs/JobImpl.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/viewJobs/JobImpl.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/viewJobs/JobImpl.java
deleted file mode 100644
index c099cae..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/viewJobs/JobImpl.java
+++ /dev/null
@@ -1,323 +0,0 @@
-/**
- * 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.ambari.view.hive.resources.jobs.viewJobs;
-
-import org.apache.commons.beanutils.PropertyUtils;
-
-import java.beans.Transient;
-import java.lang.reflect.InvocationTargetException;
-import java.util.Map;
-
-/**
- * Bean to represent saved query
- */
-public class JobImpl implements Job {
-  private String title = null;
-  private String queryFile = null;
-  private String statusDir = null;
-  private Long dateSubmitted = 0L;
-  private Long duration = 0L;
-  private String forcedContent = null;
-  private String dataBase = null;
-  private String queryId = null;
-
-  private String status = JOB_STATE_UNKNOWN;
-  private String statusMessage = null;
-  private String sqlState = null;
-
-  private String applicationId;
-  private String dagId;
-  private String dagName;
-
-  private String sessionTag;
-  private String referrer;
-  private String globalSettings;
-
-  private String id = null;
-  private String owner = null;
-
-  private String logFile;
-  private String confFile;
-
-  private String hiveQueryId;
-
-  public JobImpl() {}
-  public JobImpl(Map<String, Object> stringObjectMap) throws InvocationTargetException, IllegalAccessException {
-    for (Map.Entry<String, Object> entry : stringObjectMap.entrySet())  {
-      try {
-        PropertyUtils.setProperty(this, entry.getKey(), entry.getValue());
-      } catch (NoSuchMethodException e) {
-        //do nothing, skip
-      }
-    }
-  }
-
-  @Override
-  public boolean equals(Object o) {
-    if (this == o) return true;
-    if (!(o instanceof Job)) return false;
-
-    JobImpl job = (JobImpl) o;
-
-    return id != null ? id.equals(job.id) : job.id == null;
-
-  }
-
-  @Override
-  public int hashCode() {
-    return id != null ? id.hashCode() : 0;
-  }
-
-  @Override
-  @Transient
-  public String getHiveQueryId() {
-    return hiveQueryId;
-  }
-
-  @Override
-  @Transient
-  public void setHiveQueryId(String hiveQueryId) {
-    this.hiveQueryId = hiveQueryId;
-  }
-
-  @Override
-  public String getId() {
-    return id;
-  }
-
-  @Override
-  public void setId(String id) {
-    this.id = id;
-  }
-
-  @Override
-  public String getOwner() {
-    return owner;
-  }
-
-  @Override
-  public void setOwner(String owner) {
-    this.owner = owner;
-  }
-
-  @Override
-  public String getTitle() {
-    return title;
-  }
-
-  @Override
-  public void setTitle(String title) {
-    this.title = title;
-  }
-
-  @Override
-  public String getQueryFile() {
-    return queryFile;
-  }
-
-  @Override
-  public void setQueryFile(String queryFile) {
-    this.queryFile = queryFile;
-  }
-
-  @Override
-  public Long getDateSubmitted() {
-    return dateSubmitted;
-  }
-
-  @Override
-  public void setDateSubmitted(Long dateSubmitted) {
-    this.dateSubmitted = dateSubmitted;
-  }
-
-  @Override
-  public Long getDuration() {
-    return duration;
-  }
-
-  @Override
-  public void setDuration(Long duration) {
-    this.duration = duration;
-  }
-
-  @Override
-  public String getStatus() {
-    return status;
-  }
-
-  @Override
-  public void setStatus(String status) {
-    this.status = status;
-  }
-
-  @Override
-  @Transient
-  public String getForcedContent() {
-    return forcedContent;
-  }
-
-  @Override
-  @Transient
-  public void setForcedContent(String forcedContent) {
-    this.forcedContent = forcedContent;
-  }
-
-  @Override
-  public String getQueryId() {
-    return queryId;
-  }
-
-  @Override
-  public void setQueryId(String queryId) {
-    this.queryId = queryId;
-  }
-
-  @Override
-  public String getStatusDir() {
-    return statusDir;
-  }
-
-  @Override
-  public void setStatusDir(String statusDir) {
-    this.statusDir = statusDir;
-  }
-
-  @Override
-  public String getDataBase() {
-    return dataBase;
-  }
-
-  @Override
-  public void setDataBase(String dataBase) {
-    this.dataBase = dataBase;
-  }
-
-  @Override
-  public String getLogFile() {
-    return logFile;
-  }
-
-  @Override
-  public void setLogFile(String logFile) {
-    this.logFile = logFile;
-  }
-
-  @Override
-  public String getConfFile() {
-    return confFile;
-  }
-
-  @Override
-  public void setConfFile(String confFile) {
-    this.confFile = confFile;
-  }
-
-  @Override
-  public String getApplicationId() {
-    return applicationId;
-  }
-
-  @Override
-  public void setApplicationId(String applicationId) {
-    this.applicationId = applicationId;
-  }
-
-  @Override
-  public String getDagName() {
-    return dagName;
-  }
-
-  @Override
-  public void setDagName(String dagName) {
-    this.dagName = dagName;
-  }
-
-  @Override
-  public String getDagId() {
-    return dagId;
-  }
-
-  @Override
-  public void setDagId(String dagId) {
-    this.dagId = dagId;
-  }
-
-  @Override
-  public String getSessionTag() {
-    return sessionTag;
-  }
-
-  @Override
-  public void setSessionTag(String sessionTag) {
-    this.sessionTag = sessionTag;
-  }
-
-  @Override
-  @Transient
-  public String getStatusMessage() {
-    return statusMessage;
-  }
-
-  @Override
-  @Transient
-  public void setStatusMessage(String statusMessage) {
-    this.statusMessage = statusMessage;
-  }
-
-  @Override
-  public String getSqlState() {
-    return sqlState;
-  }
-
-  @Override
-  public void setSqlState(String sqlState) {
-    this.sqlState = sqlState;
-  }
-
-  @Override
-  public String getReferrer() {
-    return referrer;
-  }
-
-  @Override
-  public void setReferrer(String referrer) {
-    this.referrer = referrer;
-  }
-
-  @Override
-  public String getGlobalSettings() {
-    return globalSettings;
-  }
-
-  @Override
-  public void setGlobalSettings(String globalSettings) {
-    this.globalSettings = globalSettings;
-  }
-
-  @Override
-  public String toString() {
-    return new StringBuilder("JobImpl{")
-      .append("id='").append(id)
-      .append(", owner='").append(owner)
-      .append(", hiveQueryId='").append(hiveQueryId)
-      .append(", dagId='").append(dagId)
-      .append(", queryId='").append(queryId)
-      .append('}').toString();
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/viewJobs/JobInfo.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/viewJobs/JobInfo.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/viewJobs/JobInfo.java
deleted file mode 100644
index 4162594..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/viewJobs/JobInfo.java
+++ /dev/null
@@ -1,78 +0,0 @@
-/**
- * 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.ambari.view.hive.resources.jobs.viewJobs;
-
-public class JobInfo {
-  private String jobId;
-  private String hiveId;
-  private String dagId;
-  private String operationId;
-
-  public JobInfo() {
-  }
-
-  public JobInfo(String jobId, String hiveId, String dagId, String operationId) {
-    this.jobId = jobId;
-    this.hiveId = hiveId;
-    this.dagId = dagId;
-    this.operationId = operationId;
-  }
-
-  public String getJobId() {
-    return jobId;
-  }
-
-  public void setJobId(String jobId) {
-    this.jobId = jobId;
-  }
-
-  public String getHiveId() {
-    return hiveId;
-  }
-
-  public void setHiveId(String hiveId) {
-    this.hiveId = hiveId;
-  }
-
-  public String getDagId() {
-    return dagId;
-  }
-
-  public void setDagId(String dagId) {
-    this.dagId = dagId;
-  }
-
-  public String getOperationId() {
-    return operationId;
-  }
-
-  public void setOperationId(String operationId) {
-    this.operationId = operationId;
-  }
-
-  @Override
-  public String toString() {
-    return new StringBuilder().append("JobInfo{" )
-      .append("jobId=").append(jobId)
-      .append(", hiveId=").append(hiveId)
-      .append(", dagId=").append(dagId)
-      .append(", operationId=").append(operationId)
-      .append('}').toString();
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/viewJobs/JobResourceManager.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/viewJobs/JobResourceManager.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/viewJobs/JobResourceManager.java
deleted file mode 100644
index ed1866e..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/viewJobs/JobResourceManager.java
+++ /dev/null
@@ -1,107 +0,0 @@
-/**
- * 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.ambari.view.hive.resources.jobs.viewJobs;
-
-import org.apache.ambari.view.ViewContext;
-import org.apache.ambari.view.hive.client.*;
-import org.apache.ambari.view.hive.persistence.utils.FilteringStrategy;
-import org.apache.ambari.view.hive.persistence.utils.ItemNotFound;
-import org.apache.ambari.view.hive.resources.PersonalCRUDResourceManager;
-import org.apache.ambari.view.hive.utils.*;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-import java.util.*;
-
-/**
- * Object that provides CRUD operations for job objects
- */
-public class JobResourceManager extends PersonalCRUDResourceManager<Job> {
-  private final static Logger LOG =
-      LoggerFactory.getLogger(JobResourceManager.class);
-
-  private IJobControllerFactory jobControllerFactory;
-
-  /**
-   * Constructor
-   * @param context View Context instance
-   */
-  public JobResourceManager(SharedObjectsFactory sharedObjectsFactory, ViewContext context) {
-    super(JobImpl.class, sharedObjectsFactory, context);
-    jobControllerFactory = sharedObjectsFactory.getJobControllerFactory();
-  }
-
-  @Override
-  public Job create(Job object) {
-    super.create(object);
-    JobController jobController = jobControllerFactory.createControllerForJob(object);
-
-    try {
-
-      jobController.afterCreation();
-      saveIfModified(jobController);
-
-    } catch (ServiceFormattedException e) {
-      cleanupAfterErrorAndThrowAgain(object, e);
-    }
-
-    return object;
-  }
-
-  public void saveIfModified(JobController jobController) {
-    if (jobController.isModified()) {
-      save(jobController.getJobPOJO());
-      jobController.clearModified();
-    }
-  }
-
-
-  @Override
-  public Job read(Object id) throws ItemNotFound {
-    Job job = super.read(id);
-    JobController jobController =  jobControllerFactory.createControllerForJob(job);
-    jobController.update();
-    saveIfModified(jobController);
-    return job;
-  }
-
-  @Override
-  public List<Job> readAll(FilteringStrategy filteringStrategy) {
-    return super.readAll(filteringStrategy);
-  }
-
-  @Override
-  public void delete(Object resourceId) throws ItemNotFound {
-    super.delete(resourceId);
-  }
-
-  public JobController readController(Object id) throws ItemNotFound {
-    Job job = read(id);
-    return jobControllerFactory.createControllerForJob(job);
-  }
-
-  public Cursor getJobResultsCursor(Job job) {
-    try {
-      JobController jobController = jobControllerFactory.createControllerForJob(job);
-      return jobController.getResults();
-    } catch (ItemNotFound itemNotFound) {
-      throw new NotFoundFormattedException("Job results are expired", null);
-    }
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/resources/FileResourceItem.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/resources/FileResourceItem.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/resources/FileResourceItem.java
deleted file mode 100644
index c7ed078..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/resources/FileResourceItem.java
+++ /dev/null
@@ -1,78 +0,0 @@
-/**
- * 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.ambari.view.hive.resources.resources;
-
-import org.apache.ambari.view.hive.persistence.utils.PersonalResource;
-import org.apache.commons.beanutils.BeanUtils;
-
-import java.io.Serializable;
-import java.lang.reflect.InvocationTargetException;
-import java.util.Map;
-
-/**
- * Bean to represent file resource
- */
-public class FileResourceItem implements Serializable, PersonalResource {
-  private String name;
-  private String path;
-
-  private String id;
-  private String owner;
-
-  public FileResourceItem() {}
-  public FileResourceItem(Map<String, Object> stringObjectMap) throws InvocationTargetException, IllegalAccessException {
-    BeanUtils.populate(this, stringObjectMap);
-  }
-
-  @Override
-  public String getId() {
-    return id;
-  }
-
-  @Override
-  public void setId(String id) {
-    this.id = id;
-  }
-
-  @Override
-  public String getOwner() {
-    return owner;
-  }
-
-  @Override
-  public void setOwner(String owner) {
-    this.owner = owner;
-  }
-
-  public String getName() {
-    return name;
-  }
-
-  public void setName(String name) {
-    this.name = name;
-  }
-
-  public String getPath() {
-    return path;
-  }
-
-  public void setPath(String path) {
-    this.path = path;
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/resources/FileResourceResourceManager.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/resources/FileResourceResourceManager.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/resources/FileResourceResourceManager.java
deleted file mode 100644
index 822ae3c..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/resources/FileResourceResourceManager.java
+++ /dev/null
@@ -1,65 +0,0 @@
-/**
- * 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.ambari.view.hive.resources.resources;
-
-import org.apache.ambari.view.ViewContext;
-import org.apache.ambari.view.hive.persistence.IStorageFactory;
-import org.apache.ambari.view.hive.persistence.utils.FilteringStrategy;
-import org.apache.ambari.view.hive.persistence.utils.ItemNotFound;
-import org.apache.ambari.view.hive.resources.PersonalCRUDResourceManager;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-import java.util.List;
-
-/**
- * Object that provides CRUD operations for resource objects
- */
-public class FileResourceResourceManager extends PersonalCRUDResourceManager<FileResourceItem> {
-  private final static Logger LOG =
-      LoggerFactory.getLogger(FileResourceResourceManager.class);
-
-  /**
-   * Constructor
-   * @param context View Context instance
-   */
-  public FileResourceResourceManager(IStorageFactory storageFactory, ViewContext context) {
-    super(FileResourceItem.class, storageFactory, context);
-  }
-
-  @Override
-  public FileResourceItem create(FileResourceItem object) {
-    return super.create(object);
-  }
-
-  @Override
-  public FileResourceItem read(Object id) throws ItemNotFound {
-    return super.read(id);
-  }
-
-  @Override
-  public void delete(Object resourceId) throws ItemNotFound {
-    super.delete(resourceId);
-  }
-
-  @Override
-  public List<FileResourceItem> readAll(FilteringStrategy filteringStrategy) {
-    return super.readAll(filteringStrategy);
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/resources/FileResourceResourceProvider.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/resources/FileResourceResourceProvider.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/resources/FileResourceResourceProvider.java
deleted file mode 100644
index a77d10b..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/resources/FileResourceResourceProvider.java
+++ /dev/null
@@ -1,110 +0,0 @@
-/**
- * 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.ambari.view.hive.resources.resources;
-
-import org.apache.ambari.view.*;
-import org.apache.ambari.view.hive.persistence.utils.ItemNotFound;
-import org.apache.ambari.view.hive.persistence.utils.OnlyOwnersFilteringStrategy;
-import org.apache.ambari.view.hive.utils.SharedObjectsFactory;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-import javax.inject.Inject;
-import java.lang.reflect.InvocationTargetException;
-import java.util.HashSet;
-import java.util.Map;
-import java.util.Set;
-
-/**
- * Resource provider for resource
- */
-public class FileResourceResourceProvider implements ResourceProvider<FileResourceItem> {
-  @Inject
-  ViewContext context;
-
-  protected FileResourceResourceManager resourceManager = null;
-  protected final static Logger LOG =
-      LoggerFactory.getLogger(FileResourceResourceProvider.class);
-
-  protected synchronized FileResourceResourceManager getResourceManager() {
-    if (resourceManager == null) {
-      resourceManager = new FileResourceResourceManager(new SharedObjectsFactory(context), context);
-    }
-    return resourceManager;
-  }
-
-  @Override
-  public FileResourceItem getResource(String resourceId, Set<String> properties) throws SystemException, NoSuchResourceException, UnsupportedPropertyException {
-    try {
-      return getResourceManager().read(resourceId);
-    } catch (ItemNotFound itemNotFound) {
-      throw new NoSuchResourceException(resourceId);
-    }
-  }
-
-  @Override
-  public Set<FileResourceItem> getResources(ReadRequest readRequest) throws SystemException, NoSuchResourceException, UnsupportedPropertyException {
-    if (context == null) {
-      return new HashSet<FileResourceItem>();
-    }
-    return new HashSet<FileResourceItem>(getResourceManager().readAll(
-        new OnlyOwnersFilteringStrategy(this.context.getUsername())));
-  }
-
-  @Override
-  public void createResource(String s, Map<String, Object> stringObjectMap) throws SystemException, ResourceAlreadyExistsException, NoSuchResourceException, UnsupportedPropertyException {
-    FileResourceItem item = null;
-    try {
-      item = new FileResourceItem(stringObjectMap);
-    } catch (InvocationTargetException e) {
-      throw new SystemException("error on creating resource", e);
-    } catch (IllegalAccessException e) {
-      throw new SystemException("error on creating resource", e);
-    }
-    getResourceManager().create(item);
-  }
-
-  @Override
-  public boolean updateResource(String resourceId, Map<String, Object> stringObjectMap) throws SystemException, NoSuchResourceException, UnsupportedPropertyException {
-    FileResourceItem item = null;
-    try {
-      item = new FileResourceItem(stringObjectMap);
-    } catch (InvocationTargetException e) {
-      throw new SystemException("error on updating resource", e);
-    } catch (IllegalAccessException e) {
-      throw new SystemException("error on updating resource", e);
-    }
-    try {
-      getResourceManager().update(item, resourceId);
-    } catch (ItemNotFound itemNotFound) {
-      throw new NoSuchResourceException(resourceId);
-    }
-    return true;
-  }
-
-  @Override
-  public boolean deleteResource(String resourceId) throws SystemException, NoSuchResourceException, UnsupportedPropertyException {
-    try {
-      getResourceManager().delete(resourceId);
-    } catch (ItemNotFound itemNotFound) {
-      throw new NoSuchResourceException(resourceId);
-    }
-    return true;
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/resources/FileResourceService.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/resources/FileResourceService.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/resources/FileResourceService.java
deleted file mode 100644
index 412b026..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/resources/FileResourceService.java
+++ /dev/null
@@ -1,180 +0,0 @@
-/**
- * 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.ambari.view.hive.resources.resources;
-
-import org.apache.ambari.view.ViewResourceHandler;
-import org.apache.ambari.view.hive.BaseService;
-import org.apache.ambari.view.hive.persistence.utils.ItemNotFound;
-import org.apache.ambari.view.hive.persistence.utils.OnlyOwnersFilteringStrategy;
-import org.apache.ambari.view.hive.utils.NotFoundFormattedException;
-import org.apache.ambari.view.hive.utils.ServiceFormattedException;
-import org.json.simple.JSONObject;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-import javax.inject.Inject;
-import javax.servlet.http.HttpServletResponse;
-import javax.ws.rs.*;
-import javax.ws.rs.core.Context;
-import javax.ws.rs.core.MediaType;
-import javax.ws.rs.core.Response;
-import javax.ws.rs.core.UriInfo;
-import java.util.List;
-
-/**
- * Servlet for Resources
- * API:
- * GET /:id
- *      read resource
- * POST /
- *      create new resource
- * GET /
- *      get all resource of current user
- */
-public class FileResourceService extends BaseService {
-  @Inject
-  ViewResourceHandler handler;
-
-  protected FileResourceResourceManager resourceManager = null;
-  protected final static Logger LOG =
-      LoggerFactory.getLogger(FileResourceService.class);
-
-  protected synchronized FileResourceResourceManager getResourceManager() {
-    if (resourceManager == null) {
-      resourceManager = new FileResourceResourceManager(getSharedObjectsFactory(), context);
-    }
-    return resourceManager;
-  }
-
-  /**
-   * Get single item
-   */
-  @GET
-  @Path("{id}")
-  @Produces(MediaType.APPLICATION_JSON)
-  public Response getOne(@PathParam("id") String id) {
-    try {
-      FileResourceItem fileResourceItem = getResourceManager().read(id);
-      JSONObject object = new JSONObject();
-      object.put("fileResource", fileResourceItem);
-      return Response.ok(object).build();
-    } catch (WebApplicationException ex) {
-      throw ex;
-    } catch (ItemNotFound itemNotFound) {
-      throw new NotFoundFormattedException(itemNotFound.getMessage(), itemNotFound);
-    } catch (Exception ex) {
-      throw new ServiceFormattedException(ex.getMessage(), ex);
-    }
-  }
-
-  /**
-   * Delete single item
-   */
-  @DELETE
-  @Path("{id}")
-  public Response delete(@PathParam("id") String id) {
-    try {
-      getResourceManager().delete(id);
-      return Response.status(204).build();
-    } catch (WebApplicationException ex) {
-      throw ex;
-    } catch (ItemNotFound itemNotFound) {
-      throw new NotFoundFormattedException(itemNotFound.getMessage(), itemNotFound);
-    } catch (Exception ex) {
-      throw new ServiceFormattedException(ex.getMessage(), ex);
-    }
-  }
-
-  /**
-   * Get all resources
-   */
-  @GET
-  @Produces(MediaType.APPLICATION_JSON)
-  public Response getList() {
-    try {
-      LOG.debug("Getting all resources");
-      List items = getResourceManager().readAll(
-          new OnlyOwnersFilteringStrategy(this.context.getUsername()));  //TODO: move strategy to PersonalCRUDRM
-
-      JSONObject object = new JSONObject();
-      object.put("fileResources", items);
-      return Response.ok(object).build();
-    } catch (WebApplicationException ex) {
-      throw ex;
-    } catch (Exception ex) {
-      throw new ServiceFormattedException(ex.getMessage(), ex);
-    }
-  }
-
-  /**
-   * Update item
-   */
-  @PUT
-  @Path("{id}")
-  @Consumes(MediaType.APPLICATION_JSON)
-  public Response update(ResourceRequest request,
-                         @PathParam("id") String id) {
-    try {
-      getResourceManager().update(request.fileResource, id);
-      return Response.status(204).build();
-    } catch (WebApplicationException ex) {
-      throw ex;
-    } catch (ItemNotFound itemNotFound) {
-      throw new NotFoundFormattedException(itemNotFound.getMessage(), itemNotFound);
-    } catch (Exception ex) {
-      throw new ServiceFormattedException(ex.getMessage(), ex);
-    }
-  }
-
-  /**
-   * Create resource
-   */
-  @POST
-  @Consumes(MediaType.APPLICATION_JSON)
-  public Response create(ResourceRequest request, @Context HttpServletResponse response,
-                         @Context UriInfo ui) {
-    try {
-      getResourceManager().create(request.fileResource);
-
-      FileResourceItem item = null;
-
-      item = getResourceManager().read(request.fileResource.getId());
-
-      response.setHeader("Location",
-          String.format("%s/%s", ui.getAbsolutePath().toString(), request.fileResource.getId()));
-
-      JSONObject object = new JSONObject();
-      object.put("fileResource", item);
-      return Response.ok(object).status(201).build();
-    } catch (WebApplicationException ex) {
-      throw ex;
-    } catch (ItemNotFound itemNotFound) {
-      throw new NotFoundFormattedException(itemNotFound.getMessage(), itemNotFound);
-    } catch (Exception ex) {
-      throw new ServiceFormattedException(ex.getMessage(), ex);
-    }
-  }
-
-  /**
-   * Wrapper object for json mapping
-   */
-  public static class ResourceRequest {
-    public FileResourceItem fileResource;
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/savedQueries/SavedQuery.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/savedQueries/SavedQuery.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/savedQueries/SavedQuery.java
deleted file mode 100644
index 25a7748..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/savedQueries/SavedQuery.java
+++ /dev/null
@@ -1,96 +0,0 @@
-/**
- * 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.ambari.view.hive.resources.savedQueries;
-
-import org.apache.ambari.view.hive.persistence.utils.PersonalResource;
-import org.apache.commons.beanutils.BeanUtils;
-
-import java.io.Serializable;
-import java.lang.reflect.InvocationTargetException;
-import java.util.Map;
-
-/**
- * Bean to represent saved query
- */
-public class SavedQuery implements Serializable, PersonalResource {
-  private String queryFile;
-  private String dataBase;
-  private String title;
-  private String shortQuery;
-
-  private String id;
-  private String owner;
-
-  public SavedQuery() {}
-  public SavedQuery(Map<String, Object> stringObjectMap) throws InvocationTargetException, IllegalAccessException {
-    BeanUtils.populate(this, stringObjectMap);
-  }
-
-  @Override
-  public String getId() {
-    return id;
-  }
-
-  @Override
-  public void setId(String id) {
-    this.id = id;
-  }
-
-  @Override
-  public String getOwner() {
-    return owner;
-  }
-
-  @Override
-  public void setOwner(String owner) {
-    this.owner = owner;
-  }
-
-  public String getQueryFile() {
-    return queryFile;
-  }
-
-  public void setQueryFile(String queryFile) {
-    this.queryFile = queryFile;
-  }
-
-  public String getDataBase() {
-    return dataBase;
-  }
-
-  public void setDataBase(String dataBase) {
-    this.dataBase = dataBase;
-  }
-
-  public String getTitle() {
-    return title;
-  }
-
-  public void setTitle(String title) {
-    this.title = title;
-  }
-
-  public String getShortQuery() {
-    return shortQuery;
-  }
-
-  public void setShortQuery(String shortQuery) {
-    this.shortQuery = shortQuery;
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/savedQueries/SavedQueryResourceManager.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/savedQueries/SavedQueryResourceManager.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/savedQueries/SavedQueryResourceManager.java
deleted file mode 100644
index 21a3967..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/savedQueries/SavedQueryResourceManager.java
+++ /dev/null
@@ -1,162 +0,0 @@
-/**
- * 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.ambari.view.hive.resources.savedQueries;
-
-import org.apache.ambari.view.ViewContext;
-import org.apache.ambari.view.hive.persistence.utils.FilteringStrategy;
-import org.apache.ambari.view.hive.persistence.utils.ItemNotFound;
-import org.apache.ambari.view.hive.resources.PersonalCRUDResourceManager;
-import org.apache.ambari.view.hive.utils.*;
-import org.apache.ambari.view.utils.hdfs.HdfsApiException;
-import org.apache.ambari.view.utils.hdfs.HdfsUtil;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-import java.io.IOException;
-import java.text.SimpleDateFormat;
-import java.util.Date;
-import java.util.List;
-
-/**
- * Object that provides CRUD operations for query objects
- */
-public class SavedQueryResourceManager extends PersonalCRUDResourceManager<SavedQuery> {
-  private final static Logger LOG =
-      LoggerFactory.getLogger(SavedQueryResourceManager.class);
-
-  private SharedObjectsFactory sharedObjectsFactory;
-
-  /**
-   * Constructor
-   * @param context View Context instance
-   */
-  public SavedQueryResourceManager(ViewContext context, SharedObjectsFactory sharedObjectsFactory) {
-    super(SavedQuery.class, sharedObjectsFactory, context);
-    this.sharedObjectsFactory = sharedObjectsFactory;
-  }
-
-  @Override
-  public SavedQuery create(SavedQuery object) {
-    object = super.create(object);
-    try {
-
-      if (object.getQueryFile() == null || object.getQueryFile().isEmpty()) {
-        createDefaultQueryFile(object);
-      }
-
-    } catch (ServiceFormattedException e) {
-      cleanupAfterErrorAndThrowAgain(object, e);
-    }
-    return object;
-  }
-
-  private void createDefaultQueryFile(SavedQuery object) {
-    String userScriptsPath = context.getProperties().get("scripts.dir");
-    if (userScriptsPath == null) {
-      String msg = "scripts.dir is not configured!";
-      LOG.error(msg);
-      throw new MisconfigurationFormattedException("scripts.dir");
-    }
-
-    String normalizedName = String.format("hive-query-%s", object.getId());
-    String timestamp = new SimpleDateFormat("yyyy-MM-dd_hh-mm").format(new Date());
-    String baseFileName = String.format(userScriptsPath +
-        "/%s-%s", normalizedName, timestamp);
-
-    String newFilePath = null;
-    try {
-      newFilePath = HdfsUtil.findUnallocatedFileName(sharedObjectsFactory.getHdfsApi(), baseFileName, ".hql");
-      HdfsUtil.putStringToFile(sharedObjectsFactory.getHdfsApi(), newFilePath, "");
-    } catch (HdfsApiException e) {
-      throw new ServiceFormattedException(e);
-    }
-
-    object.setQueryFile(newFilePath);
-    storageFactory.getStorage().store(SavedQuery.class, object);
-  }
-
-  @Override
-  public SavedQuery read(Object id) throws ItemNotFound {
-    SavedQuery savedQuery = super.read(id);
-    fillShortQueryField(savedQuery);
-    return savedQuery;
-  }
-
-  private void fillShortQueryField(SavedQuery savedQuery) {
-    if (savedQuery.getQueryFile() != null) {
-      FilePaginator paginator = new FilePaginator(savedQuery.getQueryFile(), sharedObjectsFactory.getHdfsApi());
-      String query = null;
-      try {
-        query = paginator.readPage(0);
-      } catch (IOException e) {
-        LOG.error("Can't read query file " + savedQuery.getQueryFile());
-        return;
-      } catch (InterruptedException e) {
-        LOG.error("Can't read query file " + savedQuery.getQueryFile());
-        return;
-      }
-      savedQuery.setShortQuery(makeShortQuery(query));
-    }
-    storageFactory.getStorage().store(SavedQuery.class, savedQuery);
-  }
-
-  private void emptyShortQueryField(SavedQuery query) {
-    query.setShortQuery("");
-    storageFactory.getStorage().store(SavedQuery.class, query);
-  }
-
-  /**
-   * Generate short preview of query.
-   * Remove SET settings like "set hive.execution.engine=tez;" from beginning
-   * and trim to 42 symbols.
-   * @param query full query
-   * @return shortened query
-   */
-  protected static String makeShortQuery(String query) {
-    query = query.replaceAll("(?i)set\\s+[\\w\\-.]+(\\s*)=(\\s*)[\\w\\-.]+(\\s*);", "");
-    query = query.trim();
-    return query.substring(0, (query.length() > 42)?42:query.length());
-  }
-
-  @Override
-  public SavedQuery update(SavedQuery newObject, String id) throws ItemNotFound {
-    SavedQuery savedQuery = super.update(newObject, id);
-    // Emptying short query so that in next read, this gets updated with proper value
-    // from the queryFile
-    emptyShortQueryField(savedQuery);
-    return savedQuery;
-  }
-
-  @Override
-  public List<SavedQuery> readAll(FilteringStrategy filteringStrategy) {
-    List<SavedQuery> queries = super.readAll(filteringStrategy);
-    for(SavedQuery query : queries) {
-      String shortQuery = query.getShortQuery();
-      if(shortQuery == null || shortQuery.isEmpty()) {
-        fillShortQueryField(query);
-      }
-    }
-    return queries;
-  }
-
-  @Override
-  public void delete(Object resourceId) throws ItemNotFound {
-    super.delete(resourceId);
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/savedQueries/SavedQueryResourceProvider.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/savedQueries/SavedQueryResourceProvider.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/savedQueries/SavedQueryResourceProvider.java
deleted file mode 100644
index 5a8c2fd..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/savedQueries/SavedQueryResourceProvider.java
+++ /dev/null
@@ -1,113 +0,0 @@
-/**
- * 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.ambari.view.hive.resources.savedQueries;
-
-import org.apache.ambari.view.*;
-import org.apache.ambari.view.hive.persistence.utils.ItemNotFound;
-import org.apache.ambari.view.hive.persistence.utils.OnlyOwnersFilteringStrategy;
-import org.apache.ambari.view.hive.utils.SharedObjectsFactory;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-import javax.inject.Inject;
-import java.lang.reflect.InvocationTargetException;
-import java.util.HashSet;
-import java.util.Map;
-import java.util.Set;
-
-/**
- * Resource provider for SavedQuery
- */
-public class SavedQueryResourceProvider implements ResourceProvider<SavedQuery> {
-  @Inject
-  ViewContext context;
-
-  protected final static Logger LOG =
-      LoggerFactory.getLogger(SavedQueryResourceProvider.class);
-  private SharedObjectsFactory sharedObjectsFactory;
-
-  public SharedObjectsFactory getSharedObjectsFactory() {
-    if (sharedObjectsFactory == null)
-      sharedObjectsFactory = new SharedObjectsFactory(context);
-    return sharedObjectsFactory;
-  }
-
-  protected synchronized SavedQueryResourceManager getResourceManager() {
-    return getSharedObjectsFactory().getSavedQueryResourceManager();
-  }
-
-  @Override
-  public SavedQuery getResource(String resourceId, Set<String> properties) throws SystemException, NoSuchResourceException, UnsupportedPropertyException {
-    try {
-      return getResourceManager().read(resourceId);
-    } catch (ItemNotFound itemNotFound) {
-      throw new NoSuchResourceException(resourceId);
-    }
-  }
-
-  @Override
-  public Set<SavedQuery> getResources(ReadRequest readRequest) throws SystemException, NoSuchResourceException, UnsupportedPropertyException {
-    if (context == null) {
-      return new HashSet<SavedQuery>();
-    }
-    return new HashSet<SavedQuery>(getResourceManager().readAll(
-        new OnlyOwnersFilteringStrategy(this.context.getUsername())));
-  }
-
-  @Override
-  public void createResource(String s, Map<String, Object> stringObjectMap) throws SystemException, ResourceAlreadyExistsException, NoSuchResourceException, UnsupportedPropertyException {
-    SavedQuery item = null;
-    try {
-      item = new SavedQuery(stringObjectMap);
-    } catch (InvocationTargetException e) {
-      throw new SystemException("error on creating resource", e);
-    } catch (IllegalAccessException e) {
-      throw new SystemException("error on creating resource", e);
-    }
-    getResourceManager().create(item);
-  }
-
-  @Override
-  public boolean updateResource(String resourceId, Map<String, Object> stringObjectMap) throws SystemException, NoSuchResourceException, UnsupportedPropertyException {
-    SavedQuery item = null;
-    try {
-      item = new SavedQuery(stringObjectMap);
-    } catch (InvocationTargetException e) {
-      throw new SystemException("error on updating resource", e);
-    } catch (IllegalAccessException e) {
-      throw new SystemException("error on updating resource", e);
-    }
-    try {
-      getResourceManager().update(item, resourceId);
-    } catch (ItemNotFound itemNotFound) {
-      throw new NoSuchResourceException(resourceId);
-    }
-    return true;
-  }
-
-  @Override
-  public boolean deleteResource(String resourceId) throws SystemException, NoSuchResourceException, UnsupportedPropertyException {
-    try {
-      getResourceManager().delete(resourceId);
-    } catch (ItemNotFound itemNotFound) {
-      throw new NoSuchResourceException(resourceId);
-    }
-    return true;
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/savedQueries/SavedQueryService.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/savedQueries/SavedQueryService.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/savedQueries/SavedQueryService.java
deleted file mode 100644
index 4a5872c..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/savedQueries/SavedQueryService.java
+++ /dev/null
@@ -1,266 +0,0 @@
-/**
- * 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.ambari.view.hive.resources.savedQueries;
-
-import org.apache.ambari.view.ViewResourceHandler;
-import org.apache.ambari.view.hive.BaseService;
-import org.apache.ambari.view.hive.persistence.utils.ItemNotFound;
-import org.apache.ambari.view.hive.persistence.utils.OnlyOwnersFilteringStrategy;
-import org.apache.ambari.view.hive.utils.NotFoundFormattedException;
-import org.apache.ambari.view.hive.utils.ServiceFormattedException;
-import org.apache.ambari.view.utils.hdfs.HdfsApi;
-import org.apache.ambari.view.utils.hdfs.HdfsUtil;
-import org.json.simple.JSONObject;
-import org.json.simple.JSONValue;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-import javax.inject.Inject;
-import javax.servlet.http.HttpServletResponse;
-import javax.ws.rs.*;
-import javax.ws.rs.core.Context;
-import javax.ws.rs.core.MediaType;
-import javax.ws.rs.core.Response;
-import javax.ws.rs.core.StreamingOutput;
-import javax.ws.rs.core.UriInfo;
-import java.io.BufferedReader;
-import java.io.BufferedWriter;
-import java.io.IOException;
-import java.io.InputStreamReader;
-import java.io.OutputStream;
-import java.io.OutputStreamWriter;
-import java.io.Writer;
-import java.util.List;
-
-/**
- * Servlet for queries
- * API:
- * GET /:id
- *      read SavedQuery
- * POST /
- *      create new SavedQuery
- *      Required: title, queryFile
- * GET /
- *      get all SavedQueries of current user
- */
-public class SavedQueryService extends BaseService {
-  @Inject
-  ViewResourceHandler handler;
-
-  protected SavedQueryResourceManager resourceManager = null;
-  protected final static Logger LOG =
-      LoggerFactory.getLogger(SavedQueryService.class);
-
-  protected synchronized SavedQueryResourceManager getResourceManager() {
-    return getSharedObjectsFactory().getSavedQueryResourceManager();
-  }
-
-  protected void setResourceManager(SavedQueryResourceManager resourceManager) {
-    this.resourceManager = resourceManager;
-  }
-
-  /**
-   * Get single item
-   */
-  @GET
-  @Path("{queryId}")
-  @Produces(MediaType.APPLICATION_JSON)
-  public Response getOne(@PathParam("queryId") String queryId,
-                         @QueryParam("op") String operation) {
-  try {
-    final SavedQuery savedQuery = getResourceManager().read(queryId);
-    if(operation.equals("download")) {
-      StreamingOutput stream = new StreamingOutput() {
-      @Override
-      public void write(OutputStream os) throws IOException, WebApplicationException {
-        Writer writer = new BufferedWriter(new OutputStreamWriter(os));
-        try {
-          BufferedReader br=new BufferedReader(new InputStreamReader(getSharedObjectsFactory().getHdfsApi().open(savedQuery.getQueryFile())));
-          String line;
-          line=br.readLine();
-          while (line != null){
-            writer.write(line+"\n");
-            line = br.readLine();
-          }
-          writer.flush();
-        } catch (InterruptedException e) {
-          e.printStackTrace();
-        } finally {
-          writer.close();
-        }
-        }
-      };
-      return Response.ok(stream).
-             type(MediaType.TEXT_PLAIN).
-             build();
-    }
-    else {
-       JSONObject object = new JSONObject();
-       object.put("savedQuery", savedQuery);
-       return Response.ok(object).build();
-    }
-    } catch (WebApplicationException ex) {
-      throw ex;
-    } catch (ItemNotFound itemNotFound) {
-      throw new NotFoundFormattedException(itemNotFound.getMessage(), itemNotFound);
-    } catch (Exception ex) {
-      throw new ServiceFormattedException(ex.getMessage(), ex);
-    }
-  }
-
-  /**
-   * Delete single item
-   */
-  @DELETE
-  @Path("{queryId}")
-  public Response delete(@PathParam("queryId") String queryId) {
-    try {
-      getResourceManager().delete(queryId);
-      return Response.status(204).build();
-    } catch (WebApplicationException ex) {
-      throw ex;
-    } catch (ItemNotFound itemNotFound) {
-      throw new NotFoundFormattedException(itemNotFound.getMessage(), itemNotFound);
-    } catch (Exception ex) {
-      throw new ServiceFormattedException(ex.getMessage(), ex);
-    }
-  }
-
-  /**
-   * Get all SavedQueries
-   */
-  @GET
-  @Produces(MediaType.APPLICATION_JSON)
-  public Response getList() {
-    try {
-      LOG.debug("Getting all SavedQuery");
-      List allSavedQueries = getResourceManager().readAll(
-          new OnlyOwnersFilteringStrategy(this.context.getUsername()));  //TODO: move strategy to PersonalCRUDRM
-
-      JSONObject object = new JSONObject();
-      object.put("savedQueries", allSavedQueries);
-      return Response.ok(object).build();
-    } catch (WebApplicationException ex) {
-      throw ex;
-    } catch (Exception ex) {
-      throw new ServiceFormattedException(ex.getMessage(), ex);
-    }
-  }
-
-  /**
-   * Update item
-   */
-  @PUT
-  @Path("{queryId}")
-  @Consumes(MediaType.APPLICATION_JSON)
-  public Response update(SavedQueryRequest request,
-                         @PathParam("queryId") String queryId) {
-    try {
-      getResourceManager().update(request.savedQuery, queryId);
-      return Response.status(204).build();
-    } catch (WebApplicationException ex) {
-      throw ex;
-    } catch (ItemNotFound itemNotFound) {
-      throw new NotFoundFormattedException(itemNotFound.getMessage(), itemNotFound);
-    } catch (Exception ex) {
-      throw new ServiceFormattedException(ex.getMessage(), ex);
-    }
-  }
-
-  /**
-   * Create savedQuery
-   */
-  @POST
-  @Consumes(MediaType.APPLICATION_JSON)
-  public Response create(SavedQueryRequest request, @Context HttpServletResponse response,
-                         @Context UriInfo ui) {
-    try {
-      getResourceManager().create(request.savedQuery);
-
-      SavedQuery item = null;
-
-      item = getResourceManager().read(request.savedQuery.getId());
-
-      response.setHeader("Location",
-          String.format("%s/%s", ui.getAbsolutePath().toString(), request.savedQuery.getId()));
-
-      JSONObject object = new JSONObject();
-      object.put("savedQuery", item);
-      return Response.ok(object).status(201).build();
-    } catch (WebApplicationException ex) {
-      throw ex;
-    } catch (ItemNotFound itemNotFound) {
-      throw new NotFoundFormattedException(itemNotFound.getMessage(), itemNotFound);
-    } catch (Exception ex) {
-      throw new ServiceFormattedException(ex.getMessage(), ex);
-    }
-  }
-
-  /**
-   * Get default settings for query
-   */
-  @GET
-  @Path("defaultSettings")
-  @Produces(MediaType.APPLICATION_JSON)
-  public Response getDefaultSettings() {
-    try {
-      String defaultsFile = context.getProperties().get("scripts.settings.defaults-file");
-      HdfsApi hdfsApi = getSharedObjectsFactory().getHdfsApi();
-
-      String defaults = "{\"settings\": {}}";
-      if (hdfsApi.exists(defaultsFile)) {
-        defaults = HdfsUtil.readFile(hdfsApi, defaultsFile);
-      }
-      return Response.ok(JSONValue.parse(defaults)).build();
-    } catch (WebApplicationException ex) {
-      throw ex;
-    } catch (Exception ex) {
-      throw new ServiceFormattedException(ex.getMessage(), ex);
-    }
-  }
-
-  /**
-   * Set default settings for query (overwrites if present)
-   */
-  @POST
-  @Path("defaultSettings")
-  @Consumes(MediaType.APPLICATION_JSON)
-  public Response setDefaultSettings(JSONObject settings) {
-    try {
-      String defaultsFile = context.getProperties().get("scripts.settings.defaults-file");
-      HdfsApi hdfsApi = getSharedObjectsFactory().getHdfsApi();
-
-      HdfsUtil.putStringToFile(hdfsApi, defaultsFile,
-          settings.toString());
-      String defaults = HdfsUtil.readFile(hdfsApi, defaultsFile);
-      return Response.ok(JSONValue.parse(defaults)).build();
-    } catch (WebApplicationException ex) {
-      throw ex;
-    } catch (Exception ex) {
-      throw new ServiceFormattedException(ex.getMessage(), ex);
-    }
-  }
-
-  /**
-   * Wrapper object for json mapping
-   */
-  public static class SavedQueryRequest {
-    public SavedQuery savedQuery;
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/udfs/UDF.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/udfs/UDF.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/udfs/UDF.java
deleted file mode 100644
index 77c37b5..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/udfs/UDF.java
+++ /dev/null
@@ -1,87 +0,0 @@
-/**
- * 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.ambari.view.hive.resources.udfs;
-
-import org.apache.ambari.view.hive.persistence.utils.PersonalResource;
-import org.apache.commons.beanutils.BeanUtils;
-
-import java.io.Serializable;
-import java.lang.reflect.InvocationTargetException;
-import java.util.Map;
-
-/**
- * Bean to represent UDF
- */
-public class UDF implements Serializable, PersonalResource {
-  private String name;
-  private String classname;
-  private String fileResource;
-
-  private String id;
-  private String owner;
-
-  public UDF() {}
-  public UDF(Map<String, Object> stringObjectMap) throws InvocationTargetException, IllegalAccessException {
-    BeanUtils.populate(this, stringObjectMap);
-  }
-
-  @Override
-  public String getId() {
-    return id;
-  }
-
-  @Override
-  public void setId(String id) {
-    this.id = id;
-  }
-
-  @Override
-  public String getOwner() {
-    return owner;
-  }
-
-  @Override
-  public void setOwner(String owner) {
-    this.owner = owner;
-  }
-
-  public String getName() {
-    return name;
-  }
-
-  public void setName(String name) {
-    this.name = name;
-  }
-
-  public String getClassname() {
-    return classname;
-  }
-
-  public void setClassname(String classname) {
-    this.classname = classname;
-  }
-
-  public String getFileResource() {
-    return fileResource;
-  }
-
-  public void setFileResource(String fileResource) {
-    this.fileResource = fileResource;
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/udfs/UDFResourceManager.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/udfs/UDFResourceManager.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/udfs/UDFResourceManager.java
deleted file mode 100644
index 98a21b3..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/udfs/UDFResourceManager.java
+++ /dev/null
@@ -1,65 +0,0 @@
-/**
- * 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.ambari.view.hive.resources.udfs;
-
-import org.apache.ambari.view.ViewContext;
-import org.apache.ambari.view.hive.persistence.IStorageFactory;
-import org.apache.ambari.view.hive.persistence.utils.FilteringStrategy;
-import org.apache.ambari.view.hive.persistence.utils.ItemNotFound;
-import org.apache.ambari.view.hive.resources.PersonalCRUDResourceManager;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-import java.util.List;
-
-/**
- * Object that provides CRUD operations for udf objects
- */
-public class UDFResourceManager extends PersonalCRUDResourceManager<UDF> {
-  private final static Logger LOG =
-      LoggerFactory.getLogger(UDFResourceManager.class);
-
-  /**
-   * Constructor
-   * @param context View Context instance
-   */
-  public UDFResourceManager(IStorageFactory storageFactory, ViewContext context) {
-    super(UDF.class, storageFactory, context);
-  }
-
-  @Override
-  public UDF read(Object id) throws ItemNotFound {
-    return super.read(id);
-  }
-
-  @Override
-  public List<UDF> readAll(FilteringStrategy filteringStrategy) {
-    return super.readAll(filteringStrategy);
-  }
-
-  @Override
-  public UDF create(UDF object) {
-    return super.create(object);
-  }
-
-  @Override
-  public void delete(Object resourceId) throws ItemNotFound {
-    super.delete(resourceId);
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/udfs/UDFResourceProvider.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/udfs/UDFResourceProvider.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/udfs/UDFResourceProvider.java
deleted file mode 100644
index ba83b03..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/udfs/UDFResourceProvider.java
+++ /dev/null
@@ -1,111 +0,0 @@
-/**
- * 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.ambari.view.hive.resources.udfs;
-
-import org.apache.ambari.view.*;
-import org.apache.ambari.view.hive.persistence.utils.ItemNotFound;
-import org.apache.ambari.view.hive.persistence.utils.OnlyOwnersFilteringStrategy;
-import org.apache.ambari.view.hive.utils.SharedObjectsFactory;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-import javax.inject.Inject;
-import java.lang.reflect.InvocationTargetException;
-import java.util.HashSet;
-import java.util.Map;
-import java.util.Set;
-
-/**
- * Resource provider for udf
- */
-public class UDFResourceProvider implements ResourceProvider<UDF> {
-  @Inject
-  ViewContext context;
-
-  protected UDFResourceManager resourceManager = null;
-  protected final static Logger LOG =
-      LoggerFactory.getLogger(UDFResourceProvider.class);
-
-
-  protected synchronized UDFResourceManager getResourceManager() {
-    if (resourceManager == null) {
-      resourceManager = new UDFResourceManager(new SharedObjectsFactory(context), context);
-    }
-    return resourceManager;
-  }
-
-  @Override
-  public UDF getResource(String resourceId, Set<String> properties) throws SystemException, NoSuchResourceException, UnsupportedPropertyException {
-    try {
-      return getResourceManager().read(resourceId);
-    } catch (ItemNotFound itemNotFound) {
-      throw new NoSuchResourceException(resourceId);
-    }
-  }
-
-  @Override
-  public Set<UDF> getResources(ReadRequest readRequest) throws SystemException, NoSuchResourceException, UnsupportedPropertyException {
-    if (context == null) {
-      return new HashSet<UDF>();
-    }
-    return new HashSet<UDF>(getResourceManager().readAll(
-        new OnlyOwnersFilteringStrategy(this.context.getUsername())));
-  }
-
-  @Override
-  public void createResource(String s, Map<String, Object> stringObjectMap) throws SystemException, ResourceAlreadyExistsException, NoSuchResourceException, UnsupportedPropertyException {
-    UDF item = null;
-    try {
-      item = new UDF(stringObjectMap);
-    } catch (InvocationTargetException e) {
-      throw new SystemException("error on creating resource", e);
-    } catch (IllegalAccessException e) {
-      throw new SystemException("error on creating resource", e);
-    }
-    getResourceManager().create(item);
-  }
-
-  @Override
-  public boolean updateResource(String resourceId, Map<String, Object> stringObjectMap) throws SystemException, NoSuchResourceException, UnsupportedPropertyException {
-    UDF item = null;
-    try {
-      item = new UDF(stringObjectMap);
-    } catch (InvocationTargetException e) {
-      throw new SystemException("error on updating resource", e);
-    } catch (IllegalAccessException e) {
-      throw new SystemException("error on updating resource", e);
-    }
-    try {
-      getResourceManager().update(item, resourceId);
-    } catch (ItemNotFound itemNotFound) {
-      throw new NoSuchResourceException(resourceId);
-    }
-    return true;
-  }
-
-  @Override
-  public boolean deleteResource(String resourceId) throws SystemException, NoSuchResourceException, UnsupportedPropertyException {
-    try {
-      getResourceManager().delete(resourceId);
-    } catch (ItemNotFound itemNotFound) {
-      throw new NoSuchResourceException(resourceId);
-    }
-    return true;
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/udfs/UDFService.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/udfs/UDFService.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/udfs/UDFService.java
deleted file mode 100644
index 8082e00..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/udfs/UDFService.java
+++ /dev/null
@@ -1,193 +0,0 @@
-/**
- * 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.ambari.view.hive.resources.udfs;
-
-import org.apache.ambari.view.ViewResourceHandler;
-import org.apache.ambari.view.hive.BaseService;
-import org.apache.ambari.view.hive.persistence.utils.ItemNotFound;
-import org.apache.ambari.view.hive.persistence.utils.OnlyOwnersFilteringStrategy;
-import org.apache.ambari.view.hive.resources.resources.FileResourceResourceManager;
-import org.apache.ambari.view.hive.utils.NotFoundFormattedException;
-import org.apache.ambari.view.hive.utils.ServiceFormattedException;
-import org.json.simple.JSONObject;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-import javax.inject.Inject;
-import javax.servlet.http.HttpServletResponse;
-import javax.ws.rs.*;
-import javax.ws.rs.core.Context;
-import javax.ws.rs.core.MediaType;
-import javax.ws.rs.core.Response;
-import javax.ws.rs.core.UriInfo;
-import java.util.List;
-
-/**
- * Servlet for UDFs
- * API:
- * GET /:id
- *      read udf
- * POST /
- *      create new udf
- * GET /
- *      get all udf of current user
- */
-public class UDFService extends BaseService {
-  @Inject
-  ViewResourceHandler handler;
-
-  protected UDFResourceManager resourceManager = null;
-  protected FileResourceResourceManager fileResourceResourceManager = null;
-  protected final static Logger LOG =
-      LoggerFactory.getLogger(UDFService.class);
-
-  protected synchronized UDFResourceManager getResourceManager() {
-    if (resourceManager == null) {
-      resourceManager = new UDFResourceManager(getSharedObjectsFactory(), context);
-    }
-    return resourceManager;
-  }
-
-  protected synchronized FileResourceResourceManager getFileResourceResourceManager() {
-    if (fileResourceResourceManager == null) {
-      fileResourceResourceManager = new FileResourceResourceManager(getSharedObjectsFactory(), context);
-    }
-    return fileResourceResourceManager;
-  }
-
-  /**
-   * Get single item
-   */
-  @GET
-  @Path("{id}")
-  @Produces(MediaType.APPLICATION_JSON)
-  public Response getOne(@PathParam("id") String id) {
-    try {
-      UDF udf = getResourceManager().read(id);
-      JSONObject object = new JSONObject();
-      object.put("udf", udf);
-      return Response.ok(object).build();
-    } catch (WebApplicationException ex) {
-      throw ex;
-    } catch (ItemNotFound itemNotFound) {
-      throw new NotFoundFormattedException(itemNotFound.getMessage(), itemNotFound);
-    } catch (Exception ex) {
-      throw new ServiceFormattedException(ex.getMessage(), ex);
-    }
-  }
-
-  /**
-   * Delete single item
-   */
-  @DELETE
-  @Path("{id}")
-  public Response delete(@PathParam("id") String id) {
-    try {
-      getResourceManager().delete(id);
-      return Response.status(204).build();
-    } catch (WebApplicationException ex) {
-      throw ex;
-    } catch (ItemNotFound itemNotFound) {
-      throw new NotFoundFormattedException(itemNotFound.getMessage(), itemNotFound);
-    } catch (Exception ex) {
-      throw new ServiceFormattedException(ex.getMessage(), ex);
-    }
-  }
-
-  /**
-   * Get all UDFs
-   */
-  @GET
-  @Produces(MediaType.APPLICATION_JSON)
-  public Response getList() {
-    try {
-      LOG.debug("Getting all udf");
-      List items = getResourceManager().readAll(
-          new OnlyOwnersFilteringStrategy(this.context.getUsername()));  //TODO: move strategy to PersonalCRUDRM
-
-      JSONObject object = new JSONObject();
-      object.put("udfs", items);
-      return Response.ok(object).build();
-    } catch (WebApplicationException ex) {
-      throw ex;
-    } catch (Exception ex) {
-      throw new ServiceFormattedException(ex.getMessage(), ex);
-    }
-  }
-
-  /**
-   * Update item
-   */
-  @PUT
-  @Path("{id}")
-  @Consumes(MediaType.APPLICATION_JSON)
-  public Response update(UDFRequest request,
-                         @PathParam("id") String id) {
-    try {
-      if (request.udf.getFileResource() != null)
-        getFileResourceResourceManager().read(request.udf.getFileResource());
-      getResourceManager().update(request.udf, id);
-      return Response.status(204).build();
-    } catch (WebApplicationException ex) {
-      throw ex;
-    } catch (ItemNotFound itemNotFound) {
-      throw new NotFoundFormattedException(itemNotFound.getMessage(), itemNotFound);
-    } catch (Exception ex) {
-      throw new ServiceFormattedException(ex.getMessage(), ex);
-    }
-  }
-
-  /**
-   * Create udf
-   */
-  @POST
-  @Consumes(MediaType.APPLICATION_JSON)
-  public Response create(UDFRequest request, @Context HttpServletResponse response,
-                         @Context UriInfo ui) {
-    try {
-      if (request.udf.getFileResource() != null)
-        getFileResourceResourceManager().read(request.udf.getFileResource());
-      getResourceManager().create(request.udf);
-
-      UDF item = null;
-
-      item = getResourceManager().read(request.udf.getId());
-
-      response.setHeader("Location",
-          String.format("%s/%s", ui.getAbsolutePath().toString(), request.udf.getId()));
-
-      JSONObject object = new JSONObject();
-      object.put("udf", item);
-      return Response.ok(object).status(201).build();
-    } catch (WebApplicationException ex) {
-      throw ex;
-    } catch (ItemNotFound itemNotFound) {
-      throw new NotFoundFormattedException(itemNotFound.getMessage(), itemNotFound);
-    } catch (Exception ex) {
-      throw new ServiceFormattedException(ex.getMessage(), ex);
-    }
-  }
-
-  /**
-   * Wrapper object for json mapping
-   */
-  public static class UDFRequest {
-    public UDF udf;
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/CSVParams.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/CSVParams.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/CSVParams.java
deleted file mode 100644
index 355ed6a..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/CSVParams.java
+++ /dev/null
@@ -1,74 +0,0 @@
-/**
- * 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
- * <p/>
- * http://www.apache.org/licenses/LICENSE-2.0
- * <p/>
- * 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.ambari.view.hive.resources.uploads;
-
-import java.io.Serializable;
-
-public class CSVParams implements Serializable {
-
-  public static final char DEFAULT_DELIMITER_CHAR = ',';
-  public static final char DEFAULT_ESCAPE_CHAR = '\\';
-  public static final char DEFAULT_QUOTE_CHAR = '"';
-
-  private Character csvDelimiter;
-  private Character csvEscape;
-  private Character csvQuote;
-
-  public CSVParams() {
-  }
-
-  public CSVParams(Character csvDelimiter, Character csvQuote, Character csvEscape) {
-    this.csvDelimiter = csvDelimiter;
-    this.csvQuote = csvQuote;
-    this.csvEscape = csvEscape;
-  }
-
-  public Character getCsvDelimiter() {
-    return csvDelimiter;
-  }
-
-  public void setCsvDelimiter(Character csvDelimiter) {
-    this.csvDelimiter = csvDelimiter;
-  }
-
-  public Character getCsvEscape() {
-    return csvEscape;
-  }
-
-  public void setCsvEscape(Character csvEscape) {
-    this.csvEscape = csvEscape;
-  }
-
-  public Character getCsvQuote() {
-    return csvQuote;
-  }
-
-  public void setCsvQuote(Character csvQuote) {
-    this.csvQuote = csvQuote;
-  }
-
-  @Override
-  public String toString() {
-    return "CSVParams{" +
-      "csvDelimiter='" + csvDelimiter + '\'' +
-      ", csvEscape='" + csvEscape + '\'' +
-      ", csvQuote='" + csvQuote + '\'' +
-      '}';
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/ColumnDescriptionImpl.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/ColumnDescriptionImpl.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/ColumnDescriptionImpl.java
deleted file mode 100644
index 229b7ed..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/ColumnDescriptionImpl.java
+++ /dev/null
@@ -1,142 +0,0 @@
-/**
- * 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
- * <p/>
- * http://www.apache.org/licenses/LICENSE-2.0
- * <p/>
- * 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.ambari.view.hive.resources.uploads;
-
-import org.apache.ambari.view.hive.client.ColumnDescription;
-
-import java.io.Serializable;
-
-/**
- * implementation of ColumnDescription which also includes scale and precision.
- */
-public class ColumnDescriptionImpl implements ColumnDescription, Serializable {
-  private String name;
-  private String type;
-  private int position;
-  /**
-   * can be null
-   */
-  private Integer precision;
-  /**
-   * can be null
-   */
-  private Integer scale;
-
-  public ColumnDescriptionImpl() {
-  }
-
-  public ColumnDescriptionImpl(String name, String type, int position) {
-    this.name = name;
-    this.type = type;
-    this.position = position;
-  }
-
-  public ColumnDescriptionImpl(String name, String type, int position, int precision) {
-    this.name = name;
-    this.type = type;
-    this.position = position;
-    this.precision = precision;
-  }
-
-  public ColumnDescriptionImpl(String name, String type, int position, int precision, int scale) {
-    this.name = name;
-    this.type = type;
-    this.position = position;
-    this.precision = precision;
-    this.scale = scale;
-  }
-
-  @Override
-  public String getName() {
-    return name;
-  }
-
-  @Override
-  public void setName(String name) {
-    this.name = name;
-  }
-
-  @Override
-  public String getType() {
-    return type;
-  }
-
-  @Override
-  public void setType(String type) {
-    this.type = type;
-  }
-
-  @Override
-  public int getPosition() {
-    return this.position;
-  }
-
-  @Override
-  public void setPosition(int position) {
-    this.position = position;
-  }
-
-  public Integer getPrecision() {
-    return precision;
-  }
-
-  public Integer getScale() {
-    return scale;
-  }
-
-  public void setPrecision(Integer precision) {
-    this.precision = precision;
-  }
-
-  public void setScale(Integer scale) {
-    this.scale = scale;
-  }
-
-  @Override
-  public boolean equals(Object o) {
-    if (this == o) return true;
-    if (o == null || getClass() != o.getClass()) return false;
-
-    ColumnDescriptionImpl that = (ColumnDescriptionImpl) o;
-
-    if (position != that.position) return false;
-    if (!name.equals(that.name)) return false;
-    return type.equals(that.type);
-
-  }
-
-  @Override
-  public int hashCode() {
-    int result = name.hashCode();
-    result = 31 * result + type.hashCode();
-    result = 31 * result + position;
-    return result;
-  }
-
-  @Override
-  public String toString() {
-    return new StringBuilder().append("ColumnDescriptionImpl[")
-            .append("name : ").append(name)
-            .append(", type : " + type)
-            .append(", position : " + position)
-            .append(", precision : " + precision)
-            .append(", scale : " + scale)
-            .append("]").toString();
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/HiveFileType.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/HiveFileType.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/HiveFileType.java
deleted file mode 100644
index 6cc1d46..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/HiveFileType.java
+++ /dev/null
@@ -1,30 +0,0 @@
-
-/**
- * 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
- * <p/>
- * http://www.apache.org/licenses/LICENSE-2.0
- * <p/>
- * 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.ambari.view.hive.resources.uploads;
-
-public enum HiveFileType {
-  SEQUENCEFILE,
-  TEXTFILE,
-  RCFILE,
-  ORC,
-  PARQUET,
-  AVRO,
-  INPUTFORMAT;
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/TableDataReader.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/TableDataReader.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/TableDataReader.java
deleted file mode 100644
index 7725719..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/TableDataReader.java
+++ /dev/null
@@ -1,111 +0,0 @@
-/**
- * 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
- * <p/>
- * http://www.apache.org/licenses/LICENSE-2.0
- * <p/>
- * 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.ambari.view.hive.resources.uploads;
-
-import com.opencsv.CSVWriter;
-import org.apache.ambari.view.hive.client.ColumnDescription;
-import org.apache.ambari.view.hive.client.Row;
-import org.apache.commons.codec.binary.Hex;
-
-import java.io.IOException;
-import java.io.Reader;
-import java.io.StringReader;
-import java.io.StringWriter;
-import java.util.Iterator;
-import java.util.List;
-
-/**
- * Takes row iterator as input.
- * iterate over rows and creates a CSV formated stream separating rows by endline "\n"
- * Note : column values should not contain "\n".
- */
-public class TableDataReader extends Reader {
-
-  private static final int CAPACITY = 1024;
-  private final List<ColumnDescriptionImpl> header;
-  private StringReader stringReader = new StringReader("");
-
-  private Iterator<Row> iterator;
-  private boolean encode = false;
-  public static final char CSV_DELIMITER = '\001';
-
-  public TableDataReader(Iterator<Row> rowIterator, List<ColumnDescriptionImpl> header, boolean encode) {
-    this.iterator = rowIterator;
-    this.encode = encode;
-    this.header = header;
-  }
-
-  @Override
-  public int read(char[] cbuf, int off, int len) throws IOException {
-
-    int totalLen = len;
-    int count = 0;
-    do {
-      int n = stringReader.read(cbuf, off, len);
-
-      if (n != -1) {
-        // n  were read
-        len = len - n; // len more to be read
-        off = off + n; // off now shifted to n more
-        count += n;
-      }
-
-      if (count == totalLen) return count; // all totalLen characters were read
-
-      if (iterator.hasNext()) { // keep reading as long as we keep getting rows
-        StringWriter stringWriter = new StringWriter(CAPACITY);
-        CSVWriter csvPrinter = new CSVWriter(stringWriter,CSV_DELIMITER);
-        Row row = iterator.next();
-        // encode values so that \n and \r are overridden
-        Object[] columnValues = row.getRow();
-        String[] columns = new String[columnValues.length];
-
-        for(int i = 0; i < columnValues.length; i++){
-          String type = header.get(i).getType();
-          if(this.encode &&
-              (
-                ColumnDescription.DataTypes.STRING.toString().equals(type)
-                || ColumnDescription.DataTypes.VARCHAR.toString().equals(type)
-                || ColumnDescription.DataTypes.CHAR.toString().equals(type)
-              )
-            ){
-            columns[i] = Hex.encodeHexString(((String)columnValues[i]).getBytes()); //default charset
-          }else {
-            columns[i] = (String) columnValues[i];
-          }
-        }
-
-        csvPrinter.writeNext(columns,false);
-        stringReader.close(); // close the old string reader
-        stringReader = new StringReader(stringWriter.getBuffer().toString());
-        csvPrinter.close();
-        stringWriter.close();
-      } else {
-        return count == 0 ? -1 : count;
-      }
-    } while (count < totalLen);
-
-    return count;
-  }
-
-  @Override
-  public void close() throws IOException {
-
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/TableInput.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/TableInput.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/TableInput.java
deleted file mode 100644
index 1d5adf4..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/TableInput.java
+++ /dev/null
@@ -1,51 +0,0 @@
-/**
- * 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
- * <p/>
- * http://www.apache.org/licenses/LICENSE-2.0
- * <p/>
- * 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.ambari.view.hive.resources.uploads;
-
-import org.apache.ambari.view.hive.resources.uploads.query.TableInfo;
-
-/**
- * used as input in REST call
- */
-class TableInput extends TableInfo {
-  public Boolean isFirstRowHeader = Boolean.FALSE;
-
-  public TableInput() {
-  }
-
-  public Boolean getIsFirstRowHeader() {
-    return isFirstRowHeader;
-  }
-
-  public void setIsFirstRowHeader(Boolean isFirstRowHeader) {
-    this.isFirstRowHeader = isFirstRowHeader;
-  }
-
-  public void validate(){
-    if( null == this.getHiveFileType()){
-      throw new IllegalArgumentException("fileType parameter cannot be null.");
-    }
-    if( null == this.getTableName()){
-      throw new IllegalArgumentException("tableName parameter cannot be null.");
-    }
-    if( null == this.getDatabaseName()){
-      throw new IllegalArgumentException("databaseName parameter cannot be null.");
-    }
-  }
-}


[09/23] ambari git commit: AMBARI-19302 : removed contrib/views/hive folder and made necessary changes in pom.xml files (nitirajrathore)

Posted by ni...@apache.org.
http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/config/environment.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/config/environment.js b/contrib/views/hive/src/main/resources/ui/hive-web/config/environment.js
deleted file mode 100644
index 992d91c..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/config/environment.js
+++ /dev/null
@@ -1,70 +0,0 @@
-/**
- * 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.
- */
-
-/* jshint node: true */
-
-module.exports = function(environment) {
-  var ENV = {
-    modulePrefix: 'hive',
-    environment: environment,
-    baseURL: '/',
-    locationType: 'hash',
-    EmberENV: {
-      FEATURES: {
-        // Here you can enable experimental features on an ember canary build
-        // e.g. 'with-controller': true
-      }
-    },
-
-    contentSecurityPolicy: {
-      'connect-src': "'self' ws://localhost:35729 ws://0.0.0.0:35729",
-      'style-src': "'self' 'unsafe-inline'"
-    },
-
-    APP: {
-      // Here you can pass flags/options to your application instance
-      // when it is created
-    }
-  };
-
-  if (environment === 'development') {
-    // ENV.APP.LOG_RESOLVER = true;
-    ENV.APP.LOG_ACTIVE_GENERATION = true;
-    // ENV.APP.LOG_TRANSITIONS = true;
-    // ENV.APP.LOG_TRANSITIONS_INTERNAL = true;
-    ENV.APP.LOG_VIEW_LOOKUPS = true;
-  }
-
-  if (environment === 'test') {
-    // Testem prefers this...
-    ENV.baseURL = '/';
-    ENV.locationType = 'auto';
-
-    // keep test console output quieter
-    ENV.APP.LOG_ACTIVE_GENERATION = false;
-    ENV.APP.LOG_VIEW_LOOKUPS = false;
-
-    ENV.APP.rootElement = '#ember-testing';
-  }
-
-  if (environment === 'production') {
-
-  }
-
-  return ENV;
-};

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/package.json
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/package.json b/contrib/views/hive/src/main/resources/ui/hive-web/package.json
deleted file mode 100644
index 6fe68e2..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/package.json
+++ /dev/null
@@ -1,47 +0,0 @@
-{
-  "name": "hive",
-  "version": "0.0.0",
-  "private": true,
-  "directories": {
-    "doc": "doc",
-    "test": "tests"
-  },
-  "scripts": {
-    "start": "ember server",
-    "build": "ember build",
-    "test": "ember test",
-    "preinstall": "chmod +x node/npm/bin/node-gyp-bin/node-gyp",
-    "postinstall": "bash node/with_new_path.sh node node_modules/.bin/bower --allow-root install"
-  },
-  "repository": "https://github.com/stefanpenner/ember-cli",
-  "engines": {
-    "node": ">= 0.10.32"
-  },
-  "author": "",
-  "license": "MIT",
-  "devDependencies": {
-    "body-parser": "^1.2.0",
-    "bower": ">= 1.3.12",
-    "broccoli-asset-rev": "^2.0.0",
-    "broccoli-sass": "^0.6.3",
-    "ember-cli": "0.2.2",
-    "ember-cli-autoprefixer": "0.4.1",
-    "ember-cli-blanket": "^0.5.0",
-    "ember-cli-content-security-policy": "0.3.0",
-    "ember-cli-font-awesome": "0.0.4",
-    "ember-cli-htmlbars": "0.7.4",
-    "ember-cli-ic-ajax": "0.1.1",
-    "ember-cli-inject-live-reload": "^1.3.0",
-    "ember-cli-jquery-ui": "0.0.12",
-    "ember-cli-moment": "0.0.1",
-    "ember-cli-pretender": "^0.3.1",
-    "ember-cli-qunit": "0.3.14",
-    "ember-cli-selectize": "0.0.19",
-    "ember-cli-uglify": "1.0.1",
-    "ember-cli-uploader": "^0.3.9",
-    "ember-data": "1.0.0-beta.16.1",
-    "ember-dynamic-component": "0.0.1",
-    "ember-export-application-global": "^1.0.0",
-    "express": "^4.8.5"
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/testem.json
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/testem.json b/contrib/views/hive/src/main/resources/ui/hive-web/testem.json
deleted file mode 100644
index 78029a1..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/testem.json
+++ /dev/null
@@ -1,10 +0,0 @@
-{
-  "framework": "qunit",
-  "test_page": "tests/index.html?hidepassed&nocontainer",
-  "launch_in_ci": [
-    "PhantomJS"
-  ],
-  "launch_in_dev": [
-    "Chrome"
-  ]
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/tests/.jshintrc
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/tests/.jshintrc b/contrib/views/hive/src/main/resources/ui/hive-web/tests/.jshintrc
deleted file mode 100644
index 6ebf71a..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/tests/.jshintrc
+++ /dev/null
@@ -1,74 +0,0 @@
-{
-  "predef": [
-    "document",
-    "window",
-    "location",
-    "setTimeout",
-    "$",
-    "-Promise",
-    "QUnit",
-    "define",
-    "console",
-    "equal",
-    "notEqual",
-    "notStrictEqual",
-    "test",
-    "asyncTest",
-    "testBoth",
-    "testWithDefault",
-    "raises",
-    "throws",
-    "deepEqual",
-    "start",
-    "stop",
-    "ok",
-    "strictEqual",
-    "module",
-    "moduleFor",
-    "moduleForComponent",
-    "moduleForModel",
-    "process",
-    "expect",
-    "visit",
-    "exists",
-    "fillIn",
-    "click",
-    "keyEvent",
-    "triggerEvent",
-    "find",
-    "findWithAssert",
-    "wait",
-    "DS",
-    "isolatedContainer",
-    "startApp",
-    "andThen",
-    "currentURL",
-    "currentPath",
-    "currentRouteName"
-  ],
-  "node": false,
-  "browser": false,
-  "boss": true,
-  "curly": false,
-  "debug": false,
-  "devel": false,
-  "eqeqeq": true,
-  "evil": true,
-  "forin": false,
-  "immed": false,
-  "laxbreak": false,
-  "newcap": true,
-  "noarg": true,
-  "noempty": false,
-  "nonew": false,
-  "nomen": false,
-  "onevar": false,
-  "plusplus": false,
-  "regexp": false,
-  "undef": true,
-  "sub": true,
-  "strict": false,
-  "white": false,
-  "eqnull": true,
-  "esnext": true
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/tests/blanket-options.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/tests/blanket-options.js b/contrib/views/hive/src/main/resources/ui/hive-web/tests/blanket-options.js
deleted file mode 100644
index 63e022b..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/tests/blanket-options.js
+++ /dev/null
@@ -1,36 +0,0 @@
-/**
- * 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.
- */
-
-/*globals blanket, module */
-
-var options = {
-  modulePrefix: "hive",
-  filter: "//.*hive/.*/",
-  antifilter: "//.*(tests|template).*/",
-  loaderExclusions: ['ember-cli-jquery-ui', 'hive/config/environment'],
-  enableCoverage: true,
-  cliOptions: {
-    reporters: ['json']
-  }
-};
-
-if (typeof exports === 'undefined') {
-  blanket.options(options);
-} else {
-  module.exports = options;
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/tests/helpers/api-mock.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/tests/helpers/api-mock.js b/contrib/views/hive/src/main/resources/ui/hive-web/tests/helpers/api-mock.js
deleted file mode 100644
index 5bf41e6..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/tests/helpers/api-mock.js
+++ /dev/null
@@ -1,304 +0,0 @@
-/**
- * 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.
- */
-
-import applicationAdapter from 'hive/adapters/database';
-
-export default function() {
-  var baseUrl = applicationAdapter.create().buildURL();
-  var databases = ['db1', 'db2', 'db3'];
-
-  this.get(baseUrl + '/resources/ddl/database', function (req) {
-    var db = {
-      databases: databases
-    };
-
-    return [200, {"Content-Type": "application/json"}, JSON.stringify(db)];
-  });
-
-  this.get(baseUrl + '/resources/ddl/database/db1/table.page', function (req) {
-    var tables = {
-      rows: [
-        ['table1'],
-        ['table2'],
-        ['table3']
-      ]
-    };
-
-    return [200, {"Content-Type": "application/json"}, JSON.stringify(tables)];
-  });
-
-  this.get(baseUrl + '/resources/ddl/database/db1/table', function (req) {
-    var tables = {
-      tables: [
-        ['table1'],
-        ['table2'],
-        ['table3']
-      ],
-      database: 'db1'
-    };
-
-    return [200, {"Content-Type": "application/json"}, JSON.stringify(tables)];
-  });
-
-  this.get(baseUrl + '/resources/ddl/database/db1/table/table1.page', function (req) {
-    var columns = {
-      rows: [
-        ['column1', 'STRING'],
-        ['column2', 'STRING'],
-        ['column3', 'STRING']
-      ]
-    };
-
-    return [200, {"Content-Type": "application/json"}, JSON.stringify(columns)];
-  });
-
-  this.get(baseUrl + '/udfs', function (req) {
-    var udf = {
-      "udfs": [{
-        "name": "TestColumn",
-        "classname": "TestClassName",
-        "fileResource": 1,
-        "id": 1,
-        "owner": "owner1"
-      },
-      {
-        "name": "Test2Columns",
-        "classname": "Test2ClassName",
-        "fileResource": 1,
-        "id": 2,
-        "owner": "owner2"
-      }]
-    };
-
-    return [200, {"Content-Type": "application/json"}, JSON.stringify(udf)];
-  });
-
-  this.post(baseUrl + '/jobs', function (req) {
-    var job = {
-      "job": {
-        "status":"Finished",
-        "dataBase":"db1",
-        "dateSubmitted":1421677418,
-        "logFile":"job1/logs",
-        "properties":{},
-        "fileResources":[],
-        "statusDir":"job1",
-        "id":1,
-        "title":"Worksheet",
-        "duration":2,
-        "forcedContent":"",
-        "owner":"admin",
-        "confFile":"job1/conf",
-        "queryId":null,
-        "queryFile":"job1.hql"
-      }
-    };
-
-    return [200, {"Content-Type": "application/json"}, JSON.stringify(job)];
-  });
-
-  this.get(baseUrl + '/resources/file/job1.hql', function (req) {
-    var file = {
-      "file": {
-        "filePath": "job1.hql",
-        "fileContent": "select * from big",
-        "hasNext": false,
-        "page": 0,
-        "pageCount": 1
-      }
-    };
-
-    return [200, {"Content-Type": "application/json"}, JSON.stringify(file)];
-  });
-
-  this.get(baseUrl + '/savedQueries', function(req) {
-    var savedQueries = {
-      "savedQueries": [{
-        "queryFile": "saved1.hql",
-        "dataBase": "db1",
-        "title": "saved1",
-        "shortQuery": "",
-        "id": 1,
-        "owner": "owner1"
-      }, {
-        "queryFile": "saved2.hql",
-        "dataBase": "db2",
-        "title": "saved2",
-        "shortQuery": "select count(field_0) from big;",
-        "id": 2,
-        "owner": "owner2"
-      }]
-    };
-
-    return [200, {"Content-Type": "application/json"}, JSON.stringify(savedQueries)];
-  });
-
-  this.get(baseUrl + '/savedQueries/defaultSettings', function (req) {
-    var defaultSettings = {
-      "defaultSettings" : []
-    };
-
-    return [200, {"Content-Type": "application/json"}, JSON.stringify(defaultSettings)];
-  });
-
-  this.get(baseUrl + '/resources/file/saved1.hql', function (req) {
-    var file = {
-      "file": {
-        "filePath": "saved1.hql",
-        "fileContent": "select * from saved1",
-        "hasNext": false,
-        "page": 0,
-        "pageCount": 0
-      }
-    };
-
-    return [200, {"Content-Type": "application/json"}, JSON.stringify(file)];
-  });
-
-  this.get(baseUrl + '/jobs', function (req) {
-    var jobs = {
-      "jobs": [
-        {
-          "title": "Query1",
-          "queryFile": "saved1.hql",
-          "statusDir": "statusdir",
-          "dateSubmitted": 1421240048,
-          "duration": 97199,
-          "status": "Finished",
-          "forcedContent": "",
-          "id": 1,
-          "owner": "admin",
-          "logFile": "logs1",
-          "confFile": "conf1"
-        },
-        {
-          "title": "Query2",
-          "queryFile": "saved1.hql",
-          "statusDir": "statusdir",
-          "dateSubmitted": 1421240048,
-          "duration": 97199,
-          "status": "Finished",
-          "forcedContent": "",
-          "id": 2,
-          "owner": "admin",
-          "logFile": "logs2",
-          "confFile": "conf2"
-        },
-        {
-          "title": "Query3",
-          "queryFile": "saved1.hql",
-          "statusDir": "statusdir",
-          "dateSubmitted": 1421240048,
-          "duration": 97199,
-          "status": "Running",
-          "forcedContent": "",
-          "id": 3,
-          "owner": "admin",
-          "logFile": "logs3",
-          "confFile": "conf3"
-        },
-        {
-          "title": "Query4",
-          "queryFile": "saved1.hql",
-          "statusDir": "statusdir",
-          "dateSubmitted": 1421240048,
-          "duration": 97199,
-          "status": "Error",
-          "forcedContent": "",
-          "id": 4,
-          "owner": "admin",
-          "logFile": "logs4",
-          "confFile": "con51"
-        }
-      ]
-    };
-
-    return [200, {"Content-Type": "application/json"}, JSON.stringify(jobs)];
-  });
-
-  this.get(baseUrl + '/fileResources', function (req) {
-    var files = {
-      "fileResources": [
-        {
-          "name": "TestName",
-          "path": "TestPath",
-          "id": 1,
-          "owner": "owner1"
-        }
-      ]
-    };
-
-    return [200, {"Content-Type": "application/json"}, JSON.stringify(files)];
-  });
-
-  this.delete(baseUrl + '/fileResources/1', function (req) {
-    return [200, {"Content-Type": "application/json"}, JSON.stringify({})];
-  });
-
-  this.put(baseUrl + '/udfs/1', function (req) {
-    return [200, {"Content-Type": "application/json"}, JSON.stringify({})];
-  });
-
-
-  this.get(baseUrl + '/fileResources/1', function (req) {
-    var files = {
-      "fileResources": [
-        {
-          "name": "TestName",
-          "path": "TestPath",
-          "id": 1,
-          "owner": "owner1"
-        }
-      ]
-    };
-
-    return [200, {"Content-Type": "application/json"}, JSON.stringify(files)];
-  });
-
-  this.get(baseUrl + '/api/v1/views/TEZ', function (req) {
-    var data = {
-      versions: [
-        {
-          href: baseUrl + '/api/v1/view/TEZ/versions/1',
-          ViewVersionInfo: {version: '1', view_name: 'TEZ'}
-        }
-      ]
-    };
-
-    return [200, {"Content-Type": "application/json"}, JSON.stringify(data)];
-  });
-
-  this.delete(baseUrl + '/savedQueries/1', function (req) {
-    return [200, {"Content-Type": "application/json"}, JSON.stringify({})];
-  });
-
-  this.get(baseUrl + '/api/v1/views/TEZ/versions/1', function (req) {
-    var data = {
-      instances: [
-        {
-          ViewInstanceInfo: {
-            instance_name: 'tez',
-            version: 1
-          }
-        }
-      ]
-    };
-
-    return [200, {"Content-Type": "application/json"}, JSON.stringify(data)];
-  });
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/tests/helpers/dbclick.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/tests/helpers/dbclick.js b/contrib/views/hive/src/main/resources/ui/hive-web/tests/helpers/dbclick.js
deleted file mode 100644
index e6dfe83..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/tests/helpers/dbclick.js
+++ /dev/null
@@ -1,26 +0,0 @@
-/**
- * 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.
- */
-
-Ember.Test.registerAsyncHelper('dblclick',
-  function (app, selector, context) {
-    var $el = findWithAssert(selector, context);
-    Ember.run(function () {
-      $el.dblclick();
-    });
-  }
-);

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/tests/helpers/resolver.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/tests/helpers/resolver.js b/contrib/views/hive/src/main/resources/ui/hive-web/tests/helpers/resolver.js
deleted file mode 100644
index f94998c..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/tests/helpers/resolver.js
+++ /dev/null
@@ -1,29 +0,0 @@
-/**
- * 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.
- */
-
-import Resolver from 'ember/resolver';
-import config from '../../config/environment';
-
-var resolver = Resolver.create();
-
-resolver.namespace = {
-  modulePrefix: config.modulePrefix,
-  podModulePrefix: config.podModulePrefix
-};
-
-export default resolver;

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/tests/helpers/start-app.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/tests/helpers/start-app.js b/contrib/views/hive/src/main/resources/ui/hive-web/tests/helpers/start-app.js
deleted file mode 100644
index ab1a9d2..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/tests/helpers/start-app.js
+++ /dev/null
@@ -1,43 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-import Application from '../../app';
-import Router from '../../router';
-import config from '../../config/environment';
-
-export default function startApp(attrs) {
-  var App;
-
-  var attributes = Ember.merge({}, config.APP);
-  attributes = Ember.merge(attributes, attrs); // use defaults, but you can override;
-
-  Router.reopen({
-    location: 'none'
-  });
-
-  Ember.run(function() {
-    App = Application.create(attributes);
-    App.setupForTesting();
-    App.injectTestHelpers();
-  });
-
-  // App.reset(); // this shouldn't be needed, i want to be able to "start an app at a specific URL"
-
-  return App;
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/tests/img/spinner.gif
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/tests/img/spinner.gif b/contrib/views/hive/src/main/resources/ui/hive-web/tests/img/spinner.gif
deleted file mode 100644
index e921e36..0000000
Binary files a/contrib/views/hive/src/main/resources/ui/hive-web/tests/img/spinner.gif and /dev/null differ

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/tests/index.html
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/tests/index.html b/contrib/views/hive/src/main/resources/ui/hive-web/tests/index.html
deleted file mode 100644
index 9faecc6..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/tests/index.html
+++ /dev/null
@@ -1,71 +0,0 @@
-<!--
- * 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.
--->
-<!DOCTYPE html>
-<html>
-  <head>
-    <meta charset="utf-8">
-    <meta http-equiv="X-UA-Compatible" content="IE=edge">
-    <title>Hive Tests</title>
-    <meta name="description" content="">
-    <meta name="viewport" content="width=device-width, initial-scale=1">
-
-    {{content-for 'head'}}
-    {{content-for 'test-head'}}
-
-    <link rel="stylesheet" href="assets/vendor.css">
-    <link rel="stylesheet" href="assets/hive.css">
-    <link rel="stylesheet" href="assets/test-support.css">
-    <style>#blanket-main { position: relative; z-index: 99999; }</style>
-    <style>
-      #ember-testing-container {
-        position: absolute;
-        background: white;
-        bottom: 0;
-        right: 0;
-        width: 640px;
-        height: 384px;
-        overflow: auto;
-        z-index: 9999;
-        border: 1px solid #ccc;
-      }
-      #ember-testing {
-        zoom: 50%;
-      }
-    </style>
-
-    {{content-for 'head-footer'}}
-    {{content-for 'test-head-footer'}}
-  </head>
-  <body>
-    <div id="qunit"></div>
-    <div id="qunit-fixture"></div>
-
-    {{content-for 'body'}}
-    {{content-for 'test-body'}}
-    <script src="assets/vendor.js"></script>
-    <script src="assets/test-support.js"></script>
-    <script src="assets/hive.js"></script>
-    <script src="assets/blanket-options.js"></script>
-    <script src="assets/blanket-loader.js"></script>
-    <script src="testem.js"></script>
-    <script src="assets/test-loader.js"></script>
-
-    {{content-for 'body-footer'}}
-    {{content-for 'test-body-footer'}}
-  </body>
-</html>

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/tests/integration/database-test.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/tests/integration/database-test.js b/contrib/views/hive/src/main/resources/ui/hive-web/tests/integration/database-test.js
deleted file mode 100644
index 1af72c8..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/tests/integration/database-test.js
+++ /dev/null
@@ -1,130 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-import { test } from 'ember-qunit';
-import startApp from '../helpers/start-app';
-import api from '../helpers/api-mock';
-
-var App;
-var server;
-
-module('Integration: Databases', {
-  setup: function() {
-    App = startApp();
-    /* global Pretender: true */
-    server = new Pretender(api);
-  },
-  teardown: function() {
-    Ember.run(App, App.destroy);
-    server.shutdown();
-  }
-});
-
-test('Database Explorer is displayed and populated with databases from server.', function (assert) {
-  assert.expect(2);
-
-  visit('/');
-
-  andThen(function() {
-    equal(find('.database-explorer').length, 1, 'Databases panel is visible.');
-    equal(find('.database-explorer .databases').children().length, 3, 'Databases are listed.');
-  });
-});
-
-test('Expanding a database will retrieve the first page of tables for that database.', function () {
-  expect(1);
-
-  visit('/');
-
-  andThen(function () {
-    var targetDB = find('.fa-database').first();
-
-    click(targetDB);
-
-    andThen(function () {
-      equal(find('.fa-table').length, 3);
-    });
-  });
-});
-
-test('Expanding a table will retrieve the first page of columns for that table.', function () {
-  expect(2);
-
-  visit('/');
-
-  andThen(function () {
-    var targetDB = find('.fa-database').first();
-
-    click(targetDB);
-
-    andThen(function () {
-      var targetTable = find('.fa-table').first();
-
-      click(targetTable);
-
-      andThen(function () {
-        equal(find('.columns').length, 1, 'Columns container was loaded.');
-        equal(find('.columns strong').length, 3, '3 columns were loaded for selected table.');
-      });
-    });
-  });
-});
-
-test('Searching for a table will display table results and column search field', function () {
-  expect(2);
-
-  visit('/');
-
-  andThen(function () {
-    fillIn(find('input').first(), 'table');
-    keyEvent(find('input').first(), 'keyup', 13);
-
-    andThen(function () {
-      equal(find('input').length, 2, 'Columns search input has been rendered.');
-      equal(find('.nav-tabs li').length, 2, 'Results tab has been redendered.');
-    });
-  });
-});
-
-
-test('Users can search tables', function (assert) {
-  assert.expect(4);
-
-  visit('/');
-
-  andThen(function () {
-    fillIn(find('.database-explorer .search-tables-text'), 'not_found');
-    keyEvent(find('.database-explorer .search-tables-text'), 'keyup', 13);
-  });
-
-  andThen(function () {
-    assert.ok(find('.alert-warning .database-explorer-alert'), 'Alert is show when a table is not found');
-  });
-
-  andThen(function () {
-    fillIn(find('.database-explorer .search-tables-text'), 'table');
-    keyEvent(find('.database-explorer .search-tables-text'), 'keyup', 13);
-  });
-
-  andThen(function () {
-    assert.ok(find('.database-explorer .nav-tabs li:last').hasClass('active'), 'Search results tab is active');
-    assert.ok(find('.database-explorer .databases .fa-database').length, 'Found databases are shown');
-    assert.ok(find('.database-explorer .databases .tables').length, 'Found tables are shown');
-  });
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/tests/integration/history-test.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/tests/integration/history-test.js b/contrib/views/hive/src/main/resources/ui/hive-web/tests/integration/history-test.js
deleted file mode 100644
index 35a950d..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/tests/integration/history-test.js
+++ /dev/null
@@ -1,95 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-import { test } from 'ember-qunit';
-import startApp from '../helpers/start-app';
-import api from '../helpers/api-mock';
-
-var App;
-var server;
-
-module('Integration: History', {
-  setup: function() {
-    App = startApp();
-    /* global Pretender: true */
-    server = new Pretender(api);
-  },
-
-  teardown: function() {
-    Ember.run(App, App.destroy);
-    server.shutdown();
-  }
-});
-
-test('Save Queries should list saved queries', function() {
-  expect(1);
-
-  visit("/history");
-
-  andThen(function() {
-    equal(find('#content .table tbody tr').length, 4);
-  });
-});
-
-test('User should be able to filter the jobs', function() {
-  expect(4);
-
-  visit("/history");
-
-  fillIn('column-filter input[placeholder=title]', "Query1");
-  keyEvent('column-filter input[placeholder=title]', 'keyup');
-
-  andThen(function() {
-    equal(find('#content .table tbody tr:visible').length, 1, 'User is able to filter by title');
-  });
-
-  click('.clear-filters');
-  andThen(function() {
-    equal(find('#content .table tbody tr:visible').length, 4);
-  });
-
-
-  fillIn('column-filter input[placeholder=status]', "Finished");
-  keyEvent('column-filter input[placeholder=status]', 'keyup');
-
-  andThen(function() {
-    equal(find('#content .table tbody tr:visible').length, 2, 'User is able to filter by status');
-  });
-
-  click('.clear-filters');
-  andThen(function() {
-    equal(find('#content .table tbody tr:visible').length, 4);
-  });
-});
-
-test('A query item should expand to show the HQL', function() {
-  expect(3);
-  visit("/history");
-
-  andThen(function() {
-    equal(find('.table-expandable tbody .secondary-row').length, 0, 'All queries are collapsed');
-  });
-
-  click('.table-expandable tbody tr:first-child');
-
-  andThen(function() {
-    equal(find('.table-expandable tbody .secondary-row').length, 1, 'One query is expanded');
-    ok(find('.table-expandable tbody tr:first-child').next().hasClass('secondary-row'), 'Clicked query is expanded');
-  });
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/tests/integration/query-editor-test.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/tests/integration/query-editor-test.js b/contrib/views/hive/src/main/resources/ui/hive-web/tests/integration/query-editor-test.js
deleted file mode 100644
index 3073013..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/tests/integration/query-editor-test.js
+++ /dev/null
@@ -1,126 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-import { test } from 'ember-qunit';
-import startApp from '../helpers/start-app';
-import api from '../helpers/api-mock';
-import '../helpers/dbclick';
-
-var App;
-var server;
-
-module('Integration: Query Editor', {
-  setup: function() {
-    App = startApp();
-    /* global Pretender: true */
-    server = new Pretender(api);
-  },
-
-  teardown: function() {
-    Ember.run(App, App.destroy);
-    server.shutdown();
-  }
-});
-
-test('Query Editor is visible', function() {
-  expect(1);
-
-  visit("/");
-
-  andThen(function() {
-    equal(find('.query-editor-panel').length, 1, 'Query Editor is visible');
-  });
-});
-
-test('Can execute query either with full or partial selection', function() {
-  expect(3);
-
-  var query1 = "select count(*) from table1;",
-      query2 = "select color from z;",
-      query3 = "select fruit from z;",
-      query4 = query2 + "\n" + query3,
-      editor;
-
-  visit("/");
-
-  Ember.run(function() {
-    editor = find('.CodeMirror').get(0).CodeMirror;
-    editor.setValue(query1);
-  });
-
-  click('.execute-query');
-
-  andThen(function() {
-    equal(find('.query-process-results-panel').length, 1, 'Job tabs are visible.');
-  });
-
-  Ember.run(function() {
-    editor.setValue(query4);
-    editor.setSelection({ line: 1, ch: 0 }, { line: 1, ch: 20 });
-  });
-
-  click('.execute-query');
-
-  andThen(function() {
-    equal(editor.getValue(), query4, 'Editor value didn\'t change');
-    equal(editor.getSelection(), query3, 'Query 3 is selected');
-  });
-});
-
-
-test('Can save query', function() {
-  expect(2);
-
-  visit("/");
-
-  andThen(function() {
-    equal(find('.modal-dialog').length, 0, 'Modal dialog is hidden');
-  });
-
-  Ember.run(function() {
-    find('.CodeMirror').get(0).CodeMirror.setValue('select count(*) from table1');
-  });
-
-  click('.save-query-as');
-
-  andThen(function() {
-    equal(find('.modal-dialog').length, 1, 'Modal dialog is shown');
-  });
-
-  click('.modal-footer .btn-danger');
-});
-
-test('Can change tab title', function (assert) {
-  assert.expect(1);
-
-  visit('/');
-
-  andThen(function () {
-    dblclick('.query-editor-panel tabs li:first a');
-
-    andThen(function () {
-      fillIn('.modal-body input', 'WS');
-      click('.modal-footer .btn-success');
-
-      andThen(function () {
-        assert.equal(find('.query-editor-panel tabs li:first a').text().trim(), 'WS', 'Tab renamed');
-      });
-    });
-  });
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/tests/integration/saved-queries-test.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/tests/integration/saved-queries-test.js b/contrib/views/hive/src/main/resources/ui/hive-web/tests/integration/saved-queries-test.js
deleted file mode 100644
index fdbcd4e..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/tests/integration/saved-queries-test.js
+++ /dev/null
@@ -1,152 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-import { test } from 'ember-qunit';
-import startApp from '../helpers/start-app';
-import api from '../helpers/api-mock';
-
-var App;
-var server;
-
-module('Integration: Saved Queries', {
-  setup: function() {
-    App = startApp();
-    /* global Pretender: true */
-    server = new Pretender(api);
-  },
-
-  teardown: function() {
-    Ember.run(App, App.destroy);
-    server.shutdown();
-  }
-});
-
-test('Save Queries should list saved queries', function() {
-  expect(1);
-
-  visit("/queries");
-
-
-  andThen(function() {
-    equal(find('#content .table tbody tr').length, 2);
-  });
-});
-
-test('User should be able to filter the queries', function() {
-  expect(8);
-
-  visit("/queries");
-
-  fillIn('column-filter input[placeholder=preview]', "select count");
-  keyEvent('column-filter input[placeholder=preview]', 'keyup');
-
-  andThen(function() {
-    equal(find('#content .table tbody tr:visible').length, 1, 'User is able to filter by short query form.');
-  });
-
-  click('.clear-filters');
-  andThen(function() {
-    equal(find('#content .table tbody tr:visible').length, 2);
-  });
-
-  fillIn('column-filter input[placeholder=title]', "saved1");
-  keyEvent('column-filter input[placeholder=title]', 'keyup');
-
-  andThen(function() {
-    equal(find('#content .table tbody tr:visible').length, 1, 'User is able to filter by title');
-  });
-
-  click('.clear-filters');
-  andThen(function() {
-    equal(find('#content .table tbody tr:visible').length, 2);
-  });
-
-  fillIn('column-filter input[placeholder=database]', "db1");
-  keyEvent('column-filter input[placeholder=database]', 'keyup');
-
-  andThen(function() {
-    equal(find('#content .table tbody tr:visible').length, 1, 'User is able to filter by database');
-  });
-
-  click('.clear-filters');
-  andThen(function() {
-    equal(find('#content .table tbody tr:visible').length, 2);
-  });
-
-  fillIn('column-filter input[placeholder=owner]', "owner1");
-  keyEvent('column-filter input[placeholder=owner]', 'keyup');
-
-  andThen(function() {
-    equal(find('#content .table tbody tr:visible').length, 1, 'User is able to filter by owner');
-  });
-
-  click('.clear-filters');
-  andThen(function() {
-    equal(find('#content .table tbody tr:visible').length, 2);
-  });
-});
-
-test('User is able to load a query from saved queries', function() {
-  expect(1);
-
-  visit("/queries");
-  click('#content .table tbody tr:first-child td:first-child a');
-
-  andThen(function() {
-    equal(currentURL(), "/queries/1", 'User is redirected');
-  });
-});
-
-test('Saved Query options menu', function() {
-  expect(2);
-
-  visit("/queries");
-  click('.fa-gear:first');
-
-  andThen(function() {
-    equal(find('.dropdown-menu:visible').length, 1, 'Query menu is visible');
-    equal(find('.dropdown-menu:visible li').length, 2, 'Query menu has 2 options');
-  });
-});
-
-test('User is able to see history for a query', function (assert) {
-  assert.expect(2);
-
-  visit("/queries");
-  click('.fa-gear:first');
-  click('.dropdown-menu:visible li:first');
-
-  andThen(function () {
-    assert.equal(currentURL(), "/history", 'User is redirected to history');
-    assert.equal(find('#content .table tbody tr').length, 1, 'Queries are filtered');
-  });
-});
-
-test('User is able to delete a query', function (assert) {
-  assert.expect(1);
-
-  visit("/queries");
-  click('.fa-gear:first');
-  click('.dropdown-menu:visible li:last');
-  click('.modal-footer .btn-success');
-
-  andThen(function () {
-    equal(find('#content .table tbody tr').length, 1, 'Query deleted');
-  });
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/tests/integration/tez-ui-test.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/tests/integration/tez-ui-test.js b/contrib/views/hive/src/main/resources/ui/hive-web/tests/integration/tez-ui-test.js
deleted file mode 100644
index f64dcb2..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/tests/integration/tez-ui-test.js
+++ /dev/null
@@ -1,49 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-import { test } from 'ember-qunit';
-import startApp from '../helpers/start-app';
-import api from '../helpers/api-mock';
-
-var App;
-var server;
-
-module('Integration: Tez UI', {
-  setup: function() {
-    App = startApp();
-    /* global Pretender: true */
-    server = new Pretender(api);
-  },
-
-  teardown: function() {
-    Ember.run(App, App.destroy);
-    server.shutdown();
-  }
-});
-
-test('An error is show when there is no dag', function() {
-  expect(1);
-
-  visit("/");
-  click('#tez-icon');
-
-  andThen(function() {
-    ok(find('.panel .alert .alert-danger'), 'Error is visible');
-  });
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/tests/integration/udfs-test.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/tests/integration/udfs-test.js b/contrib/views/hive/src/main/resources/ui/hive-web/tests/integration/udfs-test.js
deleted file mode 100644
index 526efc0..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/tests/integration/udfs-test.js
+++ /dev/null
@@ -1,109 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-import { test } from 'ember-qunit';
-import startApp from '../helpers/start-app';
-import api from '../helpers/api-mock';
-
-var App;
-var server;
-
-module('Integration: Udfs', {
-  setup: function() {
-    App = startApp();
-    /* global Pretender: true */
-    server = new Pretender(api);
-  },
-
-  teardown: function() {
-    Ember.run(App, App.destroy);
-    server.shutdown();
-  }
-});
-
-test('Save Queries should list saved queries', function() {
-  expect(1);
-
-  visit("/udfs");
-
-  andThen(function() {
-    equal(find('#content .table tbody tr').length, 2);
-  });
-});
-
-test('User should be able to filter the udfs', function() {
-  expect(4);
-
-  visit("/udfs");
-
-  fillIn('column-filter input[placeholder="udf name"]', "TestColumn");
-  keyEvent('column-filter input[placeholder="udf name"]', 'keyup');
-
-  andThen(function() {
-    equal(find('#content .table tbody tr:visible').length, 1, 'User is able to filter by name');
-  });
-
-  click('.clear-filters');
-
-  andThen(function() {
-    equal(find('#content .table tbody tr:visible').length, 2);
-  });
-
-  fillIn('column-filter input[placeholder="udf class name"]', "TestClassName");
-  keyEvent('column-filter input[placeholder="udf class name"]', 'keyup');
-
-  andThen(function() {
-    equal(find('#content .table tbody tr:visible').length, 1, 'User is able to filter by class name');
-  });
-
-  click('.clear-filters');
-
-  andThen(function() {
-    equal(find('#content .table tbody tr:visible').length, 2);
-  });
-});
-
-test('User is able to add udf', function() {
-  expect(1);
-
-  visit("/udfs");
-  click('.add-udf');
-
-  andThen(function() {
-    equal(find('#content .table tbody tr').length, 3);
-  });
-});
-
-
-test('Can delete file resource', function (assert) {
-  assert.expect(1);
-
-  visit('/udfs');
-  click('.fa-gear:first');
-  click('.dropdown-menu li:first');
-  click('.dropdown-toggle:first');
-  click('.fa-remove:first');
-
-  andThen(function () {
-    click('.modal-footer .btn-success');
-    click('tr.ember-view:first .btn-success');
-  });
-
-  assert.equal($('tr.ember-view:first td:first').text().trim().length, 0, 'File Resource Deleted');
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/tests/test-helper.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/tests/test-helper.js b/contrib/views/hive/src/main/resources/ui/hive-web/tests/test-helper.js
deleted file mode 100644
index 96975ee..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/tests/test-helper.js
+++ /dev/null
@@ -1,24 +0,0 @@
-/**
- * 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.
- */
-
-import resolver from './helpers/resolver';
-import {
-  setResolver
-} from 'ember-qunit';
-
-setResolver(resolver);

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/.gitkeep
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/.gitkeep b/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/.gitkeep
deleted file mode 100644
index e69de29..0000000

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/adapters/application.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/adapters/application.js b/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/adapters/application.js
deleted file mode 100644
index 6e28a40..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/adapters/application.js
+++ /dev/null
@@ -1,48 +0,0 @@
-/**
- * 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.
- */
-
-import {
-  moduleFor,
-  test
-} from 'ember-qunit';
-
-import constants from 'hive/utils/constants';
-
-moduleFor('adapter:application', 'ApplicationAdapter', {
-  // Specify the other units that are required for this test.
-  // needs: ['serializer:foo']
-});
-
-// Replace this with your real tests.
-test('X-Requested-By header is set.', function() {
-  expect(1);
-
-  var adapter = this.subject();
-
-  ok(adapter.get('headers.X-Requested-By'), 'X-Requested-By is set to a truthy value.');
-});
-
-test('buildUrl returns an url with default values for version and instance paramters if not running within an Ambari instance.', function () {
-  expect(1);
-
-  var adapter = this.subject();
-
-  var url = adapter.buildURL();
-
-  equal(url, constants.adapter.apiPrefix + constants.adapter.version + constants.adapter.instancePrefix + 'Hive');
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/adapters/file.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/adapters/file.js b/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/adapters/file.js
deleted file mode 100644
index ea70232..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/adapters/file.js
+++ /dev/null
@@ -1,39 +0,0 @@
-/**
- * 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.
- */
-
-import {
-  moduleFor,
-  test
-} from 'ember-qunit';
-
-import constants from 'hive/utils/constants';
-
-moduleFor('adapter:file', 'FileAdapter', {
-  // Specify the other units that are required for this test.
-  // needs: ['serializer:foo']
-});
-
-// Replace this with your real tests.
-test('pathForType returns correct path.', function() {
-  expect(1);
-
-  var adapter = this.subject();
-  var type = 'dummy';
-
-  equal(adapter.pathForType(type), constants.adapter.resourcePrefix + type);
-});
\ No newline at end of file

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/components/alert-message-widget-test.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/components/alert-message-widget-test.js b/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/components/alert-message-widget-test.js
deleted file mode 100644
index 8f0f245..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/components/alert-message-widget-test.js
+++ /dev/null
@@ -1,91 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-import { moduleForComponent, test } from 'ember-qunit';
-
-moduleForComponent('alert-message-widget', 'AlertMessageWidgetComponent', {
-  needs: []
-});
-
-test('isExpanded is toggled on click', function() {
-  expect(2);
-
-  var message = Ember.Object.create({ isExpanded: false});
-
-  var component = this.subject({
-    message: message
-  });
-
-  Ember.run(function() {
-    component.send('toggleMessage');
-  });
-
-  equal(component.get('message.isExpanded'), true, 'isExpanded is set to true');
-
-  Ember.run(function() {
-    component.send('toggleMessage');
-  });
-
-  equal(component.get('message.isExpanded'), false, 'isExpanded is set to false');
-});
-
-test('removeLater should be called when the message is toggled', function() {
-  expect(1);
-
-  var message = Ember.Object.create({ isExpanded: false});
-
-  var targetObject = {
-    removeLater: function() {
-      ok(true, 'External removeLater called');
-    }
-  };
-
-  var component = this.subject({
-    targetObject: targetObject,
-    removeLater: 'removeLater',
-    message: message
-  });
-
-  Ember.run(function() {
-    component.send('toggleMessage');
-  });
-
-  Ember.run(function() {
-    component.send('toggleMessage');
-  });
-});
-
-test('remove action should call external removeMessage', function() {
-  expect(1);
-
-  var targetObject = {
-    removeMessage: function() {
-      ok(true, 'External removeMessage called');
-    }
-  };
-
-  var component = this.subject({
-    targetObject: targetObject,
-    removeMessage: 'removeMessage'
-  });
-
-  Ember.run(function() {
-    component.send('remove', {});
-  });
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/components/collapsible-widget-test.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/components/collapsible-widget-test.js b/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/components/collapsible-widget-test.js
deleted file mode 100644
index 96a551f..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/components/collapsible-widget-test.js
+++ /dev/null
@@ -1,46 +0,0 @@
-/**
- * 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.
- */
-import Ember from 'ember';
-import { moduleForComponent, test } from 'ember-qunit';
-
-moduleForComponent('collapsible-widget', 'CollapsibleWidgetComponent', {
-  unit: true
-});
-
-test('Component expand/collapse toggle action', function () {
-  expect(1);
-
-  var targetObject = {
-    expanded: function() {
-      ok(true, 'External expanded called');
-    }
-  };
-
-  var component = this.subject({
-    targetObject: targetObject,
-    isExpanded: 'isExpanded',
-    expanded: 'expanded'
-  });
-
-  var $component = this.render();
-
-  Ember.run(function() {
-    component.set('isExpanded', false);
-    component.send('toggle', {});
-   });
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/components/column-filter-widget-test.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/components/column-filter-widget-test.js b/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/components/column-filter-widget-test.js
deleted file mode 100644
index be8bdc4..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/components/column-filter-widget-test.js
+++ /dev/null
@@ -1,138 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-import { moduleForComponent, test } from 'ember-qunit';
-
-moduleForComponent('column-filter-widget', 'ColumnFilterWidgetComponent', {
-  needs: ['component:extended-input']
-});
-
-test('if a filterValue is set when the element is inserted, an action is being sent announcing a filter change', function () {
-  expect(1);
-
-  var column = Ember.Object.create({
-    caption: 'missing.translation'
-  });
-
-  var component = this.subject({ column: column });
-
-  Ember.run(function () {
-    component.set('filterValue', 'initial filter value');
-  });
-
-  var targetObject = {
-    externalAction: function(){
-      ok(true, 'initial filterValue set. Action has been sent.');
-    }
-  };
-
-  component.set('columnFiltered', 'externalAction');
-  component.set('targetObject', targetObject);
-
-  var $component = this.$();
-});
-
-test('isSorted returns true if the table is sorted by this column property', function () {
-  expect(1);
-
-  var component = this.subject();
-
-  var column = Ember.Object.create({
-    property: 'some prop'
-  });
-
-  Ember.run(function () {
-    component.set('column', column);
-    component.set('sortProperties', [column.property]);
-  });
-
-  ok(component.get('isSorted'));
-});
-
-test('isSorted returns false if the table is sorted by some other column', function () {
-  expect(1);
-
-  var component = this.subject();
-
-  var column = Ember.Object.create({
-    property: 'some prop'
-  });
-
-  Ember.run(function () {
-    component.set('column', column);
-    component.set('sortProperties', ['other prop']);
-  });
-
-  ok(!component.get('isSorted'));
-});
-
-test('isSorted returns false if the table is not sorted by any column', function () {
-  expect(1);
-
-  var component = this.subject();
-
-  var column = Ember.Object.create({
-    property: 'some prop'
-  });
-
-  Ember.run(function () {
-    component.set('column', column);
-    component.set('sortProperties', []);
-  });
-
-  ok(!component.get('isSorted'));
-});
-
-test('when sendSort gets called, the columnSorted action gets sent.', function () {
-  expect(1);
-
-  var component = this.subject();
-
-  var targetObject = {
-    externalAction: function(){
-      ok(true, 'columnSorted action has been intercepted.');
-    }
-  };
-
-  Ember.run(function () {
-    component.set('targetObject', targetObject);
-    component.set('columnSorted', 'externalAction');
-
-    component.send('sendSort');
-  });
-});
-
-test('when sendFilter gets called, the columnFiltered action gets sent.', function () {
-  expect(1);
-
-  var component = this.subject();
-
-  var targetObject = {
-    externalAction: function(){
-      ok(true, 'columnFiltered action has been intercepted.');
-    }
-  };
-
-  Ember.run(function () {
-    component.set('targetObject', targetObject);
-    component.set('columnFiltered', 'externalAction');
-
-    component.send('sendFilter');
-  });
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/components/date-range-widget-test.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/components/date-range-widget-test.js b/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/components/date-range-widget-test.js
deleted file mode 100644
index 766e9ee..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/components/date-range-widget-test.js
+++ /dev/null
@@ -1,132 +0,0 @@
-/**
- * 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.
- */
-
-/* global moment */
-
-import Ember from 'ember';
-import { moduleForComponent, test } from 'ember-qunit';
-
-moduleForComponent('date-range-widget', 'DateRangeWidgetComponent', {
-  needs: ['component:extended-input']
-});
-
-test('Date fields are set correctly', function() {
-  expect(2);
-
-  var component = this.subject();
-
-  var min = moment('04/11/2014', 'DD/MM/YYYY');
-  var max = moment('04/12/2014', 'DD/MM/YYYY');
-  var from = moment('04/11/2014', 'DD/MM/YYYY');
-  var to = moment('04/12/2014', 'DD/MM/YYYY');
-
-  var dateRange = Ember.Object.create({
-    from: from.toString(),
-    to: to.toString(),
-    min: min.toString(),
-    max: max.toString()
-  });
-
-  component.set('dateRange', Ember.Object.create());
-
-  var $component = this.$();
-
-  Ember.run(function() {
-    component.set('dateRange', dateRange);
-  });
-
-  equal($component.find('.fromDate').val(), moment(from).format('MM/DD/YYYY'), "From date is set correctly");
-  equal($component.find('.toDate').val(), moment(to).format('MM/DD/YYYY'), "To date is set correctly");
-});
-
-test('Date fields updates when the date is changed', function() {
-  expect(2);
-
-  var component = this.subject();
-
-  var min = moment('04/11/2014', 'DD/MM/YYYY');
-  var max = moment('04/12/2014', 'DD/MM/YYYY');
-  var from = moment('04/11/2014', 'DD/MM/YYYY');
-  var to = moment('04/12/2014', 'DD/MM/YYYY');
-
-  var dateRange = Ember.Object.create({
-    from: from.toString(),
-    to: to.toString(),
-    min: min.toString(),
-    max: max.toString()
-  });
-
-  Ember.run(function() {
-    component.set('dateRange', dateRange);
-  });
-
-  var $component = this.$();
-  $component.find('.fromDate').datepicker('setDate', '10/10/2014');
-  $component.find('.toDate').datepicker('setDate', '11/11/2014');
-
-  equal($component.find('.fromDate').val(), '10/10/2014', "From date field is updated");
-  equal($component.find('.toDate').val(), '11/11/2014', "To date field is updated");
-});
-
-test('Display dates are formatted correctly', function(){
-  expect(2);
-
-  var component = this.subject();
-
-  var min = moment('04/11/2014', 'DD/MM/YYYY');
-  var max = moment('04/12/2014', 'DD/MM/YYYY');
-  var from = moment('04/11/2014', 'DD/MM/YYYY');
-  var to = moment('04/12/2014', 'DD/MM/YYYY');
-
-  var dateRange = Ember.Object.create({
-    from: from.toString(),
-    to: to.toString(),
-    min: min.toString(),
-    max: max.toString()
-  });
-
-  Ember.run(function () {
-    component.set('dateRange', dateRange);
-  });
-
-  equal(component.get('displayFromDate'), '11/04/2014', "displayFromDate is formatted correctly");
-  equal(component.get('displayToDate'), '12/04/2014', "displayToDate is formatted correctly");
-});
-
-test('If from/to are not passed they are set to min/max', function() {
-  expect(2);
-
-  var component = this.subject();
-
-  var min = moment('04/11/2014', 'DD/MM/YYYY');
-  var max = moment('04/12/2014', 'DD/MM/YYYY');
-
-  var dateRange = Ember.Object.create({
-    min: min.toString(),
-    max: max.toString()
-  });
-
-  Ember.run(function () {
-    component.set('dateRange', dateRange);
-  });
-
-  var $component = this.$();
-
-  equal(component.get('dateRange.from'), min.toString(), "From date is to min date");
-  equal(component.get('dateRange.to'), max.toString(), "To date is set to max date");
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/components/expander-widget-test.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/components/expander-widget-test.js b/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/components/expander-widget-test.js
deleted file mode 100644
index 8d1f07a..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/components/expander-widget-test.js
+++ /dev/null
@@ -1,59 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-import { moduleForComponent, test } from 'ember-qunit';
-
-moduleForComponent('expander-widget', 'ExpanderWidgetComponent', {
-  unit: true
-});
-
-test('should set the heading when provided.', function () {
-  expect(2);
-
-  var component = this.subject();
-  var $component = this.$();
-  var heading = 'some header';
-
-  equal($component.find('.accordion-toggle').text(), '');
-
-  Ember.run(function () {
-    component.set('heading', heading);
-  });
-
-  equal($component.find('.accordion-toggle').text(), heading);
-});
-
-test('should correctly toggle isExpanded property.', function () {
-  expect(2);
-
-  var component = this.subject();
-  this.$();
-
-  Ember.run(function(){
-    component.send('toggle');
-  });
-
-  equal(component.get('isExpanded'), true);
-
-  Ember.run(function(){
-    component.send('toggle');
-  });
-
-  equal(component.get('isExpanded'), false);
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/components/extended-input-test.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/components/extended-input-test.js b/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/components/extended-input-test.js
deleted file mode 100644
index aa861aa..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/components/extended-input-test.js
+++ /dev/null
@@ -1,81 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-import { moduleForComponent, test } from 'ember-qunit';
-
-moduleForComponent('extended-input', 'ExtendedInputComponent', {
-  unit: true
-});
-
-test('Component has dynamicValue and dynamicContext', function () {
-  expect(1);
-
-  var component = this.subject({
-    dynamicValue: 'dynamicValue',
-    dynamicContext: Ember.Object.create({ 'dynamicValue' : 'test' })
-  });
-
-  var $component = this.$();
-
-  equal(component.get('value'), 'test', 'Value is set to dynamicValue value');
-});
-
-
-test('Component has no dynamicValue and dynamicContext', function () {
-  expect(1);
-
-  var component = this.subject();
-  var $component = this.$();
-
-  ok(!component.get('value'), 'Value is not set as dynamicValue value');
-});
-
-test("Component's dynamicValue is set", function () {
-  expect(1);
-
-  var component = this.subject({
-    dynamicValue: 'dynamicValue',
-    dynamicContext: Ember.Object.create({ 'dynamicValue' : 'test' })
-  });
-
-  var $component = this.$();
-
-  Ember.run(function() {
-    component.sendValueChanged();
-
-    equal(component.get('value'), component.dynamicContext.get('dynamicValue'), "Value is set and dynamicValue is set");
-  });
-});
-
-test("Component's dynamicValue is not set", function () {
-  expect(1);
-
-  var component = this.subject({
-    dynamicValue: 'dynamicValue',
-    dynamicContext: Ember.Object.create({ })
-  });
-
-  var $component = this.$();
-
-  Ember.run(function() {
-    component.sendValueChanged();
-
-    equal(component.get('value'), undefined, "Value is not set");
-  });
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/components/job-tr-view-test.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/components/job-tr-view-test.js b/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/components/job-tr-view-test.js
deleted file mode 100644
index d39a85e..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/components/job-tr-view-test.js
+++ /dev/null
@@ -1,62 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-import constants from 'hive/utils/constants';
-import { moduleForComponent, test } from 'ember-qunit';
-
-moduleForComponent('job-tr-view', 'JobTrViewComponent', {
-  unit: true
-});
-
-test('Statuses are computed correctly', function (assert) {
-  assert.expect(5);
-
-  var component = this.subject();
-
-  Ember.run(function() {
-    component.set('job', Ember.Object.create());
-    component.set('job.status', constants.statuses.running);
-  });
-
-  assert.equal(component.get('canStop'), true, 'Status is running canStop returns true');
-
-  Ember.run(function() {
-    component.set('job.status', constants.statuses.initialized);
-  });
-
-  assert.equal(component.get('canStop'), true, 'Status is initialized canStop returns true');
-
-  Ember.run(function() {
-    component.set('job.status', constants.statuses.pending);
-  });
-
-  assert.equal(component.get('canStop'), true, 'Status is pending canStop returns true');
-
-  Ember.run(function() {
-    component.set('job.status', constants.statuses.canceled);
-  });
-
-  assert.equal(component.get('canStop'), false, 'Status is canceled canStop returns false');
-
-  Ember.run(function() {
-    component.set('job.status', constants.statuses.unknown);
-  });
-
-  assert.equal(component.get('canStop'), false, 'Status is unknown canStop returns false');
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/components/modal-widget-test.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/components/modal-widget-test.js b/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/components/modal-widget-test.js
deleted file mode 100644
index 3016444..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/components/modal-widget-test.js
+++ /dev/null
@@ -1,69 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-import constants from 'hive/utils/constants';
-import { moduleForComponent, test } from 'ember-qunit';
-
-moduleForComponent('modal-widget', 'ModalWidgetComponent', {
-  needs: ['helper:tb-helper']
-});
-
-test('It send ok action on keyPress enter', function(assert) {
-  assert.expect(1);
-
-  Ember.run.debounce = function(target, func) {
-    func.call(target);
-  };
-
-  var component = this.subject({
-    ok: 'ok',
-    targetObject: {
-      ok: function() {
-        assert.ok(1, 'OK action sent');
-      }
-    }
-  });
-
-  var $component = this.$();
-
-  component.keyPress({ which: 13 });
-  Ember.$('.modal-backdrop').remove(); // remove overlay
-});
-
-test('It send close action on keyPress escape', function(assert) {
-  assert.expect(1);
-
-  Ember.run.debounce = function(target, func) {
-    func.call(target);
-  };
-
-  var component = this.subject({
-    close: 'close',
-    targetObject: {
-      close: function() {
-        assert.ok(1, 'Close action sent');
-      }
-    }
-  });
-
-  var $component = this.$();
-
-  component.keyPress({ which: 27 });
-  Ember.$('.modal-backdrop').remove(); // remove overlay
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/components/no-bubbling-test.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/components/no-bubbling-test.js b/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/components/no-bubbling-test.js
deleted file mode 100644
index 47a1a0f..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/components/no-bubbling-test.js
+++ /dev/null
@@ -1,44 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-import { moduleForComponent, test } from 'ember-qunit';
-
-moduleForComponent('no-bubbling', 'NoBubblingWidgetComponent', {
-  unit: true
-});
-
-
-test('External actions', function() {
-  expect(2);
-
-  var component = this.subject({
-    targetObject: {
-      click: function(data) {
-        ok(true, 'External click action called');
-        equal(data, 'data', 'Data is sent with the action');
-      }
-    },
-    click: 'click',
-    data: 'data'
-  });
-
-  var $component = this.$();
-
-  $component.trigger('click');
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/components/number-range-widget-test.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/components/number-range-widget-test.js b/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/components/number-range-widget-test.js
deleted file mode 100644
index edc65b1..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/components/number-range-widget-test.js
+++ /dev/null
@@ -1,70 +0,0 @@
-/**
- * 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.
- */
-
-/* global moment */
-
-import Ember from 'ember';
-import { moduleForComponent, test } from 'ember-qunit';
-
-moduleForComponent('number-range-widget', 'NumberRangeWidgetComponent', {
-  needs: ['component:extended-input']
-});
-
-
-test('Component is initialized correctly', function() {
-  expect(2);
-
-  var numberRange = Ember.Object.create({
-    max: 1,
-    min: 0
-  });
-
-  var component = this.subject({ numberRange: numberRange });
-  var $component = this.$();
-
-  equal(component.get('numberRange.from'), numberRange.get('min'), 'from is set to min');
-  equal(component.get('numberRange.to'), numberRange.get('max'), 'to is set to max');
-
-});
-
-test('external change action is called', function() {
-  expect(1);
-
-  var targetObject = {
-    rangeChanged: function() {
-      ok(true, 'rangeChanged external action called');
-    }
-  };
-
-  var numberRange = Ember.Object.create({
-    max: 1,
-    min: 0
-  });
-
-  var component = this.subject({
-    numberRange: numberRange,
-    targetObject: targetObject,
-    rangeChanged: 'rangeChanged'
-  });
-
-  var $component = this.$();
-
-  Ember.run(function() {
-    $component.find('.slider').slider('value', 1);
-  });
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/components/popover-widget-test.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/components/popover-widget-test.js b/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/components/popover-widget-test.js
deleted file mode 100644
index 84bec76..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/components/popover-widget-test.js
+++ /dev/null
@@ -1,36 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-import { moduleForComponent, test } from 'ember-qunit';
-
-moduleForComponent('popover-widget', 'PopoverWidgetComponent', {
-  unit: true
-});
-
-test('Component initializes correctly', function () {
-  expect(2);
-
-  var component = this.subject({
-    template: Ember.Handlebars.compile("test")
-  });
-  var $component = this.$();
-
-  ok($component, "Popover element is initialized");
-  equal($component.attr('data-content').trim(), "test", "data-content is populated");
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/components/progress-widget-test.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/components/progress-widget-test.js b/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/components/progress-widget-test.js
deleted file mode 100644
index 3984f62..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/components/progress-widget-test.js
+++ /dev/null
@@ -1,40 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-import { moduleForComponent, test } from 'ember-qunit';
-
-moduleForComponent('progress-widget', 'ProgressWidgetComponent', {
-  unit: true
-});
-
-test('Percentage is updated on value change', function() {
-  var component = this.subject({
-    value: 0
-  });
-
-  this.$();
-
-  equal(component.get('percentage'), '0%', 'Progress is at 0%');
-
-  Ember.run(function() {
-    component.set('value', 50);
-  });
-
-  equal(component.get('percentage'), '50%', 'Progress is at 50%');
-});


[21/23] ambari git commit: AMBARI-19302 : removed contrib/views/hive folder and made necessary changes in pom.xml files (nitirajrathore)

Posted by ni...@apache.org.
http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/client/Utils.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/client/Utils.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/client/Utils.java
deleted file mode 100644
index 13f93c3..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/client/Utils.java
+++ /dev/null
@@ -1,141 +0,0 @@
-/**
- * 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.ambari.view.hive.client;
-
-import org.apache.hive.service.cli.thrift.TStatus;
-import org.apache.hive.service.cli.thrift.TStatusCode;
-import org.apache.http.client.CookieStore;
-import org.apache.http.cookie.Cookie;
-
-import java.util.ArrayList;
-import java.util.List;
-
-public class Utils {
-  // This value is set to true by the setServiceUnavailableRetryStrategy() when the server returns 401
-  static final String HIVE_SERVER2_RETRY_KEY = "hive.server2.retryserver";
-  static final String HIVE_SERVER2_RETRY_TRUE = "true";
-  static final String HIVE_SERVER2_RETRY_FALSE = "false";
-
-  static final String HIVE_COMPILE_ERROR_MSG = "Error while compiling statement:";
-
-  static void verifySuccess(TStatus status, String comment) throws HiveClientException {
-    if (status.getStatusCode() != TStatusCode.SUCCESS_STATUS &&
-        status.getStatusCode() != TStatusCode.SUCCESS_WITH_INFO_STATUS) {
-      String message = (status.getErrorMessage() != null) ? status.getErrorMessage() : "";
-
-      // For schemantic exception Error code is between 10000-19999
-      // https://issues.apache.org/jira/browse/HIVE-3001
-      // https://issues.apache.org/jira/browse/HIVE-12867
-      if((status.getErrorCode() >= 10000 && status.getErrorCode() <= 19999)|| message.contains(HIVE_COMPILE_ERROR_MSG)){
-        throw new HiveInvalidQueryException(status.getStatusCode(),message);
-      }
-      throw new HiveErrorStatusException(status.getStatusCode(), comment + ". " + message);
-    }
-  }
-
-  static boolean needToSendCredentials(CookieStore cookieStore, String cookieName, boolean isSSL) {
-    if (cookieName == null || cookieStore == null) {
-      return true;
-    }
-
-    List<Cookie> cookies = cookieStore.getCookies();
-
-    for (Cookie c : cookies) {
-      // If this is a secured cookie and the current connection is non-secured,
-      // then, skip this cookie. We need to skip this cookie because, the cookie
-      // replay will not be transmitted to the server.
-      if (c.isSecure() && !isSSL) {
-        continue;
-      }
-      if (c.getName().equals(cookieName)) {
-        return false;
-      }
-    }
-    return true;
-  }
-
-  /**
-   * Removes the empty strings and returns back only the strings with content
-   */
-  static String[] removeEmptyStrings(String[] strs) {
-    List<String> nonEmptyStrings = new ArrayList<>();
-    for(String str : strs) {
-      if (!(str == null || str.trim().isEmpty())) {
-        nonEmptyStrings.add(str.trim());
-      }
-    }
-    return nonEmptyStrings.toArray(new String[] {});
-  }
-
-  public static class HiveAuthenticationParams {
-    public static final String AUTH_TYPE = "auth";
-    // We're deprecating this variable's name.
-    public static final String AUTH_QOP_DEPRECATED = "sasl.qop";
-    public static final String AUTH_QOP = "saslQop";
-    public static final String AUTH_SIMPLE = "noSasl";
-    public static final String AUTH_TOKEN = "delegationToken";
-    public static final String AUTH_USER = "user";
-    public static final String HS2_PROXY_USER = "hive.server2.proxy.user";
-    public static final String AUTH_PRINCIPAL = "principal";
-    public static final String AUTH_PASSWD = "password";
-    public static final String AUTH_KERBEROS_AUTH_TYPE = "kerberosAuthType";
-    public static final String AUTH_KERBEROS_AUTH_TYPE_FROM_SUBJECT = "fromSubject";
-    public static final String ANONYMOUS_USER = "anonymous";
-    public static final String ANONYMOUS_PASSWD = "anonymous";
-    public static final String USE_SSL = "ssl";
-    public static final String SSL_TRUST_STORE = "sslTrustStore";
-    public static final String SSL_TRUST_STORE_PASSWORD = "trustStorePassword";
-    // We're deprecating the name and placement of this in the parsed map (from hive conf vars to
-    // hive session vars).
-    public static final String TRANSPORT_MODE_DEPRECATED = "hive.server2.transport.mode";
-    public static final String TRANSPORT_MODE = "transportMode";
-    // We're deprecating the name and placement of this in the parsed map (from hive conf vars to
-    // hive session vars).
-    public static final String HTTP_PATH_DEPRECATED = "hive.server2.thrift.http.path";
-    public static final String HTTP_PATH = "httpPath";
-    public static final String SERVICE_DISCOVERY_MODE = "serviceDiscoveryMode";
-    // Don't use dynamic service discovery
-    public static final String SERVICE_DISCOVERY_MODE_NONE = "none";
-    // Use ZooKeeper for indirection while using dynamic service discovery
-    public static final String SERVICE_DISCOVERY_MODE_ZOOKEEPER = "zooKeeper";
-    public static final String ZOOKEEPER_NAMESPACE = "zooKeeperNamespace";
-    // Default namespace value on ZooKeeper.
-    // This value is used if the param "zooKeeperNamespace" is not specified in the JDBC Uri.
-    public static final String ZOOKEEPER_DEFAULT_NAMESPACE = "hiveserver2";
-    // Non-configurable params:
-    // Currently supports JKS keystore format
-    public static final String SSL_TRUST_STORE_TYPE = "JKS";
-    static final String COOKIE_AUTH = "cookieAuth";
-    static final String COOKIE_AUTH_FALSE = "false";
-    static final String COOKIE_NAME = "cookieName";
-    // The default value of the cookie name when CookieAuth=true
-    static final String DEFAULT_COOKIE_NAMES_HS2 = "hive.server2.auth";
-    static final String HTTP_HEADER_PREFIX = "http.header.";
-    // --------------- Begin 2 way ssl options -------------------------
-    // Use two way ssl. This param will take effect only when ssl=true
-    static final String USE_TWO_WAY_SSL = "twoWay";
-    static final String TRUE = "true";
-    static final String SSL_KEY_STORE = "sslKeyStore";
-    static final String SSL_KEY_STORE_PASSWORD = "keyStorePassword";
-    static final String SSL_KEY_STORE_TYPE = "JKS";
-    static final String SUNX509_ALGORITHM_STRING = "SunX509";
-    // --------------- End 2 way ssl options ----------------------------
-    static final String SUNJSSE_ALGORITHM_STRING = "SunJSSE";
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/client/ViewSessionState.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/client/ViewSessionState.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/client/ViewSessionState.java
deleted file mode 100644
index aa6cd47..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/client/ViewSessionState.java
+++ /dev/null
@@ -1,32 +0,0 @@
-/**
- * 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.ambari.view.hive.client;
-
-import org.apache.hadoop.hive.conf.HiveConf;
-import org.apache.hadoop.hive.ql.session.SessionState;
-
-public class ViewSessionState extends SessionState {
-  public ViewSessionState(HiveConf conf) {
-    super(conf);
-  }
-
-  public ViewSessionState(HiveConf conf, String userName) {
-    super(conf, userName);
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/persistence/DataStoreStorage.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/persistence/DataStoreStorage.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/persistence/DataStoreStorage.java
deleted file mode 100644
index 5457a5c..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/persistence/DataStoreStorage.java
+++ /dev/null
@@ -1,142 +0,0 @@
-/**
- * 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.ambari.view.hive.persistence;
-
-import org.apache.ambari.view.PersistenceException;
-import org.apache.ambari.view.ViewContext;
-import org.apache.ambari.view.hive.persistence.utils.FilteringStrategy;
-import org.apache.ambari.view.hive.persistence.utils.Indexed;
-import org.apache.ambari.view.hive.persistence.utils.ItemNotFound;
-import org.apache.ambari.view.hive.persistence.utils.OnlyOwnersFilteringStrategy;
-import org.apache.ambari.view.hive.utils.ServiceFormattedException;
-import org.apache.commons.beanutils.BeanUtils;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-import javax.ws.rs.WebApplicationException;
-import java.beans.Transient;
-import java.lang.reflect.InvocationTargetException;
-import java.lang.reflect.Method;
-import java.util.ArrayList;
-import java.util.LinkedList;
-import java.util.List;
-
-/**
- * Engine for storing objects to context DataStore storage
- */
-public class DataStoreStorage implements Storage {
-  private final static Logger LOG =
-      LoggerFactory.getLogger(DataStoreStorage.class);
-
-  protected ViewContext context;
-
-  /**
-   * Constructor
-   * @param context View Context instance
-   */
-  public DataStoreStorage(ViewContext context) {
-    this.context = context;
-  }
-
-  @Override
-  public synchronized void store(Class model, Indexed obj) {
-
-    try {
-      Indexed newBean = (Indexed) BeanUtils.cloneBean(obj);
-      preprocessEntity(newBean);
-      context.getDataStore().store(newBean);
-      obj.setId(newBean.getId());
-    } catch (Exception e) {
-      throw new ServiceFormattedException("S020 Data storage error", e);
-    }
-  }
-
-  private void preprocessEntity(Indexed obj) {
-    cleanTransientFields(obj);
-  }
-
-  private void cleanTransientFields(Indexed obj) {
-    for (Method m : obj.getClass().getMethods()) {
-      Transient aTransient = m.getAnnotation(Transient.class);
-      if (aTransient != null && m.getName().startsWith("set")) {
-        try {
-          m.invoke(obj, new Object[]{ null });
-        } catch (IllegalAccessException e) {
-          throw new ServiceFormattedException("S030 Data storage error", e);
-        } catch (InvocationTargetException e) {
-          throw new ServiceFormattedException("S030 Data storage error", e);
-        }
-      }
-    }
-  }
-
-  @Override
-  public synchronized <T extends Indexed> T load(Class<T> model, Object id) throws ItemNotFound {
-    LOG.debug(String.format("Loading %s #%s", model.getName(), id));
-    try {
-      T obj = context.getDataStore().find(model, id);
-      if (obj != null) {
-        return obj;
-      } else {
-        throw new ItemNotFound();
-      }
-    } catch (PersistenceException e) {
-      throw new ServiceFormattedException("S040 Data storage error", e);
-    }
-  }
-
-  @Override
-  public synchronized <T extends Indexed> List<T> loadAll(Class<? extends T> model, FilteringStrategy filter) {
-    LinkedList<T> list = new LinkedList<T>();
-    LOG.debug(String.format("Loading all %s-s", model.getName()));
-    try {
-      for(T item: context.getDataStore().findAll(model, filter.whereStatement())) {
-        list.add(item);
-      }
-    } catch (PersistenceException e) {
-      throw new ServiceFormattedException("S050 Data storage error", e);
-    }
-    return list;
-  }
-
-  @Override
-  public synchronized <T extends Indexed> List<T> loadAll(Class<T> model) {
-    return loadAll(model, new OnlyOwnersFilteringStrategy(this.context.getUsername()));
-  }
-
-  @Override
-  public synchronized void delete(Class model, Object id) throws ItemNotFound {
-    LOG.debug(String.format("Deleting %s:%s", model.getName(), id));
-    Object obj = load(model, id);
-    try {
-      context.getDataStore().remove(obj);
-    } catch (PersistenceException e) {
-      throw new ServiceFormattedException("S060 Data storage error", e);
-    }
-  }
-
-  @Override
-  public boolean exists(Class model, Object id) {
-    try {
-      return context.getDataStore().find(model, id) != null;
-    } catch (PersistenceException e) {
-      throw new ServiceFormattedException("S070 Data storage error", e);
-    }
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/persistence/IStorageFactory.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/persistence/IStorageFactory.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/persistence/IStorageFactory.java
deleted file mode 100644
index 298d4c8..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/persistence/IStorageFactory.java
+++ /dev/null
@@ -1,23 +0,0 @@
-/**
- * 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.ambari.view.hive.persistence;
-
-public interface IStorageFactory {
-  Storage getStorage();
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/persistence/InstanceKeyValueStorage.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/persistence/InstanceKeyValueStorage.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/persistence/InstanceKeyValueStorage.java
deleted file mode 100644
index 98703fa..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/persistence/InstanceKeyValueStorage.java
+++ /dev/null
@@ -1,135 +0,0 @@
-/**
- * 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.ambari.view.hive.persistence;
-
-import org.apache.ambari.view.ViewContext;
-import org.apache.ambari.view.hive.persistence.utils.ContextConfigurationAdapter;
-import org.apache.ambari.view.hive.persistence.utils.Indexed;
-import org.apache.ambari.view.hive.utils.ServiceFormattedException;
-import org.apache.commons.configuration.Configuration;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-import sun.reflect.generics.reflectiveObjects.NotImplementedException;
-
-import javax.ws.rs.WebApplicationException;
-import java.util.List;
-
-
-/**
- * Persistent storage engine for storing java beans to
- * instance data
- */
-@Deprecated
-public class InstanceKeyValueStorage extends KeyValueStorage {
-  private final static Logger LOG =
-      LoggerFactory.getLogger(InstanceKeyValueStorage.class);
-
-  private ContextConfigurationAdapter config = null;
-  private int VALUE_LENGTH_LIMIT = 254;
-
-  /**
-   * Constructor.
-   * @param context View Context instance
-   */
-  public InstanceKeyValueStorage(ViewContext context) {
-    super(context);
-  }
-
-  /**
-   * Returns config instance, adapter to Persistence API
-   * @return config instance
-   */
-  @Override
-  protected synchronized Configuration getConfig() {
-    if (config == null) {
-      config = new ContextConfigurationAdapter(context);
-    }
-    return config;
-  }
-
-  /**
-   * Value is limited to 256 symbols, this code splits value into chunks and saves them as <key>#<chunk_id>
-   * @param modelPropName key
-   * @param json value
-   */
-  protected void write(String modelPropName, String json) {
-    int saved = 0;
-    int page = 1;
-    while (saved < json.length()) {
-      int end = Math.min(saved + VALUE_LENGTH_LIMIT, json.length());
-      String substring = json.substring(saved, end);
-      getConfig().setProperty(modelPropName + "#" + page, substring);
-      saved += VALUE_LENGTH_LIMIT;
-      page += 1;
-      LOG.debug("Chunk saved: " + modelPropName + "#" + page + "=" + substring);
-    }
-    getConfig().setProperty(modelPropName, page - 1);
-    LOG.debug("Write finished: " + modelPropName + " pages:" + (page - 1));
-  }
-
-  /**
-   * Read chunked value (keys format <key>#<chunk_id>)
-   * @param modelPropName key
-   * @return value
-   */
-  protected String read(String modelPropName) {
-    StringBuilder result = new StringBuilder();
-    int pages = getConfig().getInt(modelPropName);
-    LOG.debug("Read started: " + modelPropName + " pages:" + pages);
-
-    for(int page = 1; page <= pages; page++) {
-      String substring = getConfig().getString(modelPropName + "#" + page);
-      LOG.debug("Chunk read: " + modelPropName + "#" + page + "=" + substring);
-      if (substring != null) {
-        result.append(substring);
-      }
-    }
-
-    return result.toString();
-  }
-
-  /**
-   * Remove chunked value (keys format <key>#<chunk_id>)
-   * @param modelPropName key
-   */
-  protected void clear(String modelPropName) {
-    int pages = getConfig().getInt(modelPropName);
-    LOG.debug("Clean started: " + modelPropName + " pages:" + pages);
-
-    for(int page = 1; page <= pages; page++) {
-      getConfig().clearProperty(modelPropName + "#" + page);
-      LOG.debug("Chunk clean: " + modelPropName + "#" + page);
-    }
-    getConfig().clearProperty(modelPropName);
-  }
-
-  public static void storageSmokeTest(ViewContext context) {
-    try {
-      final String property = "test.smoke.property";
-      context.putInstanceData(property, "42");
-      boolean status = context.getInstanceData(property).equals("42");
-      context.removeInstanceData(property);
-      if (!status) throw new ServiceFormattedException("Ambari Views instance data DB doesn't work properly", null);
-    } catch (WebApplicationException ex) {
-      throw ex;
-    } catch (Exception ex) {
-      throw new ServiceFormattedException(ex.getMessage(), ex);
-    }
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/persistence/KeyValueStorage.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/persistence/KeyValueStorage.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/persistence/KeyValueStorage.java
deleted file mode 100644
index 6e88063..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/persistence/KeyValueStorage.java
+++ /dev/null
@@ -1,163 +0,0 @@
-/**
- * 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.ambari.view.hive.persistence;
-
-import com.google.gson.Gson;
-import org.apache.ambari.view.ViewContext;
-import org.apache.ambari.view.hive.persistence.utils.FilteringStrategy;
-import org.apache.ambari.view.hive.persistence.utils.Indexed;
-import org.apache.ambari.view.hive.persistence.utils.ItemNotFound;
-import org.apache.ambari.view.hive.persistence.utils.OnlyOwnersFilteringStrategy;
-import org.apache.commons.configuration.Configuration;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-import java.util.ArrayList;
-import java.util.List;
-
-/**
- * Engine for storing objects to key-value storage
- */
-public abstract class KeyValueStorage implements Storage {
-  private final static Logger LOG =
-      LoggerFactory.getLogger(KeyValueStorage.class);
-  protected final Gson gson = new Gson();
-  protected ViewContext context;
-
-  /**
-   * Constructor
-   * @param context View Context instance
-   */
-  public KeyValueStorage(ViewContext context) {
-    this.context = context;
-  }
-
-  /**
-   * Returns config instance, adapter to Persistence API
-   * @return config instance
-   */
-  protected abstract Configuration getConfig();
-
-  @Override
-  public <T extends Indexed> void store(Class<T> model, Indexed obj) {
-    String modelIndexingPropName = getIndexPropertyName(model);
-
-    if (obj.getId() == null) {
-      int lastIndex = getConfig().getInt(modelIndexingPropName, 0);
-      lastIndex ++;
-      getConfig().setProperty(modelIndexingPropName, lastIndex);
-      obj.setId(String.valueOf(lastIndex));
-    }
-
-    String modelPropName = getItemPropertyName(model, obj.getId());
-    String json = serialize(obj);
-    write(modelPropName, json);
-  }
-
-  @Override
-  public <T extends Indexed> T load(Class<T> model, Object id) throws ItemNotFound {
-    String modelPropName = getItemPropertyName(model, id);
-    LOG.debug(String.format("Loading %s", modelPropName));
-    if (getConfig().containsKey(modelPropName)) {
-      String json = read(modelPropName);
-      LOG.debug(String.format("json: %s", json));
-
-      return deserialize(model, json);
-    } else {
-      throw new ItemNotFound();
-    }
-  }
-
-  /**
-   * Write json to storage
-   * @param modelPropName key
-   * @param json value
-   */
-  protected void write(String modelPropName, String json) {
-    getConfig().setProperty(modelPropName, json);
-  }
-
-  /**
-   * Read json from storage
-   * @param modelPropName key
-   * @return value
-   */
-  protected String read(String modelPropName) {
-    return getConfig().getString(modelPropName);
-  }
-
-  /**
-   * Remove line from storage
-   * @param modelPropName key
-   */
-  protected void clear(String modelPropName) {
-    getConfig().clearProperty(modelPropName);
-  }
-
-  protected String serialize(Indexed obj) {
-    return gson.toJson(obj);
-  }
-
-  protected <T extends Indexed> T deserialize(Class<T> model, String json) {
-    return gson.fromJson(json, model);
-  }
-
-  @Override
-  public synchronized <T extends Indexed> List<T> loadAll(Class<? extends T> model, FilteringStrategy filter) {
-    ArrayList<T> list = new ArrayList<T>();
-    String modelIndexingPropName = getIndexPropertyName(model);
-    LOG.debug(String.format("Loading all %s-s", model.getName()));
-    int lastIndex = getConfig().getInt(modelIndexingPropName, 0);
-    for(int i=1; i<=lastIndex; i++) {
-      try {
-        T item = load(model, i);
-        if ((filter == null) || filter.isConform(item)) {
-          list.add(item);
-        }
-      } catch (ItemNotFound ignored) {
-      }
-    }
-    return list;
-  }
-
-  @Override
-  public synchronized <T extends Indexed> List<T> loadAll(Class<T> model) {
-    return loadAll(model, new OnlyOwnersFilteringStrategy(this.context.getUsername()));
-  }
-
-  @Override
-  public synchronized void delete(Class model, Object id) {
-    LOG.debug(String.format("Deleting %s:%s", model.getName(), id));
-    String modelPropName = getItemPropertyName(model, id);
-    clear(modelPropName);
-  }
-
-  @Override
-  public boolean exists(Class model, Object id) {
-    return getConfig().containsKey(getItemPropertyName(model, id));
-  }
-
-  private String getIndexPropertyName(Class model) {
-    return String.format("%s:index", model.getName());
-  }
-
-  private String getItemPropertyName(Class model, Object id) {
-    return String.format("%s.%s", model.getName(), id);
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/persistence/LocalKeyValueStorage.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/persistence/LocalKeyValueStorage.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/persistence/LocalKeyValueStorage.java
deleted file mode 100644
index 24ed335..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/persistence/LocalKeyValueStorage.java
+++ /dev/null
@@ -1,73 +0,0 @@
-/**
- * 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.ambari.view.hive.persistence;
-
-import org.apache.ambari.view.ViewContext;
-import org.apache.ambari.view.hive.persistence.utils.Indexed;
-import org.apache.ambari.view.hive.utils.MisconfigurationFormattedException;
-import org.apache.commons.configuration.ConfigurationException;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-import sun.reflect.generics.reflectiveObjects.NotImplementedException;
-
-import java.util.List;
-
-
-/**
- * Persistent storage engine for storing java beans to
- * properties file
- * Path to file should be in 'dataworker.storagePath' parameter
- */
-@Deprecated
-public class LocalKeyValueStorage extends KeyValueStorage {
-  private final static Logger LOG =
-      LoggerFactory.getLogger(LocalKeyValueStorage.class);
-
-  private PersistentConfiguration config = null;
-
-  /**
-   * Constructor
-   * @param context View Context instance
-   */
-  public LocalKeyValueStorage(ViewContext context) {
-    super(context);
-  }
-
-  /**
-   * Returns config instance
-   * @return config instance
-   */
-  @Override
-  protected synchronized PersistentConfiguration getConfig() {
-    if (config == null) {
-      String fileName = context.getProperties().get("dataworker.storagePath");
-      if (fileName == null) {
-        String msg = "dataworker.storagePath is not configured!";
-        LOG.error(msg);
-        throw new MisconfigurationFormattedException("dataworker.storagePath");
-      }
-      try {
-        config = new PersistentConfiguration(fileName);
-      } catch (ConfigurationException e) {
-        e.printStackTrace();
-      }
-    }
-    return config;
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/persistence/PersistentConfiguration.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/persistence/PersistentConfiguration.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/persistence/PersistentConfiguration.java
deleted file mode 100644
index b8405ff..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/persistence/PersistentConfiguration.java
+++ /dev/null
@@ -1,52 +0,0 @@
-/**
- * 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.ambari.view.hive.persistence;
-
-import org.apache.commons.configuration.ConfigurationException;
-import org.apache.commons.configuration.PropertiesConfiguration;
-import org.apache.commons.configuration.reloading.FileChangedReloadingStrategy;
-
-import java.io.File;
-
-/**
- * Configuration enables all necessary options for PropertiesConfiguration:
- * auto-save, auto-reloading, no delimiter parsing and other
- */
-@Deprecated
-public class PersistentConfiguration extends PropertiesConfiguration {
-  /**
-   * Constructor
-   * @param fileName path to data file
-   * @throws ConfigurationException
-   */
-  public PersistentConfiguration(String fileName) throws ConfigurationException {
-    super();
-
-    File config = new File(fileName);
-    setFile(config);
-    this.setAutoSave(true);
-    this.setReloadingStrategy(new FileChangedReloadingStrategy());
-    this.setDelimiterParsingDisabled(true);
-    this.setListDelimiter((char) 0);
-
-    if (config.exists()) {
-      this.load();
-    }
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/persistence/Storage.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/persistence/Storage.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/persistence/Storage.java
deleted file mode 100644
index a34f566..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/persistence/Storage.java
+++ /dev/null
@@ -1,77 +0,0 @@
-/**
- * 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.ambari.view.hive.persistence;
-
-import org.apache.ambari.view.hive.persistence.utils.FilteringStrategy;
-import org.apache.ambari.view.hive.persistence.utils.Indexed;
-import org.apache.ambari.view.hive.persistence.utils.ItemNotFound;
-
-import java.util.List;
-
-/**
- * Object storage interface
- */
-public interface Storage {
-  /**
-   * Persist object to DB. It should be Indexed
-   * @param obj object to save
-   */
-  <T extends Indexed> void store(Class<T> model, Indexed obj);
-
-  /**
-   * Load object
-   * @param model bean class
-   * @param id identifier
-   * @return bean instance
-   * @throws ItemNotFound thrown if item with id was not found in DB
-   */
-  <T extends Indexed> T load(Class<T> model, Object id) throws ItemNotFound;
-
-  /**
-   * Load all objects of given bean class
-   * @param model bean class
-   * @param filter filtering strategy (return only those objects that conform condition)
-   * @param <T> bean class
-   * @return list of filtered objects
-   */
-  <T extends Indexed> List<T> loadAll(Class<? extends T> model, FilteringStrategy filter);
-
-  /**
-   * Load all objects of given bean class
-   * @param model bean class
-   * @param <T> bean class
-   * @return list of all objects
-   */
-  <T extends Indexed> List<T> loadAll(Class<T> model);
-
-  /**
-   * Delete object
-   * @param model bean class
-   * @param id identifier
-   */
-  void delete(Class model, Object id) throws ItemNotFound;
-
-  /**
-   * Check is object exists
-   * @param model bean class
-   * @param id identifier
-   * @return true if exists
-   */
-  boolean exists(Class model, Object id);
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/persistence/utils/ContextConfigurationAdapter.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/persistence/utils/ContextConfigurationAdapter.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/persistence/utils/ContextConfigurationAdapter.java
deleted file mode 100644
index afc4c78..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/persistence/utils/ContextConfigurationAdapter.java
+++ /dev/null
@@ -1,260 +0,0 @@
-/**
- * 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.ambari.view.hive.persistence.utils;
-
-import org.apache.ambari.view.ViewContext;
-import org.apache.commons.configuration.Configuration;
-
-import java.math.BigDecimal;
-import java.math.BigInteger;
-import java.util.Iterator;
-import java.util.List;
-import java.util.Map;
-import java.util.Properties;
-
-/**
- * Persistence API to Apache Configuration adapter
- */
-@Deprecated
-public class ContextConfigurationAdapter implements Configuration {
-  private ViewContext context;
-
-  /**
-   * Constructor of adapter
-   * @param context View Context
-   */
-  public ContextConfigurationAdapter(ViewContext context) {
-    this.context = context;
-  }
-
-  @Override
-  public Configuration subset(String prefix) {
-    throw new UnsupportedOperationException();
-  }
-
-  @Override
-  public boolean isEmpty() {
-    return context.getInstanceData().isEmpty();
-  }
-
-  @Override
-  public boolean containsKey(String s) {
-    Map<String, String> data = context.getInstanceData();
-    return data.containsKey(s);
-  }
-
-  @Override
-  public void addProperty(String s, Object o) {
-    throw new UnsupportedOperationException();
-  }
-
-  @Override
-  public void setProperty(String s, Object o) {
-    context.putInstanceData(s, o.toString());
-  }
-
-  @Override
-  public void clearProperty(String key) {
-    context.removeInstanceData(key);
-  }
-
-  @Override
-  public void clear() {
-    for (String key : context.getInstanceData().keySet())
-      context.removeInstanceData(key);
-  }
-
-  @Override
-  public Object getProperty(String key) {
-    return context.getInstanceData(key);
-  }
-
-  @Override
-  public Iterator getKeys(String s) {
-    throw new UnsupportedOperationException();
-  }
-
-  @Override
-  public Iterator getKeys() {
-    return context.getInstanceData().keySet().iterator();
-  }
-
-  @Override
-  public Properties getProperties(String s) {
-    throw new UnsupportedOperationException();
-  }
-
-  @Override
-  public boolean getBoolean(String s) {
-    return getBoolean(s, null);
-  }
-
-  @Override
-  public boolean getBoolean(String s, boolean b) {
-    return getBoolean(s, (Boolean)b);
-  }
-
-  @Override
-  public Boolean getBoolean(String s, Boolean aBoolean) {
-    String data = context.getInstanceData(s);
-    return (data != null)?Boolean.parseBoolean(data):aBoolean;
-  }
-
-  @Override
-  public byte getByte(String s) {
-    return getByte(s, null);
-  }
-
-  @Override
-  public byte getByte(String s, byte b) {
-    return getByte(s, (Byte)b);
-  }
-
-  @Override
-  public Byte getByte(String s, Byte aByte) {
-    String data = context.getInstanceData(s);
-    return (data != null)?Byte.parseByte(data):aByte;
-  }
-
-  @Override
-  public double getDouble(String s) {
-    return getDouble(s, null);
-  }
-
-  @Override
-  public double getDouble(String s, double v) {
-    return getDouble(s, (Double)v);
-  }
-
-  @Override
-  public Double getDouble(String s, Double aDouble) {
-    String data = context.getInstanceData(s);
-    return (data != null)?Double.parseDouble(data):aDouble;
-  }
-
-  @Override
-  public float getFloat(String s) {
-    return getFloat(s, null);
-  }
-
-  @Override
-  public float getFloat(String s, float v) {
-    return getFloat(s, (Float)v);
-  }
-
-  @Override
-  public Float getFloat(String s, Float aFloat) {
-    String data = context.getInstanceData(s);
-    return (data != null)?Float.parseFloat(data):aFloat;
-  }
-
-  @Override
-  public int getInt(String s) {
-    return getInteger(s, null);
-  }
-
-  @Override
-  public int getInt(String s, int i) {
-    return getInteger(s, i);
-  }
-
-  @Override
-  public Integer getInteger(String s, Integer integer) {
-    String data = context.getInstanceData(s);
-    return (data != null)?Integer.parseInt(data):integer;
-  }
-
-  @Override
-  public long getLong(String s) {
-    return getLong(s, null);
-  }
-
-  @Override
-  public long getLong(String s, long l) {
-    return getLong(s, (Long)l);
-  }
-
-  @Override
-  public Long getLong(String s, Long aLong) {
-    String data = context.getInstanceData(s);
-    return (data != null)?Long.parseLong(data):aLong;
-  }
-
-  @Override
-  public short getShort(String s) {
-    return getShort(s, null);
-  }
-
-  @Override
-  public short getShort(String s, short i) {
-    return getShort(s, (Short)i);
-  }
-
-  @Override
-  public Short getShort(String s, Short aShort) {
-    String data = context.getInstanceData(s);
-    return (data != null)?Short.parseShort(data):aShort;
-  }
-
-  @Override
-  public BigDecimal getBigDecimal(String s) {
-    throw new UnsupportedOperationException();
-  }
-
-  @Override
-  public BigDecimal getBigDecimal(String s, BigDecimal bigDecimal) {
-    throw new UnsupportedOperationException();
-  }
-
-  @Override
-  public BigInteger getBigInteger(String s) {
-    throw new UnsupportedOperationException();
-  }
-
-  @Override
-  public BigInteger getBigInteger(String s, BigInteger bigInteger) {
-    throw new UnsupportedOperationException();
-  }
-
-  @Override
-  public String getString(String s) {
-    return context.getInstanceData(s);
-  }
-
-  @Override
-  public String getString(String s, String s2) {
-    String data = getString(s);
-    return (data != null)?data:s2;
-  }
-
-  @Override
-  public String[] getStringArray(String s) {
-    throw new UnsupportedOperationException();
-  }
-
-  @Override
-  public List getList(String s) {
-    throw new UnsupportedOperationException();
-  }
-
-  @Override
-  public List getList(String s, List list) {
-    throw new UnsupportedOperationException();
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/persistence/utils/FilteringStrategy.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/persistence/utils/FilteringStrategy.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/persistence/utils/FilteringStrategy.java
deleted file mode 100644
index eba572e..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/persistence/utils/FilteringStrategy.java
+++ /dev/null
@@ -1,32 +0,0 @@
-/**
- * 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.ambari.view.hive.persistence.utils;
-
-/**
- * Filtering strategy for stored objects
- */
-public interface FilteringStrategy {
-  /**
-   * Check whether item conforms chosen filter or not
-   * @param item item to check
-   * @return true if item conforms this filter
-   */
-  boolean isConform(Indexed item);
-  String whereStatement();
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/persistence/utils/Indexed.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/persistence/utils/Indexed.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/persistence/utils/Indexed.java
deleted file mode 100644
index 82b7d57..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/persistence/utils/Indexed.java
+++ /dev/null
@@ -1,36 +0,0 @@
-/**
- * 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.ambari.view.hive.persistence.utils;
-
-/**
- * Interface to represent item with identifier
- */
-public interface Indexed {
-  /**
-   * Get the ID
-   * @return ID
-   */
-  String getId();
-
-  /**
-   * Set ID
-   * @param id ID
-   */
-  void setId(String id);
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/persistence/utils/ItemNotFound.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/persistence/utils/ItemNotFound.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/persistence/utils/ItemNotFound.java
deleted file mode 100644
index 06976b9..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/persistence/utils/ItemNotFound.java
+++ /dev/null
@@ -1,43 +0,0 @@
-/**
- * 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.ambari.view.hive.persistence.utils;
-
-/**
- * Thrown when item was not found in DB
- */
-public class ItemNotFound extends Exception {
-  public ItemNotFound() {
-  }
-
-  public ItemNotFound(String message) {
-    super(message);
-  }
-
-  public ItemNotFound(String message, Throwable cause) {
-    super(message, cause);
-  }
-
-  public ItemNotFound(Throwable cause) {
-    super(cause);
-  }
-
-  public ItemNotFound(String message, Throwable cause, boolean enableSuppression, boolean writableStackTrace) {
-    super(message, cause, enableSuppression, writableStackTrace);
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/persistence/utils/OnlyOwnersFilteringStrategy.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/persistence/utils/OnlyOwnersFilteringStrategy.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/persistence/utils/OnlyOwnersFilteringStrategy.java
deleted file mode 100644
index 620f440..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/persistence/utils/OnlyOwnersFilteringStrategy.java
+++ /dev/null
@@ -1,38 +0,0 @@
-/**
- * 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.ambari.view.hive.persistence.utils;
-
-public class OnlyOwnersFilteringStrategy implements FilteringStrategy {
-  private final String username;
-
-  public OnlyOwnersFilteringStrategy(String username) {
-    this.username = username;
-  }
-
-  @Override
-  public boolean isConform(Indexed item) {
-    Owned object = (Owned) item;
-    return object.getOwner().compareTo(username) == 0;
-  }
-
-  @Override
-  public String whereStatement() {
-    return "owner = '" + username + "'";
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/persistence/utils/Owned.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/persistence/utils/Owned.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/persistence/utils/Owned.java
deleted file mode 100644
index 460bf37..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/persistence/utils/Owned.java
+++ /dev/null
@@ -1,36 +0,0 @@
-/**
- * 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.ambari.view.hive.persistence.utils;
-
-/**
- * Interface to represent item with owner
- */
-public interface Owned {
-  /**
-   * Get the owner
-   * @return owner
-   */
-  String getOwner();
-
-  /**
-   * Set owner
-   * @param owner owner
-   */
-  void setOwner(String owner);
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/persistence/utils/PersonalResource.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/persistence/utils/PersonalResource.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/persistence/utils/PersonalResource.java
deleted file mode 100644
index 1b41edb..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/persistence/utils/PersonalResource.java
+++ /dev/null
@@ -1,22 +0,0 @@
-/**
- * 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.ambari.view.hive.persistence.utils;
-
-public interface PersonalResource extends Indexed, Owned {
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/persistence/utils/StorageFactory.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/persistence/utils/StorageFactory.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/persistence/utils/StorageFactory.java
deleted file mode 100644
index 88a6d66..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/persistence/utils/StorageFactory.java
+++ /dev/null
@@ -1,69 +0,0 @@
-/**
- * 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.ambari.view.hive.persistence.utils;
-
-import org.apache.ambari.view.ViewContext;
-import org.apache.ambari.view.hive.persistence.DataStoreStorage;
-import org.apache.ambari.view.hive.persistence.IStorageFactory;
-import org.apache.ambari.view.hive.persistence.LocalKeyValueStorage;
-import org.apache.ambari.view.hive.persistence.Storage;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-/**
- * Storage factory, creates storage of Local or Persistence API type.
- * Type depends on context configuration: if "dataworker.storagePath" is set,
- * storage of Local type will be created.  Otherwise, Persistence API will be used.
- *
- * Storage is singleton.
- */
-public class StorageFactory implements IStorageFactory {
-  protected final static Logger LOG =
-      LoggerFactory.getLogger(StorageFactory.class);
-
-  private ViewContext context;
-
-  /**
-   * Constructor of storage factory
-   * @param context View Context instance
-   */
-  public StorageFactory(ViewContext context) {
-    this.context = context;
-  }
-
-  /**
-   * Creates storage instance
-   * @return storage instance
-   */
-  public Storage getStorage() {
-    String fileName = context.getProperties().get("dataworker.storagePath");
-
-    Storage storageInstance;
-    if (fileName != null) {
-      LOG.debug("Using local storage in " + fileName + " to store data");
-      // If specifed, use LocalKeyValueStorage - key-value file based storage
-      storageInstance = new LocalKeyValueStorage(context);
-    } else {
-      LOG.debug("Using Persistence API to store data");
-      // If not specifed, use ambari-views Persistence API
-      storageInstance = new DataStoreStorage(context);
-    }
-    return storageInstance;
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/CRUDResourceManager.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/CRUDResourceManager.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/CRUDResourceManager.java
deleted file mode 100644
index c7167a8..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/CRUDResourceManager.java
+++ /dev/null
@@ -1,131 +0,0 @@
-/**
- * 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.ambari.view.hive.resources;
-
-import org.apache.ambari.view.hive.persistence.IStorageFactory;
-import org.apache.ambari.view.hive.persistence.Storage;
-import org.apache.ambari.view.hive.persistence.utils.FilteringStrategy;
-import org.apache.ambari.view.hive.persistence.utils.Indexed;
-import org.apache.ambari.view.hive.persistence.utils.ItemNotFound;
-import org.apache.ambari.view.hive.utils.ServiceFormattedException;
-
-import java.util.List;
-
-/**
- * CRUD resource manager
- * @param <T> Data type with ID
- */
-abstract public class CRUDResourceManager<T extends Indexed> implements IResourceManager<T> {
-  //TODO: refactor: generic parameter gets Fabric for Indexed objects, not objects itself
-  private Storage storage = null;
-
-  protected final Class<? extends T> resourceClass;
-  protected IStorageFactory storageFactory;
-
-  /**
-   * Constructor
-   * @param resourceClass model class
-   */
-  public CRUDResourceManager(Class<? extends T> resourceClass, IStorageFactory storageFactory) {
-    this.resourceClass = resourceClass;
-    this.storageFactory = storageFactory;
-  }
-  // CRUD operations
-
-  /**
-   * Create operation
-   * @param object object
-   * @return model object
-   */
-  @Override
-  public T create(T object) {
-    object.setId(null);
-    return this.save(object);
-  }
-
-  /**
-   * Read operation
-   * @param id identifier
-   * @return model object
-   * @throws org.apache.ambari.view.hive.persistence.utils.ItemNotFound
-   */
-  @Override
-  public T read(Object id) throws ItemNotFound {
-    T object = null;
-    object = storageFactory.getStorage().load(this.resourceClass, id);
-    if (!checkPermissions(object))
-      throw new ItemNotFound();
-    return object;
-  }
-
-  /**
-   * Read all objects
-   * @param filteringStrategy filtering strategy
-   * @return list of filtered objects
-   */
-  @Override
-  public List<T> readAll(FilteringStrategy filteringStrategy) {
-    return storageFactory.getStorage().loadAll(this.resourceClass, filteringStrategy);
-  }
-
-  /**
-   * Update operation
-   * @param newObject new object
-   * @param id identifier of previous object
-   * @return model object
-   * @throws org.apache.ambari.view.hive.persistence.utils.ItemNotFound
-   */
-  @Override
-  public T update(T newObject, String id) throws ItemNotFound {
-    newObject.setId(id);
-    this.save(newObject);
-    return newObject;
-  }
-
-  /**
-   * Delete operation
-   * @param resourceId object identifier
-   * @throws org.apache.ambari.view.hive.persistence.utils.ItemNotFound
-   */
-  @Override
-  public void delete(Object resourceId) throws ItemNotFound {
-    if (!storageFactory.getStorage().exists(this.resourceClass, resourceId)) {
-      throw new ItemNotFound();
-    }
-    storageFactory.getStorage().delete(this.resourceClass, resourceId);
-  }
-
-  // UTILS
-
-  protected T save(T object) {
-    storageFactory.getStorage().store(resourceClass, object);
-    return object;
-  }
-
-  protected abstract boolean checkPermissions(T object);
-
-  protected void cleanupAfterErrorAndThrowAgain(Indexed object, ServiceFormattedException e) {
-    try {
-      delete(object.getId());
-    } catch (ItemNotFound itemNotFound) {
-      throw new ServiceFormattedException("E040 Item not found", itemNotFound);
-    }
-    throw e;
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/IResourceManager.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/IResourceManager.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/IResourceManager.java
deleted file mode 100644
index 222d695..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/IResourceManager.java
+++ /dev/null
@@ -1,37 +0,0 @@
-/**
- * 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.ambari.view.hive.resources;
-
-import org.apache.ambari.view.hive.persistence.utils.FilteringStrategy;
-import org.apache.ambari.view.hive.persistence.utils.Indexed;
-import org.apache.ambari.view.hive.persistence.utils.ItemNotFound;
-
-import java.util.List;
-
-public interface IResourceManager<T extends Indexed> {
-  T create(T object);
-
-  T read(Object id) throws ItemNotFound;
-
-  List<T> readAll(FilteringStrategy filteringStrategy);
-
-  T update(T newObject, String id) throws ItemNotFound;
-
-  void delete(Object resourceId) throws ItemNotFound;
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/PersonalCRUDResourceManager.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/PersonalCRUDResourceManager.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/PersonalCRUDResourceManager.java
deleted file mode 100644
index e8ce02e..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/PersonalCRUDResourceManager.java
+++ /dev/null
@@ -1,99 +0,0 @@
-/**
- * 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.ambari.view.hive.resources;
-
-import org.apache.ambari.view.ViewContext;
-import org.apache.ambari.view.hive.persistence.IStorageFactory;
-import org.apache.ambari.view.hive.persistence.utils.ItemNotFound;
-import org.apache.ambari.view.hive.persistence.utils.PersonalResource;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-import java.util.concurrent.Callable;
-
-/**
- * Resource manager that returns only user owned elements from DB
- * @param <T> Data type with ID and Owner
- */
-public class PersonalCRUDResourceManager<T extends PersonalResource> extends CRUDResourceManager<T> {
-  protected boolean ignorePermissions = false;
-
-  private final static Logger LOG =
-      LoggerFactory.getLogger(PersonalCRUDResourceManager.class);
-  protected ViewContext context;
-
-  /**
-   * Constructor
-   * @param resourceClass model class
-   */
-  public PersonalCRUDResourceManager(Class<? extends T> resourceClass, IStorageFactory storageFabric, ViewContext context) {
-    super(resourceClass, storageFabric);
-    this.context = context;
-  }
-
-  @Override
-  public T update(T newObject, String id) throws ItemNotFound {
-    T object = storageFactory.getStorage().load(this.resourceClass, id);
-    if (object.getOwner().compareTo(this.context.getUsername()) != 0) {
-      throw new ItemNotFound();
-    }
-
-    newObject.setOwner(this.context.getUsername());
-    return super.update(newObject, id);
-  }
-
-  @Override
-  public T save(T object) {
-    if (!ignorePermissions) {
-      // in threads permissions should be ignored,
-      // because context.getUsername doesn't work. See BUG-27093.
-      object.setOwner(this.context.getUsername());
-    }
-    return super.save(object);
-  }
-
-  @Override
-  protected boolean checkPermissions(T object) {
-    if (ignorePermissions) {
-      return true;
-    }
-    return object.getOwner().compareTo(this.context.getUsername()) == 0;
-  }
-
-  /**
-   * Execute action ignoring objects owner
-   * @param actions callable to execute
-   * @return value returned from actions
-   * @throws Exception
-   */
-  public T ignorePermissions(Callable<T> actions) throws Exception {
-    ignorePermissions = true;
-    T result;
-    try {
-      result = actions.call();
-    } finally {
-      ignorePermissions = false;
-    }
-    return result;
-  }
-
-  protected String getUsername() {
-    return context.getUsername();
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/SharedCRUDResourceManager.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/SharedCRUDResourceManager.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/SharedCRUDResourceManager.java
deleted file mode 100644
index 9c4ca36..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/SharedCRUDResourceManager.java
+++ /dev/null
@@ -1,44 +0,0 @@
-/**
- * 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.ambari.view.hive.resources;
-
-import org.apache.ambari.view.ViewContext;
-import org.apache.ambari.view.hive.persistence.IStorageFactory;
-import org.apache.ambari.view.hive.persistence.utils.Indexed;
-
-/**
- * Resource manager that doesn't restrict access (Allow all)
- * @param <T> Data type with ID
- */
-public class SharedCRUDResourceManager<T extends Indexed> extends CRUDResourceManager<T> {
-  protected ViewContext context;
-
-  /**
-   * Constructor
-   * @param responseClass model class
-   */
-  public SharedCRUDResourceManager(Class<T> responseClass, IStorageFactory storageFabric) {
-    super(responseClass, storageFabric);
-  }
-
-  @Override
-  protected boolean checkPermissions(T object) {
-    return true; //everyone has permission
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/browser/HiveBrowserService.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/browser/HiveBrowserService.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/browser/HiveBrowserService.java
deleted file mode 100644
index f758fe3..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/browser/HiveBrowserService.java
+++ /dev/null
@@ -1,276 +0,0 @@
-/**
- * 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.ambari.view.hive.resources.browser;
-
-import org.apache.ambari.view.ViewContext;
-import org.apache.ambari.view.ViewResourceHandler;
-import org.apache.ambari.view.hive.client.ColumnDescription;
-import org.apache.ambari.view.hive.client.Cursor;
-import org.apache.ambari.view.hive.client.UserLocalConnection;
-import org.apache.ambari.view.hive.resources.jobs.ResultsPaginationController;
-import org.apache.ambari.view.hive.utils.BadRequestFormattedException;
-import org.apache.ambari.view.hive.utils.ServiceFormattedException;
-import org.apache.ambari.view.hive.utils.SharedObjectsFactory;
-import org.apache.commons.collections4.map.PassiveExpiringMap;
-import org.apache.hive.service.cli.thrift.TSessionHandle;
-import org.json.simple.JSONObject;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-import javax.inject.Inject;
-import javax.ws.rs.*;
-import javax.ws.rs.core.MediaType;
-import javax.ws.rs.core.Response;
-import java.util.Collections;
-import java.util.List;
-import java.util.Map;
-import java.util.concurrent.Callable;
-
-/**
- * Database access resource
- */
-public class HiveBrowserService {
-  @Inject
-  ViewResourceHandler handler;
-  @Inject
-  protected ViewContext context;
-
-  protected final static Logger LOG =
-      LoggerFactory.getLogger(HiveBrowserService.class);
-
-  private static final long EXPIRING_TIME = 10*60*1000;  // 10 minutes
-  private static Map<String, Cursor> resultsCache;
-  private UserLocalConnection connectionLocal = new UserLocalConnection();
-
-  public static Map<String, Cursor> getResultsCache() {
-    if (resultsCache == null) {
-      PassiveExpiringMap<String, Cursor> resultsCacheExpiringMap =
-          new PassiveExpiringMap<String, Cursor>(EXPIRING_TIME);
-      resultsCache = Collections.synchronizedMap(resultsCacheExpiringMap);
-    }
-    return resultsCache;
-  }
-
-  /**
-   * Returns list of databases
-   */
-  @GET
-  @Path("database")
-  @Produces(MediaType.APPLICATION_JSON)
-  public Response databases(@QueryParam("like")String like,
-                            @QueryParam("first") String fromBeginning,
-                            @QueryParam("count") Integer count,
-                            @QueryParam("columns") final String requestedColumns) {
-    if (like == null)
-      like = "*";
-    else
-      like = "*" + like + "*";
-    String curl = null;
-    try {
-      JSONObject response = new JSONObject();
-      TSessionHandle session = connectionLocal.get(context).getOrCreateSessionByTag("DDL");
-      List<String> tables = connectionLocal.get(context).ddl().getDBList(session, like);
-      response.put("databases", tables);
-      return Response.ok(response).build();
-    } catch (WebApplicationException ex) {
-      throw ex;
-    } catch (IllegalArgumentException ex) {
-      throw new BadRequestFormattedException(ex.getMessage(), ex);
-    } catch (Exception ex) {
-      throw new ServiceFormattedException(ex.getMessage(), ex, curl);
-    }
-  }
-
-  /**
-   * Returns list of databases
-   */
-  @GET
-  @Path("database.page")
-  @Produces(MediaType.APPLICATION_JSON)
-  public Response databasesPaginated(@QueryParam("like")String like,
-                            @QueryParam("first") String fromBeginning,
-                            @QueryParam("count") Integer count,
-                            @QueryParam("searchId") String searchId,
-                            @QueryParam("format") String format,
-                            @QueryParam("columns") final String requestedColumns) {
-    if (like == null)
-      like = "*";
-    else
-      like = "*" + like + "*";
-    String curl = null;
-    try {
-      final String finalLike = like;
-      return ResultsPaginationController.getInstance(context)
-          .request("databases", searchId, false, fromBeginning, count, format,
-                  new Callable<Cursor>() {
-                    @Override
-                    public Cursor call() throws Exception {
-                      TSessionHandle session = connectionLocal.get(context).getOrCreateSessionByTag("DDL");
-                      return connectionLocal.get(context).ddl().getDBListCursor(session, finalLike);
-                    }
-                  }).build();
-    } catch (WebApplicationException ex) {
-      throw ex;
-    } catch (IllegalArgumentException ex) {
-      throw new BadRequestFormattedException(ex.getMessage(), ex);
-    } catch (Exception ex) {
-      throw new ServiceFormattedException(ex.getMessage(), ex, curl);
-    }
-  }
-
-  /**
-   * Returns list of databases
-   */
-  @GET
-  @Path("database/{db}/table")
-  @Produces(MediaType.APPLICATION_JSON)
-  public Response tablesInDatabase(@PathParam("db") String db,
-                                   @QueryParam("like")String like,
-                                   @QueryParam("first") String fromBeginning,
-                                   @QueryParam("count") Integer count,
-                                   @QueryParam("columns") final String requestedColumns) {
-    if (like == null)
-      like = "*";
-    else
-      like = "*" + like + "*";
-    String curl = null;
-    try {
-      JSONObject response = new JSONObject();
-      TSessionHandle session = connectionLocal.get(context).getOrCreateSessionByTag("DDL");
-      List<String> tables = connectionLocal.get(context).ddl().getTableList(session, db, like);
-      response.put("tables", tables);
-      response.put("database", db);
-      return Response.ok(response).build();
-    } catch (WebApplicationException ex) {
-      throw ex;
-    } catch (IllegalArgumentException ex) {
-      throw new BadRequestFormattedException(ex.getMessage(), ex);
-    } catch (Exception ex) {
-      throw new ServiceFormattedException(ex.getMessage(), ex, curl);
-    }
-  }
-
-  /**
-   * Returns list of databases
-   */
-  @GET
-  @Path("database/{db}/table.page")
-  @Produces(MediaType.APPLICATION_JSON)
-  public Response tablesInDatabasePaginated(@PathParam("db") final String db,
-                                   @QueryParam("like")String like,
-                                   @QueryParam("first") String fromBeginning,
-                                   @QueryParam("count") Integer count,
-                                   @QueryParam("searchId") String searchId,
-                                   @QueryParam("format") String format,
-                                   @QueryParam("columns") final String requestedColumns) {
-    if (like == null)
-      like = "*";
-    else
-      like = "*" + like + "*";
-    String curl = null;
-    try {
-      final String finalLike = like;
-      return ResultsPaginationController.getInstance(context)
-          .request(db + ":tables", searchId, false, fromBeginning, count, format,
-                  new Callable<Cursor>() {
-                    @Override
-                    public Cursor call() throws Exception {
-                      TSessionHandle session = connectionLocal.get(context).getOrCreateSessionByTag("DDL");
-                      Cursor cursor = connectionLocal.get(context).ddl().getTableListCursor(session, db, finalLike);
-                      cursor.selectColumns(requestedColumns);
-                      return cursor;
-                    }
-                  }).build();
-    } catch (WebApplicationException ex) {
-      throw ex;
-    } catch (IllegalArgumentException ex) {
-      throw new BadRequestFormattedException(ex.getMessage(), ex);
-    } catch (Exception ex) {
-      throw new ServiceFormattedException(ex.getMessage(), ex, curl);
-    }
-  }
-
-  /**
-   * Returns list of databases
-   */
-  @GET
-  @Path("database/{db}/table/{table}")
-  @Produces(MediaType.APPLICATION_JSON)
-  public Response describeTable(@PathParam("db") String db,
-                                @PathParam("table") String table,
-                                @QueryParam("like") String like,
-                                @QueryParam("columns") String requestedColumns,
-                                @QueryParam("extended") String extended) {
-    boolean extendedTableDescription = (extended != null && extended.equals("true"));
-    String curl = null;
-    try {
-      JSONObject response = new JSONObject();
-      TSessionHandle session = connectionLocal.get(context).getOrCreateSessionByTag("DDL");
-      List<ColumnDescription> columnDescriptions = connectionLocal.get(context).ddl()
-          .getTableDescription(session, db, table, like, extendedTableDescription);
-      response.put("columns", columnDescriptions);
-      response.put("database", db);
-      response.put("table", table);
-      return Response.ok(response).build();
-    } catch (WebApplicationException ex) {
-      throw ex;
-    } catch (IllegalArgumentException ex) {
-      throw new BadRequestFormattedException(ex.getMessage(), ex);
-    } catch (Exception ex) {
-      throw new ServiceFormattedException(ex.getMessage(), ex, curl);
-    }
-  }
-
-  /**
-   * Returns list of databases
-   */
-  @GET
-  @Path("database/{db}/table/{table}.page")
-  @Produces(MediaType.APPLICATION_JSON)
-  public Response describeTablePaginated(@PathParam("db") final String db,
-                                         @PathParam("table") final String table,
-                                         @QueryParam("like") final String like,
-                                         @QueryParam("first") String fromBeginning,
-                                         @QueryParam("searchId") String searchId,
-                                         @QueryParam("count") Integer count,
-                                         @QueryParam("format") String format,
-                                         @QueryParam("columns") final String requestedColumns) {
-    String curl = null;
-    try {
-      return ResultsPaginationController.getInstance(context)
-          .request(db + ":tables:" + table + ":columns", searchId, false, fromBeginning, count, format,
-              new Callable<Cursor>() {
-                @Override
-                public Cursor call() throws Exception {
-                  TSessionHandle session = connectionLocal.get(context).getOrCreateSessionByTag("DDL");
-                  Cursor cursor = connectionLocal.get(context).ddl().
-                      getTableDescriptionCursor(session, db, table, like);
-                  cursor.selectColumns(requestedColumns);
-                  return cursor;
-                }
-              }).build();
-    } catch (WebApplicationException ex) {
-      throw ex;
-    } catch (IllegalArgumentException ex) {
-      throw new BadRequestFormattedException(ex.getMessage(), ex);
-    } catch (Exception ex) {
-      throw new ServiceFormattedException(ex.getMessage(), ex, curl);
-    }
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/files/FileResource.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/files/FileResource.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/files/FileResource.java
deleted file mode 100644
index 633e859..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/files/FileResource.java
+++ /dev/null
@@ -1,70 +0,0 @@
-/**
- * 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.ambari.view.hive.resources.files;
-
-/**
- * File bean
- */
-public class FileResource {
-  private String filePath;
-  private String fileContent;
-  private boolean hasNext;
-  private long page;
-  private long pageCount;
-
-  public String getFilePath() {
-    return filePath;
-  }
-
-  public void setFilePath(String filePath) {
-    this.filePath = filePath;
-  }
-
-  public String getFileContent() {
-    return fileContent;
-  }
-
-  public void setFileContent(String fileContent) {
-    this.fileContent = fileContent;
-  }
-
-  public boolean isHasNext() {
-    return hasNext;
-  }
-
-  public void setHasNext(boolean hasNext) {
-    this.hasNext = hasNext;
-  }
-
-  public long getPage() {
-    return page;
-  }
-
-  public void setPage(long page) {
-    this.page = page;
-  }
-
-  public long getPageCount() {
-    return pageCount;
-  }
-
-  public void setPageCount(long pageCount) {
-    this.pageCount = pageCount;
-  }
-}
\ No newline at end of file


[14/23] ambari git commit: AMBARI-19302 : removed contrib/views/hive folder and made necessary changes in pom.xml files (nitirajrathore)

Posted by ni...@apache.org.
http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/controllers/index.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/controllers/index.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/controllers/index.js
deleted file mode 100644
index e7beb77..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/controllers/index.js
+++ /dev/null
@@ -1,767 +0,0 @@
-/** * 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.
- */
-
-import Ember from 'ember';
-import constants from 'hive/utils/constants';
-import utils from 'hive/utils/functions';
-
-export default Ember.Controller.extend({
-  jobService: Ember.inject.service(constants.namingConventions.job),
-  jobProgressService: Ember.inject.service(constants.namingConventions.jobProgress),
-  databaseService: Ember.inject.service(constants.namingConventions.database),
-  notifyService: Ember.inject.service(constants.namingConventions.notify),
-  session: Ember.inject.service(constants.namingConventions.session),
-  settingsService: Ember.inject.service(constants.namingConventions.settings),
-  ldapAuthenticationService: Ember.inject.service(constants.namingConventions.ldapAuthentication),
-
-  openQueries   : Ember.inject.controller(constants.namingConventions.openQueries),
-  udfs          : Ember.inject.controller(constants.namingConventions.udfs),
-  logs          : Ember.inject.controller(constants.namingConventions.jobLogs),
-  results       : Ember.inject.controller(constants.namingConventions.jobResults),
-  explain       : Ember.inject.controller(constants.namingConventions.jobExplain),
-  settings      : Ember.inject.controller(constants.namingConventions.settings),
-  visualExplain : Ember.inject.controller(constants.namingConventions.visualExplain),
-  tezUI         : Ember.inject.controller(constants.namingConventions.tezUI),
-
-  selectedDatabase: Ember.computed.alias('databaseService.selectedDatabase'),
-  isDatabaseExplorerVisible: true,
-  canKillSession: Ember.computed.and('model.sessionTag', 'model.sessionActive'),
-
-  queryProcessTabs: [
-    Ember.Object.create({
-      name: Ember.I18n.t('menus.logs'),
-      path: constants.namingConventions.subroutes.jobLogs
-    }),
-    Ember.Object.create({
-      name: Ember.I18n.t('menus.results'),
-      path: constants.namingConventions.subroutes.jobResults
-    }),
-    Ember.Object.create({
-      name: Ember.I18n.t('menus.explain'),
-      path: constants.namingConventions.subroutes.jobExplain
-    })
-  ],
-
-  queryPanelActions: [
-    Ember.Object.create({
-      icon: 'fa-expand',
-      action: 'toggleDatabaseExplorerVisibility',
-      tooltip: Ember.I18n.t('tooltips.expand')
-    })
-  ],
-
-  init: function () {
-    this._super();
-
-    // initialize queryParams with an empty array
-    this.set('queryParams', Ember.ArrayProxy.create({ content: Ember.A([]) }));
-
-    this.set('queryProcessTabs', Ember.ArrayProxy.create({ content: Ember.A([
-      Ember.Object.create({
-        name: Ember.I18n.t('menus.logs'),
-        path: constants.namingConventions.subroutes.jobLogs
-      }),
-      Ember.Object.create({
-        name: Ember.I18n.t('menus.results'),
-        path: constants.namingConventions.subroutes.jobResults
-      }),
-      Ember.Object.create({
-        name: Ember.I18n.t('menus.explain'),
-        path: constants.namingConventions.subroutes.jobExplain
-      })
-    ])}));
-
-    this.set('queryPanelActions', Ember.ArrayProxy.create({ content: Ember.A([
-      Ember.Object.create({
-        icon: 'fa-expand',
-        action: 'toggleDatabaseExplorerVisibility',
-        tooltip: Ember.I18n.t('tooltips.expand')
-      })
-    ])}));
-  },
-
-  canExecute: function () {
-    var isModelRunning = this.get('model.isRunning');
-    var hasParams = this.get('queryParams.length');
-
-    if (isModelRunning) {
-      return false;
-    }
-
-    if (hasParams) {
-      // all param have values?
-      return this.get('queryParams').every(function (param) { return param.value; });
-    }
-
-    return true;
-  }.property('model.isRunning', 'queryParams.@each.value'),
-
-  currentQueryObserver: function () {
-    var query = this.get('openQueries.currentQuery.fileContent'),
-        param,
-        updatedParams = [],
-        currentParams = this.get('queryParams'),
-        paramRegExp = /\$\w+/ig,
-        paramNames = query.match(paramRegExp) || [];
-
-    paramNames = paramNames.uniq();
-
-    paramNames.forEach(function (name) {
-      param = currentParams.findBy('name', name);
-      if (param) {
-        updatedParams.push(param);
-      } else {
-        updatedParams.push({ name: name, value: "" });
-      }
-    });
-
-    currentParams.setObjects(updatedParams);
-
-    this.set('visualExplain.shouldChangeGraph', true);
-  }.observes('openQueries.currentQuery.fileContent'),
-
-  _executeQuery: function (referrer, shouldExplain, shouldGetVisualExplain) {
-    var queryId,
-        query,
-        finalQuery,
-        job,
-        defer = Ember.RSVP.defer(),
-        originalModel = this.get('model');
-
-    var title = "";
-    if(shouldGetVisualExplain){
-      title += "Visual Explain "
-    }else if(shouldExplain){
-      title += "Explain "
-    }
-
-    title += originalModel.get('title');
-    job = this.store.createRecord(constants.namingConventions.job, {
-      title: title,
-      sessionTag: originalModel.get('sessionTag'),
-      dataBase: this.get('selectedDatabase.name'),
-      referrer: referrer
-    });
-
-    if (!shouldGetVisualExplain) {
-      originalModel.set('isRunning', true);
-    }
-
-     //if it's a saved query / history entry set the queryId
-    if (!originalModel.get('isNew')) {
-      queryId = originalModel.get('constructor.typeKey') === constants.namingConventions.job ?
-                originalModel.get('queryId') :
-                originalModel.get('id');
-
-      job.set('queryId', queryId);
-    }
-
-    query = this.get('openQueries').getQueryForModel(originalModel);
-
-    query = this.buildQuery(query, shouldExplain, shouldGetVisualExplain);
-
-
-    // Condition for no query.
-    if(query === ';') {
-      originalModel.set('isEmptyQuery', true);
-      originalModel.set('isRunning', false);
-      defer.reject({
-        message: 'No query to process.'
-      });
-      return defer.promise;
-    }
-
-    // for now we won't support multiple queries
-    // buildQuery will return false it multiple queries
-    // are selected
-    if (!query) {
-      originalModel.set('isRunning', false);
-      defer.reject({
-        message: 'Running multiple queries is not supported.'
-      });
-
-      return defer.promise;
-    }
-
-    finalQuery = query;
-    finalQuery = this.bindQueryParams(finalQuery);
-    finalQuery = this.prependGlobalSettings(finalQuery, job);
-    job.set('forcedContent', finalQuery);
-
-    if (shouldGetVisualExplain) {
-      return this.getVisualExplainJson(job, originalModel);
-    }
-
-    return this.createJob(job, originalModel);
-  },
-
-  getVisualExplainJson: function (job, originalModel) {
-    var self = this;
-    var defer = Ember.RSVP.defer();
-
-    job.save().then(function () {
-      self.get('results').getResultsJson(job).then(function (json) {
-        defer.resolve(json);
-      }, function (err) {
-        defer.reject(err);
-      });
-    }, function (err) {
-      defer.reject(err);
-    });
-
-    return defer.promise;
-  },
-
-  createJob: function (job, originalModel) {
-    var defer = Ember.RSVP.defer(),
-        self = this,
-        openQueries = this.get('openQueries');
-
-    var handleError = function (err) {
-      self.set('jobSaveSucceeded');
-      originalModel.set('isRunning', undefined);
-      defer.reject(err);
-
-      if(err.status == 401) {
-          self.send('passwordLDAP', job, originalModel);
-      }
-
-    };
-
-    job.save().then(function () {
-      //convert tab for current model since the execution will create a new job, and navigate to the new job route.
-      openQueries.convertTabToJob(originalModel, job).then(function () {
-        self.get('jobProgressService').setupProgress(job);
-        self.set('jobSaveSucceeded', true);
-
-        //reset flag on the original model
-        originalModel.set('isRunning', undefined);
-
-        defer.resolve(job);
-      }, function (err) {
-        handleError(err);
-      });
-    }, function (err) {
-      handleError(err);
-    });
-
-    return defer.promise;
-  },
-
-  prependGlobalSettings: function (query, job) {
-    var jobGlobalSettings = job.get('globalSettings');
-    var currentGlobalSettings = this.get('settingsService').getSettings();
-
-    // remove old globals
-    if (jobGlobalSettings) {
-      query.replace(jobGlobalSettings, '');
-    }
-
-    job.set('globalSettings', currentGlobalSettings);
-    query = currentGlobalSettings + query;
-
-    return query;
-  },
-
-  buildQuery: function (query, shouldExplain, shouldGetVisualExplain) {
-    var selections = this.get('openQueries.highlightedText'),
-        isQuerySelected = selections && selections[0] !== "",
-        queryContent = query ? query.get('fileContent') : '',
-        queryComponents = this.extractComponents(queryContent),
-        finalQuery = '',
-        queries = null;
-
-    if (isQuerySelected) {
-      queryComponents.queryString = selections.join('');
-    }
-
-    queries = queryComponents.queryString.split(';');
-    queries = queries.filter(Boolean);
-
-    var queriesLength = queries.length;
-
-    queries = queries.map(function (q, index) {
-      var newQuery = q.replace(/explain formatted|explain/gi, '');
-      return newQuery;
-    });
-
-    var lastQuery = queries[queriesLength - 1];
-
-    if(!Ember.isNone(lastQuery) && shouldExplain) {
-      if (shouldGetVisualExplain) {
-        lastQuery = constants.namingConventions.explainFormattedPrefix + lastQuery;
-      } else {
-        lastQuery = constants.namingConventions.explainPrefix + lastQuery;
-      }
-      queries[queriesLength - 1] = lastQuery;
-    }
-
-    if (queryComponents.files.length) {
-      finalQuery += queryComponents.files.join("\n") + "\n\n";
-    }
-
-    if (queryComponents.udfs.length) {
-      finalQuery += queryComponents.udfs.join("\n") + "\n\n";
-    }
-
-    finalQuery += queries.join(";");
-    if(!finalQuery.trim().endsWith(';')){
-      finalQuery = finalQuery.trim() + ";";
-    }
-
-    return finalQuery.trim();
-  },
-
-  bindQueryParams: function (query) {
-    var params = this.get('queryParams');
-
-    if (!params.get('length')) {
-      return query;
-    }
-
-    params.forEach(function (param) {
-      query = query.split(param.name).join(param.value);
-    });
-
-    return query;
-  },
-
-  displayJobTabs: function () {
-    return this.get('content.constructor.typeKey') === constants.namingConventions.job &&
-           utils.isInteger(this.get('content.id')) &&
-           this.get('jobSaveSucceeded');
-  }.property('content', 'jobSaveSucceeded'),
-
-  databasesOrModelChanged: function () {
-    this.get('databaseService').setDatabaseByName(this.get('content.dataBase'));
-  }.observes('databaseService.databases', 'content'),
-
-  selectedDatabaseChanged: function () {
-    this.set('content.dataBase', this.get('selectedDatabase.name'));
-  }.observes('selectedDatabase'),
-
-  modelChanged: function () {
-    var self = this;
-    var content = this.get('content');
-    var openQueries = this.get('openQueries');
-
-    this.set('jobSaveSucceeded', true);
-
-    //update open queries list when current query model changes
-    openQueries.update(content).then(function (isExplainedQuery) {
-      var newId = content.get('id');
-      var tab = openQueries.getTabForModel(content);
-
-      //if not an ATS job
-      if (content.get('constructor.typeKey') === constants.namingConventions.job && utils.isInteger(newId)) {
-        self.get('queryProcessTabs').forEach(function (queryTab) {
-          queryTab.set('id', newId);
-        });
-
-        if (isExplainedQuery) {
-          self.set('explain.content', content);
-        } else {
-          self.set('logs.content', content);
-          self.set('results.content', content);
-        }
-
-        self.setExplainVisibility(isExplainedQuery);
-
-        self.transitionToRoute(tab.get('subroute'));
-      }
-    });
-  }.observes('content'),
-
-  csvUrl: function () {
-    if (this.get('content.constructor.typeKey') !== constants.namingConventions.job) {
-      return;
-    }
-
-    if (!utils.insensitiveCompare(this.get('content.status'), constants.statuses.succeeded)) {
-      return;
-    }
-
-    var url = this.container.lookup('adapter:application').buildURL();
-    url += '/' + constants.namingConventions.jobs + '/' + this.get('content.id');
-    url += '/results/csv';
-
-    return url;
-  }.property('content'),
-
-  downloadMenu: function () {
-    var items = [];
-    var tabs = this.get('queryProcessTabs');
-    var isResultsTabVisible = tabs.findBy('path', constants.namingConventions.subroutes.jobResults).get('visible');
-
-    if (utils.insensitiveCompare(this.get('content.status'), constants.statuses.succeeded) && isResultsTabVisible) {
-      items.push({
-        title: Ember.I18n.t('buttons.saveHdfs'),
-        action: 'saveToHDFS'
-      });
-
-      if (this.get('csvUrl')) {
-        items.push(
-          Ember.Object.create({
-            title: Ember.I18n.t('buttons.saveCsv'),
-            action: 'downloadAsCSV'
-          })
-        );
-      }
-    }
-
-    return items.length ? items : null;
-  }.property('content.status', 'queryProcessTabs.@each.visible'),
-
-  extractComponents: function (queryString) {
-    var components = {};
-
-    var udfRegEx = new RegExp("(" + constants.namingConventions.udfInsertPrefix + ").+", "ig");
-    var fileRegEx = new RegExp("(" + constants.namingConventions.fileInsertPrefix + ").+", "ig");
-
-    components.udfs         = queryString.match(udfRegEx) || [];
-    components.files        = queryString.match(fileRegEx) || [];
-    components.queryString  = queryString.replace(udfRegEx, "").replace(fileRegEx, "").trim();
-
-    return components;
-  },
-
-  saveToHDFS: function (path) {
-    var job = this.get('content');
-
-    if (!utils.insensitiveCompare(job.get('status'), constants.statuses.succeeded)) {
-      return;
-    }
-
-    var self = this;
-
-    var file = path + ".csv";
-    var url = this.container.lookup('adapter:application').buildURL();
-    url +=  "/jobs/" + job.get('id') + "/results/csv/saveToHDFS";
-
-    Ember.$.getJSON(url, {
-        commence: true,
-        file: file
-    }).then(function (response) {
-      self.pollSaveToHDFS(response);
-    }, function (error) {
-      self.get('notifyService').error(error);
-    });
-  },
-
-  pollSaveToHDFS: function (data) {
-    var self = this;
-    var url = this.container.lookup('adapter:application').buildURL();
-    url += "/jobs/" + data.jobId + "/results/csv/saveToHDFS";
-
-    Ember.run.later(function () {
-      Ember.$.getJSON(url).then(function (response) {
-        if (!utils.insensitiveCompare(response.status, constants.results.statuses.terminated)) {
-          self.pollSaveToHDFS(response);
-        } else {
-          self.set('content.isRunning', false);
-        }
-      }, function (error) {
-        self.get('notifyService').error(error);
-      });
-    }, 2000);
-  },
-
-  setExplainVisibility: function (show) {
-    var tabs = this.get('queryProcessTabs');
-
-    tabs.findBy('path', constants.namingConventions.subroutes.jobExplain).set('visible', show);
-    tabs.findBy('path', constants.namingConventions.subroutes.jobLogs).set('visible', !show);
-    tabs.findBy('path', constants.namingConventions.subroutes.jobResults).set('visible', !show);
-  },
-
-  queryProcessTitle: function () {
-    return Ember.I18n.t('titles.query.process') + ' (' + Ember.I18n.t('titles.query.status') + this.get('content.status') + ')';
-  }.property('content.status'),
-
-  updateSessionStatus: function() {
-    this.get('session').updateSessionStatus(this.get('model'));
-  }.observes('model', 'model.status'),
-
-  actions: {
-    passwordLDAP: function(){
-      var job = arguments[0],
-            originalModel = arguments[1],
-            self = this,
-            defer = Ember.RSVP.defer();
-
-      this.send('openModal', 'modal-save', {
-        heading: "modals.authenticationLDAP.heading",
-        text:"",
-        type: "password",
-        defer: defer
-      });
-
-      defer.promise.then(function (text) {
-        var ldapAuthPromise = self.get('ldapAuthenticationService').authenticateLdapPassword(text);
-
-        ldapAuthPromise.then(function (data) {
-          console.log( "LDAP done: " + data );
-          self.get('databaseService').getDatabases().then(function (databases) {
-            var selectedDatabase = self.get('databaseService.selectedDatabase.name') || 'default';
-            self.get('databaseService').setDatabaseByName( selectedDatabase);
-            return self.send('executeQuery', 'job', self.get('openQueries.currentQuery.fileContent') );
-          }).catch(function (error) {
-            self.get('notifyService').error( "Error in accessing databases." );
-          });
-
-        }, function (error) {
-          console.log( "LDAP fail: " + error );
-          self.get('notifyService').error( "Wrong Credentials." );
-        })
-      });
-
-    },
-
-    stopCurrentJob: function () {
-      this.get('jobService').stopJob(this.get('model'));
-    },
-
-    saveToHDFS: function () {
-      var self = this,
-          defer = Ember.RSVP.defer();
-
-      this.send('openModal', 'modal-save', {
-        heading: "modals.download.hdfs",
-        text: this.get('content.title') + '_' + this.get('content.id'),
-        defer: defer
-      });
-
-      defer.promise.then(function (text) {
-        self.set('content.isRunning', true);
-        self.saveToHDFS(text);
-      });
-    },
-
-    downloadAsCSV: function () {
-      var self = this,
-          defer = Ember.RSVP.defer();
-
-      this.send('openModal', 'modal-save', {
-        heading: "modals.download.csv",
-        text: this.get('content.title'),
-        defer: defer
-      });
-
-      defer.promise.then(function (text) {
-        // download file ...
-        var urlString = "%@/?fileName=%@.csv";
-        var url = self.get('csvUrl');
-        url = urlString.fmt(url, text);
-        window.open(url);
-      });
-    },
-
-    insertUdf: function (item) {
-      var query = this.get('openQueries.currentQuery');
-
-      var queryString = query.get('fileContent');
-
-      var newUdf = constants.namingConventions.udfInsertPrefix + item.get('name') + " as '" + item.get('classname') + "';";
-      var newFileResource = item.get('fileResource.path');
-
-      if (item.get('fileResource.path')) {
-        newFileResource = constants.namingConventions.fileInsertPrefix + item.get('fileResource.path') + ";";
-      }
-
-      var components = this.extractComponents(queryString);
-
-      if (!components.files.contains(newFileResource) && newFileResource) {
-        components.files.push(newFileResource);
-      }
-
-      if (!components.udfs.contains(newUdf)) {
-        components.udfs.push(newUdf);
-      }
-
-      var updatedContent = components.files.join("\n") + "\n\n";
-      updatedContent += components.udfs.join("\n") + "\n\n";
-      updatedContent += components.queryString;
-
-      query.set('fileContent', updatedContent);
-    },
-
-    filesUploaded: (function(files) {
-      var idCounter = 0;
-      return function (files) {
-        var self=this;
-        var name = files[0].name;
-        var i = name.indexOf(".");
-        var title = name.substr(0, i);
-        idCounter++;
-        var defer = Ember.RSVP.defer()
-        var reader = new FileReader();
-
-        reader.onloadstart = function(e) {
-          Ember.$("#uploadProgressModal").modal("show");
-        }
-        reader.onloadend = function(e) {
-          defer.resolve(e.target.result);
-        }
-        reader.onerror = function(e) {
-          self.get('notifyService').error("Upload failed");
-          Ember.$("#uploadProgressModal").modal("hide");
-        }
-        reader.readAsText(files[0]);
-        defer.promise.then(function(data) {
-        var model = self.store.createRecord(constants.namingConventions.savedQuery, {
-          dataBase: self.get('selectedDatabase.name'),
-          title: title,
-          id: 'fixture_upload' + idCounter
-          });
-        return Ember.RSVP.resolve(self.transitionToRoute(constants.namingConventions.subroutes.savedQuery, model)).then(function() {
-          return data;
-        });
-        }). then(function(data) {
-          self.set('openQueries.currentQuery.fileContent',data);
-          Ember.$("#uploadProgressModal").modal("hide");
-        });
-        };
-    }()),
-
-    addQuery: (function () {
-      var idCounter = 0;
-
-      return function (workSheetName) {
-        var model = this.store.createRecord(constants.namingConventions.savedQuery, {
-          dataBase: this.get('selectedDatabase.name'),
-          title: workSheetName ? workSheetName : Ember.I18n.t('titles.query.tab'),
-          queryFile: '',
-          id: 'fixture_' + idCounter
-        });
-
-        if (idCounter && !workSheetName) {
-          model.set('title', model.get('title') + ' (' + idCounter + ')');
-        }
-
-        idCounter++;
-
-        this.transitionToRoute(constants.namingConventions.subroutes.savedQuery, model);
-      };
-    }()),
-
-    saveQuery: function () {
-      //case 1. Save a new query from a new query tab -> route changes to new id
-      //case 2. Save a new query from an existing query tab -> route changes to new id
-      //case 3. Save a new query from a job tab -> route doesn't change
-      //case 4. Update an existing query tab. -> route doesn't change
-
-      var self = this,
-          defer = Ember.RSVP.defer(),
-          currentQuery = this.get('openQueries.currentQuery');
-
-      this.set('model.dataBase', this.get('selectedDatabase.name'));
-
-      this.send('openModal', 'modal-save-query', {
-        heading: 'modals.save.heading',
-        message: 'modals.save.overwrite',
-        text: this.get('content.title'),
-        content: this.get('content'),
-        defer: defer
-      });
-
-      defer.promise.then(function (result) {
-        // we need to update the original model
-        // because when this is executed
-        // it sets the title from the original model
-        self.set('model.title', result.get('text'));
-
-        if (result.get('overwrite')) {
-          self.get('openQueries').save(self.get('content'), null, true, result.get('text')).then(function () {
-            self.get('notifyService').success(Ember.I18n.t('alerts.success.query.update'));
-          });
-        } else {
-          self.get('openQueries').save(self.get('content'), null, false, result.get('text')).then(function (newId) {
-            self.get('notifyService').success(Ember.I18n.t('alerts.success.query.save'));
-
-            if (self.get('model.constructor.typeKey') !== constants.namingConventions.job) {
-              self.transitionToRoute(constants.namingConventions.subroutes.savedQuery, newId);
-            }
-          });
-        }
-      });
-    },
-
-    executeQuery: function (referrer, query) {
-      var self = this;
-
-      var isExplainQuery = (self.get('openQueries.currentQuery.fileContent').toUpperCase().trim().indexOf(constants.namingConventions.explainPrefix) === 0);
-
-      if(isExplainQuery){
-        self.send('explainQuery');
-        return;
-      }
-
-      var subroute;
-
-      if (query) {
-        this.set('openQueries.currentQuery.fileContent', query);
-      }
-
-      referrer = referrer || constants.jobReferrer.job;
-
-      this._executeQuery(referrer).then(function (job) {
-        if (job.get('status') !== constants.statuses.succeeded) {
-          subroute = constants.namingConventions.subroutes.jobLogs;
-        } else {
-          subroute = constants.namingConventions.subroutes.jobResults;
-        }
-
-        self.get('openQueries').updateTabSubroute(job, subroute);
-        self.get('notifyService').success(Ember.I18n.t('alerts.success.query.execution'));
-        self.transitionToRoute(constants.namingConventions.subroutes.historyQuery, job.get('id'));
-      }, function (error) {
-        self.get('notifyService').error(error);
-      });
-    },
-
-    explainQuery: function () {
-      var self = this;
-
-      this._executeQuery(constants.jobReferrer.explain, true).then(function (job) {
-        self.get('openQueries').updateTabSubroute(job, constants.namingConventions.subroutes.jobExplain);
-
-        self.transitionToRoute(constants.namingConventions.subroutes.historyQuery, job.get('id'));
-      }, function (error) {
-        self.get('notifyService').error(error);
-      });
-    },
-
-    toggleDatabaseExplorerVisibility: function () {
-      this.toggleProperty('isDatabaseExplorerVisible');
-    },
-
-    killSession: function() {
-      var self = this;
-      var model = this.get('model');
-
-      this.get('session').killSession(model)
-        .catch(function (response) {
-          if ([200, 404].contains(response.status)) {
-            model.set('sessionActive', false);
-            self.notify.success(Ember.I18n.t('alerts.success.sessions.deleted'));
-          } else {
-            self.notify.error(response);
-          }
-        });
-    }
-  }
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/controllers/index/history-query/explain.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/controllers/index/history-query/explain.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/controllers/index/history-query/explain.js
deleted file mode 100644
index bc74e0b..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/controllers/index/history-query/explain.js
+++ /dev/null
@@ -1,142 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-import constants from 'hive/utils/constants';
-import utils from 'hive/utils/functions';
-
-export default Ember.ObjectController.extend({
-  cachedExplains: [],
-
-  clearCachedExplainSet: function (jobId) {
-    var existingJob = this.get('cachedExplains').findBy('id', jobId);
-
-    if (existingJob) {
-      this.set('cachedExplains', this.get('cachedExplains').without(existingJob));
-    }
-  },
-
-  initExplain: function () {
-    var cachedExplain;
-
-    cachedExplain = this.get('cachedExplains').findBy('id', this.get('content.id'));
-
-    if (cachedExplain) {
-      this.formatExplainResults(cachedExplain);
-    } else {
-      this.getExplain(true);
-    }
-  }.observes('content'),
-
-  getExplain: function (firstPage, rows) {
-    var self = this;
-    var url = this.container.lookup('adapter:application').buildURL();
-    url += '/' + constants.namingConventions.jobs + '/' + this.get('content.id') + '/results';
-
-    if (firstPage) {
-      url += '?first=true';
-    }
-
-    this.get('content').reload().then(function () {
-      Ember.$.getJSON(url).then(function (data) {
-        var explainSet;
-
-        //if rows from a previous page read exist, prepend them
-        if (rows) {
-          data.rows.unshiftObjects(rows);
-        }
-
-        if (!data.hasNext) {
-          explainSet = self.get('cachedExplains').pushObject(Ember.Object.create({
-            id: self.get('content.id'),
-            explain: data
-          }));
-
-          self.set('content.explain', explainSet);
-
-          self.formatExplainResults(explainSet);
-        } else {
-          self.getExplain(false, data.rows);
-        }
-      });
-    })
-  },
-
-  formatExplainResults: function (explainSet) {
-    var formatted = [],
-        currentNode,
-        currentNodeWhitespace,
-        previousNode,
-        getLeadingWhitespacesCount = function (str) {
-          return str.replace(utils.regexes.whitespaces, '$1').length;
-        };
-
-    explainSet = explainSet
-                 .get('explain.rows')
-                 .map(function (row) {
-                    return row[0];
-                  })
-                 .filter(Boolean)
-                 .map(function (str) {
-                    return {
-                      text: str,
-                      parentNode: null,
-                      contents: []
-                    };
-                  });
-
-    for (var i = 0; i < explainSet.length; i++) {
-      currentNode = explainSet[i];
-      previousNode = explainSet[i-1];
-
-      if (i > 0) {
-        currentNodeWhitespace = getLeadingWhitespacesCount(currentNode.text);
-
-        if (currentNodeWhitespace > getLeadingWhitespacesCount(previousNode.text)) {
-          currentNode.parentNode = previousNode;
-          previousNode.contents.pushObject(currentNode);
-        } else {
-          for (var j = i - 1; j >= 0; j--) {
-            if (currentNodeWhitespace === getLeadingWhitespacesCount(explainSet[j].text)) {
-              if (currentNodeWhitespace > 0) {
-                currentNode.parentNode = explainSet[j].parentNode;
-                currentNode.parentNode.contents.pushObject(currentNode);
-              } else {
-                formatted.pushObject(currentNode);
-              }
-              break;
-            }
-          }
-        }
-      } else {
-        formatted.pushObject(currentNode);
-      }
-    }
-    formatted = this.filterExplain(formatted);
-    this.set('formattedExplain', formatted);
-  },
-  filterExplain: function (explain){
-    var formattedExplain = explain.filter(function(item){
-      if(item.text !== '""'){
-        return item;
-      }
-    })
-    return formattedExplain;
-  }
-});
-

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/controllers/index/history-query/logs.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/controllers/index/history-query/logs.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/controllers/index/history-query/logs.js
deleted file mode 100644
index 43c7a7e..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/controllers/index/history-query/logs.js
+++ /dev/null
@@ -1,108 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-import constants from 'hive/utils/constants';
-import utils from 'hive/utils/functions';
-
-export default Ember.ObjectController.extend({
-  fileService: Ember.inject.service(constants.namingConventions.file),
-  notifyService: Ember.inject.service(constants.namingConventions.notify),
-
-  needs: [ constants.namingConventions.queryTabs,
-           constants.namingConventions.index,
-           constants.namingConventions.openQueries ],
-
-  queryTabs: Ember.computed.alias('controllers.' + constants.namingConventions.queryTabs),
-  index: Ember.computed.alias('controllers.' + constants.namingConventions.index),
-  openQueries: Ember.computed.alias('controllers.' + constants.namingConventions.openQueries),
-
-  reloadJobLogs: function (job) {
-    var self = this;
-    var handleError = function (error) {
-      job.set('isRunning', false);
-
-      self.get('notifyService').error(error);
-    };
-
-    job.reload().then(function () {
-      if (utils.insensitiveCompare(job.get('status'), constants.statuses.error) ||
-          utils.insensitiveCompare(job.get('status'), constants.statuses.failed)) {
-        handleError(job.get('statusMessage'));
-      }
-
-      self.get('fileService').reloadFile(job.get('logFile')).then(function (file) {
-        var fileContent = file.get('fileContent');
-        var stillRunning = self.isJobRunning(job);
-        var currentIndexModelId = self.get('index.model.id');
-        var currentActiveTab = self.get('queryTabs.activeTab.name');
-
-        if (fileContent) {
-          job.set('log', fileContent);
-        }
-
-        //if the current model is the same with the one displayed, continue reloading job
-        if (stillRunning) {
-          Ember.run.later(self, function () {
-            this.reloadJobLogs(job);
-          }, 10000);
-        } else if (!stillRunning) {
-          job.set('isRunning', undefined);
-          job.set('retrievingLogs', false);
-
-          if (utils.insensitiveCompare(job.get('status'), constants.statuses.succeeded)) {
-            self.get('openQueries').updateTabSubroute(job, constants.namingConventions.subroutes.jobResults);
-
-            if (job.get('id') === currentIndexModelId && currentActiveTab === constants.namingConventions.index) {
-              self.transitionToRoute(constants.namingConventions.subroutes.historyQuery, job.get('id'));
-            }
-          }
-        }
-
-      },function (err) {
-        handleError(err);
-      });
-    }, function (err) {
-      handleError(err);
-    });
-  },
-
-  isJobRunning: function (job) {
-    return utils.insensitiveCompare(job.get('status'),
-                                    constants.statuses.unknown,
-                                    constants.statuses.initialized,
-                                    constants.statuses.running,
-                                    constants.statuses.pending);
-  },
-
-  getLogs: function () {
-    var job = this.get('content');
-
-    if (this.isJobRunning(job)) {
-      if (!job.get('retrievingLogs')) {
-        job.set('retrievingLogs', true);
-        job.set('isRunning', true);
-        this.reloadJobLogs(job);
-      }
-    } else if (utils.insensitiveCompare(job.get('status'), constants.statuses.succeeded) && !job.get('dagId')) {
-      //if a job that never polled for logs is succeeded, jump straight to results tab.
-      this.get('openQueries').updateTabSubroute(job, constants.namingConventions.subroutes.jobResults);
-      this.transitionToRoute(constants.namingConventions.subroutes.historyQuery, job.get('id'));
-    }
-  }.observes('content')
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/controllers/index/history-query/results.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/controllers/index/history-query/results.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/controllers/index/history-query/results.js
deleted file mode 100644
index 9e94b17..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/controllers/index/history-query/results.js
+++ /dev/null
@@ -1,238 +0,0 @@
-
-/**
- * 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.
- */
-
-import Ember from 'ember';
-import constants from 'hive/utils/constants';
-import utils from 'hive/utils/functions';
-
-export default Ember.ObjectController.extend({
-  cachedResults: [],
-  formattedResults: [],
-
-  processResults: function () {
-    var results = this.get('results');
-    var filterValue = this.get('filterValue');
-    var columns;
-    var rows;
-    var filteredColumns;
-    var filteredRows;
-
-    if (!results) {
-      return;
-    }
-
-    columns = results.schema;
-    rows = results.rows;
-
-    if (!columns || !rows) {
-      return;
-    }
-
-    columns = columns.map(function (column) {
-      return {
-        name: column[0],
-        type: column[1],
-        index: column[2] - 1 //normalize index to 0 based
-      };
-    });
-
-    if (filterValue) {
-      filteredColumns = columns.filter(function (column) {
-        return utils.insensitiveContains(column.name, filterValue);
-      });
-
-      if (filteredColumns.length < columns.length) {
-        filteredRows = rows.map(function (row) {
-          var updatedRow = [];
-
-          updatedRow.pushObjects(row.filter(function (item, index) {
-            return this.findBy('index', index);
-          }, this));
-
-          return updatedRow;
-        }, filteredColumns);
-      } else {
-        filteredRows = rows;
-      }
-    } else {
-      filteredColumns = columns;
-      filteredRows = rows;
-    }
-
-    this.set('formattedResults', { columns: filteredColumns, rows: filteredRows });
-  }.observes('results', 'filterValue'),
-
-  keepAlive: function (job) {
-    Ember.run.later(this, function () {
-      var self = this;
-      var url = this.container.lookup('adapter:application').buildURL();
-      url += '/' + constants.namingConventions.jobs + '/' + job.get('id') + '/results/keepAlive';
-
-      var existingJob = self.cachedResults.findBy('id', job.get('id'));
-
-      if (existingJob) {
-        Ember.$.getJSON(url).fail(function (data) {
-          //backend issue, this will be split in done and fail callbacks once its fixed.
-          if (data.status === 404) {
-            existingJob.set('results', []);
-            self.set('error', data.responseJSON.message);
-          } else if (data.status === 200) {
-            self.keepAlive(job);
-          }
-        });
-      }
-    }, 1000 * 300);
-  },
-
-  clearCachedResultsSet: function (jobId) {
-    this.set('cachedResults', this.get('cachedResults').without(this.get('cachedResults').findBy('id', jobId)));
-  },
-
-  initResults: function () {
-    var existingJob;
-
-    if (!utils.insensitiveCompare(this.get('content.status'), constants.statuses.succeeded)) {
-      return;
-    }
-
-    existingJob = this.cachedResults.findBy('id', this.get('content.id'));
-
-    if (existingJob) {
-      this.set('results', existingJob.results.findBy('offset', existingJob.get('offset')));
-    } else {
-      this.send('getNextPage', true);
-    }
-  }.observes('content.status'),
-
-  disableNext: function () {
-    return !this.get('results.hasNext');
-  }.property('results'),
-
-  disablePrevious: function () {
-    return this.cachedResults.findBy('id', this.get('content.id')).results.indexOf(this.get('results')) <= 0;
-  }.property('results'),
-
-  getResultsJson: function (job) {
-    var defer = Ember.RSVP.defer();
-    var url = this.container.lookup('adapter:application').buildURL();
-    url += '/' + constants.namingConventions.jobs + '/' + job.get('id') + '/results?first=true';
-
-    Ember.$.getJSON(url).then(function (results) {
-      defer.resolve(JSON.parse(results.rows[0][0]));
-    }, function (err) {
-      defer.reject(err);
-    });
-
-    return defer.promise;
-  },
-
-  getResult : function(url){
-    var promise = new Ember.RSVP.Promise(function(resolve,reject){
-      var getData =  function(){
-        //console.log("getData called.");
-        Ember.$.getJSON(url).done(function(data){
-          console.log('results.js : getResult : got success data');
-          resolve(data);
-        }).fail(function(err){
-          if(err.status == 503 && err.getResponseHeader('Retry-After')){
-            var time = Number(err.getResponseHeader('Retry-After'));
-            console.log("results.js : getResult : got error : " + err.status + " with retry.");
-            Ember.run.later(this,
-            function(){
-              getData();
-            },time*1000);
-          }else{
-            console.log("results.js : getResult : rejected. ");
-            reject(err);
-          }
-        });
-      };
-      getData();
-    });
-
-    return promise;
-  },
-
-  actions: {
-    getNextPage: function (firstPage, job) {
-      var self = this;
-      var id = job ? job.get('id') : this.get('content.id');
-      var existingJob = this.cachedResults.findBy('id', id);
-      var resultsIndex;
-      var url = this.container.lookup('adapter:application').buildURL();
-      url += '/' + constants.namingConventions.jobs + '/' + id + '/results';
-
-      if (firstPage) {
-        url += '?first=true';
-      }
-
-      if (existingJob) {
-        resultsIndex = existingJob.results.indexOf(this.get('results'));
-
-        if (~resultsIndex && resultsIndex < existingJob.get('results.length') - 1) {
-          this.set('results', existingJob.results.objectAt(resultsIndex + 1));
-          return;
-        }
-      }
-
-      this.getResult(url)
-      .then(function (results) {
-        //console.log("inside then : ", results);
-        if (existingJob) {
-          existingJob.results.pushObject(results);
-          existingJob.set('offset', results.offset);
-        } else {
-          self.cachedResults.pushObject(Ember.Object.create({
-            id: id,
-            results: [ results ],
-            offset: results.offset
-          }));
-        }
-
-        //only set results if the method was called for the current model, not after a keepAlive request.
-        if (!job) {
-          self.set('results', results);
-        }
-
-        if (firstPage) {
-          self.keepAlive(job || self.get('content'));
-        }
-
-      }, function (err) {
-        self.set('error', err.responseText);
-      });
-    },
-
-    getPreviousPage: function () {
-      var existingJob,
-          resultsIndex;
-
-      existingJob = this.cachedResults.findBy('id', this.get('content.id'));
-      resultsIndex = existingJob.results.indexOf(this.get('results'));
-
-      if (resultsIndex > 0) {
-        this.set('results', existingJob.results.objectAt(resultsIndex - 1));
-      }
-    },
-
-    filterResults: function (value) {
-      this.set('filterValue', value);
-    }
-  }
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/controllers/insert-udfs.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/controllers/insert-udfs.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/controllers/insert-udfs.js
deleted file mode 100644
index 09f17c3..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/controllers/insert-udfs.js
+++ /dev/null
@@ -1,58 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-import constants from 'hive/utils/constants';
-
-export default Ember.ArrayController.extend({
-  needs: [ constants.namingConventions.udfs ],
-
-  model: Ember.A(),
-
-  udfs: Ember.computed.alias('controllers.' + constants.namingConventions.udfs + '.udfs'),
-
-  updateUdfs: function () {
-    var self = this,
-        udfs = this.get('udfs'),
-        udfsWithoutFiles;
-
-    this.clear();
-
-    if (udfs && udfs.get('length')) {
-      udfs.getEach('fileResource.id').uniq().forEach(function (fileResourceId) {
-        if (fileResourceId) {
-          self.pushObject(Ember.Object.create({
-            file: udfs.findBy('fileResource.id', fileResourceId).get('fileResource'),
-            udfs: udfs.filterBy('fileResource.id', fileResourceId)
-          }));
-        }
-      });
-
-      udfsWithoutFiles = udfs.filter(function (udf) {
-        return !udf.get('isNew') && !udf.get('fileResource.id');
-      });
-
-      if (udfsWithoutFiles.get('length')) {
-       self.pushObject(Ember.Object.create({
-          name: "placeholders.select.noFileResource",
-          udfs: udfsWithoutFiles
-        }));
-      }
-    }
-  }.on('init').observes('udfs.@each.isNew')
-});
\ No newline at end of file

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/controllers/messages.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/controllers/messages.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/controllers/messages.js
deleted file mode 100644
index 11295d8..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/controllers/messages.js
+++ /dev/null
@@ -1,41 +0,0 @@
-/**
-* 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.
-*/
-
-import Ember from 'ember';
-import constants from 'hive/utils/constants';
-
-export default Ember.Controller.extend({
-  notifyService: Ember.inject.service(constants.namingConventions.notify),
-
-  messages: Ember.computed.alias('notifyService.messages'),
-  count: Ember.computed.alias('notifyService.unseenMessages.length'),
-
-  actions: {
-    removeMessage: function (message) {
-      this.get('notifyService').removeMessage(message);
-    },
-
-    removeAllMessages: function () {
-      this.get('notifyService').removeAllMessages();
-    },
-
-    markMessagesAsSeen: function () {
-      this.get('notifyService').markMessagesAsSeen();
-    }
-  }
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/controllers/modal-delete.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/controllers/modal-delete.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/controllers/modal-delete.js
deleted file mode 100644
index 0fbcd6b..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/controllers/modal-delete.js
+++ /dev/null
@@ -1,33 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-
-export default Ember.Controller.extend({
-  actions: {
-     delete: function () {
-      this.send('closeModal');
-      this.defer.resolve();
-    },
-
-    close: function () {
-      this.send('closeModal');
-      this.defer.reject();
-    }
-  }
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/controllers/modal-save-query.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/controllers/modal-save-query.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/controllers/modal-save-query.js
deleted file mode 100644
index d878bc7..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/controllers/modal-save-query.js
+++ /dev/null
@@ -1,42 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-import ModalSave from '../controllers/modal-save';
-import constants from '../utils/constants';
-
-export default ModalSave.extend({
-  showMessage: function () {
-    var content = this.get('content');
-
-    return !content.get('isNew') &&
-            content.get('title') === this.get('text') &&
-            content.get('constructor.typeKey') !== constants.namingConventions.job;
-  }.property('content.isNew', 'text'),
-
-  actions: {
-    save: function () {
-      this.send('closeModal');
-
-      this.defer.resolve(Ember.Object.create({
-        text: this.get('text'),
-        overwrite: this.get('showMessage')
-      }));
-    }
-  }
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/controllers/modal-save.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/controllers/modal-save.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/controllers/modal-save.js
deleted file mode 100644
index 6c16291..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/controllers/modal-save.js
+++ /dev/null
@@ -1,34 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-
-export default Ember.Controller.extend({
-  actions: {
-    save: function () {
-      this.send('closeModal');
-      this.defer.resolve(this.get('text'));
-      this.defer.resolve(this.get('type'));
-    },
-
-    close: function () {
-      this.send('closeModal');
-      this.defer.reject();
-    }
-  }
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/controllers/open-queries.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/controllers/open-queries.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/controllers/open-queries.js
deleted file mode 100644
index e4e1490..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/controllers/open-queries.js
+++ /dev/null
@@ -1,400 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-import constants from 'hive/utils/constants';
-import utils from 'hive/utils/functions';
-
-export default Ember.ArrayController.extend({
-  fileService: Ember.inject.service(constants.namingConventions.file),
-  databaseService: Ember.inject.service(constants.namingConventions.database),
-
-  needs: [ constants.namingConventions.jobResults,
-           constants.namingConventions.jobExplain,
-           constants.namingConventions.index
-         ],
-
-  jobResults: Ember.computed.alias('controllers.' + constants.namingConventions.jobResults),
-  jobExplain: Ember.computed.alias('controllers.' + constants.namingConventions.jobExplain),
-  index: Ember.computed.alias('controllers.' + constants.namingConventions.index),
-
-  selectedTables: Ember.computed.alias('databaseService.selectedTables'),
-  selectedDatabase: Ember.computed.alias('databaseService.selectedDatabase'),
-
-  init: function () {
-    this._super();
-
-    this.set('queryTabs', Ember.ArrayProxy.create({ content: Ember.A([])}));
-  },
-
-  pushObject: function (queryFile, model) {
-    return this._super(queryFile || Ember.Object.create({
-      id: model.get('id'),
-      fileContent: ""
-    }));
-  },
-
-  getTabForModel: function (model) {
-    return this.get('queryTabs').find(function (tab) {
-      return tab.id === model.get('id') && tab.type === model.get('constructor.typeKey');
-    });
-  },
-
-  updateTabSubroute: function (model, path) {
-    var tab = this.get('queryTabs').find(function (tab) {
-      return tab.id === model.get('id') && tab.type === model.get('constructor.typeKey');
-    });
-
-    if (tab) {
-      tab.set('subroute', path);
-    }
-  },
-
-  getQueryForModel: function (model) {
-    return this.find(function (openQuery) {
-      if (model.get('isNew')) {
-        return openQuery.get('id') === model.get('id');
-      }
-
-      return openQuery.get('id') === model.get('queryFile');
-    });
-  },
-
-  update: function (model) {
-    var path,
-        type,
-        currentQuery,
-        defer = Ember.RSVP.defer(),
-        existentTab,
-        self = this,
-        updateSubroute = function () {
-          var isExplainedQuery,
-              subroute;
-
-          //jobs that were run from hive ui (exclude ats jobs)
-          if (model.get('constructor.typeKey') === constants.namingConventions.job &&
-              utils.isInteger(model.get('id'))) {
-            isExplainedQuery = self.get('currentQuery.fileContent').indexOf(constants.namingConventions.explainPrefix) > -1;
-
-            if (isExplainedQuery) {
-              subroute = constants.namingConventions.subroutes.jobExplain;
-            } else {
-              subroute = constants.namingConventions.subroutes.jobLogs;
-            }
-
-            if (!existentTab.get('subroute')) {
-              self.updateTabSubroute(model, subroute);
-            }
-          }
-
-          defer.resolve(isExplainedQuery);
-        };
-
-    existentTab = this.getTabForModel(model);
-
-    if (!existentTab) {
-      type = model.get('constructor.typeKey');
-      path = type === constants.namingConventions.job ?
-             constants.namingConventions.subroutes.historyQuery :
-             constants.namingConventions.subroutes.savedQuery;
-
-      existentTab = this.get('queryTabs').pushObject(Ember.Object.create({
-        name: model.get('title'),
-        id: model.get('id'),
-        visible: true,
-        path: path,
-        type: type
-      }));
-
-      if (model.get('isNew')) {
-        this.set('currentQuery', this.pushObject(null, model));
-
-        defer.resolve();
-      } else {
-        this.get('fileService').loadFile(model.get('queryFile')).then(function (file) {
-          self.set('currentQuery', self.pushObject(file));
-
-          updateSubroute();
-        });
-
-        if (model.get('logFile') && !model.get('log')) {
-          this.get('fileService').loadFile(model.get('logFile')).then(function (file) {
-            model.set('log', file.get('fileContent'));
-          });
-        }
-      }
-    } else {
-      currentQuery = this.getQueryForModel(model);
-      this.set('currentQuery', currentQuery);
-
-      updateSubroute();
-    }
-
-    return defer.promise;
-  },
-
-  save: function (model, query, isUpdating, newTitle) {
-    var tab = this.getTabForModel(model),
-        self = this,
-        wasNew,
-        defer = Ember.RSVP.defer(),
-        jobModel = model;
-
-    if (!query) {
-      query = this.getQueryForModel(model);
-    }
-
-    if (model.get('isNew')) {
-      wasNew = true;
-      model.set('title', newTitle);
-      model.set('id', null);
-    }
-
-    //if current query it's a job, convert it to a savedQuery before saving
-    if (model.get('constructor.typeKey') === constants.namingConventions.job) {
-      model = this.store.createRecord(constants.namingConventions.savedQuery, {
-        dataBase: this.get('selectedDatabase.name'),
-        title: newTitle,
-        queryFile: model.get('queryFile'),
-        owner: model.get('owner')
-      });
-    }
-
-    tab.set('name', newTitle);
-
-    //if saving a new query from an existing one create a new record and save it
-    if (!isUpdating && !model.get('isNew') && model.get('constructor.typeKey') !== constants.namingConventions.job) {
-      model = this.store.createRecord(constants.namingConventions.savedQuery, {
-        dataBase: this.get('selectedDatabase.name'),
-        title: newTitle,
-        owner: model.get('owner')
-      });
-
-      wasNew = true;
-    }
-
-    model.save().then(function (updatedModel) {
-      jobModel.set('queryId', updatedModel.get('id'));
-
-      tab.set('isDirty', false);
-
-      var content = query.get('fileContent');
-      content = self.get('index').buildQuery(query);
-      content = self.get('index').bindQueryParams(content);
-
-      //update query tab path with saved model id if its a new record
-      if (wasNew) {
-        tab.set('id', updatedModel.get('id'));
-
-        self.get('fileService').loadFile(updatedModel.get('queryFile')).then(function (file) {
-          file.set('fileContent', content);
-          file.save().then(function (updatedFile) {
-            self.removeObject(query);
-            self.pushObject(updatedFile);
-            self.set('currentQuery', updatedFile);
-
-            defer.resolve(updatedModel.get('id'));
-          }, function (err) {
-            defer.reject(err);
-          });
-        }, function (err) {
-          defer.reject(err);
-        });
-      } else {
-        query.set('fileContent', content);
-        query.save().then(function () {
-          self.toggleProperty('tabUpdated');
-          defer.resolve(updatedModel.get('id'));
-
-        }, function (err) {
-          defer.reject(err);
-        });
-      }
-    }, function (err) {
-      defer.reject(err);
-    });
-
-    return defer.promise;
-  },
-
-  convertTabToJob: function (model, job) {
-    var defer = Ember.RSVP.defer(),
-        oldQuery = this.getQueryForModel(model),
-        tab = this.getTabForModel(model),
-        jobId = job.get('id'),
-        self = this;
-
-    tab.set('id', job.get('id'));
-    tab.set('type', constants.namingConventions.job);
-    tab.set('path', constants.namingConventions.subroutes.historyQuery);
-
-    this.get('fileService').loadFile(job.get('queryFile')).then(function (file) {
-      //replace old model representing file to reflect model update to job
-      if (self.keepOriginalQuery(jobId)) {
-        file.set('fileContent', oldQuery.get('fileContent'));
-      }
-
-      // Rollback the oldQuery if it is a DS model (type: 'savedQuery)
-      if (oldQuery.get('constructor.typeKey') !== undefined) {
-        oldQuery.rollback();
-      }
-
-      self.removeObject(oldQuery);
-      self.pushObject(file);
-
-      defer.resolve();
-    }, function (err) {
-      defer.reject(err);
-    });
-
-    return defer.promise;
-  },
-
-  keepOriginalQuery: function () {
-    var selected = this.get('highlightedText');
-    var hasQueryParams = this.get('index.queryParams.length');
-
-    return selected && selected[0] !== "" || hasQueryParams;
-  },
-
-  isDirty: function (model) {
-    var query = this.getQueryForModel(model);
-
-    if (model.get('isNew') && !query.get('fileContent')) {
-      return false;
-    }
-
-    if (query && query.get('isDirty')) {
-      return true;
-    }
-
-    return !!(!model.get('queryId') && model.get('isDirty'));
-  },
-
-  updatedDeletedQueryTab: function (model) {
-    var tab = this.getTabForModel(model);
-
-    if (tab) {
-      this.closeTab(tab);
-    }
-  },
-
-  dirtyObserver: function () {
-    var tab;
-    var model = this.get('index.model');
-
-    if (model) {
-      tab = this.getTabForModel(model);
-
-      if (tab) {
-        tab.set('isDirty', this.isDirty(model));
-      }
-    }
-  }.observes('currentQuery.isDirty', 'currentQuery.fileContent'),
-
-  closeTab: function (tab, goToNextTab) {
-    var remainingTabs = this.get('queryTabs').without(tab);
-
-    this.set('queryTabs', remainingTabs);
-
-    //remove cached results set
-    if (tab.type === constants.namingConventions.job) {
-      this.get('jobResults').clearCachedResultsSet(tab.id);
-      this.get('jobExplain').clearCachedExplainSet(tab.id);
-    }
-
-    if (goToNextTab) {
-      this.navigateToLastTab();
-    }
-  },
-
-  navigateToLastTab: function () {
-    var lastTab = this.get('queryTabs.lastObject');
-
-    if (lastTab) {
-      if (lastTab.type === constants.namingConventions.job) {
-        this.transitionToRoute(constants.namingConventions.subroutes.historyQuery, lastTab.id);
-      } else {
-        this.transitionToRoute(constants.namingConventions.subroutes.savedQuery, lastTab.id);
-      }
-    } else {
-      this.get('index').send('addQuery');
-    }
-  },
-
-  actions: {
-    removeQueryTab: function (tab) {
-      var self = this,
-          defer;
-
-      this.store.find(tab.type, tab.id).then(function (model) {
-        var query = self.getQueryForModel(model);
-
-        if (!self.isDirty(model)) {
-          self.closeTab(tab, true);
-        } else {
-          defer = Ember.RSVP.defer();
-          self.send('openModal',
-                    'modal-save',
-                     {
-                        heading: "modals.save.saveBeforeCloseHeading",
-                        text: model.get('title'),
-                        defer: defer
-                     });
-
-          defer.promise.then(function (text) {
-            model.set('title', text);
-            self.save(model, query, false, text).then(function () {
-              self.closeTab(tab, true);
-            });
-          }, function () {
-            model.rollback();
-            // Rollback the query if it is a DS model
-            if(query.get('constructor.typeKey') !== undefined) {
-              query.rollback();
-            }
-            self.closeTab(tab, true);
-          });
-        }
-      });
-    },
-
-    getColumnsForAutocomplete: function (tableName, callback) {
-      this.get('databaseService').getAllColumns(tableName).then(function () {
-        callback();
-      });
-    },
-
-    changeTabTitle: function(tab) {
-      var self = this,
-          defer = Ember.RSVP.defer(),
-          title = this.get('index.content.title');
-
-      this.send('openModal', 'modal-save', {
-        heading: 'modals.changeTitle.heading',
-        text: title,
-        defer: defer
-      });
-
-      defer.promise.then(function (result) {
-        self.set('index.model.title', result);
-        tab.set('name', result);
-      });
-    }
-  }
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/controllers/queries.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/controllers/queries.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/controllers/queries.js
deleted file mode 100644
index 4d82ae0..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/controllers/queries.js
+++ /dev/null
@@ -1,145 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-import FilterableMixin from 'hive/mixins/filterable';
-import constants from 'hive/utils/constants';
-
-export default Ember.ArrayController.extend(FilterableMixin, {
-  needs: [ constants.namingConventions.routes.history,
-           constants.namingConventions.openQueries ],
-
-  history: Ember.computed.alias('controllers.' + constants.namingConventions.routes.history),
-  openQueries: Ember.computed.alias('controllers.' + constants.namingConventions.openQueries),
-
-  sortAscending: true,
-  sortProperties: [],
-
-  init: function () {
-    this._super();
-
-    this.set('columns', Ember.ArrayProxy.create({ content: Ember.A([
-       Ember.Object.create({
-        caption: "columns.shortQuery",
-        property: 'shortQuery',
-        link: constants.namingConventions.subroutes.savedQuery
-      }),
-      Ember.Object.create({
-        caption: "columns.title",
-        property: 'title',
-        link: constants.namingConventions.subroutes.savedQuery
-      }),
-      Ember.Object.create({
-        caption: "columns.database",
-        property: 'dataBase',
-        link: constants.namingConventions.subroutes.savedQuery
-      }),
-      Ember.Object.create({
-        caption: "columns.owner",
-        property: 'owner',
-        link: constants.namingConventions.subroutes.savedQuery
-      })
-    ])}));
-  },
-
-  //row buttons
-  links: [
-    "buttons.history",
-    "buttons.delete",
-    "buttons.downloadQuery"
-  ],
-
-  model: function () {
-    return this.filter(this.get('queries'));
-  }.property('queries', 'filters.@each'),
-
-  actions: {
-    executeAction: function (action, savedQuery) {
-      var self = this;
-
-      switch (action) {
-        case "buttons.history":
-          this.get('history').filterBy('queryId', savedQuery.get('id'), true);
-          this.transitionToRoute(constants.namingConventions.routes.history);
-          break;
-        case "buttons.delete":
-          var defer = Ember.RSVP.defer();
-          this.send('openModal',
-                    'modal-delete',
-                     {
-                        heading: "modals.delete.heading",
-                        text: "modals.delete.message",
-                        defer: defer
-                     });
-
-          defer.promise.then(function () {
-            savedQuery.destroyRecord();
-            self.get('openQueries').updatedDeletedQueryTab(savedQuery);
-          });
-
-          break;
-        case "buttons.downloadQuery":
-          var self = this,
-          defer = Ember.RSVP.defer();
-          this.send('openModal', 
-                    'modal-save', 
-                    {
-                       heading: "modals.downloadQuery.heading",
-                       text: savedQuery.get('title') + ".hql",
-                       defer: defer
-                    });
-          defer.promise.then(function (text) {
-            var adapter  = self.container.lookup('adapter:application').buildURL();
-            var a = document.createElement('a');
-            a.href = adapter + '/savedQueries/' + savedQuery.get('id') + '?op=download';
-            a.download = text;
-            document.body.appendChild(a);
-            a.click();
-          });
-          break;
-      }
-    },
-
-    sort: function (property) {
-      //if same column has been selected, toggle flag, else default it to true
-      if (this.get('sortProperties').objectAt(0) === property) {
-        this.set('sortAscending', !this.get('sortAscending'));
-      } else {
-        this.set('sortAscending', true);
-        this.set('sortProperties', [ property ]);
-      }
-    },
-
-    clearFilters: function () {
-      var columns = this.get('columns');
-
-      if (columns) {
-        columns.forEach(function (column) {
-          var filterValue = column.get('filterValue');
-
-          if (filterValue && typeof filterValue === 'string') {
-            column.set('filterValue');
-          }
-        });
-      }
-
-      //call clear filters from Filterable mixin
-      this.clearFilters();
-    }
-  }
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/controllers/query-tabs.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/controllers/query-tabs.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/controllers/query-tabs.js
deleted file mode 100644
index 5f31c19..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/controllers/query-tabs.js
+++ /dev/null
@@ -1,176 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-import constants from 'hive/utils/constants';
-
-export default Ember.Controller.extend({
-  jobProgressService: Ember.inject.service(constants.namingConventions.jobProgress),
-  openQueries   : Ember.inject.controller(constants.namingConventions.openQueries),
-  notifyService: Ember.inject.service(constants.namingConventions.notify),
-  index: Ember.inject.controller(),
-
-  tabClassNames : "fa queries-icon query-context-tab",
-
-  tabs: [
-    Ember.Object.create({
-      iconClass: 'text-icon',
-      id: 'query-icon',
-      text: 'SQL',
-      action: 'setDefaultActive',
-      name: constants.namingConventions.index,
-      tooltip: Ember.I18n.t('tooltips.query')
-    }),
-    Ember.Object.create({
-      iconClass: 'fa-gear',
-      id: 'settings-icon',
-      action: 'toggleOverlay',
-      template: 'settings',
-      outlet: 'overlay',
-      into: 'open-queries',
-      tooltip: Ember.I18n.t('tooltips.settings')
-    }),
-    Ember.Object.create({
-      iconClass: 'fa-area-chart',
-      id: 'visualization-icon',
-      action: 'toggleOverlay',
-      tooltip: Ember.I18n.t('tooltips.visualization'),
-      into: 'index',
-      outlet: 'overlay',
-      template: 'visualization-ui',
-      onTabOpen: 'onTabOpen'
-    }),
-    Ember.Object.create({
-      iconClass: 'fa-link',
-      id: 'visual-explain-icon',
-      action: 'toggleOverlay',
-      template: 'visual-explain',
-      outlet: 'overlay',
-      into: 'index',
-      onTabOpen: 'onTabOpen',
-      tooltip: Ember.I18n.t('tooltips.visualExplain')
-    }),
-    Ember.Object.create({
-      iconClass: 'text-icon',
-      id: 'tez-icon',
-      text: 'TEZ',
-      action: 'toggleOverlay',
-      template: 'tez-ui',
-      outlet: 'overlay',
-      into: 'index',
-      tooltip: Ember.I18n.t('tooltips.tez')
-    }),
-    Ember.Object.create({
-      iconClass: 'fa-envelope',
-      id: 'notifications-icon',
-      action: 'toggleOverlay',
-      template: 'messages',
-      outlet: 'overlay',
-      into: 'index',
-      badgeProperty: 'count',
-      onTabOpen: 'markMessagesAsSeen',
-      tooltip: Ember.I18n.t('tooltips.notifications')
-    })
-  ],
-
-  init: function() {
-    this.setupControllers();
-    this.setDefaultTab();
-    this.setupTabsBadges();
-  },
-
-  setupControllers: function() {
-    var tabs = this.get('tabs');
-    var self = this;
-
-    tabs.map(function (tab) {
-      var controller;
-
-      if (tab.get('template')) {
-        controller = self.container.lookup('controller:' + tab.get('template'));
-        tab.set('controller', controller);
-      }
-    });
-  },
-
-  setDefaultTab: function () {
-    var defaultTab = this.get('tabs.firstObject');
-
-    defaultTab.set('active', true);
-
-    this.set('default', defaultTab);
-    this.set('activeTab', defaultTab);
-  },
-
-  setupTabsBadges: function () {
-    var tabs = this.get('tabs').filterProperty('badgeProperty');
-
-    tabs.map(function (tab) {
-        Ember.oneWay(tab, 'badge', 'controller.' + tab.badgeProperty);
-    });
-  },
-
-  closeActiveOverlay: function () {
-    this.send('closeOverlay', this.get('activeTab'));
-  },
-
-  onTabOpen: function (tab) {
-    if (!tab.onTabOpen) {
-      return;
-    }
-
-    var controller = this.container.lookup('controller:' + tab.template);
-    controller.send(tab.onTabOpen, controller);
-  },
-
-  openOverlay: function (tab) {
-    this.closeActiveOverlay();
-    this.set('activeTab.active', false);
-    tab.set('active', true);
-    this.set('activeTab', tab);
-
-    this.onTabOpen(tab);
-    this.send('openOverlay', tab);
-  },
-
-  setDefaultActive: function () {
-    var activeTab = this.get('activeTab');
-    var defaultTab = this.get('default');
-
-    if (activeTab !== defaultTab) {
-      this.closeActiveOverlay();
-      defaultTab.set('active', true);
-      activeTab.set('active', false);
-      this.set('activeTab', defaultTab);
-    }
-  },
-
-  actions: {
-    toggleOverlay: function (tab) {
-      if (tab !== this.get('default') && tab.get('active')) {
-        this.setDefaultActive();
-      } else {
-        this.openOverlay(tab);
-      }
-    },
-
-    setDefaultActive: function () {
-      this.setDefaultActive();
-    }
-  }
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/controllers/settings.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/controllers/settings.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/controllers/settings.js
deleted file mode 100644
index 77250b4..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/controllers/settings.js
+++ /dev/null
@@ -1,69 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-
-export default Ember.Controller.extend({
-  openQueries: Ember.inject.controller(),
-  index: Ember.inject.controller(),
-
-  settingsService: Ember.inject.service('settings'),
-
-  predefinedSettings: Ember.computed.alias('settingsService.predefinedSettings'),
-  settings: Ember.computed.alias('settingsService.settings'),
-
-  init: function() {
-    this._super();
-
-    this.get('settingsService').loadDefaultSettings();
-  },
-
-  excluded: function() {
-    var settings = this.get('settings');
-
-    return this.get('predefinedSettings').filter(function(setting) {
-      return settings.findBy('key.name', setting.name);
-    });
-  }.property('settings.@each.key'),
-
-  parseGlobalSettings: function () {
-    this.get('settingsService').parseGlobalSettings(this.get('openQueries.currentQuery'), this.get('index.model'));
-  }.observes('openQueries.currentQuery', 'openQueries.currentQuery.fileContent', 'openQueries.tabUpdated').on('init'),
-
-  actions: {
-    add: function () {
-      this.get('settingsService').add();
-    },
-
-    remove: function (setting) {
-      this.get('settingsService').remove(setting);
-    },
-
-    addKey: function (name) {
-      this.get('settingsService').createKey(name);
-    },
-
-    removeAll: function () {
-      this.get('settingsService').removeAll();
-    },
-
-    saveDefaultSettings: function() {
-      this.get('settingsService').saveDefaultSettings();
-    }
-  }
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/controllers/splash.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/controllers/splash.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/controllers/splash.js
deleted file mode 100644
index 0e9ee34..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/controllers/splash.js
+++ /dev/null
@@ -1,164 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-import constants from 'hive/utils/constants';
-
-
-export default Ember.Controller.extend({
-  databaseService: Ember.inject.service(constants.namingConventions.database),
-  ldapAuthenticationService: Ember.inject.service(constants.namingConventions.ldapAuthentication),
-  notifyService: Ember.inject.service(constants.namingConventions.notify),
-  isExpanded: false,
-  errors: "",
-  stackTrace: "",
-  startTests: function() {
-
-    var model = this.get('model');
-    var url = this.container.lookup('adapter:application').buildURL() + '/resources/hive/'
-    var self = this;
-
-    var processResponse = function(name, data) {
-      if( data != undefined ){
-        if(data.databases){
-          data = Ember.Object.create( {trace: null, message: "OK", status: "200"});
-        } else {
-
-          if(data.status === 401 && data.message === 'Hive Password Required'){
-            self.send('openLdapPasswordModal');
-          } else {
-            data = data;
-          }
-        }
-      } else {
-        data = Ember.Object.create( {trace: null, message: "Server Error", status: "500"});
-      }
-
-      model.set(name + 'Test', data.status == 200);
-
-      if (data.status != 200) {
-        var checkFailedMessage = "Service '" + name + "' check failed";
-        var errors = self.get("errors");
-        errors += checkFailedMessage;
-        errors += (data.message)?(': <i>' + data.message + '</i><br>'):'<br>';
-        self.set("errors", errors);
-      }
-
-      if (data.trace != null) {
-        var stackTrace = self.get("stackTrace");
-        stackTrace += checkFailedMessage + ':\n' + data.trace;
-        self.set("stackTrace", stackTrace);
-      }
-
-      model.set(name + 'TestDone', true);
-      var percent = model.get('percent');
-      model.set('percent', percent + 25);
-    };
-
-    var promises = ['hdfs', 'hiveserver', 'ats', 'userhome'].map(function(name) {
-
-      var finalurl = ((name == 'hiveserver') ? self.get('databaseService.baseUrl') : (url + name + 'Status')) || '' ;
-
-      return Ember.$.getJSON( finalurl )
-        .then(
-          function(data) {
-            processResponse(name, data);
-          },
-          function(reason) {
-            processResponse(name, reason.responseJSON);
-          }
-        );
-    });
-
-    return Ember.RSVP.all(promises);
-  },
-
-  progressBarStyle: function() {
-    return 'width: ' + this.get("model").get("percent") +  '%;';
-  }.property("model.percent"),
-
-  allTestsCompleted: function(){
-    return this.get('modelhdfsTestDone') && this.get('modelhiveserverTestDone') && this.get('modelatsTestDone') && this.get('modeluserhomeTestDone');
-  }.property('modelhdfsTestDone', 'modelhiveserverTestDone', 'modelatsTestDone', 'modeluserhomeTestDone'),
-
-  modelhdfsTestDone: function() {
-    return this.get('model.hdfsTestDone');
-  }.property('model.hdfsTestDone' ),
-
-  modeluserhomeTestDone: function() {
-    return this.get('model.userhomeTestDone');
-  }.property('model.userhomeTestDone' ),
-
-  modelhiveserverTestDone: function() {
-    return this.get('model.hiveserverTestDone');
-  }.property('model.hiveserverTestDone' ),
-
-  modelatsTestDone: function() {
-    return this.get('model.atsTestDone');
-  }.property('model.atsTestDone' ),
-
-  modelhdfsTest: function() {
-    return this.get('model.hdfsTest');
-  }.property('model.hdfsTest' ),
-
-  modeluserhomeTest: function() {
-    return this.get('model.userhomeTest');
-  }.property('model.userhomeTest' ),
-
-  modelhiveserverTest: function() {
-    return this.get('model.hiveserverTest');
-  }.property('model.hiveserverTest' ),
-
-  modelatsTest: function() {
-    return this.get('model.atsTest');
-  }.property('model.atsTest' ),
-
-  actions: {
-    toggleStackTrace:function () {
-      var value = this.get('isExpanded');
-      this.set('isExpanded', !value);
-    },
-    openLdapPasswordModal: function(){
-
-      var self = this,
-          defer = Ember.RSVP.defer();
-
-      this.send('openModal', 'modal-save', {
-        heading: "modals.authenticationLDAP.heading",
-        text:"",
-        type: "password",
-        defer: defer
-      });
-
-      defer.promise.then(function (text) {
-        var ldapAuthPromise = self.get('ldapAuthenticationService').authenticateLdapPassword(text);
-
-        ldapAuthPromise.then(function (data) {
-          self.send('reloadView');
-        }, function (error) {
-          console.log( "LDAP fail: " + error );
-          self.get('notifyService').error( "Wrong Credentials." );
-        })
-      });
-
-    },
-    reloadView: function() {
-      document.location.reload(true);
-    }
-  }
-});


[10/23] ambari git commit: AMBARI-19302 : removed contrib/views/hive folder and made necessary changes in pom.xml files (nitirajrathore)

Posted by ni...@apache.org.
http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/modal-save.hbs
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/modal-save.hbs b/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/modal-save.hbs
deleted file mode 100644
index 8d83f2b..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/modal-save.hbs
+++ /dev/null
@@ -1,21 +0,0 @@
-{{!
-* 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.
-}}
-
-{{#modal-widget heading=heading close="close" ok="save"}}
-  {{input type=type class="form-control"  value=text }}
-{{/modal-widget}}
\ No newline at end of file

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/notification.hbs
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/notification.hbs b/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/notification.hbs
deleted file mode 100644
index 35c2fe1..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/notification.hbs
+++ /dev/null
@@ -1,23 +0,0 @@
-{{!
-* 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.
-}}
-
-<div {{bind-attr class=":alert :notification view.typeClass"}}>
-  <button type="button" class="close" {{action "close" target="view"}}><span aria-hidden="true">&times;</span></button>
-  <i {{bind-attr class=":fa view.typeIcon"}}></i>
-  {{view.notification.message}}
-</div>

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/open-queries.hbs
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/open-queries.hbs b/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/open-queries.hbs
deleted file mode 100644
index 6d6f0dc..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/open-queries.hbs
+++ /dev/null
@@ -1,23 +0,0 @@
-{{!
-* 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.
-}}
-
-{{#tabs-widget tabs=queryTabs removeClicked="removeQueryTab" canRemove=true onActiveTitleClick="changeTabTitle"}}
-  {{outlet 'overlay'}}
-  {{query-editor tables=selectedTables query=currentQuery.fileContent editor=view.editor highlightedText=highlightedText
-                 columnsNeeded="getColumnsForAutocomplete"}}
-{{/tabs-widget}}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/queries.hbs
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/queries.hbs b/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/queries.hbs
deleted file mode 100644
index 96e2498..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/queries.hbs
+++ /dev/null
@@ -1,96 +0,0 @@
-{{!
-* 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.
-}}
-
-<table class="table">
-  <thead>
-    <tr>
-      {{#each column in columns}}
-        <th>
-          {{#if column.caption}}
-            {{column-filter-widget class="pull-left"
-                                   column=column
-                                   filterValue=column.filterValue
-                                   sortAscending=controller.sortAscending
-                                   sortProperties=controller.sortProperties
-                                   columnSorted="sort"
-                                   columnFiltered="filter"}}
-          {{else}}
-            {{column.caption}}
-          {{/if}}
-        </th>
-      {{/each}}
-      <th>
-        <button type="btn" class="btn btn-sm btn-warning pull-right clear-filters" {{action "clearFilters"}}>{{t "buttons.clearFilters"}}</button>
-      </th>
-    </tr>
-  </thead>
-  <tbody>
-    {{#if queries.length}}
-      {{#if model.length}}
-        {{#each query in this}}
-          {{#unless query.isNew}}
-            <tr>
-              <td>
-                {{#link-to "index.savedQuery" query}}
-                  {{query.shortQuery}}
-                {{/link-to}}
-              </td>
-
-              <td>
-                {{#link-to "index.savedQuery" query}}
-                  {{query.title}}
-                {{/link-to}}
-              </td>
-
-              <td>{{query.dataBase}}</td>
-
-              <td>{{query.owner}}</td>
-
-              <td>
-                {{#unless query.isNew}}
-                  <div class="btn-group pull-right">
-                    <span data-toggle="dropdown">
-                      <a class="fa fa-gear"></a>
-                    </span>
-                    <ul class="dropdown-menu" role="menu">
-                      {{#each link in controller.links}}
-                        <li {{action 'executeAction' link query}}><a>{{tb-helper link}}</a></li>
-                      {{/each}}
-                    </ul>
-                  </div>
-                {{/unless}}
-              </td>
-            </tr>
-          {{/unless}}
-        {{/each}}
-      {{else}}
-        <tr>
-          <td colspan="5">
-            <h4 class="empty-list">{{t "emptyList.savedQueries.noMatches"}}</h4>
-          </td>
-        </tr>
-      {{/if}}
-    {{else}}
-      <tr>
-        <td colspan="5">
-          <h4 class="empty-list">{{t "emptyList.savedQueries.noItems"}}</h4>
-        </td>
-      </tr>
-    {{/if}}
-  </tbody>
-</table>

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/query-tabs.hbs
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/query-tabs.hbs b/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/query-tabs.hbs
deleted file mode 100644
index 62b15c1..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/query-tabs.hbs
+++ /dev/null
@@ -1,28 +0,0 @@
-{{!
-* 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.
-}}
-
-{{#each tab in tabs}}
-    <span {{action tab.action tab}} {{bind-attr class=":query-menu-tab tabClassNames tab.iconClass tab.active:active tab.flash:flash" title="tab.tooltip" id="tab.id"}}>
-      {{#if tab.badge}}
-        <span class="badge">{{tab.badge}}</span>
-      {{/if}}
-      {{#if tab.text}}
-        {{tab.text}}
-      {{/if}}
-    </span>
-{{/each}}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/redirect.hbs
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/redirect.hbs b/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/redirect.hbs
deleted file mode 100644
index b776fd2..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/redirect.hbs
+++ /dev/null
@@ -1,19 +0,0 @@
-{{!
-* 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.
-}}
-
-{{outlet}}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/settings.hbs
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/settings.hbs b/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/settings.hbs
deleted file mode 100644
index e24c667..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/settings.hbs
+++ /dev/null
@@ -1,70 +0,0 @@
-{{!
-* 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.
-}}
-
-<div class="editor-overlay settings-container fadeIn">
-  <div class='settings-controls'>
-    <button class="btn btn-success btn-xs" {{action 'add'}}><i class="fa fa-plus"></i> Add</button>
-
-    {{#if settings.length}}
-      <button class="btn btn-danger btn-xs" {{action 'removeAll'}}><i class="fa fa-minus"></i> Remove All</button>
-    {{/if}}
-
-    <button class="btn btn-success btn-xs pull-right" {{action 'saveDefaultSettings'}}><i class="fa fa-plus"></i> Save Default Settings</button>
-  </div>
-
-  {{#each setting in settings}}
-    <div class="setting col-md-12 col-sm-12">
-      <form>
-        <div class="form-group">
-          <div class="input-group">
-            <div class="input-group-addon">
-
-              <div {{bind-attr keyname="setting.key.name"}} class="typeahead-container">
-                {{typeahead-widget
-                    options=predefinedSettings
-                    excluded=excluded
-                    optionLabelPath="name"
-                    optionValuePath="name"
-                    plugins="remove_button,restore_on_backspace"
-                    selection=setting.key
-                    safeValue = setting.key.name
-                    create="addKey"
-                }}
-              </div>
-            </div>
-            <div {{bind-attr class=":input-group-addon setting.valid::has-error"}}>
-              <div class="setting-input-value">
-                {{#if setting.key.values}}
-                  {{select-widget items=setting.key.values
-                                  labelPath="value"
-                                  selectedValue=setting.selection
-                                  defaultLabelTranslation="placeholders.select.value"
-                  }}
-                {{else}}
-                  {{input class="input-sm form-control" placeholderTranslation="placeholders.select.value" value=setting.selection.value}}
-                {{/if}}
-              </div>
-
-              <span class="fa fa-times-circle remove pull-right" {{action 'remove' setting}}></span>
-            </div>
-          </div>
-        </div>
-      </form>
-    </div>
-  {{/each}}
-</div>

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/splash.hbs
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/splash.hbs b/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/splash.hbs
deleted file mode 100644
index 5612542..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/splash.hbs
+++ /dev/null
@@ -1,117 +0,0 @@
-{{!
-* 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.
-}}
-
-<div class="spinner"></div>
-<div class="container-fluid">
-  {{#if allTestsCompleted }}
-    <h3>Service checks completed.</h3>
-  {{else}}
-    <h3>Service checks in progress.</h3>
-  {{/if}}
-
-  {{#if errors}}
-    <div class="progress active">
-      <div class="progress-bar progress-bar-danger" role="progressbar" aria-valuenow="60" aria-valuemin="0" aria-valuemax="100" {{bind-attr style="progressBarStyle"}}></div>
-    </div>
-  {{else}}
-    <div class="progress progress-striped active">
-      <div class="progress-bar progress-bar-success" role="progressbar" aria-valuenow="60" aria-valuemin="0" aria-valuemax="100" {{bind-attr style="progressBarStyle"}}></div>
-    </div>
-  {{/if}}
-
-  <table class="table">
-    <tbody>
-    <tr>
-      <td>
-        {{#if modelhdfsTestDone}}
-          {{#if modelhdfsTest}}
-            <i class="fa fa-check"></i>
-          {{else}}
-            <i class="fa fa-remove"></i>
-          {{/if}}
-        {{else}}
-          <i class="fa fa-arrow-right"></i>
-        {{/if}}
-      </td>
-      <td>HDFS test</td>
-    </tr>
-    <tr>
-      <td>
-        {{#if modelhiveserverTestDone}}
-          {{#if modelhiveserverTest}}
-            <i class="fa fa-check"></i>
-          {{else}}
-            <i class="fa fa-remove"></i>
-          {{/if}}
-        {{else}}
-          <i class="fa fa-arrow-right"></i>
-        {{/if}}
-      </td>
-      <td>HiveServer test</td>
-    </tr>
-    <tr>
-      <td>
-        {{#if modelatsTestDone}}
-          {{#if modelatsTest}}
-            <i class="fa fa-check"></i>
-          {{else}}
-            <i class="fa fa-remove"></i>
-          {{/if}}
-        {{else}}
-          <i class="fa fa-arrow-right"></i>
-        {{/if}}
-      </td>
-      <td>ATS test</td>
-    </tr>
-
-    <tr>
-      <td>
-        {{#if modeluserhomeTestDone}}
-          {{#if modeluserhomeTest}}
-            <i class="fa fa-check"></i>
-          {{else}}
-            <i class="fa fa-remove"></i>
-          {{/if}}
-        {{else}}
-          <i class="fa fa-arrow-right"></i>
-        {{/if}}
-      </td>
-      <td>User Home Directory test</td>
-    </tr>
-
-    </tbody>
-  </table>
-  {{#if errors}}
-    <h3>Issues detected</h3>
-    <p>{{{errors}}}</p>
-  {{/if}}
-  {{#if stackTrace}}
-    <a href="#" {{action "toggleStackTrace" post}}>
-      {{#if isExpanded}}
-        <i class="fa fa-minus"></i> Collapse Stack Trace
-      {{else}}
-        <<i class="fa fa-plus"></i> Expand Stack Trace
-      {{/if}}
-    </a>
-    {{#if isExpanded}}
-      <pre class="prettyprint">
-        {{stackTrace}}
-      </pre>
-    {{/if}}
-  {{/if}}
-</div>

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/tez-ui.hbs
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/tez-ui.hbs b/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/tez-ui.hbs
deleted file mode 100644
index 6f6df4c..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/tez-ui.hbs
+++ /dev/null
@@ -1,31 +0,0 @@
-{{!
-* 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.
-}}
-
-<div id="tez-ui" class="index-overlay">
-  {{#panel-widget headingTranslation="titles.query.tez"}}
-    {{#if dagURL}}
-      <iframe {{bind-attr src=dagURL}}></iframe>
-    {{else}}
-      {{#if error}}
-        <div class="alert alert-danger" role="alert"><strong>{{tb-helper error}}</strong></div>
-      {{else}}
-        <div class="alert alert-danger" role="alert"><strong>{{tb-helper 'tez.errors.no.dag'}}</strong></div>
-      {{/if}}
-    {{/if}}
-  {{/panel-widget}}
-</div>

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/udfs.hbs
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/udfs.hbs b/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/udfs.hbs
deleted file mode 100644
index 7650fba..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/udfs.hbs
+++ /dev/null
@@ -1,53 +0,0 @@
-{{!
-* 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.
-}}
-
-<table class="table">
-  <thead>
-    <tr>
-      <th>{{t "columns.fileResource"}}</th>
-      {{#each column in columns}}
-        <th>
-          {{column-filter-widget class="pull-left"
-                                 column=column
-                                 filterValue=column.filterValue
-                                 sortAscending=controller.sortAscending
-                                 sortProperties=controller.sortProperties
-                                 columnSorted="sort"
-                                 columnFiltered="filter"}}
-        </th>
-      {{/each}}
-      <th>
-        <div class="pull-right">
-          <button type="button" class="btn btn-sm btn-warning clear-filters" {{action "clearFilters"}}>{{t "buttons.clearFilters"}}</button>
-          <button type="button" class="btn btn-sm btn-success add-udf" {{action "add"}}>{{t "buttons.newUdf"}}</button>
-        </div>
-      </th>
-    </tr>
-  </thead>
-  <tbody>
-    {{#each udf in this}}
-      {{udf-tr-view udf=udf
-                    fileResources=fileResources
-                    columns=columns
-                    onAddFileResource="handleAddFileResource"
-                    onDeleteFileResource="handleDeleteFileResource"
-                    onSaveUdf="handleSaveUdf"
-                    onDeleteUdf='handleDeleteUdf'}}
-    {{/each}}
-  </tbody>
-</table>
\ No newline at end of file

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/upload-table.hbs
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/upload-table.hbs b/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/upload-table.hbs
deleted file mode 100644
index 1638804..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/upload-table.hbs
+++ /dev/null
@@ -1,296 +0,0 @@
-{{!
-* 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.
-}}
-
-<div style="width : 90%">
-  <div class="main-content">
-    {{#if showErrors}}
-      {{render 'messages'}}
-    {{/if}}
-  </div>
-</div>
-
-<div id="uploadProgressModal" class="modal fade" role="dialog" data-backdrop="static">
-  <div class="modal-dialog">
-
-    <!-- Modal content-->
-    <div class="modal-content">
-      <div class="modal-header">
-        <h4 class="modal-title">{{t "hive.ui.uploadProgress"}}</h4>
-      </div>
-      <div class="modal-body">
-        <p>
-        <ul>
-          {{uploadProgressInfo}}
-        </ul>
-        </p>
-      </div>
-    </div>
-
-  </div>
-</div>
-
-<!-- CSV Input Modal -->
-<div class="modal fade" id="inputParamsModal" role="dialog">
-  <div class="modal-dialog">
-    <div class="modal-content">
-      <div class="modal-header">
-        <button type="button" class="close" data-dismiss="modal">&times;</button>
-      </div>
-      <div class="modal-body">
-        <table class="table data-upload-form">
-          <tr>
-            <td><label>{{t 'hive.ui.columnDelimterField'}}:</label></td>
-            <td class="data-upload-form-field" title={{t 'hive.ui.columnDelimiterTooltip'}}>
-              {{typeahead-widget
-              content=asciiList
-              optionValuePath="id"
-              optionLabelPath="name"
-              selection=csvDelimiter
-              optionFunction=asciiFormatter
-              }}
-            </td>
-          </tr>
-          <tr>
-            <td><label>{{t 'hive.ui.escapeCharacterField'}}:</label></td>
-            <td class="data-upload-form-field" title={{t 'hive.ui.escapeCharacterTooltip'}}>
-              {{typeahead-widget
-              content=asciiList
-              optionValuePath="id"
-              optionLabelPath="name"
-              selection=csvEscape
-              optionFunction=asciiFormatter
-            }}
-            </td>
-          </tr>
-          <tr>
-            <td><label>{{t 'hive.ui.quoteCharacterField'}}:</label></td>
-            <td class="data-upload-form-field" title={{t 'hive.ui.quoteCharacterTooltip'}}>
-              {{typeahead-widget
-              content=asciiList
-              optionValuePath="id"
-              optionLabelPath="name"
-              selection=csvQuote
-              optionFunction=asciiFormatter
-              }}
-            </td>
-          </tr>
-          <tr>
-            <td><label>{{t "hive.ui.isFirstRowHeader"}}</label></td>
-            <td class="data-upload-form-field"  title={{t 'hive.ui.isFirstRowHeaderTooltip'}}>
-              {{input id="isFirstRowHeader" type="checkbox" checked=isFirstRowHeader }}
-            </td>
-          </tr>
-        </table>
-      </div>
-      <div class="modal-footer">
-        <button type="submit" class="btn btn-default btn-default pull-right" data-dismiss="modal"> Close</button>
-      </div>
-    </div>
-  </div>
-</div>
-
-<!-- Row Format Modal -->
-<div class="modal fade" id="rowFormatModal" role="dialog">
-  <div class="modal-dialog">
-    <div class="modal-content">
-      <div class="modal-header">
-        <button type="button" class="close" data-dismiss="modal">&times;</button>
-      </div>
-      <div class="modal-body">
-        <table class="table data-upload-form">
-          <tr>
-            <td><label>{{t 'hive.ui.fieldsTerminatedByField'}}:</label></td>
-            <td class="data-upload-form-field" title={{t 'hive.ui.fieldsTerminatedByTooltip'}}>
-              {{typeahead-widget
-              content=asciiList
-              optionValuePath="id"
-              optionLabelPath="name"
-              selection=fieldsTerminatedBy
-              optionFunction=asciiFormatter
-              }}
-            </td>
-          </tr>
-          <tr>
-            <td><label>{{t 'hive.ui.escapedByField'}}:</label></td>
-            <td class="data-upload-form-field" title={{t 'hive.ui.escapedByTooltip'}}>
-              {{typeahead-widget
-              content=asciiList
-              optionValuePath="id"
-              optionLabelPath="name"
-              selection=escapedBy
-              optionFunction=asciiFormatter
-              }}
-            </td>
-          </tr>
-        </table>
-      </div>
-      <div class="modal-footer">
-        <button type="submit" class="btn btn-default btn-default pull-right" data-dismiss="modal"> Close</button>
-      </div>
-    </div>
-  </div>
-</div>
-
-<div class="pull-right">
-  <i class="query-menu-tab fa queries-icon fa-envelope" {{ action 'toggleErrors'}} ></i>
-</div>
-<div {{bind-attr class="showErrors:hide-data:show-data"}}>
-  <div>
-    <table class="table data-upload-form pull-left">
-      <tr>
-        <td class="data-upload-form-label"><label>{{t "hive.ui.uploadFromLocal"}}</label></td>
-        <td  class="data-upload-form-field"> {{radio-button value='local' checked=uploadSource}}</td>
-
-        <td class="data-upload-form-label"><label>{{t "hive.ui.uploadFromHdfs"}}</label></td>
-        <td  class="data-upload-form-field">{{radio-button value='hdfs' checked=uploadSource}}</td>
-      </tr>
-      <tr>
-        <td class="data-upload-form-label"><label>{{t "hive.ui.fileType"}}</label></td>
-        <td class="data-upload-form-field">
-          <div class="col-md-11" style="padding:0">
-            {{typeahead-widget
-            content=inputFileTypes
-            optionValuePath="id"
-            optionLabelPath="name"
-            selection=inputFileType
-            placeholder="Select File Type"}}
-          </div>
-          <div class="col-md-1" style="padding: 0">
-            <span {{bind-attr class=":queries-icon :fa :fa-gear inputFileTypeCSV:settings-gear:settings-gear-disabled"}}
-                  title="Settings" {{action "showInputParamModal"}}>
-            </span>
-          </div>
-        </td>
-        {{#if isLocalUpload }}
-          <td class="data-upload-form-label"><label>{{t "hive.ui.selectFromLocal"}}</label></td>
-          <td class="data-upload-form-field">{{file-upload  filesUploaded="filesUploaded"  uploadFiles=files}}</td>
-        {{else}}
-          <td class="data-upload-form-label"><label>{{t "hive.ui.hdfsPath"}}</label></td>
-          <td class="data-upload-form-field" id="hdfs-param">
-            {{#validated-text-field inputValue=hdfsPath allowEmpty=false tagClassName="hdfsPath"
-            tooltip=(t "hive.ui.hdfsFieldTooltip") placeholder=(t "hive.ui.hdfsFieldPlaceholder")
-            invalidClass='form-control hdfsPath red-border' validClass='form-control hdfsPath' regex=HDFS_PATH_REGEX
-            errorMessage=(t "hive.ui.hdfsFieldErrorMessage")  }}
-            {{/validated-text-field}}
-            <button style="margin-left: 5px; padding-top: 6px;padding-bottom: 6px; padding-right: 10px; padding-left: 10px;" type="button" {{action "previewFromHdfs"}}
-            {{bind-attr class=":btn :btn-sm :btn-default"}}>{{t "buttons.showPreview"}}</button></td>
-        {{/if}}
-      </tr>
-      {{#if showPreview}}
-      <tr>
-        <td class="data-upload-form-label"><label>{{t "hive.words.database"}}</label></td>
-        <td class="data-upload-form-field">
-          {{typeahead-widget
-          content=databases
-          optionValuePath="id"
-          optionLabelPath="name"
-          selection=selectedDatabase
-          placeholder=(t "hive.ui.selectDatabase")
-          }}
-        </td>
-
-        <td class="data-upload-form-label"><label>{{t "hive.ui.tableName"}}</label></td>
-        <td class="data-upload-form-field">
-          {{#validated-text-field inputValue=tableName allowEmpty=false
-          tooltip=(t "hive.ui.tableNameTooltip")
-          invalidClass='form-control red-border' validClass='form-control' regex=TABLE_NAME_REGEX
-          errorMessage=(t "hive.ui.tableNameErrorMessage") }}
-          {{/validated-text-field}}
-        </td>
-      </tr>
-      <tr>
-        <td class="data-upload-form-label"><label>{{t "hive.ui.storedAs"}}</label></td>
-        <td class="data-upload-form-field">
-          <div class="col-md-11" style="padding: 0">
-              {{typeahead-widget
-              content=fileTypes
-              selection=selectedFileType}}
-          </div>
-            <div class="col-md-1" style="padding: 0">
-              <span {{bind-attr class=":queries-icon :fa :fa-gear storedAsTextFile:settings-gear:settings-gear-disabled"}}
-                    title="Settings" {{action "showRowFormatModal"}}>
-              </span>
-            </div>
-        </td>
-        {{#if storedAsNotTextFile}}
-          <td class="data-upload-form-label"><label>{{t "hive.ui.containsEndlines"}}</label></td>
-          <td class="data-upload-form-field">
-            {{input type="checkbox" checked=containsEndlines }}
-          </td>
-        {{/if}}
-      </tr>
-      {{/if}}
-    </table>
-
-    {{#if showPreview}}
-    <table class="pull-right">
-      <tr>
-        <td>
-            <button type="button" {{action "uploadTable"}}
-              {{bind-attr class=":btn :btn-sm :btn-default"}}>{{t "buttons.uploadTable"}}</button>
-        </td>
-      </tr>
-    </table>
-    {{/if}}
-  </div>
-
-  <div>
-    {{#if showPreview}}
-      <div id="upload-table">
-        <table class="table table-expandable no-border">
-          <thead>
-          <tr>
-            {{#each column in header}}
-              <th>
-                {{#validated-text-field inputValue=column.name allowEmpty=false
-                tooltip=(t "hive.ui.columnNameTooltip")
-                invalidClass='form-control red-border' validClass='form-control' regex=COLUMN_NAME_REGEX
-                errorMessage=(t "hive.ui.columnNameErrorMessage")}}
-                {{/validated-text-field}}
-              </th>
-            {{/each}}
-          </tr>
-          <tr id="upload-controls">
-            {{#each column in header}}
-              <th>
-                <table>
-                  <tbody>
-                  <tr>
-                    <td>{{typeahead-widget content=dataTypes selection=column.type }}</td>
-                    {{input-header column=column dataTypes=dataTypes}}
-                  </tr>
-                  </tbody>
-                </table>
-              </th>
-            {{/each}}
-          </tr>
-          </thead>
-          <tbody>
-          {{#each row in rows}}
-            <tr>
-              {{#each item in row.row}}
-                <td>{{item}}</td>
-              {{/each}}
-            </tr>
-          {{/each}}
-          </tbody>
-        </table>
-      </div>
-    {{/if}}
-  </div>
-</div>

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/visual-explain.hbs
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/visual-explain.hbs b/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/visual-explain.hbs
deleted file mode 100644
index bef0693..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/visual-explain.hbs
+++ /dev/null
@@ -1,93 +0,0 @@
-{{!
-* 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.
-}}
-
-<div id="visual-explain" class="index-overlay">
-  {{#panel-widget headingTranslation="titles.query.visualExplain"}}
-
-  {{#if noquery}}
-    <div class="alert alert-danger" role="alert"><strong>{{tb-helper 'hive.errors.no.query'}}</strong></div>
-  {{/if}}
-
-  {{#unless showSpinner}}
-     <div class="spinner"></div>
-  {{/unless}}
-
-  <div id="no-visual-explain-graph"></div>
-
-  <div id="visual-explain-graph">
-    {{#each edge in view.edges}}
-      <div class="edge">
-        <div class="edge-path" {{bind-attr style="edge.style"}}>
-          {{edge.type}}
-        </div>
-       {{!--  <div class="edge-arrow" ></div> --}}
-      </div>
-    {{/each}}
-
-    <div class="nodes">
-      {{#each group in view.verticesGroups}}
-        <div class="node-container">
-          {{#if group.contents}}
-            {{#each node in group.contents}}
-              <div {{bind-attr class="node.isTableNode:table-node node.isOutputNode:output-node :node" title="node.id"}}>
-                {{#if node.isTableNode}}
-                  <p><strong>{{t 'labels.table'}}</strong></p>
-                  {{node.label}}
-                {{else}}
-                  {{#if node.isOutputNode}}
-                    {{node.label}}
-                  {{else}}
-                    <div class="node-heading">
-                      <strong>{{node.label}}</strong>
-                    </div>
-                    <div class="node-content">
-                      {{#each section in node.contents}}
-                        <p>
-                          {{#popover-widget classNames="fa fa-info-circle" titleTranslation="popover.visualExplain.statistics" }}
-                            {{section.statistics}}
-                          {{/popover-widget}}
-                          <strong>
-                            {{section.index}}. {{section.title}}
-                          </strong>
-                          {{section.value}}
-                        </p>
-
-                        {{#each field in section.fields}}
-                          {{#if field.value}}
-                            <p>{{field.label}} {{field.value}}</p>
-                          {{/if}}
-                        {{/each}}
-                      {{/each}}
-                    </div>
-                    {{progress-widget value=node.progress}}
-                  {{/if}}
-                {{/if}}
-              </div>
-            {{/each}}
-          {{else}}
-            <div class="node" {{bind-attr title="group.label"}}>
-              {{group.label}}
-            </div>
-          {{/if}}
-        </div>
-      {{/each}}
-    </div>
-  </div>
-
-  {{/panel-widget}}
-</div>

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/visualization-ui.hbs
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/visualization-ui.hbs b/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/visualization-ui.hbs
deleted file mode 100644
index 22cbaef..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/visualization-ui.hbs
+++ /dev/null
@@ -1,37 +0,0 @@
-{{!
-* 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.
-}}
-
-<div id="visualization" class="index-overlay">
-  {{#panel-widget headingTranslation="titles.query.visualization"}}
-    {{#if error}}
-      <div class="alert alert-danger" role="alert"><strong>{{error}}</strong></div>
-    {{else}}
-      {{#if polestarUrl}}
-        <div class="max-rows" >
-          <label>Maximum Row Count: </label> {{input value=selectedRowCount placeholder=selectedRowCount }}
-          <button {{action "changeRowCount"}}>OK</button>
-        </div>
-        {{#visualization-tabs-widget tabs=visualizationTabs }}
-
-        {{/visualization-tabs-widget}}
-      {{else}}
-          <div class="alert alert-danger" role="alert"><strong>An unknown error occurred! Please try again later.</strong></div>
-      {{/if}}
-    {{/if}}
-  {{/panel-widget}}
-</div>

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/transforms/date.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/transforms/date.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/transforms/date.js
deleted file mode 100644
index 716ab84..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/transforms/date.js
+++ /dev/null
@@ -1,49 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-import DS from 'ember-data';
-
-export default DS.Transform.extend({
-
-  deserialize: function (serialized) {
-    var type = typeof serialized;
-
-    if (type === "string") {
-      return new Date(Ember.Date.parse(serialized));
-    } else if (type === "number") {
-      return new Date(serialized);
-    } else if (serialized === null || serialized === undefined) {
-      // if the value is not present in the data,
-      // return undefined, not null.
-      return serialized;
-    } else {
-      return null;
-    }
-  },
-
-  serialize: function (date) {
-    if (date instanceof Date) {
-      // Serialize it as a number to maintain millisecond precision
-      return Number(date);
-    } else {
-      return null;
-    }
-  }
-
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/utils/constants.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/utils/constants.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/utils/constants.js
deleted file mode 100644
index 95aeb6d..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/utils/constants.js
+++ /dev/null
@@ -1,230 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-import helpers from 'hive/utils/functions';
-
-export default Ember.Object.create({
-  appTitle: 'Hive',
-
-  /**
-   * This should reflect the naming conventions accross the application.
-   * Changing one value also means changing the filenames for the chain of files
-   * represented by that value (routes, controllers, models etc).
-   * This dependency goes both ways.
-  */
-  namingConventions: {
-    routes: {
-      index: 'index',
-      savedQuery: 'savedQuery',
-      historyQuery: 'historyQuery',
-      queries: 'queries',
-      history: 'history',
-      udfs: 'udfs',
-      logs: 'logs',
-      results: 'results',
-      explain: 'explain',
-      uploadTable :'upload-table',
-      visualization: 'visualization'
-    },
-
-    subroutes: {
-      savedQuery: 'index.savedQuery',
-      historyQuery: 'index.historyQuery',
-      jobLogs: 'index.historyQuery.logs',
-      jobResults: 'index.historyQuery.results',
-      jobExplain: 'index.historyQuery.explain'
-    },
-
-    index: 'index',
-    udf: 'udf',
-    udfs: 'udfs',
-    udfInsertPrefix: 'create temporary function ',
-    fileInsertPrefix: 'add jar ',
-    explainPrefix: 'EXPLAIN ',
-    explainFormattedPrefix: 'EXPLAIN FORMATTED ',
-    insertUdfs: 'insert-udfs',
-    job: 'job',
-    jobs: 'jobs',
-    savedQuery: 'saved-query',
-    database: 'database',
-    databases: 'databases',
-    openQueries: 'open-queries',
-    visualExplain: 'visual-explain',
-    notify: 'notify',
-    history: 'history',
-    tezUI: 'tez-ui',
-    file: 'file',
-    fileResource: 'file-resource',
-    alerts: 'alerts',
-    logs: 'logs',
-    results: 'results',
-    jobResults: 'index/history-query/results',
-    jobLogs: 'index/history-query/logs',
-    jobExplain: 'index/history-query/explain',
-    databaseTree: 'databases-tree',
-    databaseSearch: 'databases-search-results',
-    settings: 'settings',
-    jobProgress: 'job-progress',
-    ldapAuthentication: 'ldap-authentication',
-    queryTabs: 'query-tabs',
-    session: 'session'
-  },
-
-  hiveParameters: [
-    {
-      name: 'hive.tez.container.size',
-      validate: helpers.regexes.digits
-    },
-
-    {
-      name: 'hive.prewarm.enabled',
-      values: helpers.validationValues.bool
-    },
-    {
-      name: 'hive.prewarm.numcontainers',
-      validate: helpers.regexes.digits
-    },
-    {
-      name: 'hive.tez.auto.reducer.parallelism',
-      values: helpers.validationValues.bool
-    },
-    {
-      name: 'hive.execution.engine',
-      values: helpers.validationValues.execEngine
-    },
-    {
-      name: 'hive.vectorized.execution.enabled',
-      values: helpers.validationValues.bool
-    },
-    {
-      name: 'hive.auto.convert.join',
-      values: helpers.validationValues.bool
-    },
-    {
-      name: 'tez.am.resource.memory.mb',
-      validate: helpers.regexes.digits
-    },
-    {
-      name: 'tez.am.container.idle.release-timeout-min.millis',
-      validate: helpers.regexes.digits
-    },
-    {
-      name: 'tez.am.container.idle.release-timeout-max.millis',
-      validate: helpers.regexes.digits
-    },
-    {
-      name: 'tez.queue.name',
-      validate: helpers.regexes.name
-    },
-    {
-      name: 'tez.runtime.io.sort.mb',
-      validate: helpers.regexes.digits
-    },
-    {
-      name: 'tez.runtime.sort.threads',
-      validate: helpers.regexes.digits
-    },
-    {
-      name: 'tez.runtime.compress.codec',
-      validate: helpers.regexes.dotPath
-    },
-    {
-      name: 'tez.grouping.min-size',
-      validate: helpers.regexes.digits
-    },
-    {
-      name: 'tez.grouping.max-size',
-      validate: helpers.regexes.digits
-    },
-    {
-      name: 'tez.generate.debug.artifacts',
-      values: helpers.validationValues.bool
-    }
-  ],
-
-  jobReferrer: {
-    sample: 'sample',
-    explain: 'explain',
-    visualExplain: 'visualExplain',
-    job: 'job'
-  },
-
-  statuses: {
-    unknown: "UNKNOWN",
-    initialized: "INITIALIZED",
-    running: "RUNNING",
-    succeeded: "SUCCEEDED",
-    canceled: "CANCELED",
-    closed: "CLOSED",
-    error: "ERROR",
-    failed: 'FAILED',
-    killed: 'KILLED',
-    pending: "PENDING"
-  },
-
-  alerts: {
-    warning: 'warning',
-    error: 'danger',
-    success: 'success'
-  },
-
-  results: {
-    save: {
-      csv: 'Save as csv',
-      hdfs: 'Save to HDFS'
-    },
-    statuses: {
-      terminated: "TERMINATED",
-      runnable: "RUNNABLE"
-    }
-  },
-
-  //this can be replaced by a string.format implementation
-  adapter: {
-    version: '1.0.0',
-    instance: 'Hive',
-    apiPrefix: '/api/v1/views/HIVE/versions/',
-    instancePrefix: '/instances/',
-    resourcePrefix: 'resources/'
-  },
-
-  sampleDataQuery: 'SELECT * FROM %@ LIMIT 100;',
-
-  notify: {
-    ERROR:  {
-      typeClass : 'alert-danger',
-      typeIcon  : 'fa-exclamation-triangle'
-    },
-    WARN: {
-      typeClass : 'alert-warning',
-      typeIcon  : 'fa-times-circle'
-    },
-    SUCCESS: {
-      typeClass : 'alert-success',
-      typeIcon  : 'fa-check'
-    },
-    INFO: {
-      typeClass : 'alert-info',
-      typeIcon  : 'fa-info'
-    }
-  },
-
-  defaultVisualizationRowCount: 10000
-
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/utils/dag-rules.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/utils/dag-rules.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/utils/dag-rules.js
deleted file mode 100644
index c854892..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/utils/dag-rules.js
+++ /dev/null
@@ -1,141 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-
-export default Ember.ArrayProxy.create({
-  content: Ember.A(
-    [
-      {
-        targetOperator: 'TableScan',
-        targetProperty: 'alias:',
-        label: 'Table Scan:',
-
-        fields: [
-          {
-            label: 'filterExpr:',
-            targetProperty: 'filterExpr:'
-          }
-        ]
-      },
-      {
-        targetOperator: 'Filter Operator',
-        targetProperty: 'predicate:',
-        label: 'Filter:',
-
-        fields: []
-      },
-      {
-        targetOperator: 'Map Join Operator',
-        label: 'Map Join',
-
-        fields: []
-      },
-      {
-        targetOperator: 'Merge Join Operator',
-        label: 'Merge Join',
-
-        fields: []
-      },
-      {
-        targetOperator: 'Select Operator',
-        label: 'Select',
-
-        fields: []
-      },
-      {
-        targetOperator: 'Reduce Output Operator',
-        label: 'Reduce',
-
-        fields: [
-          {
-            label: 'Partition columns:',
-            targetProperty: 'Map-reduce partition columns:'
-          },
-          {
-            label: 'Key expressions:',
-            targetProperty: 'key expressions:'
-          },
-          {
-            label: 'Sort order:',
-            targetProperty: 'sort order:'
-          }
-        ]
-      },
-      {
-        targetOperator: 'File Output Operator',
-        label: 'File Output Operator',
-
-        fields: []
-      },
-      {
-        targetOperator: 'Group By Operator',
-        label: 'Group By:',
-
-        fields: [
-          {
-            label: 'Aggregations:',
-            targetProperties: 'aggregations:'
-          },
-          {
-            label: 'Keys:',
-            targetProperty: 'keys:'
-          }
-        ]
-      },
-      {
-        targetOperator: 'Limit',
-        targetProperty: 'Number of rows:',
-        label: 'Limit:',
-
-        fields: []
-      },
-      {
-        targetOperator: 'Extract',
-        label: 'Extract',
-
-        fields: []
-      },
-      {
-        targetOperator: 'PTF Operator',
-        label: 'Partition Table Function',
-
-        fields: []
-      },
-      {
-        targetOperator: 'Dynamic Partitioning Event Operator',
-        labelel: 'Dynamic Partitioning Event',
-
-        fields: [
-          {
-            label: 'Target column:',
-            targetProperty: 'Target column:'
-          },
-          {
-            label: 'Target Vertex:',
-            targetProperty: 'Target Vertex:'
-          },
-          {
-            label: 'Partition key expr:',
-            targetProperty: 'Partition key expr:'
-          }
-        ]
-      }
-    ]
-  )
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/utils/functions.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/utils/functions.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/utils/functions.js
deleted file mode 100644
index 32d81d3..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/utils/functions.js
+++ /dev/null
@@ -1,139 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-
-/* globals moment */
-
-export default Ember.Object.create({
-  isInteger: function (x) {
-    return !isNaN(x);
-  },
-
-  isDate: function (date) {
-    return moment(date).isValid();
-  },
-
-  regexes: {
-    allUppercase: /^[^a-z]*$/,
-    whitespaces: /^(\s*).*$/,
-    digits: /^\d+$/,
-    name: /\w+/ig,
-    dotPath: /[a-z.]+/i,
-    setSetting: /^set\s+[\w-.]+(\s+|\s?)=(\s+|\s?)[\w-.]+(\s+|\s?);/gim
-  },
-
-  validationValues: {
-    bool: [
-      Ember.Object.create({
-        value: 'true'
-      }),
-      Ember.Object.create({
-        value: 'false'
-      })
-    ],
-
-    execEngine: [
-      Ember.Object.create({
-        value: 'tez'
-      }),
-      Ember.Object.create({
-        value: 'mr'
-      })
-    ]
-  },
-
-  insensitiveCompare: function (sourceString) {
-    var args = Array.prototype.slice.call(arguments, 1);
-
-    if (!sourceString) {
-      return false;
-    }
-
-    return !!args.find(function (arg) {
-      return sourceString.match(new RegExp('^' + arg + '$', 'i'));
-    });
-  },
-
-  insensitiveContains: function (sourceString, destString) {
-    return sourceString.toLowerCase().indexOf(destString.toLowerCase()) > -1;
-  },
-
-  convertToArray: function (inputObj) {
-    var array = [];
-
-    for (var key in inputObj) {
-      if (inputObj.hasOwnProperty(key)) {
-        array.pushObject({
-          name: key,
-          value: inputObj[key]
-        });
-      }
-    }
-    return array;
-  },
-
-  /**
-   * Convert number of seconds into time object HH MM SS
-   *
-   * @param integer secs Number of seconds to convert
-   * @return object
-   */
-  secondsToHHMMSS: function (secs) {
-    var hours = 0,
-      minutes = 0,
-      seconds = secs,
-      divisor_for_minutes,
-      divisor_for_seconds,
-      formattedVal = [];
-
-    if (seconds < 60) {
-      formattedVal.push(Ember.I18n.t('labels.secsShort', {
-        seconds: seconds
-      }));
-    } else {
-      hours = Math.floor(seconds / (60 * 60));
-
-      divisor_for_minutes = seconds % (60 * 60);
-      minutes = Math.floor(divisor_for_minutes / 60);
-
-      divisor_for_seconds = divisor_for_minutes % 60;
-      seconds = Math.ceil(divisor_for_seconds);
-
-      if (hours > 0) {
-        formattedVal.push(Ember.I18n.t('labels.hrsShort', {
-          hours: hours
-        }));
-      }
-      if (minutes > 0) {
-        formattedVal.push(Ember.I18n.t('labels.minsShort', {
-          minutes: minutes
-        }));
-      }
-      if (seconds > 0) {
-        formattedVal.push(Ember.I18n.t('labels.secsShort', {
-          seconds: seconds
-        }));
-      }
-
-    }
-
-    return formattedVal.join(' ');
-  }
-
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/views/.gitkeep
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/views/.gitkeep b/contrib/views/hive/src/main/resources/ui/hive-web/app/views/.gitkeep
deleted file mode 100644
index e69de29..0000000

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/views/index.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/views/index.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/views/index.js
deleted file mode 100644
index 204e67f..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/views/index.js
+++ /dev/null
@@ -1,28 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-
-export default Ember.View.extend({
-  didInsertElement: function() {
-    this._super();
-    Ember.$('body').tooltip({
-      selector: '[data-toggle="tooltip"]'
-    });
-  }
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/views/message.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/views/message.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/views/message.js
deleted file mode 100644
index 45b0236..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/views/message.js
+++ /dev/null
@@ -1,36 +0,0 @@
-  /**
- * 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.
- */
-import Ember from 'ember';
-import NotificationView from 'hive/views/notification';
-
-export default NotificationView.extend({
-  templateName : 'message',
-  removeLater  : Ember.K,
-  isExpanded  : false,
-  removeMessage: 'removeMessage',
-
-  actions: {
-    expand: function () {
-      this.toggleProperty('isExpanded');
-    },
-
-    close: function () {
-      this.get('controller').send('removeMessage', this.get('notification'));
-    }
-  }
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/views/messages.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/views/messages.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/views/messages.js
deleted file mode 100644
index 5e720c0..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/views/messages.js
+++ /dev/null
@@ -1,37 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-
-export default Ember.View.extend({
-  didInsertElement: function () {
-    var target = this.$('#messages');
-    var panel = this.$('#messages .panel-body');
-
-    panel.css('min-height', $('.main-content').height());
-    target.animate({ width: $('.main-content').width() }, 'fast');
-  },
-
-  willDestroyElement: function () {
-    var target = this.$('#messages');
-    var panel = this.$('#messages .panel-body');
-
-    panel.css('min-height', 0);
-    target.css('width', 0);
-  }
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/views/notification.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/views/notification.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/views/notification.js
deleted file mode 100644
index 1fd2ce8..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/views/notification.js
+++ /dev/null
@@ -1,51 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-
-export default Ember.View.extend({
-  closeAfter         : 5000,
-  isHovering         : false,
-  templateName       : 'notification',
-  removeNotification : 'removeNotification',
-
-  setup: function () {
-    this.set('typeClass', this.get('notification.type.typeClass'));
-    this.set('typeIcon', this.get('notification.type.typeIcon'));
-  }.on('init'),
-
-  removeLater: function () {
-    Ember.run.later(this, function () {
-      if (this.get('isHovering')) {
-        this.removeLater();
-      } else if (this.element) {
-        this.send('close');
-      }
-    }, this.get('closeAfter'));
-  }.on('didInsertElement'),
-
-  mouseEnter: function () { this.set('isHovering', true);  },
-  mouseLeave: function () { this.set('isHovering', false); },
-
-  actions: {
-    close: function () {
-      this.remove();
-      this.get('parentView').send('removeNotification', this.get('notification'));
-    }
-  }
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/views/tez-ui.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/views/tez-ui.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/views/tez-ui.js
deleted file mode 100644
index 7601463..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/views/tez-ui.js
+++ /dev/null
@@ -1,37 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-
-export default Ember.View.extend({
-  didInsertElement: function () {
-    var target = this.$('#tez-ui');
-    var panel = this.$('#tez-ui .panel-body');
-
-    panel.css('min-height', $('.main-content').height());
-    target.animate({ width: $('.main-content').width() }, 'fast');
-  },
-
-  willDestroyElement: function () {
-    var target = this.$('#tez-ui');
-    var panel = this.$('#tez-ui .panel-body');
-
-    panel.css('min-height', 0);
-    target.css('width', 0);
-  }
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/views/visual-explain.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/views/visual-explain.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/views/visual-explain.js
deleted file mode 100644
index 94cb05a..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/views/visual-explain.js
+++ /dev/null
@@ -1,461 +0,0 @@
-/**
- * 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.
- */
-
-/* globals dagre */
-
-import Ember from 'ember';
-import dagRules from '../utils/dag-rules';
-import utils from 'hive/utils/functions';
-
-export default Ember.View.extend({
-  verticesGroups: [],
-  edges: [],
-
-  willInsertElement: function () {
-    this.set('graph', new dagre.graphlib.Graph());
-  },
-
-  didInsertElement: function () {
-    this._super();
-
-    var target = this.$('#visual-explain');
-    var panel = this.$('#visual-explain .panel-body');
-
-    panel.css('min-height', $('.main-content').height());
-    target.animate({ width: $('.main-content').width() }, 'fast');
-
-    this.$('#visual-explain-graph').draggable();
-
-    if (this.get('controller.rerender')) {
-      this.renderDag();
-    }
-  },
-
-  willDestroyElement: function () {
-    var target = this.$('#visual-explain');
-    var panel = this.$('#visual-explain .panel-body');
-
-    panel.css('min-height', 0);
-    target.css('width', 0);
-  },
-
-  updateProgress: function () {
-    var verticesProgress = this.get('controller.verticesProgress');
-    var verticesGroups = this.get('verticesGroups');
-
-    if (!verticesGroups || !verticesProgress || !verticesProgress.length) {
-      return;
-    }
-
-    verticesGroups.forEach(function (verticesGroup) {
-      verticesGroup.contents.forEach(function (node) {
-        var progress = verticesProgress.findBy('name', node.get('label'));
-
-        if (progress) {
-          node.set('progress', progress.get('value'));
-        }
-      });
-    });
-  }.observes('controller.verticesProgress.@each.value', 'verticesGroups'),
-
-  jsonChanged: function () {
-    var json = this.get('controller.json');
-    this.renderDag();
-  }.observes('controller.json'),
-
-  getOffset: function (el) {
-    var _x = 0;
-    var _y = 0;
-    var _w = el.offsetWidth|0;
-    var _h = el.offsetHeight|0;
-    while( el && !isNaN( el.offsetLeft ) && !isNaN( el.offsetTop ) ) {
-        _x += el.offsetLeft - el.scrollLeft;
-        _y += el.offsetTop - el.scrollTop;
-        el = el.offsetParent;
-    }
-    return { top: _y, left: _x, width: _w, height: _h };
-  },
-
-  addEdge: function (div1, div2, thickness, type) {
-    var off1 = this.getOffset(div1);
-    var off2 = this.getOffset(div2);
-    // bottom right
-    var x1 = off1.left + off1.width / 2;
-    var y1 = off1.top + off1.height;
-    // top right
-    var x2 = off2.left + off2.width / 2;
-    var y2 = off2.top;
-    // distance
-    var length = Math.sqrt(((x2-x1) * (x2-x1)) + ((y2-y1) * (y2-y1)));
-    // center
-    var cx = ((x1 + x2) / 2) - (length / 2);
-    var cy = ((y1 + y2) / 2) - (thickness / 2) - 73;
-    // angle
-    var angle = Math.round(Math.atan2((y1-y2), (x1-x2)) * (180 / Math.PI));
-
-    if (angle < -90) {
-      angle = 180 + angle;
-    }
-
-    var style = "left: %@px; top: %@px; width: %@px; transform:rotate(%@4deg);";
-    style = style.fmt(cx, cy, length, angle);
-
-    var edgeType;
-
-    if (type) {
-      if (type === 'BROADCAST_EDGE') {
-        edgeType = 'BROADCAST';
-      } else {
-        edgeType = 'SHUFFLE';
-      }
-    }
-
-    this.get('edges').pushObject({
-      style: style,
-      type: edgeType
-    });
-  },
-
-  getNodeContents: function (operator, contents, table, vertex) {
-    var currentTable = table,
-      contents = contents || [],
-      nodeName,
-      node,
-      ruleNode,
-      nodeLabelValue,
-      self = this;
-
-    if (operator.constructor === Array) {
-      operator.forEach(function (childOperator) {
-        self.getNodeContents(childOperator, contents, currentTable, vertex);
-      });
-
-      return contents;
-    } else {
-      nodeName = Object.getOwnPropertyNames(operator)[0];
-      node = operator[nodeName];
-      ruleNode = dagRules.findBy('targetOperator', nodeName);
-
-      if (ruleNode) {
-        if (nodeName.indexOf('Map Join') > -1) {
-          nodeLabelValue = this.handleMapJoinNode(node, currentTable);
-          currentTable = null;
-        } else if (nodeName.indexOf('Merge Join') > -1) {
-          nodeLabelValue = this.handleMergeJoinNode(node, vertex);
-        } else {
-          nodeLabelValue = node[ruleNode.targetProperty];
-        }
-
-        contents.pushObject({
-          title: ruleNode.label,
-          statistics: node["Statistics:"],
-          index: contents.length + 1,
-          value: nodeLabelValue,
-          fields: ruleNode.fields.map(function (field) {
-            var value = node[field.targetProperty || field.targetProperties];
-
-            return {
-              label: field.label,
-              value: value
-            };
-          })
-        });
-
-        if (node.children) {
-          return this.getNodeContents(node.children, contents, currentTable, vertex);
-        } else {
-          return contents;
-        }
-      } else {
-        return contents;
-      }
-    }
-  },
-
-  handleMapJoinNode: function (node, table) {
-    var rows = table || "<rows from above>";
-    var firstTable = node["input vertices:"][0] || rows;
-    var secondTable = node["input vertices:"][1] || rows;
-
-    var joinString = node["condition map:"][0][""];
-    joinString = joinString.replace("0", firstTable);
-    joinString = joinString.replace("1", secondTable);
-    joinString += " on ";
-    joinString += node["keys:"][0] + "=";
-    joinString += node["keys:"][1];
-
-    return joinString;
-  },
-
-  handleMergeJoinNode: function (node, vertex) {
-    var graphData = this.get('controller.json')['STAGE PLANS']['Stage-1']['Tez'];
-    var edges = graphData['Edges:'];
-    var index = 0;
-    var joinString = node["condition map:"][0][""];
-
-    edges[vertex].toArray().forEach(function (edge) {
-      if (edge.type === "SIMPLE_EDGE") {
-        joinString.replace(String(index), edge.parent);
-        index++;
-      }
-    });
-
-    return joinString;
-  },
-
-  //sets operator nodes
-  setNodes: function (vertices) {
-    var g = this.get('graph');
-    var self = this;
-
-    vertices.forEach(function (vertex) {
-      var contents = [];
-      var operator;
-      var currentTable;
-
-      if (vertex.name.indexOf('Map') > -1) {
-        if (vertex.value && vertex.value['Map Operator Tree:']) {
-          operator = vertex.value['Map Operator Tree:'][0];
-          currentTable = operator["TableScan"]["alias:"];
-        } else {
-          //https://hortonworks.jira.com/browse/BUG-36168
-          operator = "None";
-        }
-      } else if (vertex.name.indexOf('Reducer') > -1) {
-        operator = vertex.value['Reduce Operator Tree:'];
-      }
-
-      if (operator) {
-        contents = self.getNodeContents(operator, null, currentTable, vertex.name);
-
-        g.setNode(vertex.name, {
-          contents: contents,
-          id: vertex.name,
-          label: vertex.name
-        });
-      }
-    });
-
-    return this;
-  },
-
-  //sets edges between operator nodes
-  setEdges: function (edges) {
-    var g = this.get('graph');
-    var invalidEdges = [];
-    var edgesToBeRemoved = [];
-    var isValidEdgeType = function (type) {
-      return type === "SIMPLE_EDGE" ||
-             type === "BROADCAST_EDGE";
-    };
-
-    edges.forEach(function (edge) {
-      var parent;
-      var type;
-
-      if (edge.value.constructor === Array) {
-        edge.value.forEach(function (childEdge) {
-          parent = childEdge.parent;
-          type = childEdge.type;
-
-          if (isValidEdgeType(type)) {
-            g.setEdge(parent, edge.name);
-            g.edge({v: parent, w: edge.name}).type = type;
-          } else {
-            invalidEdges.pushObject({
-              vertex: edge.name,
-              edge: childEdge
-            });
-          }
-        });
-      } else {
-        parent = edge.value.parent;
-        type = edge.value.type;
-
-        if (isValidEdgeType(type)) {
-          g.setEdge(parent, edge.name);
-          g.edge({v: parent, w: edge.name}).type = type;
-        } else {
-          invalidEdges.pushObject({
-            vertex: edge.name,
-            edge: edge.name
-          });
-        }
-      }
-    });
-
-    invalidEdges.forEach(function (invalidEdge) {
-      var parent;
-      var targetEdge = g.edges().find(function (graphEdge) {
-        return graphEdge.v === invalidEdge.edge.parent ||
-               graphEdge.w === invalidEdge.edge.parent;
-      });
-
-      var targetVertex;
-
-      if (targetEdge) {
-        edgesToBeRemoved.pushObject(targetEdge);
-
-        if (targetEdge.v === invalidEdge.edge.parent) {
-          targetVertex = targetEdge.w;
-        } else {
-          targetVertex = targetEdge.v;
-        }
-
-        parent = invalidEdge.vertex;
-
-        g.setEdge({v: parent, w: targetVertex});
-        g.setEdge({v: parent, w: targetVertex}).type = "BROADCAST_EDGE";
-      }
-    });
-
-    edgesToBeRemoved.uniq().forEach(function (edge) {
-      g.removeEdge(edge.v, edge.w, edge.name);
-    });
-
-    return this;
-  },
-
-  //sets nodes for tables and their edges
-  setTableNodesAndEdges: function (vertices) {
-    var g = this.get('graph');
-
-    vertices.forEach(function (vertex) {
-      var operator;
-      var table;
-      var id;
-
-      if (vertex.name.indexOf('Map') > -1 && vertex.value && vertex.value['Map Operator Tree:']) {
-        operator = vertex.value['Map Operator Tree:'][0];
-        for (var node in operator) {
-          table = operator[node]['alias:'];
-
-          //create unique identifier by using table + map pairs so that we have
-          //different nodes for the same table if it's a table connected to multiple Map operators
-          id = table + ' for ' + vertex.name;
-
-          g.setNode(id, { id: id, label: table, isTableNode: true });
-          g.setEdge(id, vertex.name);
-        }
-      }
-    });
-
-    dagre.layout(g);
-
-    return this;
-  },
-
-  createNodeGroups: function () {
-    var groupedNodes = [];
-    var g = this.get('graph');
-    var lastRowNode;
-    var fileOutputOperator;
-
-    g.nodes().forEach(function (value) {
-      var node = g.node(value);
-
-      if (node) {
-        var existentRow = groupedNodes.findBy('topOffset', node.y);
-
-        if (!existentRow) {
-           groupedNodes.pushObject({
-              topOffset: node.y,
-              contents: [ Ember.Object.create(node) ]
-           });
-        } else {
-          existentRow.contents.pushObject(Ember.Object.create(node));
-        }
-      }
-    });
-
-    groupedNodes = groupedNodes.sortBy('topOffset');
-    groupedNodes.forEach(function (group) {
-      group.contents = group.contents.sortBy('x');
-    });
-
-    lastRowNode = groupedNodes.get('lastObject.contents.lastObject');
-    fileOutputOperator = lastRowNode.contents.get('lastObject');
-
-    g.setNode(fileOutputOperator.title, { id: fileOutputOperator.title, label: fileOutputOperator.title, isOutputNode: true });
-    g.setEdge(fileOutputOperator.title, lastRowNode.id);
-
-    groupedNodes.pushObject({
-      contents: [ Ember.Object.create(g.node(fileOutputOperator.title)) ]
-    });
-
-    lastRowNode.contents.removeObject(fileOutputOperator);
-
-    this.set('verticesGroups', groupedNodes);
-
-    return this;
-  },
-
-  renderEdges: function () {
-    var self = this;
-    var g = this.get('graph');
-
-    Ember.run.later(function () {
-      g.edges().forEach(function (value) {
-        var firstNode = self.$("[title='" + value.v + "']");
-        var secondNode = self.$("[title='" + value.w + "']");
-
-        if (firstNode && secondNode) {
-          self.addEdge(firstNode[0], secondNode[0], 2, g.edge(value).type);
-        }
-
-      });
-    }, 400);
-  },
-
-  renderDag: function () {
-    var json = this.get('controller.json');
-    var isVisualExplain = json && (json['STAGE PLANS'] != undefined) &&  (json['STAGE PLANS']['Stage-1'] != undefined) && (json['STAGE PLANS']['Stage-1']['Tez'] != undefined);
-    if (isVisualExplain) {
-      this.set('edges', []);
-
-      // Create a new directed graph
-      var g = this.get('graph');
-
-      var graphData = json['STAGE PLANS']['Stage-1']['Tez'];
-      var vertices = utils.convertToArray(graphData['Vertices:']);
-      var edges = utils.convertToArray(graphData['Edges:']);
-
-      // Set an object for the graph label
-      g.setGraph({});
-
-      // Default to assigning a new object as a label for each new edge.
-      g.setDefaultEdgeLabel(function () { return {}; });
-
-      this.setNodes(vertices)
-          .setEdges(edges)
-          .setTableNodesAndEdges(vertices)
-          .createNodeGroups()
-          .renderEdges();
-
-      this.set('controller.showSpinner', true);
-
-    } else {
-
-      if(!this.get('controller.noquery')) {
-        $('#no-visual-explain-graph').html('Visual explain is not available.');
-      }
-
-    }
-
-  }
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/views/visualization-ui.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/views/visualization-ui.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/views/visualization-ui.js
deleted file mode 100644
index b1c10df..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/views/visualization-ui.js
+++ /dev/null
@@ -1,37 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-
-export default Ember.View.extend({
-  didInsertElement: function () {
-    var target = this.$('#visualization');
-    var panel = this.$('#visualization .panel-body').first();
-
-    panel.css('min-height', $('.main-content').height());
-    target.animate({ width: $('.main-content').width() }, 'fast');
-  },
-
-  willDestroyElement: function () {
-    var target = this.$('#visualization');
-    var panel = this.$('#visualization .panel-body');
-
-    panel.css('min-height', 0);
-    target.css('width', 0);
-  }
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/big_tables.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/big_tables.js b/contrib/views/hive/src/main/resources/ui/hive-web/big_tables.js
deleted file mode 100644
index 9f3a317..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/big_tables.js
+++ /dev/null
@@ -1,54 +0,0 @@
-/**
- * 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.
- */
-
-var result = '';
-var tableCount = 15000;
-var columnCount = 100;
-
-//tables and columns script
-for (var i = 0; i < tableCount; i++) {
-  result += 'CREATE TABLE TABLE_' + i + ' (';
-  (function () {
-    for (var j = 0; j < columnCount; j++) {
-      result += 'field_' + j + ' STRING';
-
-      if (j < columnCount - 1) {
-        result += ',';
-      } else {
-        result += ') '
-      }
-    }
-  }());
-
-  result += "ROW FORMAT DELIMITED FIELDS TERMINATED BY ',' STORED AS TEXTFILE; \nLOAD  DATA LOCAL INPATH 'test.csv' OVERWRITE INTO TABLE " +
-            'TABLE_' + i + ';\n\n';
-}
-
-console.log(result);
-
-//csv script
-var fill = '';
-for (var i = 0; i < columnCount; i++) {
-  fill += 'field_' + i;
-
-  if (i < columnCount - 1) {
-    fill += ', ';
-  }
-}
-
-console.log(fill);
\ No newline at end of file

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/bower.json
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/bower.json b/contrib/views/hive/src/main/resources/ui/hive-web/bower.json
deleted file mode 100644
index d029eff..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/bower.json
+++ /dev/null
@@ -1,28 +0,0 @@
-{
-  "name": "hive",
-  "dependencies": {
-    "jquery": "1.11.3",
-    "ember": "1.10.0",
-    "ember-data": "1.0.0-beta.16.1",
-    "ember-resolver": "~0.1.12",
-    "loader.js": "stefanpenner/loader.js#3.2.0",
-    "ember-cli-shims": "stefanpenner/ember-cli-shims#0.0.3",
-    "ember-cli-test-loader": "rwjblue/ember-cli-test-loader#0.1.3",
-    "ember-load-initializers": "stefanpenner/ember-load-initializers#0.0.2",
-    "ember-qunit": "0.4.0",
-    "ember-qunit-notifications": "0.0.7",
-    "qunit": "1.18.0",
-    "bootstrap": "~3.2.0",
-    "ember-i18n": "~3.0.0",
-    "blanket": "~1.1.5",
-    "jquery-ui": "~1.11.2",
-    "selectize": "~0.12.0",
-    "pretender": "0.1.0",
-    "ember-uploader": "0.3.9",
-    "polestar": "https://github.com/hortonworks/polestar.git#0.7.2",
-    "voyager": "https://github.com/hortonworks/voyager.git#0.7.2"
-  },
-  "resolutions": {
-    "ember": "1.10.0"
-  }
-}


[02/23] ambari git commit: AMBARI-19302 : removed contrib/views/hive folder and made necessary changes in pom.xml files (nitirajrathore)

Posted by ni...@apache.org.
http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/resources/savedQueries/SavedQueryServiceTest.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/resources/savedQueries/SavedQueryServiceTest.java b/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/resources/savedQueries/SavedQueryServiceTest.java
deleted file mode 100644
index 68cb0c8..0000000
--- a/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/resources/savedQueries/SavedQueryServiceTest.java
+++ /dev/null
@@ -1,191 +0,0 @@
-/**
- * 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.ambari.view.hive.resources.savedQueries;
-
-import org.apache.ambari.view.hive.HDFSTest;
-import org.apache.ambari.view.hive.utils.NotFoundFormattedException;
-import org.json.simple.JSONObject;
-import org.junit.*;
-import org.junit.rules.ExpectedException;
-
-import javax.servlet.http.HttpServletResponse;
-import javax.ws.rs.core.Response;
-import javax.ws.rs.core.UriBuilder;
-import javax.ws.rs.core.UriInfo;
-import java.io.File;
-import java.net.URI;
-import java.util.List;
-import java.util.Map;
-
-import static org.easymock.EasyMock.*;
-
-public class SavedQueryServiceTest extends HDFSTest {
-  //TODO: run without HDFS cluster
-  private SavedQueryService savedQueryService;
-  @Rule public ExpectedException thrown = ExpectedException.none();
-
-  @BeforeClass
-  public static void startUp() throws Exception {
-    HDFSTest.startUp(); // super
-  }
-
-  @AfterClass
-  public static void shutDown() throws Exception {
-    HDFSTest.shutDown(); // super
-  }
-
-  @Override
-  @Before
-  public void setUp() throws Exception {
-    super.setUp();
-    savedQueryService = getService(SavedQueryService.class, handler, context);
-    savedQueryService.getSharedObjectsFactory().clear();
-  }
-
-  @Override
-  @After
-  public void tearDown() throws Exception {
-    super.tearDown();
-  }
-
-  @Override
-  protected void setupProperties(Map<String, String> properties, File baseDir) throws Exception {
-    super.setupProperties(properties, baseDir);
-    properties.put("scripts.dir", "/tmp/.hiveQueries");
-  }
-
-  private Response doCreateSavedQuery() {
-      return doCreateSavedQuery("Luke", "/tmp/luke.hql", savedQueryService);
-  }
-
-  public static Response doCreateSavedQuery(String title, String path, SavedQueryService service) {
-    SavedQueryService.SavedQueryRequest request = new SavedQueryService.SavedQueryRequest();
-    request.savedQuery = new SavedQuery();
-    request.savedQuery.setTitle(title);
-    request.savedQuery.setQueryFile(path);
-
-    UriInfo uriInfo = createNiceMock(UriInfo.class);
-    URI uri = UriBuilder.fromUri("http://host/a/b").build();
-    expect(uriInfo.getAbsolutePath()).andReturn(uri);
-
-    HttpServletResponse resp_obj = createNiceMock(HttpServletResponse.class);
-
-    resp_obj.setHeader(eq("Location"), anyString());
-
-    replay(uriInfo, resp_obj);
-    return service.create(request, resp_obj, uriInfo);
-  }
-
-  private Response doCreateSavedQuery(String title, String path) {
-      return doCreateSavedQuery(title, path, savedQueryService);
-  }
-
-  @Test
-  public void createSavedQuery() {
-    Response response = doCreateSavedQuery();
-    Assert.assertEquals(201, response.getStatus());
-
-    JSONObject obj = (JSONObject)response.getEntity();
-    Assert.assertTrue(obj.containsKey("savedQuery"));
-    Assert.assertNotNull(((SavedQuery) obj.get("savedQuery")).getId());
-    Assert.assertTrue(((SavedQuery) obj.get("savedQuery")).getId() != null);
-  }
-
-  @Test
-  public void createSavedQueryAutoCreate() {
-    Response response = doCreateSavedQuery("Test", null);
-    Assert.assertEquals(201, response.getStatus());
-
-    JSONObject obj = (JSONObject)response.getEntity();
-    Assert.assertTrue(obj.containsKey("savedQuery"));
-    Assert.assertNotNull(((SavedQuery) obj.get("savedQuery")).getId());
-    Assert.assertFalse(((SavedQuery) obj.get("savedQuery")).getId() == null);
-    Assert.assertFalse(((SavedQuery) obj.get("savedQuery")).getQueryFile().isEmpty());
-  }
-
-  @Test
-  public void notFound() {
-    thrown.expect(NotFoundFormattedException.class);
-    savedQueryService.getOne("4242", null);
-  }
-
-  @Test
-  public void update() {
-    Response created = doCreateSavedQuery();
-    Object createdId = ((SavedQuery) ((JSONObject) created.getEntity()).get("savedQuery")).getId();
-
-    SavedQueryService.SavedQueryRequest request = new SavedQueryService.SavedQueryRequest();
-    request.savedQuery = new SavedQuery();
-    request.savedQuery.setTitle("Updated Query");
-
-    Response response = savedQueryService.update(request, String.valueOf(createdId));
-    Assert.assertEquals(204, response.getStatus());
-
-    Response response2 = savedQueryService.getOne(String.valueOf(createdId), "");
-    Assert.assertEquals(200, response2.getStatus());
-
-    JSONObject obj = ((JSONObject) response2.getEntity());
-    Assert.assertTrue(obj.containsKey("savedQuery"));
-    Assert.assertEquals(((SavedQuery) obj.get("savedQuery")).getTitle(), request.savedQuery.getTitle());
-  }
-
-  @Test
-  public void delete() {
-    Response created = doCreateSavedQuery();
-    Object createdId = ((SavedQuery) ((JSONObject) created.getEntity()).get("savedQuery")).getId();
-
-    Response response = savedQueryService.delete(String.valueOf(createdId));
-    Assert.assertEquals(204, response.getStatus());
-
-    thrown.expect(NotFoundFormattedException.class);
-    savedQueryService.getOne(String.valueOf(createdId),null);
-  }
-
-  @Test
-  public void list() {
-    doCreateSavedQuery("Title 1", "/path/to/file.hql");
-    doCreateSavedQuery("Title 2", "/path/to/file.hql");
-
-    Response response = savedQueryService.getList();
-    Assert.assertEquals(200, response.getStatus());
-
-    JSONObject obj = (JSONObject) response.getEntity();
-    Assert.assertTrue(obj.containsKey("savedQueries"));
-    List<SavedQuery> items = (List<SavedQuery>) obj.get("savedQueries");
-    boolean containsTitle = false;
-    for(SavedQuery item : items)
-        containsTitle = containsTitle || item.getTitle().compareTo("Title 1") == 0;
-    Assert.assertTrue(containsTitle);
-
-    containsTitle = false;
-    for(SavedQuery item : items)
-        containsTitle = containsTitle || item.getTitle().compareTo("Title 2") == 0;
-    Assert.assertTrue(containsTitle);
-  }
-  @Test
-  public void downloadQuery() {
-    Response created = doCreateSavedQuery();
-    Object createdId = ((SavedQuery) ((JSONObject) created.getEntity()).get("savedQuery")).getId();
-    SavedQueryService.SavedQueryRequest request = new SavedQueryService.SavedQueryRequest();
-    request.savedQuery = new SavedQuery();
-    request.savedQuery.setTitle("Download Query");
-    Response response = savedQueryService.getOne(String.valueOf(createdId), "download");
-    Assert.assertEquals(200, response.getStatus());
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/resources/udfs/UDFServiceTest.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/resources/udfs/UDFServiceTest.java b/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/resources/udfs/UDFServiceTest.java
deleted file mode 100644
index c8b70a8..0000000
--- a/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/resources/udfs/UDFServiceTest.java
+++ /dev/null
@@ -1,119 +0,0 @@
-/**
- * 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.ambari.view.hive.resources.udfs;
-
-import org.apache.ambari.view.hive.BaseHiveTest;
-import org.apache.ambari.view.hive.resources.udfs.UDF;
-import org.apache.ambari.view.hive.resources.udfs.UDFService;
-import org.apache.ambari.view.hive.utils.NotFoundFormattedException;
-import org.json.simple.JSONObject;
-import org.junit.Assert;
-import org.junit.Before;
-import org.junit.Rule;
-import org.junit.Test;
-import org.junit.rules.ExpectedException;
-
-import javax.servlet.http.HttpServletResponse;
-import javax.ws.rs.core.Response;
-import javax.ws.rs.core.UriBuilder;
-import javax.ws.rs.core.UriInfo;
-import java.net.URI;
-
-import static org.easymock.EasyMock.*;
-
-public class UDFServiceTest extends BaseHiveTest {
-  @Rule public ExpectedException thrown = ExpectedException.none();
-  private UDFService udfService;
-
-  @Override
-  @Before
-  public void setUp() throws Exception {
-    super.setUp();
-    udfService = getService(UDFService.class, handler, context);
-  }
-
-  private Response doCreateUDF() {
-    UDFService.UDFRequest request = new UDFService.UDFRequest();
-    request.udf = new UDF();
-    request.udf.setClassname("/tmp/udf.jar");
-    request.udf.setName("TestUDF");
-
-    UriInfo uriInfo = createNiceMock(UriInfo.class);
-    URI uri = UriBuilder.fromUri("http://host/a/b").build();
-    expect(uriInfo.getAbsolutePath()).andReturn(uri);
-
-    HttpServletResponse resp_obj = createNiceMock(HttpServletResponse.class);
-
-    resp_obj.setHeader(eq("Location"), anyString());
-
-    replay(uriInfo, resp_obj);
-    return udfService.create(request, resp_obj, uriInfo);
-  }
-
-  @Test
-  public void createUDF() {
-    Response response = doCreateUDF();
-    Assert.assertEquals(201, response.getStatus());
-
-    JSONObject obj = (JSONObject)response.getEntity();
-    Assert.assertTrue(obj.containsKey("udf"));
-    Assert.assertNotNull(((UDF) obj.get("udf")).getId());
-    Assert.assertFalse(((UDF) obj.get("udf")).getId() == null);
-  }
-
-  @Test
-  public void udfNotFound() {
-    thrown.expect(NotFoundFormattedException.class);
-    udfService.getOne("4242");
-  }
-
-  @Test
-  public void updateUDF() {
-    Response createdUDF = doCreateUDF();
-    Object createdUdfId = ((UDF) ((JSONObject) createdUDF.getEntity()).get("udf")).getId();
-
-    UDFService.UDFRequest request = new UDFService.UDFRequest();
-    request.udf = new UDF();
-    request.udf.setClassname("/tmp/updatedUDF.jar");
-    request.udf.setName("TestUDF2");
-
-    Response response = udfService.update(request, String.valueOf(createdUdfId));
-    Assert.assertEquals(204, response.getStatus());
-
-    Response response2 = udfService.getOne(String.valueOf(createdUdfId));
-    Assert.assertEquals(200, response2.getStatus());
-
-    JSONObject obj = ((JSONObject) response2.getEntity());
-    Assert.assertTrue(obj.containsKey("udf"));
-    Assert.assertEquals(((UDF) obj.get("udf")).getName(), request.udf.getName());
-    Assert.assertEquals(((UDF) obj.get("udf")).getClassname(), request.udf.getClassname());
-  }
-
-  @Test
-  public void deleteUDF() {
-    Response createdUDF = doCreateUDF();
-    Object createdUdfId = ((UDF) ((JSONObject) createdUDF.getEntity()).get("udf")).getId();
-
-    Response response = udfService.delete(String.valueOf(createdUdfId));
-    Assert.assertEquals(204, response.getStatus());
-
-    thrown.expect(NotFoundFormattedException.class);
-    udfService.getOne(String.valueOf(createdUdfId));
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/resources/upload/CSVParserTest.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/resources/upload/CSVParserTest.java b/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/resources/upload/CSVParserTest.java
deleted file mode 100644
index d278fde..0000000
--- a/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/resources/upload/CSVParserTest.java
+++ /dev/null
@@ -1,275 +0,0 @@
-/**
- * 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
- * <p/>
- * http://www.apache.org/licenses/LICENSE-2.0
- * <p/>
- * 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.ambari.view.hive.resources.upload;
-
-import org.apache.ambari.view.hive.client.Row;
-import org.apache.ambari.view.hive.resources.uploads.parsers.ParseOptions;
-import org.apache.ambari.view.hive.resources.uploads.parsers.csv.commonscsv.CSVParser;
-import org.junit.Assert;
-import org.junit.Test;
-
-import java.io.IOException;
-import java.io.StringReader;
-import java.util.Iterator;
-
-public class CSVParserTest {
-
-  /**
-   * no exception in creating csvParser with emtpy stream
-   * @throws IOException
-   */
-  @Test
-  public void testEmptyStream() throws Exception {
-    String csv = "";
-
-    try(
-      StringReader sr = new StringReader(csv);
-      CSVParser jp = new CSVParser(sr, new ParseOptions());
-      ) {
-      Assert.assertEquals("There should not be any rows.",false, jp.iterator().hasNext());
-    }
-  }
-
-  /**
-   * in case of csv an empty line is still considered as row
-   * @throws IOException
-   */
-  @Test
-  public void testEmptyRow() throws Exception {
-    String csv = "       ";
-
-    try(
-      StringReader sr = new StringReader(csv);
-      CSVParser jp = new CSVParser(sr, new ParseOptions());
-      ) {
-      Iterator<Row> iterator = jp.iterator();
-
-      Assert.assertEquals("Iterator should be Empty", true, iterator.hasNext());
-      Assert.assertArrayEquals("Row should not be empty",new Object[]{"       "},iterator.next().getRow());
-    }
-  }
-
-  @Test
-  public void testParse1Row() throws Exception {
-    String csv = "value1,c,10,10.1";
-
-    try(
-      StringReader sr = new StringReader(csv);
-      CSVParser jp = new CSVParser(sr, new ParseOptions());
-      ) {
-      Iterator<Row> iterator = jp.iterator();
-
-      Assert.assertEquals("Iterator Empty!", true, iterator.hasNext());
-      Row row = iterator.next();
-      Row expected = new Row(new Object[]{"value1", "c", "10", "10.1"});
-      Assert.assertEquals("Row not equal!", expected, row);
-
-      Assert.assertEquals("Should report no more rows!", false, iterator.hasNext());
-    }
-  }
-
-  @Test
-  public void testParseMultipleRow() throws Exception {
-
-    String csv = "value1,c,10,10.1\n" +
-            "value2,c2,102,true";
-
-    try(
-      StringReader sr = new StringReader(csv);
-      CSVParser jp = new CSVParser(sr, new ParseOptions());
-    ) {
-
-      Iterator<Row> iterator = jp.iterator();
-
-      Assert.assertEquals("Failed to detect 1st row!", true, iterator.hasNext());
-      Assert.assertEquals("Failed to match 1st row!", new Row(new Object[]{"value1", "c", "10", "10.1"}), iterator.next());
-
-      Assert.assertEquals("Failed to detect 2nd row!", true, iterator.hasNext());
-      Assert.assertEquals("Failed to match 2nd row!", new Row(new Object[]{"value2", "c2", "102", Boolean.TRUE.toString()}), iterator.next());
-
-      Assert.assertEquals("Failed to detect end of rows!", false, iterator.hasNext());
-      Assert.assertEquals("Failed to detect end of rows 2nd time!", false, iterator.hasNext());
-    }
-  }
-
-
-  @Test
-  public void testQuotedEndline() throws Exception {
-
-    String csv = "\"row1-\ncol1\",1,1.1\n\"row2-\\\ncol1\",2,2.2\n";
-    ParseOptions po = new ParseOptions();
-
-    try(
-      StringReader sr = new StringReader(csv);
-      CSVParser jp = new CSVParser(sr, po);
-    ) {
-
-      Iterator<Row> iterator = jp.iterator();
-
-      Row row = new Row(new Object[]{"row1-\ncol1", "1", "1.1"});
-      Assert.assertEquals("Failed to detect 1st row!", true, iterator.hasNext());
-      Assert.assertEquals("Failed to match 1st row!", row, iterator.next());
-
-      Row row2 = new Row(new Object[]{"row2-\\\ncol1", "2", "2.2"});
-      Assert.assertEquals("Failed to detect 1st row!", true, iterator.hasNext());
-      Assert.assertEquals("Failed to match 1st row!", row2, iterator.next());
-
-    }
-  }
-
-  @Test
-  public void testQuotedDoubleQuote() throws Exception {
-
-    String csv = "\"aaa\",\"b\"\"bb\",\"ccc\"";
-    ParseOptions po = new ParseOptions();
-
-    try(
-      StringReader sr = new StringReader(csv);
-      CSVParser jp = new CSVParser(sr, po);
-    ) {
-
-      Iterator<Row> iterator = jp.iterator();
-
-      Row row = new Row(new Object[]{"aaa", "b\"bb", "ccc"});
-      Assert.assertEquals("Failed to detect 1st row!", true, iterator.hasNext());
-      Assert.assertEquals("Failed to match 1st row!", row, iterator.next());
-    }
-  }
-
-  @Test
-  public void testSpecialEscape() throws Exception {
-
-    String csv = "\"aaa\",\"b$\"bb\",\"ccc\"";
-    ParseOptions po = new ParseOptions();
-    po.setOption(ParseOptions.OPTIONS_CSV_ESCAPE_CHAR,'$');
-
-    try(
-      StringReader sr = new StringReader(csv);
-      CSVParser jp = new CSVParser(sr, po);
-    ) {
-
-      Iterator<Row> iterator = jp.iterator();
-
-      Row row = new Row(new Object[]{"aaa", "b\"bb", "ccc"});
-      Assert.assertEquals("Failed to detect 1st row!", true, iterator.hasNext());
-      Assert.assertEquals("Failed to match 1st row!", row, iterator.next());
-    }
-  }
-
-  @Test
-  public void testSpecialEscapedEscape() throws Exception {
-
-    String csv = "aaa,b$$bb,ccc";
-    ParseOptions po = new ParseOptions();
-    po.setOption(ParseOptions.OPTIONS_CSV_ESCAPE_CHAR,'$');
-
-    try(
-      StringReader sr = new StringReader(csv);
-      CSVParser jp = new CSVParser(sr, po);
-    ) {
-
-      Iterator<Row> iterator = jp.iterator();
-
-      Row row = new Row(new Object[]{"aaa", "b$bb", "ccc"});
-      Assert.assertEquals("Failed to detect 1st row!", true, iterator.hasNext());
-      Assert.assertEquals("Failed to match 1st row!", row, iterator.next());
-    }
-  }
-
-  @Test
-  public void test001Escape() throws Exception {
-
-    String csv = "aaa,b\001\"bb,ccc";
-    ParseOptions po = new ParseOptions();
-    po.setOption(ParseOptions.OPTIONS_CSV_ESCAPE_CHAR,'\001');
-
-    try(
-      StringReader sr = new StringReader(csv);
-      CSVParser jp = new CSVParser(sr, po);
-    ) {
-
-      Iterator<Row> iterator = jp.iterator();
-      Row row = new Row(new Object[]{"aaa", "b\"bb", "ccc"});
-      Assert.assertEquals("Failed to detect 1st row!", true, iterator.hasNext());
-      Assert.assertEquals("Failed to match 1st row!", row, iterator.next());    }
-  }
-
-  @Test
-  public void testSpecialQuote() throws Exception {
-
-    String csv = "\001aaa\001,\001b\001\001bb\001,\001ccc\001";
-    ParseOptions po = new ParseOptions();
-    po.setOption(ParseOptions.OPTIONS_CSV_QUOTE,'\001');
-
-    try(
-      StringReader sr = new StringReader(csv);
-      CSVParser jp = new CSVParser(sr, po);
-    ) {
-
-      Iterator<Row> iterator = jp.iterator();
-      Row row = new Row(new Object[]{"aaa", "b\001bb", "ccc"});
-      Assert.assertEquals("Failed to detect 1st row!", true, iterator.hasNext());
-      Assert.assertEquals("Failed to match 1st row!", row, iterator.next());
-    }
-  }
-
-  @Test
-  public void testSpaceAsDelimiterAndQuoted() throws Exception {
-
-    String csv = "aaa \"b bb\" ccc\naaa2 bbb2 \"c cc2\"";
-    ParseOptions po = new ParseOptions();
-//    po.setOption(ParseOptions.OPTIONS_CSV_ESCAPE_CHAR,'\001');
-    po.setOption(ParseOptions.OPTIONS_CSV_DELIMITER,' ');
-
-    try(
-      StringReader sr = new StringReader(csv);
-      CSVParser jp = new CSVParser(sr, po);
-    ) {
-
-      Iterator<Row> iterator = jp.iterator();
-      Row row = new Row(new Object[]{"aaa", "b bb", "ccc"});
-      Assert.assertEquals("Failed to detect 1st row!", true, iterator.hasNext());
-      Assert.assertEquals("Failed to match 1st row!", row, iterator.next());
-
-      Row row2 = new Row(new Object[]{"aaa2", "bbb2", "c cc2"});
-      Assert.assertEquals("Failed to detect 1st row!", true, iterator.hasNext());
-      Assert.assertEquals("Failed to match 1st row!", row2, iterator.next());
-    }
-  }
-
-  @Test
-  public void testFailedDelimiterEscaped() throws Exception {
-
-    String csv = "aaa,b\\,bb,ccc";
-    ParseOptions po = new ParseOptions();
-    po.setOption(ParseOptions.OPTIONS_CSV_ESCAPE_CHAR,'\\');
-    po.setOption(ParseOptions.OPTIONS_CSV_DELIMITER,',');
-
-    try(
-      StringReader sr = new StringReader(csv);
-      CSVParser jp = new CSVParser(sr, po);
-    ) {
-
-      Iterator<Row> iterator = jp.iterator();
-      Row row = new Row(new Object[]{"aaa", "b,bb", "ccc"});
-      Assert.assertEquals("Failed to detect 1st row!", true, iterator.hasNext());
-      Assert.assertEquals("Failed to match 1st row!", row, iterator.next());
-    }
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/resources/upload/DataParserCSVTest.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/resources/upload/DataParserCSVTest.java b/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/resources/upload/DataParserCSVTest.java
deleted file mode 100644
index 7362c89..0000000
--- a/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/resources/upload/DataParserCSVTest.java
+++ /dev/null
@@ -1,326 +0,0 @@
-/**
- * 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
- * <p/>
- * http://www.apache.org/licenses/LICENSE-2.0
- * <p/>
- * 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.ambari.view.hive.resources.upload;
-
-import org.apache.ambari.view.hive.client.ColumnDescription;
-import org.apache.ambari.view.hive.client.ColumnDescriptionShort;
-import org.apache.ambari.view.hive.client.Row;
-import org.apache.ambari.view.hive.resources.uploads.ColumnDescriptionImpl;
-import org.apache.ambari.view.hive.resources.uploads.parsers.DataParser;
-import org.apache.ambari.view.hive.resources.uploads.parsers.ParseOptions;
-import org.apache.ambari.view.hive.resources.uploads.parsers.PreviewData;
-import org.junit.Assert;
-import org.junit.Test;
-
-import java.io.IOException;
-import java.io.StringReader;
-
-public class DataParserCSVTest {
-  @Test
-  public void testParsePreviewCSV() throws Exception {
-    String str = "1,a\n" +
-            "2,b\n" +
-            "3,c\n";
-
-
-    ParseOptions parseOptions = new ParseOptions();
-    parseOptions.setOption(ParseOptions.OPTIONS_FILE_TYPE, ParseOptions.InputFileType.CSV.toString());
-    parseOptions.setOption(ParseOptions.OPTIONS_HEADER, ParseOptions.HEADER.FIRST_RECORD.toString());
-
-
-    try (
-      StringReader sr = new StringReader(str);
-      DataParser dp = new DataParser(sr, parseOptions);
-    ){
-
-      PreviewData pd = dp.parsePreview();
-      Assert.assertNotNull(pd.getPreviewRows());
-      Assert.assertNotNull(pd.getHeader());
-      Assert.assertEquals(2, pd.getPreviewRows().size()); // now it will not return the first row which is header
-      Assert.assertEquals(2, pd.getHeader().size());
-      ColumnDescription[] cd = {new ColumnDescriptionImpl("1", ColumnDescriptionShort.DataTypes.INT.toString(), 0),
-              new ColumnDescriptionImpl("a", ColumnDescriptionShort.DataTypes.CHAR.toString(), 1)};
-
-      Object cols2[] = new Object[2];
-      cols2[0] = "2";
-      cols2[1] = "b";
-      Row row2 = new Row(cols2);
-
-      Object cols3[] = new Object[2];
-      cols3[0] = "3";
-      cols3[1] = "c";
-      Row row3 = new Row(cols3);
-
-      Row[] rows = { row2, row3};
-
-      Assert.assertArrayEquals("Header Not Correct.", cd, pd.getHeader().toArray());
-      Assert.assertArrayEquals("Rows Not Correct.", rows, pd.getPreviewRows().toArray());
-    }
-  }
-
-  /**
-   * even if in one of the preview rows, datatype is not correct, then it should be assigned that datatype.
-   * but if first row is header then first row should not be acconted for detecting datatype
-   * @throws IOException
-   */
-  @Test
-  public void testParsePreviewDataTypeDetectionCSV() throws Exception {
-    String str = "1,a,10,k\n" +
-      "2,b,6,8\n" +
-      "2.2,b,7,9\n" +
-      "2,b,abc,1\n" +
-      "2,b,9,3\n" +
-      "2,b,8,5\n" +
-      "2,b,7,3\n" +
-      "2,b,6,3\n" +
-      "3,c,c,3\n";
-
-
-    ParseOptions parseOptions = new ParseOptions();
-    parseOptions.setOption(ParseOptions.OPTIONS_FILE_TYPE, ParseOptions.InputFileType.CSV.toString());
-    parseOptions.setOption(ParseOptions.OPTIONS_HEADER, ParseOptions.HEADER.FIRST_RECORD.toString());
-
-    try(StringReader sr = new StringReader(str);
-      DataParser dp= new DataParser(sr, parseOptions)) {
-
-      PreviewData pd = dp.parsePreview();
-      Assert.assertNotNull(pd.getHeader());
-      Assert.assertEquals(4, pd.getHeader().size());
-      ColumnDescription[] cd = {
-        // as row 3 contains 2.2
-        new ColumnDescriptionImpl("1", ColumnDescriptionShort.DataTypes.DOUBLE.toString(), 0),
-        // as all are chars
-        new ColumnDescriptionImpl("a", ColumnDescriptionShort.DataTypes.CHAR.toString(), 1),
-        // as row 4 contains abc
-        new ColumnDescriptionImpl("10", ColumnDescriptionShort.DataTypes.STRING.toString(), 2),
-        // although row 1 contains k but it is in header and not counted in detecting datatype
-        new ColumnDescriptionImpl("k", ColumnDescriptionShort.DataTypes.INT.toString(), 3)};
-
-      Assert.assertArrayEquals("Header Not Correct.", cd, pd.getHeader().toArray());
-    }
-  }
-
-  /**
-   * even if in one of the preview rows, datatype is not correct, then it should be assigned that datatype.
-   * but if first row is header then first row should not be acconted for detecting datatype
-   * @throws IOException
-   */
-  @Test
-  public void testParsePreviewDataTypeDetection2CSV() throws Exception {
-    String str = "1,a,10,k\n" +
-      "2,b,6,p\n" +
-      "2.2,b,7,9\n" +
-      "2,b,2.2,1\n" +
-      "2,b,9,3\n" +
-      "2,b,8,5\n" +
-      "2,b,7,3\n" +
-      "2,b,6,3\n" +
-      "3,c,c,3\n";
-
-
-    ParseOptions parseOptions = new ParseOptions();
-    parseOptions.setOption(ParseOptions.OPTIONS_FILE_TYPE, ParseOptions.InputFileType.CSV.toString());
-    parseOptions.setOption(ParseOptions.OPTIONS_HEADER, ParseOptions.HEADER.FIRST_RECORD.toString());
-
-
-    try(StringReader sr = new StringReader(str);
-        DataParser dp = new DataParser(sr, parseOptions)) {
-
-
-      PreviewData pd = dp.parsePreview();
-      Assert.assertNotNull(pd.getHeader());
-      Assert.assertEquals(4, pd.getHeader().size());
-      ColumnDescription[] cd = {
-        // as row 3 contains 2.2
-        new ColumnDescriptionImpl("1", ColumnDescriptionShort.DataTypes.DOUBLE.toString(), 0),
-        // as all are chars
-        new ColumnDescriptionImpl("a", ColumnDescriptionShort.DataTypes.CHAR.toString(), 1),
-        // some are int, char and some double .. nothing other than 'string' satisfies all the rows
-        new ColumnDescriptionImpl("10", ColumnDescriptionShort.DataTypes.STRING.toString(), 2),
-        // although row 1 contains k but it is in header and not counted in detecting datatype
-        // but row 2 also has a char p which will be acconted for datatype detection
-        new ColumnDescriptionImpl("k", ColumnDescriptionShort.DataTypes.CHAR.toString(), 3)};
-
-      Assert.assertArrayEquals("Header Not Correct.", cd, pd.getHeader().toArray());
-    }
-  }
-
-  /**
-   * One row csv will give default column names and 1st row in preview if HEADER.PROVIDED_BY_USER is selected
-   * @throws IOException
-   */
-  @Test
-  public void testParsePreview1RowCSV() throws Exception {
-    String str = "1,a\n" ;
-
-    ParseOptions parseOptions = new ParseOptions();
-    parseOptions.setOption(ParseOptions.OPTIONS_FILE_TYPE, ParseOptions.InputFileType.CSV.toString());
-    parseOptions.setOption(ParseOptions.OPTIONS_HEADER, ParseOptions.HEADER.PROVIDED_BY_USER.toString());
-
-    try(
-      StringReader sr = new StringReader(str);
-      DataParser dp = new DataParser(sr, parseOptions)
-    ) {
-
-
-      PreviewData pd = dp.parsePreview();
-      Assert.assertNotNull(pd.getPreviewRows());
-      Assert.assertNotNull(pd.getHeader());
-      Assert.assertEquals(1, pd.getPreviewRows().size());
-      Assert.assertEquals(2, pd.getHeader().size());
-      ColumnDescription[] cd = {new ColumnDescriptionImpl("column1", ColumnDescriptionShort.DataTypes.INT.toString(), 0),
-        new ColumnDescriptionImpl("column2", ColumnDescriptionShort.DataTypes.CHAR.toString(), 1)};
-
-      Object cols1[] = new Object[2];
-      cols1[0] = "1";
-      cols1[1] = "a";
-      Row row1 = new Row(cols1);
-
-      Row[] rows = {row1};
-
-      Assert.assertArrayEquals("Header Not Correct.", cd, pd.getHeader().toArray());
-      Assert.assertArrayEquals("Rows Not Correct.", rows, pd.getPreviewRows().toArray());
-    }
-  }
-
-  /**
-   * One row csv will throw exception in preview if HEADER.FIRST_RECORD is selected.
-   * @throws IOException
-   */
-  @Test(expected = java.util.NoSuchElementException.class)
-  public void testParsePreview1RowCSVFirstRowHeader() throws Exception {
-    String str = "col1,col2\n" ;
-
-
-    ParseOptions parseOptions = new ParseOptions();
-    parseOptions.setOption(ParseOptions.OPTIONS_FILE_TYPE, ParseOptions.InputFileType.CSV.toString());
-    parseOptions.setOption(ParseOptions.OPTIONS_HEADER, ParseOptions.HEADER.FIRST_RECORD.toString());
-
-
-    try(
-      StringReader sr = new StringReader(str);
-      DataParser dp = new DataParser(sr, parseOptions)
-    ) {
-
-
-      PreviewData pd = dp.parsePreview();
-    }
-  }
-
-  /**
-   * more number of columns in a row => igore the extra columns. Number of columns is decided by the first row.
-   * If other row contains more columns then those columns will be ignored
-   * Here first row has 2 columns and second row has 3 columns so the value 'x' is ignored
-   * @throws IOException
-   */
-  @Test
-  public void testParsePreviewCSVMoreColumns() throws Exception {
-    String str = "1,a\n" +
-            "2,b,x\n" +  // contains 3 cols, more number of columns
-            "3,c\n";
-
-    ParseOptions parseOptions = new ParseOptions();
-    parseOptions.setOption(ParseOptions.OPTIONS_FILE_TYPE, ParseOptions.InputFileType.CSV.toString());
-    parseOptions.setOption(ParseOptions.OPTIONS_HEADER, ParseOptions.HEADER.FIRST_RECORD.toString());
-
-
-    try(
-        StringReader sr = new StringReader(str);
-        DataParser dp = new DataParser(sr, parseOptions)
-    ) {
-
-      PreviewData pd = dp.parsePreview();
-      Row row = new Row(new Object[]{"2","b"});
-
-      Assert.assertArrayEquals("Additional columns not properly handled.", row.getRow(),pd.getPreviewRows().get(0).getRow());
-    }
-  }
-
-  /**
-   * less number of columns => treat missing values as null. Number of columns is decided by the first row of the table
-   * if other rows has less number of columns then it treats other columns as null
-   * @throws IOException
-   */
-  @Test
-  public void testParsePreviewCSVLessColumns() throws Exception {
-    String str = "1,a\n" +
-            "2\n" +  // contains 1 col, less number of columns
-            "3,c\n";
-
-    ParseOptions parseOptions = new ParseOptions();
-    parseOptions.setOption(ParseOptions.OPTIONS_FILE_TYPE, ParseOptions.InputFileType.CSV.toString());
-
-    try(
-      StringReader sr = new StringReader(str);
-      DataParser dp =  new DataParser(sr, parseOptions)
-      ) {
-
-      PreviewData pd = dp.parsePreview();
-      Assert.assertEquals("Missing value not detected as null.",pd.getPreviewRows().get(1).getRow()[1],null);
-    }
-  }
-
-  /**
-   * empty values are treated as empty string
-   * @throws IOException
-   */
-  @Test
-  public void testEmptyColumn() throws Exception {
-    String str = "1,a,x\n" +
-            "2,,y\n" +  // contains 1 col, less number of columns
-            "3,c,z\n";
-    ParseOptions parseOptions = new ParseOptions();
-    parseOptions.setOption(ParseOptions.OPTIONS_FILE_TYPE, ParseOptions.InputFileType.CSV.toString());
-    parseOptions.setOption(ParseOptions.OPTIONS_HEADER, ParseOptions.HEADER.FIRST_RECORD.toString());
-
-    try(
-      StringReader sr = new StringReader(str);
-      DataParser dp = new DataParser(sr, parseOptions)
-    ) {
-
-      PreviewData pd = dp.parsePreview();
-      Assert.assertEquals("Empty column not detected properly.",pd.getPreviewRows().get(0).getRow()[1],"");
-    }
-  }
-
-  /**
-   * empty values are treated as empty string
-   * @throws IOException
-   */
-  @Test
-  public void testLastEmptyColumn() throws Exception {
-    String str = "1,a,x\n" +
-            "2,,\n" +  // contains 1 col, less number of columns
-            "3,c,z\n";
-
-    ParseOptions parseOptions = new ParseOptions();
-    parseOptions.setOption(ParseOptions.OPTIONS_FILE_TYPE, ParseOptions.InputFileType.CSV.toString());
-    parseOptions.setOption(ParseOptions.OPTIONS_HEADER, ParseOptions.HEADER.FIRST_RECORD.toString());
-
-    try(
-      StringReader sr = new StringReader(str);
-      DataParser dp = new DataParser(sr, parseOptions)
-    ) {
-
-      PreviewData pd = dp.parsePreview();
-      Assert.assertEquals("Empty column not detected properly.",pd.getPreviewRows().get(0).getRow()[1],"");
-      Assert.assertEquals("Empty column not detected properly.",pd.getPreviewRows().get(0).getRow()[2],"");
-    }
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/resources/upload/DataParserJSONTest.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/resources/upload/DataParserJSONTest.java b/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/resources/upload/DataParserJSONTest.java
deleted file mode 100644
index 2ee92df..0000000
--- a/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/resources/upload/DataParserJSONTest.java
+++ /dev/null
@@ -1,263 +0,0 @@
-/**
- * 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
- * <p/>
- * http://www.apache.org/licenses/LICENSE-2.0
- * <p/>
- * 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.ambari.view.hive.resources.upload;
-
-import org.apache.ambari.view.hive.client.ColumnDescription;
-import org.apache.ambari.view.hive.client.ColumnDescriptionShort;
-import org.apache.ambari.view.hive.client.Row;
-import org.apache.ambari.view.hive.resources.uploads.ColumnDescriptionImpl;
-import org.apache.ambari.view.hive.resources.uploads.parsers.DataParser;
-import org.apache.ambari.view.hive.resources.uploads.parsers.ParseOptions;
-import org.apache.ambari.view.hive.resources.uploads.parsers.PreviewData;
-import org.junit.Assert;
-import org.junit.Test;
-
-import java.io.IOException;
-import java.io.StringReader;
-
-public class DataParserJSONTest {
-
-  @Test
-  public void testParsePreviewJSON() throws Exception {
-    String str = "[ {\"col1\" : \"a\", \n\"col2\": \"abcd\" ,\"col3\": \"abcd\" ,\"col4\": \"abcd\" ,\"col5\": \"abcd\" ,\"col6\": \"abcd\" ,\"col7\": \"abcd\" ,\"col8\": \"abcd\" ,\"col9\": \"abcd\" ,\"col10\": \"abcd\" ,\"col11\": \"abcd\" ,\"col12\" : \"abcd\" ,\"col13\" : \"abcd\" ,\"col14\" : \"4.4\" },"
-            + "{\"col1\": \"b\", \n\"col2\": \"abcd\" ,\"col3\": \"abcd\" ,\"col4\": \"abcd\" ,\"col5\": \"abcd\" ,\"col6\": \"abcd\" ,\"col7\": \"abcd\" ,\"col8\": \"abcd\" ,\"col9\": \"abcd\" ,\"col10\": \"abcd\" ,\"col11\": \"abcd\" ,\"col12\" : \"abcd\" ,\"col13\" : \"abcd\" ,\"col14\" : \"5.4\" },"
-            + "{\"col1\": \"c\", \n\"col2\": \"abcd\" ,\"col3\": \"abcd\" ,\"col4\": \"abcd\" ,\"col5\": \"abcd\" ,\"col6\": \"abcd\" ,\"col7\": \"abcd\" ,\"col8\": \"abcd\" ,\"col9\": \"abcd\" ,\"col10\": \"abcd\" ,\"col11\": \"abcd\" ,\"col12\" : \"abcd\" ,\"col13\" : \"abcd\" ,\"col14\" : \"6.4\" },"
-            + "{\"col1\": \"d\", \n\"col2\": \"abcd\" ,\"col3\": \"abcd\" ,\"col4\": \"abcd\" ,\"col5\": \"abcd\" ,\"col6\": \"abcd\" ,\"col7\": \"abcd\" ,\"col8\": \"abcd\" ,\"col9\": \"abcd\" ,\"col10\": \"abcd\" ,\"col11\": \"abcd\" ,\"col12\" : \"abcd\" ,\"col13\" : \"abcd\" ,\"col14\" : \"7.4\" },"
-            + "{\"col1\": \"e\", \n\"col2\": \"abcd\" ,\"col3\": \"abcd\" ,\"col4\": \"abcd\" ,\"col5\": \"abcd\" ,\"col6\": \"abcd\" ,\"col7\": \"abcd\" ,\"col8\": \"abcd\" ,\"col9\": \"abcd\" ,\"col10\": \"abcd\" ,\"col11\": \"abcd\" ,\"col12\" : \"abcd\" ,\"col13\" : \"abcd\" ,\"col14\" : \"8.4\" },"
-            + "{\"col1\": \"f\", \n\"col2\": \"abcd\" ,\"col3\": \"abcd\" ,\"col4\": \"abcd\" ,\"col5\": \"abcd\" ,\"col6\": \"abcd\" ,\"col7\": \"abcd\" ,\"col8\": \"abcd\" ,\"col9\": \"abcd\" ,\"col10\": \"abcd\" ,\"col11\": \"abcd\" ,\"col12\" : \"abcd\" ,\"col13\" : \"abcd\" ,\"col14\" : \"9.4\" },"
-            + "{\"col1\": \"g\", \n\"col2\": \"abcd\" ,\"col3\": \"abcd\" ,\"col4\": \"abcd\" ,\"col5\": \"abcd\" ,\"col6\": \"abcd\" ,\"col7\": \"abcd\" ,\"col8\": \"abcd\" ,\"col9\": \"abcd\" ,\"col10\": \"abcd\" ,\"col11\": \"abcd\" ,\"col12\" : \"abcd\" ,\"col13\" : \"abcd\" ,\"col14\" : \"10.4\" },"
-            + "{\"col1\": \"h\", \n\"col2\": \"abcd\" ,\"col3\": \"abcd\" ,\"col4\": \"abcd\" ,\"col5\": \"abcd\" ,\"col6\": \"abcd\" ,\"col7\": \"abcd\" ,\"col8\": \"abcd\" ,\"col9\": \"abcd\" ,\"col10\": \"abcd\" ,\"col11\": \"abcd\" ,\"col12\" : \"abcd\" ,\"col13\" : \"abcd\" ,\"col14\" : \"11.4\" },"
-            + "{\"col1\": \"i\", \n\"col2\": \"abcd\" ,\"col3\": \"abcd\" ,\"col4\": \"abcd\" ,\"col5\": \"abcd\" ,\"col6\": \"abcd\" ,\"col7\": \"abcd\" ,\"col8\": \"abcd\" ,\"col9\": \"abcd\" ,\"col10\": \"abcd\" ,\"col11\": \"abcd\" ,\"col12\" : \"abcd\" ,\"col13\" : \"abcd\" ,\"col14\" : \"4\" },"
-            + "{\"col1\": \"j\", \n\"col2\": \"abcd\" ,\"col3\": \"abcd\" ,\"col4\": \"abcd\" ,\"col5\": \"abcd\" ,\"col6\": \"abcd\" ,\"col7\": \"abcd\" ,\"col8\": \"abcd\" ,\"col9\": \"abcd\" ,\"col10\": \"abcd\" ,\"col11\": \"abcd\" ,\"col12\" : \"abcd\" ,\"col13\" : \"abcd\" ,\"col14\" : \"5\" },"
-            + "{\"col1\": \"k\", \n\"col2\": \"abcd\" ,\"col3\": \"abcd\" ,\"col4\": \"abcd\" ,\"col5\": \"abcd\" ,\"col6\": \"abcd\" ,\"col7\": \"abcd\" ,\"col8\": \"abcd\" ,\"col9\": \"abcd\" ,\"col10\": \"abcd\" ,\"col11\": \"abcd\" ,\"col12\" : \"abcd\" ,\"col13\" : \"abcd\" ,\"col14\" : \"6\" },"
-            + "{\"col1\": \"l\", \n\"col2\": \"abcd\" ,\"col3\": \"abcd\" ,\"col4\": \"abcd\" ,\"col5\": \"abcd\" ,\"col6\": \"abcd\" ,\"col7\": \"abcd\" ,\"col8\": \"abcd\" ,\"col9\": \"abcd\" ,\"col10\": \"abcd\" ,\"col11\": \"abcd\" ,\"col12\" : \"abcd\" ,\"col13\" : \"abcd\" ,\"col14\" : \"7\" },"
-            + "{\"col1\": \"m\", \n\"col2\": \"abcd\" ,\"col3\": \"abcd\" ,\"col4\": \"abcd\" ,\"col5\": \"abcd\" ,\"col6\": \"abcd\" ,\"col7\": \"abcd\" ,\"col8\": \"abcd\" ,\"col9\": \"abcd\" ,\"col10\": \"abcd\" ,\"col11\": \"abcd\" ,\"col12\" : \"abcd\" ,\"col13\" : \"abcd\" ,\"col14\" : \"24.4\" },"
-            + "{\"col1\": \"n\", \n\"col2\": \"abcd\" ,\"col3\": \"abcd\" ,\"col4\": \"abcd\" ,\"col5\": \"abcd\" ,\"col6\": \"abcd\" ,\"col7\": \"abcd\" ,\"col8\": \"abcd\" ,\"col9\": \"abcd\" ,\"col10\": \"abcd\" ,\"col11\": \"abcd\" ,\"col12\" : \"abcd\" ,\"col13\" : \"abcd\" ,\"col14\" : \"14.4\" },"
-            + "{\"col1\": \"o\", \n\"col2\": \"abcd\" ,\"col3\": \"abcd\" ,\"col4\": \"abcd\" ,\"col5\": \"abcd\" ,\"col6\": \"abcd\" ,\"col7\": \"abcd\" ,\"col8\": \"abcd\" ,\"col9\": \"abcd\" ,\"col10\": \"abcd\" ,\"col11\": \"abcd\" ,\"col12\" : \"abcd\" ,\"col13\" : \"abcd\" ,\"col14\" : \"34.4\" },"
-            + "{\"col1\": \"p\", \n\"col2\": \"abcd\" ,\"col3\": \"abcd\" ,\"col4\": \"abcd\" ,\"col5\": \"abcd\" ,\"col6\": \"abcd\" ,\"col7\": \"abcd\" ,\"col8\": \"abcd\" ,\"col9\": \"abcd\" ,\"col10\": \"abcd\" ,\"col11\": \"abcd\" ,\"col12\" : \"abcd\" ,\"col13\" : \"abcd\" ,\"col14\" : \"44.4\" },"
-            + "{\"col1\": \"q\", \n\"col2\": \"abcd\" ,\"col3\": \"abcd\" ,\"col4\": \"abcd\" ,\"col5\": \"abcd\" ,\"col6\": \"abcd\" ,\"col7\": \"abcd\" ,\"col8\": \"abcd\" ,\"col9\": \"abcd\" ,\"col10\": \"abcd\" ,\"col11\": \"abcd\" ,\"col12\" : \"abcd\" ,\"col13\" : \"abcd\" ,\"col14\" : \"54.4\" },"
-            + "{\"col1\": \"r\", \n\"col2\": \"abcd\" ,\"col3\": \"abcd\" ,\"col4\": \"abcd\" ,\"col5\": \"abcd\" ,\"col6\": \"abcd\" ,\"col7\": \"abcd\" ,\"col8\": \"abcd\" ,\"col9\": \"abcd\" ,\"col10\": \"abcd\" ,\"col11\": \"abcd\" ,\"col12\" : \"abcd\" ,\"col13\" : \"abcd\" ,\"col14\" : \"64.4\" }"
-            + "]";
-
-
-    ParseOptions parseOptions = new ParseOptions();
-    parseOptions.setOption(ParseOptions.OPTIONS_FILE_TYPE, ParseOptions.InputFileType.JSON.toString());
-    parseOptions.setOption(ParseOptions.OPTIONS_HEADER, ParseOptions.HEADER.EMBEDDED.toString());
-    parseOptions.setOption(ParseOptions.OPTIONS_NUMBER_OF_PREVIEW_ROWS, 7);
-
-    try(
-      StringReader sr = new StringReader(str);
-      DataParser dp =  new DataParser(sr, parseOptions)
-    ) {
-
-      PreviewData pd = dp.parsePreview();
-      Assert.assertNotNull(pd.getPreviewRows());
-      Assert.assertNotNull(pd.getHeader());
-      Assert.assertEquals(7, pd.getPreviewRows().size()); // header row + preview rows
-      Assert.assertEquals(14, pd.getHeader().size());
-      ColumnDescription[] cd = {new ColumnDescriptionImpl("col1", ColumnDescriptionShort.DataTypes.CHAR.toString(), 0),
-              new ColumnDescriptionImpl("col2", ColumnDescriptionShort.DataTypes.STRING.toString(), 1),
-              new ColumnDescriptionImpl("col3", ColumnDescriptionShort.DataTypes.STRING.toString(), 2),
-              new ColumnDescriptionImpl("col4", ColumnDescriptionShort.DataTypes.STRING.toString(), 3),
-              new ColumnDescriptionImpl("col5", ColumnDescriptionShort.DataTypes.STRING.toString(), 4),
-              new ColumnDescriptionImpl("col6", ColumnDescriptionShort.DataTypes.STRING.toString(), 5),
-              new ColumnDescriptionImpl("col7", ColumnDescriptionShort.DataTypes.STRING.toString(), 6),
-              new ColumnDescriptionImpl("col8", ColumnDescriptionShort.DataTypes.STRING.toString(), 7),
-              new ColumnDescriptionImpl("col9", ColumnDescriptionShort.DataTypes.STRING.toString(), 8),
-              new ColumnDescriptionImpl("col10", ColumnDescriptionShort.DataTypes.STRING.toString(), 9),
-              new ColumnDescriptionImpl("col11", ColumnDescriptionShort.DataTypes.STRING.toString(), 10),
-              new ColumnDescriptionImpl("col12", ColumnDescriptionShort.DataTypes.STRING.toString(), 11),
-              new ColumnDescriptionImpl("col13", ColumnDescriptionShort.DataTypes.STRING.toString(), 12),
-              new ColumnDescriptionImpl("col14", ColumnDescriptionShort.DataTypes.DOUBLE.toString(), 13)};
-
-      Row row2 = new Row(new Object[]{"a", "abcd", "abcd", "abcd", "abcd", "abcd", "abcd", "abcd", "abcd", "abcd", "abcd", "abcd", "abcd", "4.4"});
-      Row row3 = new Row(new Object[]{"b", "abcd", "abcd", "abcd", "abcd", "abcd", "abcd", "abcd", "abcd", "abcd", "abcd", "abcd", "abcd", "5.4"});
-      Row row4 = new Row(new Object[]{"c", "abcd", "abcd", "abcd", "abcd", "abcd", "abcd", "abcd", "abcd", "abcd", "abcd", "abcd", "abcd", "6.4"});
-      Row row5 = new Row(new Object[]{"d", "abcd", "abcd", "abcd", "abcd", "abcd", "abcd", "abcd", "abcd", "abcd", "abcd", "abcd", "abcd", "7.4"});
-      Row row6 = new Row(new Object[]{"e", "abcd", "abcd", "abcd", "abcd", "abcd", "abcd", "abcd", "abcd", "abcd", "abcd", "abcd", "abcd", "8.4"});
-      Row row7 = new Row(new Object[]{"f", "abcd", "abcd", "abcd", "abcd", "abcd", "abcd", "abcd", "abcd", "abcd", "abcd", "abcd", "abcd", "9.4"});
-      Row row8 = new Row(new Object[]{"g", "abcd", "abcd", "abcd", "abcd", "abcd", "abcd", "abcd", "abcd", "abcd", "abcd", "abcd", "abcd", "10.4"});
-
-      Row[] rows = { row2, row3, row4, row5, row6, row7, row8};
-
-      Assert.assertArrayEquals("Header Not Correct.", cd, pd.getHeader().toArray());
-      Assert.assertArrayEquals("Rows Not Correct.", rows, pd.getPreviewRows().toArray());
-    }
-  }
-
-  /**
-   * additional columns in rows of JSON are ignored.
-   *
-   * @throws IOException
-   */
-  @Test
-  public void testParsePreviewCSVMoreColumns() throws Exception {
-    String str = "[ {\"col1\" : \"a\", \n\"col2\": \"abcd\" ,\"col3\": \"abcd\" ,\"col4\": \"abcd\" ,\"col5\": \"abcd\" ,\"col6\": \"abcd\" ,\"col7\": \"abcd\" ,\"col8\": \"abcd\" ,\"col9\": \"abcd\" ,\"col10\": \"abcd\" ,\"col11\": \"abcd\" ,\"col12\" : \"abcd\" ,\"col13\" : \"abcd\" ,\"col14\" : \"4.4\" },"
-            + "{\"col1\": \"b\", \n\"col2\": \"abcd\" ,\"col3\": \"abcd\" ,\"col4\": \"abcd\" ,\"col5\": \"abcd\" ,\"col6\": \"abcd\" ,\"col7\": \"abcd\" ,\"col8\": \"abcd\" ,\"col9\": \"abcd\" ,\"col10\": \"abcd\" ,\"col11\": \"abcd\" ,\"col12\" : \"abcd\" ,\"col13\" : \"abcd\" , \"col14\" : \"43.4\" ,\"col15\" : \"asafsfa\" },"
-            + "{\"col1\": \"c\", \n\"col2\": \"abcd\" ,\"col3\": \"abcd\" ,\"col4\": \"abcd\" ,\"col5\": \"abcd\" ,\"col6\": \"abcd\" ,\"col7\": \"abcd\" ,\"col8\": \"abcd\" ,\"col9\": \"abcd\" ,\"col10\": \"abcd\" ,\"col11\": \"abcd\" ,\"col12\" : \"abcd\" ,\"col13\" : \"abcd\" ,\"col14\" : \"6.4\" },"
-            + "{\"col1\": \"d\", \n\"col2\": \"abcd\" ,\"col3\": \"abcd\" ,\"col4\": \"abcd\" ,\"col5\": \"abcd\" ,\"col6\": \"abcd\" ,\"col7\": \"abcd\" ,\"col8\": \"abcd\" ,\"col9\": \"abcd\" ,\"col10\": \"abcd\" ,\"col11\": \"abcd\" ,\"col12\" : \"abcd\" ,\"col13\" : \"abcd\" ,\"col14\" : \"7.4\" }"
-            + "]";
-
-
-    ParseOptions parseOptions = new ParseOptions();
-    parseOptions.setOption(ParseOptions.OPTIONS_FILE_TYPE, ParseOptions.InputFileType.JSON.toString());
-
-    try(
-      StringReader sr = new StringReader(str);
-      DataParser dp =  new DataParser(sr, parseOptions)
-    ) {
-
-      PreviewData pd = dp.parsePreview();
-
-      Row row2 = new Row(new Object[]{"b", "abcd", "abcd", "abcd", "abcd", "abcd", "abcd", "abcd", "abcd", "abcd", "abcd", "abcd", "abcd", "43.4"});
-      Assert.assertArrayEquals("More number of columns do not give correct result.", row2.getRow(), pd.getPreviewRows().get(1).getRow());
-    }
-  }
-
-  /**
-   * less columns in json makes them null.
-   *
-   * @throws IOException
-   */
-  @Test
-  public void testParsePreviewCSVLessColumns() throws Exception {
-    String str = "[ " +
-            "{\"col1\" : \"a\", \n\"col2\": \"abcd\" ,\"col3\": \"abcd\" ,\"col4\": \"abcd\" ,\"col5\": \"abcd\" ,\"col6\": \"abcd\" ,\"col7\": \"abcd\" ,\"col8\": \"abcd\" ,\"col9\": \"abcd\" ,\"col10\": \"abcd\" ,\"col11\": \"abcd\" ,\"col12\" : \"abcd\" ,\"col13\" : \"abcd\" ,\"col14\" : \"4.4\" },"
-            + "{\"col1\": \"b\", \n\"col2\": \"abcd\" ,\"col3\": \"abcd\" ,\"col4\": \"abcd\" ,\"col5\": \"abcd\" ,\"col6\": \"abcd\" ,\"col7\": \"abcd\" ,\"col8\": \"abcd\" ,\"col9\": \"abcd\" ,\"col10\": \"abcd\" ,\"col11\": \"abcd\" ,\"col12\" : \"abcd\" ,\"col13\" : \"abcd\"  },"
-            + "{\"col1\": \"c\", \n\"col2\": \"abcd\" ,\"col3\": \"abcd\" ,\"col4\": \"abcd\" ,\"col5\": \"abcd\" ,\"col6\": \"abcd\" ,\"col7\": \"abcd\" ,\"col8\": \"abcd\" ,\"col9\": \"abcd\" ,\"col10\": \"abcd\" ,\"col11\": \"abcd\" ,\"col12\" : \"abcd\" ,\"col13\" : \"abcd\" ,\"col14\" : \"6.4\" },"
-            + "{\"col1\": \"d\", \n\"col2\": \"abcd\" ,\"col3\": \"abcd\" ,\"col4\": \"abcd\" ,\"col5\": \"abcd\" ,\"col6\": \"abcd\" ,\"col7\": \"abcd\" ,\"col8\": \"abcd\" ,\"col9\": \"abcd\" ,\"col10\": \"abcd\" ,\"col11\": \"abcd\" ,\"col12\" : \"abcd\" ,\"col13\" : \"abcd\" ,\"col14\" : \"7.4\" }"
-            + "]";
-
-    ParseOptions parseOptions = new ParseOptions();
-    parseOptions.setOption(ParseOptions.OPTIONS_FILE_TYPE, ParseOptions.InputFileType.JSON.toString());
-    parseOptions.setOption(ParseOptions.OPTIONS_HEADER, ParseOptions.HEADER.EMBEDDED.toString());
-
-    try(
-      StringReader sr = new StringReader(str);
-      DataParser dp =  new DataParser(sr, parseOptions)
-    ) {
-      PreviewData pd = dp.parsePreview();
-
-      Assert.assertNull(pd.getPreviewRows().get(1).getRow()[13]);
-    }
-  }
-
-  /**
-   * illegal json format gives error
-   *
-   * @throws IOException
-   */
-  @Test(expected = IllegalArgumentException.class)
-  public void testWrongJsonFormat() throws Exception {
-    String str = "[ " +
-            "{\"col1\" : \"a\", \n\"col2\": \"abcd\" },"
-            + "{\"col1\": \"b\", \n\"col2\": \"abcd\" },"
-            + "{\"col1\": \"c\", \n\"col2\": \"abcd\"  },"
-            + "{\"col1\": \"d\",, \n\"col2\": \"abcd\"  }"       // extra comma in this line
-            + "]";
-    ParseOptions parseOptions = new ParseOptions();
-    parseOptions.setOption(ParseOptions.OPTIONS_FILE_TYPE, ParseOptions.InputFileType.JSON.toString());
-    parseOptions.setOption(ParseOptions.OPTIONS_HEADER, ParseOptions.HEADER.EMBEDDED.toString());
-
-    try(
-      StringReader sr = new StringReader(str);
-      DataParser dp = new DataParser(sr, parseOptions);
-    ) {
-      PreviewData pd = dp.parsePreview();
-    }
-  }
-
-  /**
-   * One row JSON will give embedde column names and 1st row in preview if HEADER.EMBEDDED is selected
-   * @throws IOException
-   */
-  @Test
-  public void testParsePreview1RowJSON() throws Exception {
-    String str = "[ "
-      + "{\"col1\": \"d\", \n\"col2\": \"abcd\"  }"       // extra comma in this line
-      + "]";
-
-    ParseOptions parseOptions = new ParseOptions();
-    parseOptions.setOption(ParseOptions.OPTIONS_FILE_TYPE, ParseOptions.InputFileType.JSON.toString());
-    parseOptions.setOption(ParseOptions.OPTIONS_HEADER, ParseOptions.HEADER.EMBEDDED.toString());
-
-    try(
-      StringReader sr = new StringReader(str);
-      DataParser dp = new DataParser(sr, parseOptions);
-    ) {
-
-      PreviewData pd = dp.parsePreview();
-      Assert.assertNotNull(pd.getPreviewRows());
-      Assert.assertNotNull(pd.getHeader());
-      Assert.assertEquals(1, pd.getPreviewRows().size());
-      Assert.assertEquals(2, pd.getHeader().size());
-      ColumnDescription[] cd = {new ColumnDescriptionImpl("col1", ColumnDescriptionShort.DataTypes.CHAR.toString(), 0),
-        new ColumnDescriptionImpl("col2", ColumnDescriptionShort.DataTypes.STRING.toString(), 1)};
-
-      Object cols1[] = new Object[2];
-      cols1[0] = "d";
-      cols1[1] = "abcd";
-      Row row1 = new Row(cols1);
-
-      Row[] rows = {row1};
-
-      Assert.assertArrayEquals("Header Not Correct.", cd, pd.getHeader().toArray());
-      Assert.assertArrayEquals("Rows Not Correct.", rows, pd.getPreviewRows().toArray());
-    }
-  }
-
-  /**
-   * One row JSON will give default column names and 1st row in preview if HEADER.PROVIDED_BY_USER is selected
-   * @throws IOException
-   */
-  @Test
-  public void testParsePreview1RowJSONHeaderProvided() throws Exception {
-    String str = "[ "
-      + "{\"col1\": \"d\", \n\"col2\": \"abcd\"  }"       // extra comma in this line
-      + "]";
-
-    ParseOptions parseOptions = new ParseOptions();
-    parseOptions.setOption(ParseOptions.OPTIONS_FILE_TYPE, ParseOptions.InputFileType.JSON.toString());
-    parseOptions.setOption(ParseOptions.OPTIONS_HEADER, ParseOptions.HEADER.PROVIDED_BY_USER.toString());
-
-    try(
-      StringReader sr = new StringReader(str);
-      DataParser dp = new DataParser(sr, parseOptions);
-    ) {
-
-      PreviewData pd = dp.parsePreview();
-      Assert.assertNotNull(pd.getPreviewRows());
-      Assert.assertNotNull(pd.getHeader());
-      Assert.assertEquals(1, pd.getPreviewRows().size());
-      Assert.assertEquals(2, pd.getHeader().size());
-      ColumnDescription[] cd = {new ColumnDescriptionImpl("column1", ColumnDescriptionShort.DataTypes.CHAR.toString(), 0),
-        new ColumnDescriptionImpl("column2", ColumnDescriptionShort.DataTypes.STRING.toString(), 1)};
-
-      Object cols1[] = new Object[2];
-      cols1[0] = "d";
-      cols1[1] = "abcd";
-      Row row1 = new Row(cols1);
-
-      Row[] rows = {row1};
-
-      Assert.assertArrayEquals("Header Not Correct.", cd, pd.getHeader().toArray());
-      Assert.assertArrayEquals("Rows Not Correct.", rows, pd.getPreviewRows().toArray());
-    }
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/resources/upload/DataParserXMLTest.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/resources/upload/DataParserXMLTest.java b/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/resources/upload/DataParserXMLTest.java
deleted file mode 100644
index 25be565..0000000
--- a/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/resources/upload/DataParserXMLTest.java
+++ /dev/null
@@ -1,295 +0,0 @@
-/**
- * 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
- * <p/>
- * http://www.apache.org/licenses/LICENSE-2.0
- * <p/>
- * 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.ambari.view.hive.resources.upload;
-
-import org.apache.ambari.view.hive.client.ColumnDescription;
-import org.apache.ambari.view.hive.client.ColumnDescriptionShort;
-import org.apache.ambari.view.hive.client.Row;
-import org.apache.ambari.view.hive.resources.uploads.ColumnDescriptionImpl;
-import org.apache.ambari.view.hive.resources.uploads.parsers.DataParser;
-import org.apache.ambari.view.hive.resources.uploads.parsers.ParseOptions;
-import org.apache.ambari.view.hive.resources.uploads.parsers.PreviewData;
-import org.junit.Assert;
-import org.junit.Test;
-
-import java.io.IOException;
-import java.io.StringReader;
-
-public class DataParserXMLTest {
-
-  @Test
-  public void testParsePreviewXML() throws Exception {
-    String str = "<table>" +
-            "<row>" +
-            "<col name=\"col1\">row1-col1-Value</col>" +
-            "<col name=\"col2\">row1-col2-Value</col>" +
-            "<col name=\"col3\">row1-col3-Value</col>" +
-            "<col name=\"col4\">10</col>" +
-            "<col name=\"col5\">11</col>" +
-            "</row>" +
-            "<row>" +
-            "<col name=\"col1\">row2-col1-Value</col>" +
-            "<col name=\"col2\">row2-col2-Value</col>" +
-            "<col name=\"col3\">row2-col3-Value</col>" +
-            "<col name=\"col4\">20</col>" +
-            "<col name=\"col5\">21</col>" +
-            "</row>" +
-            "</table>";
-
-
-    ParseOptions parseOptions = new ParseOptions();
-    parseOptions.setOption(ParseOptions.OPTIONS_FILE_TYPE, ParseOptions.InputFileType.XML.toString());
-    parseOptions.setOption(ParseOptions.OPTIONS_HEADER, ParseOptions.HEADER.FIRST_RECORD.toString());
-
-
-    try(
-      StringReader sr = new StringReader(str);
-      DataParser dp = new DataParser(sr, parseOptions);
-      ) {
-
-      PreviewData pd = dp.parsePreview();
-      Assert.assertNotNull(pd.getPreviewRows());
-      Assert.assertNotNull(pd.getHeader());
-      Assert.assertEquals(2, pd.getPreviewRows().size()); // header row + preview rows
-      Assert.assertEquals(5, pd.getHeader().size());
-      ColumnDescription[] cd = {new ColumnDescriptionImpl("col1", ColumnDescriptionShort.DataTypes.STRING.toString(), 0),
-              new ColumnDescriptionImpl("col2", ColumnDescriptionShort.DataTypes.STRING.toString(), 1),
-              new ColumnDescriptionImpl("col3", ColumnDescriptionShort.DataTypes.STRING.toString(), 2),
-              new ColumnDescriptionImpl("col4", ColumnDescriptionShort.DataTypes.INT.toString(), 3),
-              new ColumnDescriptionImpl("col5", ColumnDescriptionShort.DataTypes.INT.toString(), 4)
-      };
-
-      Row row2 = new Row(new Object[]{"row1-col1-Value", "row1-col2-Value", "row1-col3-Value", "10", "11"});
-      Row row3 = new Row(new Object[]{"row2-col1-Value", "row2-col2-Value", "row2-col3-Value", "20", "21"});
-
-      Row[] rows = {row2, row3};
-
-      Assert.assertArrayEquals("Header Not Correct.", cd, pd.getHeader().toArray());
-      Assert.assertArrayEquals("Rows Not Correct.", rows, pd.getPreviewRows().toArray());
-    }
-  }
-
-
-  /**
-   * additional columns in rows of XML are ignored.
-   * number of columns are decided by the first row of the table and here second row contains more columns so those are ignored.
-   * @throws IOException
-   */
-  @Test
-  public void testParsePreviewCSVMoreColumns() throws Exception {
-    String str ="<table>" +
-            "<row>" +
-            "<col name=\"col1\">row1-col1-Value</col>" +
-            "<col name=\"col2\">row1-col2-Value</col>" +
-            "<col name=\"col3\">row1-col3-Value</col>" +
-            "<col name=\"col4\">10</col>" +
-            "<col name=\"col5\">11</col>" +
-            "</row>" +
-            "<row>" +
-            "<col name=\"col1\">row2-col1-Value</col>" +
-            "<col name=\"col2\">row2-col2-Value</col>" +
-            "<col name=\"col3\">row2-col3-Value</col>" +
-            "<col name=\"col99\">row2-col99-Value</col>" +  // extra colummn
-            "<col name=\"col100\">row2-col100-Value</col>" +  // extra column
-            "<col name=\"col4\">20</col>" +
-            "<col name=\"col5\">21</col>" +
-            "</row>" +
-            "</table>";
-
-    ParseOptions parseOptions = new ParseOptions();
-    parseOptions.setOption(ParseOptions.OPTIONS_FILE_TYPE, ParseOptions.InputFileType.XML.toString());
-
-
-    try(    StringReader sr = new StringReader(str);
-            DataParser dp = new DataParser(sr, parseOptions);
-    ) {
-
-
-      PreviewData pd = dp.parsePreview();
-
-      Row row2 = new Row(new Object[]{"row2-col1-Value","row2-col2-Value","row2-col3-Value","20","21"});
-      Assert.assertArrayEquals("More number of columns do not give correct result.", row2.getRow(), pd.getPreviewRows().get(1).getRow());
-    }
-  }
-
-  /**
-   * less columns in xml makes them null.
-   * number of columns are decided by the first row of the table and here second row does not contain col99 and col100
-   * columns so those are set to null.
-   * @throws IOException
-   */
-  @Test
-  public void testParsePreviewCSVLessColumns() throws Exception {
-    String str = "<table>" +
-            "<row>" +
-            "<col name=\"col1\">row1-col1-Value</col>" +
-            "<col name=\"col2\">row1-col2-Value</col>" +
-            "<col name=\"col3\">row1-col3-Value</col>" +
-            "<col name=\"col99\">row2-col99-Value</col>" +  // extra colummn
-            "<col name=\"col100\">row2-col100-Value</col>" +  // extra column
-            "<col name=\"col4\">10</col>" +
-            "<col name=\"col5\">11</col>" +
-            "</row>" +
-            "<row>" +
-            "<col name=\"col1\">row2-col1-Value</col>" +
-            "<col name=\"col2\">row2-col2-Value</col>" +
-            "<col name=\"col3\">row2-col3-Value</col>" +
-            "<col name=\"col4\">20</col>" +
-            "<col name=\"col5\">21</col>" +
-            "</row>" +
-            "</table>";
-
-    ParseOptions parseOptions = new ParseOptions();
-    parseOptions.setOption(ParseOptions.OPTIONS_FILE_TYPE, ParseOptions.InputFileType.XML.toString());
-    parseOptions.setOption(ParseOptions.OPTIONS_HEADER, ParseOptions.HEADER.FIRST_RECORD.toString());
-
-    try(
-      StringReader sr = new StringReader(str);
-      DataParser dp = new DataParser(sr, parseOptions);
-      ) {
-      PreviewData pd = dp.parsePreview();
-
-      Row row2 = new Row(new Object[]{"row2-col1-Value","row2-col2-Value","row2-col3-Value",null,null,"20","21"});
-      Assert.assertArrayEquals("Less number of columns do not give correct result.", row2.getRow(), pd.getPreviewRows().get(1).getRow());
-    }
-  }
-
-  /**
-   * illegal xml format gives error. adding illegal tag gives error
-   *
-   * @throws IOException
-   */
-  @Test(expected = IllegalArgumentException.class)
-  public void testWrongXMLFormat() throws Exception {
-    String str = "<table>" +
-            "<row>" +
-            "<ccc></ccc>" +   // illegal tag.
-            "<col name=\"col1\">row1-col1-Value</col>" +
-            "<col name=\"col2\">row1-col2-Value</col>" +
-            "<col name=\"col3\">row1-col3-Value</col>" +
-            "<col name=\"col99\">row2-col99-Value</col>" +  // extra colummn
-            "<col name=\"col100\">row2-col100-Value</col>" +  // extra column
-            "<col name=\"col4\">10</col>" +
-            "<col name=\"col5\">11</col>" +
-            "</row>" +
-            "<row>" +
-            "<col name=\"col1\">row2-col1-Value</col>" +
-            "<col name=\"col2\">row2-col2-Value</col>" +
-            "<col name=\"col3\">row2-col3-Value</col>" +
-            "<col name=\"col4\">20</col>" +
-            "<col name=\"col5\">21</col>" +
-            "</row>" +
-            "</table>";
-
-    ParseOptions parseOptions = new ParseOptions();
-    parseOptions.setOption(ParseOptions.OPTIONS_FILE_TYPE, ParseOptions.InputFileType.XML.toString());
-    parseOptions.setOption(ParseOptions.OPTIONS_HEADER, ParseOptions.HEADER.FIRST_RECORD.toString());
-    try(
-      StringReader sr = new StringReader(str);
-      DataParser  dp = new DataParser(sr, parseOptions);
-      ) {
-      PreviewData pd = dp.parsePreview();
-    }
-  }
-
-  /**
-   * One row XML will give embedde column names and 1st row in preview if HEADER.EMBEDDED is selected
-   * @throws IOException
-   */
-  @Test
-  public void testParsePreview1RowXML() throws Exception {
-    String str = "<table>" +
-                      "<row>" +
-                      "<col name=\"col1\">row1-col1-Value</col>" +
-                      "<col name=\"col2\">11</col>" +
-                      "</row>" +
-                 "</table>";
-
-
-    ParseOptions parseOptions = new ParseOptions();
-    parseOptions.setOption(ParseOptions.OPTIONS_FILE_TYPE, ParseOptions.InputFileType.XML.toString());
-    parseOptions.setOption(ParseOptions.OPTIONS_HEADER, ParseOptions.HEADER.EMBEDDED.toString());
-
-    try(
-      StringReader sr = new StringReader(str);
-      DataParser dp = new DataParser(sr, parseOptions);
-      ) {
-
-      PreviewData pd = dp.parsePreview();
-      Assert.assertNotNull(pd.getPreviewRows());
-      Assert.assertNotNull(pd.getHeader());
-      Assert.assertEquals(1, pd.getPreviewRows().size());
-      Assert.assertEquals(2, pd.getHeader().size());
-      ColumnDescription[] cd = {new ColumnDescriptionImpl("col1", ColumnDescriptionShort.DataTypes.STRING.toString(), 0),
-        new ColumnDescriptionImpl("col2", ColumnDescriptionShort.DataTypes.INT.toString(), 1)};
-
-      Object cols1[] = new Object[2];
-      cols1[0] = "row1-col1-Value";
-      cols1[1] = "11";
-      Row row1 = new Row(cols1);
-
-      Row[] rows = {row1};
-
-      Assert.assertArrayEquals("Header Not Correct.", cd, pd.getHeader().toArray());
-      Assert.assertArrayEquals("Rows Not Correct.", rows, pd.getPreviewRows().toArray());
-    }
-  }
-
-  /**
-   * One row XML will give default column names and 1st row in preview if HEADER.PROVIDED_BY_USER is selected
-   * @throws IOException
-   */
-  @Test
-  public void testParsePreview1RowXMLHeaderProvided() throws Exception {
-    String str = "<table>" +
-                    "<row>" +
-                    "<col name=\"col1\">row1-col1-Value</col>" +
-                    "<col name=\"col2\">11</col>" +
-                    "</row>" +
-                 "</table>";
-
-    ParseOptions parseOptions = new ParseOptions();
-    parseOptions.setOption(ParseOptions.OPTIONS_FILE_TYPE, ParseOptions.InputFileType.XML.toString());
-    parseOptions.setOption(ParseOptions.OPTIONS_HEADER, ParseOptions.HEADER.PROVIDED_BY_USER.toString());
-
-    try(
-      StringReader sr = new StringReader(str);
-      DataParser dp = new DataParser(sr, parseOptions)
-      ) {
-
-      PreviewData pd = dp.parsePreview();
-      Assert.assertNotNull(pd.getPreviewRows());
-      Assert.assertNotNull(pd.getHeader());
-      Assert.assertEquals(1, pd.getPreviewRows().size());
-      Assert.assertEquals(2, pd.getHeader().size());
-      ColumnDescription[] cd = {new ColumnDescriptionImpl("column1", ColumnDescriptionShort.DataTypes.STRING.toString(), 0),
-        new ColumnDescriptionImpl("column2", ColumnDescriptionShort.DataTypes.INT.toString(), 1)};
-
-      Object cols1[] = new Object[2];
-      cols1[0] = "row1-col1-Value";
-      cols1[1] = "11";
-      Row row1 = new Row(cols1);
-
-      Row[] rows = {row1};
-
-      Assert.assertArrayEquals("Header Not Correct.", cd, pd.getHeader().toArray());
-      Assert.assertArrayEquals("Rows Not Correct.", rows, pd.getPreviewRows().toArray());
-    }
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/resources/upload/JsonParserTest.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/resources/upload/JsonParserTest.java b/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/resources/upload/JsonParserTest.java
deleted file mode 100644
index cd571b3..0000000
--- a/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/resources/upload/JsonParserTest.java
+++ /dev/null
@@ -1,147 +0,0 @@
-/**
- * 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
- * <p/>
- * http://www.apache.org/licenses/LICENSE-2.0
- * <p/>
- * 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.ambari.view.hive.resources.upload;
-
-import com.google.gson.JsonArray;
-import com.google.gson.JsonObject;
-import org.apache.ambari.view.hive.client.Row;
-import org.apache.ambari.view.hive.resources.uploads.parsers.json.JSONParser;
-import org.apache.ambari.view.hive.resources.uploads.parsers.xml.XMLParser;
-import org.junit.Assert;
-import org.junit.Test;
-
-import java.io.IOException;
-import java.io.StringReader;
-import java.util.Iterator;
-
-public class JsonParserTest {
-
-  @Test(expected = IOException.class)
-  public void testEmptyStream() throws Exception {
-    String json = "";
-
-    try(
-      StringReader sr = new StringReader(json);
-      JSONParser jp =  new JSONParser(sr, null);
-    ) {
-      // PARSING WILL THROW ERROR
-    }
-  }
-
-  @Test
-  public void testEmptyRow() throws Exception {
-    JsonObject jo = new JsonObject();
-    JsonArray ja = new JsonArray();
-    ja.add(jo);
-    String json = ja.toString();
-
-    try(
-      StringReader sr = new StringReader(json);
-      JSONParser jp = new JSONParser(sr, null)
-      ) {
-
-      Iterator<Row> iterator = jp.iterator();
-
-      Assert.assertEquals("Iterator should not be Empty", true, iterator.hasNext());
-      Assert.assertArrayEquals("Row should be empty",new Object[]{},iterator.next().getRow());
-    }
-  }
-
-
-  @Test
-  public void testEmptyTable() throws Exception {
-    JsonArray ja = new JsonArray();
-    String json = ja.toString();
-
-    try(
-      StringReader sr = new StringReader(json);
-      JSONParser jp =  new JSONParser(sr, null);
-    ) {
-      Iterator<Row> iterator = jp.iterator();
-      Assert.assertEquals("Iterator Empty!", false, iterator.hasNext());
-    }
-  }
-
-  @Test
-  public void testParse1Row() throws Exception {
-    JsonObject jo = new JsonObject();
-    jo.addProperty("key1","value1");
-    jo.addProperty("key2",'c');
-    jo.addProperty("key3",10);
-    jo.addProperty("key4",10.1);
-
-    JsonArray ja = new JsonArray();
-    ja.add(jo);
-    String json = ja.toString();
-
-    try(StringReader sr = new StringReader(json);
-
-        JSONParser jp  = new JSONParser(sr, null)
-    ) {
-      Iterator<Row> iterator = jp.iterator();
-
-      Assert.assertEquals("Iterator Empty!", true, iterator.hasNext());
-      Row row = iterator.next();
-      Row expected = new Row(new Object[]{"value1", "c", "10", "10.1"});
-      Assert.assertEquals("Row not equal!", expected, row);
-
-      Assert.assertEquals("Should report no more rows!", false, iterator.hasNext());
-    }
-  }
-
-  @Test
-  public void testParseMultipleRow() throws Exception {
-    JsonObject jo1 = new JsonObject();
-    jo1.addProperty("key1","value1");
-    jo1.addProperty("key2","c");
-    jo1.addProperty("key3","10");
-    jo1.addProperty("key4","10.1");
-
-    JsonObject jo2 = new JsonObject();
-    jo2.addProperty("key1","value2");
-    jo2.addProperty("key2","c2");
-    jo2.addProperty("key3","102");
-    jo2.addProperty("key4",true);
-
-
-    JsonArray ja = new JsonArray();
-    ja.add(jo1);
-    ja.add(jo2);
-
-    String json = ja.toString();
-
-
-
-    try(
-      StringReader sr = new StringReader(json);
-      JSONParser jp = new JSONParser(sr, null)
-    ) {
-      Iterator<Row> iterator = jp.iterator();
-
-      Assert.assertEquals("Failed to detect 1st row!", true, iterator.hasNext());
-      Assert.assertEquals("Failed to match 1st row!", new Row(new Object[]{"value1", "c", "10", "10.1"}), iterator.next());
-
-      Assert.assertEquals("Failed to detect 2nd row!", true, iterator.hasNext());
-      Assert.assertEquals("Failed to match 2nd row!", new Row(new Object[]{"value2", "c2", "102", Boolean.TRUE.toString()}), iterator.next());
-
-      Assert.assertEquals("Failed to detect end of rows!", false, iterator.hasNext());
-      Assert.assertEquals("Failed to detect end of rows 2nd time!", false, iterator.hasNext());
-    }
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/resources/upload/OpenCSVParserTest.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/resources/upload/OpenCSVParserTest.java b/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/resources/upload/OpenCSVParserTest.java
deleted file mode 100644
index 5256b5a..0000000
--- a/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/resources/upload/OpenCSVParserTest.java
+++ /dev/null
@@ -1,333 +0,0 @@
-/**
- * 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
- * <p/>
- * http://www.apache.org/licenses/LICENSE-2.0
- * <p/>
- * 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.ambari.view.hive.resources.upload;
-
-import org.apache.ambari.view.hive.client.Row;
-import org.apache.ambari.view.hive.resources.uploads.parsers.ParseOptions;
-import org.apache.ambari.view.hive.resources.uploads.parsers.csv.opencsv.OpenCSVParser;
-import org.junit.Assert;
-import org.junit.Test;
-
-import java.io.IOException;
-import java.io.StringReader;
-import java.util.Iterator;
-
-public class OpenCSVParserTest {
-
-  /**
-   * no exception in creating csvParser with emtpy stream
-   * @throws IOException
-   */
-  @Test
-  public void testEmptyStream() throws Exception {
-    String csv = "";
-
-    try(
-      StringReader sr = new StringReader(csv);
-      OpenCSVParser jp = new OpenCSVParser(sr, new ParseOptions());
-      ) {
-      Assert.assertEquals("There should not be any rows.",false, jp.iterator().hasNext());
-    }
-  }
-
-  /**
-   * in case of csv an empty line is still considered as row
-   * @throws IOException
-   */
-  @Test
-  public void testEmptyRow() throws Exception {
-    String csv = "       ";
-
-    try(
-      StringReader sr = new StringReader(csv);
-      OpenCSVParser jp = new OpenCSVParser(sr, new ParseOptions());
-      ) {
-      Iterator<Row> iterator = jp.iterator();
-
-      Assert.assertEquals("Iterator should be Empty", true, iterator.hasNext());
-      Assert.assertArrayEquals("Row should not be empty",new Object[]{"       "},iterator.next().getRow());
-    }
-  }
-
-  @Test
-  public void testParse1Row() throws Exception {
-    String csv = "value1,c,10,10.1";
-
-    try(
-      StringReader sr = new StringReader(csv);
-      OpenCSVParser jp = new OpenCSVParser(sr, new ParseOptions());
-      ) {
-      Iterator<Row> iterator = jp.iterator();
-
-      Assert.assertEquals("Iterator Empty!", true, iterator.hasNext());
-      Row row = iterator.next();
-      Row expected = new Row(new Object[]{"value1", "c", "10", "10.1"});
-      Assert.assertEquals("Row not equal!", expected, row);
-
-      Assert.assertEquals("Should report no more rows!", false, iterator.hasNext());
-    }
-  }
-
-  @Test
-  public void testParseMultipleRow() throws Exception {
-
-    String csv = "value1,c,10,10.1\n" +
-            "value2,c2,102,true";
-
-    try(
-      StringReader sr = new StringReader(csv);
-      OpenCSVParser jp = new OpenCSVParser(sr, new ParseOptions());
-    ) {
-
-      Iterator<Row> iterator = jp.iterator();
-
-      Assert.assertEquals("Failed to detect 1st row!", true, iterator.hasNext());
-      Assert.assertEquals("Failed to match 1st row!", new Row(new Object[]{"value1", "c", "10", "10.1"}), iterator.next());
-
-      Assert.assertEquals("Failed to detect 2nd row!", true, iterator.hasNext());
-      Assert.assertEquals("Failed to match 2nd row!", new Row(new Object[]{"value2", "c2", "102", Boolean.TRUE.toString()}), iterator.next());
-
-      Assert.assertEquals("Failed to detect end of rows!", false, iterator.hasNext());
-      Assert.assertEquals("Failed to detect end of rows 2nd time!", false, iterator.hasNext());
-    }
-  }
-
-  @Test
-  public void testQuotedAndEscapedEndline() throws Exception {
-
-    String csv = "\"row1-\ncol1\",1,1.1\n\"row2-\\\ncol1\",2,2.2\n";
-    ParseOptions po = new ParseOptions();
-
-    try(
-      StringReader sr = new StringReader(csv);
-      OpenCSVParser jp = new OpenCSVParser(sr, po);
-    ) {
-
-      Iterator<Row> iterator = jp.iterator();
-
-      Row row = new Row(new Object[]{"row1-\ncol1", "1", "1.1"});
-      Assert.assertEquals("Failed to detect 1st row!", true, iterator.hasNext());
-      Assert.assertEquals("Failed to match 1st row!", row, iterator.next());
-
-      Row row2 = new Row(new Object[]{"row2-\ncol1", "2", "2.2"});
-      Assert.assertEquals("Failed to detect 1st row!", true, iterator.hasNext());
-      Assert.assertEquals("Failed to match 1st row!", row2, iterator.next());
-
-    }
-  }
-
-  @Test
-  public void testQuotedDoubleQuote() throws Exception {
-
-    String csv = "\"aaa\",\"b\"\"bb\",\"ccc\"";
-    ParseOptions po = new ParseOptions();
-
-    try(
-      StringReader sr = new StringReader(csv);
-      OpenCSVParser jp = new OpenCSVParser(sr, po);
-    ) {
-
-      Iterator<Row> iterator = jp.iterator();
-
-      Row row = new Row(new Object[]{"aaa", "b\"bb", "ccc"});
-      Assert.assertEquals("Failed to detect 1st row!", true, iterator.hasNext());
-      Assert.assertEquals("Failed to match 1st row!", row, iterator.next());
-    }
-  }
-
-  @Test
-  public void testEscapedDoubleQuote() throws Exception {
-
-    String csv = "\"aaa\",\"b\\\"bb\",\"ccc\"";
-    ParseOptions po = new ParseOptions();
-
-    try(
-      StringReader sr = new StringReader(csv);
-      OpenCSVParser jp = new OpenCSVParser(sr, po);
-    ) {
-
-      Iterator<Row> iterator = jp.iterator();
-
-      Row row = new Row(new Object[]{"aaa", "b\"bb", "ccc"});
-      Assert.assertEquals("Failed to detect 1st row!", true, iterator.hasNext());
-      Assert.assertEquals("Failed to match 1st row!", row, iterator.next());
-    }
-  }
-
-
-  @Test
-  public void testSpecialEscape() throws Exception {
-
-    String csv = "\"aaa\",\"b$\"bb\",\"ccc\"";
-    ParseOptions po = new ParseOptions();
-    po.setOption(ParseOptions.OPTIONS_CSV_ESCAPE_CHAR,'$');
-
-    try(
-      StringReader sr = new StringReader(csv);
-      OpenCSVParser jp = new OpenCSVParser(sr, po);
-    ) {
-
-      Iterator<Row> iterator = jp.iterator();
-
-      Row row = new Row(new Object[]{"aaa", "b\"bb", "ccc"});
-      Assert.assertEquals("Failed to detect 1st row!", true, iterator.hasNext());
-      Assert.assertEquals("Failed to match 1st row!", row, iterator.next());
-    }
-  }
-
-  @Test
-  public void testMultipleEscape() throws Exception {
-
-    String csv = "BBAABBKMAABB";
-    ParseOptions po = new ParseOptions();
-    po.setOption(ParseOptions.OPTIONS_CSV_ESCAPE_CHAR,'B');
-    po.setOption(ParseOptions.OPTIONS_CSV_DELIMITER,'M');
-
-    try(
-      StringReader sr = new StringReader(csv);
-      OpenCSVParser jp = new OpenCSVParser(sr, po);
-    ) {
-      Iterator<Row> iterator = jp.iterator();
-
-      Row row = new Row(new Object[]{"AABK", "AAB"});
-      Assert.assertEquals("Failed to detect 1st row!", true, iterator.hasNext());
-      Assert.assertEquals("Failed to match 1st row!", row, iterator.next());
-    }
-  }
-
-  @Test
-  public void testSpecialEscapedEscape() throws Exception {
-
-    String csv = "aaa,b$$bb,ccc";
-    ParseOptions po = new ParseOptions();
-    po.setOption(ParseOptions.OPTIONS_CSV_ESCAPE_CHAR,'$');
-
-    try(
-      StringReader sr = new StringReader(csv);
-      OpenCSVParser jp = new OpenCSVParser(sr, po);
-    ) {
-
-      Iterator<Row> iterator = jp.iterator();
-
-      Row row = new Row(new Object[]{"aaa", "b$bb", "ccc"});
-      Assert.assertEquals("Failed to detect 1st row!", true, iterator.hasNext());
-      Assert.assertEquals("Failed to match 1st row!", row, iterator.next());
-    }
-  }
-
-
-  @Test
-  public void testSpecialUnEscapedEscape() throws Exception {
-
-    String csv = "aaa,b$bb,ccc";
-    ParseOptions po = new ParseOptions();
-    po.setOption(ParseOptions.OPTIONS_CSV_ESCAPE_CHAR,'$');
-
-    try(
-      StringReader sr = new StringReader(csv);
-      OpenCSVParser jp = new OpenCSVParser(sr, po);
-    ) {
-
-      Iterator<Row> iterator = jp.iterator();
-
-      Row row = new Row(new Object[]{"aaa", "bbb", "ccc"});
-      Assert.assertEquals("Failed to detect 1st row!", true, iterator.hasNext());
-      Assert.assertEquals("Failed to match 1st row!", row, iterator.next());
-    }
-  }
-
-  @Test
-  public void test001Escape() throws Exception {
-
-    String csv = "aaa,b\001\"bb,ccc";
-    ParseOptions po = new ParseOptions();
-    po.setOption(ParseOptions.OPTIONS_CSV_ESCAPE_CHAR,'\001');
-
-    try(
-      StringReader sr = new StringReader(csv);
-      OpenCSVParser jp = new OpenCSVParser(sr, po);
-    ) {
-
-      Iterator<Row> iterator = jp.iterator();
-      Row row = new Row(new Object[]{"aaa", "b\"bb", "ccc"});
-      Assert.assertEquals("Failed to detect 1st row!", true, iterator.hasNext());
-      Assert.assertEquals("Failed to match 1st row!", row, iterator.next());    }
-  }
-
-  @Test
-  public void testSpecialQuote() throws Exception {
-
-    String csv = "\001aaa\001,\001b\001\001bb\001,\001ccc\001";
-    ParseOptions po = new ParseOptions();
-    po.setOption(ParseOptions.OPTIONS_CSV_QUOTE,'\001');
-
-    try(
-      StringReader sr = new StringReader(csv);
-      OpenCSVParser jp = new OpenCSVParser(sr, po);
-    ) {
-
-      Iterator<Row> iterator = jp.iterator();
-      Row row = new Row(new Object[]{"aaa", "b\001bb", "ccc"});
-      Assert.assertEquals("Failed to detect 1st row!", true, iterator.hasNext());
-      Assert.assertEquals("Failed to match 1st row!", row, iterator.next());
-    }
-  }
-
-  @Test
-  public void testSpaceAsDelimiterAndQuoted() throws Exception {
-
-    String csv = "aaa \"b bb\" ccc\naaa2 bbb2 \"c cc2\"";
-    ParseOptions po = new ParseOptions();
-//    po.setOption(ParseOptions.OPTIONS_CSV_ESCAPE_CHAR,'\001');
-    po.setOption(ParseOptions.OPTIONS_CSV_DELIMITER,' ');
-
-    try(
-      StringReader sr = new StringReader(csv);
-      OpenCSVParser jp = new OpenCSVParser(sr, po);
-    ) {
-
-      Iterator<Row> iterator = jp.iterator();
-      Row row = new Row(new Object[]{"aaa", "b bb", "ccc"});
-      Assert.assertEquals("Failed to detect 1st row!", true, iterator.hasNext());
-      Assert.assertEquals("Failed to match 1st row!", row, iterator.next());
-
-      Row row2 = new Row(new Object[]{"aaa2", "bbb2", "c cc2"});
-      Assert.assertEquals("Failed to detect 1st row!", true, iterator.hasNext());
-      Assert.assertEquals("Failed to match 1st row!", row2, iterator.next());
-    }
-  }
-
-  @Test
-  public void testFailedDelimiterEscaped() throws Exception {
-
-    String csv = "aaa,b\\,bb,ccc";
-    ParseOptions po = new ParseOptions();
-
-    try(
-      StringReader sr = new StringReader(csv);
-      OpenCSVParser jp = new OpenCSVParser(sr, po);
-    ) {
-
-      Iterator<Row> iterator = jp.iterator();
-      Row row = new Row(new Object[]{"aaa", "b","bb", "ccc"});   // different from Common CSVParser
-      Assert.assertEquals("Failed to detect 1st row!", true, iterator.hasNext());
-      Assert.assertEquals("Failed to match 1st row!", row, iterator.next());
-    }
-  }
-}


[06/23] ambari git commit: AMBARI-19302 : removed contrib/views/hive folder and made necessary changes in pom.xml files (nitirajrathore)

Posted by ni...@apache.org.
http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/vendor/codemirror/codemirror.css
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/vendor/codemirror/codemirror.css b/contrib/views/hive/src/main/resources/ui/hive-web/vendor/codemirror/codemirror.css
deleted file mode 100644
index 68c67b1..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/vendor/codemirror/codemirror.css
+++ /dev/null
@@ -1,309 +0,0 @@
-/* BASICS */
-
-.CodeMirror {
-  /* Set height, width, borders, and global font properties here */
-  font-family: monospace;
-  height: 300px;
-}
-.CodeMirror-scroll {
-  /* Set scrolling behaviour here */
-  overflow: auto;
-}
-
-/* PADDING */
-
-.CodeMirror-lines {
-  padding: 4px 0; /* Vertical padding around content */
-}
-.CodeMirror pre {
-  padding: 0 4px; /* Horizontal padding of content */
-}
-
-.CodeMirror-scrollbar-filler, .CodeMirror-gutter-filler {
-  background-color: white; /* The little square between H and V scrollbars */
-}
-
-/* GUTTER */
-
-.CodeMirror-gutters {
-  border-right: 1px solid #ddd;
-  background-color: #f7f7f7;
-  white-space: nowrap;
-}
-.CodeMirror-linenumbers {}
-.CodeMirror-linenumber {
-  padding: 0 3px 0 5px;
-  min-width: 20px;
-  text-align: right;
-  color: #999;
-  -moz-box-sizing: content-box;
-  box-sizing: content-box;
-}
-
-.CodeMirror-guttermarker { color: black; }
-.CodeMirror-guttermarker-subtle { color: #999; }
-
-/* CURSOR */
-
-.CodeMirror div.CodeMirror-cursor {
-  border-left: 1px solid black;
-}
-/* Shown when moving in bi-directional text */
-.CodeMirror div.CodeMirror-secondarycursor {
-  border-left: 1px solid silver;
-}
-.CodeMirror.cm-keymap-fat-cursor div.CodeMirror-cursor {
-  width: auto;
-  border: 0;
-  background: #7e7;
-}
-.CodeMirror.cm-keymap-fat-cursor div.CodeMirror-cursors {
-  z-index: 1;
-}
-
-.cm-animate-fat-cursor {
-  width: auto;
-  border: 0;
-  -webkit-animation: blink 1.06s steps(1) infinite;
-  -moz-animation: blink 1.06s steps(1) infinite;
-  animation: blink 1.06s steps(1) infinite;
-}
-@-moz-keyframes blink {
-  0% { background: #7e7; }
-  50% { background: none; }
-  100% { background: #7e7; }
-}
-@-webkit-keyframes blink {
-  0% { background: #7e7; }
-  50% { background: none; }
-  100% { background: #7e7; }
-}
-@keyframes blink {
-  0% { background: #7e7; }
-  50% { background: none; }
-  100% { background: #7e7; }
-}
-
-/* Can style cursor different in overwrite (non-insert) mode */
-div.CodeMirror-overwrite div.CodeMirror-cursor {}
-
-.cm-tab { display: inline-block; text-decoration: inherit; }
-
-.CodeMirror-ruler {
-  border-left: 1px solid #ccc;
-  position: absolute;
-}
-
-/* DEFAULT THEME */
-
-.cm-s-default .cm-keyword {color: #708;}
-.cm-s-default .cm-atom {color: #219;}
-.cm-s-default .cm-number {color: #164;}
-.cm-s-default .cm-def {color: #00f;}
-.cm-s-default .cm-variable,
-.cm-s-default .cm-punctuation,
-.cm-s-default .cm-property,
-.cm-s-default .cm-operator {}
-.cm-s-default .cm-variable-2 {color: #05a;}
-.cm-s-default .cm-variable-3 {color: #085;}
-.cm-s-default .cm-comment {color: #a50;}
-.cm-s-default .cm-string {color: #a11;}
-.cm-s-default .cm-string-2 {color: #f50;}
-.cm-s-default .cm-meta {color: #555;}
-.cm-s-default .cm-qualifier {color: #555;}
-.cm-s-default .cm-builtin {color: #30a;}
-.cm-s-default .cm-bracket {color: #997;}
-.cm-s-default .cm-tag {color: #170;}
-.cm-s-default .cm-attribute {color: #00c;}
-.cm-s-default .cm-header {color: blue;}
-.cm-s-default .cm-quote {color: #090;}
-.cm-s-default .cm-hr {color: #999;}
-.cm-s-default .cm-link {color: #00c;}
-
-.cm-negative {color: #d44;}
-.cm-positive {color: #292;}
-.cm-header, .cm-strong {font-weight: bold;}
-.cm-em {font-style: italic;}
-.cm-link {text-decoration: underline;}
-
-.cm-s-default .cm-error {color: #f00;}
-.cm-invalidchar {color: #f00;}
-
-/* Default styles for common addons */
-
-div.CodeMirror span.CodeMirror-matchingbracket {color: #0f0;}
-div.CodeMirror span.CodeMirror-nonmatchingbracket {color: #f22;}
-.CodeMirror-matchingtag { background: rgba(255, 150, 0, .3); }
-.CodeMirror-activeline-background {background: #e8f2ff;}
-
-/* STOP */
-
-/* The rest of this file contains styles related to the mechanics of
-   the editor. You probably shouldn't touch them. */
-
-.CodeMirror {
-  line-height: 1;
-  position: relative;
-  overflow: hidden;
-  background: white;
-  color: black;
-}
-
-.CodeMirror-scroll {
-  /* 30px is the magic margin used to hide the element's real scrollbars */
-  /* See overflow: hidden in .CodeMirror */
-  margin-bottom: -30px; margin-right: -30px;
-  padding-bottom: 30px;
-  height: 100%;
-  outline: none; /* Prevent dragging from highlighting the element */
-  position: relative;
-  -moz-box-sizing: content-box;
-  box-sizing: content-box;
-}
-.CodeMirror-sizer {
-  position: relative;
-  border-right: 30px solid transparent;
-  -moz-box-sizing: content-box;
-  box-sizing: content-box;
-}
-
-/* The fake, visible scrollbars. Used to force redraw during scrolling
-   before actuall scrolling happens, thus preventing shaking and
-   flickering artifacts. */
-.CodeMirror-vscrollbar, .CodeMirror-hscrollbar, .CodeMirror-scrollbar-filler, .CodeMirror-gutter-filler {
-  position: absolute;
-  z-index: 6;
-  display: none;
-}
-.CodeMirror-vscrollbar {
-  right: 0; top: 0;
-  overflow-x: hidden;
-  overflow-y: scroll;
-}
-.CodeMirror-hscrollbar {
-  bottom: 0; left: 0;
-  overflow-y: hidden;
-  overflow-x: scroll;
-}
-.CodeMirror-scrollbar-filler {
-  right: 0; bottom: 0;
-}
-.CodeMirror-gutter-filler {
-  left: 0; bottom: 0;
-}
-
-.CodeMirror-gutters {
-  position: absolute; left: 0; top: 0;
-  padding-bottom: 30px;
-  z-index: 3;
-}
-.CodeMirror-gutter {
-  white-space: normal;
-  height: 100%;
-  -moz-box-sizing: content-box;
-  box-sizing: content-box;
-  padding-bottom: 30px;
-  margin-bottom: -32px;
-  display: inline-block;
-  /* Hack to make IE7 behave */
-  *zoom:1;
-  *display:inline;
-}
-.CodeMirror-gutter-elt {
-  position: absolute;
-  cursor: default;
-  z-index: 4;
-}
-
-.CodeMirror-lines {
-  cursor: text;
-  min-height: 1px; /* prevents collapsing before first draw */
-}
-.CodeMirror pre {
-  /* Reset some styles that the rest of the page might have set */
-  -moz-border-radius: 0; -webkit-border-radius: 0; border-radius: 0;
-  border-width: 0;
-  background: transparent;
-  font-family: inherit;
-  font-size: inherit;
-  margin: 0;
-  white-space: pre;
-  word-wrap: normal;
-  line-height: inherit;
-  color: inherit;
-  z-index: 2;
-  position: relative;
-  overflow: visible;
-}
-.CodeMirror-wrap pre {
-  word-wrap: break-word;
-  white-space: pre-wrap;
-  word-break: normal;
-}
-
-.CodeMirror-linebackground {
-  position: absolute;
-  left: 0; right: 0; top: 0; bottom: 0;
-  z-index: 0;
-}
-
-.CodeMirror-linewidget {
-  position: relative;
-  z-index: 2;
-  overflow: auto;
-}
-
-.CodeMirror-widget {}
-
-.CodeMirror-wrap .CodeMirror-scroll {
-  overflow-x: hidden;
-}
-
-.CodeMirror-measure {
-  position: absolute;
-  width: 100%;
-  height: 0;
-  overflow: hidden;
-  visibility: hidden;
-}
-.CodeMirror-measure pre { position: static; }
-
-.CodeMirror div.CodeMirror-cursor {
-  position: absolute;
-  border-right: none;
-  width: 0;
-}
-
-div.CodeMirror-cursors {
-  visibility: hidden;
-  position: relative;
-  z-index: 3;
-}
-.CodeMirror-focused div.CodeMirror-cursors {
-  visibility: visible;
-}
-
-.CodeMirror-selected { background: #d9d9d9; }
-.CodeMirror-focused .CodeMirror-selected { background: #d7d4f0; }
-.CodeMirror-crosshair { cursor: crosshair; }
-
-.cm-searching {
-  background: #ffa;
-  background: rgba(255, 255, 0, .4);
-}
-
-/* IE7 hack to prevent it from returning funny offsetTops on the spans */
-.CodeMirror span { *vertical-align: text-bottom; }
-
-/* Used to force a border model for a node */
-.cm-force-border { padding-right: .1px; }
-
-@media print {
-  /* Hide the cursor when printing */
-  .CodeMirror div.CodeMirror-cursors {
-    visibility: hidden;
-  }
-}
-
-/* Help users use markselection to safely style text background */
-span.CodeMirror-selectedtext { background: none; }

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/vendor/codemirror/show-hint.css
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/vendor/codemirror/show-hint.css b/contrib/views/hive/src/main/resources/ui/hive-web/vendor/codemirror/show-hint.css
deleted file mode 100644
index 924e638..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/vendor/codemirror/show-hint.css
+++ /dev/null
@@ -1,38 +0,0 @@
-.CodeMirror-hints {
-  position: absolute;
-  z-index: 10;
-  overflow: hidden;
-  list-style: none;
-
-  margin: 0;
-  padding: 2px;
-
-  -webkit-box-shadow: 2px 3px 5px rgba(0,0,0,.2);
-  -moz-box-shadow: 2px 3px 5px rgba(0,0,0,.2);
-  box-shadow: 2px 3px 5px rgba(0,0,0,.2);
-  border-radius: 3px;
-  border: 1px solid silver;
-
-  background: white;
-  font-size: 90%;
-  font-family: monospace;
-
-  max-height: 20em;
-  overflow-y: auto;
-}
-
-.CodeMirror-hint {
-  margin: 0;
-  padding: 0 4px;
-  border-radius: 2px;
-  max-width: 19em;
-  overflow: hidden;
-  white-space: pre;
-  color: black;
-  cursor: pointer;
-}
-
-li.CodeMirror-hint-active {
-  background: #08f;
-  color: white;
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/vendor/codemirror/show-hint.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/vendor/codemirror/show-hint.js b/contrib/views/hive/src/main/resources/ui/hive-web/vendor/codemirror/show-hint.js
deleted file mode 100644
index 27b770b..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/vendor/codemirror/show-hint.js
+++ /dev/null
@@ -1,389 +0,0 @@
-// CodeMirror, copyright (c) by Marijn Haverbeke and others
-// Distributed under an MIT license: http://codemirror.net/LICENSE
-
-(function(mod) {
-  if (typeof exports == "object" && typeof module == "object") // CommonJS
-    mod(require("../../lib/codemirror"));
-  else if (typeof define == "function" && define.amd) // AMD
-    define(["../../lib/codemirror"], mod);
-  else // Plain browser env
-    mod(CodeMirror);
-})(function(CodeMirror) {
-  "use strict";
-
-  var HINT_ELEMENT_CLASS        = "CodeMirror-hint";
-  var ACTIVE_HINT_ELEMENT_CLASS = "CodeMirror-hint-active";
-
-  // This is the old interface, kept around for now to stay
-  // backwards-compatible.
-  CodeMirror.showHint = function(cm, getHints, options) {
-    if (!getHints) return cm.showHint(options);
-    if (options && options.async) getHints.async = true;
-    var newOpts = {hint: getHints};
-    if (options) for (var prop in options) newOpts[prop] = options[prop];
-    return cm.showHint(newOpts);
-  };
-
-  CodeMirror.defineExtension("showHint", function(options) {
-    // We want a single cursor position.
-    if (this.listSelections().length > 1 || this.somethingSelected()) return;
-
-    if (this.state.completionActive) this.state.completionActive.close();
-    var completion = this.state.completionActive = new Completion(this, options);
-    var getHints = completion.options.hint;
-    if (!getHints) return;
-
-    CodeMirror.signal(this, "startCompletion", this);
-    if (getHints.async)
-      getHints(this, function(hints) { completion.showHints(hints); }, completion.options);
-    else
-      return completion.showHints(getHints(this, completion.options));
-  });
-
-  function Completion(cm, options) {
-    this.cm = cm;
-    this.options = this.buildOptions(options);
-    this.widget = this.onClose = null;
-  }
-
-  Completion.prototype = {
-    close: function() {
-      if (!this.active()) return;
-      this.cm.state.completionActive = null;
-
-      if (this.widget) this.widget.close();
-      if (this.onClose) this.onClose();
-      CodeMirror.signal(this.cm, "endCompletion", this.cm);
-    },
-
-    active: function() {
-      return this.cm.state.completionActive == this;
-    },
-
-    pick: function(data, i) {
-      var completion = data.list[i];
-      if (completion.hint) completion.hint(this.cm, data, completion);
-      else this.cm.replaceRange(getText(completion), completion.from || data.from,
-                                completion.to || data.to, "complete");
-      CodeMirror.signal(data, "pick", completion);
-      this.close();
-    },
-
-    showHints: function(data) {
-      if (!data || !data.list.length || !this.active()) return this.close();
-
-      if (this.options.completeSingle && data.list.length == 1)
-        this.pick(data, 0);
-      else
-        this.showWidget(data);
-    },
-
-    showWidget: function(data) {
-      this.widget = new Widget(this, data);
-      CodeMirror.signal(data, "shown");
-
-      var debounce = 0, completion = this, finished;
-      var closeOn = this.options.closeCharacters;
-      var startPos = this.cm.getCursor(), startLen = this.cm.getLine(startPos.line).length;
-
-      var requestAnimationFrame = window.requestAnimationFrame || function(fn) {
-        return setTimeout(fn, 1000/60);
-      };
-      var cancelAnimationFrame = window.cancelAnimationFrame || clearTimeout;
-
-      function done() {
-        if (finished) return;
-        finished = true;
-        completion.close();
-        completion.cm.off("cursorActivity", activity);
-        if (data) CodeMirror.signal(data, "close");
-      }
-
-      function update() {
-        if (finished) return;
-        CodeMirror.signal(data, "update");
-        var getHints = completion.options.hint;
-        if (getHints.async)
-          getHints(completion.cm, finishUpdate, completion.options);
-        else
-          finishUpdate(getHints(completion.cm, completion.options));
-      }
-      function finishUpdate(data_) {
-        data = data_;
-        if (finished) return;
-        if (!data || !data.list.length) return done();
-        if (completion.widget) completion.widget.close();
-        completion.widget = new Widget(completion, data);
-      }
-
-      function clearDebounce() {
-        if (debounce) {
-          cancelAnimationFrame(debounce);
-          debounce = 0;
-        }
-      }
-
-      function activity() {
-        clearDebounce();
-        var pos = completion.cm.getCursor(), line = completion.cm.getLine(pos.line);
-        if (pos.line != startPos.line || line.length - pos.ch != startLen - startPos.ch ||
-            pos.ch < startPos.ch || completion.cm.somethingSelected() ||
-            (pos.ch && closeOn.test(line.charAt(pos.ch - 1)))) {
-          completion.close();
-        } else {
-          debounce = requestAnimationFrame(update);
-          if (completion.widget) completion.widget.close();
-        }
-      }
-      this.cm.on("cursorActivity", activity);
-      this.onClose = done;
-    },
-
-    buildOptions: function(options) {
-      var editor = this.cm.options.hintOptions;
-      var out = {};
-      for (var prop in defaultOptions) out[prop] = defaultOptions[prop];
-      if (editor) for (var prop in editor)
-        if (editor[prop] !== undefined) out[prop] = editor[prop];
-      if (options) for (var prop in options)
-        if (options[prop] !== undefined) out[prop] = options[prop];
-      return out;
-    }
-  };
-
-  function getText(completion) {
-    if (typeof completion == "string") return completion;
-    else return completion.text;
-  }
-
-  function buildKeyMap(completion, handle) {
-    var baseMap = {
-      Up: function() {handle.moveFocus(-1);},
-      Down: function() {handle.moveFocus(1);},
-      PageUp: function() {handle.moveFocus(-handle.menuSize() + 1, true);},
-      PageDown: function() {handle.moveFocus(handle.menuSize() - 1, true);},
-      Home: function() {handle.setFocus(0);},
-      End: function() {handle.setFocus(handle.length - 1);},
-      Enter: handle.pick,
-      Tab: handle.pick,
-      Esc: handle.close
-    };
-    var custom = completion.options.customKeys;
-    var ourMap = custom ? {} : baseMap;
-    function addBinding(key, val) {
-      var bound;
-      if (typeof val != "string")
-        bound = function(cm) { return val(cm, handle); };
-      // This mechanism is deprecated
-      else if (baseMap.hasOwnProperty(val))
-        bound = baseMap[val];
-      else
-        bound = val;
-      ourMap[key] = bound;
-    }
-    if (custom)
-      for (var key in custom) if (custom.hasOwnProperty(key))
-        addBinding(key, custom[key]);
-    var extra = completion.options.extraKeys;
-    if (extra)
-      for (var key in extra) if (extra.hasOwnProperty(key))
-        addBinding(key, extra[key]);
-    return ourMap;
-  }
-
-  function getHintElement(hintsElement, el) {
-    while (el && el != hintsElement) {
-      if (el.nodeName.toUpperCase() === "LI" && el.parentNode == hintsElement) return el;
-      el = el.parentNode;
-    }
-  }
-
-  function Widget(completion, data) {
-    this.completion = completion;
-    this.data = data;
-    var widget = this, cm = completion.cm;
-
-    var hints = this.hints = document.createElement("ul");
-    hints.className = "CodeMirror-hints";
-    this.selectedHint = data.selectedHint || 0;
-
-    var completions = data.list;
-    for (var i = 0; i < completions.length; ++i) {
-      var elt = hints.appendChild(document.createElement("li")), cur = completions[i];
-      var className = HINT_ELEMENT_CLASS + (i != this.selectedHint ? "" : " " + ACTIVE_HINT_ELEMENT_CLASS);
-      if (cur.className != null) className = cur.className + " " + className;
-      elt.className = className;
-      if (cur.render) cur.render(elt, data, cur);
-      else elt.appendChild(document.createTextNode(cur.displayText || getText(cur)));
-      elt.hintId = i;
-    }
-
-    var pos = cm.cursorCoords(completion.options.alignWithWord ? data.from : null);
-    var left = pos.left, top = pos.bottom, below = true;
-    hints.style.left = left + "px";
-    hints.style.top = top + "px";
-    // If we're at the edge of the screen, then we want the menu to appear on the left of the cursor.
-    var winW = window.innerWidth || Math.max(document.body.offsetWidth, document.documentElement.offsetWidth);
-    var winH = window.innerHeight || Math.max(document.body.offsetHeight, document.documentElement.offsetHeight);
-    (completion.options.container || document.body).appendChild(hints);
-    var box = hints.getBoundingClientRect(), overlapY = box.bottom - winH;
-    if (overlapY > 0) {
-      var height = box.bottom - box.top, curTop = pos.top - (pos.bottom - box.top);
-      if (curTop - height > 0) { // Fits above cursor
-        hints.style.top = (top = pos.top - height) + "px";
-        below = false;
-      } else if (height > winH) {
-        hints.style.height = (winH - 5) + "px";
-        hints.style.top = (top = pos.bottom - box.top) + "px";
-        var cursor = cm.getCursor();
-        if (data.from.ch != cursor.ch) {
-          pos = cm.cursorCoords(cursor);
-          hints.style.left = (left = pos.left) + "px";
-          box = hints.getBoundingClientRect();
-        }
-      }
-    }
-    var overlapX = box.left - winW;
-    if (overlapX > 0) {
-      if (box.right - box.left > winW) {
-        hints.style.width = (winW - 5) + "px";
-        overlapX -= (box.right - box.left) - winW;
-      }
-      hints.style.left = (left = pos.left - overlapX) + "px";
-    }
-
-    cm.addKeyMap(this.keyMap = buildKeyMap(completion, {
-      moveFocus: function(n, avoidWrap) { widget.changeActive(widget.selectedHint + n, avoidWrap); },
-      setFocus: function(n) { widget.changeActive(n); },
-      menuSize: function() { return widget.screenAmount(); },
-      length: completions.length,
-      close: function() { completion.close(); },
-      pick: function() { widget.pick(); },
-      data: data
-    }));
-
-    if (completion.options.closeOnUnfocus) {
-      var closingOnBlur;
-      cm.on("blur", this.onBlur = function() { closingOnBlur = setTimeout(function() { completion.close(); }, 100); });
-      cm.on("focus", this.onFocus = function() { clearTimeout(closingOnBlur); });
-    }
-
-    var startScroll = cm.getScrollInfo();
-    cm.on("scroll", this.onScroll = function() {
-      var curScroll = cm.getScrollInfo(), editor = cm.getWrapperElement().getBoundingClientRect();
-      var newTop = top + startScroll.top - curScroll.top;
-      var point = newTop - (window.pageYOffset || (document.documentElement || document.body).scrollTop);
-      if (!below) point += hints.offsetHeight;
-      if (point <= editor.top || point >= editor.bottom) return completion.close();
-      hints.style.top = newTop + "px";
-      hints.style.left = (left + startScroll.left - curScroll.left) + "px";
-    });
-
-    CodeMirror.on(hints, "dblclick", function(e) {
-      var t = getHintElement(hints, e.target || e.srcElement);
-      if (t && t.hintId != null) {widget.changeActive(t.hintId); widget.pick();}
-    });
-
-    CodeMirror.on(hints, "click", function(e) {
-      var t = getHintElement(hints, e.target || e.srcElement);
-      if (t && t.hintId != null) {
-        widget.changeActive(t.hintId);
-        if (completion.options.completeOnSingleClick) widget.pick();
-      }
-    });
-
-    CodeMirror.on(hints, "mousedown", function() {
-      setTimeout(function(){cm.focus();}, 20);
-    });
-
-    CodeMirror.signal(data, "select", completions[0], hints.firstChild);
-    return true;
-  }
-
-  Widget.prototype = {
-    close: function() {
-      if (this.completion.widget != this) return;
-      this.completion.widget = null;
-      this.hints.parentNode.removeChild(this.hints);
-      this.completion.cm.removeKeyMap(this.keyMap);
-
-      var cm = this.completion.cm;
-      if (this.completion.options.closeOnUnfocus) {
-        cm.off("blur", this.onBlur);
-        cm.off("focus", this.onFocus);
-      }
-      cm.off("scroll", this.onScroll);
-    },
-
-    pick: function() {
-      this.completion.pick(this.data, this.selectedHint);
-    },
-
-    changeActive: function(i, avoidWrap) {
-      if (i >= this.data.list.length)
-        i = avoidWrap ? this.data.list.length - 1 : 0;
-      else if (i < 0)
-        i = avoidWrap ? 0  : this.data.list.length - 1;
-      if (this.selectedHint == i) return;
-      var node = this.hints.childNodes[this.selectedHint];
-      node.className = node.className.replace(" " + ACTIVE_HINT_ELEMENT_CLASS, "");
-      node = this.hints.childNodes[this.selectedHint = i];
-      node.className += " " + ACTIVE_HINT_ELEMENT_CLASS;
-      if (node.offsetTop < this.hints.scrollTop)
-        this.hints.scrollTop = node.offsetTop - 3;
-      else if (node.offsetTop + node.offsetHeight > this.hints.scrollTop + this.hints.clientHeight)
-        this.hints.scrollTop = node.offsetTop + node.offsetHeight - this.hints.clientHeight + 3;
-      CodeMirror.signal(this.data, "select", this.data.list[this.selectedHint], node);
-    },
-
-    screenAmount: function() {
-      return Math.floor(this.hints.clientHeight / this.hints.firstChild.offsetHeight) || 1;
-    }
-  };
-
-  CodeMirror.registerHelper("hint", "auto", function(cm, options) {
-    var helpers = cm.getHelpers(cm.getCursor(), "hint"), words;
-    if (helpers.length) {
-      for (var i = 0; i < helpers.length; i++) {
-        var cur = helpers[i](cm, options);
-        if (cur && cur.list.length) return cur;
-      }
-    } else if (words = cm.getHelper(cm.getCursor(), "hintWords")) {
-      if (words) return CodeMirror.hint.fromList(cm, {words: words});
-    } else if (CodeMirror.hint.anyword) {
-      return CodeMirror.hint.anyword(cm, options);
-    }
-  });
-
-  CodeMirror.registerHelper("hint", "fromList", function(cm, options) {
-    var cur = cm.getCursor(), token = cm.getTokenAt(cur);
-    var found = [];
-    for (var i = 0; i < options.words.length; i++) {
-      var word = options.words[i];
-      if (word.slice(0, token.string.length) == token.string)
-        found.push(word);
-    }
-
-    if (found.length) return {
-      list: found,
-      from: CodeMirror.Pos(cur.line, token.start),
-            to: CodeMirror.Pos(cur.line, token.end)
-    };
-  });
-
-  CodeMirror.commands.autocomplete = CodeMirror.showHint;
-
-  var defaultOptions = {
-    hint: CodeMirror.hint.auto,
-    completeSingle: true,
-    alignWithWord: true,
-    closeCharacters: /[\s()\[\]{};:>,]/,
-    closeOnUnfocus: true,
-    completeOnSingleClick: false,
-    container: null,
-    customKeys: null,
-    extraKeys: null
-  };
-
-  CodeMirror.defineOption("hintOptions", null);
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/vendor/codemirror/sql-hint.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/vendor/codemirror/sql-hint.js b/contrib/views/hive/src/main/resources/ui/hive-web/vendor/codemirror/sql-hint.js
deleted file mode 100644
index 522f9e8..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/vendor/codemirror/sql-hint.js
+++ /dev/null
@@ -1,192 +0,0 @@
-// CodeMirror, copyright (c) by Marijn Haverbeke and others
-// Distributed under an MIT license: http://codemirror.net/LICENSE
-
-(function(mod) {
-  if (typeof exports == "object" && typeof module == "object") // CommonJS
-    mod(require("../../lib/codemirror"), require("../../mode/sql/sql"));
-  else if (typeof define == "function" && define.amd) // AMD
-    define(["../../lib/codemirror", "../../mode/sql/sql"], mod);
-  else // Plain browser env
-    mod(CodeMirror);
-})(function(CodeMirror) {
-  "use strict";
-
-  var tables;
-  var defaultTable;
-  var keywords;
-  var CONS = {
-    QUERY_DIV: ";",
-    ALIAS_KEYWORD: "AS"
-  };
-  var Pos = CodeMirror.Pos;
-
-  function getKeywords(editor) {
-    var mode = editor.doc.modeOption;
-    if (mode === "sql") mode = "text/x-sql";
-    return CodeMirror.resolveMode(mode).keywords;
-  }
-
-  function match(string, word) {
-    var len = string.length;
-    var sub = word.substr(0, len);
-    return string.toUpperCase() === sub.toUpperCase();
-  }
-
-  function addMatches(result, search, wordlist, formatter) {
-    for (var word in wordlist) {
-      if (!wordlist.hasOwnProperty(word)) continue;
-      if (Array.isArray(wordlist)) {
-        word = wordlist[word];
-      }
-      if (match(search, word)) {
-        result.push(formatter(word));
-      }
-    }
-  }
-
-  function nameCompletion(result, editor) {
-    var cur = editor.getCursor();
-    var token = editor.getTokenAt(cur);
-    var useBacktick = (token.string.charAt(0) == "`");
-    var string = token.string.substr(1);
-    var prevToken = editor.getTokenAt(Pos(cur.line, token.start));
-    if (token.string.charAt(0) == "." || prevToken.string == "."){
-      //Suggest colunm names
-      prevToken = prevToken.string == "." ? editor.getTokenAt(Pos(cur.line, token.start - 1)) : prevToken;
-      var table = prevToken.string;
-      //Check if backtick is used in table name. If yes, use it for columns too.
-      var useBacktickTable = false;
-      if (table.match(/`/g)) {
-        useBacktickTable = true;
-        table = table.replace(/`/g, "");
-      }
-      //Check if table is available. If not, find table by Alias
-      if (!tables.hasOwnProperty(table))
-        table = findTableByAlias(table, editor);
-      var columns = tables[table];
-      if (!columns) return;
-
-      if (useBacktick) {
-        addMatches(result, string, columns, function(w) {return "`" + w + "`";});
-      }
-      else if(useBacktickTable) {
-        addMatches(result, string, columns, function(w) {return ".`" + w + "`";});
-      }
-      else {
-        addMatches(result, string, columns, function(w) {return "." + w;});
-      }
-    }
-    else {
-      //Suggest table names or colums in defaultTable
-      while (token.start && string.charAt(0) == ".") {
-        token = editor.getTokenAt(Pos(cur.line, token.start - 1));
-        string = token.string + string;
-      }
-      if (useBacktick) {
-        addMatches(result, string, tables, function(w) {return "`" + w + "`";});
-        addMatches(result, string, defaultTable, function(w) {return "`" + w + "`";});
-      }
-      else {
-        addMatches(result, string, tables, function(w) {return w;});
-        addMatches(result, string, defaultTable, function(w) {return w;});
-      }
-    }
-  }
-
-  function eachWord(lineText, f) {
-    if (!lineText) return;
-    var excepted = /[,;]/g;
-    var words = lineText.split(" ");
-    for (var i = 0; i < words.length; i++) {
-      f(words[i]?words[i].replace(excepted, '') : '');
-    }
-  }
-
-  function convertCurToNumber(cur) {
-    // max characters of a line is 999,999.
-    return cur.line + cur.ch / Math.pow(10, 6);
-  }
-
-  function convertNumberToCur(num) {
-    return Pos(Math.floor(num), +num.toString().split('.').pop());
-  }
-
-  function findTableByAlias(alias, editor) {
-    var doc = editor.doc;
-    var fullQuery = doc.getValue();
-    var aliasUpperCase = alias.toUpperCase();
-    var previousWord = "";
-    var table = "";
-    var separator = [];
-    var validRange = {
-      start: Pos(0, 0),
-      end: Pos(editor.lastLine(), editor.getLineHandle(editor.lastLine()).length)
-    };
-
-    //add separator
-    var indexOfSeparator = fullQuery.indexOf(CONS.QUERY_DIV);
-    while(indexOfSeparator != -1) {
-      separator.push(doc.posFromIndex(indexOfSeparator));
-      indexOfSeparator = fullQuery.indexOf(CONS.QUERY_DIV, indexOfSeparator+1);
-    }
-    separator.unshift(Pos(0, 0));
-    separator.push(Pos(editor.lastLine(), editor.getLineHandle(editor.lastLine()).text.length));
-
-    //find valid range
-    var prevItem = 0;
-    var current = convertCurToNumber(editor.getCursor());
-    for (var i=0; i< separator.length; i++) {
-      var _v = convertCurToNumber(separator[i]);
-      if (current > prevItem && current <= _v) {
-        validRange = { start: convertNumberToCur(prevItem), end: convertNumberToCur(_v) };
-        break;
-      }
-      prevItem = _v;
-    }
-
-    var query = doc.getRange(validRange.start, validRange.end, false);
-
-    for (var i = 0; i < query.length; i++) {
-      var lineText = query[i];
-      eachWord(lineText, function(word) {
-        var wordUpperCase = word.toUpperCase();
-        if (wordUpperCase === aliasUpperCase && tables.hasOwnProperty(previousWord)) {
-            table = previousWord;
-        }
-        if (wordUpperCase !== CONS.ALIAS_KEYWORD) {
-          previousWord = word;
-        }
-      });
-      if (table) break;
-    }
-    return table;
-  }
-
-  CodeMirror.registerHelper("hint", "sql", function(editor, options) {
-    tables = (options && options.tables) || {};
-    var defaultTableName = options && options.defaultTable;
-    defaultTable = (defaultTableName && tables[defaultTableName] || []);
-    keywords = keywords || getKeywords(editor);
-
-    var cur = editor.getCursor();
-    var result = [];
-    var token = editor.getTokenAt(cur), start, end, search;
-    if (token.string.match(/^[.`\w@]\w*$/)) {
-      search = token.string;
-      start = token.start;
-      end = token.end;
-    } else {
-      start = end = cur.ch;
-      search = "";
-    }
-    if (search.charAt(0) == "." || search.charAt(0) == "`") {
-      nameCompletion(result, editor);
-    } else {
-      addMatches(result, search, tables, function(w) {return w;});
-      addMatches(result, search, defaultTable, function(w) {return w;});
-      addMatches(result, search, keywords, function(w) {return w.toUpperCase();});
-    }
-
-    return {list: result, from: Pos(cur.line, start), to: Pos(cur.line, end)};
-  });
-});


[23/23] ambari git commit: AMBARI-19302 : removed contrib/views/hive folder and made necessary changes in pom.xml files (nitirajrathore)

Posted by ni...@apache.org.
AMBARI-19302 : removed contrib/views/hive folder and made necessary changes in pom.xml files (nitirajrathore)


Project: http://git-wip-us.apache.org/repos/asf/ambari/repo
Commit: http://git-wip-us.apache.org/repos/asf/ambari/commit/c0f9621f
Tree: http://git-wip-us.apache.org/repos/asf/ambari/tree/c0f9621f
Diff: http://git-wip-us.apache.org/repos/asf/ambari/diff/c0f9621f

Branch: refs/heads/branch-2.5
Commit: c0f9621f2008aff2b71a7e7075c8e13cea05db87
Parents: ff9eb72
Author: Nitiraj Rathore <ni...@gmail.com>
Authored: Wed Dec 28 00:02:36 2016 +0530
Committer: Nitiraj Rathore <ni...@gmail.com>
Committed: Wed Dec 28 15:02:31 2016 +0530

----------------------------------------------------------------------
 contrib/views/hive/pom.xml                      | 386 --------
 .../apache/ambari/view/hive/BaseService.java    |  54 --
 .../apache/ambari/view/hive/HelpService.java    | 132 ---
 .../apache/ambari/view/hive/HiveViewImpl.java   |  50 -
 .../ambari/view/hive/PropertyValidator.java     | 113 ---
 .../org/apache/ambari/view/hive/TestBean.java   |  36 -
 .../backgroundjobs/BackgroundJobController.java |  90 --
 .../view/hive/client/ColumnDescription.java     |  48 -
 .../hive/client/ColumnDescriptionExtended.java  | 103 --
 .../hive/client/ColumnDescriptionShort.java     |  72 --
 .../ambari/view/hive/client/Connection.java     | 740 --------------
 .../view/hive/client/ConnectionFactory.java     | 166 ----
 .../apache/ambari/view/hive/client/Cursor.java  | 243 -----
 .../ambari/view/hive/client/DDLDelegator.java   | 140 ---
 .../view/hive/client/HiveAuthCredentials.java   |  31 -
 .../hive/client/HiveAuthRequiredException.java  |  27 -
 .../ambari/view/hive/client/HiveCall.java       | 120 ---
 .../client/HiveClientAuthRequiredException.java |  25 -
 .../view/hive/client/HiveClientException.java   |  25 -
 .../hive/client/HiveClientRuntimeException.java |  25 -
 .../hive/client/HiveErrorStatusException.java   |  30 -
 .../hive/client/HiveInvalidQueryException.java  |  27 -
 .../hive/client/HttpBasicAuthInterceptor.java   |  55 --
 .../client/HttpKerberosRequestInterceptor.java  |  72 --
 .../hive/client/HttpRequestInterceptorBase.java |  88 --
 .../ambari/view/hive/client/LogsCursor.java     |  36 -
 .../org/apache/ambari/view/hive/client/Row.java |  74 --
 .../view/hive/client/UserLocalConnection.java   |  48 -
 .../client/UserLocalHiveAuthCredentials.java    |  33 -
 .../apache/ambari/view/hive/client/Utils.java   | 141 ---
 .../view/hive/client/ViewSessionState.java      |  32 -
 .../view/hive/persistence/DataStoreStorage.java | 142 ---
 .../view/hive/persistence/IStorageFactory.java  |  23 -
 .../persistence/InstanceKeyValueStorage.java    | 135 ---
 .../view/hive/persistence/KeyValueStorage.java  | 163 ----
 .../hive/persistence/LocalKeyValueStorage.java  |  73 --
 .../persistence/PersistentConfiguration.java    |  52 -
 .../ambari/view/hive/persistence/Storage.java   |  77 --
 .../utils/ContextConfigurationAdapter.java      | 260 -----
 .../persistence/utils/FilteringStrategy.java    |  32 -
 .../view/hive/persistence/utils/Indexed.java    |  36 -
 .../hive/persistence/utils/ItemNotFound.java    |  43 -
 .../utils/OnlyOwnersFilteringStrategy.java      |  38 -
 .../view/hive/persistence/utils/Owned.java      |  36 -
 .../persistence/utils/PersonalResource.java     |  22 -
 .../hive/persistence/utils/StorageFactory.java  |  69 --
 .../hive/resources/CRUDResourceManager.java     | 131 ---
 .../view/hive/resources/IResourceManager.java   |  37 -
 .../resources/PersonalCRUDResourceManager.java  |  99 --
 .../resources/SharedCRUDResourceManager.java    |  44 -
 .../resources/browser/HiveBrowserService.java   | 276 ------
 .../view/hive/resources/files/FileResource.java |  70 --
 .../view/hive/resources/files/FileService.java  | 266 -----
 .../view/hive/resources/jobs/Aggregator.java    | 417 --------
 .../resources/jobs/ConnectionController.java    |  74 --
 .../hive/resources/jobs/FileResourceShort.java  |  55 --
 .../jobs/IOperationHandleResourceManager.java   |  40 -
 .../resources/jobs/JobResourceProvider.java     | 113 ---
 .../view/hive/resources/jobs/JobService.java    | 609 ------------
 .../view/hive/resources/jobs/LogParser.java     | 139 ---
 .../jobs/ModifyNotificationDelegate.java        |  23 -
 .../ModifyNotificationInvocationHandler.java    |  40 -
 .../jobs/NoOperationStatusSetException.java     |  23 -
 .../jobs/OperationHandleController.java         | 135 ---
 .../jobs/OperationHandleControllerFactory.java  |  43 -
 .../jobs/OperationHandleResourceManager.java    | 120 ---
 .../hive/resources/jobs/ProgressRetriever.java  |  67 --
 .../jobs/ResultsPaginationController.java       | 240 -----
 .../resources/jobs/StoredOperationHandle.java   | 146 ---
 .../hive/resources/jobs/atsJobs/ATSParser.java  | 248 -----
 .../jobs/atsJobs/ATSParserFactory.java          |  45 -
 .../jobs/atsJobs/ATSRequestsDelegate.java       |  47 -
 .../jobs/atsJobs/ATSRequestsDelegateImpl.java   | 175 ----
 .../resources/jobs/atsJobs/HiveQueryId.java     |  42 -
 .../hive/resources/jobs/atsJobs/IATSParser.java |  39 -
 .../hive/resources/jobs/atsJobs/TezDagId.java   |  26 -
 .../resources/jobs/atsJobs/TezVertexId.java     |  24 -
 .../view/hive/resources/jobs/rm/RMParser.java   | 129 ---
 .../hive/resources/jobs/rm/RMParserFactory.java |  49 -
 .../resources/jobs/rm/RMRequestsDelegate.java   |  31 -
 .../jobs/rm/RMRequestsDelegateImpl.java         | 100 --
 .../jobs/viewJobs/IJobControllerFactory.java    |  23 -
 .../view/hive/resources/jobs/viewJobs/Job.java  | 130 ---
 .../resources/jobs/viewJobs/JobController.java  |  53 -
 .../jobs/viewJobs/JobControllerFactory.java     |  41 -
 .../jobs/viewJobs/JobControllerImpl.java        | 401 --------
 .../hive/resources/jobs/viewJobs/JobImpl.java   | 323 -------
 .../hive/resources/jobs/viewJobs/JobInfo.java   |  78 --
 .../jobs/viewJobs/JobResourceManager.java       | 107 --
 .../resources/resources/FileResourceItem.java   |  78 --
 .../resources/FileResourceResourceManager.java  |  65 --
 .../resources/FileResourceResourceProvider.java | 110 ---
 .../resources/FileResourceService.java          | 180 ----
 .../hive/resources/savedQueries/SavedQuery.java |  96 --
 .../savedQueries/SavedQueryResourceManager.java | 162 ----
 .../SavedQueryResourceProvider.java             | 113 ---
 .../savedQueries/SavedQueryService.java         | 266 -----
 .../ambari/view/hive/resources/udfs/UDF.java    |  87 --
 .../hive/resources/udfs/UDFResourceManager.java |  65 --
 .../resources/udfs/UDFResourceProvider.java     | 111 ---
 .../view/hive/resources/udfs/UDFService.java    | 193 ----
 .../view/hive/resources/uploads/CSVParams.java  |  74 --
 .../uploads/ColumnDescriptionImpl.java          | 142 ---
 .../hive/resources/uploads/HiveFileType.java    |  30 -
 .../hive/resources/uploads/TableDataReader.java | 111 ---
 .../view/hive/resources/uploads/TableInput.java |  51 -
 .../resources/uploads/UploadFromHdfsInput.java  | 130 ---
 .../hive/resources/uploads/UploadService.java   | 556 -----------
 .../resources/uploads/parsers/DataParser.java   |  66 --
 .../uploads/parsers/EndOfDocumentException.java |  41 -
 .../hive/resources/uploads/parsers/IParser.java |  32 -
 .../resources/uploads/parsers/ParseOptions.java |  61 --
 .../resources/uploads/parsers/ParseUtils.java   | 213 ----
 .../hive/resources/uploads/parsers/Parser.java  | 161 ----
 .../resources/uploads/parsers/PreviewData.java  |  56 --
 .../resources/uploads/parsers/RowIterator.java  |  98 --
 .../uploads/parsers/RowMapIterator.java         |  29 -
 .../parsers/csv/commonscsv/CSVIterator.java     |  57 --
 .../parsers/csv/commonscsv/CSVParser.java       |  88 --
 .../parsers/csv/opencsv/OpenCSVIterator.java    |  56 --
 .../parsers/csv/opencsv/OpenCSVParser.java      |  92 --
 .../uploads/parsers/json/JSONIterator.java      | 160 ---
 .../uploads/parsers/json/JSONParser.java        |  85 --
 .../uploads/parsers/xml/XMLIterator.java        | 195 ----
 .../uploads/parsers/xml/XMLParser.java          | 100 --
 .../uploads/query/DeleteQueryInput.java         |  48 -
 .../uploads/query/InsertFromQueryInput.java     |  92 --
 .../resources/uploads/query/LoadQueryInput.java |  67 --
 .../resources/uploads/query/QueryGenerator.java | 142 ---
 .../hive/resources/uploads/query/RowFormat.java |  57 --
 .../hive/resources/uploads/query/TableInfo.java |  96 --
 .../utils/BadRequestFormattedException.java     |  27 -
 .../ambari/view/hive/utils/FilePaginator.java   | 127 ---
 .../utils/HiveClientFormattedException.java     |  26 -
 .../MisconfigurationFormattedException.java     |  47 -
 .../hive/utils/NotFoundFormattedException.java  |  27 -
 .../hive/utils/ServiceFormattedException.java   | 107 --
 .../view/hive/utils/SharedObjectsFactory.java   | 187 ----
 .../src/main/resources/ui/hive-web/.bowerrc     |   4 -
 .../main/resources/ui/hive-web/.editorconfig    |  34 -
 .../src/main/resources/ui/hive-web/.ember-cli   |  27 -
 .../src/main/resources/ui/hive-web/.gitignore   |  37 -
 .../src/main/resources/ui/hive-web/.jshintrc    |  33 -
 .../src/main/resources/ui/hive-web/.travis.yml  |  38 -
 .../src/main/resources/ui/hive-web/Brocfile.js  |  54 --
 .../src/main/resources/ui/hive-web/README.md    |  14 -
 .../ui/hive-web/app/adapters/application.js     |  54 --
 .../ui/hive-web/app/adapters/database.js        |  25 -
 .../ui/hive-web/app/adapters/file-upload.js     |  30 -
 .../resources/ui/hive-web/app/adapters/file.js  |  26 -
 .../ui/hive-web/app/adapters/upload-table.js    |  89 --
 .../src/main/resources/ui/hive-web/app/app.js   |  34 -
 .../ui/hive-web/app/components/.gitkeep         |   0
 .../app/components/alert-message-widget.js      |  35 -
 .../app/components/collapsible-widget.js        |  38 -
 .../app/components/column-filter-widget.js      |  56 --
 .../app/components/date-range-widget.js         |  98 --
 .../hive-web/app/components/expander-widget.js  |  36 -
 .../hive-web/app/components/extended-input.js   |  50 -
 .../ui/hive-web/app/components/file-upload.js   |  34 -
 .../ui/hive-web/app/components/input-header.js  |  61 --
 .../ui/hive-web/app/components/job-tr-view.js   |  41 -
 .../ui/hive-web/app/components/modal-widget.js  |  58 --
 .../ui/hive-web/app/components/navbar-widget.js |  42 -
 .../ui/hive-web/app/components/no-bubbling.js   |  31 -
 .../ui/hive-web/app/components/notify-widget.js |  31 -
 .../app/components/number-range-widget.js       |  79 --
 .../ui/hive-web/app/components/panel-widget.js  |  30 -
 .../hive-web/app/components/popover-widget.js   |  34 -
 .../hive-web/app/components/progress-widget.js  |  30 -
 .../ui/hive-web/app/components/query-editor.js  | 129 ---
 .../ui/hive-web/app/components/radio-button.js  |  39 -
 .../ui/hive-web/app/components/select-widget.js |  66 --
 .../ui/hive-web/app/components/tabs-widget.js   |  68 --
 .../ui/hive-web/app/components/tree-view.js     |  23 -
 .../hive-web/app/components/typeahead-widget.js | 108 ---
 .../ui/hive-web/app/components/udf-tr-view.js   |  81 --
 .../ui/hive-web/app/components/upload-query.js  |  32 -
 .../app/components/validated-text-field.js      |  62 --
 .../app/components/visualization-tabs-widget.js |  56 --
 .../ui/hive-web/app/controllers/.gitkeep        |   0
 .../ui/hive-web/app/controllers/application.js  |  26 -
 .../ui/hive-web/app/controllers/databases.js    | 465 ---------
 .../ui/hive-web/app/controllers/history.js      | 257 -----
 .../ui/hive-web/app/controllers/index.js        | 767 ---------------
 .../controllers/index/history-query/explain.js  | 142 ---
 .../app/controllers/index/history-query/logs.js | 108 ---
 .../controllers/index/history-query/results.js  | 238 -----
 .../ui/hive-web/app/controllers/insert-udfs.js  |  58 --
 .../ui/hive-web/app/controllers/messages.js     |  41 -
 .../ui/hive-web/app/controllers/modal-delete.js |  33 -
 .../app/controllers/modal-save-query.js         |  42 -
 .../ui/hive-web/app/controllers/modal-save.js   |  34 -
 .../ui/hive-web/app/controllers/open-queries.js | 400 --------
 .../ui/hive-web/app/controllers/queries.js      | 145 ---
 .../ui/hive-web/app/controllers/query-tabs.js   | 176 ----
 .../ui/hive-web/app/controllers/settings.js     |  69 --
 .../ui/hive-web/app/controllers/splash.js       | 164 ----
 .../ui/hive-web/app/controllers/tez-ui.js       | 106 --
 .../ui/hive-web/app/controllers/udfs.js         | 143 ---
 .../ui/hive-web/app/controllers/upload-table.js | 965 -------------------
 .../hive-web/app/controllers/visual-explain.js  |  64 --
 .../app/controllers/visualization-ui.js         | 134 ---
 .../resources/ui/hive-web/app/helpers/.gitkeep  |   0
 .../ui/hive-web/app/helpers/all-uppercase.js    |  25 -
 .../ui/hive-web/app/helpers/code-helper.js      |  28 -
 .../ui/hive-web/app/helpers/date-binding.js     |  27 -
 .../hive-web/app/helpers/format-column-type.js  |  39 -
 .../ui/hive-web/app/helpers/log-helper.js       |  28 -
 .../ui/hive-web/app/helpers/path-binding.js     |  29 -
 .../hive-web/app/helpers/preformatted-string.js |  28 -
 .../ui/hive-web/app/helpers/tb-helper.js        |  33 -
 .../main/resources/ui/hive-web/app/index.html   |  42 -
 .../ui/hive-web/app/initializers/i18n.js        | 348 -------
 .../ui/hive-web/app/mixins/filterable.js        | 106 --
 .../ui/hive-web/app/mixins/sortable.js          |  31 -
 .../resources/ui/hive-web/app/models/.gitkeep   |   0
 .../ui/hive-web/app/models/database.js          |  25 -
 .../ui/hive-web/app/models/file-resource.js     |  25 -
 .../resources/ui/hive-web/app/models/file.js    |  26 -
 .../resources/ui/hive-web/app/models/job.js     |  55 --
 .../ui/hive-web/app/models/saved-query.js       |  29 -
 .../resources/ui/hive-web/app/models/udf.js     |  27 -
 .../main/resources/ui/hive-web/app/router.js    |  50 -
 .../resources/ui/hive-web/app/routes/.gitkeep   |   0
 .../ui/hive-web/app/routes/application.js       |  89 --
 .../resources/ui/hive-web/app/routes/history.js |  29 -
 .../app/routes/index/history-query/explain.js   |  28 -
 .../app/routes/index/history-query/index.js     |  44 -
 .../app/routes/index/history-query/logs.js      |  28 -
 .../app/routes/index/history-query/results.js   |  28 -
 .../ui/hive-web/app/routes/index/index.js       |  36 -
 .../ui/hive-web/app/routes/index/saved-query.js |  43 -
 .../resources/ui/hive-web/app/routes/loading.js |  22 -
 .../resources/ui/hive-web/app/routes/queries.js |  40 -
 .../resources/ui/hive-web/app/routes/splash.js  |  61 --
 .../resources/ui/hive-web/app/routes/udfs.js    |  36 -
 .../ui/hive-web/app/serializers/database.js     |  41 -
 .../ui/hive-web/app/serializers/file.js         |  23 -
 .../ui/hive-web/app/services/database.js        | 243 -----
 .../resources/ui/hive-web/app/services/file.js  |  59 --
 .../ui/hive-web/app/services/history.js         | 204 ----
 .../ui/hive-web/app/services/job-progress.js    | 102 --
 .../resources/ui/hive-web/app/services/job.js   |  56 --
 .../app/services/ldap-authentication.js         |  41 -
 .../ui/hive-web/app/services/notify.js          | 113 ---
 .../ui/hive-web/app/services/session.js         |  48 -
 .../ui/hive-web/app/services/settings.js        | 193 ----
 .../resources/ui/hive-web/app/styles/.gitkeep   |   0
 .../resources/ui/hive-web/app/styles/app.scss   | 716 --------------
 .../hive-web/app/styles/dropdown-submenu.scss   |  65 --
 .../ui/hive-web/app/styles/mixins.scss          |  28 -
 .../ui/hive-web/app/styles/notifications.scss   |  37 -
 .../ui/hive-web/app/styles/query-tabs.scss      |  69 --
 .../resources/ui/hive-web/app/styles/vars.scss  |  21 -
 .../ui/hive-web/app/templates/.gitkeep          |   0
 .../ui/hive-web/app/templates/application.hbs   |  26 -
 .../hive-web/app/templates/components/.gitkeep  |   0
 .../components/alert-message-widget.hbs         |  28 -
 .../templates/components/collapsible-widget.hbs |  33 -
 .../components/column-filter-widget.hbs         |  42 -
 .../templates/components/date-range-widget.hbs  |  22 -
 .../templates/components/expander-widget.hbs    |  31 -
 .../app/templates/components/input-header.hbs   |  20 -
 .../app/templates/components/job-tr-view.hbs    |  49 -
 .../app/templates/components/modal-widget.hbs   |  35 -
 .../app/templates/components/navbar-widget.hbs  |  45 -
 .../app/templates/components/no-bubbling.hbs    |  19 -
 .../app/templates/components/notify-widget.hbs  |  21 -
 .../components/number-range-widget.hbs          |  23 -
 .../app/templates/components/panel-widget.hbs   |  54 --
 .../app/templates/components/popover-widget.hbs |  19 -
 .../templates/components/progress-widget.hbs    |  23 -
 .../app/templates/components/query-editor.hbs   |  19 -
 .../app/templates/components/select-widget.hbs  |  39 -
 .../app/templates/components/tabs-widget.hbs    |  41 -
 .../app/templates/components/tree-view.hbs      |  28 -
 .../app/templates/components/udf-tr-view.hbs    |  77 --
 .../components/validated-text-field.hbs         |  23 -
 .../components/visualization-tabs-widget.hbs    |  27 -
 .../app/templates/databases-search-results.hbs  |  54 --
 .../hive-web/app/templates/databases-tree.hbs   |  50 -
 .../ui/hive-web/app/templates/databases.hbs     |  54 --
 .../ui/hive-web/app/templates/history.hbs       |  67 --
 .../ui/hive-web/app/templates/index.hbs         | 134 ---
 .../templates/index/history-query/explain.hbs   |  27 -
 .../app/templates/index/history-query/logs.hbs  |  19 -
 .../templates/index/history-query/results.hbs   |  56 --
 .../ui/hive-web/app/templates/insert-udfs.hbs   |  46 -
 .../ui/hive-web/app/templates/loading.hbs       |  19 -
 .../ui/hive-web/app/templates/logs.hbs          |  19 -
 .../ui/hive-web/app/templates/message.hbs       |  36 -
 .../ui/hive-web/app/templates/messages.hbs      |  32 -
 .../ui/hive-web/app/templates/modal-delete.hbs  |  21 -
 .../hive-web/app/templates/modal-save-query.hbs |  24 -
 .../ui/hive-web/app/templates/modal-save.hbs    |  21 -
 .../ui/hive-web/app/templates/notification.hbs  |  23 -
 .../ui/hive-web/app/templates/open-queries.hbs  |  23 -
 .../ui/hive-web/app/templates/queries.hbs       |  96 --
 .../ui/hive-web/app/templates/query-tabs.hbs    |  28 -
 .../ui/hive-web/app/templates/redirect.hbs      |  19 -
 .../ui/hive-web/app/templates/settings.hbs      |  70 --
 .../ui/hive-web/app/templates/splash.hbs        | 117 ---
 .../ui/hive-web/app/templates/tez-ui.hbs        |  31 -
 .../ui/hive-web/app/templates/udfs.hbs          |  53 -
 .../ui/hive-web/app/templates/upload-table.hbs  | 296 ------
 .../hive-web/app/templates/visual-explain.hbs   |  93 --
 .../hive-web/app/templates/visualization-ui.hbs |  37 -
 .../ui/hive-web/app/transforms/date.js          |  49 -
 .../ui/hive-web/app/utils/constants.js          | 230 -----
 .../ui/hive-web/app/utils/dag-rules.js          | 141 ---
 .../ui/hive-web/app/utils/functions.js          | 139 ---
 .../resources/ui/hive-web/app/views/.gitkeep    |   0
 .../resources/ui/hive-web/app/views/index.js    |  28 -
 .../resources/ui/hive-web/app/views/message.js  |  36 -
 .../resources/ui/hive-web/app/views/messages.js |  37 -
 .../ui/hive-web/app/views/notification.js       |  51 -
 .../resources/ui/hive-web/app/views/tez-ui.js   |  37 -
 .../ui/hive-web/app/views/visual-explain.js     | 461 ---------
 .../ui/hive-web/app/views/visualization-ui.js   |  37 -
 .../main/resources/ui/hive-web/big_tables.js    |  54 --
 .../src/main/resources/ui/hive-web/bower.json   |  28 -
 .../resources/ui/hive-web/config/environment.js |  70 --
 .../src/main/resources/ui/hive-web/package.json |  47 -
 .../src/main/resources/ui/hive-web/testem.json  |  10 -
 .../main/resources/ui/hive-web/tests/.jshintrc  |  74 --
 .../ui/hive-web/tests/blanket-options.js        |  36 -
 .../ui/hive-web/tests/helpers/api-mock.js       | 304 ------
 .../ui/hive-web/tests/helpers/dbclick.js        |  26 -
 .../ui/hive-web/tests/helpers/resolver.js       |  29 -
 .../ui/hive-web/tests/helpers/start-app.js      |  43 -
 .../resources/ui/hive-web/tests/img/spinner.gif | Bin 11435 -> 0 bytes
 .../main/resources/ui/hive-web/tests/index.html |  71 --
 .../hive-web/tests/integration/database-test.js | 130 ---
 .../hive-web/tests/integration/history-test.js  |  95 --
 .../tests/integration/query-editor-test.js      | 126 ---
 .../tests/integration/saved-queries-test.js     | 152 ---
 .../hive-web/tests/integration/tez-ui-test.js   |  49 -
 .../ui/hive-web/tests/integration/udfs-test.js  | 109 ---
 .../resources/ui/hive-web/tests/test-helper.js  |  24 -
 .../resources/ui/hive-web/tests/unit/.gitkeep   |   0
 .../hive-web/tests/unit/adapters/application.js |  48 -
 .../ui/hive-web/tests/unit/adapters/file.js     |  39 -
 .../components/alert-message-widget-test.js     |  91 --
 .../unit/components/collapsible-widget-test.js  |  46 -
 .../components/column-filter-widget-test.js     | 138 ---
 .../unit/components/date-range-widget-test.js   | 132 ---
 .../unit/components/expander-widget-test.js     |  59 --
 .../unit/components/extended-input-test.js      |  81 --
 .../tests/unit/components/job-tr-view-test.js   |  62 --
 .../tests/unit/components/modal-widget-test.js  |  69 --
 .../tests/unit/components/no-bubbling-test.js   |  44 -
 .../unit/components/number-range-widget-test.js |  70 --
 .../unit/components/popover-widget-test.js      |  36 -
 .../unit/components/progress-widget-test.js     |  40 -
 .../tests/unit/components/query-editor-test.js  |  52 -
 .../tests/unit/components/select-widget-test.js | 158 ---
 .../tests/unit/components/tabs-wiget-test.js    | 117 ---
 .../unit/components/typeahead-widget-test.js    |  46 -
 .../tests/unit/components/udf-tr-view-test.js   | 122 ---
 .../tests/unit/controllers/databases-test.js    | 276 ------
 .../tests/unit/controllers/history-test.js      | 117 ---
 .../tests/unit/controllers/index-test.js        | 328 -------
 .../tests/unit/controllers/insert-udfs-test.js  |  68 --
 .../tests/unit/controllers/messages-test.js     |  53 -
 .../tests/unit/controllers/open-queries-test.js | 102 --
 .../tests/unit/controllers/queries-test.js      |  35 -
 .../tests/unit/controllers/settings-test.js     | 136 ---
 .../tests/unit/controllers/tez-ui-test.js       |  98 --
 .../tests/unit/controllers/udfs-test.js         |  82 --
 .../tests/unit/helpers/path-binding-test.js     |  35 -
 .../hive-web/tests/unit/services/notify-test.js | 155 ---
 .../tests/unit/services/settings-test.js        | 155 ---
 .../tests/unit/views/visual-explain-test.js     | 106 --
 .../main/resources/ui/hive-web/vendor/.gitkeep  |   0
 .../vendor/codemirror/codemirror-min.js         |  17 -
 .../hive-web/vendor/codemirror/codemirror.css   | 309 ------
 .../ui/hive-web/vendor/codemirror/show-hint.css |  38 -
 .../ui/hive-web/vendor/codemirror/show-hint.js  | 389 --------
 .../ui/hive-web/vendor/codemirror/sql-hint.js   | 192 ----
 .../resources/ui/hive-web/vendor/dagre.min.js   |  27 -
 .../src/main/resources/view.log4j.properties    |  27 -
 contrib/views/hive/src/main/resources/view.xml  | 347 -------
 .../apache/ambari/view/hive/BaseHiveTest.java   | 116 ---
 .../org/apache/ambari/view/hive/HDFSTest.java   |  64 --
 .../ambari/view/hive/PropertyValidatorTest.java | 112 ---
 .../ambari/view/hive/ServiceTestUtils.java      |  63 --
 .../BackgroundJobControllerTest.java            |  77 --
 .../ambari/view/hive/client/ConnectionTest.java |  73 --
 .../ambari/view/hive/client/UtilsTest.java      |  78 --
 .../hive/resources/files/FileServiceTest.java   | 273 ------
 .../view/hive/resources/jobs/ATSParserTest.java | 512 ----------
 .../hive/resources/jobs/AggregatorTest.java     | 506 ----------
 .../hive/resources/jobs/JobLDAPServiceTest.java | 159 ---
 .../hive/resources/jobs/JobServiceTest.java     | 225 -----
 .../view/hive/resources/jobs/LogParserTest.java |  73 --
 .../resources/FileResourceServiceTest.java      | 119 ---
 .../SavedQueryResourceManagerTest.java          |  55 --
 .../savedQueries/SavedQueryServiceTest.java     | 191 ----
 .../hive/resources/udfs/UDFServiceTest.java     | 119 ---
 .../hive/resources/upload/CSVParserTest.java    | 275 ------
 .../resources/upload/DataParserCSVTest.java     | 326 -------
 .../resources/upload/DataParserJSONTest.java    | 263 -----
 .../resources/upload/DataParserXMLTest.java     | 295 ------
 .../hive/resources/upload/JsonParserTest.java   | 147 ---
 .../resources/upload/OpenCSVParserTest.java     | 333 -------
 .../view/hive/resources/upload/OpenCSVTest.java | 259 -----
 .../hive/resources/upload/ParseUtilsTest.java   |  56 --
 .../resources/upload/QueryGeneratorTest.java    | 108 ---
 .../resources/upload/TableDataReaderTest.java   | 127 ---
 .../hive/resources/upload/XMLParserTest.java    | 138 ---
 .../ambari/view/hive/utils/HdfsApiMock.java     |  86 --
 .../utils/SeekableByteArrayInputStream.java     |  71 --
 contrib/views/pom.xml                           |   4 -
 pom.xml                                         |   2 -
 415 files changed, 39988 deletions(-)
----------------------------------------------------------------------


http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/pom.xml
----------------------------------------------------------------------
diff --git a/contrib/views/hive/pom.xml b/contrib/views/hive/pom.xml
deleted file mode 100644
index b224fb3b..0000000
--- a/contrib/views/hive/pom.xml
+++ /dev/null
@@ -1,386 +0,0 @@
-<!--
-   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.
--->
-<project xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://maven.apache.org/POM/4.0.0"
-         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
-  <modelVersion>4.0.0</modelVersion>
-  <groupId>org.apache.ambari.contrib.views</groupId>
-  <artifactId>hive</artifactId>
-  <version>1.0.0.0-SNAPSHOT</version>
-  <name>Hive</name>
-
-  <parent>
-    <groupId>org.apache.ambari.contrib.views</groupId>
-    <artifactId>ambari-contrib-views</artifactId>
-    <version>2.5.0.0.0</version>
-  </parent>
-
-  <dependencies>
-    <dependency>
-      <groupId>com.jayway.jsonpath</groupId>
-      <artifactId>json-path</artifactId>
-      <version>2.0.0</version>
-    </dependency>
-      <dependency>
-      <groupId>com.google.inject</groupId>
-      <artifactId>guice</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>com.sun.jersey.contribs</groupId>
-      <artifactId>jersey-multipart</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>com.sun.jersey</groupId>
-      <artifactId>jersey-client</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>com.sun.jersey</groupId>
-      <artifactId>jersey-core</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>com.sun.jersey</groupId>
-      <artifactId>jersey-json</artifactId>
-    </dependency>
-    <dependency>
-      <groupId>com.googlecode.json-simple</groupId>
-      <artifactId>json-simple</artifactId>
-      <version>1.1.1</version>
-    </dependency>
-    <dependency>
-      <groupId>commons-configuration</groupId>
-      <artifactId>commons-configuration</artifactId>
-      <version>1.6</version>
-    </dependency>
-    <dependency>
-      <groupId>com.opencsv</groupId>
-      <artifactId>opencsv</artifactId>
-      <version>3.8</version>
-    </dependency>
-    <dependency>
-      <groupId>org.apache.commons</groupId>
-      <artifactId>commons-collections4</artifactId>
-      <version>4.0</version>
-    </dependency>
-    <dependency>
-      <groupId>org.apache.ambari</groupId>
-      <artifactId>ambari-views</artifactId>
-      <scope>provided</scope>
-    </dependency>
-    <dependency>
-      <groupId>com.google.code.gson</groupId>
-      <artifactId>gson</artifactId>
-      <version>2.2.2</version>
-    </dependency>
-    <dependency>
-      <groupId>javax.servlet</groupId>
-      <artifactId>javax.servlet-api</artifactId>
-      <version>3.0.1</version>
-    </dependency>
-    <dependency>
-      <groupId>org.slf4j</groupId>
-      <artifactId>slf4j-api</artifactId>
-      <version>1.7.5</version>
-    </dependency>
-    <dependency>
-      <groupId>org.apache.hadoop</groupId>
-      <artifactId>hadoop-hdfs</artifactId>
-      <version>${hadoop.version}</version>
-        <exclusions>
-            <exclusion>
-                <groupId>tomcat</groupId>
-                <artifactId>jasper-runtime</artifactId>
-            </exclusion>
-        </exclusions>
-    </dependency>
-    <dependency>
-      <groupId>org.apache.hadoop</groupId>
-      <artifactId>hadoop-common</artifactId>
-      <version>${hadoop.version}</version>
-        <exclusions>
-          <exclusion>
-            <groupId>tomcat</groupId>
-            <artifactId>jasper-runtime</artifactId>
-          </exclusion>
-          <exclusion>
-            <groupId>tomcat</groupId>
-            <artifactId>jasper-compiler</artifactId>
-          </exclusion>
-        </exclusions>
-    </dependency>
-    <dependency>
-      <groupId>org.apache.hadoop</groupId>
-      <artifactId>hadoop-mapreduce-client-common</artifactId>
-      <version>${hadoop.version}</version>
-    </dependency>
-    <dependency>
-      <groupId>org.apache.hadoop</groupId>
-      <artifactId>hadoop-mapreduce-client-core</artifactId>
-      <version>${hadoop.version}</version>
-    </dependency>
-    <dependency>
-      <groupId>org.apache.hadoop</groupId>
-      <artifactId>hadoop-yarn-client</artifactId>
-      <version>${hadoop.version}</version>
-    </dependency>
-    <dependency>
-      <groupId>javax.ws.rs</groupId>
-      <artifactId>javax.ws.rs-api</artifactId>
-      <version>2.0</version>
-    </dependency>
-    <dependency>
-      <groupId>org.apache.hive</groupId>
-      <artifactId>hive-service</artifactId>
-      <version>${hive-version}</version>
-    </dependency>
-    <dependency>
-      <groupId>org.apache.hive</groupId>
-      <artifactId>hive-common</artifactId>
-      <version>${hive-version}</version>
-    </dependency>
-    <dependency>
-      <groupId>org.apache.hive</groupId>
-      <artifactId>hive-shims</artifactId>
-      <version>${hive-version}</version>
-    </dependency>
-    <dependency>
-      <groupId>org.apache.hive</groupId>
-      <artifactId>hive-metastore</artifactId>
-      <version>${hive-version}</version>
-    </dependency>
-    <dependency>
-      <groupId>org.apache.hive</groupId>
-      <artifactId>hive-exec</artifactId>
-      <version>${hive-version}</version>
-    </dependency>
-    <dependency>
-      <groupId>commons-cli</groupId>
-      <artifactId>commons-cli</artifactId>
-      <version>1.2</version>
-    </dependency>
-    <dependency>
-      <groupId>commons-lang</groupId>
-      <artifactId>commons-lang</artifactId>
-      <version>2.2</version>
-    </dependency>
-    <dependency>
-      <groupId>org.apache.thrift</groupId>
-      <artifactId>libthrift</artifactId>
-      <version>0.9.0</version>
-    </dependency>
-    <dependency>
-      <groupId>junit</groupId>
-      <artifactId>junit</artifactId>
-      <scope>test</scope>
-    </dependency>
-    <dependency>
-      <groupId>org.easymock</groupId>
-      <artifactId>easymock</artifactId>
-      <scope>test</scope>
-    </dependency>
-    <dependency>
-      <groupId>org.apache.hadoop</groupId>
-      <artifactId>hadoop-minicluster</artifactId>
-      <version>${hadoop.version}</version>
-      <scope>test</scope>
-    </dependency>
-    <dependency>
-      <groupId>org.apache.ambari.contrib.views</groupId>
-      <artifactId>ambari-views-utils</artifactId>
-      <version>2.5.0.0.0</version>
-    </dependency>
-    <dependency>
-      <groupId>commons-validator</groupId>
-      <artifactId>commons-validator</artifactId>
-      <version>1.4.0</version>
-    </dependency>
-    <dependency>
-      <groupId>commons-io</groupId>
-      <artifactId>commons-io</artifactId>
-      <version>2.4</version>
-    </dependency>
-    <dependency>
-      <groupId>org.apache.httpcomponents</groupId>
-      <artifactId>httpclient</artifactId>
-      <version>4.5.2</version>
-    </dependency>
-    <dependency>
-      <groupId>org.apache.httpcomponents</groupId>
-      <artifactId>httpcore</artifactId>
-      <version>4.4.3</version>
-    </dependency>
-    <dependency>
-      <groupId>org.apache.commons</groupId>
-      <artifactId>commons-csv</artifactId>
-      <version>1.1</version>
-    </dependency>
-    <dependency>
-      <groupId>org.apache.ambari.contrib.views</groupId>
-      <artifactId>ambari-views-commons</artifactId>
-      <version>2.5.0.0.0</version>
-    </dependency>
-  </dependencies>
-
-  <properties>
-    <ambari.dir>${project.parent.parent.parent.basedir}</ambari.dir>
-    <hive-version>1.0.0</hive-version>
-    <ambari.version>2.5.0.0.0</ambari.version>
-  </properties>
-  <build>
-    <plugins>
-
-      <!-- Building frontend -->
-      <plugin>
-        <groupId>com.github.eirslett</groupId>
-        <artifactId>frontend-maven-plugin</artifactId>
-        <version>0.0.16</version>
-        <configuration>
-          <nodeVersion>v4.5.0</nodeVersion>
-          <npmVersion>2.15.0</npmVersion>
-          <workingDirectory>src/main/resources/ui/hive-web/</workingDirectory>
-        </configuration>
-        <executions>
-          <execution>
-            <id>install node and npm</id>
-            <phase>generate-sources</phase>
-            <goals>
-              <goal>install-node-and-npm</goal>
-            </goals>
-          </execution>
-          <execution>
-            <id>npm install</id>
-            <phase>generate-sources</phase>
-            <goals>
-              <goal>npm</goal>
-            </goals>
-            <configuration>
-              <arguments>install --python="${project.basedir}/../src/main/unix/ambari-python-wrap" --unsafe-perm</arguments>
-            </configuration>
-          </execution>
-        </executions>
-      </plugin>
-      <plugin>
-        <artifactId>exec-maven-plugin</artifactId>
-        <groupId>org.codehaus.mojo</groupId>
-        <version>1.3.2</version>
-        <executions>
-          <execution>
-            <id>Hive build</id>
-            <phase>generate-sources</phase>
-            <goals>
-              <goal>exec</goal>
-            </goals>
-            <configuration>
-              <workingDirectory>${basedir}/src/main/resources/ui/hive-web</workingDirectory>
-              <executable>node/node</executable>
-              <arguments>
-                <argument>node_modules/.bin/ember</argument>
-                <argument>build</argument>
-              </arguments>
-            </configuration>
-          </execution>
-        </executions>
-      </plugin>
-      <plugin>
-        <groupId>org.apache.maven.plugins</groupId>
-        <artifactId>maven-compiler-plugin</artifactId>
-        <version>3.1</version>
-        <configuration>
-          <source>1.7</source>
-          <target>1.7</target>
-        </configuration>
-      </plugin>
-      <plugin>
-        <artifactId>maven-dependency-plugin</artifactId>
-        <executions>
-          <execution>
-            <phase>generate-resources</phase>
-            <goals>
-              <goal>copy-dependencies</goal>
-            </goals>
-            <configuration>
-              <outputDirectory>${project.build.directory}/lib</outputDirectory>
-              <includeScope>runtime</includeScope>
-            </configuration>
-          </execution>
-          <execution>
-            <id>copy-artifact</id>
-            <phase>package</phase>
-            <goals>
-              <goal>copy</goal>
-            </goals>
-            <configuration>
-              <artifactItems>
-                <artifactItem>
-                  <groupId>${project.groupId}</groupId>
-                  <artifactId>${project.artifactId}</artifactId>
-                  <version>${project.version}</version>
-                  <type>${project.packaging}</type>
-                </artifactItem>
-              </artifactItems>
-              <outputDirectory>${views.jars.dir.rel}</outputDirectory>
-            </configuration>
-          </execution>
-        </executions>
-      </plugin>
-      <plugin>
-       <groupId>org.vafer</groupId>
-       <artifactId>jdeb</artifactId>
-       <version>1.0.1</version>
-       <executions>
-           <execution>
-               <phase>none</phase>
-               <goals>
-                   <goal>jdeb</goal>
-               </goals>
-           </execution>
-       </executions>
-       <configuration>
-           <submodules>false</submodules>
-       </configuration>
-     </plugin>
-    </plugins>
-    <resources>
-      <resource>
-        <directory>src/main/resources</directory>
-        <filtering>false</filtering>
-        <includes>
-          <include>META-INF/**/*</include>
-          <include>view.xml</include>
-          <include>view.log4j.properties</include>
-        </includes>
-      </resource>
-      <resource>
-        <directory>src/main/resources/ui/hive-web/dist</directory>
-        <filtering>false</filtering>
-      </resource>
-      <resource>
-        <directory>src/main/resources/ui/hive-web/bower_components/polestar</directory>
-        <filtering>false</filtering>
-        <targetPath>polestar</targetPath>
-      </resource>
-      <resource>
-        <directory>src/main/resources/ui/hive-web/bower_components/voyager</directory>
-        <filtering>false</filtering>
-        <targetPath>voyager</targetPath>
-      </resource>
-      <resource>
-        <targetPath>WEB-INF/lib</targetPath>
-        <filtering>false</filtering>
-        <directory>target/lib</directory>
-      </resource>
-    </resources>
-  </build>
-</project>

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/BaseService.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/BaseService.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/BaseService.java
deleted file mode 100644
index d29d758..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/BaseService.java
+++ /dev/null
@@ -1,54 +0,0 @@
-/**
- * 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.ambari.view.hive;
-
-import org.apache.ambari.view.ViewContext;
-import org.apache.ambari.view.hive.utils.SharedObjectsFactory;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-import javax.inject.Inject;
-
-
-/**
- * Parent service
- */
-public class BaseService {
-  @Inject
-  protected ViewContext context;
-
-  protected final static Logger LOG =
-      LoggerFactory.getLogger(BaseService.class);
-
-  private SharedObjectsFactory sharedObjectsFactory;
-  public SharedObjectsFactory getSharedObjectsFactory() {
-    if (sharedObjectsFactory == null) {
-      sharedObjectsFactory = new SharedObjectsFactory(context);
-    }
-    return sharedObjectsFactory;
-  }
-
-  public void setSharedObjectsFactory(SharedObjectsFactory sharedObjectsFactory) {
-    this.sharedObjectsFactory = sharedObjectsFactory;
-  }
-
-  public BaseService() {
-//    Thread.currentThread().setContextClassLoader(null);
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/HelpService.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/HelpService.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/HelpService.java
deleted file mode 100644
index dcddf6d..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/HelpService.java
+++ /dev/null
@@ -1,132 +0,0 @@
-/**
- * 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.ambari.view.hive;
-
-import org.apache.ambari.view.ViewContext;
-import org.apache.ambari.view.ViewResourceHandler;
-import org.apache.ambari.view.hive.resources.files.FileService;
-import org.apache.ambari.view.hive.resources.jobs.atsJobs.ATSParserFactory;
-import org.apache.ambari.view.hive.resources.jobs.atsJobs.ATSRequestsDelegate;
-import org.apache.ambari.view.hive.resources.jobs.atsJobs.ATSRequestsDelegateImpl;
-import org.json.simple.JSONObject;
-
-import javax.inject.Inject;
-import javax.ws.rs.GET;
-import javax.ws.rs.Path;
-import javax.ws.rs.Produces;
-import javax.ws.rs.WebApplicationException;
-import javax.ws.rs.core.MediaType;
-import javax.ws.rs.core.Response;
-import java.io.IOException;
-
-/**
- * Help service
- */
-public class HelpService extends BaseService {
-  @Inject
-  ViewContext context;
-
-  @Inject
-  protected ViewResourceHandler handler;
-
-  /**
-   * Constructor
-   */
-  public HelpService() {
-    super();
-  }
-
-  /**
-   * Version
-   * @return version
-   */
-  @GET
-  @Path("/version")
-  @Produces(MediaType.TEXT_PLAIN)
-  public Response version(){
-    return Response.ok("0.0.1-SNAPSHOT").build();
-  }
-
-  // ================================================================================
-  // Smoke tests
-  // ================================================================================
-
-  /**
-   * HDFS Status
-   * @return status
-   */
-  @GET
-  @Path("/hdfsStatus")
-  @Produces(MediaType.APPLICATION_JSON)
-  public Response hdfsStatus(){
-    FileService.hdfsSmokeTest(context);
-    return getOKResponse();
-  }
-
-  /**
-   * HomeDirectory Status
-   * @return status
-   */
-  @GET
-  @Path("/userhomeStatus")
-  @Produces(MediaType.APPLICATION_JSON)
-  public Response userhomeStatus (){
-    FileService.userhomeSmokeTest(context);
-    return getOKResponse();
-  }
-
-  /**
-   * ATS Status
-   * @return status
-   */
-  @GET
-  @Path("/atsStatus")
-  @Produces(MediaType.APPLICATION_JSON)
-  public Response atsStatus() {
-    try {
-      ATSRequestsDelegateImpl atsimpl = new ATSRequestsDelegateImpl(context, new ATSParserFactory(context).getATSUrl());
-      atsimpl.checkATSStatus();
-      return getOKResponse();
-    }catch (IOException e){
-      throw new WebApplicationException(e);
-    }
-  }
-
-  private Response getOKResponse() {
-    JSONObject response = new JSONObject();
-    response.put("message", "OK");
-    response.put("trace", null);
-    response.put("status", "200");
-    return Response.ok().entity(response).type(MediaType.APPLICATION_JSON).build();
-  }
-
-  /**
-   * Version
-   * @return version
-   */
-  @GET
-  @Path("/test")
-  @Produces(MediaType.TEXT_PLAIN)
-  public Response testStorage(){
-    TestBean test = new TestBean();
-    test.someData = "hello world";
-    getSharedObjectsFactory().getStorage().store(TestBean.class, test);
-    return Response.ok("OK").build();
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/HiveViewImpl.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/HiveViewImpl.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/HiveViewImpl.java
deleted file mode 100644
index e28dfbf..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/HiveViewImpl.java
+++ /dev/null
@@ -1,50 +0,0 @@
-/**
- * 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.ambari.view.hive;
-
-import org.apache.ambari.view.View;
-import org.apache.ambari.view.ViewDefinition;
-import org.apache.ambari.view.ViewInstanceDefinition;
-import org.apache.ambari.view.hive.utils.SharedObjectsFactory;
-import org.apache.ambari.view.utils.UserLocal;
-
-
-public class HiveViewImpl implements View {
-  @Override
-  public void onDeploy(ViewDefinition definition) {
-
-  }
-
-  @Override
-  public void onCreate(ViewInstanceDefinition definition) {
-
-  }
-
-  @Override
-  public void onDestroy(ViewInstanceDefinition definition) {
-    SharedObjectsFactory.dropInstanceCache(definition.getInstanceName());
-  }
-
-  @Override
-  public void onUpdate(ViewInstanceDefinition definition) {
-    //drop all cached connection for instance
-    UserLocal.dropInstanceCache(definition.getInstanceName());
-    SharedObjectsFactory.dropInstanceCache(definition.getInstanceName());
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/PropertyValidator.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/PropertyValidator.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/PropertyValidator.java
deleted file mode 100644
index e10dad3..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/PropertyValidator.java
+++ /dev/null
@@ -1,113 +0,0 @@
-/**
- * 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.ambari.view.hive;
-
-import org.apache.ambari.view.ClusterType;
-import org.apache.ambari.view.ViewInstanceDefinition;
-import org.apache.ambari.view.utils.ambari.ValidatorUtils;
-import org.apache.ambari.view.validation.ValidationResult;
-import org.apache.ambari.view.validation.Validator;
-
-public class PropertyValidator implements Validator {
-
-  public static final String WEBHDFS_URL = "webhdfs.url";
-  public static final String HIVE_PORT = "hive.port";
-  public static final String YARN_ATS_URL = "yarn.ats.url";
-  public static final String HIVE_AUTH = "hive.auth";
-
-  @Override
-  public ValidationResult validateInstance(ViewInstanceDefinition viewInstanceDefinition, ValidationContext validationContext) {
-    return null;
-  }
-
-  @Override
-  public ValidationResult validateProperty(String property, ViewInstanceDefinition viewInstanceDefinition, ValidationContext validationContext) {
-    // Validate non cluster associated properties
-    if (property.equals(HIVE_AUTH)) {
-      String auth = viewInstanceDefinition.getPropertyMap().get(HIVE_AUTH);
-
-      if (auth != null && !auth.isEmpty()) {
-        for(String param : auth.split(";")) {
-          String[] keyvalue = param.split("=");
-          if (keyvalue.length != 2) {
-            return new InvalidPropertyValidationResult(false, "Can not parse authentication param " + param + " in " + auth);
-          }
-        }
-      }
-    }
-
-    // if associated with cluster(local or remote), no need to validate associated properties
-    ClusterType clusterType = viewInstanceDefinition.getClusterType();
-    if (clusterType == ClusterType.LOCAL_AMBARI || clusterType == ClusterType.REMOTE_AMBARI) {
-      return ValidationResult.SUCCESS;
-    }
-
-    // Cluster associated properties
-    if (property.equals(WEBHDFS_URL)) {
-      String webhdfsUrl = viewInstanceDefinition.getPropertyMap().get(WEBHDFS_URL);
-      if (!ValidatorUtils.validateHdfsURL(webhdfsUrl)) {
-        return new InvalidPropertyValidationResult(false, "Must be valid URL");
-      }
-    }
-
-    if (property.equals(HIVE_PORT)) {
-      String hivePort = viewInstanceDefinition.getPropertyMap().get(HIVE_PORT);
-      if (hivePort != null) {
-        try {
-          int port = Integer.valueOf(hivePort);
-          if (port < 1 || port > 65535) {
-            return new InvalidPropertyValidationResult(false, "Must be from 1 to 65535");
-          }
-        } catch (NumberFormatException e) {
-          return new InvalidPropertyValidationResult(false, "Must be integer");
-        }
-      }
-    }
-
-    if (property.equals(YARN_ATS_URL)) {
-      String atsUrl = viewInstanceDefinition.getPropertyMap().get(YARN_ATS_URL);
-      if (!ValidatorUtils.validateHttpURL(atsUrl)) {
-        return new InvalidPropertyValidationResult(false, "Must be valid URL");
-      }
-    }
-
-    return ValidationResult.SUCCESS;
-  }
-
-  public static class InvalidPropertyValidationResult implements ValidationResult {
-    private boolean valid;
-    private String detail;
-
-    public InvalidPropertyValidationResult(boolean valid, String detail) {
-      this.valid = valid;
-      this.detail = detail;
-    }
-
-    @Override
-    public boolean isValid() {
-      return valid;
-    }
-
-    @Override
-    public String getDetail() {
-      return detail;
-    }
-  }
-
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/TestBean.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/TestBean.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/TestBean.java
deleted file mode 100644
index d298931..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/TestBean.java
+++ /dev/null
@@ -1,36 +0,0 @@
-/**
- * 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.ambari.view.hive;
-
-import org.apache.ambari.view.hive.persistence.utils.Indexed;
-
-public class TestBean implements Indexed {
-  public String someData;
-  public String id;
-
-  @Override
-  public String getId() {
-    return id;
-  }
-
-  @Override
-  public void setId(String id) {
-    this.id = id;
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/backgroundjobs/BackgroundJobController.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/backgroundjobs/BackgroundJobController.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/backgroundjobs/BackgroundJobController.java
deleted file mode 100644
index ea8d51c..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/backgroundjobs/BackgroundJobController.java
+++ /dev/null
@@ -1,90 +0,0 @@
-/**
- * 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.ambari.view.hive.backgroundjobs;
-
-import org.apache.ambari.view.ViewContext;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-import java.util.HashMap;
-import java.util.Map;
-
-public class BackgroundJobController {
-  private final static Logger LOG =
-    LoggerFactory.getLogger(BackgroundJobController.class);
-
-  private ViewContext context;
-
-  protected BackgroundJobController(ViewContext context) {
-    this.context = context;
-  }
-
-  private static Map<String, BackgroundJobController> viewSingletonObjects = new HashMap<String, BackgroundJobController>();
-  public static BackgroundJobController getInstance(ViewContext context) {
-    if (!viewSingletonObjects.containsKey(context.getInstanceName()))
-      viewSingletonObjects.put(context.getInstanceName(), new BackgroundJobController(context));
-    return viewSingletonObjects.get(context.getInstanceName());
-  }
-
-  private Map<String, Thread> jobs = new HashMap<String, Thread>();
-  public void startJob(String key, Runnable runnable) {
-    LOG.info("Starting job with key : {}", key);
-    if (jobs.containsKey(key)) {
-      interrupt(key);
-      try {
-        jobs.get(key).join();
-      } catch (InterruptedException ignored) {
-      }
-    }
-    Thread t = new Thread(runnable);
-    jobs.put(key, t);
-    t.start();
-  }
-
-  public Thread.State state(String key) {
-    if (!jobs.containsKey(key)) {
-      return Thread.State.TERMINATED;
-    }
-
-    Thread.State state = jobs.get(key).getState();
-
-    if (state == Thread.State.TERMINATED) {
-      jobs.remove(key);
-    }
-
-    return state;
-  }
-
-  public boolean interrupt(String key) {
-    if (!jobs.containsKey(key)) {
-      return false;
-    }
-
-    jobs.get(key).interrupt();
-    return true;
-  }
-
-  public boolean isInterrupted(String key) {
-    if (state(key) == Thread.State.TERMINATED) {
-      return true;
-    }
-
-    return jobs.get(key).isInterrupted();
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/client/ColumnDescription.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/client/ColumnDescription.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/client/ColumnDescription.java
deleted file mode 100644
index a25571f..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/client/ColumnDescription.java
+++ /dev/null
@@ -1,48 +0,0 @@
-/**
- * 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.ambari.view.hive.client;
-
-public interface ColumnDescription {
-  enum DataTypes {
-    TINYINT, //
-    SMALLINT, //
-    INT, //
-    BIGINT, //
-    BOOLEAN, //
-    FLOAT, //
-    DOUBLE, //
-    STRING, //
-    BINARY, // -- (Note: Available in Hive 0.8.0 and later)
-    TIMESTAMP, // -- (Note: Available in Hive 0.8.0 and later)
-    DECIMAL, // -- (Note: Available in Hive 0.11.0 and later)
-    // DECIMAL,(precision, scale)� -- (Note: Available in Hive 0.13.0 and later) Not included.
-    DATE, // -- (Note: Available in Hive 0.12.0 and later)
-    VARCHAR, // -- (Note: Available in Hive 0.12.0 and later)
-    CHAR, // -- (Note: Available in Hive 0.13.0 and later)
-  }
-
-  public abstract String getName();
-  public abstract void setName(String name);
-
-  public abstract String getType();
-  public abstract void setType(String type);
-
-  public abstract int getPosition();
-  public abstract void setPosition(int position);
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/client/ColumnDescriptionExtended.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/client/ColumnDescriptionExtended.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/client/ColumnDescriptionExtended.java
deleted file mode 100644
index ab54e61..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/client/ColumnDescriptionExtended.java
+++ /dev/null
@@ -1,103 +0,0 @@
-/**
- * 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.ambari.view.hive.client;
-
-public class ColumnDescriptionExtended implements ColumnDescription {
-  private String name;
-  private String type;
-  private int position;
-  private String comment;
-  private boolean partitioned;
-  private boolean sortedBy;
-  private boolean clusteredBy;
-
-  private ColumnDescriptionExtended(String name, String type, String comment, boolean partitioned,
-                                   boolean sortedBy, boolean clusteredBy, int position) {
-    setName(name);
-    setType(type);
-    setPosition(position);
-    setComment(comment);
-    setPartitioned(partitioned);
-    setSortedBy(sortedBy);
-    setClusteredBy(clusteredBy);
-  }
-
-  public static ColumnDescription createExtendedColumnDescription(String name, String type, String comment,
-                                                                  boolean partitioned, boolean sortedBy, boolean clusteredBy,
-                                                                  int position) {
-    return new ColumnDescriptionExtended(name, type, comment, partitioned, sortedBy, clusteredBy, position);
-  }
-
-  public String getName() {
-    return name;
-  }
-
-  public void setName(String name) {
-    this.name = name;
-  }
-
-  public String getType() {
-    return type;
-  }
-
-  public void setType(String type) {
-    this.type = type;
-  }
-
-  public int getPosition() {
-    return position;
-  }
-
-  public void setPosition(int position) {
-    this.position = position;
-  }
-
-  public String getComment() {
-    return comment;
-  }
-
-  public void setComment(String comment) {
-    this.comment = comment;
-  }
-
-  public boolean isPartitioned() {
-    return partitioned;
-  }
-
-  public void setPartitioned(boolean partitioned) {
-    this.partitioned = partitioned;
-  }
-
-  public boolean isSortedBy() {
-    return sortedBy;
-  }
-
-  public void setSortedBy(boolean sortedBy) {
-    this.sortedBy = sortedBy;
-  }
-
-  public boolean isClusteredBy() {
-    return clusteredBy;
-  }
-
-  public void setClusteredBy(boolean clusteredBy) {
-    this.clusteredBy = clusteredBy;
-  }
-
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/client/ColumnDescriptionShort.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/client/ColumnDescriptionShort.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/client/ColumnDescriptionShort.java
deleted file mode 100644
index a6500aa..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/client/ColumnDescriptionShort.java
+++ /dev/null
@@ -1,72 +0,0 @@
-/**
- * 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.ambari.view.hive.client;
-
-import java.util.ArrayList;
-
-public class ColumnDescriptionShort extends ArrayList<Object> implements ColumnDescription {
-  public static final int INITIAL_CAPACITY = 3;
-  public static final int NAME_INDEX = 0;
-  public static final int TYPE_INDEX = 1;
-  public static final int POSITION_INDEX = 2;
-
-  private ColumnDescriptionShort(String name, String type, int position) {
-    super(INITIAL_CAPACITY);
-    this.add(null);
-    this.add(null);
-    this.add(null);
-    setName(name);
-    setType(type);
-    setPosition(position);
-  }
-
-  public static ColumnDescription createShortColumnDescription(String name, String type, int position) {
-    return new ColumnDescriptionShort(name, type, position);
-  }
-
-  @Override
-  public String getName() {
-    return (String) this.get(NAME_INDEX);
-  }
-
-  @Override
-  public void setName(String name) {
-    this.set(NAME_INDEX, name);
-  }
-
-  @Override
-  public String getType() {
-    return (String) this.get(TYPE_INDEX);
-  }
-
-  @Override
-  public void setType(String type) {
-    this.set(TYPE_INDEX, type);
-  }
-
-  @Override
-  public int getPosition() {
-    return (Integer) this.get(POSITION_INDEX);
-  }
-
-  @Override
-  public void setPosition(int position) {
-    this.set(POSITION_INDEX, position);
-  }
-}


[05/23] ambari git commit: AMBARI-19302 : removed contrib/views/hive folder and made necessary changes in pom.xml files (nitirajrathore)

Posted by ni...@apache.org.
http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/vendor/dagre.min.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/vendor/dagre.min.js b/contrib/views/hive/src/main/resources/ui/hive-web/vendor/dagre.min.js
deleted file mode 100644
index 10a0471..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/vendor/dagre.min.js
+++ /dev/null
@@ -1,27 +0,0 @@
-/**
- * @license
- * Copyright (c) 2012-2014 Chris Pettitt
- *
- * Permission is hereby granted, free of charge, to any person obtaining a copy
- * of this software and associated documentation files (the "Software"), to deal
- * in the Software without restriction, including without limitation the rights
- * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
- * copies of the Software, and to permit persons to whom the Software is
- * furnished to do so, subject to the following conditions:
- *
- * The above copyright notice and this permission notice shall be included in
- * all copies or substantial portions of the Software.
- *
- * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
- * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
- * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
- * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
- * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
- * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
- * THE SOFTWARE.
- */
-
-(function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require=="function"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error("Cannot find module '"+o+"'");throw f.code="MODULE_NOT_FOUND",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require=="function"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})({1:[function(require,module,exports){(function(global){global.dagre=require("./index");global.dagre.graphlib=require("graphlib")}).call(this,typeof global!=="undefined"?global:typeof self!=="undefined"?self:typeof window!=="undefined"?window:{})},{"./index":2,graphlib:29}],2:[function(require,module,exports){module.exports={layout:require("./lib/layout"),debug:require("./lib/debug"),util:{time:require("./lib/util").time,notime:require("./lib/util").notime},version:require("./lib/version")}},{"./lib/debug":6,"./lib/layout":8,"./lib/util":27,"./lib/v
 ersion":28}],3:[function(require,module,exports){"use strict";var _=require("lodash"),greedyFAS=require("./greedy-fas");module.exports={run:run,undo:undo};function run(g){var fas=g.graph().acyclicer==="greedy"?greedyFAS(g,weightFn(g)):dfsFAS(g);_.each(fas,function(e){var label=g.edge(e);g.removeEdge(e);label.forwardName=e.name;label.reversed=true;g.setEdge(e.w,e.v,label,_.uniqueId("rev"))});function weightFn(g){return function(e){return g.edge(e).weight}}}function dfsFAS(g){var fas=[],stack={},visited={};function dfs(v){if(_.has(visited,v)){return}visited[v]=true;stack[v]=true;_.each(g.outEdges(v),function(e){if(_.has(stack,e.w)){fas.push(e)}else{dfs(e.w)}});delete stack[v]}_.each(g.nodes(),dfs);return fas}function undo(g){_.each(g.edges(),function(e){var label=g.edge(e);if(label.reversed){g.removeEdge(e);var forwardName=label.forwardName;delete label.reversed;delete label.forwardName;g.setEdge(e.w,e.v,label,forwardName)}})}},{"./greedy-fas":7,lodash:48}],4:[function(require,module,
 exports){var _=require("lodash"),util=require("./util");module.exports=addBorderSegments;function addBorderSegments(g){function dfs(v){var children=g.children(v),node=g.node(v);if(children.length){_.each(children,dfs)}if(_.has(node,"minRank")){node.borderLeft=[];node.borderRight=[];for(var rank=node.minRank,maxRank=node.maxRank+1;rank<maxRank;++rank){addBorderNode(g,"borderLeft","_bl",v,node,rank);addBorderNode(g,"borderRight","_br",v,node,rank)}}}_.each(g.children(),dfs)}function addBorderNode(g,prop,prefix,sg,sgNode,rank){var label={width:0,height:0,rank:rank},prev=sgNode[prop][rank-1],curr=util.addDummyNode(g,"border",label,prefix);sgNode[prop][rank]=curr;g.setParent(curr,sg);if(prev){g.setEdge(prev,curr,{weight:1})}}},{"./util":27,lodash:48}],5:[function(require,module,exports){module.exports=List;function List(){var sentinel={};sentinel._next=sentinel._prev=sentinel;this._sentinel=sentinel}List.prototype.dequeue=function(){var sentinel=this._sentinel,entry=sentinel._prev;if(ent
 ry!==sentinel){unlink(entry);return entry}};List.prototype.enqueue=function(entry){var sentinel=this._sentinel;if(entry._prev&&entry._next){unlink(entry)}entry._next=sentinel._next;sentinel._next._prev=entry;sentinel._next=entry;entry._prev=sentinel};List.prototype.toString=function(){var strs=[],sentinel=this._sentinel,curr=sentinel._prev;while(curr!==sentinel){strs.push(JSON.stringify(curr,filterOutLinks));curr=curr._prev}return"["+strs.join(", ")+"]"};function unlink(entry){entry._prev._next=entry._next;entry._next._prev=entry._prev;delete entry._next;delete entry._prev}function filterOutLinks(k,v){if(k!=="_next"&&k!=="_prev"){return v}}},{}],6:[function(require,module,exports){var _=require("lodash"),util=require("./util"),Graph=require("graphlib").Graph;module.exports={debugOrdering:debugOrdering};function debugOrdering(g){var layerMatrix=util.buildLayerMatrix(g);var h=new Graph({compound:true,multigraph:true}).setGraph({});_.each(g.nodes(),function(v){h.setNode(v,{label:v});h.
 setParent(v,"layer"+g.node(v).rank)});_.each(g.edges(),function(e){h.setEdge(e.v,e.w,{},e.name)});_.each(layerMatrix,function(layer,i){var layerV="layer"+i;h.setNode(layerV,{rank:"same"});_.reduce(layer,function(u,v){h.setEdge(u,v,{style:"invis"});return v})});return h}},{"./util":27,graphlib:29,lodash:48}],7:[function(require,module,exports){var _=require("lodash"),Graph=require("graphlib").Graph,List=require("./data/list");module.exports=greedyFAS;var DEFAULT_WEIGHT_FN=_.constant(1);function greedyFAS(g,weightFn){if(g.nodeCount()<=1){return[]}var state=buildState(g,weightFn||DEFAULT_WEIGHT_FN);var results=doGreedyFAS(state.graph,state.buckets,state.zeroIdx);return _.flatten(_.map(results,function(e){return g.outEdges(e.v,e.w)}),true)}function doGreedyFAS(g,buckets,zeroIdx){var results=[],sources=buckets[buckets.length-1],sinks=buckets[0];var entry;while(g.nodeCount()){while(entry=sinks.dequeue()){removeNode(g,buckets,zeroIdx,entry)}while(entry=sources.dequeue()){removeNode(g,bucke
 ts,zeroIdx,entry)}if(g.nodeCount()){for(var i=buckets.length-2;i>0;--i){entry=buckets[i].dequeue();if(entry){results=results.concat(removeNode(g,buckets,zeroIdx,entry,true));break}}}}return results}function removeNode(g,buckets,zeroIdx,entry,collectPredecessors){var results=collectPredecessors?[]:undefined;_.each(g.inEdges(entry.v),function(edge){var weight=g.edge(edge),uEntry=g.node(edge.v);if(collectPredecessors){results.push({v:edge.v,w:edge.w})}uEntry.out-=weight;assignBucket(buckets,zeroIdx,uEntry)});_.each(g.outEdges(entry.v),function(edge){var weight=g.edge(edge),w=edge.w,wEntry=g.node(w);wEntry.in-=weight;assignBucket(buckets,zeroIdx,wEntry)});g.removeNode(entry.v);return results}function buildState(g,weightFn){var fasGraph=new Graph,maxIn=0,maxOut=0;_.each(g.nodes(),function(v){fasGraph.setNode(v,{v:v,"in":0,out:0})});_.each(g.edges(),function(e){var prevWeight=fasGraph.edge(e.v,e.w)||0,weight=weightFn(e),edgeWeight=prevWeight+weight;fasGraph.setEdge(e.v,e.w,edgeWeight);max
 Out=Math.max(maxOut,fasGraph.node(e.v).out+=weight);maxIn=Math.max(maxIn,fasGraph.node(e.w).in+=weight)});var buckets=_.range(maxOut+maxIn+3).map(function(){return new List});var zeroIdx=maxIn+1;_.each(fasGraph.nodes(),function(v){assignBucket(buckets,zeroIdx,fasGraph.node(v))});return{graph:fasGraph,buckets:buckets,zeroIdx:zeroIdx}}function assignBucket(buckets,zeroIdx,entry){if(!entry.out){buckets[0].enqueue(entry)}else if(!entry.in){buckets[buckets.length-1].enqueue(entry)}else{buckets[entry.out-entry.in+zeroIdx].enqueue(entry)}}},{"./data/list":5,graphlib:29,lodash:48}],8:[function(require,module,exports){"use strict";var _=require("lodash"),acyclic=require("./acyclic"),normalize=require("./normalize"),rank=require("./rank"),normalizeRanks=require("./util").normalizeRanks,parentDummyChains=require("./parent-dummy-chains"),removeEmptyRanks=require("./util").removeEmptyRanks,nestingGraph=require("./nesting-graph"),addBorderSegments=require("./add-border-segments"),order=require(".
 /order"),position=require("./position"),util=require("./util"),Graph=require("graphlib").Graph;module.exports=layout;function layout(g,opts){var time=opts&&opts.debugTiming?util.time:util.notime;time("layout",function(){var layoutGraph=time("  buildLayoutGraph",function(){return buildLayoutGraph(g)});time("  runLayout",function(){runLayout(layoutGraph,time)});time("  updateInputGraph",function(){updateInputGraph(g,layoutGraph)})})}function runLayout(g,time){time("    makeSpaceForEdgeLabels",function(){makeSpaceForEdgeLabels(g)});time("    removeSelfEdges",function(){removeSelfEdges(g)});time("    acyclic",function(){acyclic.run(g)});time("    nestingGraph.run",function(){nestingGraph.run(g)});time("    rank",function(){rank(util.asNonCompoundGraph(g))});time("    injectEdgeLabelProxies",function(){injectEdgeLabelProxies(g)});time("    removeEmptyRanks",function(){removeEmptyRanks(g)});time("    nestingGraph.cleanup",function(){nestingGraph.cleanup(g)});time("    normalizeRanks",func
 tion(){normalizeRanks(g)});time("    assignRankMinMax",function(){assignRankMinMax(g)});time("    removeEdgeLabelProxies",function(){removeEdgeLabelProxies(g)});time("    normalize.run",function(){normalize.run(g)});time("    parentDummyChains",function(){parentDummyChains(g)});time("    addBorderSegments",function(){addBorderSegments(g)});time("    order",function(){order(g)});time("    insertSelfEdges",function(){insertSelfEdges(g)});time("    position",function(){position(g)});time("    positionSelfEdges",function(){positionSelfEdges(g)});time("    setGraphDimensions",function(){setGraphDimensions(g)});time("    removeBorderNodes",function(){removeBorderNodes(g)});time("    normalize.undo",function(){normalize.undo(g)});time("    assignNodeIntersects",function(){assignNodeIntersects(g)});time("    reversePoints",function(){reversePointsForReversedEdges(g)});time("    acyclic.undo",function(){acyclic.undo(g)})}function updateInputGraph(inputGraph,layoutGraph){_.each(inputGraph.nod
 es(),function(v){var inputLabel=inputGraph.node(v),layoutLabel=layoutGraph.node(v);if(inputLabel){inputLabel.x=layoutLabel.x;inputLabel.y=layoutLabel.y;if(layoutGraph.children(v).length){inputLabel.width=layoutLabel.width;inputLabel.height=layoutLabel.height}}});_.each(inputGraph.edges(),function(e){var inputLabel=inputGraph.edge(e),layoutLabel=layoutGraph.edge(e);inputLabel.points=layoutLabel.points;if(_.has(layoutLabel,"x")){inputLabel.x=layoutLabel.x;inputLabel.y=layoutLabel.y}});inputGraph.graph().width=layoutGraph.graph().width;inputGraph.graph().height=layoutGraph.graph().height}var graphNumAttrs=["nodesep","edgesep","ranksep","marginx","marginy"],graphDefaults={ranksep:50,edgesep:10,nodesep:50},graphAttrs=["acyclicer","ranker","rankdir","align"],nodeNumAttrs=["width","height"],nodeDefaults={width:0,height:0},edgeNumAttrs=["minlen","weight","width","height"],edgeDefaults={minlen:1,weight:1,width:0,height:0};function buildLayoutGraph(inputGraph){var g=new Graph({multigraph:true
 ,compound:true});g.setGraph(_.merge({},graphDefaults,selectNumberAttrs(inputGraph.graph(),graphNumAttrs),_.pick(inputGraph.graph(),graphAttrs)));_.each(inputGraph.nodes(),function(v){var label=inputGraph.node(v);g.setNode(v,_.defaults(selectNumberAttrs(label,nodeNumAttrs),nodeDefaults));g.setParent(v,inputGraph.parent(v))});_.each(inputGraph.edges(),function(e){var label=inputGraph.edge(e);g.setEdge(e,_.defaults(selectNumberAttrs(label,edgeNumAttrs),edgeDefaults))});return g}function makeSpaceForEdgeLabels(g){var graphLabel=g.graph();graphLabel.ranksep/=2;_.each(g.edges(),function(e){g.edge(e).minlen*=2})}function injectEdgeLabelProxies(g){_.each(g.edges(),function(e){var edge=g.edge(e);if(edge.width&&edge.height){var v=g.node(e.v),w=g.node(e.w),label={rank:(w.rank-v.rank)/2+v.rank,e:e};util.addDummyNode(g,"edge-proxy",label,"_ep")}})}function assignRankMinMax(g){var maxRank=0;_.each(g.nodes(),function(v){var node=g.node(v);if(node.borderTop){node.minRank=g.node(node.borderTop).rank
 ;node.maxRank=g.node(node.borderBottom).rank;maxRank=_.max(maxRank,node.maxRank)}});g.graph().maxRank=maxRank}function removeEdgeLabelProxies(g){_.each(g.nodes(),function(v){var node=g.node(v);if(node.dummy==="edge-proxy"){g.edge(node.e).labelRank=node.rank;g.removeNode(v)}})}function setGraphDimensions(g){var width=0,height=0,graph=g.graph();_.each(g.nodes(),function(v){var node=g.node(v);width=Math.max(width,node.x+node.width/2);height=Math.max(height,node.y+node.height/2)});graph.width=width;graph.height=height}function assignNodeIntersects(g){_.each(g.edges(),function(e){var edge=g.edge(e),nodeV=g.node(e.v),nodeW=g.node(e.w),p1,p2;if(!edge.points){edge.points=[];p1=nodeW;p2=nodeV}else{p1=edge.points[0];p2=edge.points[edge.points.length-1]}edge.points.unshift(util.intersectRect(nodeV,p1));edge.points.push(util.intersectRect(nodeW,p2))})}function reversePointsForReversedEdges(g){_.each(g.edges(),function(e){var edge=g.edge(e);if(edge.reversed){edge.points.reverse()}})}function rem
 oveBorderNodes(g){var rankdir=(g.graph().rankdir||"tb").toLowerCase();_.each(g.nodes(),function(v){if(g.children(v).length){var node=g.node(v),t=g.node(node.borderTop),b=g.node(node.borderBottom),l=g.node(_.last(node.borderLeft)),r=g.node(_.last(node.borderRight)),tmp;if(rankdir==="bt"||rankdir==="rl"){tmp=t;t=b;b=tmp}if(rankdir==="lr"||rankdir==="rl"){tmp=t;t=l;l=tmp;tmp=b;b=r;r=tmp}node.width=r.x-l.x;node.height=b.y-t.y;node.x=l.x+node.width/2;node.y=t.y+node.height/2}});_.each(g.nodes(),function(v){if(g.node(v).dummy==="border"){g.removeNode(v)}})}function removeSelfEdges(g){_.each(g.edges(),function(e){if(e.v===e.w){var node=g.node(e.v);if(!node.selfEdges){node.selfEdges=[]}node.selfEdges.push({e:e,label:g.edge(e)});g.removeEdge(e)}})}function insertSelfEdges(g){var layers=util.buildLayerMatrix(g);_.each(layers,function(layer){var orderShift=0;_.each(layer,function(v,i){var node=g.node(v);node.order=i+orderShift;_.each(node.selfEdges,function(selfEdge){util.addDummyNode(g,"selfe
 dge",{width:selfEdge.label.width,height:selfEdge.label.height,rank:node.rank,order:i+ ++orderShift,e:selfEdge.e,label:selfEdge.label},"_se")});delete node.selfEdges})})}function positionSelfEdges(g){_.each(g.nodes(),function(v){var node=g.node(v);if(node.dummy==="selfedge"){var selfNode=g.node(node.e.v),x=selfNode.x+selfNode.width/2,y=selfNode.y,dx=node.x-x,dy=selfNode.height/2;g.setEdge(node.e,node.label);g.removeNode(v);node.label.points=[{x:x+2*dx/3,y:y-dy},{x:x+5*dx/6,y:y-dy},{x:x+dx,y:y},{x:x+5*dx/6,y:y+dy},{x:x+2*dx/3,y:y+dy}];node.label.x=node.x;node.label.y=node.y}})}function selectNumberAttrs(obj,attrs){return _.mapValues(_.pick(obj,attrs),Number)}},{"./acyclic":3,"./add-border-segments":4,"./nesting-graph":9,"./normalize":10,"./order":15,"./parent-dummy-chains":20,"./position":22,"./rank":24,"./util":27,graphlib:29,lodash:48}],9:[function(require,module,exports){var _=require("lodash"),util=require("./util");module.exports={run:run,cleanup:cleanup};function run(g){var root
 =util.addDummyNode(g,"root",{},"_root"),depths=treeDepths(g),height=_.max(depths)-1,nodeSep=2*height+1;g.graph().nestingRoot=root;_.each(g.edges(),function(e){g.edge(e).minlen*=nodeSep});var weight=sumWeights(g)+1;_.each(g.children(),function(child){dfs(g,root,nodeSep,weight,height,depths,child)});g.graph().nodeRankFactor=nodeSep}function dfs(g,root,nodeSep,weight,height,depths,v){var children=g.children(v);if(!children.length){if(v!==root){g.setEdge(root,v,{weight:0,minlen:nodeSep})}return}var top=util.addBorderNode(g,"_bt"),bottom=util.addBorderNode(g,"_bb"),label=g.node(v);g.setParent(top,v);label.borderTop=top;g.setParent(bottom,v);label.borderBottom=bottom;_.each(children,function(child){dfs(g,root,nodeSep,weight,height,depths,child);var childNode=g.node(child),childTop=childNode.borderTop?childNode.borderTop:child,childBottom=childNode.borderBottom?childNode.borderBottom:child,thisWeight=childNode.borderTop?weight:2*weight,minlen=childTop!==childBottom?1:height-depths[v]+1;g.s
 etEdge(top,childTop,{weight:thisWeight,minlen:minlen,nestingEdge:true});g.setEdge(childBottom,bottom,{weight:thisWeight,minlen:minlen,nestingEdge:true})});if(!g.parent(v)){g.setEdge(root,top,{weight:0,minlen:height+depths[v]})}}function treeDepths(g){var depths={};function dfs(v,depth){var children=g.children(v);if(children&&children.length){_.each(children,function(child){dfs(child,depth+1)})}depths[v]=depth}_.each(g.children(),function(v){dfs(v,1)});return depths}function sumWeights(g){return _.reduce(g.edges(),function(acc,e){return acc+g.edge(e).weight},0)}function cleanup(g){var graphLabel=g.graph();g.removeNode(graphLabel.nestingRoot);delete graphLabel.nestingRoot;_.each(g.edges(),function(e){var edge=g.edge(e);if(edge.nestingEdge){g.removeEdge(e)}})}},{"./util":27,lodash:48}],10:[function(require,module,exports){"use strict";var _=require("lodash"),util=require("./util");module.exports={run:run,undo:undo};function run(g){g.graph().dummyChains=[];_.each(g.edges(),function(edge
 ){normalizeEdge(g,edge)})}function normalizeEdge(g,e){var v=e.v,vRank=g.node(v).rank,w=e.w,wRank=g.node(w).rank,name=e.name,edgeLabel=g.edge(e),labelRank=edgeLabel.labelRank;if(wRank===vRank+1)return;g.removeEdge(e);var dummy,attrs,i;for(i=0,++vRank;vRank<wRank;++i,++vRank){edgeLabel.points=[];attrs={width:0,height:0,edgeLabel:edgeLabel,edgeObj:e,rank:vRank};dummy=util.addDummyNode(g,"edge",attrs,"_d");if(vRank===labelRank){attrs.width=edgeLabel.width;attrs.height=edgeLabel.height;attrs.dummy="edge-label"}g.setEdge(v,dummy,{weight:edgeLabel.weight},name);if(i===0){g.graph().dummyChains.push(dummy)}v=dummy}g.setEdge(v,w,{weight:edgeLabel.weight},name)}function undo(g){_.each(g.graph().dummyChains,function(v){var node=g.node(v),origLabel=node.edgeLabel,w;g.setEdge(node.edgeObj,origLabel);while(node.dummy){w=g.successors(v)[0];g.removeNode(v);origLabel.points.push({x:node.x,y:node.y});if(node.dummy==="edge-label"){origLabel.x=node.x;origLabel.y=node.y}v=w;node=g.node(v)}})}},{"./util":
 27,lodash:48}],11:[function(require,module,exports){var _=require("lodash");module.exports=addSubgraphConstraints;function addSubgraphConstraints(g,cg,vs){var prev={},rootPrev;_.each(vs,function(v){var child=g.parent(v),parent,prevChild;while(child){parent=g.parent(child);if(parent){prevChild=prev[parent];prev[parent]=child}else{prevChild=rootPrev;rootPrev=child}if(prevChild&&prevChild!==child){cg.setEdge(prevChild,child);return}child=parent}})}},{lodash:48}],12:[function(require,module,exports){var _=require("lodash");module.exports=barycenter;function barycenter(g,movable){return _.map(movable,function(v){var inV=g.inEdges(v);if(!inV.length){return{v:v}}else{var result=_.reduce(inV,function(acc,e){var edge=g.edge(e),nodeU=g.node(e.v);return{sum:acc.sum+edge.weight*nodeU.order,weight:acc.weight+edge.weight}},{sum:0,weight:0});return{v:v,barycenter:result.sum/result.weight,weight:result.weight}}})}},{lodash:48}],13:[function(require,module,exports){var _=require("lodash"),Graph=requ
 ire("graphlib").Graph;module.exports=buildLayerGraph;function buildLayerGraph(g,rank,relationship){var root=createRootNode(g),result=new Graph({compound:true}).setGraph({root:root}).setDefaultNodeLabel(function(v){return g.node(v)});_.each(g.nodes(),function(v){var node=g.node(v),parent=g.parent(v);if(node.rank===rank||node.minRank<=rank&&rank<=node.maxRank){result.setNode(v);result.setParent(v,parent||root);_.each(g[relationship](v),function(e){var u=e.v===v?e.w:e.v,edge=result.edge(u,v),weight=!_.isUndefined(edge)?edge.weight:0;result.setEdge(u,v,{weight:g.edge(e).weight+weight})});if(_.has(node,"minRank")){result.setNode(v,{borderLeft:node.borderLeft[rank],borderRight:node.borderRight[rank]})}}});return result}function createRootNode(g){var v;while(g.hasNode(v=_.uniqueId("_root")));return v}},{graphlib:29,lodash:48}],14:[function(require,module,exports){"use strict";var _=require("lodash");module.exports=crossCount;function crossCount(g,layering){var cc=0;for(var i=1;i<layering.l
 ength;++i){cc+=twoLayerCrossCount(g,layering[i-1],layering[i])}return cc}function twoLayerCrossCount(g,northLayer,southLayer){var southPos=_.zipObject(southLayer,_.map(southLayer,function(v,i){return i}));var southEntries=_.flatten(_.map(northLayer,function(v){return _.chain(g.outEdges(v)).map(function(e){return{pos:southPos[e.w],weight:g.edge(e).weight}}).sortBy("pos").value()}),true);var firstIndex=1;while(firstIndex<southLayer.length)firstIndex<<=1;var treeSize=2*firstIndex-1;firstIndex-=1;var tree=_.map(new Array(treeSize),function(){return 0});var cc=0;_.each(southEntries.forEach(function(entry){var index=entry.pos+firstIndex;tree[index]+=entry.weight;var weightSum=0;while(index>0){if(index%2){weightSum+=tree[index+1]}index=index-1>>1;tree[index]+=entry.weight}cc+=entry.weight*weightSum}));return cc}},{lodash:48}],15:[function(require,module,exports){"use strict";var _=require("lodash"),initOrder=require("./init-order"),crossCount=require("./cross-count"),sortSubgraph=require("
 ./sort-subgraph"),buildLayerGraph=require("./build-layer-graph"),addSubgraphConstraints=require("./add-subgraph-constraints"),Graph=require("graphlib").Graph,util=require("../util");module.exports=order;function order(g){var maxRank=util.maxRank(g),downLayerGraphs=buildLayerGraphs(g,_.range(1,maxRank+1),"inEdges"),upLayerGraphs=buildLayerGraphs(g,_.range(maxRank-1,-1,-1),"outEdges");var layering=initOrder(g);assignOrder(g,layering);var bestCC=Number.POSITIVE_INFINITY,best;for(var i=0,lastBest=0;lastBest<4;++i,++lastBest){sweepLayerGraphs(i%2?downLayerGraphs:upLayerGraphs,i%4>=2);layering=util.buildLayerMatrix(g);var cc=crossCount(g,layering);if(cc<bestCC){lastBest=0;best=_.cloneDeep(layering);bestCC=cc}}assignOrder(g,best)}function buildLayerGraphs(g,ranks,relationship){return _.map(ranks,function(rank){return buildLayerGraph(g,rank,relationship)})}function sweepLayerGraphs(layerGraphs,biasRight){var cg=new Graph;_.each(layerGraphs,function(lg){var root=lg.graph().root;var sorted=so
 rtSubgraph(lg,root,cg,biasRight);_.each(sorted.vs,function(v,i){lg.node(v).order=i});addSubgraphConstraints(lg,cg,sorted.vs)})}function assignOrder(g,layering){_.each(layering,function(layer){_.each(layer,function(v,i){g.node(v).order=i})})}},{"../util":27,"./add-subgraph-constraints":11,"./build-layer-graph":13,"./cross-count":14,"./init-order":16,"./sort-subgraph":18,graphlib:29,lodash:48}],16:[function(require,module,exports){"use strict";var _=require("lodash");module.exports=initOrder;function initOrder(g){var visited={},simpleNodes=_.filter(g.nodes(),function(v){return!g.children(v).length}),maxRank=_.max(_.map(simpleNodes,function(v){return g.node(v).rank})),layers=_.map(_.range(maxRank+1),function(){return[]});function dfs(v){if(_.has(visited,v))return;visited[v]=true;var node=g.node(v);layers[node.rank].push(v);_.each(g.successors(v),dfs)}var orderedVs=_.sortBy(simpleNodes,function(v){return g.node(v).rank});_.each(orderedVs,dfs);return layers}},{lodash:48}],17:[function(re
 quire,module,exports){"use strict";var _=require("lodash");module.exports=resolveConflicts;function resolveConflicts(entries,cg){var mappedEntries={};_.each(entries,function(entry,i){var tmp=mappedEntries[entry.v]={indegree:0,"in":[],out:[],vs:[entry.v],i:i};if(!_.isUndefined(entry.barycenter)){tmp.barycenter=entry.barycenter;tmp.weight=entry.weight}});_.each(cg.edges(),function(e){var entryV=mappedEntries[e.v],entryW=mappedEntries[e.w];if(!_.isUndefined(entryV)&&!_.isUndefined(entryW)){entryW.indegree++;entryV.out.push(mappedEntries[e.w])}});var sourceSet=_.filter(mappedEntries,function(entry){return!entry.indegree});return doResolveConflicts(sourceSet)}function doResolveConflicts(sourceSet){var entries=[];function handleIn(vEntry){return function(uEntry){if(uEntry.merged){return}if(_.isUndefined(uEntry.barycenter)||_.isUndefined(vEntry.barycenter)||uEntry.barycenter>=vEntry.barycenter){mergeEntries(vEntry,uEntry)}}}function handleOut(vEntry){return function(wEntry){wEntry.in.push(
 vEntry);if(--wEntry.indegree===0){sourceSet.push(wEntry)}}}while(sourceSet.length){var entry=sourceSet.pop();entries.push(entry);_.each(entry.in.reverse(),handleIn(entry));_.each(entry.out,handleOut(entry))}return _.chain(entries).filter(function(entry){return!entry.merged}).map(function(entry){return _.pick(entry,["vs","i","barycenter","weight"])}).value()}function mergeEntries(target,source){var sum=0,weight=0;if(target.weight){sum+=target.barycenter*target.weight;weight+=target.weight}if(source.weight){sum+=source.barycenter*source.weight;weight+=source.weight}target.vs=source.vs.concat(target.vs);target.barycenter=sum/weight;target.weight=weight;target.i=Math.min(source.i,target.i);source.merged=true}},{lodash:48}],18:[function(require,module,exports){var _=require("lodash"),barycenter=require("./barycenter"),resolveConflicts=require("./resolve-conflicts"),sort=require("./sort");module.exports=sortSubgraph;function sortSubgraph(g,v,cg,biasRight){var movable=g.children(v),node=g.
 node(v),bl=node?node.borderLeft:undefined,br=node?node.borderRight:undefined,subgraphs={};if(bl){movable=_.filter(movable,function(w){return w!==bl&&w!==br})}var barycenters=barycenter(g,movable);_.each(barycenters,function(entry){if(g.children(entry.v).length){var subgraphResult=sortSubgraph(g,entry.v,cg,biasRight);subgraphs[entry.v]=subgraphResult;if(_.has(subgraphResult,"barycenter")){mergeBarycenters(entry,subgraphResult)}}});var entries=resolveConflicts(barycenters,cg);expandSubgraphs(entries,subgraphs);var result=sort(entries,biasRight);if(bl){result.vs=_.flatten([bl,result.vs,br],true);if(g.predecessors(bl).length){var blPred=g.node(g.predecessors(bl)[0]),brPred=g.node(g.predecessors(br)[0]);if(!_.has(result,"barycenter")){result.barycenter=0;result.weight=0}result.barycenter=(result.barycenter*result.weight+blPred.order+brPred.order)/(result.weight+2);result.weight+=2}}return result}function expandSubgraphs(entries,subgraphs){_.each(entries,function(entry){entry.vs=_.flatten
 (entry.vs.map(function(v){if(subgraphs[v]){return subgraphs[v].vs}return v}),true)})}function mergeBarycenters(target,other){if(!_.isUndefined(target.barycenter)){target.barycenter=(target.barycenter*target.weight+other.barycenter*other.weight)/(target.weight+other.weight);target.weight+=other.weight}else{target.barycenter=other.barycenter;target.weight=other.weight}}},{"./barycenter":12,"./resolve-conflicts":17,"./sort":19,lodash:48}],19:[function(require,module,exports){var _=require("lodash"),util=require("../util");module.exports=sort;function sort(entries,biasRight){var parts=util.partition(entries,function(entry){return _.has(entry,"barycenter")});var sortable=parts.lhs,unsortable=_.sortBy(parts.rhs,function(entry){return-entry.i}),vs=[],sum=0,weight=0,vsIndex=0;sortable.sort(compareWithBias(!!biasRight));vsIndex=consumeUnsortable(vs,unsortable,vsIndex);_.each(sortable,function(entry){vsIndex+=entry.vs.length;vs.push(entry.vs);sum+=entry.barycenter*entry.weight;weight+=entry.w
 eight;vsIndex=consumeUnsortable(vs,unsortable,vsIndex)});var result={vs:_.flatten(vs,true)};if(weight){result.barycenter=sum/weight;result.weight=weight}return result}function consumeUnsortable(vs,unsortable,index){var last;while(unsortable.length&&(last=_.last(unsortable)).i<=index){unsortable.pop();vs.push(last.vs);index++}return index}function compareWithBias(bias){return function(entryV,entryW){if(entryV.barycenter<entryW.barycenter){return-1}else if(entryV.barycenter>entryW.barycenter){return 1}return!bias?entryV.i-entryW.i:entryW.i-entryV.i}}},{"../util":27,lodash:48}],20:[function(require,module,exports){var _=require("lodash");module.exports=parentDummyChains;function parentDummyChains(g){var postorderNums=postorder(g);_.each(g.graph().dummyChains,function(v){var node=g.node(v),edgeObj=node.edgeObj,pathData=findPath(g,postorderNums,edgeObj.v,edgeObj.w),path=pathData.path,lca=pathData.lca,pathIdx=0,pathV=path[pathIdx],ascending=true;while(v!==edgeObj.w){node=g.node(v);if(asce
 nding){while((pathV=path[pathIdx])!==lca&&g.node(pathV).maxRank<node.rank){pathIdx++}if(pathV===lca){ascending=false}}if(!ascending){while(pathIdx<path.length-1&&g.node(pathV=path[pathIdx+1]).minRank<=node.rank){pathIdx++}pathV=path[pathIdx]}g.setParent(v,pathV);v=g.successors(v)[0]}})}function findPath(g,postorderNums,v,w){var vPath=[],wPath=[],low=Math.min(postorderNums[v].low,postorderNums[w].low),lim=Math.max(postorderNums[v].lim,postorderNums[w].lim),parent,lca;parent=v;do{parent=g.parent(parent);vPath.push(parent)}while(parent&&(postorderNums[parent].low>low||lim>postorderNums[parent].lim));lca=parent;parent=w;while((parent=g.parent(parent))!==lca){wPath.push(parent)}return{path:vPath.concat(wPath.reverse()),lca:lca}}function postorder(g){var result={},lim=0;function dfs(v){var low=lim;_.each(g.children(v),dfs);result[v]={low:low,lim:lim++}}_.each(g.children(),dfs);return result}},{lodash:48}],21:[function(require,module,exports){"use strict";var _=require("lodash"),util=requi
 re("../util");module.exports={positionX:positionX,findType1Conflicts:findType1Conflicts,findType2Conflicts:findType2Conflicts,addConflict:addConflict,hasConflict:hasConflict,verticalAlignment:verticalAlignment,horizontalCompaction:horizontalCompaction,alignCoordinates:alignCoordinates,findSmallestWidthAlignment:findSmallestWidthAlignment,balance:balance};function findType1Conflicts(g,layering){var conflicts={};function visitLayer(prevLayer,layer){var k0=0,scanPos=0,prevLayerLength=prevLayer.length,lastNode=_.last(layer);_.each(layer,function(v,i){var w=findOtherInnerSegmentNode(g,v),k1=w?g.node(w).order:prevLayerLength;if(w||v===lastNode){_.each(layer.slice(scanPos,i+1),function(scanNode){_.each(g.predecessors(scanNode),function(u){var uLabel=g.node(u),uPos=uLabel.order;if((uPos<k0||k1<uPos)&&!(uLabel.dummy&&g.node(scanNode).dummy)){addConflict(conflicts,u,scanNode)}})});scanPos=i+1;k0=k1}});return layer}_.reduce(layering,visitLayer);return conflicts}function findType2Conflicts(g,la
 yering){var conflicts={};function scan(south,southPos,southEnd,prevNorthBorder,nextNorthBorder){var v;_.each(_.range(southPos,southEnd),function(i){v=south[i];if(g.node(v).dummy){_.each(g.predecessors(v),function(u){var uNode=g.node(u);if(uNode.dummy&&(uNode.order<prevNorthBorder||uNode.order>nextNorthBorder)){addConflict(conflicts,u,v)}})}})}function visitLayer(north,south){var prevNorthPos=-1,nextNorthPos,southPos=0;_.each(south,function(v,southLookahead){if(g.node(v).dummy==="border"){var predecessors=g.predecessors(v);if(predecessors.length){nextNorthPos=g.node(predecessors[0]).order;scan(south,southPos,southLookahead,prevNorthPos,nextNorthPos);southPos=southLookahead;prevNorthPos=nextNorthPos}}scan(south,southPos,south.length,nextNorthPos,north.length)});return south}_.reduce(layering,visitLayer);return conflicts}function findOtherInnerSegmentNode(g,v){if(g.node(v).dummy){return _.find(g.predecessors(v),function(u){return g.node(u).dummy})}}function addConflict(conflicts,v,w){i
 f(v>w){var tmp=v;v=w;w=tmp}var conflictsV=conflicts[v];if(!conflictsV){conflicts[v]=conflictsV={}}conflictsV[w]=true}function hasConflict(conflicts,v,w){if(v>w){var tmp=v;v=w;w=tmp}return _.has(conflicts[v],w)}function verticalAlignment(g,layering,conflicts,neighborFn){var root={},align={},pos={};_.each(layering,function(layer){_.each(layer,function(v,order){root[v]=v;align[v]=v;pos[v]=order})});_.each(layering,function(layer){var prevIdx=-1;_.each(layer,function(v){var ws=neighborFn(v);if(ws.length){ws=_.sortBy(ws,function(w){return pos[w]});var mp=(ws.length-1)/2;for(var i=Math.floor(mp),il=Math.ceil(mp);i<=il;++i){var w=ws[i];if(align[v]===v&&prevIdx<pos[w]&&!hasConflict(conflicts,v,w)){align[w]=v;align[v]=root[v]=root[w];prevIdx=pos[w]}}}})});return{root:root,align:align}}function horizontalCompaction(g,layering,root,align){var shift={},sink={},xs={},pred={},graphLabel=g.graph(),sepFn=sep(graphLabel.nodesep,graphLabel.edgesep);_.each(layering,function(layer){_.each(layer,functio
 n(v,order){sink[v]=v;shift[v]=Number.POSITIVE_INFINITY;pred[v]=layer[order-1]})});_.each(g.nodes(),function(v){if(root[v]===v){placeBlock(g,layering,sepFn,root,align,shift,sink,pred,xs,v)}});_.each(layering,function(layer){_.each(layer,function(v){xs[v]=xs[root[v]];if(v===root[v]&&shift[sink[root[v]]]<Number.POSITIVE_INFINITY){xs[v]+=shift[sink[root[v]]]}})});return xs}function placeBlock(g,layering,sepFn,root,align,shift,sink,pred,xs,v){if(_.has(xs,v))return;xs[v]=0;var w=v,u;do{if(pred[w]){u=root[pred[w]];placeBlock(g,layering,sepFn,root,align,shift,sink,pred,xs,u);if(sink[v]===v){sink[v]=sink[u]}var delta=sepFn(g,w,pred[w]);if(sink[v]!==sink[u]){shift[sink[u]]=Math.min(shift[sink[u]],xs[v]-xs[u]-delta)}else{xs[v]=Math.max(xs[v],xs[u]+delta)}}w=align[w]}while(w!==v)}function findSmallestWidthAlignment(g,xss){return _.min(xss,function(xs){var min=_.min(xs,function(x,v){return x-width(g,v)/2}),max=_.max(xs,function(x,v){return x+width(g,v)/2});return max-min})}function alignCoordina
 tes(xss,alignTo){var alignToMin=_.min(alignTo),alignToMax=_.max(alignTo);_.each(["u","d"],function(vert){_.each(["l","r"],function(horiz){var alignment=vert+horiz,xs=xss[alignment],delta;if(xs===alignTo)return;delta=horiz==="l"?alignToMin-_.min(xs):alignToMax-_.max(xs);if(delta){xss[alignment]=_.mapValues(xs,function(x){return x+delta})}})})}function balance(xss,align){return _.mapValues(xss.ul,function(ignore,v){if(align){return xss[align.toLowerCase()][v]}else{var xs=_.sortBy(_.pluck(xss,v));return(xs[1]+xs[2])/2}})}function positionX(g){var layering=util.buildLayerMatrix(g),conflicts=_.merge(findType1Conflicts(g,layering),findType2Conflicts(g,layering));
-var xss={},adjustedLayering;_.each(["u","d"],function(vert){adjustedLayering=vert==="u"?layering:_.values(layering).reverse();_.each(["l","r"],function(horiz){if(horiz==="r"){adjustedLayering=_.map(adjustedLayering,function(inner){return _.values(inner).reverse()})}var neighborFn=vert==="u"?g.predecessors.bind(g):g.successors.bind(g);var align=verticalAlignment(g,adjustedLayering,conflicts,neighborFn);var xs=horizontalCompaction(g,adjustedLayering,align.root,align.align);if(horiz==="r"){xs=_.mapValues(xs,function(x){return-x})}xss[vert+horiz]=xs})});var smallestWidth=findSmallestWidthAlignment(g,xss);alignCoordinates(xss,smallestWidth);return balance(xss,g.graph().align)}function sep(nodeSep,edgeSep){return function(g,v,u){var vLabel=g.node(v),uLabel=g.node(u),sums=uLabel.width+(uLabel.dummy?edgeSep:nodeSep)+(vLabel.dummy?edgeSep:nodeSep)+vLabel.width;return sums/2}}function width(g,v){return g.node(v).width}},{"../util":27,lodash:48}],22:[function(require,module,exports){"use stric
 t";var _=require("lodash"),util=require("../util"),positionX=require("./bk").positionX;module.exports=position;function position(g){g=util.asNonCompoundGraph(g);var rankDir=(g.graph().rankdir||"tb").toLowerCase();if(rankDir==="lr"||rankDir==="rl"){swapWidthHeight(g)}positionY(g);_.each(positionX(g),function(x,v){g.node(v).x=x});if(rankDir==="bt"||rankDir==="rl"){reverseY(g)}if(rankDir==="lr"||rankDir==="rl"){swapXY(g);swapWidthHeight(g)}translate(g)}function positionY(g){var layering=util.buildLayerMatrix(g),rankSep=g.graph().ranksep,prevY=0;_.each(layering,function(layer){var maxHeight=_.max(_.map(layer,function(v){return g.node(v).height}));_.each(layer,function(v){g.node(v).y=prevY+maxHeight/2});prevY+=maxHeight+rankSep})}function translate(g){var minX=Number.POSITIVE_INFINITY,maxX=0,minY=Number.POSITIVE_INFINITY,maxY=0,graphLabel=g.graph(),marginX=graphLabel.marginx||0,marginY=graphLabel.marginy||0;_.each(g.nodes(),function(v){var node=g.node(v),x=node.x,y=node.y,w=node.width,h=
 node.height;minX=Math.min(minX,x-w/2);maxX=Math.max(maxX,x+w/2);minY=Math.min(minY,y-h/2);maxY=Math.max(maxY,y+h/2)});minX-=marginX;minY-=marginY;_.each(g.nodes(),function(v){var node=g.node(v);node.x-=minX;node.y-=minY});graphLabel.width=maxX-minX+marginX;graphLabel.height=maxY-minY+marginY}function reverseY(g){_.each(g.nodes(),function(v){var node=g.node(v);node.y=-node.y})}function swapWidthHeight(g){_.each(g.nodes(),function(v){var node=g.node(v),width=node.width,height=node.height;node.width=height;node.height=width})}function swapXY(g){_.each(g.nodes(),function(v){var node=g.node(v),x=node.x,y=node.y;node.x=y;node.y=x})}},{"../util":27,"./bk":21,lodash:48}],23:[function(require,module,exports){"use strict";var _=require("lodash"),Graph=require("graphlib").Graph,slack=require("./util").slack;module.exports=feasibleTree;function feasibleTree(g){var t=new Graph({directed:false});var start=g.nodes()[0],size=g.nodeCount();t.setNode(start,{});var edge,delta;while(tightTree(t,g)<size
 ){edge=findMinSlackEdge(t,g);delta=t.hasNode(edge.v)?slack(g,edge):-slack(g,edge);shiftRanks(t,g,delta)}return t}function tightTree(t,g){function dfs(v){_.each(g.nodeEdges(v),function(e){var edgeV=e.v,w=v===edgeV?e.w:edgeV;if(!t.hasNode(w)&&!slack(g,e)){t.setNode(w,{});t.setEdge(v,w,{});dfs(w)}})}_.each(t.nodes(),dfs);return t.nodeCount()}function findMinSlackEdge(t,g){return _.min(g.edges(),function(e){if(t.hasNode(e.v)!==t.hasNode(e.w)){return slack(g,e)}})}function shiftRanks(t,g,delta){_.each(t.nodes(),function(v){g.node(v).rank+=delta})}},{"./util":26,graphlib:29,lodash:48}],24:[function(require,module,exports){"use strict";var rankUtil=require("./util"),longestPath=rankUtil.longestPath,feasibleTree=require("./feasible-tree"),networkSimplex=require("./network-simplex");module.exports=rank;function rank(g){switch(g.graph().ranker){case"network-simplex":networkSimplexRanker(g);break;case"tight-tree":tightTreeRanker(g);break;case"longest-path":longestPathRanker(g);break;default:ne
 tworkSimplexRanker(g)}}var longestPathRanker=longestPath;function tightTreeRanker(g){longestPath(g);feasibleTree(g)}function networkSimplexRanker(g){networkSimplex(g)}},{"./feasible-tree":23,"./network-simplex":25,"./util":26}],25:[function(require,module,exports){"use strict";var _=require("lodash"),feasibleTree=require("./feasible-tree"),slack=require("./util").slack,initRank=require("./util").longestPath,preorder=require("graphlib").alg.preorder,postorder=require("graphlib").alg.postorder,simplify=require("../util").simplify;module.exports=networkSimplex;networkSimplex.initLowLimValues=initLowLimValues;networkSimplex.initCutValues=initCutValues;networkSimplex.calcCutValue=calcCutValue;networkSimplex.leaveEdge=leaveEdge;networkSimplex.enterEdge=enterEdge;networkSimplex.exchangeEdges=exchangeEdges;function networkSimplex(g){g=simplify(g);initRank(g);var t=feasibleTree(g);initLowLimValues(t);initCutValues(t,g);var e,f;while(e=leaveEdge(t)){f=enterEdge(t,g,e);exchangeEdges(t,g,e,f)}}
 function initCutValues(t,g){var vs=postorder(t,t.nodes());vs=vs.slice(0,vs.length-1);_.each(vs,function(v){assignCutValue(t,g,v)})}function assignCutValue(t,g,child){var childLab=t.node(child),parent=childLab.parent;t.edge(child,parent).cutvalue=calcCutValue(t,g,child)}function calcCutValue(t,g,child){var childLab=t.node(child),parent=childLab.parent,childIsTail=true,graphEdge=g.edge(child,parent),cutValue=0;if(!graphEdge){childIsTail=false;graphEdge=g.edge(parent,child)}cutValue=graphEdge.weight;_.each(g.nodeEdges(child),function(e){var isOutEdge=e.v===child,other=isOutEdge?e.w:e.v;if(other!==parent){var pointsToHead=isOutEdge===childIsTail,otherWeight=g.edge(e).weight;cutValue+=pointsToHead?otherWeight:-otherWeight;if(isTreeEdge(t,child,other)){var otherCutValue=t.edge(child,other).cutvalue;cutValue+=pointsToHead?-otherCutValue:otherCutValue}}});return cutValue}function initLowLimValues(tree,root){if(arguments.length<2){root=tree.nodes()[0]}dfsAssignLowLim(tree,{},1,root)}function
  dfsAssignLowLim(tree,visited,nextLim,v,parent){var low=nextLim,label=tree.node(v);visited[v]=true;_.each(tree.neighbors(v),function(w){if(!_.has(visited,w)){nextLim=dfsAssignLowLim(tree,visited,nextLim,w,v)}});label.low=low;label.lim=nextLim++;if(parent){label.parent=parent}else{delete label.parent}return nextLim}function leaveEdge(tree){return _.find(tree.edges(),function(e){return tree.edge(e).cutvalue<0})}function enterEdge(t,g,edge){var v=edge.v,w=edge.w;if(!g.hasEdge(v,w)){v=edge.w;w=edge.v}var vLabel=t.node(v),wLabel=t.node(w),tailLabel=vLabel,flip=false;if(vLabel.lim>wLabel.lim){tailLabel=wLabel;flip=true}var candidates=_.filter(g.edges(),function(edge){return flip===isDescendant(t,t.node(edge.v),tailLabel)&&flip!==isDescendant(t,t.node(edge.w),tailLabel)});return _.min(candidates,function(edge){return slack(g,edge)})}function exchangeEdges(t,g,e,f){var v=e.v,w=e.w;t.removeEdge(v,w);t.setEdge(f.v,f.w,{});initLowLimValues(t);initCutValues(t,g);updateRanks(t,g)}function update
 Ranks(t,g){var root=_.find(t.nodes(),function(v){return!g.node(v).parent}),vs=preorder(t,root);vs=vs.slice(1);_.each(vs,function(v){var parent=t.node(v).parent,edge=g.edge(v,parent),flipped=false;if(!edge){edge=g.edge(parent,v);flipped=true}g.node(v).rank=g.node(parent).rank+(flipped?edge.minlen:-edge.minlen)})}function isTreeEdge(tree,u,v){return tree.hasEdge(u,v)}function isDescendant(tree,vLabel,rootLabel){return rootLabel.low<=vLabel.lim&&vLabel.lim<=rootLabel.lim}},{"../util":27,"./feasible-tree":23,"./util":26,graphlib:29,lodash:48}],26:[function(require,module,exports){"use strict";var _=require("lodash");module.exports={longestPath:longestPath,slack:slack};function longestPath(g){var visited={};function dfs(v){var label=g.node(v);if(_.has(visited,v)){return label.rank}visited[v]=true;var rank=_.min(_.map(g.outEdges(v),function(e){return dfs(e.w)-g.edge(e).minlen}));if(rank===Number.POSITIVE_INFINITY){rank=0}return label.rank=rank}_.each(g.sources(),dfs)}function slack(g,e){r
 eturn g.node(e.w).rank-g.node(e.v).rank-g.edge(e).minlen}},{lodash:48}],27:[function(require,module,exports){"use strict";var _=require("lodash"),Graph=require("graphlib").Graph;module.exports={addDummyNode:addDummyNode,simplify:simplify,asNonCompoundGraph:asNonCompoundGraph,successorWeights:successorWeights,predecessorWeights:predecessorWeights,intersectRect:intersectRect,buildLayerMatrix:buildLayerMatrix,normalizeRanks:normalizeRanks,removeEmptyRanks:removeEmptyRanks,addBorderNode:addBorderNode,maxRank:maxRank,partition:partition,time:time,notime:notime};function addDummyNode(g,type,attrs,name){var v;do{v=_.uniqueId(name)}while(g.hasNode(v));attrs.dummy=type;g.setNode(v,attrs);return v}function simplify(g){var simplified=(new Graph).setGraph(g.graph());_.each(g.nodes(),function(v){simplified.setNode(v,g.node(v))});_.each(g.edges(),function(e){var simpleLabel=simplified.edge(e.v,e.w)||{weight:0,minlen:1},label=g.edge(e);simplified.setEdge(e.v,e.w,{weight:simpleLabel.weight+label.we
 ight,minlen:Math.max(simpleLabel.minlen,label.minlen)})});return simplified}function asNonCompoundGraph(g){var simplified=new Graph({multigraph:g.isMultigraph()}).setGraph(g.graph());_.each(g.nodes(),function(v){if(!g.children(v).length){simplified.setNode(v,g.node(v))}});_.each(g.edges(),function(e){simplified.setEdge(e,g.edge(e))});return simplified}function successorWeights(g){var weightMap=_.map(g.nodes(),function(v){var sucs={};_.each(g.outEdges(v),function(e){sucs[e.w]=(sucs[e.w]||0)+g.edge(e).weight});return sucs});return _.zipObject(g.nodes(),weightMap)}function predecessorWeights(g){var weightMap=_.map(g.nodes(),function(v){var preds={};_.each(g.inEdges(v),function(e){preds[e.v]=(preds[e.v]||0)+g.edge(e).weight});return preds});return _.zipObject(g.nodes(),weightMap)}function intersectRect(rect,point){var x=rect.x;var y=rect.y;var dx=point.x-x;var dy=point.y-y;var w=rect.width/2;var h=rect.height/2;if(!dx&&!dy){throw new Error("Not possible to find intersection inside of th
 e rectangle")}var sx,sy;if(Math.abs(dy)*w>Math.abs(dx)*h){if(dy<0){h=-h}sx=h*dx/dy;sy=h}else{if(dx<0){w=-w}sx=w;sy=w*dy/dx}return{x:x+sx,y:y+sy}}function buildLayerMatrix(g){var layering=_.map(_.range(maxRank(g)+1),function(){return[]});_.each(g.nodes(),function(v){var node=g.node(v),rank=node.rank;if(!_.isUndefined(rank)){layering[rank][node.order]=v}});return layering}function normalizeRanks(g){var min=_.min(_.map(g.nodes(),function(v){return g.node(v).rank}));_.each(g.nodes(),function(v){var node=g.node(v);if(_.has(node,"rank")){node.rank-=min}})}function removeEmptyRanks(g){var offset=_.min(_.map(g.nodes(),function(v){return g.node(v).rank}));var layers=[];_.each(g.nodes(),function(v){var rank=g.node(v).rank-offset;if(!_.has(layers,rank)){layers[rank]=[]}layers[rank].push(v)});var delta=0,nodeRankFactor=g.graph().nodeRankFactor;_.each(layers,function(vs,i){if(_.isUndefined(vs)&&i%nodeRankFactor!==0){--delta}else if(delta){_.each(vs,function(v){g.node(v).rank+=delta})}})}function
  addBorderNode(g,prefix,rank,order){var node={width:0,height:0};if(arguments.length>=4){node.rank=rank;node.order=order}return addDummyNode(g,"border",node,prefix)}function maxRank(g){return _.max(_.map(g.nodes(),function(v){var rank=g.node(v).rank;if(!_.isUndefined(rank)){return rank}}))}function partition(collection,fn){var result={lhs:[],rhs:[]};_.each(collection,function(value){if(fn(value)){result.lhs.push(value)}else{result.rhs.push(value)}});return result}function time(name,fn){var start=_.now();try{return fn()}finally{console.log(name+" time: "+(_.now()-start)+"ms")}}function notime(name,fn){return fn()}},{graphlib:29,lodash:48}],28:[function(require,module,exports){module.exports="0.5.1"},{}],29:[function(require,module,exports){var _=require("lodash");module.exports=_.clone(require("./lib"));module.exports.json=require("./lib/json");module.exports.alg=require("./lib/alg")},{"./lib":45,"./lib/alg":36,"./lib/json":46,lodash:48}],30:[function(require,module,exports){var _=req
 uire("lodash");module.exports=components;function components(g){var visited={},cmpts=[],cmpt;function dfs(v){if(_.has(visited,v))return;visited[v]=true;cmpt.push(v);_.each(g.successors(v),dfs);_.each(g.predecessors(v),dfs)}_.each(g.nodes(),function(v){cmpt=[];dfs(v);if(cmpt.length){cmpts.push(cmpt)}});return cmpts}},{lodash:48}],31:[function(require,module,exports){var _=require("lodash");module.exports=dfs;function dfs(g,vs,order){if(!_.isArray(vs)){vs=[vs]}var acc=[],visited={};_.each(vs,function(v){if(!g.hasNode(v)){throw new Error("Graph does not have node: "+v)}doDfs(g,v,order==="post",visited,acc)});return acc}function doDfs(g,v,postorder,visited,acc){if(!_.has(visited,v)){visited[v]=true;if(!postorder){acc.push(v)}_.each(g.neighbors(v),function(w){doDfs(g,w,postorder,visited,acc)});if(postorder){acc.push(v)}}}},{lodash:48}],32:[function(require,module,exports){var dijkstra=require("./dijkstra"),_=require("lodash");module.exports=dijkstraAll;function dijkstraAll(g,weightFunc,e
 dgeFunc){return _.transform(g.nodes(),function(acc,v){acc[v]=dijkstra(g,v,weightFunc,edgeFunc)},{})}},{"./dijkstra":33,lodash:48}],33:[function(require,module,exports){var _=require("lodash"),PriorityQueue=require("../data/priority-queue");module.exports=dijkstra;var DEFAULT_WEIGHT_FUNC=_.constant(1);function dijkstra(g,source,weightFn,edgeFn){return runDijkstra(g,String(source),weightFn||DEFAULT_WEIGHT_FUNC,edgeFn||function(v){return g.outEdges(v)})}function runDijkstra(g,source,weightFn,edgeFn){var results={},pq=new PriorityQueue,v,vEntry;var updateNeighbors=function(edge){var w=edge.v!==v?edge.v:edge.w,wEntry=results[w],weight=weightFn(edge),distance=vEntry.distance+weight;if(weight<0){throw new Error("dijkstra does not allow negative edge weights. "+"Bad edge: "+edge+" Weight: "+weight)}if(distance<wEntry.distance){wEntry.distance=distance;wEntry.predecessor=v;pq.decrease(w,distance)}};g.nodes().forEach(function(v){var distance=v===source?0:Number.POSITIVE_INFINITY;results[v]={d
 istance:distance};pq.add(v,distance)});while(pq.size()>0){v=pq.removeMin();vEntry=results[v];if(vEntry.distance===Number.POSITIVE_INFINITY){break}edgeFn(v).forEach(updateNeighbors)}return results}},{"../data/priority-queue":43,lodash:48}],34:[function(require,module,exports){var _=require("lodash"),tarjan=require("./tarjan");module.exports=findCycles;function findCycles(g){return _.filter(tarjan(g),function(cmpt){return cmpt.length>1})}},{"./tarjan":41,lodash:48}],35:[function(require,module,exports){var _=require("lodash");module.exports=floydWarshall;var DEFAULT_WEIGHT_FUNC=_.constant(1);function floydWarshall(g,weightFn,edgeFn){return runFloydWarshall(g,weightFn||DEFAULT_WEIGHT_FUNC,edgeFn||function(v){return g.outEdges(v)})}function runFloydWarshall(g,weightFn,edgeFn){var results={},nodes=g.nodes();nodes.forEach(function(v){results[v]={};results[v][v]={distance:0};nodes.forEach(function(w){if(v!==w){results[v][w]={distance:Number.POSITIVE_INFINITY}}});edgeFn(v).forEach(function(
 edge){var w=edge.v===v?edge.w:edge.v,d=weightFn(edge);results[v][w]={distance:d,predecessor:v}})});nodes.forEach(function(k){var rowK=results[k];nodes.forEach(function(i){var rowI=results[i];nodes.forEach(function(j){var ik=rowI[k];var kj=rowK[j];var ij=rowI[j];var altDistance=ik.distance+kj.distance;if(altDistance<ij.distance){ij.distance=altDistance;ij.predecessor=kj.predecessor}})})});return results}},{lodash:48}],36:[function(require,module,exports){module.exports={components:require("./components"),dijkstra:require("./dijkstra"),dijkstraAll:require("./dijkstra-all"),findCycles:require("./find-cycles"),floydWarshall:require("./floyd-warshall"),isAcyclic:require("./is-acyclic"),postorder:require("./postorder"),preorder:require("./preorder"),prim:require("./prim"),tarjan:require("./tarjan"),topsort:require("./topsort")}},{"./components":30,"./dijkstra":33,"./dijkstra-all":32,"./find-cycles":34,"./floyd-warshall":35,"./is-acyclic":37,"./postorder":38,"./preorder":39,"./prim":40,"./
 tarjan":41,"./topsort":42}],37:[function(require,module,exports){var topsort=require("./topsort");module.exports=isAcyclic;function isAcyclic(g){try{topsort(g)}catch(e){if(e instanceof topsort.CycleException){return false}throw e}return true}},{"./topsort":42}],38:[function(require,module,exports){var dfs=require("./dfs");module.exports=postorder;function postorder(g,vs){return dfs(g,vs,"post")}},{"./dfs":31}],39:[function(require,module,exports){var dfs=require("./dfs");module.exports=preorder;function preorder(g,vs){return dfs(g,vs,"pre")}},{"./dfs":31}],40:[function(require,module,exports){var _=require("lodash"),Graph=require("../graph"),PriorityQueue=require("../data/priority-queue");module.exports=prim;function prim(g,weightFunc){var result=new Graph,parents={},pq=new PriorityQueue,v;function updateNeighbors(edge){var w=edge.v===v?edge.w:edge.v,pri=pq.priority(w);if(pri!==undefined){var edgeWeight=weightFunc(edge);if(edgeWeight<pri){parents[w]=v;pq.decrease(w,edgeWeight)}}}if(
 g.nodeCount()===0){return result}_.each(g.nodes(),function(v){pq.add(v,Number.POSITIVE_INFINITY);result.setNode(v)});pq.decrease(g.nodes()[0],0);var init=false;while(pq.size()>0){v=pq.removeMin();if(_.has(parents,v)){result.setEdge(v,parents[v])}else if(init){throw new Error("Input graph is not connected: "+g)}else{init=true}g.nodeEdges(v).forEach(updateNeighbors)}return result}},{"../data/priority-queue":43,"../graph":44,lodash:48}],41:[function(require,module,exports){var _=require("lodash");module.exports=tarjan;function tarjan(g){var index=0,stack=[],visited={},results=[];function dfs(v){var entry=visited[v]={onStack:true,lowlink:index,index:index++};stack.push(v);g.successors(v).forEach(function(w){if(!_.has(visited,w)){dfs(w);entry.lowlink=Math.min(entry.lowlink,visited[w].lowlink)}else if(visited[w].onStack){entry.lowlink=Math.min(entry.lowlink,visited[w].index)}});if(entry.lowlink===entry.index){var cmpt=[],w;do{w=stack.pop();visited[w].onStack=false;cmpt.push(w)}while(v!==w
 );results.push(cmpt)}}g.nodes().forEach(function(v){if(!_.has(visited,v)){dfs(v)}});return results}},{lodash:48}],42:[function(require,module,exports){var _=require("lodash");module.exports=topsort;topsort.CycleException=CycleException;function topsort(g){var visited={},stack={},results=[];function visit(node){if(_.has(stack,node)){throw new CycleException}if(!_.has(visited,node)){stack[node]=true;visited[node]=true;_.each(g.predecessors(node),visit);delete stack[node];results.push(node)}}_.each(g.sinks(),visit);if(_.size(visited)!==g.nodeCount()){throw new CycleException}return results}function CycleException(){}},{lodash:48}],43:[function(require,module,exports){var _=require("lodash");module.exports=PriorityQueue;function PriorityQueue(){this._arr=[];this._keyIndices={}}PriorityQueue.prototype.size=function(){return this._arr.length};PriorityQueue.prototype.keys=function(){return this._arr.map(function(x){return x.key})};PriorityQueue.prototype.has=function(key){return _.has(this
 ._keyIndices,key)};PriorityQueue.prototype.priority=function(key){var index=this._keyIndices[key];if(index!==undefined){return this._arr[index].priority}};PriorityQueue.prototype.min=function(){if(this.size()===0){throw new Error("Queue underflow")}return this._arr[0].key};PriorityQueue.prototype.add=function(key,priority){var keyIndices=this._keyIndices;key=String(key);if(!_.has(keyIndices,key)){var arr=this._arr;var index=arr.length;keyIndices[key]=index;arr.push({key:key,priority:priority});this._decrease(index);return true}return false};PriorityQueue.prototype.removeMin=function(){this._swap(0,this._arr.length-1);var min=this._arr.pop();delete this._keyIndices[min.key];this._heapify(0);return min.key};PriorityQueue.prototype.decrease=function(key,priority){var index=this._keyIndices[key];if(priority>this._arr[index].priority){throw new Error("New priority is greater than current priority. "+"Key: "+key+" Old: "+this._arr[index].priority+" New: "+priority)}this._arr[index].priori
 ty=priority;this._decrease(index)};PriorityQueue.prototype._heapify=function(i){var arr=this._arr;var l=2*i,r=l+1,largest=i;if(l<arr.length){largest=arr[l].priority<arr[largest].priority?l:largest;if(r<arr.length){largest=arr[r].priority<arr[largest].priority?r:largest}if(largest!==i){this._swap(i,largest);this._heapify(largest)}}};PriorityQueue.prototype._decrease=function(index){var arr=this._arr;var priority=arr[index].priority;var parent;while(index!==0){parent=index>>1;if(arr[parent].priority<priority){break}this._swap(index,parent);index=parent}};PriorityQueue.prototype._swap=function(i,j){var arr=this._arr;var keyIndices=this._keyIndices;var origArrI=arr[i];var origArrJ=arr[j];arr[i]=origArrJ;arr[j]=origArrI;keyIndices[origArrJ.key]=i;keyIndices[origArrI.key]=j}},{lodash:48}],44:[function(require,module,exports){"use strict";var _=require("lodash");module.exports=Graph;var DEFAULT_EDGE_NAME="\x00",GRAPH_NODE="\x00",EDGE_KEY_DELIM="";function Graph(opts){this._isDirected=_.ha
 s(opts,"directed")?opts.directed:true;this._isMultigraph=_.has(opts,"multigraph")?opts.multigraph:false;this._isCompound=_.has(opts,"compound")?opts.compound:false;this._label=undefined;this._defaultNodeLabelFn=_.constant(undefined);this._defaultEdgeLabelFn=_.constant(undefined);this._nodes={};if(this._isCompound){this._parent={};this._children={};this._children[GRAPH_NODE]={}}this._in={};this._preds={};this._out={};this._sucs={};this._edgeObjs={};this._edgeLabels={}}Graph.prototype._nodeCount=0;Graph.prototype._edgeCount=0;Graph.prototype.isDirected=function(){return this._isDirected};Graph.prototype.isMultigraph=function(){return this._isMultigraph};Graph.prototype.isCompound=function(){return this._isCompound};Graph.prototype.setGraph=function(label){this._label=label;return this};Graph.prototype.graph=function(){return this._label};Graph.prototype.setDefaultNodeLabel=function(newDefault){if(!_.isFunction(newDefault)){newDefault=_.constant(newDefault)}this._defaultNodeLabelFn=new
 Default;return this};Graph.prototype.nodeCount=function(){return this._nodeCount};Graph.prototype.nodes=function(){return _.keys(this._nodes)};Graph.prototype.sources=function(){return _.filter(this.nodes(),function(v){return _.isEmpty(this._in[v])},this)};Graph.prototype.sinks=function(){return _.filter(this.nodes(),function(v){return _.isEmpty(this._out[v])},this)};Graph.prototype.setNodes=function(vs,value){var args=arguments;_.each(vs,function(v){if(args.length>1){this.setNode(v,value)}else{this.setNode(v)}},this);return this};Graph.prototype.setNode=function(v,value){if(_.has(this._nodes,v)){if(arguments.length>1){this._nodes[v]=value}return this}this._nodes[v]=arguments.length>1?value:this._defaultNodeLabelFn(v);if(this._isCompound){this._parent[v]=GRAPH_NODE;this._children[v]={};this._children[GRAPH_NODE][v]=true}this._in[v]={};this._preds[v]={};this._out[v]={};this._sucs[v]={};++this._nodeCount;return this};Graph.prototype.node=function(v){return this._nodes[v]};Graph.protot
 ype.hasNode=function(v){return _.has(this._nodes,v)};Graph.prototype.removeNode=function(v){var self=this;if(_.has(this._nodes,v)){var removeEdge=function(e){self.removeEdge(self._edgeObjs[e])};delete this._nodes[v];if(this._isCompound){this._removeFromParentsChildList(v);delete this._parent[v];_.each(this.children(v),function(child){this.setParent(child)},this);delete this._children[v]}_.each(_.keys(this._in[v]),removeEdge);delete this._in[v];delete this._preds[v];_.each(_.keys(this._out[v]),removeEdge);delete this._out[v];delete this._sucs[v];--this._nodeCount}return this};Graph.prototype.setParent=function(v,parent){if(!this._isCompound){throw new Error("Cannot set parent in a non-compound graph")}if(_.isUndefined(parent)){parent=GRAPH_NODE}else{for(var ancestor=parent;!_.isUndefined(ancestor);ancestor=this.parent(ancestor)){if(ancestor===v){throw new Error("Setting "+parent+" as parent of "+v+" would create create a cycle")}}this.setNode(parent)}this.setNode(v);this._removeFromP
 arentsChildList(v);this._parent[v]=parent;this._children[parent][v]=true;return this};Graph.prototype._removeFromParentsChildList=function(v){delete this._children[this._parent[v]][v]};Graph.prototype.parent=function(v){if(this._isCompound){var parent=this._parent[v];if(parent!==GRAPH_NODE){return parent}}};Graph.prototype.children=function(v){if(_.isUndefined(v)){v=GRAPH_NODE}if(this._isCompound){var children=this._children[v];if(children){return _.keys(children)}}else if(v===GRAPH_NODE){return this.nodes()}else if(this.hasNode(v)){return[]}};Graph.prototype.predecessors=function(v){var predsV=this._preds[v];if(predsV){return _.keys(predsV)}};Graph.prototype.successors=function(v){var sucsV=this._sucs[v];if(sucsV){return _.keys(sucsV)}};Graph.prototype.neighbors=function(v){var preds=this.predecessors(v);if(preds){return _.union(preds,this.successors(v))}};Graph.prototype.setDefaultEdgeLabel=function(newDefault){if(!_.isFunction(newDefault)){newDefault=_.constant(newDefault)}this._
 defaultEdgeLabelFn=newDefault;return this};Graph.prototype.edgeCount=function(){return this._edgeCount};Graph.prototype.edges=function(){return _.values(this._edgeObjs)};Graph.prototype.setPath=function(vs,value){var self=this,args=arguments;_.reduce(vs,function(v,w){if(args.length>1){self.setEdge(v,w,value)}else{self.setEdge(v,w)}return w});return this};Graph.prototype.setEdge=function(v,w,value,name){var valueSpecified=arguments.length>2;if(_.isPlainObject(arguments[0])){v=arguments[0].v;w=arguments[0].w;name=arguments[0].name;if(arguments.length===2){value=arguments[1];valueSpecified=true}}var e=edgeArgsToId(this._isDirected,v,w,name);if(_.has(this._edgeLabels,e)){if(valueSpecified){this._edgeLabels[e]=value}return this}if(!_.isUndefined(name)&&!this._isMultigraph){throw new Error("Cannot set a named edge when isMultigraph = false")}this.setNode(v);this.setNode(w);this._edgeLabels[e]=valueSpecified?value:this._defaultEdgeLabelFn(v,w,name);var edgeObj=edgeArgsToObj(this._isDirecte
 d,v,w,name);v=edgeObj.v;w=edgeObj.w;Object.freeze(edgeObj);this._edgeObjs[e]=edgeObj;incrementOrInitEntry(this._preds[w],v);incrementOrInitEntry(this._sucs[v],w);this._in[w][e]=edgeObj;this._out[v][e]=edgeObj;this._edgeCount++;return this};Graph.prototype.edge=function(v,w,name){var e=arguments.length===1?edgeObjToId(this._isDirected,arguments[0]):edgeArgsToId(this._isDirected,v,w,name);return this._edgeLabels[e]};Graph.prototype.hasEdge=function(v,w,name){var e=arguments.length===1?edgeObjToId(this._isDirected,arguments[0]):edgeArgsToId(this._isDirected,v,w,name);return _.has(this._edgeLabels,e)};Graph.prototype.removeEdge=function(v,w,name){var e=arguments.length===1?edgeObjToId(this._isDirected,arguments[0]):edgeArgsToId(this._isDirected,v,w,name),edge=this._edgeObjs[e];if(edge){v=edge.v;w=edge.w;delete this._edgeLabels[e];delete this._edgeObjs[e];decrementOrRemoveEntry(this._preds[w],v);decrementOrRemoveEntry(this._sucs[v],w);delete this._in[w][e];delete this._out[v][e];this._ed
 geCount--}return this};Graph.prototype.inEdges=function(v,u){var inV=this._in[v];if(inV){var edges=_.values(inV);if(!u){return edges}return _.filter(edges,function(edge){return edge.v===u})}};Graph.prototype.outEdges=function(v,w){var outV=this._out[v];if(outV){var edges=_.values(outV);if(!w){return edges}return _.filter(edges,function(edge){return edge.w===w})}};Graph.prototype.nodeEdges=function(v,w){var inEdges=this.inEdges(v,w);if(inEdges){return inEdges.concat(this.outEdges(v,w))}};function incrementOrInitEntry(map,k){if(_.has(map,k)){map[k]++}else{map[k]=1}}function decrementOrRemoveEntry(map,k){if(!--map[k]){delete map[k]}}function edgeArgsToId(isDirected,v,w,name){if(!isDirected&&v>w){var tmp=v;v=w;w=tmp}return v+EDGE_KEY_DELIM+w+EDGE_KEY_DELIM+(_.isUndefined(name)?DEFAULT_EDGE_NAME:name)}function edgeArgsToObj(isDirected,v,w,name){if(!isDirected&&v>w){var tmp=v;v=w;w=tmp}var edgeObj={v:v,w:w};if(name){edgeObj.name=name}return edgeObj}function edgeObjToId(isDirected,edgeObj)
 {return edgeArgsToId(isDirected,edgeObj.v,edgeObj.w,edgeObj.name)}},{lodash:48}],45:[function(require,module,exports){module.exports={Graph:require("./graph"),version:require("./version")}},{"./graph":44,"./version":47}],46:[function(require,module,exports){var _=require("lodash"),Graph=require("./graph");module.exports={write:write,read:read};function write(g){var json={options:{directed:g.isDirected(),multigraph:g.isMultigraph(),compound:g.isCompound()},nodes:writeNodes(g),edges:writeEdges(g)};if(!_.isUndefined(g.graph())){json.value=_.clone(g.graph())}return json}function writeNodes(g){return _.map(g.nodes(),function(v){var nodeValue=g.node(v),parent=g.parent(v),node={v:v};if(!_.isUndefined(nodeValue)){node.value=nodeValue}if(!_.isUndefined(parent)){node.parent=parent}return node})}function writeEdges(g){return _.map(g.edges(),function(e){var edgeValue=g.edge(e),edge={v:e.v,w:e.w};if(!_.isUndefined(e.name)){edge.name=e.name}if(!_.isUndefined(edgeValue)){edge.value=edgeValue}retur
 n edge})}function read(json){var g=new Graph(json.options).setGraph(json.value);_.each(json.nodes,function(entry){g.setNode(entry.v,entry.value);if(entry.parent){g.setParent(entry.v,entry.parent)}});_.each(json.edges,function(entry){g.setEdge({v:entry.v,w:entry.w,name:entry.name},entry.value)});return g}},{"./graph":44,lodash:48}],47:[function(require,module,exports){module.exports="0.8.0"},{}],48:[function(require,module,exports){(function(global){(function(){var undefined;var arrayPool=[],objectPool=[];var idCounter=0;var keyPrefix=+new Date+"";var largeArraySize=75;var maxPoolSize=40;var whitespace="   \f \ufeff"+"\n\r\u2028\u2029"+"\u1680\u180e\u2000\u2001\u2002\u2003\u2004\u2005\u2006\u2007\u2008\u2009\u200a\u202f\u205f\u3000";var reEmptyStringLeading=/\b__p \+= '';/g,reEmptyStringMiddle=/\b(__p \+=) '' \+/g,reEmptyStringTrailing=/(__e\(.*?\)|\b__t\)) \+\n'';/g;var reEsTemplate=/\$\{([^\\}]*(?:\\.[^\\}]*)*)\}/g;var reFlags=/\w*$/;var reFuncName=/^\s*function[ \n\r\t]+\w/;var reInterpolate=/<%=([\s\S]+?)%>/g;var reLeadingSpaces
 AndZeros=RegExp("^["+whitespace+"]*0+(?=.$)");var reNoMatch=/($^)/;var reThis=/\bthis\b/;var reUnescapedString=/['\n\r\t\u2028\u2029\\]/g;var contextProps=["Array","Boolean","Date","Function","Math","Number","Object","RegExp","String","_","attachEvent","clearTimeout","isFinite","isNaN","parseInt","setTimeout"];var templateCounter=0;var argsClass="[object Arguments]",arrayClass="[object Array]",boolClass="[object Boolean]",dateClass="[object Date]",funcClass="[object Function]",numberClass="[object Number]",objectClass="[object Object]",regexpClass="[object RegExp]",stringClass="[object String]";var cloneableClasses={};cloneableClasses[funcClass]=false;cloneableClasses[argsClass]=cloneableClasses[arrayClass]=cloneableClasses[boolClass]=cloneableClasses[dateClass]=cloneableClasses[numberClass]=cloneableClasses[objectClass]=cloneableClasses[regexpClass]=cloneableClasses[stringClass]=true;var debounceOptions={leading:false,maxWait:0,trailing:false};var descriptor={configurable:false,enu
 merable:false,value:null,writable:false};var objectTypes={"boolean":false,"function":true,object:true,number:false,string:false,undefined:false};var stringEscapes={"\\":"\\","'":"'","\n":"n","\r":"r","  ":"t","\u2028":"u2028","\u2029":"u2029"};var root=objectTypes[typeof window]&&window||this;var freeExports=objectTypes[typeof exports]&&exports&&!exports.nodeType&&exports;var freeModule=objectTypes[typeof module]&&module&&!module.nodeType&&module;var moduleExports=freeModule&&freeModule.exports===freeExports&&freeExports;var freeGlobal=objectTypes[typeof global]&&global;if(freeGlobal&&(freeGlobal.global===freeGlobal||freeGlobal.window===freeGlobal)){root=freeGlobal}function baseIndexOf(array,value,fromIndex){var index=(fromIndex||0)-1,length=array?array.length:0;while(++index<length){if(array[index]===value){return index}}return-1}function cacheIndexOf(cache,value){var type=typeof value;cache=cache.cache;if(type=="boolean"||value==null){return cache[value]?0:-1}if(type!="number"&&ty
 pe!="string"){type="object"}var key=type=="number"?value:keyPrefix+value;cache=(cache=cache[type])&&cache[key];return type=="object"?cache&&baseIndexOf(cache,value)>-1?0:-1:cache?0:-1
-}function cachePush(value){var cache=this.cache,type=typeof value;if(type=="boolean"||value==null){cache[value]=true}else{if(type!="number"&&type!="string"){type="object"}var key=type=="number"?value:keyPrefix+value,typeCache=cache[type]||(cache[type]={});if(type=="object"){(typeCache[key]||(typeCache[key]=[])).push(value)}else{typeCache[key]=true}}}function charAtCallback(value){return value.charCodeAt(0)}function compareAscending(a,b){var ac=a.criteria,bc=b.criteria,index=-1,length=ac.length;while(++index<length){var value=ac[index],other=bc[index];if(value!==other){if(value>other||typeof value=="undefined"){return 1}if(value<other||typeof other=="undefined"){return-1}}}return a.index-b.index}function createCache(array){var index=-1,length=array.length,first=array[0],mid=array[length/2|0],last=array[length-1];if(first&&typeof first=="object"&&mid&&typeof mid=="object"&&last&&typeof last=="object"){return false}var cache=getObject();cache["false"]=cache["null"]=cache["true"]=cache[
 "undefined"]=false;var result=getObject();result.array=array;result.cache=cache;result.push=cachePush;while(++index<length){result.push(array[index])}return result}function escapeStringChar(match){return"\\"+stringEscapes[match]}function getArray(){return arrayPool.pop()||[]}function getObject(){return objectPool.pop()||{array:null,cache:null,criteria:null,"false":false,index:0,"null":false,number:null,object:null,push:null,string:null,"true":false,undefined:false,value:null}}function releaseArray(array){array.length=0;if(arrayPool.length<maxPoolSize){arrayPool.push(array)}}function releaseObject(object){var cache=object.cache;if(cache){releaseObject(cache)}object.array=object.cache=object.criteria=object.object=object.number=object.string=object.value=null;if(objectPool.length<maxPoolSize){objectPool.push(object)}}function slice(array,start,end){start||(start=0);if(typeof end=="undefined"){end=array?array.length:0}var index=-1,length=end-start||0,result=Array(length<0?0:length);whi
 le(++index<length){result[index]=array[start+index]}return result}function runInContext(context){context=context?_.defaults(root.Object(),context,_.pick(root,contextProps)):root;var Array=context.Array,Boolean=context.Boolean,Date=context.Date,Function=context.Function,Math=context.Math,Number=context.Number,Object=context.Object,RegExp=context.RegExp,String=context.String,TypeError=context.TypeError;var arrayRef=[];var objectProto=Object.prototype;var oldDash=context._;var toString=objectProto.toString;var reNative=RegExp("^"+String(toString).replace(/[.*+?^${}()|[\]\\]/g,"\\$&").replace(/toString| for [^\]]+/g,".*?")+"$");var ceil=Math.ceil,clearTimeout=context.clearTimeout,floor=Math.floor,fnToString=Function.prototype.toString,getPrototypeOf=isNative(getPrototypeOf=Object.getPrototypeOf)&&getPrototypeOf,hasOwnProperty=objectProto.hasOwnProperty,push=arrayRef.push,setTimeout=context.setTimeout,splice=arrayRef.splice,unshift=arrayRef.unshift;var defineProperty=function(){try{var o
 ={},func=isNative(func=Object.defineProperty)&&func,result=func(o,o,o)&&func}catch(e){}return result}();var nativeCreate=isNative(nativeCreate=Object.create)&&nativeCreate,nativeIsArray=isNative(nativeIsArray=Array.isArray)&&nativeIsArray,nativeIsFinite=context.isFinite,nativeIsNaN=context.isNaN,nativeKeys=isNative(nativeKeys=Object.keys)&&nativeKeys,nativeMax=Math.max,nativeMin=Math.min,nativeParseInt=context.parseInt,nativeRandom=Math.random;var ctorByClass={};ctorByClass[arrayClass]=Array;ctorByClass[boolClass]=Boolean;ctorByClass[dateClass]=Date;ctorByClass[funcClass]=Function;ctorByClass[objectClass]=Object;ctorByClass[numberClass]=Number;ctorByClass[regexpClass]=RegExp;ctorByClass[stringClass]=String;function lodash(value){return value&&typeof value=="object"&&!isArray(value)&&hasOwnProperty.call(value,"__wrapped__")?value:new lodashWrapper(value)}function lodashWrapper(value,chainAll){this.__chain__=!!chainAll;this.__wrapped__=value}lodashWrapper.prototype=lodash.prototype;va
 r support=lodash.support={};support.funcDecomp=!isNative(context.WinRTError)&&reThis.test(runInContext);support.funcNames=typeof Function.name=="string";lodash.templateSettings={escape:/<%-([\s\S]+?)%>/g,evaluate:/<%([\s\S]+?)%>/g,interpolate:reInterpolate,variable:"",imports:{_:lodash}};function baseBind(bindData){var func=bindData[0],partialArgs=bindData[2],thisArg=bindData[4];function bound(){if(partialArgs){var args=slice(partialArgs);push.apply(args,arguments)}if(this instanceof bound){var thisBinding=baseCreate(func.prototype),result=func.apply(thisBinding,args||arguments);return isObject(result)?result:thisBinding}return func.apply(thisArg,args||arguments)}setBindData(bound,bindData);return bound}function baseClone(value,isDeep,callback,stackA,stackB){if(callback){var result=callback(value);if(typeof result!="undefined"){return result}}var isObj=isObject(value);if(isObj){var className=toString.call(value);if(!cloneableClasses[className]){return value}var ctor=ctorByClass[clas
 sName];switch(className){case boolClass:case dateClass:return new ctor(+value);case numberClass:case stringClass:return new ctor(value);case regexpClass:result=ctor(value.source,reFlags.exec(value));result.lastIndex=value.lastIndex;return result}}else{return value}var isArr=isArray(value);if(isDeep){var initedStack=!stackA;stackA||(stackA=getArray());stackB||(stackB=getArray());var length=stackA.length;while(length--){if(stackA[length]==value){return stackB[length]}}result=isArr?ctor(value.length):{}}else{result=isArr?slice(value):assign({},value)}if(isArr){if(hasOwnProperty.call(value,"index")){result.index=value.index}if(hasOwnProperty.call(value,"input")){result.input=value.input}}if(!isDeep){return result}stackA.push(value);stackB.push(result);(isArr?forEach:forOwn)(value,function(objValue,key){result[key]=baseClone(objValue,isDeep,callback,stackA,stackB)});if(initedStack){releaseArray(stackA);releaseArray(stackB)}return result}function baseCreate(prototype,properties){return is
 Object(prototype)?nativeCreate(prototype):{}}if(!nativeCreate){baseCreate=function(){function Object(){}return function(prototype){if(isObject(prototype)){Object.prototype=prototype;var result=new Object;Object.prototype=null}return result||context.Object()}}()}function baseCreateCallback(func,thisArg,argCount){if(typeof func!="function"){return identity}if(typeof thisArg=="undefined"||!("prototype"in func)){return func}var bindData=func.__bindData__;if(typeof bindData=="undefined"){if(support.funcNames){bindData=!func.name}bindData=bindData||!support.funcDecomp;if(!bindData){var source=fnToString.call(func);if(!support.funcNames){bindData=!reFuncName.test(source)}if(!bindData){bindData=reThis.test(source);setBindData(func,bindData)}}}if(bindData===false||bindData!==true&&bindData[1]&1){return func}switch(argCount){case 1:return function(value){return func.call(thisArg,value)};case 2:return function(a,b){return func.call(thisArg,a,b)};case 3:return function(value,index,collection){r
 eturn func.call(thisArg,value,index,collection)};case 4:return function(accumulator,value,index,collection){return func.call(thisArg,accumulator,value,index,collection)}}return bind(func,thisArg)}function baseCreateWrapper(bindData){var func=bindData[0],bitmask=bindData[1],partialArgs=bindData[2],partialRightArgs=bindData[3],thisArg=bindData[4],arity=bindData[5];var isBind=bitmask&1,isBindKey=bitmask&2,isCurry=bitmask&4,isCurryBound=bitmask&8,key=func;function bound(){var thisBinding=isBind?thisArg:this;if(partialArgs){var args=slice(partialArgs);push.apply(args,arguments)}if(partialRightArgs||isCurry){args||(args=slice(arguments));if(partialRightArgs){push.apply(args,partialRightArgs)}if(isCurry&&args.length<arity){bitmask|=16&~32;return baseCreateWrapper([func,isCurryBound?bitmask:bitmask&~3,args,null,thisArg,arity])}}args||(args=arguments);if(isBindKey){func=thisBinding[key]}if(this instanceof bound){thisBinding=baseCreate(func.prototype);var result=func.apply(thisBinding,args);r
 eturn isObject(result)?result:thisBinding}return func.apply(thisBinding,args)}setBindData(bound,bindData);return bound}function baseDifference(array,values){var index=-1,indexOf=getIndexOf(),length=array?array.length:0,isLarge=length>=largeArraySize&&indexOf===baseIndexOf,result=[];if(isLarge){var cache=createCache(values);if(cache){indexOf=cacheIndexOf;values=cache}else{isLarge=false}}while(++index<length){var value=array[index];if(indexOf(values,value)<0){result.push(value)}}if(isLarge){releaseObject(values)}return result}function baseFlatten(array,isShallow,isStrict,fromIndex){var index=(fromIndex||0)-1,length=array?array.length:0,result=[];while(++index<length){var value=array[index];if(value&&typeof value=="object"&&typeof value.length=="number"&&(isArray(value)||isArguments(value))){if(!isShallow){value=baseFlatten(value,isShallow,isStrict)}var valIndex=-1,valLength=value.length,resIndex=result.length;result.length+=valLength;while(++valIndex<valLength){result[resIndex++]=valu
 e[valIndex]}}else if(!isStrict){result.push(value)}}return result}function baseIsEqual(a,b,callback,isWhere,stackA,stackB){if(callback){var result=callback(a,b);if(typeof result!="undefined"){return!!result}}if(a===b){return a!==0||1/a==1/b}var type=typeof a,otherType=typeof b;if(a===a&&!(a&&objectTypes[type])&&!(b&&objectTypes[otherType])){return false}if(a==null||b==null){return a===b}var className=toString.call(a),otherClass=toString.call(b);if(className==argsClass){className=objectClass}if(otherClass==argsClass){otherClass=objectClass}if(className!=otherClass){return false}switch(className){case boolClass:case dateClass:return+a==+b;case numberClass:return a!=+a?b!=+b:a==0?1/a==1/b:a==+b;case regexpClass:case stringClass:return a==String(b)}var isArr=className==arrayClass;if(!isArr){var aWrapped=hasOwnProperty.call(a,"__wrapped__"),bWrapped=hasOwnProperty.call(b,"__wrapped__");if(aWrapped||bWrapped){return baseIsEqual(aWrapped?a.__wrapped__:a,bWrapped?b.__wrapped__:b,callback,is
 Where,stackA,stackB)}if(className!=objectClass){return false}var ctorA=a.constructor,ctorB=b.constructor;if(ctorA!=ctorB&&!(isFunction(ctorA)&&ctorA instanceof ctorA&&isFunction(ctorB)&&ctorB instanceof ctorB)&&("constructor"in a&&"constructor"in b)){return false}}var initedStack=!stackA;stackA||(stackA=getArray());stackB||(stackB=getArray());var length=stackA.length;while(length--){if(stackA[length]==a){return stackB[length]==b}}var size=0;result=true;stackA.push(a);stackB.push(b);if(isArr){length=a.length;size=b.length;result=size==length;if(result||isWhere){while(size--){var index=length,value=b[size];if(isWhere){while(index--){if(result=baseIsEqual(a[index],value,callback,isWhere,stackA,stackB)){break}}}else if(!(result=baseIsEqual(a[size],value,callback,isWhere,stackA,stackB))){break}}}}else{forIn(b,function(value,key,b){if(hasOwnProperty.call(b,key)){size++;return result=hasOwnProperty.call(a,key)&&baseIsEqual(a[key],value,callback,isWhere,stackA,stackB)}});if(result&&!isWhere
 ){forIn(a,function(value,key,a){if(hasOwnProperty.call(a,key)){return result=--size>-1}})}}stackA.pop();stackB.pop();if(initedStack){releaseArray(stackA);releaseArray(stackB)}return result}function baseMerge(object,source,callback,stackA,stackB){(isArray(source)?forEach:forOwn)(source,function(source,key){var found,isArr,result=source,value=object[key];if(source&&((isArr=isArray(source))||isPlainObject(source))){var stackLength=stackA.length;while(stackLength--){if(found=stackA[stackLength]==source){value=stackB[stackLength];break}}if(!found){var isShallow;if(callback){result=callback(value,source);if(isShallow=typeof result!="undefined"){value=result}}if(!isShallow){value=isArr?isArray(value)?value:[]:isPlainObject(value)?value:{}}stackA.push(source);stackB.push(value);if(!isShallow){baseMerge(value,source,callback,stackA,stackB)}}}else{if(callback){result=callback(value,source);if(typeof result=="undefined"){result=source}}if(typeof result!="undefined"){value=result}}object[key]=v
 alue})}function baseRandom(min,max){return min+floor(nativeRandom()*(max-min+1))}function baseUniq(array,isSorted,callback){var index=-1,indexOf=getIndexOf(),length=array?array.length:0,result=[];var isLarge=!isSorted&&length>=largeArraySize&&indexOf===baseIndexOf,seen=callback||isLarge?getArray():result;if(isLarge){var cache=createCache(seen);indexOf=cacheIndexOf;seen=cache}while(++index<length){var value=array[index],computed=callback?callback(value,index,array):value;if(isSorted?!index||seen[seen.length-1]!==computed:indexOf(seen,computed)<0){if(callback||isLarge){seen.push(computed)}result.push(value)}}if(isLarge){releaseArray(seen.array);releaseObject(seen)}else if(callback){releaseArray(seen)}return result}function createAggregator(setter){return function(collection,callback,thisArg){var result={};callback=lodash.createCallback(callback,thisArg,3);var index=-1,length=collection?collection.length:0;if(typeof length=="number"){while(++index<length){var value=collection[index];se
 tter(result,value,callback(value,index,collection),collection)}}else{forOwn(collection,function(value,key,collection){setter(result,value,callback(value,key,collection),collection)})}return result}}function createWrapper(func,bitmask,partialArgs,partialRightArgs,thisArg,arity){var isBind=bitmask&1,isBindKey=bitmask&2,isCurry=bitmask&4,isCurryBound=bitmask&8,isPartial=bitmask&16,isPartialRight=bitmask&32;if(!isBindKey&&!isFunction(func)){throw new TypeError}if(isPartial&&!partialArgs.length){bitmask&=~16;isPartial=partialArgs=false}if(isPartialRight&&!partialRightArgs.length){bitmask&=~32;isPartialRight=partialRightArgs=false}var bindData=func&&func.__bindData__;if(bindData&&bindData!==true){bindData=slice(bindData);if(bindData[2]){bindData[2]=slice(bindData[2])}if(bindData[3]){bindData[3]=slice(bindData[3])}if(isBind&&!(bindData[1]&1)){bindData[4]=thisArg}if(!isBind&&bindData[1]&1){bitmask|=8}if(isCurry&&!(bindData[1]&4)){bindData[5]=arity}if(isPartial){push.apply(bindData[2]||(bind
 Data[2]=[]),partialArgs)}if(isPartialRight){unshift.apply(bindData[3]||(bindData[3]=[]),partialRightArgs)}bindData[1]|=bitmask;return createWrapper.apply(null,bindData)}var creater=bitmask==1||bitmask===17?baseBind:baseCreateWrapper;return creater([func,bitmask,partialArgs,partialRightArgs,thisArg,arity])}function escapeHtmlChar(match){return htmlEscapes[match]}function getIndexOf(){var result=(result=lodash.indexOf)===indexOf?baseIndexOf:result;return result}function isNative(value){return typeof value=="function"&&reNative.test(value)}var setBindData=!defineProperty?noop:function(func,value){descriptor.value=value;defineProperty(func,"__bindData__",descriptor)};function shimIsPlainObject(value){var ctor,result;if(!(value&&toString.call(value)==objectClass)||(ctor=value.constructor,isFunction(ctor)&&!(ctor instanceof ctor))){return false}forIn(value,function(value,key){result=key});return typeof result=="undefined"||hasOwnProperty.call(value,result)}function unescapeHtmlChar(match)
 {return htmlUnescapes[match]}function isArguments(value){return value&&typeof value=="object"&&typeof value.length=="number"&&toString.call(value)==argsClass||false}var isArray=nativeIsArray||function(value){return value&&typeof value=="object"&&typeof value.length=="number"&&toString.call(value)==arrayClass||false};var shimKeys=function(object){var index,iterable=object,result=[];if(!iterable)return result;if(!objectTypes[typeof object])return result;for(index in iterable){if(hasOwnProperty.call(iterable,index)){result.push(index)}}return result};var keys=!nativeKeys?shimKeys:function(object){if(!isObject(object)){return[]}return nativeKeys(object)};var htmlEscapes={"&":"&amp;","<":"&lt;",">":"&gt;",'"':"&quot;","'":"&#39;"};var htmlUnescapes=invert(htmlEscapes);var reEscapedHtml=RegExp("("+keys(htmlUnescapes).join("|")+")","g"),reUnescapedHtml=RegExp("["+keys(htmlEscapes).join("")+"]","g");var assign=function(object,source,guard){var index,iterable=object,result=iterable;if(!itera
 ble)return result;var args=arguments,argsIndex=0,argsLength=typeof guard=="number"?2:args.length;if(argsLength>3&&typeof args[argsLength-2]=="function"){var callback=baseCreateCallback(args[--argsLength-1],args[argsLength--],2)}else if(argsLength>2&&typeof args[argsLength-1]=="function"){callback=args[--argsLength]}while(++argsIndex<argsLength){iterable=args[argsIndex];if(iterable&&objectTypes[typeof iterable]){var ownIndex=-1,ownProps=objectTypes[typeof iterable]&&keys(iterable),length=ownProps?ownProps.length:0;while(++ownIndex<length){index=ownProps[ownIndex];result[index]=callback?callback(result[index],iterable[index]):iterable[index]}}}return result};function clone(value,isDeep,callback,thisArg){if(typeof isDeep!="boolean"&&isDeep!=null){thisArg=callback;callback=isDeep;isDeep=false}return baseClone(value,isDeep,typeof callback=="function"&&baseCreateCallback(callback,thisArg,1))}function cloneDeep(value,callback,thisArg){return baseClone(value,true,typeof callback=="function"
 &&baseCreateCallback(callback,thisArg,1))}function create(prototype,properties){var result=baseCreate(prototype);return properties?assign(result,properties):result}var defaults=function(object,source,guard){var index,iterable=object,result=iterable;if(!iterable)return result;var args=arguments,argsIndex=0,argsLength=typeof guard=="number"?2:args.length;while(++argsIndex<argsLength){iterable=args[argsIndex];if(iterable&&objectTypes[typeof iterable]){var ownIndex=-1,ownProps=objectTypes[typeof iterable]&&keys(iterable),length=ownProps?ownProps.length:0;while(++ownIndex<length){index=ownProps[ownIndex];if(typeof result[index]=="undefined")result[index]=iterable[index]}}}return result};function findKey(object,callback,thisArg){var result;callback=lodash.createCallback(callback,thisArg,3);forOwn(object,function(value,key,object){if(callback(value,key,object)){result=key;return false}});return result}function findLastKey(object,callback,thisArg){var result;callback=lodash.createCallback(c
 allback,thisArg,3);forOwnRight(object,function(value,key,object){if(callback(value,key,object)){result=key;return false}});return result}var forIn=function(collection,callback,thisArg){var index,iterable=collection,result=iterable;if(!iterable)return result;if(!objectTypes[typeof iterable])return result;callback=callback&&typeof thisArg=="undefined"?callback:baseCreateCallback(callback,thisArg,3);for(index in iterable){if(callback(iterable[index],index,collection)===false)return result}return result};function forInRight(object,callback,thisArg){var pairs=[];forIn(object,function(value,key){pairs.push(key,value)});var length=pairs.length;callback=baseCreateCallback(callback,thisArg,3);while(length--){if(callback(pairs[length--],pairs[length],object)===false){break}}return object}var forOwn=function(collection,callback,thisArg){var index,iterable=collection,result=iterable;if(!iterable)return result;if(!objectTypes[typeof iterable])return result;callback=callback&&typeof thisArg=="und
 efined"?callback:baseCreateCallback(callback,thisArg,3);var ownIndex=-1,ownProps=objectTypes[typeof iterable]&&keys(iterable),length=ownProps?ownProps.length:0;while(++ownIndex<length){index=ownProps[ownIndex];if(callback(iterable[index],index,collection)===false)return result}return result};function forOwnRight(object,callback,thisArg){var props=keys(object),length=props.length;callback=baseCreateCallback(callback,thisArg,3);while(length--){var key=props[length];if(callback(object[key],key,object)===false){break}}return object}function functions(object){var result=[];forIn(object,function(value,key){if(isFunction(value)){result.push(key)}});return result.sort()}function has(object,key){return object?hasOwnProperty.call(object,key):false}function invert(object){var index=-1,props=keys(object),length=props.length,result={};while(++index<length){var key=props[index];result[object[key]]=key}return result}function isBoolean(value){return value===true||value===false||value&&typeof value=
 ="object"&&toString.call(value)==boolClass||false}function isDate(value){return value&&typeof value=="object"&&toString.call(value)==dateClass||false}function isElement(value){return value&&value.nodeType===1||false}function isEmpty(value){var result=true;if(!value){return result}var className=toString.call(value),length=value.length;if(className==arrayClass||className==stringClass||className==argsClass||className==objectClass&&typeof length=="number"&&isFunction(value.splice)){return!length}forOwn(value,function(){return result=false});return result}function isEqual(a,b,callback,thisArg){return baseIsEqual(a,b,typeof callback=="function"&&baseCreateCallback(callback,thisArg,2))}function isFinite(value){return nativeIsFinite(value)&&!nativeIsNaN(parseFloat(value))}function isFunction(value){return typeof value=="function"}function isObject(value){return!!(value&&objectTypes[typeof value])}function isNaN(value){return isNumber(value)&&value!=+value}function isNull(value){return value
 ===null}function isNumber(value){return typeof value=="number"||value&&typeof value=="object"&&toString.call(value)==numberClass||false}var isPlainObject=!getPrototypeOf?shimIsPlainObject:function(value){if(!(value&&toString.call(value)==objectClass)){return false}var valueOf=value.valueOf,objProto=isNative(valueOf)&&(objProto=getPrototypeOf(valueOf))&&getPrototypeOf(objProto);return objProto?value==objProto||getPrototypeOf(value)==objProto:shimIsPlainObject(value)};function isRegExp(value){return value&&typeof value=="object"&&toString.call(value)==regexpClass||false}function isString(value){return typeof value=="string"||value&&typeof value=="object"&&toString.call(value)==stringClass||false}function isUndefined(value){return typeof value=="undefined"}function mapValues(object,callback,thisArg){var result={};callback=lodash.createCallback(callback,thisArg,3);forOwn(object,function(value,key,object){result[key]=callback(value,key,object)});return result}function merge(object){var a
 rgs=arguments,length=2;if(!isObject(object)){return object}if(typeof args[2]!="number"){length=args.length}if(length>3&&typeof args[length-2]=="function"){var callback=baseCreateCallback(args[--length-1],args[length--],2)}else if(length>2&&typeof args[length-1]=="function"){callback=args[--length]}var sources=slice(arguments,1,length),index=-1,stackA=getArray(),stackB=getArray();while(++index<length){baseMerge(object,sources[index],callback,stackA,stackB)}releaseArray(stackA);releaseArray(stackB);return object}function omit(object,callback,thisArg){var result={};if(typeof callback!="function"){var props=[];forIn(object,function(value,key){props.push(key)});props=baseDifference(props,baseFlatten(arguments,true,false,1));var index=-1,length=props.length;while(++index<length){var key=props[index];result[key]=object[key]}}else{callback=lodash.createCallback(callback,thisArg,3);forIn(object,function(value,key,object){if(!callback(value,key,object)){result[key]=value}})}return result}func
 tion pairs(object){var index=-1,props=keys(object),length=props.length,result=Array(length);while(++index<length){var key=props[index];result[index]=[key,object[key]]}return result}function pick(object,callback,thisArg){var result={};if(typeof callback!="func

<TRUNCATED>

[22/23] ambari git commit: AMBARI-19302 : removed contrib/views/hive folder and made necessary changes in pom.xml files (nitirajrathore)

Posted by ni...@apache.org.
http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/client/Connection.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/client/Connection.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/client/Connection.java
deleted file mode 100644
index d69a1a5..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/client/Connection.java
+++ /dev/null
@@ -1,740 +0,0 @@
-/**
- * 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.ambari.view.hive.client;
-
-import org.apache.commons.codec.binary.Hex;
-import org.apache.hadoop.conf.Configuration;
-import org.apache.hadoop.hive.shims.ShimLoader;
-import org.apache.hadoop.security.UserGroupInformation;
-import org.apache.hive.service.auth.HiveAuthFactory;
-import org.apache.hive.service.auth.KerberosSaslHelper;
-import org.apache.hive.service.auth.PlainSaslHelper;
-import org.apache.hive.service.auth.SaslQOP;
-import org.apache.hive.service.cli.thrift.*;
-import org.apache.http.HttpRequestInterceptor;
-import org.apache.http.HttpResponse;
-import org.apache.http.client.CookieStore;
-import org.apache.http.client.ServiceUnavailableRetryStrategy;
-import org.apache.http.config.Registry;
-import org.apache.http.config.RegistryBuilder;
-import org.apache.http.conn.socket.ConnectionSocketFactory;
-import org.apache.http.conn.ssl.SSLSocketFactory;
-import org.apache.http.impl.client.BasicCookieStore;
-import org.apache.http.impl.client.CloseableHttpClient;
-import org.apache.http.impl.client.HttpClientBuilder;
-import org.apache.http.impl.client.HttpClients;
-import org.apache.http.impl.conn.BasicHttpClientConnectionManager;
-import org.apache.http.protocol.HttpContext;
-import org.apache.thrift.TException;
-import org.apache.thrift.protocol.TBinaryProtocol;
-import org.apache.thrift.transport.THttpClient;
-import org.apache.thrift.transport.TTransport;
-import org.apache.thrift.transport.TTransportException;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-import javax.net.ssl.KeyManagerFactory;
-import javax.net.ssl.SSLContext;
-import javax.net.ssl.TrustManagerFactory;
-import javax.security.sasl.Sasl;
-import javax.security.sasl.SaslException;
-import java.io.FileInputStream;
-import java.io.IOException;
-import java.security.KeyStore;
-import java.security.SecureRandom;
-import java.sql.SQLException;
-import java.util.HashMap;
-import java.util.Iterator;
-import java.util.List;
-import java.util.Map;
-
-/**
- * Holds sessions
- */
-public class Connection {
-  private final static Logger LOG =
-      LoggerFactory.getLogger(Connection.class);
-  private String host;
-  private int port;
-  private Map<String, String> authParams;
-
-  private TCLIService.Client client = null;
-  private Map<String, TSessionHandle> sessHandles = null;
-  private TProtocolVersion protocol = null;
-  private TTransport transport;
-
-  private DDLDelegator ddl;
-  private String username;
-  private String password;
-
-  public Connection(String host, int port, Map<String, String> authParams, String username, String password)
-      throws HiveClientException, HiveAuthRequiredException {
-    this.host = host;
-    this.port = port;
-    this.authParams = authParams;
-    this.username = username;
-    this.password = password;
-
-    this.sessHandles = new HashMap<String, TSessionHandle>();
-
-    openConnection();
-    ddl = new DDLDelegator(this);
-  }
-
-  public DDLDelegator ddl() {
-    return ddl;
-  }
-
-  public synchronized void openConnection() throws HiveClientException, HiveAuthRequiredException {
-    try {
-      transport = isHttpTransportMode() ? createHttpTransport() : createBinaryTransport();
-      transport.open();
-      client = new TCLIService.Client(new TBinaryProtocol(transport));
-    } catch (TTransportException e) {
-      throw new HiveClientException("H020 Could not establish connection to "
-          + host + ":" + port + ": " + e.toString(), e);
-    } catch (SQLException e) {
-      throw new HiveClientException(e.getMessage(), e);
-    }
-    LOG.info("Hive connection opened");
-  }
-
-  /**
-   * Based on JDBC implementation of HiveConnection.createBinaryTransport
-   *
-   * @return transport
-   * @throws HiveClientException
-   */
-  protected TTransport createBinaryTransport() throws HiveClientException, TTransportException, HiveAuthRequiredException {
-    TTransport transport;
-    boolean assumeSubject =
-        Utils.HiveAuthenticationParams.AUTH_KERBEROS_AUTH_TYPE_FROM_SUBJECT.equals(authParams
-            .get(Utils.HiveAuthenticationParams.AUTH_KERBEROS_AUTH_TYPE));
-    try {
-      if (!Utils.HiveAuthenticationParams.AUTH_SIMPLE.equalsIgnoreCase(authParams.get(Utils.HiveAuthenticationParams.AUTH_TYPE))) {
-        // If Kerberos
-        Map<String, String> saslProps = new HashMap<String, String>();
-        SaslQOP saslQOP = SaslQOP.AUTH;
-        if (authParams.containsKey(Utils.HiveAuthenticationParams.AUTH_PRINCIPAL)) {
-          if (authParams.containsKey(Utils.HiveAuthenticationParams.AUTH_QOP)) {
-            try {
-              saslQOP = SaslQOP.fromString(authParams.get(Utils.HiveAuthenticationParams.AUTH_QOP));
-            } catch (IllegalArgumentException e) {
-              throw new HiveClientException("H040 Invalid " + Utils.HiveAuthenticationParams.AUTH_QOP +
-                  " parameter. " + e.getMessage(), e);
-            }
-          }
-          saslProps.put(Sasl.QOP, saslQOP.toString());
-          saslProps.put(Sasl.SERVER_AUTH, "true");
-
-          Configuration conf = new Configuration();
-          conf.set("hadoop.security.authentication", "kerberos");
-          UserGroupInformation.setConfiguration(conf);
-
-          transport = KerberosSaslHelper.getKerberosTransport(
-              authParams.get(Utils.HiveAuthenticationParams.AUTH_PRINCIPAL), host,
-              HiveAuthFactory.getSocketTransport(host, port, 10000), saslProps,
-              assumeSubject);
-        } else {
-          // If there's a delegation token available then use token based connection
-          String tokenStr = getClientDelegationToken(authParams);
-          if (tokenStr != null) {
-            transport = KerberosSaslHelper.getTokenTransport(tokenStr,
-                host, HiveAuthFactory.getSocketTransport(host, port, 10000), saslProps);
-          } else {
-            // we are using PLAIN Sasl connection with user/password
-            String userName = getAuthParamDefault(Utils.HiveAuthenticationParams.AUTH_USER, getUsername());
-            String passwd = getPassword();
-            // Note: Thrift returns an SSL socket that is already bound to the specified host:port
-            // Therefore an open called on this would be a no-op later
-            // Hence, any TTransportException related to connecting with the peer are thrown here.
-            // Bubbling them up the call hierarchy so that a retry can happen in openTransport,
-            // if dynamic service discovery is configured.
-            if (isSslConnection()) {
-              // get SSL socket
-              String sslTrustStore = authParams.get(Utils.HiveAuthenticationParams.SSL_TRUST_STORE);
-              String sslTrustStorePassword = authParams.get(Utils.HiveAuthenticationParams.SSL_TRUST_STORE_PASSWORD);
-              if (sslTrustStore == null || sslTrustStore.isEmpty()) {
-                transport = HiveAuthFactory.getSSLSocket(host, port, 10000);
-              } else {
-                transport = HiveAuthFactory.getSSLSocket(host, port, 10000,
-                    sslTrustStore, sslTrustStorePassword);
-              }
-            } else {
-              // get non-SSL socket transport
-              transport = HiveAuthFactory.getSocketTransport(host, port, 10000);
-            }
-            // Overlay the SASL transport on top of the base socket transport (SSL or non-SSL)
-            transport = PlainSaslHelper.getPlainTransport(userName, passwd, transport);
-          }
-        }
-      } else {
-        //NOSASL
-        return HiveAuthFactory.getSocketTransport(host, port, 10000);
-      }
-    } catch (SaslException e) {
-      throw new HiveClientException("H040 Could not create secure connection to "
-          + host + ": " + e.getMessage(), e);
-    }
-    return transport;
-  }
-
-  private String getServerHttpUrl(boolean useSsl) {
-    // Create the http/https url
-    // JDBC driver will set up an https url if ssl is enabled, otherwise http
-    String schemeName = useSsl ? "https" : "http";
-    // http path should begin with "/"
-    String httpPath;
-    httpPath = authParams.get(Utils.HiveAuthenticationParams.HTTP_PATH);
-    if (httpPath == null) {
-      httpPath = "/";
-    } else if (!httpPath.startsWith("/")) {
-      httpPath = "/" + httpPath;
-    }
-    return schemeName + "://" + host + ":" + port + httpPath;
-  }
-
-  private TTransport createHttpTransport() throws SQLException, TTransportException {
-    CloseableHttpClient httpClient;
-    boolean useSsl = isSslConnection();
-    // Create an http client from the configs
-    httpClient = getHttpClient(useSsl);
-    try {
-      transport = new THttpClient(getServerHttpUrl(useSsl), httpClient);
-      // We'll call an open/close here to send a test HTTP message to the server. Any
-      // TTransportException caused by trying to connect to a non-available peer are thrown here.
-      // Bubbling them up the call hierarchy so that a retry can happen in openTransport,
-      // if dynamic service discovery is configured.
-      TCLIService.Iface client = new TCLIService.Client(new TBinaryProtocol(transport));
-      TOpenSessionResp openResp = client.OpenSession(new TOpenSessionReq());
-      if (openResp != null) {
-        client.CloseSession(new TCloseSessionReq(openResp.getSessionHandle()));
-      }
-    } catch (TException e) {
-      LOG.info("JDBC Connection Parameters used : useSSL = " + useSsl + " , httpPath  = " +
-          authParams.get(Utils.HiveAuthenticationParams.HTTP_PATH) + " Authentication type = " +
-          authParams.get(Utils.HiveAuthenticationParams.AUTH_TYPE));
-      String msg = "Could not create http connection to " +
-          getServerHttpUrl(useSsl) + ". " + e.getMessage();
-      throw new TTransportException(msg, e);
-    }
-    return transport;
-  }
-
-  private CloseableHttpClient getHttpClient(Boolean useSsl) throws SQLException {
-    boolean isCookieEnabled = authParams.get(Utils.HiveAuthenticationParams.COOKIE_AUTH) == null ||
-        (!Utils.HiveAuthenticationParams.COOKIE_AUTH_FALSE.equalsIgnoreCase(
-            authParams.get(Utils.HiveAuthenticationParams.COOKIE_AUTH)));
-    String cookieName = authParams.get(Utils.HiveAuthenticationParams.COOKIE_NAME) == null ?
-        Utils.HiveAuthenticationParams.DEFAULT_COOKIE_NAMES_HS2 :
-        authParams.get(Utils.HiveAuthenticationParams.COOKIE_NAME);
-    CookieStore cookieStore = isCookieEnabled ? new BasicCookieStore() : null;
-    HttpClientBuilder httpClientBuilder;
-    // Request interceptor for any request pre-processing logic
-    HttpRequestInterceptor requestInterceptor;
-    Map<String, String> additionalHttpHeaders = new HashMap<String, String>();
-
-    // Retrieve the additional HttpHeaders
-    for (Map.Entry<String, String> entry : authParams.entrySet()) {
-      String key = entry.getKey();
-
-      if (key.startsWith(Utils.HiveAuthenticationParams.HTTP_HEADER_PREFIX)) {
-        additionalHttpHeaders.put(key.substring(Utils.HiveAuthenticationParams.HTTP_HEADER_PREFIX.length()),
-            entry.getValue());
-      }
-    }
-    // Configure http client for kerberos/password based authentication
-    if (isKerberosAuthMode()) {
-      /**
-       * Add an interceptor which sets the appropriate header in the request.
-       * It does the kerberos authentication and get the final service ticket,
-       * for sending to the server before every request.
-       * In https mode, the entire information is encrypted
-       */
-
-      Boolean assumeSubject =
-          Utils.HiveAuthenticationParams.AUTH_KERBEROS_AUTH_TYPE_FROM_SUBJECT.equals(authParams
-              .get(Utils.HiveAuthenticationParams.AUTH_KERBEROS_AUTH_TYPE));
-      requestInterceptor =
-          new HttpKerberosRequestInterceptor(authParams.get(Utils.HiveAuthenticationParams.AUTH_PRINCIPAL),
-              host, getServerHttpUrl(useSsl), assumeSubject, cookieStore, cookieName, useSsl,
-              additionalHttpHeaders);
-    } else {
-      /**
-       * Add an interceptor to pass username/password in the header.
-       * In https mode, the entire information is encrypted
-       */
-      requestInterceptor = new HttpBasicAuthInterceptor(
-          getAuthParamDefault(Utils.HiveAuthenticationParams.AUTH_USER, getUsername())
-          , getPassword(),cookieStore, cookieName, useSsl,
-          additionalHttpHeaders);
-    }
-    // Configure http client for cookie based authentication
-    if (isCookieEnabled) {
-      // Create a http client with a retry mechanism when the server returns a status code of 401.
-      httpClientBuilder =
-          HttpClients.custom().setServiceUnavailableRetryStrategy(
-              new ServiceUnavailableRetryStrategy() {
-
-                @Override
-                public boolean retryRequest(
-                    final HttpResponse response,
-                    final int executionCount,
-                    final HttpContext context) {
-                  int statusCode = response.getStatusLine().getStatusCode();
-                  boolean ret = statusCode == 401 && executionCount <= 1;
-
-                  // Set the context attribute to true which will be interpreted by the request interceptor
-                  if (ret) {
-                    context.setAttribute(Utils.HIVE_SERVER2_RETRY_KEY, Utils.HIVE_SERVER2_RETRY_TRUE);
-                  }
-                  return ret;
-                }
-
-                @Override
-                public long getRetryInterval() {
-                  // Immediate retry
-                  return 0;
-                }
-              });
-    } else {
-      httpClientBuilder = HttpClientBuilder.create();
-    }
-    // Add the request interceptor to the client builder
-    httpClientBuilder.addInterceptorFirst(requestInterceptor);
-    // Configure http client for SSL
-    if (useSsl) {
-      String useTwoWaySSL = authParams.get(Utils.HiveAuthenticationParams.USE_TWO_WAY_SSL);
-      String sslTrustStorePath = authParams.get(Utils.HiveAuthenticationParams.SSL_TRUST_STORE);
-      String sslTrustStorePassword = authParams.get(
-          Utils.HiveAuthenticationParams.SSL_TRUST_STORE_PASSWORD);
-      KeyStore sslTrustStore;
-      SSLSocketFactory socketFactory;
-
-      /**
-       * The code within the try block throws:
-       * 1. SSLInitializationException
-       * 2. KeyStoreException
-       * 3. IOException
-       * 4. NoSuchAlgorithmException
-       * 5. CertificateException
-       * 6. KeyManagementException
-       * 7. UnrecoverableKeyException
-       * We don't want the client to retry on any of these, hence we catch all
-       * and throw a SQLException.
-       */
-      try {
-        if (useTwoWaySSL != null &&
-            useTwoWaySSL.equalsIgnoreCase(Utils.HiveAuthenticationParams.TRUE)) {
-          socketFactory = getTwoWaySSLSocketFactory();
-        } else if (sslTrustStorePath == null || sslTrustStorePath.isEmpty()) {
-          // Create a default socket factory based on standard JSSE trust material
-          socketFactory = SSLSocketFactory.getSocketFactory();
-        } else {
-          // Pick trust store config from the given path
-          sslTrustStore = KeyStore.getInstance(Utils.HiveAuthenticationParams.SSL_TRUST_STORE_TYPE);
-          try (FileInputStream fis = new FileInputStream(sslTrustStorePath)) {
-            sslTrustStore.load(fis, sslTrustStorePassword.toCharArray());
-          }
-          socketFactory = new SSLSocketFactory(sslTrustStore);
-        }
-        socketFactory.setHostnameVerifier(SSLSocketFactory.ALLOW_ALL_HOSTNAME_VERIFIER);
-
-        final Registry<ConnectionSocketFactory> registry =
-            RegistryBuilder.<ConnectionSocketFactory>create()
-                .register("https", socketFactory)
-                .build();
-
-        httpClientBuilder.setConnectionManager(new BasicHttpClientConnectionManager(registry));
-      } catch (Exception e) {
-        String msg = "Could not create an https connection to " +
-            getServerHttpUrl(useSsl) + ". " + e.getMessage();
-        throw new SQLException(msg, " 08S01", e);
-      }
-    }
-    return httpClientBuilder.build();
-  }
-
-  private boolean isKerberosAuthMode() {
-    return !Utils.HiveAuthenticationParams.AUTH_SIMPLE.equals(authParams.get(Utils.HiveAuthenticationParams.AUTH_TYPE))
-        && authParams.containsKey(Utils.HiveAuthenticationParams.AUTH_PRINCIPAL);
-  }
-
-  private boolean isHttpTransportMode() {
-    String transportMode = authParams.get(Utils.HiveAuthenticationParams.TRANSPORT_MODE);
-    if (transportMode != null && (transportMode.equalsIgnoreCase("http"))) {
-      return true;
-    }
-    return false;
-  }
-
-  private String getPassword() throws HiveAuthRequiredException {
-    String password = getAuthParamDefault(Utils.HiveAuthenticationParams.AUTH_PASSWD, Utils.HiveAuthenticationParams.ANONYMOUS_USER);
-    if (password.equals("${ask_password}")) {
-      if (this.password == null) {
-        throw new HiveAuthRequiredException();
-      } else {
-        password = this.password;
-      }
-    }
-    return password;
-  }
-
-  SSLSocketFactory getTwoWaySSLSocketFactory() throws SQLException {
-    SSLSocketFactory socketFactory = null;
-
-    try {
-      KeyManagerFactory keyManagerFactory = KeyManagerFactory.getInstance(
-          Utils.HiveAuthenticationParams.SUNX509_ALGORITHM_STRING,
-          Utils.HiveAuthenticationParams.SUNJSSE_ALGORITHM_STRING);
-      String keyStorePath = authParams.get(Utils.HiveAuthenticationParams.SSL_KEY_STORE);
-      String keyStorePassword = authParams.get(Utils.HiveAuthenticationParams.SSL_KEY_STORE_PASSWORD);
-      KeyStore sslKeyStore = KeyStore.getInstance(Utils.HiveAuthenticationParams.SSL_KEY_STORE_TYPE);
-
-      if (keyStorePath == null || keyStorePath.isEmpty()) {
-        throw new IllegalArgumentException(Utils.HiveAuthenticationParams.SSL_KEY_STORE
-            + " Not configured for 2 way SSL connection, keyStorePath param is empty");
-      }
-      try (FileInputStream fis = new FileInputStream(keyStorePath)) {
-        sslKeyStore.load(fis, keyStorePassword.toCharArray());
-      }
-      keyManagerFactory.init(sslKeyStore, keyStorePassword.toCharArray());
-
-      TrustManagerFactory trustManagerFactory = TrustManagerFactory.getInstance(
-          Utils.HiveAuthenticationParams.SUNX509_ALGORITHM_STRING);
-      String trustStorePath = authParams.get(Utils.HiveAuthenticationParams.SSL_TRUST_STORE);
-      String trustStorePassword = authParams.get(
-          Utils.HiveAuthenticationParams.SSL_TRUST_STORE_PASSWORD);
-      KeyStore sslTrustStore = KeyStore.getInstance(Utils.HiveAuthenticationParams.SSL_TRUST_STORE_TYPE);
-
-      if (trustStorePath == null || trustStorePath.isEmpty()) {
-        throw new IllegalArgumentException(Utils.HiveAuthenticationParams.SSL_TRUST_STORE
-            + " Not configured for 2 way SSL connection");
-      }
-      try (FileInputStream fis = new FileInputStream(trustStorePath)) {
-        sslTrustStore.load(fis, trustStorePassword.toCharArray());
-      }
-      trustManagerFactory.init(sslTrustStore);
-      SSLContext context = SSLContext.getInstance("TLS");
-      context.init(keyManagerFactory.getKeyManagers(),
-          trustManagerFactory.getTrustManagers(), new SecureRandom());
-      socketFactory = new SSLSocketFactory(context);
-    } catch (Exception e) {
-      throw new SQLException("Error while initializing 2 way ssl socket factory ", e);
-    }
-    return socketFactory;
-  }
-
-  private boolean isSslConnection() {
-    return "true".equalsIgnoreCase(authParams.get(Utils.HiveAuthenticationParams.USE_SSL));
-  }
-
-  // Lookup the delegation token. First in the connection URL, then Configuration
-  private String getClientDelegationToken(Map<String, String> jdbcConnConf) throws HiveClientException {
-    String tokenStr = null;
-    if (Utils.HiveAuthenticationParams.AUTH_TOKEN.equalsIgnoreCase(jdbcConnConf.get(Utils.HiveAuthenticationParams.AUTH_TYPE))) {
-      // check delegation token in job conf if any
-      try {
-        tokenStr = ShimLoader.getHadoopShims().
-            getTokenStrForm(HiveAuthFactory.HS2_CLIENT_TOKEN);
-      } catch (IOException e) {
-        throw new HiveClientException("H050 Error reading token", e);
-      }
-    }
-    return tokenStr;
-  }
-
-  private String getAuthParamDefault(String key, String defaultValue) {
-    if (authParams.containsKey(key)) {
-      return authParams.get(key);
-    }
-    return defaultValue;
-  }
-
-  public synchronized TSessionHandle openSession() throws HiveClientException {
-    return openSession(null);
-  }
-
-  public synchronized TSessionHandle openSession(String forcedTag) throws HiveClientException {
-    TOpenSessionResp openResp = new HiveCall<TOpenSessionResp>(this) {
-      @Override
-      public TOpenSessionResp body() throws HiveClientException {
-        TOpenSessionReq openReq = new TOpenSessionReq();
-        Map<String, String> openConf = new HashMap<String, String>();
-        if(authParams.containsKey(Utils.HiveAuthenticationParams.HS2_PROXY_USER)){
-          openConf.put(Utils.HiveAuthenticationParams.HS2_PROXY_USER,
-                       authParams.get(Utils.HiveAuthenticationParams.HS2_PROXY_USER));
-        }
-        openReq.setConfiguration(openConf);
-        try {
-          return client.OpenSession(openReq);
-        } catch (TException e) {
-          throw new HiveClientException("H060 Unable to open Hive session", e);
-        }
-
-      }
-    }.call();
-    Utils.verifySuccess(openResp.getStatus(), "H070 Unable to open Hive session");
-
-    if (protocol == null)
-      protocol = openResp.getServerProtocolVersion();
-    LOG.info("Hive session opened");
-
-    TSessionHandle sessionHandle = openResp.getSessionHandle();
-    String tag;
-    if (forcedTag == null)
-      tag = Hex.encodeHexString(sessionHandle.getSessionId().getGuid());
-    else
-      tag = forcedTag;
-
-    sessHandles.put(tag, sessionHandle);
-
-    return sessionHandle;
-  }
-
-  public TSessionHandle getSessionByTag(String tag) throws HiveClientException {
-    TSessionHandle sessionHandle = sessHandles.get(tag);
-    if (sessionHandle == null) {
-      throw new HiveClientException("E030 Session with provided tag not found", null);
-    }
-    return sessionHandle;
-  }
-
-  public TSessionHandle getOrCreateSessionByTag(String tag) throws HiveClientException {
-    try {
-      return getSessionByTag(tag);
-    } catch (HiveClientException e) {
-      return openSession(tag);
-    }
-  }
-
-  public void invalidateSessionByTag(String tag) throws HiveClientException {
-    TSessionHandle sessionHandle = getSessionByTag(tag);
-    closeSession(sessionHandle);
-    sessHandles.remove(tag);
-  }
-
-  public void invalidateSessionBySessionHandle(TSessionHandle sessionHandle) throws HiveClientException{
-    sessHandles.values().remove(sessionHandle);
-    closeSession(sessionHandle);
-  }
-
-  private synchronized void closeSession(TSessionHandle sessHandle) throws HiveClientException {
-    if (sessHandle == null) return;
-    TCloseSessionReq closeReq = new TCloseSessionReq(sessHandle);
-    TCloseSessionResp closeResp = null;
-    try {
-      closeResp = client.CloseSession(closeReq);
-      Utils.verifySuccess(closeResp.getStatus(), "H080 Unable to close Hive session");
-    } catch (TException e) {
-      throw new HiveClientException("H090 Unable to close Hive session", e);
-    }
-    LOG.info("Hive session closed");
-  }
-
-  public synchronized void closeConnection() throws HiveClientException {
-    if (client == null) return;
-    try {
-
-      for(Iterator<Map.Entry<String, TSessionHandle>> it = sessHandles.entrySet().iterator(); it.hasNext(); ) {
-        Map.Entry<String, TSessionHandle> entry = it.next();
-        try {
-          closeSession(entry.getValue());
-        } catch (HiveClientException e) {
-          LOG.error("Unable to close Hive session: " + e.getMessage());
-        } finally {
-          it.remove();
-        }
-      }
-
-    } finally {
-      transport.close();
-      transport = null;
-      client = null;
-      protocol = null;
-    }
-    LOG.info("Connection to Hive closed");
-  }
-
-  /**
-   * Execute query
-   * @param cmd query
-   * @param async wait till query finish?
-   * @return handle of operation
-   * @throws HiveClientException
-   */
-  public TOperationHandle execute(final TSessionHandle session, final String cmd, final boolean async) throws HiveClientException {
-    TOperationHandle handle = null;
-
-    String[] commands = Utils.removeEmptyStrings(cmd.split(";"));
-    for(int i=0; i<commands.length; i++) {
-      final String oneCmd = commands[i];
-      final boolean lastCommand = i == commands.length-1;
-
-      TExecuteStatementResp execResp = new HiveCall<TExecuteStatementResp>(this,session) {
-        @Override
-        public TExecuteStatementResp body() throws HiveClientException {
-
-          TExecuteStatementReq execReq = null;
-          execReq = new TExecuteStatementReq(session, oneCmd);
-
-          // only last command should be asynchronous and return some results
-          // all previous commands are supposed to be set properties entries
-          if (lastCommand) {
-            execReq.setRunAsync(async);
-          } else {
-            execReq.setRunAsync(false);
-          }
-          execReq.setConfOverlay(new HashMap<String, String>());
-          try {
-            return client.ExecuteStatement(execReq);
-          } catch (TException e) {
-            throw new HiveClientException("H100 Unable to submit statement " + cmd, e);
-          }
-
-        }
-      }.call();
-
-      Utils.verifySuccess(execResp.getStatus(), "H110 Unable to submit statement");
-      //TODO: check if status have results
-      handle = execResp.getOperationHandle();
-    }
-    if (handle == null) {
-      throw new HiveClientException("H120 Empty command given", null);
-    }
-    return handle;
-  }
-
-  public TOperationHandle executeAsync(TSessionHandle session, String cmd) throws HiveClientException {
-    return execute(session, cmd, true);
-  }
-
-  public TOperationHandle executeSync(TSessionHandle session, String cmd) throws HiveClientException {
-    return execute(session, cmd, false);
-  }
-
-  public String getLogs(TOperationHandle handle) {
-    LogsCursor results = new LogsCursor(this, handle);
-    results.reset(); // we have to read from FIRST line, to get
-    // logs from beginning on every call this function
-    List<String> logLineList = results.getValuesInColumn(0);
-    StringBuilder log = new StringBuilder();
-    for (String line : logLineList) {
-      log.append(line);
-      log.append('\n');
-    }
-    return log.toString();
-  }
-
-  public Cursor getResults(TOperationHandle handle) {
-    Cursor cursor = new Cursor(this, handle);
-    cursor.reset(); // we have to read from FIRST line, to get
-    // logs from beginning on every call this function
-    return cursor;
-  }
-
-  /**
-   * Retrieve status of operation
-   * @param operationHandle handle
-   * @return thrift status response object
-   * @throws HiveClientException
-   */
-  public TGetOperationStatusResp getOperationStatus(final TOperationHandle operationHandle) throws HiveClientException {
-    return new HiveCall<TGetOperationStatusResp>(this) {
-      @Override
-      public TGetOperationStatusResp body() throws HiveClientException {
-
-        TGetOperationStatusReq statusReq = new TGetOperationStatusReq(operationHandle);
-        try {
-          return client.GetOperationStatus(statusReq);
-        } catch (TException e) {
-          throw new HiveClientException("H130 Unable to fetch operation status", e);
-        }
-
-      }
-    }.call();
-  }
-
-  /**
-   * Cancel operation
-   * @param operationHandle operation handle
-   */
-  public void cancelOperation(final TOperationHandle operationHandle) throws HiveClientException {
-    TCancelOperationResp cancelResp = new HiveCall<TCancelOperationResp>(this) {
-      @Override
-      public TCancelOperationResp body() throws HiveClientException {
-        TCancelOperationReq cancelReq = new TCancelOperationReq(operationHandle);
-        try {
-          return client.CancelOperation(cancelReq);
-        } catch (TException e) {
-          throw new HiveClientException("H140 Unable to cancel operation", null);
-        }
-      }
-    }.call();
-    Utils.verifySuccess(cancelResp.getStatus(), "H150 Unable to cancel operation");
-  }
-
-  public int getPort() {
-    return port;
-  }
-
-  public void setPort(int port) {
-    this.port = port;
-  }
-
-  public String getHost() {
-    return host;
-  }
-
-  public void setHost(String host) {
-    this.host = host;
-  }
-
-  public TCLIService.Client getClient() {
-    return client;
-  }
-
-  public void setClient(TCLIService.Client client) {
-    this.client = client;
-  }
-
-  public TProtocolVersion getProtocol() {
-    return protocol;
-  }
-
-  public void setProtocol(TProtocolVersion protocol) {
-    this.protocol = protocol;
-  }
-
-  public Map<String, String> getAuthParams() {
-    return authParams;
-  }
-
-  public void setAuthParams(Map<String, String> authParams) {
-    this.authParams = authParams;
-  }
-
-  public String getUsername() {
-    return username;
-  }
-
-  public void setUsername(String username) {
-    this.username = username;
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/client/ConnectionFactory.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/client/ConnectionFactory.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/client/ConnectionFactory.java
deleted file mode 100644
index d3cbb08..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/client/ConnectionFactory.java
+++ /dev/null
@@ -1,166 +0,0 @@
-/**
- * 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.ambari.view.hive.client;
-
-import org.apache.ambari.view.ViewContext;
-import org.apache.ambari.view.hive.utils.HiveClientFormattedException;
-import org.apache.ambari.view.hive.utils.ServiceFormattedException;
-import org.apache.ambari.view.utils.UserLocalFactory;
-import org.apache.ambari.view.utils.ambari.AmbariApi;
-import org.apache.ambari.view.utils.ambari.AmbariApiException;
-import org.apache.ambari.view.utils.hdfs.HdfsApi;
-import org.apache.ambari.view.utils.hdfs.HdfsUtil;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-import java.util.HashMap;
-import java.util.List;
-import java.util.Map;
-
-public class ConnectionFactory implements UserLocalFactory<Connection> {
-  private final static Logger LOG =
-      LoggerFactory.getLogger(ConnectionFactory.class);
-  private ViewContext context;
-  private HiveAuthCredentials credentials;
-  private AmbariApi ambariApi;
-  private HdfsApi hdfsApi = null;
-
-  public static String HIVE_SERVER2_AUTHENTICATION = "hive.server2.authentication" ;
-  public static String HIVE_SITE = "hive-site" ;
-  public static String HIVE_SERVER2_KERBEROS_PRINCIPAL = "hive.server2.authentication.kerberos.principal" ;
-  public static String HIVE_SASL_QOP = "hive.server2.thrift.sasl.qop" ;
-
-  public ConnectionFactory(ViewContext context, HiveAuthCredentials credentials) {
-    this.context = context;
-    this.credentials = credentials;
-    this.ambariApi = new AmbariApi(context);
-  }
-
-  /**
-   * Get HdfsApi instance
-   * @return HdfsApi business delegate
-   */
-  public synchronized HdfsApi getHDFSApi() {
-    if (hdfsApi == null) {
-      try {
-        hdfsApi = HdfsUtil.connectToHDFSApi(context);
-      } catch (Exception ex) {
-        throw new ServiceFormattedException("HdfsApi connection failed. Check \"webhdfs.url\" property", ex);
-      }
-    }
-    return hdfsApi;
-  }
-
-  @Override
-  public Connection create() {
-    try {
-      return new Connection(getHiveHost(), Integer.valueOf(getHivePort()),
-          getHiveAuthParams(), context.getUsername(), getCredentials().getPassword());
-    } catch (HiveClientException e) {
-      throw new HiveClientFormattedException(e);
-    }
-  }
-
-  private String getHiveHost() {
-    if (context.getCluster() != null) {
-      List<String> hiveServerHosts;
-      try {
-        hiveServerHosts = context.getCluster().getHostsForServiceComponent("HIVE","HIVE_SERVER");
-      } catch (AmbariApiException e) {
-        throw new ServiceFormattedException(e);
-      }
-
-      if (!hiveServerHosts.isEmpty()) {
-        String hostname = hiveServerHosts.get(0);
-        LOG.info("HIVE_SERVER component was found on host " + hostname);
-        return hostname;
-      }
-      LOG.warn("No host was found with HIVE_SERVER component. Using hive.host property to get hostname.");
-    }
-    return context.getProperties().get("hive.host");
-  }
-
-  private String getHivePort() {
-    Boolean isHttpMode = context.getProperties().get("hive.transport.mode").equalsIgnoreCase("http");
-    String port;
-    if(isHttpMode){
-      port = context.getProperties().get("hive.http.port");
-    }else{
-      port = context.getProperties().get("hive.port");
-    }
-    return  port;
-  }
-
-  private Map<String, String> getHiveAuthParams() {
-    String auth = context.getProperties().get("hive.auth");
-    Map<String, String> params = new HashMap<String, String>();
-    if ((auth == null || auth.isEmpty()) && context.getCluster() != null) {
-      params.putAll(getDefaultAuthParams());
-    } else if(auth == null || auth.isEmpty()) {
-      params.put("auth","NONE");
-    } else {
-      for (String param : auth.split(";")) {
-        String[] keyvalue = param.split("=");
-        if (keyvalue.length != 2) {
-          //Should never happen because validator already checked this
-          throw new ServiceFormattedException("H010 Can not parse authentication param " + param + " in " + auth);
-        }
-        params.put(keyvalue[0], keyvalue[1]);
-      }
-    }
-    params.put(Utils.HiveAuthenticationParams.TRANSPORT_MODE,context.getProperties().get("hive.transport.mode"));
-    params.put(Utils.HiveAuthenticationParams.HTTP_PATH,context.getProperties().get("hive.http.path"));
-    return params;
-  }
-
-  private Map<String, String> getDefaultAuthParams() {
-    Map<String, String> params = new HashMap<String, String>();
-    String auth = getProperty(HIVE_SITE, HIVE_SERVER2_AUTHENTICATION);
-    params.put("auth", auth);
-
-    if (auth.equalsIgnoreCase("KERBEROS")) {
-      params.put("principal", getProperty(HIVE_SITE, HIVE_SERVER2_KERBEROS_PRINCIPAL));
-      params.put(Utils.HiveAuthenticationParams.HS2_PROXY_USER, context.getUsername());
-    } else if (auth.equalsIgnoreCase("LDAP") || auth.equalsIgnoreCase("CUSTOM")) {
-      params.put("auth", "NONE");
-      params.put("password", "${ask_password}");
-    }
-
-    String qop = getProperty(HIVE_SITE, HIVE_SASL_QOP);
-    if (qop != null && !qop.equals("auth")) {
-      params.put(Utils.HiveAuthenticationParams.AUTH_QOP, qop);
-    }
-    return params;
-  }
-
-  private String getProperty(String type,String key){
-    if(context.getCluster() != null){
-      return context.getCluster().getConfigurationValue(type,key);
-    }
-    return null;
-  }
-
-  public HiveAuthCredentials getCredentials() {
-    return credentials;
-  }
-
-  public void setCredentials(HiveAuthCredentials credentials) {
-    this.credentials = credentials;
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/client/Cursor.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/client/Cursor.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/client/Cursor.java
deleted file mode 100644
index 16fdf36..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/client/Cursor.java
+++ /dev/null
@@ -1,243 +0,0 @@
-/**
- * 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.ambari.view.hive.client;
-
-import static org.apache.hive.service.cli.thrift.TCLIServiceConstants.TYPE_NAMES;
-
-import org.apache.ambari.view.hive.utils.BadRequestFormattedException;
-import org.apache.ambari.view.hive.utils.HiveClientFormattedException;
-import org.apache.hive.service.cli.RowSet;
-import org.apache.hive.service.cli.RowSetFactory;
-import org.apache.hive.service.cli.thrift.*;
-import org.apache.thrift.TException;
-import sun.reflect.generics.reflectiveObjects.NotImplementedException;
-
-import java.util.*;
-
-public class Cursor implements Iterator<Row>, Iterable<Row> {
-  private final int FETCH_SIZE = 50;
-
-  private TCLIService.Client client;
-  private TOperationHandle opHandle;
-
-  private RowSet fetched = null;
-  private Iterator<Object[]> fetchedIterator = null;
-  private Connection connection;
-  private boolean resetCursor = false;
-  private ArrayList<ColumnDescription> schema;
-  private long offset;
-  private HashSet<Integer> selectedColumns = new LinkedHashSet<Integer>();
-
-  public Cursor(Connection connection, TOperationHandle opHandle) {
-    this.connection = connection;
-    this.client = connection.getClient();
-    this.opHandle = opHandle;
-  }
-
-  public TOperationHandle getOpHandle() {
-    return opHandle;
-  }
-
-  public void setOpHandle(TOperationHandle opHandle) {
-    this.opHandle = opHandle;
-  }
-
-  private void fetchNextBlock() throws HiveClientException {
-    //fetch another bunch
-    TFetchResultsResp fetchResp = new HiveCall<TFetchResultsResp>(connection) {
-      @Override
-      public TFetchResultsResp body() throws HiveClientException {
-        TFetchOrientation orientation = TFetchOrientation.FETCH_NEXT;
-        if (resetCursor) {
-          orientation = TFetchOrientation.FETCH_FIRST;
-          resetCursor = false;
-          offset = 0;
-        }
-
-        TFetchResultsReq fetchReq = getFetchResultsReq(orientation);
-        try {
-          return client.FetchResults(fetchReq);
-        } catch (TException e) {
-          throw new HiveClientException("H160 Unable to fetch results", e);
-        }
-
-      }
-    }.call();
-    Utils.verifySuccess(fetchResp.getStatus(), "H170 Unable to fetch results");
-    TRowSet results = fetchResp.getResults();
-    fetched = RowSetFactory.create(results, connection.getProtocol());
-    fetchedIterator = fetched.iterator();
-  }
-
-  protected TFetchResultsReq getFetchResultsReq(TFetchOrientation orientation) {
-    return new TFetchResultsReq(opHandle, orientation, FETCH_SIZE);
-  }
-
-  public ArrayList<ColumnDescription> getSchema() throws HiveClientException {
-    if (this.schema == null) {
-      TGetResultSetMetadataResp fetchResp = new HiveCall<TGetResultSetMetadataResp>(connection) {
-        @Override
-        public TGetResultSetMetadataResp body() throws HiveClientException {
-
-          TGetResultSetMetadataReq fetchReq = new TGetResultSetMetadataReq(opHandle);
-          try {
-            return client.GetResultSetMetadata(fetchReq);
-          } catch (TException e) {
-            throw new HiveClientException("H180 Unable to fetch results metadata", e);
-          }
-
-        }
-      }.call();
-      Utils.verifySuccess(fetchResp.getStatus(), "H190 Unable to fetch results metadata");
-      TTableSchema schema = fetchResp.getSchema();
-
-      List<TColumnDesc> thriftColumns = schema.getColumns();
-      ArrayList<ColumnDescription> columnDescriptions = new ArrayList<ColumnDescription>(thriftColumns.size());
-
-      for (TColumnDesc columnDesc : thriftColumns) {
-        String name = columnDesc.getColumnName();
-        String type = TYPE_NAMES.get(columnDesc.getTypeDesc().getTypes().get(0).getPrimitiveEntry().getType());
-        int position = columnDesc.getPosition();
-        columnDescriptions.add(ColumnDescriptionShort.createShortColumnDescription(name, type, position));
-      }
-      if (selectedColumns.size() == 0)
-        this.schema = columnDescriptions;
-      else {
-        ArrayList<ColumnDescription> selectedColumnsSchema = new ArrayList<ColumnDescription>();
-        for (Integer selectedIndex : selectedColumns) {
-          selectedColumnsSchema.add(columnDescriptions.get(selectedIndex));
-        }
-        this.schema = selectedColumnsSchema;
-      }
-    }
-    return this.schema;
-  }
-
-  /**
-   * Get list with all values in one column
-   * @param column column index
-   * @return list of objects in column
-   */
-  public <T> List<T> getValuesInColumn(int column) {
-    LinkedList<T> list = new LinkedList<T>();
-    for (Row row : this) {
-      list.add((T) row.getRow()[column]);
-    }
-    return list;
-  }
-
-  /**
-   * Get logs Result object
-   * @return Result object configured to fetch logs
-   */
-  public Cursor getLogs() {
-    return new LogsCursor(connection, opHandle);
-  }
-
-  public void reset() {
-    fetchedIterator = null;
-    fetched = null;
-    resetCursor = true;
-    offset = 0;
-  }
-
-  @Override
-  public boolean hasNext() {
-    fetchIfNeeded();
-    return fetchedIterator.hasNext();
-  }
-
-  private void fetchIfNeeded() {
-    if (fetchedIterator == null || !fetchedIterator.hasNext()) {
-      try {
-        fetchNextBlock();
-      } catch (HiveClientException e) {
-        throw new HiveClientFormattedException(e);
-      }
-    }
-  }
-
-  @Override
-  public Row next() {
-    if (!hasNext())
-      throw new NoSuchElementException();
-    Row row = new Row(fetchedIterator.next(), selectedColumns);
-    offset ++;
-    return row;
-  }
-
-  @Override
-  public void remove() {
-    throw new NotImplementedException();
-  }
-
-  @Override
-  public Iterator<Row> iterator() {
-    return this;
-  }
-
-//  public int size() {
-//    fetchIfNeeded();
-//    return fetched.numRows();
-//  }
-  public long getOffset() {
-    return offset;
-  }
-
-  public int read(ArrayList<Row> rows, int count) {
-    int read = 0;
-    while(read < count && hasNext()) {
-      rows.add(next());
-      read ++;
-    }
-    return read;
-  }
-
-  public Row getHeadersRow() throws HiveClientException {
-    ArrayList<ColumnDescription> schema = getSchema();
-
-    Object[] row = new Object[schema.size()];
-    for (ColumnDescription columnDescription : schema) {
-      row[columnDescription.getPosition()-1] = columnDescription.getName();
-    }
-    return new Row(row, selectedColumns);
-  }
-
-  public int readRaw(ArrayList<Object[]> rows, int count) {
-    int read = 0;
-    while(read < count && hasNext()) {
-      rows.add(next().getRow());
-      read ++;
-    }
-    return read;
-  }
-
-  public void selectColumns(String columnsRequested) {
-    selectedColumns.clear();
-    if (columnsRequested != null) {
-      for (String columnRequested : columnsRequested.split(",")) {
-        try {
-          selectedColumns.add(Integer.parseInt(columnRequested));
-        } catch (NumberFormatException ex) {
-          throw new BadRequestFormattedException("Columns param should be comma-separated integers", ex);
-        }
-      }
-    }
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/client/DDLDelegator.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/client/DDLDelegator.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/client/DDLDelegator.java
deleted file mode 100644
index e609978..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/client/DDLDelegator.java
+++ /dev/null
@@ -1,140 +0,0 @@
-/**
- * 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.ambari.view.hive.client;
-
-import org.apache.hive.service.cli.thrift.*;
-import org.apache.thrift.TException;
-
-import java.util.LinkedList;
-import java.util.List;
-
-public class DDLDelegator {
-  private Connection connection;
-
-  public DDLDelegator(Connection connection) {
-    this.connection = connection;
-  }
-
-  /**
-   * Retrieve list of tables in DB
-   * @param db db name
-   * @return list of table names
-   * @throws HiveClientException
-   */
-  public List<String> getTableList(TSessionHandle session, String db, String like) throws HiveClientException {
-    Cursor cursor = getTableListCursor(session, db, like);
-    return cursor.getValuesInColumn(0);
-  }
-
-  /**
-   * Retrieve list of tables in DB results set
-   * @param db db name
-   * @return list of table names
-   * @throws HiveClientException
-   */
-   public Cursor getTableListCursor(TSessionHandle session, String db, String like) throws HiveClientException {
-    connection.executeSync(session, String.format("use %s", db));
-    TOperationHandle handle = connection.executeSync(session, String.format("show tables like '%s'", like));
-
-    return new Cursor(connection, handle);
-  }
-
-  /**
-   * Retrieve databases
-   * @param like '*' for all
-   * @return list of databases
-   * @throws HiveClientException
-   */
-  public List<String> getDBList(TSessionHandle session, String like) throws HiveClientException {
-    Cursor cursor = getDBListCursor(session, like);
-    return cursor.getValuesInColumn(0);
-  }
-
-  /**
-   * Retrieve databases results set
-   * @param like '*' for all
-   * @return list of databases
-   * @throws HiveClientException
-   */
-  public Cursor getDBListCursor(TSessionHandle session, String like) throws HiveClientException {
-    TOperationHandle handle = connection.executeSync(session, String.format("show databases like '%s'", like));
-    return new Cursor(connection, handle);
-  }
-
-  /**
-   * Retrieve table schema
-   * @param db database name
-   * @param table table name
-   * @return schema
-   * @throws HiveClientException
-   */
-  public List<ColumnDescription> getTableDescription(TSessionHandle session, final String db, final String table, String like, boolean extended) throws HiveClientException {
-    List<ColumnDescription> columnDescriptions = new LinkedList<ColumnDescription>();
-    Cursor cursor = getTableDescriptionCursor(session, db, table, like);
-    for(Row row : cursor) {
-      Object[] rowObjects = row.getRow();
-
-      ColumnDescription columnDescription;
-      if (extended) {
-        //TODO: retrieve sortedBy, clusteredBy, partitioned
-        columnDescription = ColumnDescriptionExtended.createExtendedColumnDescription(
-            (String) rowObjects[3], (String) rowObjects[5], (String) rowObjects[11],
-            false, false, false, (Integer) rowObjects[16]);
-      } else {
-        columnDescription = ColumnDescriptionShort.createShortColumnDescription(
-            (String) rowObjects[3], (String) rowObjects[5], (Integer) rowObjects[16]);
-      }
-      columnDescriptions.add(columnDescription);
-    }
-    return columnDescriptions;
-  }
-
-  /**
-   * Retrieve table schema results set
-   * @param db database name
-   * @param table table name
-   * @return schema
-   * @throws HiveClientException
-   */
-  public Cursor getTableDescriptionCursor(final TSessionHandle session, final String db, final String table, String like) throws HiveClientException {
-    if (like == null)
-      like = ".*";
-    else
-      like = ".*" + like + ".*";
-    final String finalLike = like;
-    TGetColumnsResp resp = new HiveCall<TGetColumnsResp>(connection,session) {
-      @Override
-      public TGetColumnsResp body() throws HiveClientException {
-
-        TGetColumnsReq req = new TGetColumnsReq(session);
-        req.setSchemaName(db);
-        req.setTableName(table);
-        req.setColumnName(finalLike);
-        try {
-          return connection.getClient().GetColumns(req);
-        } catch (TException e) {
-          throw new HiveClientException("H200 Unable to get table columns", e);
-        }
-      }
-
-    }.call();
-
-    return new Cursor(connection, resp.getOperationHandle());
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/client/HiveAuthCredentials.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/client/HiveAuthCredentials.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/client/HiveAuthCredentials.java
deleted file mode 100644
index 2b3f43b..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/client/HiveAuthCredentials.java
+++ /dev/null
@@ -1,31 +0,0 @@
-/**
- * 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.ambari.view.hive.client;
-
-public class HiveAuthCredentials {
-  private String password;
-
-  public String getPassword() {
-    return password;
-  }
-
-  public void setPassword(String password) {
-    this.password = password;
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/client/HiveAuthRequiredException.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/client/HiveAuthRequiredException.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/client/HiveAuthRequiredException.java
deleted file mode 100644
index ac15f2f..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/client/HiveAuthRequiredException.java
+++ /dev/null
@@ -1,27 +0,0 @@
-/**
- * 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.ambari.view.hive.client;
-
-import org.apache.ambari.view.hive.utils.ServiceFormattedException;
-
-public class HiveAuthRequiredException extends ServiceFormattedException {
-  public HiveAuthRequiredException() {
-    super("Hive Password Required", null, 401);
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/client/HiveCall.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/client/HiveCall.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/client/HiveCall.java
deleted file mode 100644
index d2a459f..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/client/HiveCall.java
+++ /dev/null
@@ -1,120 +0,0 @@
-/**
- * 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.ambari.view.hive.client;
-
-import org.apache.commons.lang.exception.ExceptionUtils;
-import org.apache.hive.service.cli.thrift.TSessionHandle;
-import org.apache.hive.service.cli.thrift.TStatus;
-import org.apache.hive.service.cli.thrift.TStatusCode;
-import org.apache.thrift.transport.TTransportException;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-import java.lang.reflect.InvocationTargetException;
-import java.lang.reflect.Method;
-
-public abstract class HiveCall <T> {
-  private final static Logger LOG =
-      LoggerFactory.getLogger(HiveCall.class);
-
-  protected final Connection conn;
-  protected final TSessionHandle sessionHandle;
-
-  public HiveCall(Connection connection) {
-    this(connection,null);
-  }
-
-  public HiveCall(Connection connection, TSessionHandle sessionHandle) {
-    this.conn = connection;
-    this.sessionHandle = sessionHandle;
-  }
-
-  public abstract T body() throws HiveClientException;
-
-  public boolean validateSession(T t) throws HiveClientException {
-    //invalidate a session
-    try {
-      Method m = t.getClass().getMethod("getStatus");
-      if (m != null) {
-        TStatus status = (TStatus) m.invoke(t);
-        if (status.getStatusCode().equals(TStatusCode.ERROR_STATUS) &&
-          status.getErrorMessage().startsWith("Invalid SessionHandle: SessionHandle")) {
-          try {
-            conn.invalidateSessionBySessionHandle(sessionHandle);
-          } catch (HiveClientException e) {
-            LOG.error(e.getMessage(),e);
-          }
-          throw new HiveClientException("Please Retry." + status.getErrorMessage(), null);
-          //return false;
-        }
-      }
-    } catch (NoSuchMethodException e) {
-
-    } catch (InvocationTargetException e) {
-
-    } catch (IllegalAccessException e) {
-
-    }
-    return true;
-  }
-
-  public T call() throws HiveClientException {
-    T result = null;
-    boolean needRetry = false;
-    int attempts = 0;
-    do {
-      if (needRetry) {
-        needRetry = false;
-        attempts += 1;
-        try {
-          conn.closeConnection();
-        } catch (Exception e) {
-          LOG.error("Connection closed with error", e);
-        }
-      }
-
-      if (conn.getClient() == null) {
-        // previous attempt closed the connection, but new was failed to be established.
-        // on new call trying to open the connection again.
-        conn.openConnection();
-      }
-
-      try {
-
-        synchronized (conn) {
-          result = body();
-          if(sessionHandle !=null) {
-            this.validateSession(result);
-          }
-        }
-
-      } catch (HiveClientException ex) {
-        Throwable root = ExceptionUtils.getRootCause(ex);
-        if (attempts < 2 && root instanceof TTransportException) {
-          needRetry = true;
-          LOG.error("Retry call because of Transport Exception: " + root.toString());
-          continue;
-        }
-        throw ex;
-      }
-    } while (needRetry);
-    return result;
-  }
-
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/client/HiveClientAuthRequiredException.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/client/HiveClientAuthRequiredException.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/client/HiveClientAuthRequiredException.java
deleted file mode 100644
index 955bdf9..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/client/HiveClientAuthRequiredException.java
+++ /dev/null
@@ -1,25 +0,0 @@
-/**
- * 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.ambari.view.hive.client;
-
-public class HiveClientAuthRequiredException extends Exception {
-  public HiveClientAuthRequiredException(String comment, Exception ex) {
-    super(comment + ((ex == null)?"":(": " + ex.toString())), ex);
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/client/HiveClientException.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/client/HiveClientException.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/client/HiveClientException.java
deleted file mode 100644
index 9dd04de..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/client/HiveClientException.java
+++ /dev/null
@@ -1,25 +0,0 @@
-/**
- * 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.ambari.view.hive.client;
-
-public class HiveClientException extends Exception {
-  public HiveClientException(String comment, Exception ex) {
-    super(comment + ((ex == null)?"":(": " + ex.toString())), ex);
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/client/HiveClientRuntimeException.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/client/HiveClientRuntimeException.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/client/HiveClientRuntimeException.java
deleted file mode 100644
index 1393012..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/client/HiveClientRuntimeException.java
+++ /dev/null
@@ -1,25 +0,0 @@
-/**
- * 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.ambari.view.hive.client;
-
-public class HiveClientRuntimeException extends RuntimeException {
-  public HiveClientRuntimeException(String comment, Exception ex) {
-    super(comment + ((ex == null)?"":(": " + ex.toString())), ex);
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/client/HiveErrorStatusException.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/client/HiveErrorStatusException.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/client/HiveErrorStatusException.java
deleted file mode 100644
index 1b306dc..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/client/HiveErrorStatusException.java
+++ /dev/null
@@ -1,30 +0,0 @@
-/**
- * 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.ambari.view.hive.client;
-
-import org.apache.hive.service.cli.thrift.TStatusCode;
-
-/**
- * Some thrift operation done with status 'failed'
- */
-public class HiveErrorStatusException extends HiveClientException {
-  public HiveErrorStatusException(TStatusCode statusCode, String comment) {
-    super(String.format("%s [%s]", comment, statusCode), null);
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/client/HiveInvalidQueryException.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/client/HiveInvalidQueryException.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/client/HiveInvalidQueryException.java
deleted file mode 100644
index 473ab65..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/client/HiveInvalidQueryException.java
+++ /dev/null
@@ -1,27 +0,0 @@
-/**
- * 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.ambari.view.hive.client;
-
-import org.apache.hive.service.cli.thrift.TStatusCode;
-
-public class HiveInvalidQueryException extends HiveClientException {
-  public HiveInvalidQueryException(TStatusCode statusCode, String comment) {
-    super(String.format("%s [%s]", comment, statusCode), null);
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/client/HttpBasicAuthInterceptor.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/client/HttpBasicAuthInterceptor.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/client/HttpBasicAuthInterceptor.java
deleted file mode 100644
index dea8fcb..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/client/HttpBasicAuthInterceptor.java
+++ /dev/null
@@ -1,55 +0,0 @@
-/**
- * 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.ambari.view.hive.client;
-
-import org.apache.http.Header;
-import org.apache.http.HttpRequest;
-import org.apache.http.auth.UsernamePasswordCredentials;
-import org.apache.http.client.CookieStore;
-import org.apache.http.impl.auth.AuthSchemeBase;
-import org.apache.http.impl.auth.BasicScheme;
-import org.apache.http.protocol.HttpContext;
-
-import java.util.Map;
-
-/**
- * The class is instantiated with the username and password, it is then
- * used to add header with these credentials to HTTP requests
- *
- */
-public class HttpBasicAuthInterceptor extends HttpRequestInterceptorBase {
-  UsernamePasswordCredentials credentials;
-  AuthSchemeBase authScheme;
-
-  public HttpBasicAuthInterceptor(String username, String password, CookieStore cookieStore,
-                           String cn, boolean isSSL, Map<String, String> additionalHeaders) {
-    super(cookieStore, cn, isSSL, additionalHeaders);
-    this.authScheme = new BasicScheme();
-    if (username != null){
-      this.credentials = new UsernamePasswordCredentials(username, password);
-    }
-  }
-
-  @Override
-  protected void addHttpAuthHeader(HttpRequest httpRequest, HttpContext httpContext)
-    throws Exception {
-    Header basicAuthHeader = authScheme.authenticate(credentials, httpRequest, httpContext);
-    httpRequest.addHeader(basicAuthHeader);
-  }
-}
\ No newline at end of file

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/client/HttpKerberosRequestInterceptor.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/client/HttpKerberosRequestInterceptor.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/client/HttpKerberosRequestInterceptor.java
deleted file mode 100644
index 786c94d..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/client/HttpKerberosRequestInterceptor.java
+++ /dev/null
@@ -1,72 +0,0 @@
-/**
- * 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.ambari.view.hive.client;
-
-import org.apache.hive.service.auth.HttpAuthUtils;
-import org.apache.http.HttpException;
-import org.apache.http.HttpRequest;
-import org.apache.http.client.CookieStore;
-import org.apache.http.protocol.HttpContext;
-
-import java.util.Map;
-import java.util.concurrent.locks.ReentrantLock;
-
-/**
- * Authentication interceptor which adds Base64 encoded payload,
- * containing the username and kerberos service ticket,
- * to the outgoing http request header.
- */
-public class HttpKerberosRequestInterceptor extends HttpRequestInterceptorBase {
-
-  // A fair reentrant lock
-  private static ReentrantLock kerberosLock = new ReentrantLock(true);
-  String principal;
-  String host;
-  String serverHttpUrl;
-  boolean assumeSubject;
-
-  public HttpKerberosRequestInterceptor(String principal, String host,
-      String serverHttpUrl, boolean assumeSubject, CookieStore cs, String cn,
-      boolean isSSL, Map<String, String> additionalHeaders) {
-    super(cs, cn, isSSL, additionalHeaders);
-    this.principal = principal;
-    this.host = host;
-    this.serverHttpUrl = serverHttpUrl;
-    this.assumeSubject = assumeSubject;
-  }
-
-  @Override
-  protected void addHttpAuthHeader(HttpRequest httpRequest,
-    HttpContext httpContext) throws Exception {
-	try {
-      // Generate the service ticket for sending to the server.
-      // Locking ensures the tokens are unique in case of concurrent requests
-      kerberosLock.lock();
-      String kerberosAuthHeader = HttpAuthUtils.getKerberosServiceTicket(
-              principal, host, serverHttpUrl, assumeSubject);
-      // Set the session key token (Base64 encoded) in the headers
-      httpRequest.addHeader(HttpAuthUtils.AUTHORIZATION + ": " +
-        HttpAuthUtils.NEGOTIATE + " ", kerberosAuthHeader);
-    } catch (Exception e) {
-      throw new HttpException(e.getMessage(), e);
-    } finally {
-      kerberosLock.unlock();
-    }
-  }
-}
\ No newline at end of file

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/client/HttpRequestInterceptorBase.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/client/HttpRequestInterceptorBase.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/client/HttpRequestInterceptorBase.java
deleted file mode 100644
index 7dc3c53..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/client/HttpRequestInterceptorBase.java
+++ /dev/null
@@ -1,88 +0,0 @@
-/**
- * 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.ambari.view.hive.client;
-
-import org.apache.http.HttpException;
-import org.apache.http.HttpRequest;
-import org.apache.http.HttpRequestInterceptor;
-import org.apache.http.client.CookieStore;
-import org.apache.http.client.protocol.ClientContext;
-import org.apache.http.protocol.HttpContext;
-
-import java.io.IOException;
-import java.util.Map;
-
-public abstract class HttpRequestInterceptorBase implements HttpRequestInterceptor {
-  CookieStore cookieStore;
-  boolean isCookieEnabled;
-  String cookieName;
-  boolean isSSL;
-  Map<String, String> additionalHeaders;
-
-  public HttpRequestInterceptorBase(CookieStore cs, String cn, boolean isSSL,
-                                    Map<String, String> additionalHeaders) {
-    this.cookieStore = cs;
-    this.isCookieEnabled = (cs != null);
-    this.cookieName = cn;
-    this.isSSL = isSSL;
-    this.additionalHeaders = additionalHeaders;
-  }
-
-  // Abstract function to add HttpAuth Header
-  protected abstract void addHttpAuthHeader(HttpRequest httpRequest, HttpContext httpContext)
-    throws Exception;
-
-  @Override
-  public void process(HttpRequest httpRequest, HttpContext httpContext)
-    throws HttpException, IOException {
-    try {
-      // If cookie based authentication is allowed, generate ticket only when necessary.
-      // The necessary condition is either when there are no server side cookies in the
-      // cookiestore which can be send back or when the server returns a 401 error code
-      // indicating that the previous cookie has expired.
-      if (isCookieEnabled) {
-        httpContext.setAttribute(ClientContext.COOKIE_STORE, cookieStore);
-      }
-      // Generate the kerberos ticket under the following scenarios:
-      // 1. Cookie Authentication is disabled OR
-      // 2. The first time when the request is sent OR
-      // 3. The server returns a 401, which sometimes means the cookie has expired
-      // 4. The cookie is secured where as the client connect does not use SSL
-      if (!isCookieEnabled || ((httpContext.getAttribute(Utils.HIVE_SERVER2_RETRY_KEY) == null &&
-          (cookieStore == null || (cookieStore != null &&
-          Utils.needToSendCredentials(cookieStore, cookieName, isSSL)))) ||
-          (httpContext.getAttribute(Utils.HIVE_SERVER2_RETRY_KEY) != null &&
-          httpContext.getAttribute(Utils.HIVE_SERVER2_RETRY_KEY).
-          equals(Utils.HIVE_SERVER2_RETRY_TRUE)))) {
-        addHttpAuthHeader(httpRequest, httpContext);
-      }
-      if (isCookieEnabled) {
-        httpContext.setAttribute(Utils.HIVE_SERVER2_RETRY_KEY, Utils.HIVE_SERVER2_RETRY_FALSE);
-      }
-      // Insert the additional http headers
-      if (additionalHeaders != null) {
-        for (Map.Entry<String, String> entry : additionalHeaders.entrySet()) {
-          httpRequest.addHeader(entry.getKey(), entry.getValue());
-        }
-      }
-    } catch (Exception e) {
-      throw new HttpException(e.getMessage(), e);
-    }
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/client/LogsCursor.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/client/LogsCursor.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/client/LogsCursor.java
deleted file mode 100644
index a6705e4..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/client/LogsCursor.java
+++ /dev/null
@@ -1,36 +0,0 @@
-/**
- * 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.ambari.view.hive.client;
-
-import org.apache.hive.service.cli.thrift.TFetchOrientation;
-import org.apache.hive.service.cli.thrift.TFetchResultsReq;
-import org.apache.hive.service.cli.thrift.TOperationHandle;
-
-public class LogsCursor extends Cursor {
-  public LogsCursor(Connection connection, TOperationHandle opHandle) {
-    super(connection, opHandle);
-  }
-
-  @Override
-  protected TFetchResultsReq getFetchResultsReq(TFetchOrientation orientation) {
-    TFetchResultsReq req = super.getFetchResultsReq(orientation);
-    req.setFetchType((short) 1);
-    return req;
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/client/Row.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/client/Row.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/client/Row.java
deleted file mode 100644
index cfce1f0..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/client/Row.java
+++ /dev/null
@@ -1,74 +0,0 @@
-/**
- * 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.ambari.view.hive.client;
-
-import java.util.Arrays;
-import java.util.HashSet;
-
-public class Row {
-  private Object[] row;
-
-  public Row(Object[] row) {
-    this(row, null);
-  }
-
-  public Row(Object[] row, HashSet<Integer> selectedColumns) {
-    if (selectedColumns == null || selectedColumns.size() == 0)
-      this.row = row.clone();
-    else {
-      this.row = new Object[selectedColumns.size()];
-      int rowIndex = 0;
-      for (Integer selectedIndex : selectedColumns) {
-        this.row[rowIndex] = row[selectedIndex];
-        rowIndex ++;
-      }
-    }
-  }
-
-  public Object[] getRow() {
-    return row;
-  }
-
-  public void setRow(Object[] row) {
-    this.row = row;
-  }
-
-  @Override
-  public boolean equals(Object o) {
-    if (this == o) return true;
-    if (o == null || getClass() != o.getClass()) return false;
-
-    Row row1 = (Row) o;
-
-    boolean retValue = Arrays.equals(row, row1.row);
-    return retValue;
-  }
-
-  @Override
-  public int hashCode() {
-    return Arrays.hashCode(row);
-  }
-
-  @Override
-  public String toString() {
-    return "Row{" +
-            "row=" + Arrays.toString(row) +
-            '}';
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/client/UserLocalConnection.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/client/UserLocalConnection.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/client/UserLocalConnection.java
deleted file mode 100644
index 3e2c3cc..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/client/UserLocalConnection.java
+++ /dev/null
@@ -1,48 +0,0 @@
-/**
- * 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.ambari.view.hive.client;
-
-import org.apache.ambari.view.ViewContext;
-import org.apache.ambari.view.utils.UserLocal;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-public class UserLocalConnection extends UserLocal<Connection> {
-  protected final static Logger LOG =
-      LoggerFactory.getLogger(UserLocalConnection.class);
-
-  public UserLocalConnection() {
-    super(Connection.class);
-  }
-
-  private UserLocal<HiveAuthCredentials> authCredentialsLocal =
-      new UserLocalHiveAuthCredentials();
-
-  @Override
-  protected Connection initialValue(ViewContext context) {
-      LOG.debug("creating connection for context : {}" , context);
-      ConnectionFactory hiveConnectionFactory = new ConnectionFactory(context, authCredentialsLocal.get(context));
-      authCredentialsLocal.remove(context);  // we should not store credentials in memory,
-      // password is erased after connection established
-      Connection connection = hiveConnectionFactory.create();
-    LOG.debug("returning connection : {} for context : {} ", connection, context);
-      return connection;
-  }
-
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/client/UserLocalHiveAuthCredentials.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/client/UserLocalHiveAuthCredentials.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/client/UserLocalHiveAuthCredentials.java
deleted file mode 100644
index f658c14..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/client/UserLocalHiveAuthCredentials.java
+++ /dev/null
@@ -1,33 +0,0 @@
-/**
- * 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.ambari.view.hive.client;
-
-import org.apache.ambari.view.ViewContext;
-import org.apache.ambari.view.utils.UserLocal;
-
-public class UserLocalHiveAuthCredentials extends UserLocal<HiveAuthCredentials> {
-  public UserLocalHiveAuthCredentials() {
-    super(HiveAuthCredentials.class);
-  }
-
-  @Override
-  protected HiveAuthCredentials initialValue(ViewContext context) {
-    return new HiveAuthCredentials();
-  }
-}


[11/23] ambari git commit: AMBARI-19302 : removed contrib/views/hive folder and made necessary changes in pom.xml files (nitirajrathore)

Posted by ni...@apache.org.
http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/styles/dropdown-submenu.scss
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/styles/dropdown-submenu.scss b/contrib/views/hive/src/main/resources/ui/hive-web/app/styles/dropdown-submenu.scss
deleted file mode 100644
index bab2216..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/styles/dropdown-submenu.scss
+++ /dev/null
@@ -1,65 +0,0 @@
-/**
- * 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.
- */
-
-.dropdown-submenu {
-    position:relative;
-}
-
-.dropdown-submenu>.dropdown-menu {
-    top:0;
-    left:100%;
-    margin-top:-6px;
-    margin-left:-1px;
-    -webkit-border-radius:0 6px 6px 6px;
-    -moz-border-radius:0 6px 6px 6px;
-    border-radius:0 6px 6px 6px;
-}
-
-.dropdown-submenu:hover>.dropdown-menu {
-    display:block;
-}
-
-.dropdown-submenu>a:after {
-    display:block;
-    content:" ";
-    float:right;
-    width:0;
-    height:0;
-    border-color:transparent;
-    border-style:solid;
-    border-width:5px 0 5px 5px;
-    border-left-color:#cccccc;
-    margin-top:5px;
-    margin-right:-10px;
-}
-
-.dropdown-submenu:hover>a:after {
-    border-left-color:#ffffff;
-}
-
-.dropdown-submenu.pull-left {
-    float:none;
-}
-
-.dropdown-submenu.pull-left>.dropdown-menu {
-    left:-100%;
-    margin-left:10px;
-    -webkit-border-radius:6px 0 6px 6px;
-    -moz-border-radius:6px 0 6px 6px;
-    border-radius:6px 0 6px 6px;
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/styles/mixins.scss
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/styles/mixins.scss b/contrib/views/hive/src/main/resources/ui/hive-web/app/styles/mixins.scss
deleted file mode 100644
index acaa386..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/styles/mixins.scss
+++ /dev/null
@@ -1,28 +0,0 @@
-/**
-* 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.
-*/
-
-@mixin box-shadow($horizontal, $vertical, $blur, $color) {
-  -webkit-box-shadow: $horizontal $vertical $blur $color;
-     -moz-box-shadow: $horizontal $vertical $blur $color;
-          box-shadow: $horizontal $vertical $blur $color;
-}
-
-@mixin animate-width($time) {
-  -webkit-transition: $time;
-  transition: width $time;
-}
\ No newline at end of file

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/styles/notifications.scss
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/styles/notifications.scss b/contrib/views/hive/src/main/resources/ui/hive-web/app/styles/notifications.scss
deleted file mode 100644
index 166056b..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/styles/notifications.scss
+++ /dev/null
@@ -1,37 +0,0 @@
-/**
-* 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.
-*/
-
-.notifications-container {
-  position: absolute;
-  top: 4px;
-  right: 20px;
-  width: 600px;
-  z-index: 9999;
-}
-
-.notification > .fa {
-  width: 15px;
-  text-align: center;
-  margin-right: 10px;
-}
-
-.notifications-container .notification {
-  word-wrap: break-word;
-  max-height: 200px;
-  overflow-x: auto;
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/styles/query-tabs.scss
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/styles/query-tabs.scss b/contrib/views/hive/src/main/resources/ui/hive-web/app/styles/query-tabs.scss
deleted file mode 100644
index 9f803b4..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/styles/query-tabs.scss
+++ /dev/null
@@ -1,69 +0,0 @@
-/**
-* 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.
-*/
-
-.query-menu {
-  margin-top: 58px;
-
-  span, popover {
-    cursor: pointer;
-    display: block;
-    border-bottom: 1px solid $border-color;
-    padding: 10px;
-  }
-}
-
-.fa.panel-action-icon {
-  line-height: 22px;
-  font-size: 16px;
-}
-
-.editor-overlay {
-  width: 100%;
-  overflow-y: scroll;
-  height: calc(100% - 57px);
-  top: 57px;
-  left: 0;
-  background-color: #fff;
-  position: absolute;
-  padding: 10px 15px;
-  z-index: 1000;
-
-  border: 1px solid $border-color;
-  -webkit-animation-duration: .5s;
-          animation-duration: .5s;
-  -webkit-animation-fill-mode: both;
-          animation-fill-mode: both;
-}
-
-.message-body {
-  margin-top: 10px;
-}
-
-.query-menu-tab {
-  position: relative;
-}
-.query-menu-tab .badge {
-  position: absolute;
-  top: -4px;
-  right: 0px;
-  background-color: red;
-  color: #fff;
-  padding: 2px 4px;
-  font-weight: bold;
-  z-index: 9999;
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/styles/vars.scss
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/styles/vars.scss b/contrib/views/hive/src/main/resources/ui/hive-web/app/styles/vars.scss
deleted file mode 100644
index 184ac9d..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/styles/vars.scss
+++ /dev/null
@@ -1,21 +0,0 @@
-/**
-* 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.
-*/
-
-$panel-background: #f5f5f5;
-$placeholder-color: #aaa;
-$border-color: #ddd;

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/.gitkeep
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/.gitkeep b/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/.gitkeep
deleted file mode 100644
index e69de29..0000000

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/application.hbs
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/application.hbs b/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/application.hbs
deleted file mode 100644
index db053fa..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/application.hbs
+++ /dev/null
@@ -1,26 +0,0 @@
-{{!
-* 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.
-}}
-
-{{notify-widget notifications=notifications}}
-{{navbar-widget}}
-
-<div id="content">
-  {{outlet}}
-
-  {{outlet "modal"}}
-</div>

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/components/.gitkeep
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/components/.gitkeep b/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/components/.gitkeep
deleted file mode 100644
index e69de29..0000000

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/components/alert-message-widget.hbs
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/components/alert-message-widget.hbs b/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/components/alert-message-widget.hbs
deleted file mode 100644
index 0901b30..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/components/alert-message-widget.hbs
+++ /dev/null
@@ -1,28 +0,0 @@
-{{!
-* 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.
-}}
-
-<div {{bind-attr class=":alert :alert-dismissible message.typeClass"}}>
-  <button type="button" class="close" data-dismiss="alert" aria-hidden="true" {{action "remove"}}>&times;</button>
-  <strong {{action 'toggleMessage'}}>{{tb-helper message.title}}</strong>
-
-  {{#if message.isExpanded}}
-    <div class="alert-message">
-      {{message.content}}
-    </div>
-  {{/if}}
-</div>

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/components/collapsible-widget.hbs
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/components/collapsible-widget.hbs b/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/components/collapsible-widget.hbs
deleted file mode 100644
index 68ff307..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/components/collapsible-widget.hbs
+++ /dev/null
@@ -1,33 +0,0 @@
-{{!
-* 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.
-}}
-
-<div class="clearfix">
-
-  <a {{action "toggle"}} {{bind-attr class=":fa iconClass :collapsible-row" data-original-title=heading}}
-          data-toggle="tooltip" data-placement="top"
-          title>{{heading}}</a>
-
-  <div class="pull-right widget-controls">
-    {{#each control in controls}}
-      <a {{action 'sendControlAction' control.action}} {{bind-attr class=":fa control.icon" title="control.tooltip"}}></a>
-    {{/each}}
-  </div>
-</div>
-{{#if isExpanded}}
-  {{yield}}
-{{/if}}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/components/column-filter-widget.hbs
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/components/column-filter-widget.hbs b/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/components/column-filter-widget.hbs
deleted file mode 100644
index 3435093..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/components/column-filter-widget.hbs
+++ /dev/null
@@ -1,42 +0,0 @@
-{{!
-* 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.
-}}
-
-{{#if column.dateRange}}
-    {{date-range-widget class="pull-left history-date-range"
-                        rangeChanged="sendFilter"
-                        dateRange=column.dateRange}}
-{{else}}
-  {{#if column.numberRange}}
-    {{number-range-widget class="pull-left"
-                          numberRange=column.numberRange
-                          rangeChanged="sendFilter"}}
-  {{else}}
-    {{extended-input type="text"
-                     class="pull-left form-control input-sm"
-                     placeholderTranslation=column.caption
-                     value=filterValue
-                     valueChanged="sendFilter"}}
-  {{/if}}
-{{/if}}
-<span {{action "sendSort"}}>
-  {{#if isSorted}}
-    <a {{bind-attr class=":pull-right :fa sortAscending:fa-sort-asc:fa-sort-desc"}}></a>
-  {{else}}
-    <i class="pull-right fa fa-unsorted"></i>
-  {{/if}}
-</span>
\ No newline at end of file

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/components/date-range-widget.hbs
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/components/date-range-widget.hbs b/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/components/date-range-widget.hbs
deleted file mode 100644
index 4b9686e..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/components/date-range-widget.hbs
+++ /dev/null
@@ -1,22 +0,0 @@
-{{!
-* 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.
-}}
-
-<div class="form-inline">
-    {{input type="text" value=displayFromDate class="input-sm form-control fromDate"}}
-    {{input type="text" value=displayToDate class="input-sm form-control toDate"}}
-</div>
\ No newline at end of file

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/components/expander-widget.hbs
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/components/expander-widget.hbs b/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/components/expander-widget.hbs
deleted file mode 100644
index 386556c..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/components/expander-widget.hbs
+++ /dev/null
@@ -1,31 +0,0 @@
-{{!
-* 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.
-}}
-
-<div class="panel panel-default no-margin">
-  <div class="panel-heading accordion-heading" {{action "toggle"}}>
-      <span {{bind-attr class=":fa isExpanded:fa-caret-down:fa-caret-right"}}></span>
-      <a class="accordion-toggle">{{heading}}</a>
-      <span class="badge pull-right">{{count}}</span>
-  </div>
-
-  <div class="panel-body accordion-body collapse">
-    <div class="accordion-inner">
-      {{yield}}
-    </div>
-  </div>
-</div>
\ No newline at end of file

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/components/input-header.hbs
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/components/input-header.hbs b/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/components/input-header.hbs
deleted file mode 100644
index b2349fa..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/components/input-header.hbs
+++ /dev/null
@@ -1,20 +0,0 @@
-{{!
-* 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.
-}}
-
-<td  {{bind-attr class="noPrecision:hidden:visible"}}>{{input type="number" placeholder="precision" class="form-control" value=column.precision }}</td>
-<td {{bind-attr class="noScale:hidden:visible"}}>{{input placeholder="scale" type="number" class="form-control" value=column.scale }}</td>
\ No newline at end of file

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/components/job-tr-view.hbs
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/components/job-tr-view.hbs b/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/components/job-tr-view.hbs
deleted file mode 100644
index 6b01946..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/components/job-tr-view.hbs
+++ /dev/null
@@ -1,49 +0,0 @@
-{{!
-* 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.
-}}
-
-<tr class="main-row" {{action "requestFile"}}>
-  <td>
-  {{#link-to "index.historyQuery" job}}
-    {{job.title}}
-  {{/link-to}}
-  </td>
-  <td {{bind-attr class=job.uppercaseStatus}}>{{all-uppercase job.status}}</td>
-  <td>{{date-binding job "dateSubmittedTimestamp"}}</td>
-  <td>{{job.duration}}</td>
-  <td>
-    <a class="fa fa-expand pull-right"></a>
-  </td>
-</tr>
-{{#if expanded}}
-  <tr class="secondary-row">
-    <td colspan="5">
-      {{code-helper job.file.fileContent}}
-
-      {{#if canStop}}
-        <button type="button" {{bind-attr class=":btn :btn-warning :btn-sm :pull-right job.isCancelling:disabled"}} {{action "stopJob"}}>
-          {{#if job.isCancelling}}
-            {{t "buttons.stoppingJob"}}
-            <div class="spinner small inline-spinner"></div>
-          {{else}}
-            {{t "buttons.stopJob"}}
-          {{/if}}
-        </button>
-      {{/if}}
-    </td>
-  </tr>
-{{/if}}
\ No newline at end of file

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/components/modal-widget.hbs
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/components/modal-widget.hbs b/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/components/modal-widget.hbs
deleted file mode 100644
index 8f2dec7..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/components/modal-widget.hbs
+++ /dev/null
@@ -1,35 +0,0 @@
-{{!
-* 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.
-}}
-
-<div class="modal fade">
-  <div class="modal-dialog">
-    <div class="modal-content">
-      <div class="modal-header">
-        <button type="button" class="close"><span aria-hidden="true" data-dismiss="modal">&times;</span><span class="sr-only">Close</span></button>
-        <h4 class="modal-title">{{tb-helper heading}}</h4>
-      </div>
-      <div class="modal-body">
-        {{yield}}
-      </div>
-      <div class="modal-footer">
-        <button type="button" class="btn btn-sm btn-danger" data-dismiss="modal">{{t "buttons.close"}}</button>
-        <button type="button" class="btn btn-sm btn-success" {{action 'ok'}}>{{t "buttons.ok"}}</button>
-      </div>
-    </div>
-  </div>
-</div>

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/components/navbar-widget.hbs
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/components/navbar-widget.hbs b/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/components/navbar-widget.hbs
deleted file mode 100644
index f13f7b5..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/components/navbar-widget.hbs
+++ /dev/null
@@ -1,45 +0,0 @@
-{{!
-* 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.
-}}
-
-<nav class="navbar navbar-default no-margin" role="navigation">
-  <div class="container-fluid">
-    <!-- Brand and toggle get grouped for better mobile display -->
-    <div class="navbar-header">
-      <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#bs-example-navbar-collapse-1">
-        <span class="sr-only">Toggle navigation</span>
-        <span class="icon-bar"></span>
-        <span class="icon-bar"></span>
-        <span class="icon-bar"></span>
-      </button>
-      {{#link-to "index" classNames="navbar-brand mozBoxSizeFix"}}
-        {{view.title}}
-      {{/link-to}}
-    </div>
-
-    <!-- Collect the nav links, forms, and other content for toggling -->
-    <div class="collapse navbar-collapse" id="bs-example-navbar-collapse-1">
-       <ul class="nav navbar-nav">
-        {{#each item in view.items}}
-          {{#link-to item.path tagName="li"}}
-            <a>{{tb-helper "text" item}}</a>
-          {{/link-to}}
-        {{/each}}
-      </ul>
-    </div>
-  </div>
-</nav>
\ No newline at end of file

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/components/no-bubbling.hbs
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/components/no-bubbling.hbs b/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/components/no-bubbling.hbs
deleted file mode 100644
index 6ae472f..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/components/no-bubbling.hbs
+++ /dev/null
@@ -1,19 +0,0 @@
-{{!
-* 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.
-}}
-
-{{yield}}
\ No newline at end of file

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/components/notify-widget.hbs
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/components/notify-widget.hbs b/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/components/notify-widget.hbs
deleted file mode 100644
index 5f905a8..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/components/notify-widget.hbs
+++ /dev/null
@@ -1,21 +0,0 @@
-{{!
-* 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.
-}}
-
-{{#each notification in notifications}}
-  {{view "notification" notification=notification}}
-{{/each}}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/components/number-range-widget.hbs
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/components/number-range-widget.hbs b/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/components/number-range-widget.hbs
deleted file mode 100644
index da99e9c..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/components/number-range-widget.hbs
+++ /dev/null
@@ -1,23 +0,0 @@
-{{!
-* 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.
-}}
-
-<div class="slider"></div>
-<div class="slider-labels">
-  <span class="pull-left">{{numberRange.fromDuration}}</span>
-  <span class="pull-right">{{numberRange.toDuration}}</span>
-</div>
\ No newline at end of file

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/components/panel-widget.hbs
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/components/panel-widget.hbs b/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/components/panel-widget.hbs
deleted file mode 100644
index a8af586..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/components/panel-widget.hbs
+++ /dev/null
@@ -1,54 +0,0 @@
-{{!
-* 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.
-}}
-
-<div {{bind-attr class=":panel :panel-default classNames"}}>
-  {{#if heading}}
-    <div class="panel-heading">
-      {{#if menuItems}}
-          <div class="dropdown pull-right">
-              <a href="#" class="dropdown-toggle" data-toggle="dropdown">{{menuHeading}} <b class="caret"></b></a>
-
-              <ul class="dropdown-menu" role="menu">
-                  {{#each item in menuItems}}
-                      {{#if item.href}}
-                          <li><a {{bind-attr href=item.href}}>{{item.title}}</a></li>
-                      {{else}}
-                          <li><a {{action "sendMenuItemAction" item.action}}>{{item.title}}</a></li>
-                      {{/if}}
-                  {{/each}}
-              </ul>
-          </div>
-      {{/if}}
-
-      {{#if iconActions}}
-        {{#each iconAction in iconActions}}
-        <i {{action "sendMenuItemAction" iconAction.action}}
-          {{bind-attr class=":pull-right :panel-action-icon :fa iconAction.icon" title="iconAction.tooltip"}}></i>
-        {{/each}}
-      {{/if}}
-
-      <strong>{{heading}}</strong>
-      {{#if isLoading}}
-        <div class="spinner small pull-right"></div>
-      {{/if}}
-    </div>
-  {{/if}}
-  <div class="panel-body">
-    {{yield}}
-  </div>
-</div>

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/components/popover-widget.hbs
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/components/popover-widget.hbs b/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/components/popover-widget.hbs
deleted file mode 100644
index f7c6d9c..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/components/popover-widget.hbs
+++ /dev/null
@@ -1,19 +0,0 @@
-{{!
-* 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.
-}}
-
-<span class="hide"> {{yield}} </span>

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/components/progress-widget.hbs
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/components/progress-widget.hbs b/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/components/progress-widget.hbs
deleted file mode 100644
index 2ea7b94..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/components/progress-widget.hbs
+++ /dev/null
@@ -1,23 +0,0 @@
-{{!
-* 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.
-}}
-
-<div class="progress">
-  <div {{bind-attr class=":progress-bar :progress-bar-success" style=style}}>
-    {{percentage}}
-  </div>
-</div>
\ No newline at end of file

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/components/query-editor.hbs
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/components/query-editor.hbs b/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/components/query-editor.hbs
deleted file mode 100644
index 4ec9259..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/components/query-editor.hbs
+++ /dev/null
@@ -1,19 +0,0 @@
-{{!
-* 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.
-}}
-
-{{textarea id="code-mirror" rows="15" cols="20" value=query}}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/components/select-widget.hbs
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/components/select-widget.hbs b/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/components/select-widget.hbs
deleted file mode 100644
index 6da1f3e..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/components/select-widget.hbs
+++ /dev/null
@@ -1,39 +0,0 @@
-{{!
-* 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.
-}}
-
-<div class="btn-group">
-  <a class="btn btn-default dropdown-toggle" data-toggle="dropdown">
-      <span class="selected-item pull-left">{{selectedLabel}}</span>
-      <span class="pull-right fa fa-caret-down"></span>
-  </a>
-  <ul class="dropdown-menu">
-    {{#each item in items}}
-      <li {{action "select" item}}>
-        <a>{{path-binding item labelPath}}
-          {{#if canEdit}}
-            <span class="fa fa-remove pull-right" {{action "remove" item}}></span>
-            <span class="fa fa-edit pull-right" {{action "edit" item}}></span>
-          {{/if}}
-        </a>
-      </li>
-    {{/each}}
-    {{#if canAdd}}
-      <li {{action "add"}}><a>{{t "buttons.addItem"}}</a></li>
-    {{/if}}
-  </ul>
-</div>
\ No newline at end of file

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/components/tabs-widget.hbs
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/components/tabs-widget.hbs b/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/components/tabs-widget.hbs
deleted file mode 100644
index edef7fd..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/components/tabs-widget.hbs
+++ /dev/null
@@ -1,41 +0,0 @@
-{{!
-* 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.
-}}
-
-<ul class="nav nav-tabs">
-  {{#each tab in tabs}}
-    {{#if tab.visible}}
-      {{#if tab.path}}
-        {{#link-to tab.path tab.id tagName="li"}}
-          <a {{action 'titleClick' tab on="doubleClick"}}>
-            {{tab.name}}
-            {{#if tab.isDirty}}*{{/if}}
-            {{#if view.removeEnabled}}
-              <i class="fa fa-remove" {{action 'remove' tab}}></i>
-            {{/if}}
-          </a>
-        {{/link-to}}
-      {{else}}
-        <li {{bind-attr class="tab.active:active"}} {{action 'selectTab' tab}}>
-          <a>{{tab.name}}</a>
-        </li>
-      {{/if}}
-    {{/if}}
-  {{/each}}
-</ul>
-
-{{yield}}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/components/tree-view.hbs
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/components/tree-view.hbs b/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/components/tree-view.hbs
deleted file mode 100644
index ef9a566..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/components/tree-view.hbs
+++ /dev/null
@@ -1,28 +0,0 @@
-{{!
-* 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.
-}}
-
-<ul class="list-unstyled explainlist">
-  {{#each item in content}}
-    <li>
-      {{item.text}}
-      {{#if item.contents}}
-        {{tree-view content=item.contents}}
-      {{/if}}
-    </li>
-  {{/each}}
-</ul>
\ No newline at end of file

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/components/udf-tr-view.hbs
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/components/udf-tr-view.hbs b/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/components/udf-tr-view.hbs
deleted file mode 100644
index 4b5cd61..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/components/udf-tr-view.hbs
+++ /dev/null
@@ -1,77 +0,0 @@
-{{!
-* 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.
-}}
-
-<td>
-  {{#if udf.isEditing}}
-    {{#if udf.isEditingResource}}
-      {{extended-input type="text"
-                       class="pull-left form-control halfed input-sm"
-                       placeholderTranslation="placeholders.fileResource.name"
-                       value=udf.fileResource.name}}
-      {{extended-input type="text"
-                       class="pull-left form-control halfed input-sm"
-                       placeholderTranslation="placeholders.fileResource.path"
-                       value=udf.fileResource.path}}
-    {{else}}
-      {{select-widget items=fileResources
-                      selectedValue=udf.fileResource
-                      labelPath="name"
-                      defaultLabelTranslation="placeholders.select.file"
-                      itemAdded="addFileResource"
-                      itemEdited="editFileResource"
-                      itemRemoved="deleteFileResource"
-                      canAdd=true
-                      canEdit=true}}
-    {{/if}}
-  {{else}}
-    {{#if udf.fileResource}}
-      {{udf.fileResource.name}}  ({{udf.fileResource.path}})
-    {{/if}}
-  {{/if}}
-</td>
-{{#each column in columns}}
-  <td>
-    {{#if udf.isEditing}}
-      {{extended-input type="text"
-                       class="pull-left form-control input-sm"
-                       placeholderTranslation=column.caption
-                       dynamicContextBinding="udf"
-                       dynamicValueBinding="column.property"}}
-    {{else}}
-      {{path-binding udf column.property}}
-    {{/if}}
-  </td>
-{{/each}}
-<td>
-  {{#if udf.isEditing}}
-    <div class="pull-right">
-      <button type="button" class="btn btn-sm btn-warning" {{action "cancel"}}>{{t "buttons.cancel"}}</button>
-      <button type="button" class="btn btn-sm btn-success" {{action "save"}}>{{t "buttons.save"}}</button>
-    </div>
-  {{else}}
-    <div class="btn-group pull-right">
-      <span data-toggle="dropdown">
-        <a class="fa fa-gear"></a>
-      </span>
-      <ul class="dropdown-menu" role="menu">
-        <li {{action 'editUdf'}}><a>{{t 'buttons.edit'}}</a></li>
-        <li {{action 'deleteUdf'}}><a>{{t 'buttons.delete'}}</a></li>
-      </ul>
-    </div>
-  {{/if}}
-</td>
\ No newline at end of file

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/components/validated-text-field.hbs
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/components/validated-text-field.hbs b/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/components/validated-text-field.hbs
deleted file mode 100644
index 7cf0fcf..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/components/validated-text-field.hbs
+++ /dev/null
@@ -1,23 +0,0 @@
-{{!
-* 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.
-}}
-
-{{!
-* see example in validated-text-field.js component file
-}}
-
-{{input class=inputClass value=inputValue title=message placeholder=placeholder}}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/components/visualization-tabs-widget.hbs
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/components/visualization-tabs-widget.hbs b/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/components/visualization-tabs-widget.hbs
deleted file mode 100644
index dad5e41..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/components/visualization-tabs-widget.hbs
+++ /dev/null
@@ -1,27 +0,0 @@
-{{!
-* 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.
-}}
-
-<ul class="nav nav-tabs visualization-tabs">
-  {{#each tab in tabs}}
-      <li {{bind-attr class="tab.active:active"}} {{action 'selectTab' tab}}>
-        <a>{{tab.name}}</a>
-      </li>
-  {{/each}}
-</ul>
-
-<iframe {{bind-attr src=selectedTab.url}} id="visualization_frame" style="width:100%;height:1000px;border:0px;" allowfullscreen="true"></iframe>

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/databases-search-results.hbs
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/databases-search-results.hbs b/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/databases-search-results.hbs
deleted file mode 100644
index 8ff3895..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/databases-search-results.hbs
+++ /dev/null
@@ -1,54 +0,0 @@
-{{!
-* 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.
-}}
-
-{{#if tableSearchResults.tables}}
-  <div class="databases">
-    <a class="fa fa-database"> {{selectedDatabase.name}}</a>
-
-    <div class="tables">
-      {{#each table in tableSearchResults.tables}}
-        <a class="fa fa-th"> {{table.name}}</a>
-
-        <div class="columns">
-          {{#each column in table.columns}}
-            <div>
-              <strong>{{column.name}}</strong>
-              <span class="pull-right">{{column.type}}</span>
-            </div>
-          {{/each}}
-
-          {{#if table.hasNext}}
-            <strong><a {{action "showMoreResultColumns" table}}>{{t "buttons.loadMore"}}</a></strong>
-          {{/if}}
-        </div>
-      {{/each}}
-      {{#if tableSearchResults.hasNext}}
-        <strong><a {{action "showMoreResultTables" database}}>{{t "buttons.loadMore"}}</a></strong>
-      {{/if}}
-      {{#if showColumnsResultAlert}}
-        <div class="alert alert-warning database-explorer-alert" role="alert">
-          {{t "labels.noColumnsMatch"}} <strong>&quot;{{textColumnSearchTerm}}&quot;</strong>
-        </div>
-      {{/if}}
-    </div>
-  </div>
-{{else}}
-  <div class="alert alert-warning database-explorer-alert" role="alert">
-    {{t "labels.noTablesMatch"}} <strong>&quot;{{tablesSearchTerm}}&quot;</strong>
-  </div>
-{{/if}}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/databases-tree.hbs
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/databases-tree.hbs b/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/databases-tree.hbs
deleted file mode 100644
index 5023c40..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/databases-tree.hbs
+++ /dev/null
@@ -1,50 +0,0 @@
-{{!
-* 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.
-}}
-
-<div class="databases">
-  {{#each database in databases}}
-    {{#collapsible-widget heading=database.name isExpanded=database.isExpanded iconClass="fa-database" expanded="getTables" toggledParam=database}}
-      {{#if database.isExpanded}}
-        <div class="tables">
-          {{#each table in database.visibleTables}}
-            {{#collapsible-widget heading=table.name isExpanded=table.isExpanded toggledParam=database iconClass="fa-table" expanded="getColumns" controls=tableControls}}
-              {{#if table.isExpanded}}
-                <div class="columns">
-                  {{#each column in table.visibleColumns}}
-                    <div>
-                      <div class="column-name" {{bind-attr data-original-title=column.name}}
-                              data-toggle="tooltip" data-placement="top" title>{{column.name}}
-                      </div>
-                      <span class="pull-right widget-controls">{{format-column-type column}}</span>
-                    </div>
-                  {{/each}}
-                  {{#if table.canGetNextPage}}
-                    <strong><a {{action "showMoreColumns" table database}}>{{t "buttons.loadMore"}}</a></strong>
-                  {{/if}}
-                </div>
-              {{/if}}
-            {{/collapsible-widget}}
-          {{/each}}
-          {{#if database.canGetNextPage}}
-            <strong><a {{action "showMoreTables" database}}>{{t "buttons.loadMore"}}</a></strong>
-          {{/if}}
-        </div>
-      {{/if}}
-    {{/collapsible-widget}}
-  {{/each}}
-</div>

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/databases.hbs
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/databases.hbs b/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/databases.hbs
deleted file mode 100644
index 3997ea8..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/databases.hbs
+++ /dev/null
@@ -1,54 +0,0 @@
-{{!
-* 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.
-}}
-
-{{#panel-widget headingTranslation="titles.database" isLoading=isLoading classNames="database-explorer" iconActions=panelIconActions}}
-  {{#if databases}}
-
-    {{typeahead-widget
-        content=databases
-        optionValuePath="id"
-        optionLabelPath="name"
-        selection=selectedDatabase
-    }}
-
-    <hr />
-
-    {{#if selectedDatabase}}
-      {{extended-input class="form-control input-sm mozBoxSizeFix input-sm search-tables-text"
-                       placeholderTranslation="placeholders.search.tables"
-                       valueSearched="searchTables"
-                       value=tableSearchTerm}}
-
-      <hr />
-    {{/if}}
-
-
-    {{#if tableSearchResults.tables}}
-      {{extended-input class="form-control input-sm mozBoxSizeFix search-columns-text"
-                       placeholderTranslation="placeholders.search.columns"
-                       valueSearched="searchColumns"
-                       value=columnSearchTerm}}
-
-      <hr />
-    {{/if}}
-
-    {{#tabs-widget tabs=tabs selectedTab=selectedTab}}
-      {{partial selectedTab.view}}
-    {{/tabs-widget}}
-  {{/if}}
-{{/panel-widget}}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/history.hbs
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/history.hbs b/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/history.hbs
deleted file mode 100644
index 7121b85..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/history.hbs
+++ /dev/null
@@ -1,67 +0,0 @@
-{{!
-* 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.
-}}
-<table class="table table-expandable">
-    <thead>
-    <tr>
-        {{#each column in columns}}
-        <th>
-            {{#if column.caption}}
-            {{column-filter-widget class="pull-left"
-            column=column
-            filterValue=column.filterValue
-            sortAscending=controller.sortAscending
-            sortProperties=controller.sortProperties
-            columnSorted="sort"
-            columnFiltered="filterUpdated"}}
-            {{else}}
-            {{tb-helper "caption" column}}
-            {{/if}}
-        </th>
-        {{/each}}
-        <th>
-            <button type="btn" class="btn btn-primary btn-sm icon-refresh" {{action
-            "refreshJobs"}}><i class="fa fa-refresh" aria-hidden="true"></i>
-            {{t "buttons.refresh"}}</button>
-
-            <button type="btn" class="btn btn-sm btn-warning pull-right clear-filters" {{action
-            "clearFilters"}}>{{t "buttons.clearFilters"}}</button>
-        </th>
-    </tr>
-    </thead>
-    <tbody>
-    {{#if history.length}}
-    {{#if model.length}}
-    {{#each item in this}}
-    {{job-tr-view job=item onStopJob="interruptJob" onFileRequested="loadFile"}}
-    {{/each}}
-    {{else}}
-    <tr>
-        <td colspan="5">
-            <h4 class="empty-list">{{t "emptyList.history.noMatches"}}</h4>
-        </td>
-    </tr>
-    {{/if}}
-    {{else}}
-    <tr>
-        <td colspan="5">
-            <h4 class="empty-list">{{t "emptyList.history.noItems"}}</h4>
-        </td>
-    </tr>
-    {{/if}}
-    </tbody>
-</table>

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/index.hbs
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/index.hbs b/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/index.hbs
deleted file mode 100644
index b9e5a46..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/index.hbs
+++ /dev/null
@@ -1,134 +0,0 @@
-{{!
-* 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.
-}}
-<div id="uploadProgressModal" class="modal fade" role="dialog" data-backdrop="static">
-  <div class="modal-dialog">
-
-    <!-- Modal content-->
-    <div class="modal-content">
-      <div class="modal-header">
-        <h4 class="modal-title">{{t "hive.ui.uploadProgress"}}</h4>
-      </div>
-      <div class="modal-body">
-        <p>
-        <ul>
-          {{t "hive.ui.uploading"}}
-        </ul>
-        </p>
-      </div>
-    </div>
-
-  </div>
-</div>
-
-<div id="index-content">
-  <div class="main-content">
-    <aside {{bind-attr class="isDatabaseExplorerVisible:col-md-3:no-width :col-xs-3 :no-padding"}}>
-      {{render 'databases'}}
-    </aside>
-
-    <div {{bind-attr class="isDatabaseExplorerVisible:col-md-9:col-md-12 :col-xs-9 :query-container"}}>
-      {{#panel-widget headingTranslation="titles.query.editor" classNames="query-editor-panel" iconActions=queryPanelActions}}
-        {{render 'open-queries'}}
-
-        <div class="toolbox">
-          {{#if canExecute}}
-            <button type="button" class="btn btn-sm btn-success execute-query" {{action "executeQuery"}}>
-              {{t "buttons.execute"}}
-            </button>
-          {{else}}
-            <button type="button" {{bind-attr class=":btn :btn-sm :btn-warning model.isCancelling:disabled"}} {{action "stopCurrentJob"}}>
-              {{#if model.isCancelling}}
-                {{t "buttons.stoppingJob"}}
-                <div class="spinner small inline-spinner"></div>
-              {{else}}
-                {{t "buttons.stopJob"}}
-              {{/if}}
-            </button>
-          {{/if}}
-
-          <button type="button" {{bind-attr class=":btn :btn-sm :btn-default canExecute::disabled"}} {{action "explainQuery"}}>
-            {{t "buttons.explain"}}
-          </button>
-
-          <label for="upload">
-            <span {{bind-attr class=":btn :btn-sm :btn-default"}}>{{t "buttons.uploadQuery"}}</span>
-            {{upload-query filesUploaded="filesUploaded"}}
-          </label>
-
-          <button type="button" class="btn btn-sm btn-default save-query-as" {{action "saveQuery"}}>{{t "buttons.saveAs"}}</button>
-
-          {{render 'insert-udfs'}}
-
-          {{#if canKillSession}}
-            <button type="button" class="btn btn-sm btn-danger kill-session" {{action "killSession"}}>{{t "buttons.killSession"}}</button>
-          {{/if}}
-
-          <button type="button" class="btn btn-sm btn-primary  pull-right" {{action "addQuery"}}>{{t "buttons.newQuery"}}</button>
-        </div>
-      {{/panel-widget}}
-
-      {{#if displayJobTabs}}
-        {{#if jobProgressService.currentJob.stages.length}}
-          {{#progress-widget value=jobProgressService.currentJob.totalProgress}}
-          {{/progress-widget}}
-        {{/if}}
-      {{/if}}
-
-      {{#if queryParams}}
-        {{#panel-widget headingTranslation="titles.query.parameters"}}
-          <div class="form-horizontal">
-            {{#each param in queryParams}}
-              <div {{bind-attr class=":form-group param.value:has-success:has-error"}}>
-                <label class="col-sm-3 control-label">{{param.name}}</label>
-                  <div class="col-sm-9">
-                    {{input value=param.value placeholder="value" class="form-control"}}
-                  </div>
-              </div>
-            {{/each}}
-          </div>
-        {{/panel-widget}}
-      {{/if}}
-
-      {{#if displayJobTabs}}
-        {{#panel-widget heading=queryProcessTitle
-                        isLoading=content.isRunning
-                        menuItems=downloadMenu
-                        menuHeadingTranslation="titles.download"
-                        classNames="query-process-results-panel"}}
-          {{#tabs-widget tabs=queryProcessTabs selectedTab=selectedQueryProcessTab}}
-            {{outlet}}
-          {{/tabs-widget}}
-        {{/panel-widget}}
-      {{/if}}
-    </div>
-  </div>
-
-  {{outlet 'overlay'}}
-
-  <div class="query-menu">
-    {{#popover-widget classNames="fa fa-info-circle queries-icon" titleTranslation="popover.queryEditorHelp.title" }}
-      <ul>
-        <li>{{t 'popover.queryEditorHelp.content.line1'}}</li>
-        <li>{{t 'popover.queryEditorHelp.content.line2'}}</li>
-        <li>{{t 'popover.queryEditorHelp.content.line3'}}</li>
-      </ul>
-    {{/popover-widget}}
-
-    {{render 'query-tabs'}}
-  </div>
-</div>

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/index/history-query/explain.hbs
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/index/history-query/explain.hbs b/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/index/history-query/explain.hbs
deleted file mode 100644
index f7948e2..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/index/history-query/explain.hbs
+++ /dev/null
@@ -1,27 +0,0 @@
-{{!
-* 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.
-}}
-<pre class="explainprint">
-{{#each header in formattedExplain}}
-  {{#if header.text}}
-    <div>{{header.text}}</div>
-    {{#if header.contents.length }}
-      {{tree-view content=header.contents}}
-    {{/if}}
-  {{/if}}
-{{/each}}
-</pre>
\ No newline at end of file

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/index/history-query/logs.hbs
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/index/history-query/logs.hbs b/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/index/history-query/logs.hbs
deleted file mode 100644
index 283d929..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/index/history-query/logs.hbs
+++ /dev/null
@@ -1,19 +0,0 @@
-{{!
-* 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.
-}}
-
-{{log-helper model.log}}
\ No newline at end of file

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/index/history-query/results.hbs
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/index/history-query/results.hbs b/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/index/history-query/results.hbs
deleted file mode 100644
index 2b7dae9..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/index/history-query/results.hbs
+++ /dev/null
@@ -1,56 +0,0 @@
-{{!
-* 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.
-}}
-
-<div id="query-results">
-  {{#if results}}
-    <div class="query-results-tools">
-      {{extended-input type="text"
-                       class="pull-left input-sm form-control"
-                       placeholderTranslation='placeholders.search.results'
-                       valueChanged="filterResults"}}
-
-      <div class="pull-right">
-        <button type="button" {{action "getPreviousPage"}}
-                {{bind-attr class=":btn :btn-sm :btn-default disablePrevious:disabled"}}>{{t "buttons.previousPage"}}</button>
-        <button type="button" {{action "getNextPage"}}
-                {{bind-attr class=":btn :btn-sm :btn-default disableNext:disabled"}}>{{t "buttons.nextPage"}}</button>
-      </div>
-    </div>
-
-    <table class="table table-expandable">
-      <thead>
-        <tr>
-          {{#each column in formattedResults.columns}}
-            <th> {{column.name}} </th>
-          {{/each}}
-        </tr>
-      </thead>
-      <tbody>
-        {{#each row in formattedResults.rows}}
-          <tr>
-            {{#each item in row}}
-              <td>{{item}}</td>
-            {{/each}}
-          </tr>
-        {{/each}}
-      </tbody>
-    </table>
-  {{else}}
-    {{error}}
-  {{/if}}
-</div>
\ No newline at end of file

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/insert-udfs.hbs
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/insert-udfs.hbs b/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/insert-udfs.hbs
deleted file mode 100644
index f01104b..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/insert-udfs.hbs
+++ /dev/null
@@ -1,46 +0,0 @@
-{{!
-* 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.
-}}
-
-{{#if this.length}}
-  <div class="dropdown insert-udfs">
-    <a role="button" data-toggle="dropdown" class="btn btn-default btn-sm" data-target="#">
-      {{t "placeholders.select.udfs"}}
-      <span class="caret"></span>
-    </a>
-    <ul class="dropdown-menu pull-right" role="menu" aria-labelledby="dropdownMenu">
-      {{#each item in this}}
-        <li class="dropdown dropdown-submenu">
-          {{#if item.file}}
-            <a tabindex="-1">{{item.file.name}}</a>
-          {{else}}
-            <a tabindex="-1">{{tb-helper item.name}}</a>
-          {{/if}}
-          <ul class="dropdown-menu">
-            {{#each udf in item.udfs}}
-              <li>
-                {{#no-bubbling click="insertUdf" data=udf tagName="a"}}
-                  {{udf.name}}
-                {{/no-bubbling}}
-              </li>
-            {{/each}}
-          </ul>
-        </li>
-      {{/each}}
-    </ul>
-  </div>
-{{/if}}
\ No newline at end of file

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/loading.hbs
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/loading.hbs b/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/loading.hbs
deleted file mode 100644
index c0de275..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/loading.hbs
+++ /dev/null
@@ -1,19 +0,0 @@
-{{!
-* 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.
-}}
-
-<div class="spinner"></div>
\ No newline at end of file

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/logs.hbs
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/logs.hbs b/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/logs.hbs
deleted file mode 100644
index 283d929..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/logs.hbs
+++ /dev/null
@@ -1,19 +0,0 @@
-{{!
-* 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.
-}}
-
-{{log-helper model.log}}
\ No newline at end of file

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/message.hbs
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/message.hbs b/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/message.hbs
deleted file mode 100644
index ad7fb9a..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/message.hbs
+++ /dev/null
@@ -1,36 +0,0 @@
-{{!
-* 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.
-}}
-
-<div {{bind-attr class=":alert :notification view.typeClass"}}>
-  <button type="button" class="close" {{action "close" target="view"}}><span aria-hidden="true">&times;</span></button>
-  <i {{bind-attr class=":fa view.typeIcon"}}></i>
-
-  {{#if view.notification.body}}
-    <a {{action "expand" target="view"}}>
-      {{view.notification.message}}
-    </a>
-  {{else}}
-      {{view.notification.message}}
-  {{/if}}
-
-  {{#if view.isExpanded}}
-  <pre class="message-body">
-    {{preformatted-string view.notification.body}}
-  </pre>
-  {{/if}}
-</div>

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/messages.hbs
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/messages.hbs b/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/messages.hbs
deleted file mode 100644
index 3dfc7d0..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/messages.hbs
+++ /dev/null
@@ -1,32 +0,0 @@
-{{!
-* 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.
-}}
-
-<div id="messages" class="index-overlay">
-  {{#panel-widget headingTranslation="titles.query.messages"}}
-    <div class="messages-controls">
-      {{#if messages.length}}
-        <button class="btn btn-danger btn-xs" {{action 'removeAllMessages'}}><i class="fa fa-minus"></i> Clear All</button>
-      {{/if}}
-    </div>
-
-
-    {{#each message in messages}}
-      {{view 'message' notification=message}}
-    {{/each}}
-  {{/panel-widget}}
-</div>

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/modal-delete.hbs
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/modal-delete.hbs b/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/modal-delete.hbs
deleted file mode 100644
index 032c144..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/modal-delete.hbs
+++ /dev/null
@@ -1,21 +0,0 @@
-{{!
-* 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.
-}}
-
-{{#modal-widget heading=heading close="close" ok="delete"}}
-  {{tb-helper text}}
-{{/modal-widget}}
\ No newline at end of file

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/modal-save-query.hbs
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/modal-save-query.hbs b/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/modal-save-query.hbs
deleted file mode 100644
index 6853550..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/templates/modal-save-query.hbs
+++ /dev/null
@@ -1,24 +0,0 @@
-{{!
-* 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.
-}}
-
-{{#modal-widget heading=heading close="close" ok="save"}}
-  {{input type="text" class="form-control" value=text }}
-  {{#if showMessage}}
-    <span class="label label-warning">{{tb-helper message}}</span>
-  {{/if}}
-{{/modal-widget}}
\ No newline at end of file


[17/23] ambari git commit: AMBARI-19302 : removed contrib/views/hive folder and made necessary changes in pom.xml files (nitirajrathore)

Posted by ni...@apache.org.
http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/UploadFromHdfsInput.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/UploadFromHdfsInput.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/UploadFromHdfsInput.java
deleted file mode 100644
index af20aff..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/UploadFromHdfsInput.java
+++ /dev/null
@@ -1,130 +0,0 @@
-/**
- * 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
- * <p/>
- * http://www.apache.org/licenses/LICENSE-2.0
- * <p/>
- * 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.ambari.view.hive.resources.uploads;
-
-import java.io.Serializable;
-import java.util.List;
-
-public class UploadFromHdfsInput implements Serializable{
-  private Boolean isFirstRowHeader = Boolean.FALSE;
-  private String inputFileType;
-  private String hdfsPath;
-  private String tableName;
-  private String databaseName;
-  private List<ColumnDescriptionImpl> header;
-  private boolean containsEndlines;
-
-  private String csvDelimiter;
-  private String csvEscape;
-  private String csvQuote;
-
-  public UploadFromHdfsInput() {
-  }
-
-  public String getCsvDelimiter() {
-    return csvDelimiter;
-  }
-
-  public List<ColumnDescriptionImpl> getHeader() {
-    return header;
-  }
-
-  public void setHeader(List<ColumnDescriptionImpl> header) {
-    this.header = header;
-  }
-
-  public boolean isContainsEndlines() {
-    return containsEndlines;
-  }
-
-  public void setContainsEndlines(boolean containsEndlines) {
-    this.containsEndlines = containsEndlines;
-  }
-
-  public void setCsvDelimiter(String csvDelimiter) {
-    this.csvDelimiter = csvDelimiter;
-  }
-
-  public String getCsvEscape() {
-    return csvEscape;
-  }
-
-  public void setCsvEscape(String csvEscape) {
-    this.csvEscape = csvEscape;
-  }
-
-  public String getCsvQuote() {
-    return csvQuote;
-  }
-
-  public void setCsvQuote(String csvQuote) {
-    this.csvQuote = csvQuote;
-  }
-
-  public Boolean getIsFirstRowHeader() {
-    return isFirstRowHeader;
-  }
-
-  public void setIsFirstRowHeader(Boolean firstRowHeader) {
-    isFirstRowHeader = firstRowHeader;
-  }
-
-  public String getInputFileType() {
-    return inputFileType;
-  }
-
-  public void setInputFileType(String inputFileType) {
-    this.inputFileType = inputFileType;
-  }
-
-  public String getHdfsPath() {
-    return hdfsPath;
-  }
-
-  public void setHdfsPath(String hdfsPath) {
-    this.hdfsPath = hdfsPath;
-  }
-
-  public String getTableName() {
-    return tableName;
-  }
-
-  public void setTableName(String tableName) {
-    this.tableName = tableName;
-  }
-
-  public String getDatabaseName() {
-    return databaseName;
-  }
-
-  public void setDatabaseName(String databaseName) {
-    this.databaseName = databaseName;
-  }
-
-  @Override
-  public String toString() {
-    return new StringBuilder("UploadFromHdfsInput{" )
-            .append("isFirstRowHeader=").append( isFirstRowHeader )
-            .append(", inputFileType='" ).append(inputFileType)
-            .append(", hdfsPath='").append(hdfsPath)
-            .append(", tableName='").append( tableName )
-            .append(", databaseName='").append(databaseName )
-            .append('}').toString();
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/UploadService.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/UploadService.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/UploadService.java
deleted file mode 100644
index 2dceadf..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/UploadService.java
+++ /dev/null
@@ -1,556 +0,0 @@
-/**
- * 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
- * <p/>
- * http://www.apache.org/licenses/LICENSE-2.0
- * <p/>
- * 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.ambari.view.hive.resources.uploads;
-
-import com.sun.jersey.core.header.FormDataContentDisposition;
-import com.sun.jersey.multipart.FormDataParam;
-import org.apache.ambari.view.hive.BaseService;
-import org.apache.ambari.view.hive.persistence.utils.ItemNotFound;
-import org.apache.ambari.view.hive.resources.jobs.viewJobs.Job;
-import org.apache.ambari.view.hive.resources.jobs.viewJobs.JobController;
-import org.apache.ambari.view.hive.resources.jobs.viewJobs.JobImpl;
-import org.apache.ambari.view.hive.resources.jobs.viewJobs.JobResourceManager;
-import org.apache.ambari.view.hive.resources.uploads.parsers.DataParser;
-import org.apache.ambari.view.hive.resources.uploads.parsers.ParseOptions;
-import org.apache.ambari.view.hive.resources.uploads.parsers.PreviewData;
-import org.apache.ambari.view.hive.resources.uploads.query.DeleteQueryInput;
-import org.apache.ambari.view.hive.resources.uploads.query.InsertFromQueryInput;
-import org.apache.ambari.view.hive.resources.uploads.query.QueryGenerator;
-import org.apache.ambari.view.hive.resources.uploads.query.TableInfo;
-import org.apache.ambari.view.hive.utils.ServiceFormattedException;
-import org.apache.ambari.view.hive.utils.SharedObjectsFactory;
-import org.apache.ambari.view.utils.ambari.AmbariApi;
-import org.apache.commons.io.ByteOrderMark;
-import org.apache.commons.io.input.BOMInputStream;
-import org.apache.commons.io.input.ReaderInputStream;
-import org.apache.hadoop.fs.FSDataInputStream;
-import org.apache.hadoop.fs.FSDataOutputStream;
-import org.codehaus.jackson.map.ObjectMapper;
-import org.codehaus.jackson.type.TypeReference;
-import org.json.simple.JSONObject;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-import javax.ws.rs.Consumes;
-import javax.ws.rs.POST;
-import javax.ws.rs.Path;
-import javax.ws.rs.Produces;
-import javax.ws.rs.WebApplicationException;
-import javax.ws.rs.core.MediaType;
-import javax.ws.rs.core.Response;
-import java.io.File;
-import java.io.IOException;
-import java.io.InputStream;
-import java.io.InputStreamReader;
-import java.io.Reader;
-import java.lang.reflect.InvocationTargetException;
-import java.util.HashMap;
-import java.util.List;
-import java.util.Map;
-
-/**
- * UI driven end points for creation of new hive table and inserting data into it.
- * It uploads a file, parses it partially based on its type, generates preview,
- * creates temporary hive table for storage as CSV and actual hive table,
- * uploads the file again, parses it, create CSV stream and upload to hdfs in temporary table,
- * insert rows from temporary table to actual table, delete temporary table.
- * <p/>
- * API:
- * POST /preview : takes stream, parses it and returns preview rows, headers and column type suggestions
- * POST /createTable : runs hive query to create table in hive
- * POST /upload : takes stream, parses it and converts it into CSV and uploads it to the temporary table
- * POST /insertIntoTable : runs hive query to insert data from temporary table to actual hive table
- * POST /deleteTable : deletes the temporary table
- */
-public class UploadService extends BaseService {
-
-  private final static Logger LOG =
-    LoggerFactory.getLogger(UploadService.class);
-
-  private AmbariApi ambariApi;
-  protected JobResourceManager resourceManager;
-
-  final private static String HIVE_METASTORE_LOCATION_KEY = "hive.metastore.warehouse.dir";
-  final private static String HIVE_SITE = "hive-site";
-  final private static String HIVE_METASTORE_LOCATION_KEY_VIEW_PROPERTY = HIVE_METASTORE_LOCATION_KEY;
-  private static final String HIVE_DEFAULT_METASTORE_LOCATION = "/apps/hive/warehouse";
-  final private static String HIVE_DEFAULT_DB = "default";
-
-  public void validateForUploadFile(UploadFromHdfsInput input){
-    if( null == input.getInputFileType()){
-      throw new IllegalArgumentException("inputFileType parameter cannot be null.");
-    }
-    if( null == input.getHdfsPath()){
-      throw new IllegalArgumentException("hdfsPath parameter cannot be null.");
-    }
-    if( null == input.getTableName()){
-      throw new IllegalArgumentException("tableName parameter cannot be null.");
-    }
-    if( null == input.getDatabaseName()){
-      throw new IllegalArgumentException("databaseName parameter cannot be null.");
-    }
-
-    if( input.getIsFirstRowHeader() == null ){
-      input.setIsFirstRowHeader(false);
-    }
-  }
-
-  public void validateForPreview(UploadFromHdfsInput input){
-    if( input.getIsFirstRowHeader() == null ){
-      input.setIsFirstRowHeader(false);
-    }
-
-    if( null == input.getInputFileType()){
-      throw new IllegalArgumentException("inputFileType parameter cannot be null.");
-    }
-    if( null == input.getHdfsPath()){
-      throw new IllegalArgumentException("hdfsPath parameter cannot be null.");
-    }
-  }
-
-  @POST
-  @Path("/previewFromHdfs")
-  @Consumes(MediaType.APPLICATION_JSON)
-  @Produces(MediaType.APPLICATION_JSON)
-  public Response uploadForPreviewFromHDFS(UploadFromHdfsInput input) {
-    InputStream uploadedInputStream = null;
-    try {
-      uploadedInputStream = getHDFSFileStream(input.getHdfsPath());
-      this.validateForPreview(input);
-      CSVParams csvParams = getCsvParams(input.getCsvDelimiter(), input.getCsvQuote(), input.getCsvEscape());
-      PreviewData pd = generatePreview(input.getIsFirstRowHeader(), input.getInputFileType(), csvParams, uploadedInputStream);
-      String tableName = getBasenameFromPath(input.getHdfsPath());
-      return createPreviewResponse(pd, input.getIsFirstRowHeader(), tableName);
-    } catch (WebApplicationException e) {
-      LOG.error(getErrorMessage(e), e);
-      throw e;
-    } catch (Exception e) {
-      LOG.error(e.getMessage(), e);
-      throw new ServiceFormattedException(e);
-    } finally {
-      if (null != uploadedInputStream) {
-        try {
-          uploadedInputStream.close();
-        } catch (IOException e) {
-          LOG.error("Exception occured while closing the HDFS file stream for path " + input.getHdfsPath(), e);
-        }
-      }
-    }
-  }
-
-  @POST
-  @Path("/preview")
-  @Consumes(MediaType.MULTIPART_FORM_DATA)
-  public Response uploadForPreview(
-    @FormDataParam("file") InputStream uploadedInputStream,
-    @FormDataParam("file") FormDataContentDisposition fileDetail,
-    @FormDataParam("isFirstRowHeader") Boolean isFirstRowHeader,
-    @FormDataParam("inputFileType") String inputFileType,
-    @FormDataParam("csvDelimiter") String csvDelimiter,
-    @FormDataParam("csvEscape") String csvEscape,
-    @FormDataParam("csvQuote") String csvQuote
-  ) {
-    try {
-      if( null == inputFileType)
-        throw new IllegalArgumentException("inputFileType parameter cannot be null.");
-
-      if( null == isFirstRowHeader )
-        isFirstRowHeader = false;
-
-      CSVParams csvParams = getCsvParams(csvDelimiter, csvQuote, csvEscape);
-
-      PreviewData pd = generatePreview(isFirstRowHeader, inputFileType, csvParams, uploadedInputStream);
-      return createPreviewResponse(pd, isFirstRowHeader, getBasename(fileDetail.getFileName()));
-    } catch (WebApplicationException e) {
-      LOG.error(getErrorMessage(e), e);
-      throw e;
-    } catch (Exception e) {
-      LOG.error(e.getMessage(), e);
-      throw new ServiceFormattedException(e);
-    }
-  }
-
-  private CSVParams getCsvParams(String csvDelimiter, String csvQuote, String csvEscape) {
-    char csvq =  CSVParams.DEFAULT_QUOTE_CHAR;
-    char csvd =  CSVParams.DEFAULT_DELIMITER_CHAR;
-    char csve =  CSVParams.DEFAULT_ESCAPE_CHAR;
-
-    if(null != csvDelimiter){
-      char[] csvdArray = csvDelimiter.toCharArray();
-      if(csvdArray.length > 0 ) {
-        csvd = csvdArray[0];
-      }
-    }
-
-    if(null != csvQuote){
-      char[] csvqArray = csvQuote.toCharArray();
-      if(csvqArray.length > 0 ) {
-        csvq = csvqArray[0];
-      }
-    }
-
-    if(null != csvEscape){
-      char[] csveArray = csvEscape.toCharArray();
-      if(csveArray.length > 0 ) {
-        csve = csveArray[0];
-      }
-    }
-
-    return new CSVParams(csvd, csvq, csve);
-  }
-
-
-  @Path("/createTable")
-  @POST
-  @Consumes(MediaType.APPLICATION_JSON)
-  @Produces(MediaType.APPLICATION_JSON)
-  public Response createTable(TableInput tableInput) {
-    try {
-      tableInput.validate();
-      String databaseName = tableInput.getDatabaseName();
-      String tableCreationQuery = generateCreateQuery(tableInput);
-      LOG.info("tableCreationQuery : {}", tableCreationQuery);
-
-      Job job = createJob(tableCreationQuery, databaseName);
-      LOG.info("job created for table creation {}", job);
-      return Response.ok(job).build();
-    } catch (WebApplicationException e) {
-      LOG.error(getErrorMessage(e), e);
-      throw e;
-    } catch (Exception e) {
-      LOG.error(e.getMessage(), e);
-      throw new ServiceFormattedException(e);
-    }
-  }
-
-  @Path("/uploadFromHDFS")
-  @POST
-  @Consumes(MediaType.APPLICATION_JSON)
-  @Produces(MediaType.APPLICATION_JSON)
-  public Response uploadFileFromHdfs(UploadFromHdfsInput input) {
-    // create stream and upload
-    InputStream hdfsStream = null;
-    try {
-      hdfsStream = getHDFSFileStream(input.getHdfsPath());
-      CSVParams csvParams = getCsvParams(input.getCsvDelimiter(), input.getCsvQuote(), input.getCsvEscape());
-      String path = uploadFileFromStream(hdfsStream, input.getIsFirstRowHeader(), input.getInputFileType(), input.getTableName(), input.getDatabaseName(), input.getHeader(), input.isContainsEndlines(), csvParams);
-
-      JSONObject jo = new JSONObject();
-      jo.put("uploadedPath", path);
-
-      return Response.ok(jo).build();
-    } catch (WebApplicationException e) {
-      LOG.error(getErrorMessage(e), e);
-      throw e;
-    } catch (Exception e) {
-      LOG.error(e.getMessage(), e);
-      throw new ServiceFormattedException(e);
-    } finally {
-      if (null != hdfsStream)
-        try {
-          hdfsStream.close();
-        } catch (IOException e) {
-          LOG.error("Exception occured while closing the HDFS stream for path : " + input.getHdfsPath(), e);
-        }
-    }
-  }
-
-  @Path("/upload")
-  @POST
-  @Consumes(MediaType.MULTIPART_FORM_DATA)
-  @Produces(MediaType.APPLICATION_JSON)
-  public Response uploadFile(
-    @FormDataParam("file") InputStream uploadedInputStream,
-    @FormDataParam("file") FormDataContentDisposition fileDetail,
-    @FormDataParam("isFirstRowHeader") Boolean isFirstRowHeader,
-    @FormDataParam("inputFileType") String inputFileType,   // the format of the file uploaded. CSV/JSON etc.
-    @FormDataParam("tableName") String tableName,
-    @FormDataParam("databaseName") String databaseName,
-    @FormDataParam("header") String header,
-    @FormDataParam("containsEndlines") boolean containsEndlines,
-    @FormDataParam("csvDelimiter") String csvDelimiter,
-    @FormDataParam("csvEscape") String csvEscape,
-    @FormDataParam("csvQuote") String csvQuote
-
-  ) {
-    try {
-      CSVParams csvParams = getCsvParams(csvDelimiter, csvQuote, csvEscape);
-      ObjectMapper mapper = new ObjectMapper();
-      List<ColumnDescriptionImpl> columnList = mapper.readValue(header, new TypeReference<List<ColumnDescriptionImpl>>(){});
-      String path = uploadFileFromStream(uploadedInputStream, isFirstRowHeader, inputFileType, tableName, databaseName, columnList, containsEndlines, csvParams);
-
-      JSONObject jo = new JSONObject();
-      jo.put("uploadedPath", path);
-      return Response.ok(jo).build();
-    } catch (WebApplicationException e) {
-      LOG.error(getErrorMessage(e), e);
-      throw e;
-    } catch (Exception e) {
-      LOG.error(e.getMessage(), e);
-      throw new ServiceFormattedException(e);
-    }
-  }
-
-  @Path("/insertIntoTable")
-  @POST
-  @Consumes(MediaType.APPLICATION_JSON)
-  @Produces(MediaType.APPLICATION_JSON)
-  public Response insertFromTempTable(InsertFromQueryInput input) {
-    try {
-      String insertQuery = generateInsertFromQuery(input);
-      LOG.info("insertQuery : {}", insertQuery);
-
-      Job job = createJob(insertQuery, "default");
-      LOG.info("Job created for insert from temp table : {}", job);
-      return Response.ok(job).build();
-    } catch (WebApplicationException e) {
-      LOG.error(getErrorMessage(e), e);
-      throw e;
-    } catch (Exception e) {
-      LOG.error(e.getMessage(), e);
-      throw new ServiceFormattedException(e);
-    }
-  }
-
-  @Path("/deleteTable")
-  @POST
-  @Consumes(MediaType.APPLICATION_JSON)
-  @Produces(MediaType.APPLICATION_JSON)
-  public Response deleteTable(DeleteQueryInput input) {
-    try {
-      String deleteQuery = generateDeleteQuery(input);
-      LOG.info("deleteQuery : {}", deleteQuery);
-
-      Job job = createJob(deleteQuery, "default");
-      LOG.info("Job created for delete temp table : {} ", job);
-      return Response.ok(job).build();
-    } catch (WebApplicationException e) {
-      LOG.error(getErrorMessage(e), e);
-      throw e;
-    } catch (Exception e) {
-      LOG.error(e.getMessage(), e);
-      throw new ServiceFormattedException(e);
-    }
-  }
-
-  private String uploadIntoTable(Reader reader, String databaseName, String tempTableName) {
-    try {
-      String basePath = getHiveMetaStoreLocation();
-
-      if (!basePath.endsWith("/")) {
-        basePath = basePath + "/";
-      }
-
-      if (databaseName != null && !databaseName.equals(HIVE_DEFAULT_DB)) {
-        basePath = basePath + databaseName + ".db/";
-      }
-
-      String fullPath = basePath + tempTableName + "/" + tempTableName + ".csv";
-
-      LOG.info("Uploading file into : {}", fullPath);
-
-      uploadFile(fullPath, new ReaderInputStream(reader));
-
-      return fullPath;
-    } catch (WebApplicationException e) {
-      LOG.error(getErrorMessage(e), e);
-      throw e;
-    } catch (Exception e) {
-      LOG.error(e.getMessage(), e);
-      throw new ServiceFormattedException(e);
-    }
-  }
-
-  private synchronized JobResourceManager getResourceManager() {
-    if (resourceManager == null) {
-      SharedObjectsFactory connectionsFactory = getSharedObjectsFactory();
-      resourceManager = new JobResourceManager(connectionsFactory, context);
-    }
-    return resourceManager;
-  }
-
-  private synchronized AmbariApi getAmbariApi() {
-    if (null == ambariApi) {
-      ambariApi = new AmbariApi(this.context);
-    }
-    return ambariApi;
-  }
-
-  private String generateCreateQuery(TableInfo ti) {
-    return new QueryGenerator().generateCreateQuery(ti);
-  }
-
-  private String generateInsertFromQuery(InsertFromQueryInput input) {
-    return new QueryGenerator().generateInsertFromQuery(input);
-  }
-
-  private String generateDeleteQuery(DeleteQueryInput deleteQueryInput) {
-    return new QueryGenerator().generateDropTableQuery(deleteQueryInput);
-  }
-
-  private Job createJob(String query, String databaseName) throws InvocationTargetException, IllegalAccessException, ItemNotFound {
-    Map jobInfo = new HashMap<>();
-    jobInfo.put("title", "Internal Job");
-    jobInfo.put("forcedContent", query);
-    jobInfo.put("dataBase", databaseName);
-
-    Job job = new JobImpl(jobInfo);
-    LOG.info("creating job : {}", job);
-    getResourceManager().create(job);
-
-    JobController createdJobController = getResourceManager().readController(job.getId());
-    createdJobController.submit();
-    getResourceManager().saveIfModified(createdJobController);
-
-    return job;
-  }
-
-  private String getHiveMetaStoreLocation() {
-    String dir = context.getProperties().get(HIVE_METASTORE_LOCATION_KEY_VIEW_PROPERTY);
-    if (dir != null && !dir.trim().isEmpty()) {
-      return dir;
-    } else {
-      LOG.debug("Neither found associated cluster nor found the view property {}. Returning default location : {}", HIVE_METASTORE_LOCATION_KEY_VIEW_PROPERTY, HIVE_DEFAULT_METASTORE_LOCATION);
-      return HIVE_DEFAULT_METASTORE_LOCATION;
-    }
-  }
-
-  private void uploadFile(final String filePath, InputStream uploadedInputStream)
-    throws IOException, InterruptedException {
-    byte[] chunk = new byte[1024];
-    FSDataOutputStream out = getSharedObjectsFactory().getHdfsApi().create(filePath, false);
-    int n = -1;
-    while ((n = uploadedInputStream.read(chunk)) != -1) {
-      out.write(chunk, 0, n);
-    }
-    out.close();
-  }
-
-  private static String getErrorMessage(WebApplicationException e) {
-    if (null != e.getResponse() && null != e.getResponse().getEntity())
-      return e.getResponse().getEntity().toString();
-    else return e.getMessage();
-  }
-
-  private PreviewData generatePreview(Boolean isFirstRowHeader, String inputFileType, CSVParams csvParams, InputStream uploadedInputStream) throws Exception {
-    ParseOptions parseOptions = new ParseOptions();
-    parseOptions.setOption(ParseOptions.OPTIONS_FILE_TYPE, inputFileType);
-    if (inputFileType.equals(ParseOptions.InputFileType.CSV.toString())){
-      if(isFirstRowHeader)
-        parseOptions.setOption(ParseOptions.OPTIONS_HEADER, ParseOptions.HEADER.FIRST_RECORD.toString());
-      else
-        parseOptions.setOption(ParseOptions.OPTIONS_HEADER, ParseOptions.HEADER.NONE.toString());
-
-      parseOptions.setOption(ParseOptions.OPTIONS_CSV_DELIMITER, csvParams.getCsvDelimiter());
-      parseOptions.setOption(ParseOptions.OPTIONS_CSV_ESCAPE_CHAR, csvParams.getCsvEscape());
-      parseOptions.setOption(ParseOptions.OPTIONS_CSV_QUOTE, csvParams.getCsvQuote());
-    }
-    else
-      parseOptions.setOption(ParseOptions.OPTIONS_HEADER, ParseOptions.HEADER.EMBEDDED.toString());
-
-    LOG.info("isFirstRowHeader : {}, inputFileType : {}", isFirstRowHeader, inputFileType);
-
-    Reader reader = getInputStreamReader(uploadedInputStream);
-    DataParser dataParser = new DataParser(reader, parseOptions);
-
-    return dataParser.parsePreview();
-  }
-
-  private Response createPreviewResponse(PreviewData pd, Boolean isFirstRowHeader, String tableName) {
-    Map<String, Object> retData = new HashMap<>();
-    retData.put("header", pd.getHeader());
-    retData.put("rows", pd.getPreviewRows());
-    retData.put("isFirstRowHeader", isFirstRowHeader);
-    retData.put("tableName", tableName);
-
-    JSONObject jsonObject = new JSONObject(retData);
-    return Response.ok(jsonObject).build();
-  }
-
-  private InputStream getHDFSFileStream(String path) throws IOException, InterruptedException {
-    FSDataInputStream fsStream = getSharedObjectsFactory().getHdfsApi().open(path);
-    return fsStream;
-  }
-
-  private String uploadFileFromStream(
-    InputStream uploadedInputStream,
-    Boolean isFirstRowHeader,
-    String inputFileType,   // the format of the file uploaded. CSV/JSON etc.
-    String tableName,
-    String databaseName,
-    List<ColumnDescriptionImpl> header,
-    boolean containsEndlines,
-    CSVParams csvParams
-  ) throws Exception {
-    LOG.info(" uploading file into databaseName {}, tableName {}", databaseName, tableName);
-    ParseOptions parseOptions = new ParseOptions();
-    parseOptions.setOption(ParseOptions.OPTIONS_FILE_TYPE, inputFileType);
-    if(isFirstRowHeader){
-      parseOptions.setOption(ParseOptions.OPTIONS_HEADER, ParseOptions.HEADER.FIRST_RECORD.toString());
-    }else{
-      parseOptions.setOption(ParseOptions.OPTIONS_HEADER, ParseOptions.HEADER.NONE.toString());
-    }
-
-    if(null != csvParams){
-      parseOptions.setOption(ParseOptions.OPTIONS_CSV_DELIMITER, csvParams.getCsvDelimiter());
-      parseOptions.setOption(ParseOptions.OPTIONS_CSV_ESCAPE_CHAR, csvParams.getCsvEscape());
-      parseOptions.setOption(ParseOptions.OPTIONS_CSV_QUOTE, csvParams.getCsvQuote());
-    }
-
-    Reader reader = getInputStreamReader(uploadedInputStream);
-    DataParser dataParser = new DataParser(reader, parseOptions);
-
-    Reader csvReader = new TableDataReader(dataParser.iterator(), header, containsEndlines); // encode column values into HEX so that \n etc dont appear in the hive table data
-    String path = uploadIntoTable(csvReader, databaseName, tableName);
-    return path;
-  }
-
-  /**
-   * takes care of any BOM in the stream
-   * @param is : the input stream
-   * @return : the reader from the stream
-   * @throws IOException
-   */
-  private Reader getInputStreamReader(InputStream is) throws IOException {
-    BOMInputStream bomInputStream = new BOMInputStream(is,
-      ByteOrderMark.UTF_8, ByteOrderMark.UTF_16LE, ByteOrderMark.UTF_16BE,
-      ByteOrderMark.UTF_32LE, ByteOrderMark.UTF_32BE
-    );
-    if(bomInputStream.hasBOM()){
-      String charSetName = bomInputStream.getBOMCharsetName();
-      return new InputStreamReader(bomInputStream, charSetName); // return with the encoded charset encoding.
-    }else{
-      return new InputStreamReader(bomInputStream); //return with default charset
-    }
-  }
-
-  private String getBasenameFromPath(String path) {
-    String fileName = new File(path).getName();
-    return getBasename(fileName);
-  }
-
-  private String getBasename(String fileName) {
-    int index = fileName.indexOf(".");
-    if (index != -1) {
-      return fileName.substring(0, index);
-    }
-
-    return fileName;
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/parsers/DataParser.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/parsers/DataParser.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/parsers/DataParser.java
deleted file mode 100644
index fe2c740..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/parsers/DataParser.java
+++ /dev/null
@@ -1,66 +0,0 @@
-/**
- * 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
- * <p/>
- * http://www.apache.org/licenses/LICENSE-2.0
- * <p/>
- * 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.ambari.view.hive.resources.uploads.parsers;
-
-import org.apache.ambari.view.hive.client.Row;
-import org.apache.ambari.view.hive.resources.uploads.parsers.csv.opencsv.OpenCSVParser;
-import org.apache.ambari.view.hive.resources.uploads.parsers.json.JSONParser;
-import org.apache.ambari.view.hive.resources.uploads.parsers.xml.XMLParser;
-
-import java.io.Reader;
-import java.util.Iterator;
-
-/**
- * Wrapper/Decorator over the Stream parsers.
- * Supports XML/JSON/CSV parsing.
- */
-public class DataParser implements IParser {
-
-  private IParser parser;
-
-  public DataParser(Reader reader, ParseOptions parseOptions) throws Exception {
-    if (parseOptions.getOption(ParseOptions.OPTIONS_FILE_TYPE).equals(ParseOptions.InputFileType.CSV.toString())) {
-      parser = new OpenCSVParser(reader, parseOptions);
-    } else if (parseOptions.getOption(ParseOptions.OPTIONS_FILE_TYPE).equals(ParseOptions.InputFileType.JSON.toString())) {
-      parser = new JSONParser(reader, parseOptions);
-    } else if (parseOptions.getOption(ParseOptions.OPTIONS_FILE_TYPE).equals(ParseOptions.InputFileType.XML.toString())) {
-      parser = new XMLParser(reader, parseOptions);
-    }
-  }
-
-  @Override
-  public PreviewData parsePreview() {
-    return parser.parsePreview();
-  }
-
-  @Override
-  public Row extractHeader() {
-    return parser.extractHeader();
-  }
-
-  @Override
-  public void close() throws Exception {
-    parser.close();
-  }
-
-  @Override
-  public Iterator<Row> iterator() {
-    return parser.iterator();
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/parsers/EndOfDocumentException.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/parsers/EndOfDocumentException.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/parsers/EndOfDocumentException.java
deleted file mode 100644
index 6bbe303..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/parsers/EndOfDocumentException.java
+++ /dev/null
@@ -1,41 +0,0 @@
-/**
- * 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
- * <p/>
- * http://www.apache.org/licenses/LICENSE-2.0
- * <p/>
- * 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.ambari.view.hive.resources.uploads.parsers;
-
-
-public class EndOfDocumentException extends Exception {
-  public EndOfDocumentException() {
-  }
-
-  public EndOfDocumentException(String message) {
-    super(message);
-  }
-
-  public EndOfDocumentException(String message, Throwable cause) {
-    super(message, cause);
-  }
-
-  public EndOfDocumentException(Throwable cause) {
-    super(cause);
-  }
-
-  public EndOfDocumentException(String message, Throwable cause, boolean enableSuppression, boolean writableStackTrace) {
-    super(message, cause, enableSuppression, writableStackTrace);
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/parsers/IParser.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/parsers/IParser.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/parsers/IParser.java
deleted file mode 100644
index 4f4dc37..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/parsers/IParser.java
+++ /dev/null
@@ -1,32 +0,0 @@
-/**
- * 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
- * <p/>
- * http://www.apache.org/licenses/LICENSE-2.0
- * <p/>
- * 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.ambari.view.hive.resources.uploads.parsers;
-
-import org.apache.ambari.view.hive.client.Row;
-
-/**
- * Interface defining methods for Parsers that can used for generating preview
- * and uploading table into hive.
- */
-public interface IParser extends Iterable<Row>, AutoCloseable{
-
-  PreviewData parsePreview();
-
-  Row extractHeader();
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/parsers/ParseOptions.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/parsers/ParseOptions.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/parsers/ParseOptions.java
deleted file mode 100644
index 3db4813..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/parsers/ParseOptions.java
+++ /dev/null
@@ -1,61 +0,0 @@
-/**
- * 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
- * <p/>
- * http://www.apache.org/licenses/LICENSE-2.0
- * <p/>
- * 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.ambari.view.hive.resources.uploads.parsers;
-
-import java.util.HashMap;
-
-public class ParseOptions {
-  public static final String OPTIONS_CSV_DELIMITER = "OPTIONS_CSV_DELIMITER";
-  public static final String OPTIONS_CSV_QUOTE = "OPTIONS_CSV_QUOTE";
-  public static final String OPTIONS_HEADERS = "OPTIONS_HEADERS";
-  public static final String OPTIONS_CSV_ESCAPE_CHAR = "OPTIONS_CSV_ESCAPE_CHAR";
-
-  public enum InputFileType {
-    CSV,
-    JSON,
-    XML
-  }
-
-  public enum HEADER {
-    FIRST_RECORD,
-    PROVIDED_BY_USER, // not used right now but can be used when some metadata of file provide this information
-    EMBEDDED, // this one is for JSON/ XML and may be other file formats where its embedded with the data
-    NONE   // if the file does not contain header information at all
-  }
-  final public static String OPTIONS_FILE_TYPE = "FILE_TYPE";
-  final public static String OPTIONS_HEADER = "HEADER";
-  final public static String OPTIONS_NUMBER_OF_PREVIEW_ROWS = "NUMBER_OF_PREVIEW_ROWS";
-
-  private HashMap<String, Object> options = new HashMap<>();
-
-  public void setOption(String key, Object value) {
-    this.options.put(key, value);
-  }
-
-  public Object getOption(String key) {
-    return this.options.get(key);
-  }
-
-  @Override
-  public String toString() {
-    return new StringBuilder("ParseOptions{")
-      .append("options=").append(options)
-      .append('}').toString();
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/parsers/ParseUtils.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/parsers/ParseUtils.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/parsers/ParseUtils.java
deleted file mode 100644
index 10b042a..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/parsers/ParseUtils.java
+++ /dev/null
@@ -1,213 +0,0 @@
-/**
- * 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
- * <p/>
- * http://www.apache.org/licenses/LICENSE-2.0
- * <p/>
- * 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.ambari.view.hive.resources.uploads.parsers;
-
-import org.apache.directory.api.util.Strings;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-import java.sql.Timestamp;
-import java.text.SimpleDateFormat;
-import java.util.Date;
-import java.util.List;
-
-import static org.apache.ambari.view.hive.client.ColumnDescription.DataTypes;
-
-public class ParseUtils {
-
-  protected final static Logger LOG =
-    LoggerFactory.getLogger(ParseUtils.class);
-
-  final public static DataTypes[] dataTypeList = {DataTypes.BOOLEAN, DataTypes.INT, DataTypes.BIGINT, DataTypes.DOUBLE, DataTypes.CHAR, DataTypes.TIMESTAMP, DataTypes.DATE, DataTypes.STRING};
-  private static final String HIVE_DATE_FORMAT = "yyyy-MM-dd";
-
-  // no strict checking required as it is done by Date parsing
-  private static final String HIVE_DATE_FORMAT_REGEX = "^[0-9]{4}-[0-9]?[0-9]-[0-9]?[0-9]$";
-
-
-  public static boolean isInteger(Object object) {
-    if (object == null)
-      return false;
-
-    if (object instanceof Integer)
-      return true;
-
-    try {
-      Integer i = Integer.parseInt(object.toString());
-      return true;
-    } catch (NumberFormatException nfe) {
-      return false;
-    }
-  }
-
-  public static boolean isBoolean(Object object) {
-    if (object == null)
-      return false;
-
-    if (object instanceof Boolean)
-      return true;
-
-    String strValue = object.toString();
-    return strValue.equalsIgnoreCase("true") || strValue.equalsIgnoreCase("false");
-  }
-
-  public static boolean isString(Object object) {
-    return object != null;
-  }
-
-  public static boolean isLong(Object object) {
-    if (object == null)
-      return false;
-
-    if (object instanceof Long)
-      return true;
-
-    try {
-      Long i = Long.parseLong(object.toString());
-      return true;
-    } catch (Exception nfe) {
-      return false;
-    }
-  }
-
-  public static boolean isDouble(Object object) {
-    if (object == null)
-      return false;
-
-    if (object instanceof Double)
-      return true;
-
-    try {
-      Double i = Double.parseDouble(object.toString());
-      return true;
-    } catch (Exception nfe) {
-      return false;
-    }
-  }
-
-  public static boolean isChar(Object object) {
-    if (object == null)
-      return false;
-
-    if (object instanceof Character)
-      return true;
-
-    String str = object.toString().trim();
-    return str.length() == 1;
-
-  }
-
-  public static boolean isDate(Object object) {
-    if (object == null)
-      return false;
-
-    if (object instanceof Date)
-      return true;
-
-    String str = object.toString();
-    if (Strings.isNotEmpty(str)) {
-      str = str.trim();
-      if (str.matches(HIVE_DATE_FORMAT_REGEX)) {
-        try {
-          SimpleDateFormat sdf = new SimpleDateFormat(HIVE_DATE_FORMAT);
-          sdf.setLenient(false);
-          Date date = sdf.parse(str);
-          return true;
-        } catch (Exception e) {
-          LOG.debug("error while parsing as date string {}, format {}", str, HIVE_DATE_FORMAT, e);
-        }
-      }
-    }
-    return false;
-  }
-
-  public static boolean isTimeStamp(Object object) {
-    if (object == null)
-      return false;
-
-    if (object instanceof Date)
-      return true;
-
-    String str = object.toString();
-    try {
-      Timestamp ts = Timestamp.valueOf(str);
-      return true;
-    } catch (Exception e) {
-      LOG.debug("error while parsing as timestamp string {}", str, e);
-    }
-
-    return false;
-  }
-
-  public static DataTypes detectHiveDataType(Object object) {
-    // detect Integer
-    if (isBoolean(object)) return DataTypes.BOOLEAN;
-    if (isInteger(object)) return DataTypes.INT;
-    if (isLong(object)) return DataTypes.BIGINT;
-    if (isDouble(object)) return DataTypes.DOUBLE;
-    if (isChar(object)) return DataTypes.CHAR;
-    if (isTimeStamp(object)) return DataTypes.TIMESTAMP;
-    if (isDate(object)) return DataTypes.DATE;
-
-    return DataTypes.STRING;
-  }
-
-  public static boolean checkDatatype( Object object, DataTypes datatype){
-    switch(datatype){
-
-      case BOOLEAN :
-        return isBoolean(object);
-      case INT :
-        return isInteger(object);
-      case BIGINT :
-        return isLong(object);
-      case DOUBLE:
-        return isDouble(object);
-      case CHAR:
-        return isChar(object);
-      case DATE:
-        return isDate(object);
-      case TIMESTAMP:
-        return isTimeStamp(object);
-      case STRING:
-        return isString(object);
-
-      default:
-        LOG.error("this datatype detection is not supported : {}", datatype);
-        return false;
-    }
-  }
-
-  public static DataTypes detectHiveColumnDataType(List<Object> colValues) {
-    boolean found;
-    for(DataTypes datatype : dataTypeList){
-      found = true;
-      for(Object object : colValues){
-        if(!checkDatatype(object,datatype)){
-          found = false;
-          break;
-        }
-      }
-
-      if(found) return datatype;
-    }
-
-    return DataTypes.STRING; //default
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/parsers/Parser.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/parsers/Parser.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/parsers/Parser.java
deleted file mode 100644
index 782b088..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/parsers/Parser.java
+++ /dev/null
@@ -1,161 +0,0 @@
-/**
- * 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
- * <p/>
- * http://www.apache.org/licenses/LICENSE-2.0
- * <p/>
- * 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.ambari.view.hive.resources.uploads.parsers;
-
-import org.apache.ambari.view.hive.client.ColumnDescription;
-import org.apache.ambari.view.hive.client.Row;
-import org.apache.ambari.view.hive.resources.uploads.ColumnDescriptionImpl;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-import java.io.Reader;
-import java.util.ArrayList;
-import java.util.List;
-import java.util.NoSuchElementException;
-
-/**
- * provides general implementation for parsing JSON,CSV,XML file
- * to generate preview rows, headers and column types
- * also provides TableDataReader for converting any type to CSV.
- */
-public abstract class Parser implements IParser {
-
-  protected final static Logger LOG =
-    LoggerFactory.getLogger(Parser.class);
-  public static final String COLUMN_PREFIX = "column";
-
-  protected Reader reader; // same as CSV reader in this case
-  protected ParseOptions parseOptions;
-  private int numberOfPreviewRows = 10;
-
-  public Parser(Reader originalReader, ParseOptions parseOptions) {
-    this.reader = originalReader;
-    this.parseOptions = parseOptions;
-  }
-
-  /**
-   * returns which datatype is valid for all the values
-   */
-
-  /**
-   *
-   * @param rows : non empty list of rows
-   * @param colNum : to detect datatype for this column number.
-   * @return data type for that column
-   */
-  private ColumnDescription.DataTypes getLikelyDataType(List<Row> rows, int colNum) {
-    // order of detection BOOLEAN,INT,BIGINT,DOUBLE,DATE,CHAR,STRING
-    List<Object> colValues = new ArrayList<>(rows.size());
-    for( Row row : rows ){
-      colValues.add(row.getRow()[colNum]);
-    }
-
-    return ParseUtils.detectHiveColumnDataType(colValues);
-  }
-
-  @Override
-  public PreviewData parsePreview() {
-    LOG.info("generating preview for : {}", this.parseOptions );
-
-    ArrayList<Row> previewRows;
-    List<ColumnDescription> header;
-
-    try {
-      numberOfPreviewRows = (Integer) parseOptions.getOption(ParseOptions.OPTIONS_NUMBER_OF_PREVIEW_ROWS);
-    } catch (Exception e) {
-      LOG.debug("Illegal number of preview columns supplied {}",parseOptions.getOption(ParseOptions.OPTIONS_NUMBER_OF_PREVIEW_ROWS) );
-    }
-
-    int numberOfRows = numberOfPreviewRows;
-    previewRows = new ArrayList<>(numberOfPreviewRows);
-
-    Row headerRow = null;
-    Integer numOfCols = null;
-
-    if (parseOptions.getOption(ParseOptions.OPTIONS_HEADER) != null &&
-      ( parseOptions.getOption(ParseOptions.OPTIONS_HEADER).equals(ParseOptions.HEADER.FIRST_RECORD.toString()) ||
-        parseOptions.getOption(ParseOptions.OPTIONS_HEADER).equals(ParseOptions.HEADER.EMBEDDED.toString())
-      )) {
-      headerRow = extractHeader();
-      numOfCols = headerRow.getRow().length;
-    }
-
-    Row r;
-    if (iterator().hasNext()) {
-      r = iterator().next();
-      if( null == numOfCols ) {
-        numOfCols = r.getRow().length;
-      }
-    } else {
-      LOG.error("No rows found in the file. returning error.");
-      throw new NoSuchElementException("No rows in the file.");
-    }
-
-    while (true) {
-      // create Header definition from row
-      Object[] values = r.getRow();
-      Object[] newValues= new Object[numOfCols]; // adds null if less columns detected and removes extra columns if any
-
-      for (int colNum = 0; colNum < numOfCols; colNum++) {
-        if(colNum < values.length) {
-          newValues[colNum] = values[colNum];
-        }else{
-          newValues[colNum] = null;
-        }
-      }
-
-      previewRows.add(new Row(newValues));
-
-      numberOfRows--;
-      if (numberOfRows <= 0 || !iterator().hasNext())
-        break;
-
-      r = iterator().next();
-    }
-
-    if (previewRows.size() <= 0) {
-      LOG.error("No rows found in the file. returning error.");
-      throw new NoSuchElementException("Does not contain any rows.");
-    }
-
-    // find data types.
-    header = generateHeader(headerRow,previewRows,numOfCols);
-
-    return new PreviewData(header,previewRows);
-  }
-
-  private List<ColumnDescription> generateHeader(Row headerRow,List<Row> previewRows, int numOfCols) {
-    List<ColumnDescription> header = new ArrayList<>();
-
-    for (int colNum = 0; colNum < numOfCols; colNum++) {
-      ColumnDescription.DataTypes type = getLikelyDataType(previewRows,colNum);
-      LOG.info("datatype detected for column {} : {}", colNum, type);
-
-      String colName = COLUMN_PREFIX + (colNum + 1);
-      if (null != headerRow)
-        colName = (String) headerRow.getRow()[colNum];
-
-      ColumnDescription cd = new ColumnDescriptionImpl(colName, type.toString(), colNum);
-      header.add(cd);
-    }
-
-    LOG.debug("return headers : {} ", header);
-    return header;
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/parsers/PreviewData.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/parsers/PreviewData.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/parsers/PreviewData.java
deleted file mode 100644
index 8fcae95..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/parsers/PreviewData.java
+++ /dev/null
@@ -1,56 +0,0 @@
-/**
- * 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
- * <p/>
- * http://www.apache.org/licenses/LICENSE-2.0
- * <p/>
- * 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.ambari.view.hive.resources.uploads.parsers;
-
-import org.apache.ambari.view.hive.client.ColumnDescription;
-import org.apache.ambari.view.hive.client.Row;
-
-import java.util.List;
-
-/**
- * Encapsulating preview data from parser.
- */
-public class PreviewData {
-  private List<ColumnDescription> header;
-  private List<Row> previewRows;
-
-  public PreviewData() {
-  }
-
-  public PreviewData(List<ColumnDescription> header, List<Row> previewRows) {
-    this.header = header;
-    this.previewRows = previewRows;
-  }
-
-  public List<ColumnDescription> getHeader() {
-    return header;
-  }
-
-  public void setHeader(List<ColumnDescription> header) {
-    this.header = header;
-  }
-
-  public List<Row> getPreviewRows() {
-    return previewRows;
-  }
-
-  public void setPreviewRows(List<Row> previewRows) {
-    this.previewRows = previewRows;
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/parsers/RowIterator.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/parsers/RowIterator.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/parsers/RowIterator.java
deleted file mode 100644
index 2dc8c22..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/parsers/RowIterator.java
+++ /dev/null
@@ -1,98 +0,0 @@
-/**
- * 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
- * <p/>
- * http://www.apache.org/licenses/LICENSE-2.0
- * <p/>
- * 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.ambari.view.hive.resources.uploads.parsers;
-
-import org.apache.ambari.view.hive.client.Row;
-
-import java.util.Iterator;
-import java.util.LinkedHashMap;
-import java.util.LinkedList;
-
-/**
- * Converts the Map of values created by JSON/XML Parser into ordered values in Row
- * Takes RowMapIterator as input
- */
-public class RowIterator implements Iterator<Row> {
-
-  private LinkedList<String> headers = null;
-  private RowMapIterator iterator;
-
-  /**
-   * creates a row iterator for the map values in RowMapIterator
-   * keeps the keys in map as header.
-   * @param iterator
-   */
-  public RowIterator(RowMapIterator iterator) {
-    this.iterator = iterator;
-    LinkedHashMap<String, String> obj = iterator.peek();
-    headers = new LinkedList<>();
-    if (null != obj) {
-      headers.addAll(obj.keySet());
-    }
-  }
-
-  @Override
-  public boolean hasNext() {
-    return iterator.hasNext();
-  }
-
-
-  @Override
-  public Row next() {
-    LinkedHashMap<String, String> r = this.iterator.next();
-    if (null == r) {
-      return null;
-    }
-
-    return convertToRow(r);
-  }
-
-  @Override
-  public void remove() {
-    iterator.remove();
-  }
-
-  /**
-   * @return : ordered collection of string of headers
-   */
-  public LinkedList<String> extractHeaders() {
-    return headers;
-  }
-
-  /**
-   * converts the map into a Row
-   * @param lr
-   * @return
-   */
-  private Row convertToRow(LinkedHashMap<String, String> lr) {
-    Object[] data = new Object[headers.size()];
-    int i = 0;
-    for (String cd : headers) {
-      String d = lr.get(cd);
-
-      if (d != null)
-        d = d.trim(); // trim to remove any \n etc which is used as a separator for rows in TableDataReader
-
-      data[i++] = d;
-    }
-
-    return new Row(data);
-  }
-
-}
\ No newline at end of file

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/parsers/RowMapIterator.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/parsers/RowMapIterator.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/parsers/RowMapIterator.java
deleted file mode 100644
index a0ff2d7..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/parsers/RowMapIterator.java
+++ /dev/null
@@ -1,29 +0,0 @@
-/**
- * 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
- * <p/>
- * http://www.apache.org/licenses/LICENSE-2.0
- * <p/>
- * 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.ambari.view.hive.resources.uploads.parsers;
-
-import java.util.Iterator;
-import java.util.LinkedHashMap;
-
-/**
- * iterator which generates Ordered Map of column name and values for each row from streams like JSON and XML
- */
-public interface RowMapIterator extends Iterator<LinkedHashMap<String, String>> {
-  LinkedHashMap<String, String> peek() ;
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/parsers/csv/commonscsv/CSVIterator.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/parsers/csv/commonscsv/CSVIterator.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/parsers/csv/commonscsv/CSVIterator.java
deleted file mode 100644
index e50a87c..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/parsers/csv/commonscsv/CSVIterator.java
+++ /dev/null
@@ -1,57 +0,0 @@
-/**
- * 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
- * <p/>
- * http://www.apache.org/licenses/LICENSE-2.0
- * <p/>
- * 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.ambari.view.hive.resources.uploads.parsers.csv.commonscsv;
-
-import org.apache.ambari.view.hive.client.Row;
-import org.apache.commons.csv.CSVRecord;
-
-import java.util.Iterator;
-
-/**
- * iterates over the input CSV records and generates Row objects
- */
-class CSVIterator implements Iterator<Row> {
-
-  private Iterator<CSVRecord> iterator;
-
-  public CSVIterator(Iterator<CSVRecord> iterator) {
-    this.iterator = iterator;
-  }
-
-  @Override
-  public boolean hasNext() {
-    return iterator.hasNext();
-  }
-
-  @Override
-  public Row next() {
-    CSVRecord row = iterator.next();
-    Object[] values = new Object[row.size()];
-    for (int i = 0; i < values.length; i++) {
-      values[i] = row.get(i);
-    }
-    Row r = new Row(values);
-    return r;
-  }
-
-  @Override
-  public void remove() {
-    this.iterator.remove();
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/parsers/csv/commonscsv/CSVParser.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/parsers/csv/commonscsv/CSVParser.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/parsers/csv/commonscsv/CSVParser.java
deleted file mode 100644
index ea9c9fb..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/parsers/csv/commonscsv/CSVParser.java
+++ /dev/null
@@ -1,88 +0,0 @@
-/**
- * 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
- * <p/>
- * http://www.apache.org/licenses/LICENSE-2.0
- * <p/>
- * 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.ambari.view.hive.resources.uploads.parsers.csv.commonscsv;
-
-import org.apache.ambari.view.hive.client.Row;
-import org.apache.ambari.view.hive.resources.uploads.parsers.ParseOptions;
-import org.apache.ambari.view.hive.resources.uploads.parsers.Parser;
-import org.apache.commons.csv.CSVFormat;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-import java.io.IOException;
-import java.io.Reader;
-import java.util.Iterator;
-
-/**
- * Parses the given Reader which contains CSV stream and extracts headers and rows, and detect datatypes of columns
- */
-public class CSVParser extends Parser {
-  private CSVIterator iterator;
-  private org.apache.commons.csv.CSVParser parser;
-  private final static Logger LOG =
-    LoggerFactory.getLogger(CSVParser.class);
-
-  public CSVParser(Reader reader, ParseOptions parseOptions) throws IOException {
-    super(reader, parseOptions);
-    CSVFormat format = CSVFormat.DEFAULT;
-    String optHeader =  (String)parseOptions.getOption(ParseOptions.OPTIONS_HEADER);
-    if(optHeader != null){
-      if(optHeader.equals(ParseOptions.HEADER.FIRST_RECORD.toString())) {
-        format = format.withHeader();
-      }else if( optHeader.equals(ParseOptions.HEADER.PROVIDED_BY_USER.toString())){
-        String [] headers = (String[]) parseOptions.getOption(ParseOptions.OPTIONS_HEADERS);
-        format = format.withHeader(headers);
-      }
-    }
-
-    Character delimiter = (Character) parseOptions.getOption(ParseOptions.OPTIONS_CSV_DELIMITER);
-    if(delimiter != null){
-      LOG.info("setting delimiter as {}", delimiter);
-      format = format.withDelimiter(delimiter);
-    }
-
-    Character quote = (Character) parseOptions.getOption(ParseOptions.OPTIONS_CSV_QUOTE);
-    if( null != quote ){
-      LOG.info("setting Quote char : {}", quote);
-      format = format.withQuote(quote);
-    }
-
-    Character escape = (Character) parseOptions.getOption(ParseOptions.OPTIONS_CSV_ESCAPE_CHAR);
-    if(escape != null){
-      LOG.info("setting escape as {}", escape);
-      format = format.withEscape(escape);
-    }
-
-    parser = new org.apache.commons.csv.CSVParser(this.reader,format );
-    iterator = new CSVIterator(parser.iterator());
-  }
-
-  @Override
-  public Row extractHeader() {
-    return new Row(parser.getHeaderMap().keySet().toArray());
-  }
-
-  @Override
-  public void close() throws Exception {
-    this.parser.close();
-  }
-
-  public Iterator<Row> iterator() {
-    return iterator; // only one iterator per parser.
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/parsers/csv/opencsv/OpenCSVIterator.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/parsers/csv/opencsv/OpenCSVIterator.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/parsers/csv/opencsv/OpenCSVIterator.java
deleted file mode 100644
index 3f605cb..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/parsers/csv/opencsv/OpenCSVIterator.java
+++ /dev/null
@@ -1,56 +0,0 @@
-/**
- * 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
- * <p/>
- * http://www.apache.org/licenses/LICENSE-2.0
- * <p/>
- * 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.ambari.view.hive.resources.uploads.parsers.csv.opencsv;
-
-import org.apache.ambari.view.hive.client.Row;
-
-import java.util.Iterator;
-
-/**
- * iterates over the input CSV records and generates Row objects
- */
-class OpenCSVIterator implements Iterator<Row> {
-
-  private Iterator<String[]> iterator;
-
-  public OpenCSVIterator(Iterator<String[]> iterator) {
-    this.iterator = iterator;
-  }
-
-  @Override
-  public boolean hasNext() {
-    return iterator.hasNext();
-  }
-
-  @Override
-  public Row next() {
-    String[] row = iterator.next();
-    Object[] values = new Object[row.length];
-    for (int i = 0; i < values.length; i++) {
-      values[i] = row[i];
-    }
-    Row r = new Row(values);
-    return r;
-  }
-
-  @Override
-  public void remove() {
-    this.iterator.remove();
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/parsers/csv/opencsv/OpenCSVParser.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/parsers/csv/opencsv/OpenCSVParser.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/parsers/csv/opencsv/OpenCSVParser.java
deleted file mode 100644
index 0109e91..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/parsers/csv/opencsv/OpenCSVParser.java
+++ /dev/null
@@ -1,92 +0,0 @@
-/**
- * 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
- * <p/>
- * http://www.apache.org/licenses/LICENSE-2.0
- * <p/>
- * 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.ambari.view.hive.resources.uploads.parsers.csv.opencsv;
-
-import com.opencsv.CSVParserBuilder;
-import com.opencsv.CSVReader;
-import com.opencsv.CSVReaderBuilder;
-import org.apache.ambari.view.hive.client.Row;
-import org.apache.ambari.view.hive.resources.uploads.parsers.ParseOptions;
-import org.apache.ambari.view.hive.resources.uploads.parsers.Parser;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-import java.io.IOException;
-import java.io.Reader;
-import java.util.Iterator;
-
-/**
- * Parses the given Reader which contains CSV stream and extracts headers and rows
- */
-public class OpenCSVParser extends Parser {
-  private Row headerRow;
-  private OpenCSVIterator iterator;
-  private CSVReader csvReader = null;
-  private final static Logger LOG =
-    LoggerFactory.getLogger(OpenCSVParser.class);
-
-  public OpenCSVParser(Reader reader, ParseOptions parseOptions) throws IOException {
-    super(reader, parseOptions);
-    CSVParserBuilder csvParserBuilder = new CSVParserBuilder();
-    CSVReaderBuilder builder =  new CSVReaderBuilder(reader);
-
-    Character delimiter = (Character) parseOptions.getOption(ParseOptions.OPTIONS_CSV_DELIMITER);
-    if(delimiter != null){
-      LOG.info("setting delimiter as {}", delimiter);
-      csvParserBuilder = csvParserBuilder.withSeparator(delimiter);
-    }
-
-    Character quote = (Character) parseOptions.getOption(ParseOptions.OPTIONS_CSV_QUOTE);
-    if( null != quote ){
-      LOG.info("setting Quote char : {}", quote);
-      csvParserBuilder = csvParserBuilder.withQuoteChar(quote);
-    }
-
-    Character escapeChar = (Character) parseOptions.getOption(ParseOptions.OPTIONS_CSV_ESCAPE_CHAR);
-    if( null != escapeChar ){
-      LOG.info("setting escapeChar : {}", escapeChar);
-      csvParserBuilder = csvParserBuilder.withEscapeChar(escapeChar);
-    }
-
-    builder.withCSVParser(csvParserBuilder.build());
-    this.csvReader = builder.build();
-    iterator = new OpenCSVIterator(this.csvReader.iterator());
-
-    String optHeader =  (String)parseOptions.getOption(ParseOptions.OPTIONS_HEADER);
-    if(optHeader != null){
-      if(optHeader.equals(ParseOptions.HEADER.FIRST_RECORD.toString())) {
-        this.headerRow = iterator().hasNext() ? iterator.next() : new Row(new Object[]{});
-      }
-    }
-
-  }
-
-  @Override
-  public Row extractHeader() {
-    return headerRow;
-  }
-
-  @Override
-  public void close() throws Exception {
-    this.csvReader.close();
-  }
-
-  public Iterator<Row> iterator() {
-    return iterator; // only one iterator per parser.
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/parsers/json/JSONIterator.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/parsers/json/JSONIterator.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/parsers/json/JSONIterator.java
deleted file mode 100644
index 534d9e7..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/parsers/json/JSONIterator.java
+++ /dev/null
@@ -1,160 +0,0 @@
-/**
- * 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
- * <p/>
- * http://www.apache.org/licenses/LICENSE-2.0
- * <p/>
- * 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.ambari.view.hive.resources.uploads.parsers.json;
-
-import com.google.gson.stream.JsonReader;
-import com.google.gson.stream.JsonToken;
-import org.apache.ambari.view.hive.resources.uploads.parsers.EndOfDocumentException;
-import org.apache.ambari.view.hive.resources.uploads.parsers.RowMapIterator;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-import java.io.IOException;
-import java.util.LinkedHashMap;
-
-/**
- * iterates over the JsonReader and reads creates row data
- * assumes the array of json objects.
- * eg : [ { "col1Name" : "value-1-1", "col2Name" : "value-1-2"}, { "col1Name" : "value-2-1", "col2Name" : "value-2-2"}]
- */
-class JSONIterator implements RowMapIterator {
-
-  protected final static Logger LOG =
-          LoggerFactory.getLogger(JSONIterator.class);
-
-  private LinkedHashMap<String, String> nextObject = null;
-
-  private LinkedHashMap<String, String> readNextObject(JsonReader reader) throws IOException, EndOfDocumentException {
-    LinkedHashMap<String, String> row = new LinkedHashMap<>();
-    boolean objectStarted = false;
-    boolean shouldBeName = false;
-    String currentName = null;
-
-    while (true) {
-      JsonToken token = reader.peek();
-      switch (token) {
-        case BEGIN_ARRAY:
-          throw new IllegalArgumentException("Row data cannot have an array.");
-        case END_ARRAY:
-          throw new EndOfDocumentException("End of Json Array document.");
-        case BEGIN_OBJECT:
-          if (objectStarted == true) {
-            throw new IllegalArgumentException("Nested objects not supported.");
-          }
-          if (shouldBeName == true) {
-            throw new IllegalArgumentException("name expected, got begin_object");
-          }
-          objectStarted = true;
-          shouldBeName = true;
-          reader.beginObject();
-          break;
-        case END_OBJECT:
-          if (shouldBeName == false) {
-            throw new IllegalArgumentException("value expected, got end_object");
-          }
-          reader.endObject();
-          return row;
-        case NAME:
-          if (shouldBeName == false) {
-            throw new IllegalArgumentException("name not expected at this point.");
-          }
-          shouldBeName = false;
-          currentName = reader.nextName();
-          break;
-        case NUMBER:
-        case STRING:
-          if (shouldBeName == true) {
-            throw new IllegalArgumentException("value not expected at this point.");
-          }
-          String n = reader.nextString();
-          row.put(currentName, n);
-          shouldBeName = true;
-          break;
-        case BOOLEAN:
-          if (shouldBeName == true) {
-            throw new IllegalArgumentException("value not expected at this point.");
-          }
-          String b = String.valueOf(reader.nextBoolean());
-          row.put(currentName, b);
-          shouldBeName = true;
-          break;
-        case NULL:
-          if (shouldBeName == true) {
-            throw new IllegalArgumentException("value not expected at this point.");
-          }
-          reader.nextNull();
-          row.put(currentName, "");
-          shouldBeName = true;
-          break;
-        case END_DOCUMENT:
-          return row;
-
-        default:
-          throw new IllegalArgumentException("Illegal token detected inside json: token : " + token.toString());
-      }
-    }
-  }
-
-  private JsonReader reader;
-
-  public JSONIterator(JsonReader reader) throws IOException {
-    this.reader = reader;
-    // test the start of array
-    JsonToken jt = reader.peek();
-    if (jt != JsonToken.BEGIN_ARRAY) {
-      throw new IllegalArgumentException("Expected the whole document to contain a single JsonArray.");
-    }
-
-    reader.beginArray(); // read the start of array
-    try {
-      nextObject = readNextObject(this.reader);
-    } catch (EndOfDocumentException e) {
-    }
-  }
-
-  @Override
-  public boolean hasNext() {
-    return null != nextObject;
-  }
-
-  public LinkedHashMap<String, String> peek() {
-    return nextObject;
-  }
-
-  @Override
-  public LinkedHashMap<String, String> next() {
-    LinkedHashMap<String, String> currObject = nextObject;
-    try {
-      nextObject = readNextObject(this.reader);
-    } catch (EndOfDocumentException e) {
-      LOG.debug("End of Json document reached with next character ending the JSON Array.");
-      nextObject = null;
-    } catch (Exception e){
-      // for any other exception throw error right away
-      throw new IllegalArgumentException(e);
-    }
-    return currObject;
-  }
-
-  @Override
-  public void remove() {
-    // no operation.
-    LOG.info("No operation when remove called on JSONIterator.");
-  }
-}
\ No newline at end of file

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/parsers/json/JSONParser.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/parsers/json/JSONParser.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/parsers/json/JSONParser.java
deleted file mode 100644
index 9ca89a7..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/parsers/json/JSONParser.java
+++ /dev/null
@@ -1,85 +0,0 @@
-/**
- * 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
- * <p/>
- * http://www.apache.org/licenses/LICENSE-2.0
- * <p/>
- * 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.ambari.view.hive.resources.uploads.parsers.json;
-
-import com.google.gson.stream.JsonReader;
-import org.apache.ambari.view.hive.client.Row;
-import org.apache.ambari.view.hive.resources.uploads.parsers.ParseOptions;
-import org.apache.ambari.view.hive.resources.uploads.parsers.Parser;
-import org.apache.ambari.view.hive.resources.uploads.parsers.RowIterator;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-import java.io.IOException;
-import java.io.Reader;
-import java.util.Collection;
-import java.util.Iterator;
-
-
-/**
- * Parses the input data from reader as JSON and provides iterator for rows.
- *
- * Expects the input reader to contains a JsonArray in which each element is a JsonObject
- * corresponding to the row.
- * eg. :
- *
- * [
- *  {row1-col1, row1-col2, row1-col3},
- *  {row2-col1, row2-col2, row2-col3}
- * ]
- *
- */
-public class JSONParser extends Parser {
-
-  protected final static Logger LOG =
-          LoggerFactory.getLogger(JSONParser.class);
-
-  private RowIterator iterator;
-  private JsonReader jsonReader;
-  private JSONIterator JSONIterator;
-
-  public JSONParser(Reader reader, ParseOptions parseOptions) throws IOException {
-    super(reader, parseOptions);
-    this.jsonReader = new JsonReader(this.reader);
-    JSONIterator = new JSONIterator(this.jsonReader);
-    iterator = new RowIterator(JSONIterator);
-  }
-
-  @Override
-  public Row extractHeader() {
-    Collection<String> headers = this.iterator.extractHeaders();
-    Object[] objs = new Object[headers.size()];
-    Iterator<String> iterator = headers.iterator();
-    for(int i = 0 ; i < headers.size() ; i++){
-      objs[i] = iterator.next();
-    }
-
-    return new Row(objs);
-  }
-
-  @Override
-  public void close() throws Exception {
-    this.jsonReader.close();
-  }
-
-  @Override
-  public Iterator<Row> iterator() {
-    return iterator;
-  }
-}
\ No newline at end of file

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/parsers/xml/XMLIterator.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/parsers/xml/XMLIterator.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/parsers/xml/XMLIterator.java
deleted file mode 100644
index 5852dfc..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/parsers/xml/XMLIterator.java
+++ /dev/null
@@ -1,195 +0,0 @@
-/**
- * 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
- * <p/>
- * http://www.apache.org/licenses/LICENSE-2.0
- * <p/>
- * 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.ambari.view.hive.resources.uploads.parsers.xml;
-
-import org.apache.ambari.view.hive.resources.uploads.parsers.EndOfDocumentException;
-import org.apache.ambari.view.hive.resources.uploads.parsers.RowMapIterator;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-import javax.xml.namespace.QName;
-import javax.xml.stream.XMLEventReader;
-import javax.xml.stream.XMLStreamConstants;
-import javax.xml.stream.XMLStreamException;
-import javax.xml.stream.events.*;
-import java.io.IOException;
-import java.util.LinkedHashMap;
-
-/**
- * assumes XML of following format
- * <table>
- * <row>
- * <col name="col1Name">row1-col1-Data</col>
- * <col name="col2Name">row1-col2-Data</col>
- * <col name="col3Name">row1-col3-Data</col>
- * <col name="col4Name">row1-col4-Data</col>
- * </row>
- * <row>
- * <col name="col1Name">row2-col1-Data</col>
- * <col name="col2Name">row2-col2-Data</col>
- * <col name="col3Name">row2-col3-Data</col>
- * <col name="col4Name">row2-col4-Data</col>
- * </row>
- * </table>
- */
-class XMLIterator implements RowMapIterator {
-
-  protected final static Logger LOG =
-          LoggerFactory.getLogger(XMLIterator.class);
-
-  private LinkedHashMap<String, String> nextObject = null;
-  private static final String TAG_TABLE = "table";
-  private static final String TAG_ROW = "row";
-  private static final String TAG_COL = "col";
-  private boolean documentStarted = false;
-  private XMLEventReader reader;
-
-  public XMLIterator(XMLEventReader reader) throws IOException {
-    this.reader = reader;
-    try {
-      nextObject = readNextObject(this.reader);
-    } catch (EndOfDocumentException e) {
-      LOG.debug("error : {}", e);
-    } catch (XMLStreamException e) {
-      throw new IOException(e);
-    }
-  }
-
-  @Override
-  public boolean hasNext() {
-    return null != nextObject;
-  }
-
-  public LinkedHashMap<String, String> peek() {
-    return nextObject;
-  }
-
-  @Override
-  public LinkedHashMap<String, String> next() {
-    LinkedHashMap<String, String> currObject = nextObject;
-    try {
-      nextObject = readNextObject(this.reader);
-    } catch (IOException e) {
-      LOG.error("Exception occured while reading the next row from XML : {} ", e);
-      nextObject = null;
-    } catch (EndOfDocumentException e) {
-      LOG.debug("End of XML document reached with next character ending the XML.");
-      nextObject = null;
-    } catch (XMLStreamException e) {
-      LOG.error("Exception occured while reading the next row from XML : {} ", e);
-      nextObject = null;
-    }
-    return currObject;
-  }
-
-  @Override
-  public void remove() {
-    // no operation.
-    LOG.info("No operation when remove called.");
-  }
-
-  private LinkedHashMap<String, String> readNextObject(XMLEventReader reader) throws IOException, EndOfDocumentException, XMLStreamException {
-    LinkedHashMap<String, String> row = new LinkedHashMap<>();
-    boolean objectStarted = false;
-    String currentName = null;
-
-    while (true) {
-      XMLEvent event = reader.nextEvent();
-      switch (event.getEventType()) {
-        case XMLStreamConstants.START_ELEMENT:
-          StartElement startElement = event.asStartElement();
-          String qName = startElement.getName().getLocalPart();
-          LOG.debug("startName : {}" , qName);
-          switch (qName) {
-            case TAG_TABLE:
-              if (documentStarted) {
-                throw new IllegalArgumentException("Cannot have a <table> tag nested inside another <table> tag");
-              } else {
-                documentStarted = true;
-              }
-              break;
-            case TAG_ROW:
-              if (objectStarted) {
-                throw new IllegalArgumentException("Cannot have a <row> tag nested inside another <row> tag");
-              } else {
-                objectStarted = true;
-              }
-              break;
-            case TAG_COL:
-              if (!objectStarted) {
-                throw new IllegalArgumentException("Stray tag " + qName);
-              }
-              Attribute nameAttr = startElement.getAttributeByName( new QName("name"));
-              if( null == nameAttr ){
-                throw new IllegalArgumentException("Missing name attribute in col tag.");
-              }
-              currentName = nameAttr.getValue();
-              break;
-            default:
-              throw new IllegalArgumentException("Illegal start tag " + qName + " encountered.");
-          }
-          break;
-        case XMLStreamConstants.END_ELEMENT:
-          EndElement endElement = event.asEndElement();
-          String name = endElement.getName().getLocalPart();
-          LOG.debug("endName : {}", name);
-          switch (name) {
-            case TAG_TABLE:
-              if (!documentStarted) {
-                throw new IllegalArgumentException("Stray </table> tag.");
-              }
-              throw new EndOfDocumentException("End of XML document.");
-
-            case TAG_ROW:
-              if (!objectStarted) {
-                throw new IllegalArgumentException("Stray </row> tag.");
-              }
-              return row;
-
-            case TAG_COL:
-              if (!objectStarted) {
-                throw new IllegalArgumentException("Stray tag " + name);
-              }
-              currentName = null;
-              break;
-
-            default:
-              throw new IllegalArgumentException("Illegal start ending " + name + " encountered.");
-          }
-          break;
-        case XMLStreamConstants.CHARACTERS:
-          Characters characters = event.asCharacters();
-          if (characters.isWhiteSpace() && currentName == null)
-            break;
-          String data = characters.getData();
-          LOG.debug("character data : {}", data);
-          if (currentName == null) {
-            throw new IllegalArgumentException("Illegal characters outside any tag : " + data);
-          } else {
-            String oldData = row.get(currentName);
-            if (null != oldData) {
-              data = oldData + data;
-            }
-            row.put(currentName, data);
-          }
-          break;
-      }
-    }
-  }
-}


[03/23] ambari git commit: AMBARI-19302 : removed contrib/views/hive folder and made necessary changes in pom.xml files (nitirajrathore)

Posted by ni...@apache.org.
http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/resources/jobs/ATSParserTest.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/resources/jobs/ATSParserTest.java b/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/resources/jobs/ATSParserTest.java
deleted file mode 100644
index 43b0b65..0000000
--- a/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/resources/jobs/ATSParserTest.java
+++ /dev/null
@@ -1,512 +0,0 @@
-/**
- * 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
- * <p/>
- * http://www.apache.org/licenses/LICENSE-2.0
- * <p/>
- * 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.ambari.view.hive.resources.jobs;
-
-import org.apache.ambari.view.hive.resources.jobs.atsJobs.ATSParser;
-import org.apache.ambari.view.hive.resources.jobs.atsJobs.ATSRequestsDelegate;
-import org.apache.ambari.view.hive.resources.jobs.atsJobs.HiveQueryId;
-import org.apache.ambari.view.hive.resources.jobs.atsJobs.IATSParser;
-import org.apache.ambari.view.hive.resources.jobs.atsJobs.TezDagId;
-import org.apache.commons.codec.binary.Base64;
-import org.json.simple.JSONObject;
-import org.json.simple.JSONValue;
-import org.junit.Assert;
-import org.junit.Test;
-import sun.reflect.generics.reflectiveObjects.NotImplementedException;
-
-import java.util.Arrays;
-import java.util.List;
-
-public class ATSParserTest {
-  @Test
-  public void testBase64() throws Exception {
-    System.out.println(Arrays.toString(Base64.decodeBase64("HWvpjKiERZCy_le4s-odOQ")));
-  }
-
-  @Test
-  public void testGetHiveJobsList() throws Exception {
-    IATSParser jobLoader = new ATSParser(new ATSRequestsDelegateStub());
-
-    List<HiveQueryId> jobs = jobLoader.getHiveQueryIdsForUser("hive");
-
-    Assert.assertEquals(1, jobs.size());
-
-    HiveQueryId job = jobs.get(0);
-    Assert.assertEquals("hive_20150209144848_c3a5a07b-c3b6-4f57-a6d5-3dadecdd6fd0", job.entity);
-    Assert.assertEquals(1423493324355L, job.starttime);
-    Assert.assertEquals("hive", job.user);
-    Assert.assertEquals((1423493342843L - 1423493324355L) / 1000L, job.duration);
-    Assert.assertEquals("select count(*) from z", job.query);
-
-    Assert.assertEquals(1, job.dagNames.size());
-    Assert.assertEquals("hive_20150209144848_c3a5a07b-c3b6-4f57-a6d5-3dadecdd6fd0:4", job.dagNames.get(0));
-
-    Assert.assertEquals(2, job.stages.size());
-    Assert.assertTrue(HiveQueryId.ATS_15_RESPONSE_VERSION > job.version);
-
-    jobLoader = new ATSParser(new ATSV15RequestsDelegateStub());
-    List<HiveQueryId> jobsv2 = jobLoader.getHiveQueryIdsForUser("hive");
-    Assert.assertEquals(1, jobsv2.size());
-    HiveQueryId jobv2 = jobsv2.get(0);
-    Assert.assertTrue(HiveQueryId.ATS_15_RESPONSE_VERSION <= jobv2.version);
-  }
-
-  @Test
-  public void testGetTezDAGByName() throws Exception {
-    IATSParser jobLoader = new ATSParser(new ATSRequestsDelegateStub());
-
-    TezDagId tezDag = jobLoader.getTezDAGByName("hive_20150209144848_c3a5a07b-c3b6-4f57-a6d5-3dadecdd6fd0:4");
-
-    Assert.assertEquals("dag_1423156117563_0005_2", tezDag.entity);
-    Assert.assertEquals("application_1423156117563_0005", tezDag.applicationId);
-    Assert.assertEquals("SUCCEEDED", tezDag.status);
-  }
-
-  @Test
-  public void testGetTezDagByEntity() throws Exception {
-    IATSParser jobLoader = new ATSParser(new ATSV15RequestsDelegateStub());
-
-    TezDagId tezDag = jobLoader.getTezDAGByEntity("hive_20150209144848_c3a5a07b-c3b6-4f57-a6d5-3dadecdd6fd0:4");
-
-    Assert.assertEquals("dag_1423156117563_0005_2", tezDag.entity);
-    Assert.assertEquals("application_1423156117563_0005", tezDag.applicationId);
-    Assert.assertEquals("SUCCEEDED", tezDag.status);
-  }
-
-  protected static class ATSV15RequestsDelegateStub extends ATSRequestsDelegateStub {
-    /**
-     * This returns the version field that the ATS v1.5 returns.
-     */
-    @Override
-    public JSONObject hiveQueryIdsForUser(String username) {
-      return (JSONObject) JSONValue.parse(
-        "{ \"entities\" : [ { \"domain\" : \"DEFAULT\",\n" +
-          "        \"entity\" : \"hive_20150209144848_c3a5a07b-c3b6-4f57-a6d5-3dadecdd6fd0\",\n" +
-          "        \"entitytype\" : \"HIVE_QUERY_ID\",\n" +
-          "        \"events\" : [ { \"eventinfo\" : {  },\n" +
-          "              \"eventtype\" : \"QUERY_COMPLETED\",\n" +
-          "              \"timestamp\" : 1423493342843\n" +
-          "            },\n" +
-          "            { \"eventinfo\" : {  },\n" +
-          "              \"eventtype\" : \"QUERY_SUBMITTED\",\n" +
-          "              \"timestamp\" : 1423493324355\n" +
-          "            }\n" +
-          "          ],\n" +
-          "        \"otherinfo\" : { \"MAPRED\" : false,\n" +
-          "            \"QUERY\" : \"{\\\"queryText\\\":\\\"select count(*) from z\\\",\\\"queryPlan\\\":{\\\"STAGE PLANS\\\":{\\\"Stage-1\\\":{\\\"Tez\\\":{\\\"DagName:\\\":\\\"hive_20150209144848_c3a5a07b-c3b6-4f57-a6d5-3dadecdd6fd0:4\\\",\\\"Vertices:\\\":{\\\"Reducer 2\\\":{\\\"Reduce Operator Tree:\\\":{\\\"Group By Operator\\\":{\\\"mode:\\\":\\\"mergepartial\\\",\\\"aggregations:\\\":[\\\"count(VALUE._col0)\\\"],\\\"outputColumnNames:\\\":[\\\"_col0\\\"],\\\"children\\\":{\\\"Select Operator\\\":{\\\"expressions:\\\":\\\"_col0 (type: bigint)\\\",\\\"outputColumnNames:\\\":[\\\"_col0\\\"],\\\"children\\\":{\\\"File Output Operator\\\":{\\\"Statistics:\\\":\\\"Num rows: 1 Data size: 8 Basic stats: COMPLETE Column stats: COMPLETE\\\",\\\"compressed:\\\":\\\"false\\\",\\\"table:\\\":{\\\"serde:\\\":\\\"org.apache.hadoop.hive.serde2.lazy.LazySimpleSerDe\\\",\\\"input format:\\\":\\\"org.apache.hadoop.mapred.TextInputFormat\\\",\\\"output format:\\\":\\\"org.apache.hadoop.hive.ql.i
 o.HiveIgnoreKeyTextOutputFormat\\\"}}},\\\"Statistics:\\\":\\\"Num rows: 1 Data size: 8 Basic stats: COMPLETE Column stats: COMPLETE\\\"}},\\\"Statistics:\\\":\\\"Num rows: 1 Data size: 8 Basic stats: COMPLETE Column stats: COMPLETE\\\"}}},\\\"Map 1\\\":{\\\"Map Operator Tree:\\\":[{\\\"TableScan\\\":{\\\"alias:\\\":\\\"z\\\",\\\"children\\\":{\\\"Select Operator\\\":{\\\"children\\\":{\\\"Group By Operator\\\":{\\\"mode:\\\":\\\"hash\\\",\\\"aggregations:\\\":[\\\"count()\\\"],\\\"outputColumnNames:\\\":[\\\"_col0\\\"],\\\"children\\\":{\\\"Reduce Output Operator\\\":{\\\"sort order:\\\":\\\"\\\",\\\"value expressions:\\\":\\\"_col0 (type: bigint)\\\",\\\"Statistics:\\\":\\\"Num rows: 1 Data size: 8 Basic stats: COMPLETE Column stats: COMPLETE\\\"}},\\\"Statistics:\\\":\\\"Num rows: 1 Data size: 8 Basic stats: COMPLETE Column stats: COMPLETE\\\"}},\\\"Statistics:\\\":\\\"Num rows: 0 Data size: 40 Basic stats: PARTIAL Column stats: COMPLETE\\\"}},\\\"Statistics:\\\":\\\"Num rows: 0 
 Data size: 40 Basic stats: PARTIAL Column stats: COMPLETE\\\"}}]}},\\\"Edges:\\\":{\\\"Reducer 2\\\":{\\\"parent\\\":\\\"Map 1\\\",\\\"type\\\":\\\"SIMPLE_EDGE\\\"}}}},\\\"Stage-0\\\":{\\\"Fetch Operator\\\":{\\\"limit:\\\":\\\"-1\\\",\\\"Processor Tree:\\\":{\\\"ListSink\\\":{}}}}},\\\"STAGE DEPENDENCIES\\\":{\\\"Stage-1\\\":{\\\"ROOT STAGE\\\":\\\"TRUE\\\"},\\\"Stage-0\\\":{\\\"DEPENDENT STAGES\\\":\\\"Stage-1\\\"}}}}\",\n" +
-          "            \"STATUS\" : true,\n" +
-          "            \"TEZ\" : true\n" +
-          "            \"VERSION\" : 2\n" +
-          "          },\n" +
-          "        \"primaryfilters\" : { \"user\" : [ \"hive\" ] },\n" +
-          "        \"relatedentities\" : {  },\n" +
-          "        \"starttime\" : 1423493324355\n" +
-          "      } ] }"
-      );
-    }
-  }
-
-  protected static class ATSRequestsDelegateStub implements ATSRequestsDelegate {
-
-
-    public JSONObject hiveQueryIdsForUserByTime(String username, long startTime, long endTime) {
-      throw new NotImplementedException();
-    }
-
-    @Override
-    public JSONObject hiveQueryEntityByEntityId(String hiveEntityId) {
-      return null;
-    }
-
-    @Override
-    public String hiveQueryIdDirectUrl(String entity) {
-      return null;
-    }
-
-    @Override
-    public String hiveQueryIdOperationIdUrl(String operationId) {
-      return null;
-    }
-
-    @Override
-    public String tezDagDirectUrl(String entity) {
-      return null;
-    }
-
-    @Override
-    public String tezDagNameUrl(String name) {
-      return null;
-    }
-
-    @Override
-    public String tezVerticesListForDAGUrl(String dagId) {
-      return null;
-    }
-
-    @Override
-    public JSONObject hiveQueryIdsForUser(String username) {
-      return (JSONObject) JSONValue.parse(
-          "{ \"entities\" : [ { \"domain\" : \"DEFAULT\",\n" +
-              "        \"entity\" : \"hive_20150209144848_c3a5a07b-c3b6-4f57-a6d5-3dadecdd6fd0\",\n" +
-              "        \"entitytype\" : \"HIVE_QUERY_ID\",\n" +
-              "        \"events\" : [ { \"eventinfo\" : {  },\n" +
-              "              \"eventtype\" : \"QUERY_COMPLETED\",\n" +
-              "              \"timestamp\" : 1423493342843\n" +
-              "            },\n" +
-              "            { \"eventinfo\" : {  },\n" +
-              "              \"eventtype\" : \"QUERY_SUBMITTED\",\n" +
-              "              \"timestamp\" : 1423493324355\n" +
-              "            }\n" +
-              "          ],\n" +
-              "        \"otherinfo\" : { \"MAPRED\" : false,\n" +
-              "            \"QUERY\" : \"{\\\"queryText\\\":\\\"select count(*) from z\\\",\\\"queryPlan\\\":{\\\"STAGE PLANS\\\":{\\\"Stage-1\\\":{\\\"Tez\\\":{\\\"DagName:\\\":\\\"hive_20150209144848_c3a5a07b-c3b6-4f57-a6d5-3dadecdd6fd0:4\\\",\\\"Vertices:\\\":{\\\"Reducer 2\\\":{\\\"Reduce Operator Tree:\\\":{\\\"Group By Operator\\\":{\\\"mode:\\\":\\\"mergepartial\\\",\\\"aggregations:\\\":[\\\"count(VALUE._col0)\\\"],\\\"outputColumnNames:\\\":[\\\"_col0\\\"],\\\"children\\\":{\\\"Select Operator\\\":{\\\"expressions:\\\":\\\"_col0 (type: bigint)\\\",\\\"outputColumnNames:\\\":[\\\"_col0\\\"],\\\"children\\\":{\\\"File Output Operator\\\":{\\\"Statistics:\\\":\\\"Num rows: 1 Data size: 8 Basic stats: COMPLETE Column stats: COMPLETE\\\",\\\"compressed:\\\":\\\"false\\\",\\\"table:\\\":{\\\"serde:\\\":\\\"org.apache.hadoop.hive.serde2.lazy.LazySimpleSerDe\\\",\\\"input format:\\\":\\\"org.apache.hadoop.mapred.TextInputFormat\\\",\\\"output format:\\\":\\\"org.apache.hadoop.hive.
 ql.io.HiveIgnoreKeyTextOutputFormat\\\"}}},\\\"Statistics:\\\":\\\"Num rows: 1 Data size: 8 Basic stats: COMPLETE Column stats: COMPLETE\\\"}},\\\"Statistics:\\\":\\\"Num rows: 1 Data size: 8 Basic stats: COMPLETE Column stats: COMPLETE\\\"}}},\\\"Map 1\\\":{\\\"Map Operator Tree:\\\":[{\\\"TableScan\\\":{\\\"alias:\\\":\\\"z\\\",\\\"children\\\":{\\\"Select Operator\\\":{\\\"children\\\":{\\\"Group By Operator\\\":{\\\"mode:\\\":\\\"hash\\\",\\\"aggregations:\\\":[\\\"count()\\\"],\\\"outputColumnNames:\\\":[\\\"_col0\\\"],\\\"children\\\":{\\\"Reduce Output Operator\\\":{\\\"sort order:\\\":\\\"\\\",\\\"value expressions:\\\":\\\"_col0 (type: bigint)\\\",\\\"Statistics:\\\":\\\"Num rows: 1 Data size: 8 Basic stats: COMPLETE Column stats: COMPLETE\\\"}},\\\"Statistics:\\\":\\\"Num rows: 1 Data size: 8 Basic stats: COMPLETE Column stats: COMPLETE\\\"}},\\\"Statistics:\\\":\\\"Num rows: 0 Data size: 40 Basic stats: PARTIAL Column stats: COMPLETE\\\"}},\\\"Statistics:\\\":\\\"Num rows
 : 0 Data size: 40 Basic stats: PARTIAL Column stats: COMPLETE\\\"}}]}},\\\"Edges:\\\":{\\\"Reducer 2\\\":{\\\"parent\\\":\\\"Map 1\\\",\\\"type\\\":\\\"SIMPLE_EDGE\\\"}}}},\\\"Stage-0\\\":{\\\"Fetch Operator\\\":{\\\"limit:\\\":\\\"-1\\\",\\\"Processor Tree:\\\":{\\\"ListSink\\\":{}}}}},\\\"STAGE DEPENDENCIES\\\":{\\\"Stage-1\\\":{\\\"ROOT STAGE\\\":\\\"TRUE\\\"},\\\"Stage-0\\\":{\\\"DEPENDENT STAGES\\\":\\\"Stage-1\\\"}}}}\",\n" +
-              "            \"STATUS\" : true,\n" +
-              "            \"TEZ\" : true\n" +
-              "          },\n" +
-              "        \"primaryfilters\" : { \"user\" : [ \"hive\" ] },\n" +
-              "        \"relatedentities\" : {  },\n" +
-              "        \"starttime\" : 1423493324355\n" +
-              "      } ] }"
-      );
-    }
-
-    @Override
-    public JSONObject hiveQueryIdByOperationId(String operationId) {
-      throw new NotImplementedException();
-    }
-
-    @Override
-    public JSONObject tezDagByName(String name) {
-      return (JSONObject) JSONValue.parse(
-          "{ \"entities\" : [ { \"domain\" : \"DEFAULT\",\n" +
-              "        \"entity\" : \"dag_1423156117563_0005_2\",\n" +
-              "        \"entitytype\" : \"TEZ_DAG_ID\",\n" +
-              "        \"events\" : [ { \"eventinfo\" : {  },\n" +
-              "              \"eventtype\" : \"DAG_FINISHED\",\n" +
-              "              \"timestamp\" : 1423493342484\n" +
-              "            },\n" +
-              "            { \"eventinfo\" : {  },\n" +
-              "              \"eventtype\" : \"DAG_STARTED\",\n" +
-              "              \"timestamp\" : 1423493325803\n" +
-              "            },\n" +
-              "            { \"eventinfo\" : {  },\n" +
-              "              \"eventtype\" : \"DAG_INITIALIZED\",\n" +
-              "              \"timestamp\" : 1423493325794\n" +
-              "            },\n" +
-              "            { \"eventinfo\" : {  },\n" +
-              "              \"eventtype\" : \"DAG_SUBMITTED\",\n" +
-              "              \"timestamp\" : 1423493325578\n" +
-              "            }\n" +
-              "          ],\n" +
-              "        \"otherinfo\" : { \"applicationId\" : \"application_1423156117563_0005\",\n" +
-              "            \"counters\" : { \"counterGroups\" : [ { \"counterGroupDisplayName\" : \"org.apache.tez.common.counters.DAGCounter\",\n" +
-              "                      \"counterGroupName\" : \"org.apache.tez.common.counters.DAGCounter\",\n" +
-              "                      \"counters\" : [ { \"counterDisplayName\" : \"NUM_SUCCEEDED_TASKS\",\n" +
-              "                            \"counterName\" : \"NUM_SUCCEEDED_TASKS\",\n" +
-              "                            \"counterValue\" : 2\n" +
-              "                          },\n" +
-              "                          { \"counterDisplayName\" : \"TOTAL_LAUNCHED_TASKS\",\n" +
-              "                            \"counterName\" : \"TOTAL_LAUNCHED_TASKS\",\n" +
-              "                            \"counterValue\" : 2\n" +
-              "                          },\n" +
-              "                          { \"counterDisplayName\" : \"DATA_LOCAL_TASKS\",\n" +
-              "                            \"counterName\" : \"DATA_LOCAL_TASKS\",\n" +
-              "                            \"counterValue\" : 1\n" +
-              "                          }\n" +
-              "                        ]\n" +
-              "                    },\n" +
-              "                    { \"counterGroupDisplayName\" : \"File System Counters\",\n" +
-              "                      \"counterGroupName\" : \"org.apache.tez.common.counters.FileSystemCounter\",\n" +
-              "                      \"counters\" : [ { \"counterDisplayName\" : \"FILE_BYTES_READ\",\n" +
-              "                            \"counterName\" : \"FILE_BYTES_READ\",\n" +
-              "                            \"counterValue\" : 57\n" +
-              "                          },\n" +
-              "                          { \"counterDisplayName\" : \"FILE_BYTES_WRITTEN\",\n" +
-              "                            \"counterName\" : \"FILE_BYTES_WRITTEN\",\n" +
-              "                            \"counterValue\" : 82\n" +
-              "                          },\n" +
-              "                          { \"counterDisplayName\" : \"FILE_READ_OPS\",\n" +
-              "                            \"counterName\" : \"FILE_READ_OPS\",\n" +
-              "                            \"counterValue\" : 0\n" +
-              "                          },\n" +
-              "                          { \"counterDisplayName\" : \"FILE_LARGE_READ_OPS\",\n" +
-              "                            \"counterName\" : \"FILE_LARGE_READ_OPS\",\n" +
-              "                            \"counterValue\" : 0\n" +
-              "                          },\n" +
-              "                          { \"counterDisplayName\" : \"FILE_WRITE_OPS\",\n" +
-              "                            \"counterName\" : \"FILE_WRITE_OPS\",\n" +
-              "                            \"counterValue\" : 0\n" +
-              "                          },\n" +
-              "                          { \"counterDisplayName\" : \"HDFS_BYTES_READ\",\n" +
-              "                            \"counterName\" : \"HDFS_BYTES_READ\",\n" +
-              "                            \"counterValue\" : 287\n" +
-              "                          },\n" +
-              "                          { \"counterDisplayName\" : \"HDFS_BYTES_WRITTEN\",\n" +
-              "                            \"counterName\" : \"HDFS_BYTES_WRITTEN\",\n" +
-              "                            \"counterValue\" : 2\n" +
-              "                          },\n" +
-              "                          { \"counterDisplayName\" : \"HDFS_READ_OPS\",\n" +
-              "                            \"counterName\" : \"HDFS_READ_OPS\",\n" +
-              "                            \"counterValue\" : 16\n" +
-              "                          },\n" +
-              "                          { \"counterDisplayName\" : \"HDFS_LARGE_READ_OPS\",\n" +
-              "                            \"counterName\" : \"HDFS_LARGE_READ_OPS\",\n" +
-              "                            \"counterValue\" : 0\n" +
-              "                          },\n" +
-              "                          { \"counterDisplayName\" : \"HDFS_WRITE_OPS\",\n" +
-              "                            \"counterName\" : \"HDFS_WRITE_OPS\",\n" +
-              "                            \"counterValue\" : 2\n" +
-              "                          }\n" +
-              "                        ]\n" +
-              "                    },\n" +
-              "                    { \"counterGroupDisplayName\" : \"org.apache.tez.common.counters.TaskCounter\",\n" +
-              "                      \"counterGroupName\" : \"org.apache.tez.common.counters.TaskCounter\",\n" +
-              "                      \"counters\" : [ { \"counterDisplayName\" : \"REDUCE_INPUT_GROUPS\",\n" +
-              "                            \"counterName\" : \"REDUCE_INPUT_GROUPS\",\n" +
-              "                            \"counterValue\" : 0\n" +
-              "                          },\n" +
-              "                          { \"counterDisplayName\" : \"REDUCE_INPUT_RECORDS\",\n" +
-              "                            \"counterName\" : \"REDUCE_INPUT_RECORDS\",\n" +
-              "                            \"counterValue\" : 1\n" +
-              "                          },\n" +
-              "                          { \"counterDisplayName\" : \"COMBINE_INPUT_RECORDS\",\n" +
-              "                            \"counterName\" : \"COMBINE_INPUT_RECORDS\",\n" +
-              "                            \"counterValue\" : 0\n" +
-              "                          },\n" +
-              "                          { \"counterDisplayName\" : \"SPILLED_RECORDS\",\n" +
-              "                            \"counterName\" : \"SPILLED_RECORDS\",\n" +
-              "                            \"counterValue\" : 2\n" +
-              "                          },\n" +
-              "                          { \"counterDisplayName\" : \"NUM_SHUFFLED_INPUTS\",\n" +
-              "                            \"counterName\" : \"NUM_SHUFFLED_INPUTS\",\n" +
-              "                            \"counterValue\" : 1\n" +
-              "                          },\n" +
-              "                          { \"counterDisplayName\" : \"NUM_SKIPPED_INPUTS\",\n" +
-              "                            \"counterName\" : \"NUM_SKIPPED_INPUTS\",\n" +
-              "                            \"counterValue\" : 0\n" +
-              "                          },\n" +
-              "                          { \"counterDisplayName\" : \"NUM_FAILED_SHUFFLE_INPUTS\",\n" +
-              "                            \"counterName\" : \"NUM_FAILED_SHUFFLE_INPUTS\",\n" +
-              "                            \"counterValue\" : 0\n" +
-              "                          },\n" +
-              "                          { \"counterDisplayName\" : \"MERGED_MAP_OUTPUTS\",\n" +
-              "                            \"counterName\" : \"MERGED_MAP_OUTPUTS\",\n" +
-              "                            \"counterValue\" : 1\n" +
-              "                          },\n" +
-              "                          { \"counterDisplayName\" : \"GC_TIME_MILLIS\",\n" +
-              "                            \"counterName\" : \"GC_TIME_MILLIS\",\n" +
-              "                            \"counterValue\" : 389\n" +
-              "                          },\n" +
-              "                          { \"counterDisplayName\" : \"CPU_MILLISECONDS\",\n" +
-              "                            \"counterName\" : \"CPU_MILLISECONDS\",\n" +
-              "                            \"counterValue\" : 2820\n" +
-              "                          },\n" +
-              "                          { \"counterDisplayName\" : \"PHYSICAL_MEMORY_BYTES\",\n" +
-              "                            \"counterName\" : \"PHYSICAL_MEMORY_BYTES\",\n" +
-              "                            \"counterValue\" : 490799104\n" +
-              "                          },\n" +
-              "                          { \"counterDisplayName\" : \"VIRTUAL_MEMORY_BYTES\",\n" +
-              "                            \"counterName\" : \"VIRTUAL_MEMORY_BYTES\",\n" +
-              "                            \"counterValue\" : 1558253568\n" +
-              "                          },\n" +
-              "                          { \"counterDisplayName\" : \"COMMITTED_HEAP_BYTES\",\n" +
-              "                            \"counterName\" : \"COMMITTED_HEAP_BYTES\",\n" +
-              "                            \"counterValue\" : 312475648\n" +
-              "                          },\n" +
-              "                          { \"counterDisplayName\" : \"INPUT_RECORDS_PROCESSED\",\n" +
-              "                            \"counterName\" : \"INPUT_RECORDS_PROCESSED\",\n" +
-              "                            \"counterValue\" : 3\n" +
-              "                          },\n" +
-              "                          { \"counterDisplayName\" : \"OUTPUT_RECORDS\",\n" +
-              "                            \"counterName\" : \"OUTPUT_RECORDS\",\n" +
-              "                            \"counterValue\" : 1\n" +
-              "                          },\n" +
-              "                          { \"counterDisplayName\" : \"OUTPUT_BYTES\",\n" +
-              "                            \"counterName\" : \"OUTPUT_BYTES\",\n" +
-              "                            \"counterValue\" : 3\n" +
-              "                          },\n" +
-              "                          { \"counterDisplayName\" : \"OUTPUT_BYTES_WITH_OVERHEAD\",\n" +
-              "                            \"counterName\" : \"OUTPUT_BYTES_WITH_OVERHEAD\",\n" +
-              "                            \"counterValue\" : 11\n" +
-              "                          },\n" +
-              "                          { \"counterDisplayName\" : \"OUTPUT_BYTES_PHYSICAL\",\n" +
-              "                            \"counterName\" : \"OUTPUT_BYTES_PHYSICAL\",\n" +
-              "                            \"counterValue\" : 25\n" +
-              "                          },\n" +
-              "                          { \"counterDisplayName\" : \"ADDITIONAL_SPILLS_BYTES_WRITTEN\",\n" +
-              "                            \"counterName\" : \"ADDITIONAL_SPILLS_BYTES_WRITTEN\",\n" +
-              "                            \"counterValue\" : 25\n" +
-              "                          },\n" +
-              "                          { \"counterDisplayName\" : \"ADDITIONAL_SPILLS_BYTES_READ\",\n" +
-              "                            \"counterName\" : \"ADDITIONAL_SPILLS_BYTES_READ\",\n" +
-              "                            \"counterValue\" : 25\n" +
-              "                          },\n" +
-              "                          { \"counterDisplayName\" : \"ADDITIONAL_SPILL_COUNT\",\n" +
-              "                            \"counterName\" : \"ADDITIONAL_SPILL_COUNT\",\n" +
-              "                            \"counterValue\" : 0\n" +
-              "                          },\n" +
-              "                          { \"counterDisplayName\" : \"SHUFFLE_BYTES\",\n" +
-              "                            \"counterName\" : \"SHUFFLE_BYTES\",\n" +
-              "                            \"counterValue\" : 25\n" +
-              "                          },\n" +
-              "                          { \"counterDisplayName\" : \"SHUFFLE_BYTES_DECOMPRESSED\",\n" +
-              "                            \"counterName\" : \"SHUFFLE_BYTES_DECOMPRESSED\",\n" +
-              "                            \"counterValue\" : 11\n" +
-              "                          },\n" +
-              "                          { \"counterDisplayName\" : \"SHUFFLE_BYTES_TO_MEM\",\n" +
-              "                            \"counterName\" : \"SHUFFLE_BYTES_TO_MEM\",\n" +
-              "                            \"counterValue\" : 25\n" +
-              "                          },\n" +
-              "                          { \"counterDisplayName\" : \"SHUFFLE_BYTES_TO_DISK\",\n" +
-              "                            \"counterName\" : \"SHUFFLE_BYTES_TO_DISK\",\n" +
-              "                            \"counterValue\" : 0\n" +
-              "                          },\n" +
-              "                          { \"counterDisplayName\" : \"SHUFFLE_BYTES_DISK_DIRECT\",\n" +
-              "                            \"counterName\" : \"SHUFFLE_BYTES_DISK_DIRECT\",\n" +
-              "                            \"counterValue\" : 0\n" +
-              "                          },\n" +
-              "                          { \"counterDisplayName\" : \"NUM_MEM_TO_DISK_MERGES\",\n" +
-              "                            \"counterName\" : \"NUM_MEM_TO_DISK_MERGES\",\n" +
-              "                            \"counterValue\" : 0\n" +
-              "                          },\n" +
-              "                          { \"counterDisplayName\" : \"NUM_DISK_TO_DISK_MERGES\",\n" +
-              "                            \"counterName\" : \"NUM_DISK_TO_DISK_MERGES\",\n" +
-              "                            \"counterValue\" : 0\n" +
-              "                          }\n" +
-              "                        ]\n" +
-              "                    },\n" +
-              "                    { \"counterGroupDisplayName\" : \"HIVE\",\n" +
-              "                      \"counterGroupName\" : \"HIVE\",\n" +
-              "                      \"counters\" : [ { \"counterDisplayName\" : \"CREATED_FILES\",\n" +
-              "                            \"counterName\" : \"CREATED_FILES\",\n" +
-              "                            \"counterValue\" : 1\n" +
-              "                          },\n" +
-              "                          { \"counterDisplayName\" : \"DESERIALIZE_ERRORS\",\n" +
-              "                            \"counterName\" : \"DESERIALIZE_ERRORS\",\n" +
-              "                            \"counterValue\" : 0\n" +
-              "                          },\n" +
-              "                          { \"counterDisplayName\" : \"RECORDS_IN_Map_1\",\n" +
-              "                            \"counterName\" : \"RECORDS_IN_Map_1\",\n" +
-              "                            \"counterValue\" : 3\n" +
-              "                          },\n" +
-              "                          { \"counterDisplayName\" : \"RECORDS_OUT_INTERMEDIATE_Map_1\",\n" +
-              "                            \"counterName\" : \"RECORDS_OUT_INTERMEDIATE_Map_1\",\n" +
-              "                            \"counterValue\" : 1\n" +
-              "                          },\n" +
-              "                          { \"counterDisplayName\" : \"RECORDS_OUT_Reducer_2\",\n" +
-              "                            \"counterName\" : \"RECORDS_OUT_Reducer_2\",\n" +
-              "                            \"counterValue\" : 1\n" +
-              "                          }\n" +
-              "                        ]\n" +
-              "                    },\n" +
-              "                    { \"counterGroupDisplayName\" : \"Shuffle Errors\",\n" +
-              "                      \"counterGroupName\" : \"Shuffle Errors\",\n" +
-              "                      \"counters\" : [ { \"counterDisplayName\" : \"BAD_ID\",\n" +
-              "                            \"counterName\" : \"BAD_ID\",\n" +
-              "                            \"counterValue\" : 0\n" +
-              "                          },\n" +
-              "                          { \"counterDisplayName\" : \"CONNECTION\",\n" +
-              "                            \"counterName\" : \"CONNECTION\",\n" +
-              "                            \"counterValue\" : 0\n" +
-              "                          },\n" +
-              "                          { \"counterDisplayName\" : \"IO_ERROR\",\n" +
-              "                            \"counterName\" : \"IO_ERROR\",\n" +
-              "                            \"counterValue\" : 0\n" +
-              "                          },\n" +
-              "                          { \"counterDisplayName\" : \"WRONG_LENGTH\",\n" +
-              "                            \"counterName\" : \"WRONG_LENGTH\",\n" +
-              "                            \"counterValue\" : 0\n" +
-              "                          },\n" +
-              "                          { \"counterDisplayName\" : \"WRONG_MAP\",\n" +
-              "                            \"counterName\" : \"WRONG_MAP\",\n" +
-              "                            \"counterValue\" : 0\n" +
-              "                          },\n" +
-              "                          { \"counterDisplayName\" : \"WRONG_REDUCE\",\n" +
-              "                            \"counterName\" : \"WRONG_REDUCE\",\n" +
-              "                            \"counterValue\" : 0\n" +
-              "                          }\n" +
-              "                        ]\n" +
-              "                    }\n" +
-              "                  ] },\n" +
-              "            \"dagPlan\" : { \"dagName\" : \"hive_20150209144848_c3a5a07b-c3b6-4f57-a6d5-3dadecdd6fd0:4\",\n" +
-              "                \"edges\" : [ { \"dataMovementType\" : \"SCATTER_GATHER\",\n" +
-              "                      \"dataSourceType\" : \"PERSISTED\",\n" +
-              "                      \"edgeDestinationClass\" : \"org.apache.tez.runtime.library.input.OrderedGroupedKVInput\",\n" +
-              "                      \"edgeId\" : \"533454263\",\n" +
-              "                      \"edgeSourceClass\" : \"org.apache.tez.runtime.library.output.OrderedPartitionedKVOutput\",\n" +
-              "                      \"inputVertexName\" : \"Map 1\",\n" +
-              "                      \"outputVertexName\" : \"Reducer 2\",\n" +
-              "                      \"schedulingType\" : \"SEQUENTIAL\"\n" +
-              "                    } ],\n" +
-              "                \"version\" : 1,\n" +
-              "                \"vertices\" : [ { \"additionalInputs\" : [ { \"class\" : \"org.apache.tez.mapreduce.input.MRInputLegacy\",\n" +
-              "                            \"initializer\" : \"org.apache.hadoop.hive.ql.exec.tez.HiveSplitGenerator\",\n" +
-              "                            \"name\" : \"z\"\n" +
-              "                          } ],\n" +
-              "                      \"outEdgeIds\" : [ \"533454263\" ],\n" +
-              "                      \"processorClass\" : \"org.apache.hadoop.hive.ql.exec.tez.MapTezProcessor\",\n" +
-              "                      \"vertexName\" : \"Map 1\"\n" +
-              "                    },\n" +
-              "                    { \"additionalOutputs\" : [ { \"class\" : \"org.apache.tez.mapreduce.output.MROutput\",\n" +
-              "                            \"name\" : \"out_Reducer 2\"\n" +
-              "                          } ],\n" +
-              "                      \"inEdgeIds\" : [ \"533454263\" ],\n" +
-              "                      \"processorClass\" : \"org.apache.hadoop.hive.ql.exec.tez.ReduceTezProcessor\",\n" +
-              "                      \"vertexName\" : \"Reducer 2\"\n" +
-              "                    }\n" +
-              "                  ]\n" +
-              "              },\n" +
-              "            \"diagnostics\" : \"\",\n" +
-              "            \"endTime\" : 1423493342484,\n" +
-              "            \"initTime\" : 1423493325794,\n" +
-              "            \"numCompletedTasks\" : 2,\n" +
-              "            \"numFailedTaskAttempts\" : 0,\n" +
-              "            \"numFailedTasks\" : 0,\n" +
-              "            \"numKilledTaskAttempts\" : 0,\n" +
-              "            \"numKilledTasks\" : 0,\n" +
-              "            \"numSucceededTasks\" : 2,\n" +
-              "            \"startTime\" : 1423493325803,\n" +
-              "            \"status\" : \"SUCCEEDED\",\n" +
-              "            \"timeTaken\" : 16681,\n" +
-              "            \"vertexNameIdMapping\" : { \"Map 1\" : \"vertex_1423156117563_0005_2_00\",\n" +
-              "                \"Reducer 2\" : \"vertex_1423156117563_0005_2_01\"\n" +
-              "              }\n" +
-              "          },\n" +
-              "        \"primaryfilters\" : { \"applicationId\" : [ \"application_1423156117563_0005\" ],\n" +
-              "            \"dagName\" : [ \"hive_20150209144848_c3a5a07b-c3b6-4f57-a6d5-3dadecdd6fd0:4\" ],\n" +
-              "            \"status\" : [ \"SUCCEEDED\" ],\n" +
-              "            \"user\" : [ \"hive\" ]\n" +
-              "          },\n" +
-              "        \"relatedentities\" : {  },\n" +
-              "        \"starttime\" : 1423493325578\n" +
-              "      } ] }"
-      );
-    }
-
-    @Override
-    public JSONObject tezVerticesListForDAG(String dagId) {
-      return null;
-    }
-
-    @Override
-    public JSONObject tezDagByEntity(String entity) {
-      return tezDagByName(entity);
-    }
-  }
-}
\ No newline at end of file

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/resources/jobs/AggregatorTest.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/resources/jobs/AggregatorTest.java b/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/resources/jobs/AggregatorTest.java
deleted file mode 100644
index 91478e7..0000000
--- a/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/resources/jobs/AggregatorTest.java
+++ /dev/null
@@ -1,506 +0,0 @@
-/**
- * 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.ambari.view.hive.resources.jobs;
-
-import org.apache.ambari.view.hive.persistence.utils.FilteringStrategy;
-import org.apache.ambari.view.hive.persistence.utils.ItemNotFound;
-import org.apache.ambari.view.hive.resources.IResourceManager;
-import org.apache.ambari.view.hive.resources.jobs.atsJobs.HiveQueryId;
-import org.apache.ambari.view.hive.resources.jobs.atsJobs.IATSParser;
-import org.apache.ambari.view.hive.resources.jobs.atsJobs.TezDagId;
-import org.apache.ambari.view.hive.resources.jobs.atsJobs.TezVertexId;
-import org.apache.ambari.view.hive.resources.jobs.viewJobs.Job;
-import org.apache.ambari.view.hive.resources.jobs.viewJobs.JobImpl;
-import org.apache.hive.service.cli.thrift.TOperationHandle;
-import org.junit.Assert;
-import org.junit.Test;
-
-import java.util.Arrays;
-import java.util.HashMap;
-import java.util.Iterator;
-import java.util.LinkedList;
-import java.util.List;
-
-public class AggregatorTest {
-
-  public static final String SOME_QUERY = "some query";
-
-  @Test
-  public void testReadJobOutsideOfHS2() throws Exception {
-    HiveQueryId hiveQueryId = getSampleHiveQueryId("ENTITY-NAME");
-    ensureOperationIdUnset(hiveQueryId);
-
-    MockATSParser atsParser = getMockATSWithQueries(hiveQueryId);
-
-
-    Aggregator aggregator = new Aggregator(getEmptyJobResourceManager(),
-        getEmptyOperationHandleResourceManager(),
-        atsParser);
-
-    List<Job> aggregated = aggregator.readAll("luke");
-
-    Assert.assertEquals(1, aggregated.size());
-    Job job = aggregated.get(0);
-    Assert.assertEquals("ENTITY-NAME", job.getId());
-    Assert.assertEquals(SOME_QUERY, job.getTitle());
-  }
-
-  @Test
-  public void testReadJobWithHS2OutsideOfView() throws Exception {
-    HiveQueryId hiveQueryId = getSampleHiveQueryId("ENTITY-NAME");
-    ensureOperationIdUnset(hiveQueryId);
-
-    MockATSParser atsParser = getMockATSWithQueries(hiveQueryId);
-    Aggregator aggregator = new Aggregator(getEmptyJobResourceManager(),
-        getEmptyOperationHandleResourceManager(),
-        atsParser);
-
-    List<Job> aggregated = aggregator.readAll("luke");
-
-    Assert.assertEquals(1, aggregated.size());
-    Job job = aggregated.get(0);
-    Assert.assertEquals("ENTITY-NAME", job.getId());
-    Assert.assertEquals(SOME_QUERY, job.getTitle());
-  }
-
-  @Test
-  public void testJobWithoutOperationIdShouldBeIgnored() throws Exception {
-    MockJobResourceManager jobResourceManager = getJobResourceManagerWithJobs(getSampleViewJob("1"));
-
-    Aggregator aggregator = new Aggregator(jobResourceManager,
-        getEmptyOperationHandleResourceManager(),
-        getEmptyATSParser());
-
-    List<Job> aggregated = aggregator.readAll("luke");
-
-    Assert.assertEquals(0, aggregated.size());
-  }
-
-  @Test
-  public void testReadJobOnlyInView() throws Exception {
-    MockJobResourceManager jobResourceManager = getJobResourceManagerWithJobs(getSampleViewJob("1"));
-
-    StoredOperationHandle operationHandle = getSampleOperationHandle("5", "1");
-    MockOperationHandleResourceManager operationHandleResourceManager = getOperationHandleRMWithEntities(Arrays.asList(operationHandle), null);
-
-    Aggregator aggregator = new Aggregator(jobResourceManager,
-        operationHandleResourceManager,
-        getEmptyATSParser());
-
-    List<Job> aggregated = aggregator.readAll("luke");
-
-    Assert.assertEquals(1, aggregated.size());
-    Job job = aggregated.get(0);
-    Assert.assertEquals("1", job.getId());
-  }
-
-  private MockOperationHandleResourceManager getOperationHandleRMWithEntities(List<StoredOperationHandle> operationHandles, List<Job> jobs) {
-    MockOperationHandleResourceManager operationHandleResourceManager = getEmptyOperationHandleResourceManager();
-    HashMap<String, StoredOperationHandle> storage = new HashMap<String, StoredOperationHandle>();
-    for (StoredOperationHandle handle : operationHandles) {
-      storage.put(handle.getJobId(), handle);
-    }
-    if (null != jobs) {
-      Iterator<Job> jobIterator = jobs.iterator();
-      HashMap<String, Job> jobStorage = new HashMap<String, Job>();
-      for (StoredOperationHandle handle : operationHandles) {
-        jobStorage.put(handle.getGuid(), jobIterator.next());
-        operationHandleResourceManager.setJobStorage(jobStorage);
-      }
-    }
-    operationHandleResourceManager.setStorage(storage);
-
-    return operationHandleResourceManager;
-  }
-
-  @Test
-  public void testReadJobBothATSAndView() throws Exception {
-    HiveQueryId hiveQueryId = getSampleHiveQueryId("ENTITY-NAME");
-    hiveQueryId.operationId = Aggregator.hexStringToUrlSafeBase64("1b2b");
-    MockATSParser atsParser = getMockATSWithQueries(hiveQueryId);
-
-    Job job1 = getSampleViewJob("1");
-    MockJobResourceManager jobResourceManager = getJobResourceManagerWithJobs(job1);
-
-    StoredOperationHandle operationHandle = getSampleOperationHandle("5", "1");
-    operationHandle.setGuid("1b2b");
-    MockOperationHandleResourceManager operationHandleResourceManager = getOperationHandleRMWithEntities(Arrays.asList(operationHandle), Arrays.asList(job1));
-
-    Aggregator aggregator = new Aggregator(jobResourceManager,
-        operationHandleResourceManager,
-        atsParser);
-
-    List<Job> aggregated = aggregator.readAll("luke");
-
-    Assert.assertEquals(1, aggregated.size());
-    Job job = aggregated.get(0);
-    Assert.assertEquals("1", job.getId());
-  }
-
-  @Test
-  public void testReadJobBothATSAndViewV2() throws Exception {
-    HiveQueryId hiveQueryId = getSampleHiveQueryIdV2("ENTITY-NAME");
-    hiveQueryId.operationId = Aggregator.hexStringToUrlSafeBase64("1b2b");
-    MockATSParser atsParser = getMockATSWithQueries(hiveQueryId);
-
-    Job job1 = getSampleViewJob("1");
-    MockJobResourceManager jobResourceManager = getJobResourceManagerWithJobs(job1);
-
-    StoredOperationHandle operationHandle = getSampleOperationHandle("5", "1");
-    operationHandle.setGuid("1b2b");
-    MockOperationHandleResourceManager operationHandleResourceManager = getOperationHandleRMWithEntities(Arrays.asList(operationHandle), Arrays.asList(job1));
-
-    Aggregator aggregator = new Aggregator(jobResourceManager,
-      operationHandleResourceManager,
-      atsParser);
-
-    List<Job> aggregated = aggregator.readAll("luke");
-
-    Assert.assertEquals(1, aggregated.size());
-    Job job = aggregated.get(0);
-    Assert.assertEquals("1", job.getId());
-    Assert.assertEquals("app_test_1", job.getApplicationId());
-    Assert.assertEquals("ENTITY-NAME", job.getDagId());
-    Assert.assertEquals("SUCCEEDED", job.getStatus());
-  }
-
-
-  @Test
-  public void testReadJobComplex() throws Exception {
-    //job both on ATS and View
-    HiveQueryId hiveQueryId1 = getSampleHiveQueryId("ENTITY-NAME");
-    hiveQueryId1.operationId = Aggregator.hexStringToUrlSafeBase64("1a1b");
-    Job job1 = getSampleViewJob("1");
-    Job job2 = getSampleViewJob("2");
-    StoredOperationHandle operationHandle1 = getSampleOperationHandle("5", "1");
-    operationHandle1.setGuid("1a1b");
-    StoredOperationHandle operationHandle2 = getSampleOperationHandle("5", "2");
-    operationHandle2.setGuid("2a2b");
-    //job only on ATS
-    HiveQueryId hiveQueryId2 = getSampleHiveQueryId("ENTITY-NAME2");
-    hiveQueryId2.operationId = Aggregator.hexStringToUrlSafeBase64("2a2b");
-
-    //job only in View
-    Job job3 = getSampleViewJob("3");
-    StoredOperationHandle operationHandle3 = getSampleOperationHandle("6", "3");
-    operationHandle3.setGuid("3c3d");
-
-
-    MockATSParser atsParser = getMockATSWithQueries(
-        hiveQueryId1, hiveQueryId2);
-    MockJobResourceManager jobResourceManager = getJobResourceManagerWithJobs(
-        job1, job3);
-    MockOperationHandleResourceManager operationHandleRM = getOperationHandleRMWithEntities(Arrays.asList(
-      operationHandle1, operationHandle2, operationHandle3), Arrays.asList(job1, job2, job3));
-
-    Aggregator aggregator = new Aggregator(jobResourceManager,
-        operationHandleRM,
-        atsParser);
-
-    List<Job> aggregated = aggregator.readAll("luke");
-
-    Assert.assertEquals(3, aggregated.size());
-  }
-
-  private MockJobResourceManager getJobResourceManagerWithJobs(Job... jobs) {
-    MockJobResourceManager jobResourceManager = getEmptyJobResourceManager();
-    jobResourceManager.setJobs(Arrays.asList(jobs));
-    return jobResourceManager;
-  }
-
-  private MockATSParser getEmptyATSParser() {
-    return new MockATSParser();
-  }
-
-  private void ensureOperationIdUnset(HiveQueryId hiveQueryId) {
-    hiveQueryId.operationId = null;
-  }
-
-  public void ensureOperationIdSet(HiveQueryId hiveQueryId) {
-    hiveQueryId.operationId = "operation-id";
-  }
-
-  private MockOperationHandleResourceManager getEmptyOperationHandleResourceManager() {
-    return new MockOperationHandleResourceManager();
-  }
-
-  private MockJobResourceManager getEmptyJobResourceManager() {
-    return new MockJobResourceManager();
-  }
-
-  private MockATSParser getMockATSWithQueries(HiveQueryId... hiveQueryIds) {
-    MockATSParser atsParser = getEmptyATSParser();
-    atsParser.setHiveQueryIds(Arrays.asList(hiveQueryIds));
-    return atsParser;
-  }
-
-  private JobImpl getSampleViewJob(String id) {
-    JobImpl job = new JobImpl();
-    job.setTitle("Test");
-    job.setId(id);
-    job.setOwner("luke");
-    return job;
-  }
-
-  private StoredOperationHandle getSampleOperationHandle(String id, String jobId) {
-    StoredOperationHandle opHandle = new StoredOperationHandle();
-    opHandle.setId(id);
-    opHandle.setJobId(jobId);
-    opHandle.setGuid("1b2b");
-    return opHandle;
-  }
-
-  private HiveQueryId getSampleHiveQueryId(String id) {
-    HiveQueryId hiveQueryId = new HiveQueryId();
-    hiveQueryId.entity = id;
-    hiveQueryId.query = SOME_QUERY;
-    hiveQueryId.user = "luke";
-    hiveQueryId.operationId = "fUjdt-VMRYuKRPCDTUr_rg";
-    hiveQueryId.dagNames = new LinkedList<String>();
-    return hiveQueryId;
-  }
-
-  private HiveQueryId getSampleHiveQueryIdV2(String id) {
-    HiveQueryId hiveQueryId = getSampleHiveQueryId(id);
-    hiveQueryId.version = HiveQueryId.ATS_15_RESPONSE_VERSION;
-    return hiveQueryId;
-  }
-
-  @Test
-  public void testGetJobByOperationId() throws Exception {
-
-  }
-
-  @Test
-  public void testUrlSafeBase64ToHexString() throws Exception {
-    String urlSafe = Aggregator.hexStringToUrlSafeBase64("1a1b");
-    Assert.assertEquals("Ghs", urlSafe);
-  }
-
-  @Test
-  public void testHexStringToUrlSafeBase64() throws Exception {
-    String hex = Aggregator.urlSafeBase64ToHexString("Ghs");
-    Assert.assertEquals("1a1b", hex);
-  }
-
-  public static class MockJobResourceManager implements IResourceManager<Job> {
-
-    private List<Job> jobs = new LinkedList<Job>();
-
-    @Override
-    public Job create(Job object) {
-      return null;
-    }
-
-    @Override
-    public Job read(Object id) throws ItemNotFound {
-      for(Job job : jobs) {
-        if (job.getId().equals(id)) {
-          return job;
-        }
-      }
-      throw new ItemNotFound();
-    }
-
-    @Override
-    public List<Job> readAll(FilteringStrategy filteringStrategy) {
-      return jobs;
-    }
-
-    @Override
-    public Job update(Job newObject, String id) throws ItemNotFound {
-      return null;
-    }
-
-    @Override
-    public void delete(Object resourceId) throws ItemNotFound {
-
-    }
-
-    public List<Job> getJobs() {
-      return jobs;
-    }
-
-    public void setJobs(List<Job> jobs) {
-      this.jobs = jobs;
-    }
-  }
-
-  public static class MockOperationHandleResourceManager implements IOperationHandleResourceManager {
-    private HashMap<String, StoredOperationHandle> storage = new HashMap<String, StoredOperationHandle>();
-    private HashMap<String, Job> jobStorage = new HashMap<>();
-
-    public MockOperationHandleResourceManager() {
-
-    }
-
-    @Override
-    public List<StoredOperationHandle> readJobRelatedHandles(Job job) {
-      LinkedList<StoredOperationHandle> storedOperationHandles = new LinkedList<StoredOperationHandle>();
-      StoredOperationHandle operationHandle = storage.get(job.getId());
-      if (operationHandle != null)
-        storedOperationHandles.add(operationHandle);
-      return storedOperationHandles;
-    }
-
-    @Override
-    public List<Job> getHandleRelatedJobs(StoredOperationHandle operationHandle) {
-      return new LinkedList<Job>();
-    }
-
-    @Override
-    public Job getJobByHandle(StoredOperationHandle handle) throws ItemNotFound {
-      return jobStorage.get(handle.getGuid());
-    }
-
-    @Override
-    public void putHandleForJob(TOperationHandle h, Job job) {
-
-    }
-
-    @Override
-    public boolean containsHandleForJob(Job job) {
-      return false;
-    }
-
-    @Override
-    public StoredOperationHandle getHandleForJob(Job job) throws ItemNotFound {
-      List<StoredOperationHandle> handles = readJobRelatedHandles(job);
-      if (handles.size() == 0)
-        throw new ItemNotFound();
-      return handles.get(0);
-    }
-
-    @Override
-    public StoredOperationHandle create(StoredOperationHandle object) {
-      return null;
-    }
-
-    @Override
-    public StoredOperationHandle read(Object id) throws ItemNotFound {
-      return null;
-    }
-
-    @Override
-    public List<StoredOperationHandle> readAll(FilteringStrategy filteringStrategy) {
-      LinkedList<StoredOperationHandle> storedOperationHandles = new LinkedList<StoredOperationHandle>();
-      for (StoredOperationHandle handle : storage.values()) {
-        if (filteringStrategy.isConform(handle))
-          storedOperationHandles.add(handle);
-      }
-      return storedOperationHandles;
-    }
-
-    @Override
-    public StoredOperationHandle update(StoredOperationHandle newObject, String id) throws ItemNotFound {
-      return null;
-    }
-
-    @Override
-    public void delete(Object resourceId) throws ItemNotFound {
-
-    }
-
-    public HashMap<String, StoredOperationHandle> getStorage() {
-      return storage;
-    }
-
-    public void setStorage(HashMap<String, StoredOperationHandle> storage) {
-      this.storage = storage;
-    }
-
-    public HashMap<String, Job> getJobStorage() {
-      return jobStorage;
-    }
-
-    public void setJobStorage(HashMap<String, Job> jobStorage) {
-      this.jobStorage = jobStorage;
-    }
-  }
-
-  public static class MockATSParser implements IATSParser {
-
-    private List<HiveQueryId> hiveQueryIds = new LinkedList<HiveQueryId>();
-
-    public MockATSParser() {
-    }
-
-    @Override
-    public List<HiveQueryId> getHiveQueryIdsForUser(String username) {
-      return hiveQueryIds;
-    }
-
-    @Override
-    public List<TezVertexId> getVerticesForDAGId(String dagId) {
-      List<TezVertexId> vertices = new LinkedList<TezVertexId>();
-      TezVertexId tezVertexId1 = new TezVertexId();
-      tezVertexId1.entity = "vertex_1234567_99_99_01";
-      tezVertexId1.vertexName = "Map 1";
-      vertices.add(tezVertexId1);
-
-      TezVertexId tezVertexId2 = new TezVertexId();
-      tezVertexId2.entity = "vertex_1234567_99_99_00";
-      tezVertexId2.vertexName = "Reduce 1";
-      vertices.add(tezVertexId2);
-      return vertices;
-    }
-
-    @Override
-    public HiveQueryId getHiveQueryIdByOperationId(String guid) {
-      return new HiveQueryId();
-    }
-
-    @Override
-    public TezDagId getTezDAGByName(String name) {
-      return new TezDagId();
-    }
-
-    @Override
-    public TezDagId getTezDAGByEntity(String entity) {
-      TezDagId dagId = new TezDagId();
-      dagId.applicationId = "app_test_1";
-      dagId.entity = entity;
-      dagId.status = "SUCCEEDED";
-      return dagId;
-    }
-
-    @Override
-    public List<HiveQueryId> getHiveQueryIdsForUserByTime(String username, long startTime, long endTime) {
-      return null;
-    }
-
-    @Override
-    public HiveQueryId getHiveQueryIdByHiveEntityId(String hiveEntityId) {
-      return null;
-    }
-
-    @Override
-    public List<HiveQueryId> getHiveQueryIdByEntityList(List<String> hiveEntityIds) {
-      return null;
-    }
-
-    public List<HiveQueryId> getHiveQueryIds() {
-      return hiveQueryIds;
-    }
-
-    public void setHiveQueryIds(List<HiveQueryId> hiveQueryIds) {
-      this.hiveQueryIds = hiveQueryIds;
-    }
-  }
-}
\ No newline at end of file

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/resources/jobs/JobLDAPServiceTest.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/resources/jobs/JobLDAPServiceTest.java b/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/resources/jobs/JobLDAPServiceTest.java
deleted file mode 100644
index dfdcb34..0000000
--- a/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/resources/jobs/JobLDAPServiceTest.java
+++ /dev/null
@@ -1,159 +0,0 @@
-/**
- * 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.ambari.view.hive.resources.jobs;
-
-import org.apache.ambari.view.hive.BaseHiveTest;
-import org.apache.ambari.view.hive.ServiceTestUtils;
-import org.apache.ambari.view.hive.client.Connection;
-import org.apache.ambari.view.hive.client.HiveAuthRequiredException;
-import org.apache.ambari.view.hive.resources.jobs.viewJobs.JobImpl;
-import org.apache.ambari.view.hive.utils.HdfsApiMock;
-import org.apache.ambari.view.utils.UserLocal;
-import org.apache.ambari.view.utils.hdfs.HdfsApi;
-import org.apache.ambari.view.utils.hdfs.HdfsApiException;
-import org.hamcrest.BaseMatcher;
-import org.hamcrest.Description;
-import org.json.simple.JSONObject;
-import org.junit.*;
-import org.junit.rules.ExpectedException;
-
-import javax.ws.rs.WebApplicationException;
-import java.io.File;
-import java.io.IOException;
-import java.util.HashMap;
-import java.util.Map;
-
-import static org.easymock.EasyMock.*;
-
-public class JobLDAPServiceTest extends BaseHiveTest {
-  private JobService jobService;
-  @Rule public ExpectedException thrown = ExpectedException.none();
-
-  @BeforeClass
-  public static void startUp() throws Exception {
-    BaseHiveTest.startUp(); // super
-  }
-
-  @AfterClass
-  public static void shutDown() throws Exception {
-    BaseHiveTest.shutDown(); // super
-  }
-
-  @Override
-  @After
-  public void tearDown() throws Exception {
-    jobService.getSharedObjectsFactory().clear(HdfsApi.class);
-  }
-
-  @Override
-  protected void setupProperties(Map<String, String> properties, File baseDir) throws Exception {
-    super.setupProperties(properties, baseDir);
-    properties.put("hive.transport.mode", "binary");
-    properties.put("hive.host", "127.0.0.1");
-    properties.put("hive.port", "42420");
-
-    properties.put("scripts.dir", "/tmp/.hiveQueries");
-    properties.put("jobs.dir", "/tmp/.hiveJobs");
-  }
-
-  private HdfsApiMock setupHdfsApiMock() throws IOException, InterruptedException, HdfsApiException {
-    HdfsApiMock hdfsApiMock = new HdfsApiMock("select * from Z");
-    HdfsApi hdfsApi = hdfsApiMock.getHdfsApi();
-    jobService.getSharedObjectsFactory().setInstance(HdfsApi.class, hdfsApi);
-    replay(hdfsApi);
-    return hdfsApiMock;
-  }
-
-  @Test
-  public void createJobNoPasswordProvided() throws Exception {
-    UserLocal.dropAllConnections(Connection.class);
-    Map<String, String> properties = new HashMap<String, String>();
-    properties.put("hive.auth", "auth=NONE;password=${ask_password}");
-    context = makeContext(properties, "ambari-qa-1", "MyHive");
-    replay(context);
-    jobService = getService(JobService.class, handler, context);
-    setupHdfsApiMock();
-
-    JobService.JobRequest request = new JobService.JobRequest();
-    request.job = new JobImpl();
-    request.job.setForcedContent("Hello world");
-
-    thrown.expect(HiveAuthRequiredException.class);
-    jobService.create(request,
-        ServiceTestUtils.getResponseWithLocation(), ServiceTestUtils.getDefaultUriInfo());
-  }
-
-  @Test
-  public void createJobNoPasswordRequired() throws Exception {
-    Map<String, String> properties = new HashMap<String, String>();
-    properties.put("hive.auth", "auth=NONE");
-    context = makeContext(properties, "ambari-qa-2", "MyHive");
-    replay(context);
-    jobService = getService(JobService.class, handler, context);
-    setupHdfsApiMock();
-
-    JobService.JobRequest request = new JobService.JobRequest();
-    request.job = new JobImpl();
-    request.job.setForcedContent("Hello world");
-
-    thrown.expect(new ExpectedJSONErrorMessage("Connection refused"));
-    jobService.create(request,
-        ServiceTestUtils.getResponseWithLocation(), ServiceTestUtils.getDefaultUriInfo());
-  }
-
-  @Test
-  public void createJobPasswordProvided() throws Exception {
-    Map<String, String> properties = new HashMap<String, String>();
-    properties.put("hive.auth", "auth=NONE;password=${ask_password}");
-    context = makeContext(properties, "ambari-qa-3", "MyHive");
-    replay(context);
-    jobService = getService(JobService.class, handler, context);
-    setupHdfsApiMock();
-
-    JobService.JobRequest request = new JobService.JobRequest();
-    request.job = new JobImpl();
-    request.job.setForcedContent("Hello world");
-
-    JobService.AuthRequest authRequest = new JobService.AuthRequest();
-    authRequest.password = "ok";
-
-    thrown.expect(new ExpectedJSONErrorMessage("Connection refused"));
-    jobService.setupPassword(authRequest);
-  }
-
-  private static class ExpectedJSONErrorMessage extends BaseMatcher<WebApplicationException> {
-    private String expectedMessage;
-
-    public ExpectedJSONErrorMessage(String message) {
-      this.expectedMessage = message;
-    }
-
-    @Override
-    public void describeTo(Description description) {
-      description.appendText(this.expectedMessage);
-    }
-
-    @Override
-    public boolean matches(Object o) {
-      JSONObject response = (JSONObject) ((WebApplicationException) o).getResponse().getEntity();
-      String message = (String) response.get("message");
-      return message.contains(expectedMessage);
-    }
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/resources/jobs/JobServiceTest.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/resources/jobs/JobServiceTest.java b/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/resources/jobs/JobServiceTest.java
deleted file mode 100644
index 55c62e7..0000000
--- a/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/resources/jobs/JobServiceTest.java
+++ /dev/null
@@ -1,225 +0,0 @@
-/**
- * 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.ambari.view.hive.resources.jobs;
-
-import org.apache.ambari.view.hive.ServiceTestUtils;
-import org.apache.ambari.view.hive.BaseHiveTest;
-import org.apache.ambari.view.hive.client.UserLocalConnection;
-import org.apache.ambari.view.hive.resources.jobs.viewJobs.JobImpl;
-import org.apache.ambari.view.hive.utils.HdfsApiMock;
-import org.apache.ambari.view.hive.client.Connection;
-import org.apache.ambari.view.hive.client.HiveClientException;
-import org.apache.ambari.view.hive.resources.savedQueries.SavedQuery;
-import org.apache.ambari.view.hive.resources.savedQueries.SavedQueryService;
-import org.apache.ambari.view.hive.utils.BadRequestFormattedException;
-import org.apache.ambari.view.utils.hdfs.HdfsApi;
-import org.apache.ambari.view.utils.hdfs.HdfsApiException;
-import org.apache.hive.service.cli.thrift.*;
-import org.json.simple.JSONObject;
-import org.junit.*;
-import org.junit.rules.ExpectedException;
-
-import javax.ws.rs.core.Response;
-import java.io.File;
-import java.io.IOException;
-import java.util.Map;
-
-import static org.easymock.EasyMock.*;
-
-public class JobServiceTest extends BaseHiveTest {
-  private SavedQueryService savedQueryService;
-  private JobService jobService;
-  @Rule public ExpectedException thrown = ExpectedException.none();
-
-  @BeforeClass
-  public static void startUp() throws Exception {
-    BaseHiveTest.startUp(); // super
-  }
-
-  @AfterClass
-  public static void shutDown() throws Exception {
-    BaseHiveTest.shutDown(); // super
-  }
-
-  @Override
-  @After
-  public void tearDown() throws Exception {
-    jobService.getSharedObjectsFactory().clear(HdfsApi.class);
-  }
-
-  @Override
-  @Before
-  public void setUp() throws Exception {
-    super.setUp();
-    savedQueryService = getService(SavedQueryService.class, handler, context);
-    jobService = getService(JobService.class, handler, context);
-
-    Connection hiveConnection = configureHiveConnectionMock();
-
-    new UserLocalConnection().set(hiveConnection, context);
-    jobService.setAggregator(
-        new Aggregator(
-            jobService.getResourceManager(),
-            jobService.getOperationHandleResourceManager(),
-            new AggregatorTest.MockATSParser())
-    );
-  }
-
-  @Test
-  public void createJobFromQuery() throws IOException, InterruptedException, HdfsApiException {
-    setupHdfsApiMock();
-
-    SavedQuery savedQueryForJob = createSavedQuery("Test", null);
-    JobService.JobRequest jobCreationRequest = new JobService.JobRequest();
-    jobCreationRequest.job = new JobImpl();
-    jobCreationRequest.job.setQueryId(savedQueryForJob.getId());
-
-    Response response = jobService.create(jobCreationRequest,
-        ServiceTestUtils.getResponseWithLocation(), ServiceTestUtils.getDefaultUriInfo());
-    ServiceTestUtils.assertHTTPResponseCreated(response);
-    JSONObject jobObj = (JSONObject)response.getEntity();
-
-
-    assertResponseJobSanity(jobObj);
-    Assert.assertEquals(getFieldFromJobJSON(jobObj, "queryId"), savedQueryForJob.getId());
-  }
-
-  @Test
-  public void createJobForcedContent() throws IOException, InterruptedException, HdfsApiException {
-    HdfsApiMock hdfsApiMock = setupHdfsApiMock();
-
-    JobService.JobRequest request = new JobService.JobRequest();
-    request.job = new JobImpl();
-    request.job.setForcedContent("Hello world");
-
-
-    Response response = jobService.create(request,
-        ServiceTestUtils.getResponseWithLocation(), ServiceTestUtils.getDefaultUriInfo());
-    ServiceTestUtils.assertHTTPResponseCreated(response);
-    JSONObject jobObj = (JSONObject)response.getEntity();
-
-
-    assertResponseJobSanity(jobObj);
-    Assert.assertNull(getFieldFromJobJSON(jobObj, "queryId"));
-    Assert.assertEquals("", getFieldFromJobJSON(jobObj, "forcedContent"));
-    Assert.assertEquals("Hello world", hdfsApiMock.getQueryOutputStream().toString());
-  }
-
-  @Test
-  public void createJobNoSource() throws IOException, InterruptedException {
-    HdfsApi hdfsApi = createNiceMock(HdfsApi.class);
-    expect(hdfsApi.mkdir(anyString())).andReturn(true).anyTimes();
-    jobService.getSharedObjectsFactory().setInstance(HdfsApi.class, hdfsApi);
-    replay(hdfsApi);
-
-    JobService.JobRequest request = new JobService.JobRequest();
-    request.job = new JobImpl();
-    request.job.setForcedContent(null);
-    request.job.setQueryId(null);
-
-    thrown.expect(BadRequestFormattedException.class);
-    jobService.create(request,
-        ServiceTestUtils.getResponseWithLocation(), ServiceTestUtils.getDefaultUriInfo());
-  }
-
-  private Connection configureHiveConnectionMock() throws HiveClientException {
-    TGetOperationStatusResp statusResp = getOperationStatusResp();
-    TOperationHandle operationHandle = getExecutionOperationHandle();
-
-    Connection connection = createNiceMock(Connection.class);
-    TSessionHandle sessionHandle = new TSessionHandle();
-    THandleIdentifier handleIdentifier = new THandleIdentifier();
-    handleIdentifier.setGuid(new byte[]{1,2,3,4,5,6,7,8});
-    sessionHandle.setSessionId(handleIdentifier);
-    expect(connection.openSession()).andReturn(sessionHandle).anyTimes();
-    expect(connection.executeAsync((TSessionHandle) anyObject(), anyString())).andReturn(operationHandle).anyTimes();
-    expect(connection.getLogs(anyObject(TOperationHandle.class))).andReturn("some logs").anyTimes();
-    expect(connection.getOperationStatus(anyObject(TOperationHandle.class))).andReturn(statusResp).anyTimes();
-
-    replay(connection);
-    return connection;
-  }
-
-  private TGetOperationStatusResp getOperationStatusResp() {
-    TStatus status = new TStatus();
-    status.setStatusCode(TStatusCode.SUCCESS_STATUS);
-
-    TGetOperationStatusResp statusResp = new TGetOperationStatusResp();
-    statusResp.setStatus(status);
-
-    return statusResp;
-  }
-
-  private TOperationHandle getExecutionOperationHandle() {
-    THandleIdentifier handleIdentifier = new THandleIdentifier();
-    handleIdentifier.setGuid("some guid".getBytes());
-    handleIdentifier.setSecret("some secret".getBytes());
-
-    TOperationHandle operationHandle = new TOperationHandle();
-    operationHandle.setHasResultSet(true);
-    operationHandle.setModifiedRowCount(0);
-    operationHandle.setOperationType(TOperationType.EXECUTE_STATEMENT);
-    operationHandle.setOperationId(handleIdentifier);
-    return operationHandle;
-  }
-
-  @Override
-  protected void setupProperties(Map<String, String> properties, File baseDir) throws Exception {
-    super.setupProperties(properties, baseDir);
-    properties.put("scripts.dir", "/tmp/.hiveQueries");
-    properties.put("jobs.dir", "/tmp/.hiveJobs");
-  }
-
-  public static Response doCreateSavedQuery(String title, String path, SavedQueryService service) {
-    SavedQueryService.SavedQueryRequest request = new SavedQueryService.SavedQueryRequest();
-    request.savedQuery = new SavedQuery();
-    request.savedQuery.setTitle(title);
-    request.savedQuery.setQueryFile(path);
-
-    return service.create(request,
-        ServiceTestUtils.getResponseWithLocation(), ServiceTestUtils.getDefaultUriInfo());
-  }
-
-  private SavedQuery createSavedQuery(String title, String path) {
-    Response response = doCreateSavedQuery(title, path, savedQueryService);
-    JSONObject obj = (JSONObject)response.getEntity();
-    SavedQuery query = ((SavedQuery) obj.get("savedQuery"));
-    return query;
-  }
-
-
-  private Object getFieldFromJobJSON(JSONObject jobObj, String field) {
-    return ((Map) jobObj.get("job")).get(field);
-  }
-
-  private HdfsApiMock setupHdfsApiMock() throws IOException, InterruptedException, HdfsApiException {
-    HdfsApiMock hdfsApiMock = new HdfsApiMock("select * from Z");
-    HdfsApi hdfsApi = hdfsApiMock.getHdfsApi();
-    jobService.getSharedObjectsFactory().setInstance(HdfsApi.class, hdfsApi);
-    replay(hdfsApi);
-    return hdfsApiMock;
-  }
-
-  private void assertResponseJobSanity(JSONObject jobObj) {
-    Assert.assertTrue(jobObj.containsKey("job"));
-    Assert.assertNotNull(((Map) jobObj.get("job")).get("id"));
-    Assert.assertNotNull(((Map) jobObj.get("job")).get("queryFile"));
-  }
-
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/resources/jobs/LogParserTest.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/resources/jobs/LogParserTest.java b/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/resources/jobs/LogParserTest.java
deleted file mode 100644
index 1e04dd7..0000000
--- a/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/resources/jobs/LogParserTest.java
+++ /dev/null
@@ -1,73 +0,0 @@
-/**
- * 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.ambari.view.hive.resources.jobs;
-
-import org.junit.Assert;
-import org.junit.Test;
-
-public class LogParserTest {
-    @Test
-    public void testParseMRLog() {
-        String log = "INFO : Number of reduce tasks determined at compile time: 1\n" +
-            "INFO : In order to change the average load for a reducer (in bytes):\n" +
-            "INFO : set hive.exec.reducers.bytes.per.reducer=<number>\n" +
-            "INFO : In order to limit the maximum number of reducers:\n" +
-            "INFO : set hive.exec.reducers.max=<number>\n" +
-            "INFO : In order to set a constant number of reducers:\n" +
-            "INFO : set mapreduce.job.reduces=<number>\n" +
-            "WARN : Hadoop command-line option parsing not performed. Implement the Tool interface and execute your application with ToolRunner to remedy this.\n" +
-            "INFO : number of splits:1\n" +
-            "INFO : Submitting tokens for job: job_1421248330903_0003\n" +
-            "INFO : The url to track the job: http://dataworker.hortonworks.com:8088/proxy/application_1421248330903_0003/\n" +
-            "INFO : Starting Job = job_1421248330903_0003, Tracking URL = http://dataworker.hortonworks.com:8088/proxy/application_1421248330903_0003/\n" +
-            "INFO : Kill Command = /usr/hdp/current/hadoop-client/bin/hadoop job -kill job_1421248330903_0003\n" +
-            "INFO : Hadoop job information for Stage-1: number of mappers: 1; number of reducers: 1\n" +
-            "INFO : 2015-01-21 15:03:55,979 Stage-1 map = 0%, reduce = 0%\n" +
-            "INFO : 2015-01-21 15:04:07,503 Stage-1 map = 100%, reduce = 0%, Cumulative CPU 0.79 sec\n" +
-            "INFO : 2015-01-21 15:04:17,384 Stage-1 map = 100%, reduce = 100%, Cumulative CPU 1.86 sec\n" +
-            "INFO : MapReduce Total cumulative CPU time: 1 seconds 860 msec\n" +
-            "INFO : Ended Job = job_1421248330903_0003";
-
-        LogParser p = LogParser.parseLog(log);
-        Assert.assertEquals(1, p.getAppsList().size());
-        Assert.assertEquals("application_1421248330903_0003",(((LogParser.AppId) (p.getAppsList().toArray())[0])
-                                                            .getIdentifier()));
-    }
-
-    @Test
-    public void testParseTezLog() {
-        String log = "INFO : Tez session hasn't been created yet. Opening session\n" +
-            "INFO :\n" +
-            "\n" +
-            "INFO : Status: Running (Executing on YARN cluster with App id application_1423156117563_0003)\n" +
-            "\n" +
-            "INFO : Map 1: -/- Reducer 2: 0/1\n" +
-            "INFO : Map 1: 0/1 Reducer 2: 0/1\n" +
-            "INFO : Map 1: 0/1 Reducer 2: 0/1\n" +
-            "INFO : Map 1: 0(+1)/1 Reducer 2: 0/1\n" +
-            "INFO : Map 1: 0(+1)/1 Reducer 2: 0/1\n" +
-            "INFO : Map 1: 1/1 Reducer 2: 0(+1)/1\n" +
-            "INFO : Map 1: 1/1 Reducer 2: 1/1 ";
-
-        LogParser p = LogParser.parseLog(log);
-        Assert.assertEquals(1, p.getAppsList().size());
-        Assert.assertEquals("application_1423156117563_0003",(((LogParser.AppId) (p.getAppsList().toArray())[0])
-            .getIdentifier()));
-    }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/resources/resources/FileResourceServiceTest.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/resources/resources/FileResourceServiceTest.java b/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/resources/resources/FileResourceServiceTest.java
deleted file mode 100644
index 026acc3..0000000
--- a/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/resources/resources/FileResourceServiceTest.java
+++ /dev/null
@@ -1,119 +0,0 @@
-/**
- * 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.ambari.view.hive.resources.resources;
-
-import org.apache.ambari.view.hive.BaseHiveTest;
-import org.apache.ambari.view.hive.resources.resources.FileResourceItem;
-import org.apache.ambari.view.hive.resources.resources.FileResourceService;
-import org.apache.ambari.view.hive.utils.NotFoundFormattedException;
-import org.json.simple.JSONObject;
-import org.junit.Assert;
-import org.junit.Before;
-import org.junit.Rule;
-import org.junit.Test;
-import org.junit.rules.ExpectedException;
-
-import javax.servlet.http.HttpServletResponse;
-import javax.ws.rs.core.Response;
-import javax.ws.rs.core.UriBuilder;
-import javax.ws.rs.core.UriInfo;
-import java.net.URI;
-
-import static org.easymock.EasyMock.*;
-
-public class FileResourceServiceTest extends BaseHiveTest {
-  @Rule public ExpectedException thrown = ExpectedException.none();
-  private FileResourceService resourceService;
-
-  @Override
-  @Before
-  public void setUp() throws Exception {
-    super.setUp();
-    resourceService = getService(FileResourceService.class, handler, context);
-  }
-
-  private Response doCreateFileResourceItem() {
-    FileResourceService.ResourceRequest request = new FileResourceService.ResourceRequest();
-    request.fileResource = new FileResourceItem();
-    request.fileResource.setPath("/tmp/file.jar");
-    request.fileResource.setName("TestFileResourceItem");
-
-    UriInfo uriInfo = createNiceMock(UriInfo.class);
-    URI uri = UriBuilder.fromUri("http://host/a/b").build();
-    expect(uriInfo.getAbsolutePath()).andReturn(uri);
-
-    HttpServletResponse resp_obj = createNiceMock(HttpServletResponse.class);
-
-    resp_obj.setHeader(eq("Location"), anyString());
-
-    replay(uriInfo, resp_obj);
-    return resourceService.create(request, resp_obj, uriInfo);
-  }
-
-  @Test
-  public void createFileResourceItem() {
-    Response response = doCreateFileResourceItem();
-    Assert.assertEquals(201, response.getStatus());
-
-    JSONObject obj = (JSONObject)response.getEntity();
-    Assert.assertTrue(obj.containsKey("fileResource"));
-    Assert.assertNotNull(((FileResourceItem) obj.get("fileResource")).getId());
-    Assert.assertFalse(((FileResourceItem) obj.get("fileResource")).getId() == null);
-  }
-
-  @Test
-  public void resourceNotFound() {
-    thrown.expect(NotFoundFormattedException.class);
-    resourceService.getOne("4242");
-  }
-
-  @Test
-  public void updateFileResourceItem() {
-    Response createdFileResourceItem = doCreateFileResourceItem();
-    Object createdUdfId = ((FileResourceItem) ((JSONObject) createdFileResourceItem.getEntity()).get("fileResource")).getId();
-
-    FileResourceService.ResourceRequest request = new FileResourceService.ResourceRequest();
-    request.fileResource = new FileResourceItem();
-    request.fileResource.setPath("/tmp/updatedFileResourceItem.jar");
-    request.fileResource.setName("TestFileResourceItem2");
-
-    Response response = resourceService.update(request, String.valueOf(createdUdfId));
-    Assert.assertEquals(204, response.getStatus());
-
-    Response response2 = resourceService.getOne(String.valueOf(createdUdfId));
-    Assert.assertEquals(200, response2.getStatus());
-
-    JSONObject obj = ((JSONObject) response2.getEntity());
-    Assert.assertTrue(obj.containsKey("fileResource"));
-    Assert.assertEquals(((FileResourceItem) obj.get("fileResource")).getName(), request.fileResource.getName());
-    Assert.assertEquals(((FileResourceItem) obj.get("fileResource")).getPath(), request.fileResource.getPath());
-  }
-
-  @Test
-  public void deleteFileResourceItem() {
-    Response createdFileResourceItem = doCreateFileResourceItem();
-    Object createdUdfId = ((FileResourceItem) ((JSONObject) createdFileResourceItem.getEntity()).get("fileResource")).getId();
-
-    Response response = resourceService.delete(String.valueOf(createdUdfId));
-    Assert.assertEquals(204, response.getStatus());
-
-    thrown.expect(NotFoundFormattedException.class);
-    resourceService.getOne(String.valueOf(createdUdfId));
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/resources/savedQueries/SavedQueryResourceManagerTest.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/resources/savedQueries/SavedQueryResourceManagerTest.java b/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/resources/savedQueries/SavedQueryResourceManagerTest.java
deleted file mode 100644
index b9fac9f..0000000
--- a/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/resources/savedQueries/SavedQueryResourceManagerTest.java
+++ /dev/null
@@ -1,55 +0,0 @@
-/**
- * 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.ambari.view.hive.resources.savedQueries;
-
-import org.junit.Assert;
-import org.junit.Test;
-
-public class SavedQueryResourceManagerTest {
-
-  @Test
-  public void testMakeShortQuery() throws Exception {
-    String query = "select * from table;";
-    String shortQuery = SavedQueryResourceManager.makeShortQuery(query);
-    Assert.assertEquals(query, shortQuery);
-  }
-
-  @Test
-  public void testMakeShortQuery42Trim() throws Exception {
-    String str50 = "12345678901234567890123456789012345678901234567890";
-    String str42 = "123456789012345678901234567890123456789012";
-    String shortQuery = SavedQueryResourceManager.makeShortQuery(str50);
-    Assert.assertEquals(str42, shortQuery);
-  }
-
-  @Test
-  public void testMakeShortQueryRemoveSet() throws Exception {
-    String str50 = "set hive.execution.engine=tez;\nselect * from table;";
-    String shortQuery = SavedQueryResourceManager.makeShortQuery(str50);
-    Assert.assertEquals("select * from table;", shortQuery);
-
-    str50 = "set hive.execution.engine = tez;  \n select * from table;";
-    shortQuery = SavedQueryResourceManager.makeShortQuery(str50);
-    Assert.assertEquals("select * from table;", shortQuery);
-
-    str50 = "SET  property=value;\nselect * from table;";
-    shortQuery = SavedQueryResourceManager.makeShortQuery(str50);
-    Assert.assertEquals("select * from table;", shortQuery);
-  }
-}
\ No newline at end of file


[12/23] ambari git commit: AMBARI-19302 : removed contrib/views/hive folder and made necessary changes in pom.xml files (nitirajrathore)

Posted by ni...@apache.org.
http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/models/file-resource.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/models/file-resource.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/models/file-resource.js
deleted file mode 100644
index 47f4911..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/models/file-resource.js
+++ /dev/null
@@ -1,25 +0,0 @@
-/**
- * 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.
- */
-
-import DS from 'ember-data';
-
-export default DS.Model.extend({
-  name: DS.attr(),
-  path: DS.attr(),
-  owner: DS.attr()
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/models/file.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/models/file.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/models/file.js
deleted file mode 100644
index c13d4e1..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/models/file.js
+++ /dev/null
@@ -1,26 +0,0 @@
-/**
- * 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.
- */
-
-import DS from 'ember-data';
-
-export default DS.Model.extend({
-  fileContent: DS.attr(),
-  hasNext: DS.attr(),
-  page: DS.attr('number'),
-  pageCount: DS.attr()
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/models/job.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/models/job.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/models/job.js
deleted file mode 100644
index 185f512..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/models/job.js
+++ /dev/null
@@ -1,55 +0,0 @@
-/**
- * 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.
- */
-
-import DS from 'ember-data';
-
-export default DS.Model.extend({
-  title: DS.attr('string'),
-  queryId: DS.attr(),
-  hiveQueryId: DS.attr('string'),
-  queryFile: DS.attr('string'),
-  owner: DS.attr('string'),
-  dataBase: DS.attr('string'),
-  duration: DS.attr(),
-  status: DS.attr('string'),
-  statusMessage: DS.attr('string'),
-  dateSubmitted: DS.attr('date'),
-  forcedContent: DS.attr('string'),
-  logFile: DS.attr('string'),
-  dagName:  DS.attr('string'),
-  dagId: DS.attr('string'),
-  sessionTag: DS.attr('string'),
-  page: DS.attr(),
-  statusDir: DS.attr('string'),
-  applicationId: DS.attr(),
-  referrer: DS.attr('string'),
-  confFile: DS.attr('string'),
-  globalSettings: DS.attr('string'),
-
-  dateSubmittedTimestamp: function () {
-    var date = this.get('dateSubmitted');
-
-    return date; // ? date * 1000 : date; now dateSubmitted itself is in miliseconds. so conversion not required.
-  }.property('dateSubmitted'),
-
-  uppercaseStatus: function () {
-    var status = this.get('status');
-
-    return status ? status.toUpperCase() : status;
-  }.property('status')
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/models/saved-query.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/models/saved-query.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/models/saved-query.js
deleted file mode 100644
index 44536af..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/models/saved-query.js
+++ /dev/null
@@ -1,29 +0,0 @@
-/**
- * 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.
- */
-
-import DS from 'ember-data';
-
-var Model = DS.Model.extend({
-  dataBase: DS.attr('string'),
-  title: DS.attr('string'),
-  queryFile: DS.attr('string'),
-  owner: DS.attr('string'),
-  shortQuery: DS.attr('string')
-});
-
-export default Model;

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/models/udf.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/models/udf.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/models/udf.js
deleted file mode 100644
index c64221e..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/models/udf.js
+++ /dev/null
@@ -1,27 +0,0 @@
-/**
- * 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.
- */
-
-import DS from 'ember-data';
-import constants from 'hive/utils/constants';
-
-export default DS.Model.extend({
-  name: DS.attr(),
-  classname: DS.attr(),
-  fileResource: DS.belongsTo(constants.namingConventions.fileResource, { async: true }),
-  owner: DS.attr()
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/router.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/router.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/router.js
deleted file mode 100644
index 382f1eb..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/router.js
+++ /dev/null
@@ -1,50 +0,0 @@
- /**
- * 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.
- */
-
-import Ember from 'ember';
-import config from './config/environment';
-import constants from 'hive/utils/constants';
-
-var Router = Ember.Router.extend({
-  location: config.locationType
-});
-
-Router.map(function () {
-  var savedQueryPath = constants.namingConventions.routes.queries + '/:' + constants.namingConventions.savedQuery + '_id';
-  var historyQueryPath = constants.namingConventions.routes.history + '/:' + constants.namingConventions.job + '_id';
-
-  this.route(constants.namingConventions.routes.queries);
-  this.route(constants.namingConventions.routes.history);
-  this.route(constants.namingConventions.routes.udfs);
-  this.route(constants.namingConventions.routes.uploadTable);
-
-  this.resource(constants.namingConventions.routes.index, { path: '/' }, function () {
-    this.route(constants.namingConventions.routes.savedQuery, { path: savedQueryPath});
-    this.route(constants.namingConventions.routes.historyQuery, { path: historyQueryPath}, function () {
-      this.route(constants.namingConventions.routes.logs);
-      this.route(constants.namingConventions.routes.results);
-      this.route(constants.namingConventions.routes.explain);
-    });
-  });
-
-  this.route('loading');
-  this.route('splash');
-
-});
-
-export default Router;

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/routes/.gitkeep
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/routes/.gitkeep b/contrib/views/hive/src/main/resources/ui/hive-web/app/routes/.gitkeep
deleted file mode 100644
index e69de29..0000000

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/routes/application.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/routes/application.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/routes/application.js
deleted file mode 100644
index 096ce30..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/routes/application.js
+++ /dev/null
@@ -1,89 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-import constants from 'hive/utils/constants';
-
-export default Ember.Route.extend({
-
-  beforeModel: function () {
-    this.transitionTo('splash');
-  },
-
-  notifyService: Ember.inject.service(constants.namingConventions.notify),
-
-  setupController: function (controller, model) {
-    var self = this;
-
-    this.store.find(constants.namingConventions.udf).then(function (udfs) {
-      self.controllerFor(constants.namingConventions.udfs).set('udfs', udfs);
-    }, function (error) {
-      self.get('notifyService').error(error);
-    });
-  },
-
-  actions: {
-    openModal: function (modalTemplate, options) {
-      this.controllerFor(modalTemplate).setProperties({
-        content: options.content || {},
-        message: options.message,
-        heading: options.heading,
-        text: options.text,
-        type: options.type || "text",
-        defer: options.defer
-      });
-
-      return this.render(modalTemplate, {
-        into: 'application',
-        outlet: 'modal'
-      });
-    },
-
-    closeModal: function () {
-      return this.disconnectOutlet({
-        outlet: 'modal',
-        parentView: 'application'
-      });
-    },
-
-    openOverlay: function (overlay) {
-      return this.render(overlay.template, {
-        outlet: overlay.outlet,
-        into: overlay.into
-      });
-    },
-
-    closeOverlay: function (overlay) {
-      return this.disconnectOutlet({
-        outlet: overlay.outlet,
-        parentView: overlay.into
-      });
-    },
-
-    removeNotification: function (notification) {
-      this.get('notifyService').removeNotification(notification);
-    },
-
-    willTransition: function(transition) {
-      // close active overlay if we transition
-      this.controllerFor('queryTabs').setDefaultActive();
-
-      return transition;
-    }
-  }
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/routes/history.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/routes/history.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/routes/history.js
deleted file mode 100644
index e9fcf88..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/routes/history.js
+++ /dev/null
@@ -1,29 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-
-export default Ember.Route.extend({
-  deactivate: function () {
-    this.controller.onUnloadRoute();
-  },
-
-  setupController: function (controller, model) {
-    this.controller.onLoadRoute();
-  }
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/routes/index/history-query/explain.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/routes/index/history-query/explain.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/routes/index/history-query/explain.js
deleted file mode 100644
index 742f7a8..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/routes/index/history-query/explain.js
+++ /dev/null
@@ -1,28 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-import constants from 'hive/utils/constants';
-
-export default Ember.Route.extend({
-  setupController: function (controller, model) {
-    this.controllerFor(constants.namingConventions.openQueries).updateTabSubroute(model, constants.namingConventions.subroutes.jobExplain);
-
-    this.controllerFor(constants.namingConventions.routes.index).set('model', model);
-  }
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/routes/index/history-query/index.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/routes/index/history-query/index.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/routes/index/history-query/index.js
deleted file mode 100644
index 5959938..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/routes/index/history-query/index.js
+++ /dev/null
@@ -1,44 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-import constants from 'hive/utils/constants';
-import utils from 'hive/utils/functions';
-
-export default Ember.Route.extend({
-  setupController: function (controller, model) {
-    var subroute;
-    var existingTab = this.controllerFor(constants.namingConventions.openQueries).getTabForModel(model);
-
-    if (existingTab) {
-      subroute = existingTab.get('subroute');
-    }
-
-    // filter out hdfs jobs
-    if (utils.isInteger(model.get('id'))) {
-      if (subroute) {
-        this.transitionTo(subroute, model);
-      } else {
-        this.transitionTo(constants.namingConventions.subroutes.jobLogs, model);
-      }
-    } else {
-      this.transitionTo(constants.namingConventions.subroutes.historyQuery, model);
-      this.controllerFor(constants.namingConventions.routes.index).set('model', model);
-    }
-  }
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/routes/index/history-query/logs.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/routes/index/history-query/logs.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/routes/index/history-query/logs.js
deleted file mode 100644
index 954f725..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/routes/index/history-query/logs.js
+++ /dev/null
@@ -1,28 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-import constants from 'hive/utils/constants';
-
-export default Ember.Route.extend({
-  setupController: function (controller, model) {
-    this.controllerFor(constants.namingConventions.openQueries).updateTabSubroute(model, constants.namingConventions.subroutes.jobLogs);
-
-    this.controllerFor(constants.namingConventions.routes.index).set('model', model);
-  }
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/routes/index/history-query/results.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/routes/index/history-query/results.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/routes/index/history-query/results.js
deleted file mode 100644
index f1593c5..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/routes/index/history-query/results.js
+++ /dev/null
@@ -1,28 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-import constants from 'hive/utils/constants';
-
-export default Ember.Route.extend({
-  setupController: function (controller, model) {
-    this.controllerFor(constants.namingConventions.openQueries).updateTabSubroute(model, constants.namingConventions.subroutes.jobResults);
-
-    this.controllerFor(constants.namingConventions.routes.index).set('model', model);
-  }
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/routes/index/index.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/routes/index/index.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/routes/index/index.js
deleted file mode 100644
index 120a102..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/routes/index/index.js
+++ /dev/null
@@ -1,36 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-import constants from 'hive/utils/constants';
-
-export default Ember.Route.extend({
-  beforeModel: function () {
-    var model = this.controllerFor(constants.namingConventions.routes.index).get('model');
-
-    if (model && !model.get('isDeleted')) {
-      if (model.get('constructor.typeKey') === constants.namingConventions.job) {
-        this.transitionTo(constants.namingConventions.subroutes.historyQuery, model);
-      } else {
-        this.transitionTo(constants.namingConventions.subroutes.savedQuery, model);
-      }
-    } else {
-      this.controllerFor(constants.namingConventions.openQueries).navigateToLastTab();
-    }
-  }
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/routes/index/saved-query.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/routes/index/saved-query.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/routes/index/saved-query.js
deleted file mode 100644
index 0366b0d..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/routes/index/saved-query.js
+++ /dev/null
@@ -1,43 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-import constants from 'hive/utils/constants';
-
-export default Ember.Route.extend({
-  setupController: function (controller, model) {
-    // settings modify fileContent to extract the settings
-    // when you load a saved query use the original fileContent
-    // this.store.find('file', model.get('queryFile'))
-    //   .then(function(queryFile) {
-    //     var changes = queryFile.changedAttributes();
-    //     if (changes.fileContent && changes.fileContent[0]) {
-    //       queryFile.set('fileContent', changes.fileContent[0]);
-    //     }
-    //   });
-
-    this.controllerFor(constants.namingConventions.routes.index).set('model', model);
-  },
-
-  actions: {
-    error: function () {
-      this.store.unloadAll(constants.namingConventions.savedQuery);
-      this.transitionTo(constants.namingConventions.routes.index);
-    }
-  }
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/routes/loading.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/routes/loading.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/routes/loading.js
deleted file mode 100644
index 8719170..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/routes/loading.js
+++ /dev/null
@@ -1,22 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-
-export default Ember.Route.extend({
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/routes/queries.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/routes/queries.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/routes/queries.js
deleted file mode 100644
index 29e144b..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/routes/queries.js
+++ /dev/null
@@ -1,40 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-import constants from 'hive/utils/constants';
-
-export default Ember.Route.extend({
-  notifyService: Ember.inject.service(constants.namingConventions.notify),
-
-  model: function () {
-    var self = this;
-
-    return this.store.find(constants.namingConventions.savedQuery).catch(function (error) {
-      self.get('notifyService').error(error);
-    });
-  },
-
-  setupController: function (controller, model) {
-    if (!model) {
-      return;
-    }
-
-    controller.set('queries', model);
-  }
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/routes/splash.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/routes/splash.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/routes/splash.js
deleted file mode 100644
index 463a1c6..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/routes/splash.js
+++ /dev/null
@@ -1,61 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-
-export default Ember.Route.extend({
-
-  model: function() {
-    return Ember.Object.create({
-      hdfsTest: null,
-      hdfsTestDone: null,
-      hiveserverTest: null,
-      hiveserverTestDone: null,
-      atsTest: null,
-      atsTestDone: null,
-      userhomeTest: null,
-      userhomeTestDone: null,
-      percent: 0
-    });
-  },
-
-  setupController: function(controller, model) {
-
-    if (!model) {
-      return;
-    }
-
-    controller.set('model', model);
-    var self = this;
-    controller.startTests().then(function() {
-
-    if (model.get("hiveserverTest") && model.get("hdfsTest") && model.get("atsTest") && model.get("userhomeTest")) {
-      Ember.run.later(this, function() {
-        self.send('transition');
-      }, 2000);
-    }
-    });
-  },
-
-  actions: {
-    transition: function() {
-      this.transitionTo('index');
-    }
-  }
-
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/routes/udfs.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/routes/udfs.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/routes/udfs.js
deleted file mode 100644
index 5a96cd6..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/routes/udfs.js
+++ /dev/null
@@ -1,36 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-import constants from 'hive/utils/constants';
-
-export default Ember.Route.extend({
-  notifyService: Ember.inject.service(constants.namingConventions.notify),
-
-  setupController: function (controller, model) {
-    this._super();
-
-    var self = this;
-
-    this.store.find(constants.namingConventions.fileResource).then(function (fileResources) {
-      controller.set('fileResources', fileResources);
-    }).catch(function (error) {
-      self.get('notifyService').error(error);
-    });;
-  }
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/serializers/database.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/serializers/database.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/serializers/database.js
deleted file mode 100644
index f598b20..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/serializers/database.js
+++ /dev/null
@@ -1,41 +0,0 @@
-/**
- * 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.
- */
-
-import DS from 'ember-data';
-
-export default DS.JSONSerializer.extend({
-  extractArray: function (store, primaryType, rawPayload) {
-    var databases = rawPayload.databases.map(function (database) {
-      return {
-        id: database,
-        name: database
-      };
-    });
-
-    var payload = { databases: databases };
-    return this._super(store, primaryType, payload);
-  },
-
-  normalizePayload: function (payload) {
-    var normalized = payload.databases.map(function (database) {
-      return database;
-    });
-
-    return this._super(normalized);
-  }
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/serializers/file.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/serializers/file.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/serializers/file.js
deleted file mode 100644
index 416db0c..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/serializers/file.js
+++ /dev/null
@@ -1,23 +0,0 @@
-/**
- * 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.
- */
-
-import DS from 'ember-data';
-
-export default DS.RESTSerializer.extend({
-  primaryKey: 'filePath'
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/services/database.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/services/database.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/services/database.js
deleted file mode 100644
index 2a6f5d4..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/services/database.js
+++ /dev/null
@@ -1,243 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-import constants from 'hive/utils/constants';
-
-export default Ember.Service.extend({
-  store: Ember.inject.service(),
-
-  pageCount: 10,
-  selectedDatabase: null,
-  selectedTables: null,
-  databases: [],
-
-  init: function () {
-    this._super();
-
-    var databaseAdapter = this.container.lookup('adapter:database');
-    var baseUrl = databaseAdapter.buildURL() + '/' +
-                  databaseAdapter.pathForType(constants.namingConventions.database) + '/';
-
-    this.set('baseUrl', baseUrl);
-  },
-
-  getDatabases: function () {
-    var defer = Ember.RSVP.defer();
-    var self = this;
-
-    this.get('store').unloadAll(constants.namingConventions.database);
-    this.get('store').fetchAll(constants.namingConventions.database).then(function (databases) {
-      self.set('databases', databases);
-      defer.resolve(databases);
-    }, function (error) {
-      defer.reject(error);
-    })
-
-    return defer.promise;
-  },
-
-  // This will do a ajax call to fetch the current database by by-passing the store.
-  // As we want to retain the current state of databases in store and just want to
-  // find the current databases in the server
-  getDatabasesFromServer: function() {
-    var defer = Ember.RSVP.defer();
-    var url = this.get('baseUrl');
-    Ember.$.getJSON(url).then(function(data) {
-      defer.resolve(data.databases);
-    }, function(err) {
-      defer.reject(err);
-    });
-    return defer.promise;
-  },
-
-  setDatabaseByName: function (name) {
-    var database = this.databases.findBy('name', name);
-
-    if (database) {
-      this.set('selectedDatabase', database);
-    }
-  },
-
-  getColumnsPage: function (databaseName, table, searchTerm, firstSearchPage) {
-    var defer = Ember.RSVP.defer();
-
-    var url = this.get('baseUrl') +
-              databaseName +
-              '/table/' +
-              table.get('name');
-
-    url += '.page?searchId&count=' + this.get('pageCount');
-    url += '&columns=3,5,6,8';
-
-    if (searchTerm) {
-      url += '&searchId=searchColumns' + '&like=' + searchTerm;
-
-      if (firstSearchPage) {
-        url += '&first=true';
-      }
-    } else if (!table.get('columns.length')) {
-      url += '&first=true';
-    }
-
-    Ember.$.getJSON(url).then(function (data) {
-      Ember.run(function () {
-        var columns;
-
-        columns = data.rows.map(function (row) {
-            return Ember.Object.create({
-              name: row[0],
-              type: row[1],
-              precision : row[2],
-              scale : row[3]
-            });
-        });
-
-        defer.resolve({
-          columns: columns,
-          hasNext: data.hasNext
-        });
-      });
-    }, function (err) {
-      defer.reject(err);
-    });
-
-    return defer.promise;
-  },
-
-  getTablesPage: function (database, searchTerm, firstSearchPage) {
-    var defer = Ember.RSVP.defer(),
-        url = this.get('baseUrl') +
-              database.get('name') +
-              '/table.page?count=';
-
-    url += this.get('pageCount');
-
-    if (searchTerm) {
-      url += '&searchId=searchTables' + '&like=' + searchTerm;
-
-      if (firstSearchPage) {
-        url += '&first=true';
-      }
-    } else if (!database.get('tables.length')) {
-      url += '&first=true';
-    }
-
-    Ember.$.getJSON(url).then(function (data) {
-      var tables;
-
-      tables = data.rows.map(function (row) {
-        return Ember.Object.create({
-          name: row[0]
-        });
-      });
-
-      defer.resolve({
-        tables: tables,
-        hasNext: data.hasNext
-      });
-    }, function (err) {
-      defer.reject(err);
-    });
-
-    return defer.promise;
-  },
-
-  getAllTables: function (db) {
-    var defer = Ember.RSVP.defer();
-    var database = db || this.get('selectedDatabase');
-    var self;
-    var url;
-
-    if (!database) {
-      defer.resolve();
-    } else if (database.tables && !database.get('hasNext')) {
-      this.set('selectedTables', database.tables.mapProperty('name'));
-      defer.resolve();
-    } else {
-      self = this;
-      url = this.get('baseUrl') + database.get('name') + '/table';
-
-      Ember.$.getJSON(url).then(function (data) {
-        var tables = data.tables.map(function (table) {
-          return Ember.Object.create({
-            name: table
-          });
-        });
-
-        //don't use Ember.Object.set since it can be very expensive for large collections (e.g. 15000 tables),
-        //thus we should not do any bindings directly on the 'tables' collection.
-        database.tables = tables;
-
-        Ember.run(function () {
-          self.set('selectedTables', tables.mapProperty('name'));
-        });
-
-        defer.resolve();
-      }, function (err) {
-        defer.reject(err);
-      });
-    }
-
-    return defer.promise;
-  },
-
-  getAllColumns: function (tableName, db) {
-    var database = db || this.get('selectedDatabase');
-    var defer = Ember.RSVP.defer();
-    var table;
-    var self;
-    var url;
-
-    if (!database) {
-      defer.resolve();
-    } else {
-      table = database.tables.findBy('name', tableName);
-
-      if (!table) {
-        defer.resolve();
-      } else if (table.columns && !table.get('hasNext')) {
-        this.get('selectedTables')[tableName] = table.columns.mapProperty('name');
-        defer.resolve();
-      } else {
-        self = this;
-        url = this.get('baseUrl') + database.get('name') + '/table/' + tableName
-
-        Ember.$.getJSON(url).then(function (data) {
-          var columns = data.columns.map(function (column) {
-            return Ember.Object.create({
-              name: column[0],
-              type: column[1]
-            });
-          });
-
-          table.columns = columns;
-          table.set('hasNext', false);
-
-          self.get('selectedTables')[tableName] = columns.mapProperty('name');
-
-          defer.resolve();
-        }, function (err) {
-          defer.reject(err);
-        });
-      }
-    }
-
-    return defer.promise;
-  }
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/services/file.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/services/file.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/services/file.js
deleted file mode 100644
index 7f01795..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/services/file.js
+++ /dev/null
@@ -1,59 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-import constants from 'hive/utils/constants';
-
-export default Ember.Service.extend({
-  files: [],
-  store: Ember.inject.service(),
-
-  loadFile: function (path) {
-    var self = this;
-    var defer = Ember.RSVP.defer();
-    var file = this.files.findBy('id', path);
-
-    if (file) {
-      defer.resolve(file);
-    } else {
-      this.get('store').find(constants.namingConventions.file, path).then(function (file) {
-        defer.resolve(self.files.pushObject(file));
-      }, function (err) {
-        defer.reject(err);
-      });
-    }
-
-    return defer.promise;
-  },
-
-  reloadFile: function (path) {
-    var defer = Ember.RSVP.defer();
-
-    this.get('store').find(constants.namingConventions.file, path).then(function (file) {
-      file.reload().then(function (reloadedFile) {
-        defer.resolve(reloadedFile);
-      }, function (err) {
-        defer.reject(err);
-      });
-    }, function (err) {
-      defer.reject(err);
-    });
-
-    return defer.promise;
-  }
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/services/history.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/services/history.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/services/history.js
deleted file mode 100644
index 4998d19..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/services/history.js
+++ /dev/null
@@ -1,204 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-import Job from 'hive/models/job'
-import constants from 'hive/utils/constants';
-
-export default Ember.Service.extend({
-  historyJobsMap: {},
-  store: Ember.inject.service(),
-  fromDate: null,
-  toDate: null,
-
-  getJobs: function (fromDate, toDate) {
-    var self = this;
-    console.log("getJobs : fromDate : ", fromDate, ", toDate : ", toDate);
-
-    if (Ember.isEmpty(fromDate) || Ember.isEmpty(toDate)) {
-      throw new Error("Dates cannot be empty.");
-    }
-    if (toDate < fromDate) {
-      throw new Error("toDate cannot be smaller than fromDate");
-    }
-
-    var currFromDate = this.get("fromDate");
-    var currToDate = this.get("toDate");
-    var currJobsMap = this.get("historyJobsMap");
-
-    if (!Ember.isEmpty(currFromDate) && !Ember.isEmpty(currToDate)
-      && currFromDate <= fromDate && currToDate >= toDate
-      && !Ember.isEmpty(currJobsMap)
-    ) {
-      // filter current jobs and return
-      var validJobs = [];
-      Object.keys(currJobsMap).forEach(function (id) {
-        var job = currJobsMap[id];
-        if (job.get('dateSubmitted') >= fromDate && job.get('dateSubmitted') < toDate) {
-          validJobs.push(job);
-        }
-      });
-
-      return Ember.RSVP.Promise.resolve(validJobs);
-    }
-
-    return this.fetchJobs(fromDate, toDate).then(function (data) {
-      var jobMap = {};
-      var jobs = data.map(function (j) {
-        var job = this.get('store').push('job', j);
-        jobMap[job.id] = job;
-        return job;
-      }, self);
-      self.set('fromDate', fromDate);
-      self.set('toDate', toDate);
-      self.set('historyJobsMap', jobMap);
-      return jobs;
-    });
-  },
-
-  fetchJobs: function (fromDate, toDate) {
-    console.log("getJobs : fromDate : ", fromDate, ", toDate : ", toDate);
-
-    if (Ember.isEmpty(fromDate) || Ember.isEmpty(toDate)) {
-      throw new Error("Dates cannot be empty.");
-    }
-    if (toDate < fromDate) {
-      throw new Error("toDate cannot be smaller than fromDate");
-    }
-
-    var self = this;
-    var url = this.container.lookup('adapter:application').buildURL();
-    url += "/jobs";
-    var jobMap = {};
-    return Ember.$.ajax({
-      url: url,
-      type: 'GET',
-      data: {
-        "startTime": fromDate,
-        "endTime": toDate
-      },
-      headers: {
-        'X-Requested-By': 'ambari'
-      }
-    });
-  },
-
-  fetchAndMergeNew: function (toTime) {
-    var self = this;
-    return this.fetchNew(toTime).then(function (data) {
-      var jobMap = self.get('historyJobsMap');
-      var jobs = data.map(function (j) {
-        var job = this.get('store').push('job', j);
-        jobMap[job.id] = job;
-        return job;
-      }, self);
-      self.set('toDate', toTime);
-      return jobs;
-    });
-  },
-
-  getUpdatedJobList: function (toTime) {
-    var self = this;
-    return this.refreshAndFetchNew(toTime).then(function (data) {
-      var jobMap = self.get('historyJobsMap');
-      var allJobs = Object.keys(jobMap).map(function (id) {
-        return jobMap[id];
-      });
-      return allJobs;
-    });
-  },
-
-  fetchNew: function (toTime) {
-    var self = this;
-    var jobMap = this.get('historyJobsMap');
-    var fromTime = 0;
-    if (this.get('fromDate')) {
-      fromTime = this.get('fromDate');
-    }
-
-    Object.keys(jobMap).forEach(function (id) {
-      var job = jobMap[id];
-      fromTime = Math.max(fromTime, job.get('dateSubmitted'));
-    });
-
-    if (fromTime > toTime) {
-      // we already have latest data.
-      return Ember.RSVP.Promise.resolve([]);
-    }
-    return this.fetchJobs(fromTime, toTime);
-  },
-
-  refresh: function () {
-    var self = this;
-    var url = this.container.lookup('adapter:application').buildURL();
-    url += "/jobs/getList";
-    var jobMap = this.get('historyJobsMap');
-    var statuses = constants.statuses;
-    var jobIds = [];
-    Object.keys(jobMap).forEach(function (id) {
-      var job = jobMap[id];
-      var jobStatus = job.get('uppercaseStatus');
-      if (jobStatus === statuses.initialized
-        || jobStatus === statuses.pending
-        || jobStatus === statuses.running
-        || jobStatus === statuses.unknown
-      ) {
-        // note jobId will either have DB's id or hiveId
-        jobIds.push({
-          jobId: job.get('id'),
-          hiveId: job.get('hiveQueryId'),
-          dagId: job.get('dagId'),
-          operationId: job.get('operationId')
-        });
-      }
-    });
-
-    if (Ember.isEmpty(jobIds)) {
-      return Ember.RSVP.Promise.resolve([]);
-    }
-    console.log("refresh jobIds to refresh : ", jobIds);
-    return Ember.$.ajax({
-      url: url,
-      type: 'POST',
-      data: JSON.stringify(jobIds),
-      headers: {
-        'X-Requested-By': 'ambari'
-      },
-      contentType: "application/json"
-    }).then(function (data) {
-      var jobs = data.map(function (j) {
-        var job = this.get('store').push('job', j);
-        jobMap[job.id] = job;
-        return job;
-      }, self);
-      self.set('historyJobsMap', jobMap);
-      // return all the jobs
-      var allJobs = Object.keys(jobMap).map(function (id) {
-        return jobMap[id];
-      });
-      return allJobs;
-    });
-  },
-
-  refreshAndFetchNew: function (toTime) {
-    var self = this;
-    return this.refresh().then(function (data) {
-      return self.fetchAndMergeNew(toTime);
-    })
-  }
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/services/job-progress.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/services/job-progress.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/services/job-progress.js
deleted file mode 100644
index 1e0b96b..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/services/job-progress.js
+++ /dev/null
@@ -1,102 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-import constants from 'hive/utils/constants';
-
-export default Ember.Service.extend({
-  jobs: [],
-
-  setupProgress: function (currentModel) {
-    var job = this.jobs.findBy('model', currentModel);
-
-    if (!job) {
-      job = this.jobs.pushObject(Ember.Object.create({
-        model: currentModel,
-        stages: [],
-        totalProgress: 0,
-        retrievingProgress: false,
-      }));
-    }
-
-    this.set('currentJob', job);
-  },
-
-  updateProgress: function () {
-    var job = this.get('currentJob');
-
-    if (!job.get('model.dagId')) {
-      return;
-    }
-
-    if (job.get('totalProgress') < 100 && !job.get('retrievingProgress')) {
-      this.reloadProgress(job);
-    }
-  }.observes('currentJob.model.dagId'),
-
-  reloadProgress: function (job) {
-    var self = this;
-    var url = '%@/%@/%@/progress'.fmt(this.container.lookup('adapter:application').buildURL(),
-                                         constants.namingConventions.jobs,
-                                         job.get('model.id'));
-
-    job.set('retrievingProgress', true);
-
-    Ember.$.getJSON(url).then(function (data) {
-      var total = 0;
-      var length = Object.keys(data.vertexProgresses).length;
-
-      if (!job.get('stages.length')) {
-        data.vertexProgresses.forEach(function (vertexProgress) {
-          var progress = vertexProgress.progress * 100;
-
-          job.get('stages').pushObject(Ember.Object.create({
-            name: vertexProgress.name,
-            value: progress
-          }));
-
-          total += progress;
-        });
-      } else {
-        data.vertexProgresses.forEach(function (vertexProgress) {
-          var progress = vertexProgress.progress * 100;
-
-          job.get('stages').findBy('name', vertexProgress.name).set('value', progress);
-
-          total += progress;
-        });
-      }
-
-      total /= length;
-
-      job.set('totalProgress', total);
-
-      if (job.get('model.isRunning') && total < 100) {
-        Ember.run.later(function () {
-          self.reloadProgress(job);
-        }, 1000);
-      } else {
-        job.set('retrievingProgress');
-      }
-    });
-  },
-
-  isJob: function (model) {
-    return model.get('constructor.typeKey') === constants.namingConventions.job;
-  }
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/services/job.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/services/job.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/services/job.js
deleted file mode 100644
index 7ba0601..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/services/job.js
+++ /dev/null
@@ -1,56 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-
-export default Ember.Service.extend({
-  stopJob: function (job) {
-    var self = this;
-    var id = job.get('id');
-    var url = this.container.lookup('adapter:application').buildURL();
-    url +=  "/jobs/" + id;
-
-    job.set('isCancelling', true);
-
-    Ember.$.ajax({
-       url: url,
-       type: 'DELETE',
-       headers: {
-        'X-Requested-By': 'ambari'
-       },
-       success: function () {
-         job.reload();
-       }
-    });
-  },
-
-  fetchJob : function (jobId){
-    console.log("fetching job : ", jobId);
-    var self = this;
-    var url = this.container.lookup('adapter:application').buildURL();
-    url +=  "/jobs/" + jobId ;
-
-    return Ember.$.ajax({
-      url: url,
-      type: 'GET',
-      headers: {
-        'X-Requested-By': 'ambari'
-      }
-    });
-  }
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/services/ldap-authentication.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/services/ldap-authentication.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/services/ldap-authentication.js
deleted file mode 100644
index 711419c..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/services/ldap-authentication.js
+++ /dev/null
@@ -1,41 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-import constants from 'hive/utils/constants';
-import ENV from '../config/environment';
-
-export default Ember.Service.extend({
-
-  authenticateLdapPassword: function(password){
-      var password = password;
-      var pathName = window.location.pathname;
-      var pathNameArray = pathName.split("/");
-      var hiveViewVersion = pathNameArray[3];
-      var hiveViewName = pathNameArray[4];
-      var ldapAuthURL = "/api/v1/views/HIVE/versions/"+ hiveViewVersion + "/instances/" + hiveViewName + "/jobs/auth";
-
-      return Ember.$.ajax({
-        url: ldapAuthURL,
-        type: 'post',
-        headers: {'X-Requested-With': 'XMLHttpRequest', 'X-Requested-By': 'ambari'},
-        contentType: 'application/json',
-        data: JSON.stringify({ "password" : password}),
-      })
-  }
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/services/notify.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/services/notify.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/services/notify.js
deleted file mode 100644
index 04c13ff..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/services/notify.js
+++ /dev/null
@@ -1,113 +0,0 @@
-/**
-* 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.
-*/
-import Ember from 'ember';
-import constants from 'hive/utils/constants';
-
-export default Ember.Service.extend({
-  types: constants.notify,
-
-  messages       : Ember.ArrayProxy.create({ content : [] }),
-  notifications  : Ember.ArrayProxy.create({ content : [] }),
-  unseenMessages : Ember.ArrayProxy.create({ content : [] }),
-
-  add: function (type, message, body) {
-    var formattedBody = this.formatMessageBody(body);
-
-    var notification = Ember.Object.create({
-      type    : type,
-      message : message,
-      body    : formattedBody
-    });
-
-    this.messages.pushObject(notification);
-    this.notifications.pushObject(notification);
-    this.unseenMessages.pushObject(notification);
-  },
-
-  info: function (message, body) {
-    this.add(this.types.INFO, message, body);
-  },
-
-  warn: function (message, body) {
-    this.add(this.types.WARN, message, body);
-  },
-
-  pushError: function (message, body) {
-    this.add(this.types.ERROR, message, body);
-  },
-
-  error: function (error) {
-    var message,
-        body;
-
-    if (error.responseJSON) {
-      message = error.responseJSON.message;
-      body = error.responseJSON.trace;
-    } else if (error.errorThrown) {
-      message = error.errorThrown;
-    } else if (error.message) {
-      message = error.message;
-    } else {
-      message = error;
-    }
-
-    this.add(this.types.ERROR, message, body);
-  },
-
-  success: function (message, body) {
-    this.add(this.types.SUCCESS, message, body);
-  },
-
-  formatMessageBody: function (body) {
-    if (!body) {
-      return;
-    }
-
-    if (typeof body === "string") {
-      return body;
-    }
-
-    if (typeof body === "object") {
-      var formattedBody = "";
-      for (var key in body) {
-        formattedBody += "\n\n%@:\n%@".fmt(key, body[key]);
-      }
-
-      return formattedBody;
-    }
-  },
-
-  removeMessage: function (message) {
-    this.messages.removeObject(message);
-    this.notifications.removeObject(message);
-  },
-
-  removeNotification: function (notification) {
-    this.notifications.removeObject(notification);
-  },
-
-  removeAllMessages: function () {
-    this.messages.clear();
-  },
-
-  markMessagesAsSeen: function () {
-    if (this.unseenMessages.get('length')) {
-      this.unseenMessages.removeAt(0, this.unseenMessages.get('length'));
-    }
-  }
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/services/session.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/services/session.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/services/session.js
deleted file mode 100644
index d7d448d..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/services/session.js
+++ /dev/null
@@ -1,48 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-
-export default Ember.Service.extend({
-
-  updateSessionStatus: function (model) {
-    var sessionActive = model.get('sessionActive');
-    var sessionTag    = model.get('sessionTag');
-    var adapter       = this.container.lookup('adapter:application');
-    var url           = adapter.buildURL() + '/jobs/sessions/' + sessionTag;
-
-    if (sessionTag && sessionActive === undefined) {
-      adapter.ajax(url, 'GET')
-        .then(function (response) {
-          model.set('sessionActive', response.session.actual);
-        })
-        .catch(function () {
-          model.set('sessionActive', false);
-        });
-    }
-  },
-
-  killSession: function (model) {
-    var sessionTag = model.get('sessionTag');
-    var adapter    = this.container.lookup('adapter:application');
-    var url        = adapter.buildURL() + '/jobs/sessions/' + sessionTag;
-
-    return adapter.ajax(url, 'DELETE');
-  }
-
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/services/settings.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/services/settings.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/services/settings.js
deleted file mode 100644
index cae3076..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/services/settings.js
+++ /dev/null
@@ -1,193 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-import constants from 'hive/utils/constants';
-
-export default Ember.Service.extend({
-
-  notifyService: Ember.inject.service('notify'),
-
-  settings: Ember.ArrayProxy.create({ content: [] }),
-  predefinedSettings: constants.hiveParameters,
-
-  _createSetting: function(name, value) {
-    var setting = Ember.Object.createWithMixins({
-      valid     : true,
-      value     : Ember.computed.alias('selection.value'),
-      selection : Ember.Object.create()
-    });
-
-    if (name) {
-      setting.set('key', Ember.Object.create({ name: name }));
-    }
-
-    if (value) {
-      setting.set('selection.value', value);
-    }
-
-    return setting;
-  },
-
-  _createDefaultSettings: function(settings) {
-    if (!settings) {
-      return;
-    }
-
-    for (var key in settings) {
-      this.get('settings').pushObject(this._createSetting(key, settings[key]));
-    }
-  },
-
-  _validate: function () {
-    var settings = this.get('settings');
-    var predefinedSettings = this.get('predefinedSettings');
-
-    settings.forEach(function (setting) {
-      var predefined = predefinedSettings.findBy('name', setting.get('key.name'));
-
-      if (!predefined) {
-        return;
-      }
-
-      if (predefined.values && predefined.values.contains(setting.get('value'))) {
-        setting.set('valid', true);
-        return;
-      }
-
-      if (predefined.validate && predefined.validate.test(setting.get('value'))) {
-        setting.set('valid', true);
-        return;
-      }
-
-      if (!predefined.validate) {
-        setting.set('valid', true);
-        return;
-      }
-
-      setting.set('valid', false);
-    });
-  }.observes('settings.@each.value', 'settings.@each.key'),
-
-  add: function() {
-    this.get('settings').pushObject(this._createSetting());
-  },
-
-  createKey: function(name) {
-    var key = { name: name };
-    this.get('predefinedSettings').pushObject(key);
-
-    this.get('settings').findBy('key', null).set('key', key);
-  },
-
-  remove: function(setting) {
-    this.get('settings').removeObject(setting);
-  },
-
-  removeAll: function() {
-    this.get('settings').clear();
-  },
-
-  loadDefaultSettings: function() {
-    var adapter       = this.container.lookup('adapter:application');
-    var url           = adapter.buildURL() + '/savedQueries/defaultSettings';
-    var self = this;
-
-    adapter.ajax(url)
-      .then(function(response) {
-        self._createDefaultSettings(response.settings);
-      })
-      .catch(function(error) {
-        self.get('notifyService').error(error);
-      });
-  },
-
-  saveDefaultSettings: function() {
-    var self     = this;
-    var data     = {};
-    var adapter  = this.container.lookup('adapter:application');
-    var url      = adapter.buildURL() + '/savedQueries/defaultSettings';
-    var settings = this.get('settings');
-
-    var settingException = {};
-
-    try {
-      settings.forEach(function(setting) {
-
-        settingException['value'] = Ember.isEmpty(setting.get('value'));
-
-        if(settingException['value']) {
-          settingException['name'] = setting.get('key.name');
-          throw settingException
-        }
-        data[setting.get('key.name')] = setting.get('value');
-
-      });
-    } catch(e) {
-      if (e!==settingException) throw e;
-    }
-
-
-    if(settingException['value']){
-      self.get('notifyService').error('Please enter the value for '+ settingException['name'] );
-      return;
-    }
-
-    adapter.ajax(url, 'POST', {
-        data: {settings: data }
-      })
-      .then(function(response) {
-        if (response && response.settings) {
-          self.get('notifyService').success(Ember.I18n.t('alerts.success.settings.saved'));
-        } else {
-          self.get('notifyService').error(response);
-        }
-      });
-  },
-
-  getSettings: function() {
-    var settings = this.get('settings');
-    var asString = "";
-
-    if (!settings.get('length')) {
-      return asString;
-    }
-
-    settings.forEach(function(setting) {
-      asString += "set %@=%@;\n".fmt(setting.get('key.name'), setting.get('value'));
-    });
-
-    return asString;
-  },
-
-  parseGlobalSettings: function(query, model) {
-    if (!query || !model || !model.get('globalSettings')) {
-      return;
-    }
-
-    var globals = model.get('globalSettings');
-    var content = query.get('fileContent');
-
-    if (globals !== this.getSettings()) {
-      return;
-    }
-
-    query.set('fileContent', content.replace(globals, ''));
-  }
-
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/styles/.gitkeep
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/styles/.gitkeep b/contrib/views/hive/src/main/resources/ui/hive-web/app/styles/.gitkeep
deleted file mode 100644
index e69de29..0000000

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/styles/app.scss
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/styles/app.scss b/contrib/views/hive/src/main/resources/ui/hive-web/app/styles/app.scss
deleted file mode 100644
index 7598b0e..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/styles/app.scss
+++ /dev/null
@@ -1,716 +0,0 @@
-/**
- * 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.
- */
-
-@import 'vars';
-@import 'dropdown-submenu';
-@import 'mixins';
-@import 'notifications';
-@import 'query-tabs';
-
-a {
-  word-wrap: break-word;
-}
-
-@keyframes flash {
-  0% {
-    background-color: transparent;
-  }
-
-  25% {
-    background-color: #428bca;
-    color: #fff;
-  }
-
-  50% {
-    background-color: transparent;
-    color: #333;
-  }
-
-  75% {
-    background-color: #428bca;
-    color: #fff;
-  }
-
-  100% {
-    background-color: transparent;
-    color: #333;
-  }
-}
-
-.flash {
-  animation: flash 1s;
-}
-
-@-webkit-keyframes fadeIn {
-  0% {opacity: 0;}
-  100% {opacity: 1;}
-}
-
-@keyframes fadeIn {
-  0% {opacity: 0;}
-  100% {opacity: 1;}
-}
-
-.fadeIn {
-  -webkit-animation-name: fadeIn;
-          animation-name: fadeIn;
-}
-
-@-webkit-keyframes fadeOut {
-  0% {opacity: 1;}
-  100% {opacity: 0;}
-}
-
-@keyframes fadeOut {
-  0% {opacity: 1;}
-  100% {opacity: 0;}
-}
-
-.fadeOut {
-  -webkit-animation-name: fadeOut;
-          animation-name: fadeOut;
-}
-
-.empty-list {
-  text-align: center;
-}
-
-#content {
-  padding: 20px 0;
-}
-
-#index-content {
-  display: flex;
-}
-
-#visual-explain {
-  white-space: nowrap;
-
-  .panel-body {
-    overflow: hidden;
-  }
-}
-
-.index-overlay {
-  position: absolute;
-  left: 0;
-  width: 0;
-  z-index: 99;
-  background: white;
-}
-
-aside  {
-  hr {
-    margin: 10px 0;
-  }
-
-  &.no-width {
-    width: 0;
-    overflow: hidden;
-
-    @include animate-width(0.25s);
-  }
-
-  &.col-md-3 {
-    @include animate-width(0.25s);
-  }
-}
-
-.halfed {
-  width: 50%;
-}
-
-.no-padding {
-  padding: 0;
-}
-
-.no-margin {
-  margin: 0;
-}
-
-.toolbox {
-  margin: 15px 15px 0 0;
-
-  .insert-udfs {
-    display: inline-block;
-  }
-}
-
-.history-date-range {
-  white-space: nowrap;
-}
-.history-date-range .fromDate,
-.history-date-range .toDate {
-  width: 48%;
-}
-
-.form-control::-moz-placeholder {
-  color: $placeholder-color;
-}
-
-.form-control:-ms-input-placeholder {
-  color: $placeholder-color;
-}
-
-.form-control::-webkit-input-placeholder {
-  color: $placeholder-color;
-}
-
-.form-group {
-  margin-bottom: 0;
-}
-
-.secondary-row {
-  background: $panel-background;
-}
-
-.btn-group {
-  .dropdown-menu {
-    right: 0;
-    left: auto;
-  }
-}
-
-.CodeMirror {
-  border: 0 1px solid $border-color;
-}
-
-.grip {
-  height: 20px;
-  border: 0 1px 1px solid $border-color;
-  background-color: $panel-background;
-  color: #bbb;
-  text-align: center;
-  font-size: inherit;
-}
-
-.slider {
-  min-width: 200px;
-  margin-right: 8px;
-}
-
-.slider-labels {
-  font-size: 10px;
-}
-
-.modal-backdrop {
-  background-color: white;
-}
-
-.gray {
-  background-color: gray;
-}
-
-.green {
-  background-color: #99CC00;
-}
-
-.red {
-  background-color: #ff3300;
-}
-
-.orange {
-  background-color: #FF9933;
-}
-
-.yellow {
-  background-color: #CCCC00;
-}
-
-.blue {
-  background-color: blue;
-}
-
-.UNKNOWN {
-  color: gray;
-}
-
-.RUNNING, .PENDING, .INITIALIZED, .fa-edit {
-  color: orange;
-}
-
-.SUCCEEDED {
-  color: green;
-}
-
-.CANCELED, .ERROR, .FAILED, .KILLED {
-  color: red;
-}
-
-dropdown .fa-remove {
-  color: red;
-}
-
-.CLOSED {
-  color: blue;
-}
-
-.query-container {
-  position: relative;
-  padding-right: 0;
-  -moz-box-sizing: border-box;
-
-  &.col-md-9 {
-    @include animate-width(0.25s);
-  }
-
-  &.col-md-12 {
-    @include animate-width(0.25s);
-  }
-}
-
-.main-content {
-  width: 96%;
-}
-
-.queries-icon {
-  font-size: 20px;
-
-  &.active {
-    color: white;
-  }
-
-  &.text-icon {
-    font-size: 12px;
-    font-weight: 800;
-  }
-}
-
-.query-context-tab {
-  background: #f1f1f1;
-  border-left: 2px solid #428bca;
-
-  &.active {
-    color: #428bca;
-    border-left: 2px solid white;
-  }
-}
-
-.alert {
-  margin-bottom: 5px;
-  padding-bottom: 10px;
-  padding-top: 10px;
-
-  strong {
-    text-decoration: underline;
-  }
-
-  .alert-message {
-    max-height: 250px;
-    overflow-y: auto;
-  }
-}
-
-body {
-  a, i {
-    cursor: pointer;  }
-
-  dropdown {
-    .btn-group, .dropdown-toggle, .dropdown-menu {
-      width: 100%;
-    }
-  }
-
-  tabs {
-    ul li{
-      background: $panel-background;
-    }
-  }
-
-  table {
-    tbody tr {
-      border: 1px solid #ccc;
-    }
-
-    td *{
-      white-space: nowrap;
-    }
-  }
-
-  column-filter {
-    display: -webkit-inline-flex; /* Safari */
-    display: inline-flex;
-
-    .slider {
-      margin-top: 10px;
-    }
-
-    .btn {
-      padding: 0;
-      border: 0;
-    }
-
-    .form-control {
-      width: auto;
-    }
-
-    .fa {
-      padding: 10px 0;
-    }
-  }
-}
-
-.CodeMirror-hints {
-  min-width: 200px;
-  z-index: 100;
-}
-
-.spinner {
-  width: 36px;
-  height: 36px;
-  background: url("/img/spinner.gif");
-  background-repeat: no-repeat;
-  margin: 0 auto;
-
-  &.small {
-    background-size: 20px;
-    width: 20px;
-    height: 20px;
-  }
-
-  &.inline-spinner {
-    vertical-align: middle;
-    display: inline-block;
-  }
-}
-
-.ellipsis{
-  text-overflow: ellipsis;
-  white-space: nowrap;
-  overflow: hidden;
-  display:inline-block;
-}
-
-.databases {
-  max-height: 500px;
-  overflow-y: auto;
-
-  .tables {
-    padding-left: 10px;
-
-    .columns {
-      padding-left: 10px;
-      .column-name{
-        width: 10em;
-        font-weight: bold;
-        @extend .ellipsis;
-      }
-    }
-  }
-}
-
-@media only screen and (max-width : 992px) {
-  .databases {
-    .tables {
-      .columns {
-        .column-name{
-          width: 5em;
-        }
-      }
-    }
-  }
-}
-
-.collapsible-row {
-  width: 13em;
-  @extend .ellipsis;
-}
-
-.selectize-control.plugin-remove_button [data-value] {
-  padding-right: 0 !important;
-}
-
-.query-editor-panel .panel-body {
-  position: relative;
-  padding-right: 0;
-}
-
-.settings-containers-toggle {
-  position: absolute;
-  top: 0;
-  right: 25px;
-  cursor: pointer;
-}
-
-.settings-container .close-settings {
-  float: right;
-  font-size: 18px;
-  cursor: pointer;
-  line-height: 24px;
-}
-
-.settings-controls {
-  margin: 10px 0;
-}
-
-.setting {
-  float: left;
-  padding: 10px 0 0 0;
-
-  .input-group {
-    width: 100%;
-  }
-  .input-group-addon {
-    text-align: justify;
-    width: 50%;
-    vertical-align: top;
-  }
-}
-
-.setting .remove {
-  line-height: 30px;
-  font-size: 18px;
-  cursor: pointer;
-  position: absolute;
-}
-
-.setting .setting-input-value {
-  width: calc(100% - 30px);
-  display: inline-block;
-  input {
-    height: 33px;
-  }
-}
-.setting .global-setting-value {
-  width: calc(100% - 25px);
-}
-
-.settings-set .settings-set-selector {
-  display: inline-block;
-  width: 300px;
-}
-
-tree-view ul li {
-  padding-left: 10px;
-}
-
-#tez-ui iframe {
-  width: 100%;
-  height: 822px;
-  border: none;
-}
-
-.edge {
-  text-align: center;
-  font-size: 10px;
-  font-weight: 800;
-
-  .edge-path {
-    margin-top: -55px;
-    height: 2px;
-    background-color: #dedede;
-    position: absolute;
-  }
-
-  .edge-arrow {
-    position: absolute;
-    width: 0;
-    height: 0;
-    border-top: 5px solid transparent;
-    border-bottom: 5px solid transparent;
-    border-right: 10px solid black;
-  }
-}
-
-.nodes {
-  width: 100%;
-  position: relative;
-
-  .node-container {
-    text-align: center;
-
-    .node {
-      border: 1px solid #bbb;
-      background: #fefefe;
-      font-size: 12px;
-      box-sizing: border-box;
-      text-align: left;
-      max-width: 200px;
-      margin: 0 25px 100px 0;
-      display: inline-block;
-      vertical-align: top;
-
-      @include box-shadow(1px, 1px, 15px, #888888);
-
-      &.table-node, &.output-node {
-        background-color: ghostwhite;
-        color: gray;
-        padding: 5px;
-        text-align: center;
-        min-width: 100px;
-        line-height: 8px;
-        vertical-align: bottom;
-        margin-bottom: 50px;
-      }
-
-      .node-heading {
-        padding: 5px;
-        text-align: center;
-        background-color: lightslategrey;
-        color: white;
-      }
-
-      .node-content {
-        max-height: 300px;
-        white-space: normal;
-        padding: 5px;
-        overflow-y: auto;
-        overflow-x: hidden;
-
-        .fa {
-          color: green;
-        }
-      }
-
-      .progress {
-        border-radius: 0;
-        margin: 0 10px 10px 10px;
-      }
-    }
-  }
-}
-
-.progress-bar {
-  min-width: 2em;
-}
-
-.messages-controls {
-  margin: 0 0 10px;
-}
-
-#query-results, #upload-table{
-  .table {
-    display: inline-block;
-    overflow: auto;
-  }
-
-  .query-results-tools {
-    margin-top: 10px;
-  }
-
-  input, .selectize-input {
-    width: 300px;
-  }
-}
-
-#upload-controls {
-  .table {
-    display: inline-block;
-    overflow: auto;
-  }
-
-  input, .selectize-input {
-    width: 94px;
-    font-size : smaller;
-  }
-
-  .hidden {
-    visibility:hidden;
-  }
-
-  .visible {
-    visibility:visible;
-  }
-
-  td {
-    padding-right : 5px;
-  }
-}
-
-
-.data-upload-form tr td {
-    padding-right : 5px;
-}
-
-td.data-upload-form-label {
-    width: 150px;
-    padding-left: 50px;
-}
-td.data-upload-form-field {
-    width: 350px;
-}
-
-.hdfsPath {
-  width: 80%;
-  display: inline;
-}
-
-#visualization{
-    .max-rows {
-      float: right;
-    }
-}
-
-#visualization{
-    .max-rows {
-      float: right;
-    }
-}
-
-.mozBoxSizeFix {
-  -moz-box-sizing: border-box;
-}
-.show-data {
-    display : block;
-}
-.hide-data {
-    display : none;
-}
-.no-shadow {
-  box-shadow: none;
-  width: inherit;
-}
-
-.widget-controls {
-  padding-right: 10px;
-}
-
-.accordion-body {
-   word-break: break-all;
-   overflow-y: scroll;
-}
-
-table.no-border, table.no-border tr, table.no-border tr td {
-  border: none;
-}
-
-.red-border {
-  border-color :red;
-}
-
-ul.explainlist li{
-  background: none;
-  word-break: break-all;
-  padding: 0;
-}
-
-pre.explainprint{
- line-height: 0.5;
- padding: 12px 15px;
-}
-.settings-gear {
-  padding:5px;
-  cursor: pointer;
-}
-
-.settings-gear-disabled {
-  @extend .settings-gear;
-
-  color:#ddd;
-  cursor: default;
-}


[16/23] ambari git commit: AMBARI-19302 : removed contrib/views/hive folder and made necessary changes in pom.xml files (nitirajrathore)

Posted by ni...@apache.org.
http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/parsers/xml/XMLParser.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/parsers/xml/XMLParser.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/parsers/xml/XMLParser.java
deleted file mode 100644
index 4edc82c..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/parsers/xml/XMLParser.java
+++ /dev/null
@@ -1,100 +0,0 @@
-/**
- * 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
- * <p/>
- * http://www.apache.org/licenses/LICENSE-2.0
- * <p/>
- * 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.ambari.view.hive.resources.uploads.parsers.xml;
-
-import org.apache.ambari.view.hive.client.Row;
-import org.apache.ambari.view.hive.resources.uploads.parsers.ParseOptions;
-import org.apache.ambari.view.hive.resources.uploads.parsers.Parser;
-import org.apache.ambari.view.hive.resources.uploads.parsers.RowIterator;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-import javax.xml.stream.XMLEventReader;
-import javax.xml.stream.XMLInputFactory;
-import javax.xml.stream.XMLStreamException;
-import java.io.IOException;
-import java.io.Reader;
-import java.util.Collection;
-import java.util.Iterator;
-
-/**
- * assumes XML of following format
- * <table>
- * <row>
- * <col name="col1Name">row1-col1-Data</col>
- * <col name="col2Name">row1-col2-Data</col>
- * <col name="col3Name">row1-col3-Data</col>
- * <col name="col4Name">row1-col4-Data</col>
- * </row>
- * <row>
- * <col name="col1Name">row2-col1-Data</col>
- * <col name="col2Name">row2-col2-Data</col>
- * <col name="col3Name">row2-col3-Data</col>
- * <col name="col4Name">row2-col4-Data</col>
- * </row>
- * </table>
- */
-public class XMLParser extends Parser {
-
-  protected final static Logger LOG =
-          LoggerFactory.getLogger(XMLParser.class);
-
-  private RowIterator iterator;
-  private XMLEventReader xmlReader;
-  private XMLIterator xmlIterator;
-
-  public XMLParser(Reader reader, ParseOptions parseOptions) throws IOException {
-    super(reader, parseOptions);
-    XMLInputFactory factory = XMLInputFactory.newInstance();
-    try {
-      this.xmlReader = factory.createXMLEventReader(reader);
-    } catch (XMLStreamException e) {
-      LOG.error("error occurred while creating xml reader : ", e);
-      throw new IOException("error occurred while creating xml reader : ", e);
-    }
-    xmlIterator = new XMLIterator(this.xmlReader);
-    iterator = new RowIterator(xmlIterator);
-  }
-
-  @Override
-  public Row extractHeader() {
-    Collection<String> headers = this.iterator.extractHeaders();
-    Object[] objs = new Object[headers.size()];
-    Iterator<String> iterator = headers.iterator();
-    for (int i = 0; i < headers.size(); i++) {
-      objs[i] = iterator.next();
-    }
-
-    return new Row(objs);
-  }
-
-  @Override
-  public void close() throws Exception {
-    try {
-      this.xmlReader.close();
-    } catch (XMLStreamException e) {
-      throw new IOException(e);
-    }
-  }
-
-  @Override
-  public Iterator<Row> iterator() {
-    return iterator;
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/query/DeleteQueryInput.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/query/DeleteQueryInput.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/query/DeleteQueryInput.java
deleted file mode 100644
index 1fe30fd..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/query/DeleteQueryInput.java
+++ /dev/null
@@ -1,48 +0,0 @@
-/**
- * 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
- * <p/>
- * http://www.apache.org/licenses/LICENSE-2.0
- * <p/>
- * 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.ambari.view.hive.resources.uploads.query;
-
-public class DeleteQueryInput {
-  private String database;
-  private String table;
-
-  public DeleteQueryInput() {
-  }
-
-  public DeleteQueryInput(String database, String table) {
-    this.database = database;
-    this.table = table;
-  }
-
-  public String getDatabase() {
-    return database;
-  }
-
-  public void setDatabase(String database) {
-    this.database = database;
-  }
-
-  public String getTable() {
-    return table;
-  }
-
-  public void setTable(String table) {
-    this.table = table;
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/query/InsertFromQueryInput.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/query/InsertFromQueryInput.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/query/InsertFromQueryInput.java
deleted file mode 100644
index c568e0b..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/query/InsertFromQueryInput.java
+++ /dev/null
@@ -1,92 +0,0 @@
-/**
- * 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
- * <p/>
- * http://www.apache.org/licenses/LICENSE-2.0
- * <p/>
- * 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.ambari.view.hive.resources.uploads.query;
-
-import org.apache.ambari.view.hive.resources.uploads.ColumnDescriptionImpl;
-
-import java.util.List;
-
-public class InsertFromQueryInput {
-  private String fromDatabase;
-  private String fromTable;
-  private String toDatabase;
-  private String toTable;
-  private List<ColumnDescriptionImpl> header;
-  private Boolean unhexInsert = Boolean.FALSE;
-
-  public InsertFromQueryInput() {
-  }
-
-  public InsertFromQueryInput(String fromDatabase, String fromTable, String toDatabase, String toTable, List<ColumnDescriptionImpl> header, Boolean unhexInsert) {
-    this.fromDatabase = fromDatabase;
-    this.fromTable = fromTable;
-    this.toDatabase = toDatabase;
-    this.toTable = toTable;
-    this.header = header;
-    this.unhexInsert = unhexInsert;
-  }
-
-  public List<ColumnDescriptionImpl> getHeader() {
-    return header;
-  }
-
-  public void setHeader(List<ColumnDescriptionImpl> header) {
-    this.header = header;
-  }
-
-  public Boolean getUnhexInsert() {
-    return unhexInsert;
-  }
-
-  public void setUnhexInsert(Boolean unhexInsert) {
-    this.unhexInsert = unhexInsert;
-  }
-
-  public String getFromDatabase() {
-    return fromDatabase;
-  }
-
-  public void setFromDatabase(String fromDatabase) {
-    this.fromDatabase = fromDatabase;
-  }
-
-  public String getFromTable() {
-    return fromTable;
-  }
-
-  public void setFromTable(String fromTable) {
-    this.fromTable = fromTable;
-  }
-
-  public String getToDatabase() {
-    return toDatabase;
-  }
-
-  public void setToDatabase(String toDatabase) {
-    this.toDatabase = toDatabase;
-  }
-
-  public String getToTable() {
-    return toTable;
-  }
-
-  public void setToTable(String toTable) {
-    this.toTable = toTable;
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/query/LoadQueryInput.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/query/LoadQueryInput.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/query/LoadQueryInput.java
deleted file mode 100644
index 122b754..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/query/LoadQueryInput.java
+++ /dev/null
@@ -1,67 +0,0 @@
-/**
- * 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
- * <p/>
- * http://www.apache.org/licenses/LICENSE-2.0
- * <p/>
- * 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.ambari.view.hive.resources.uploads.query;
-
-/**
- * input for QueryGenerator for generating Load From Query
- */
-public class LoadQueryInput {
-  private String hdfsFilePath;
-  private String databaseName;
-  private String tableName;
-
-  public LoadQueryInput(String hdfsFilePath, String databaseName, String tableName) {
-    this.hdfsFilePath = hdfsFilePath;
-    this.databaseName = databaseName;
-    this.tableName = tableName;
-  }
-
-  public String getHdfsFilePath() {
-    return hdfsFilePath;
-  }
-
-  public void setHdfsFilePath(String hdfsFilePath) {
-    this.hdfsFilePath = hdfsFilePath;
-  }
-
-  public String getDatabaseName() {
-    return databaseName;
-  }
-
-  public void setDatabaseName(String databaseName) {
-    this.databaseName = databaseName;
-  }
-
-  public String getTableName() {
-    return tableName;
-  }
-
-  public void setTableName(String tableName) {
-    this.tableName = tableName;
-  }
-
-  @Override
-  public String toString() {
-    return "LoadQueryInput{" +
-            "hdfsFilePath='" + hdfsFilePath + '\'' +
-            ", databaseName='" + databaseName + '\'' +
-            ", tableName='" + tableName + '\'' +
-            '}';
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/query/QueryGenerator.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/query/QueryGenerator.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/query/QueryGenerator.java
deleted file mode 100644
index 6db89e0..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/query/QueryGenerator.java
+++ /dev/null
@@ -1,142 +0,0 @@
-/**
- * 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
- * <p/>
- * http://www.apache.org/licenses/LICENSE-2.0
- * <p/>
- * 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.ambari.view.hive.resources.uploads.query;
-
-import org.apache.ambari.view.hive.client.ColumnDescription;
-import org.apache.ambari.view.hive.resources.uploads.ColumnDescriptionImpl;
-import org.apache.ambari.view.hive.resources.uploads.HiveFileType;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-import java.util.Collections;
-import java.util.Comparator;
-import java.util.List;
-
-/**
- * generates the sql query from given data
- */
-public class QueryGenerator {
-  protected final static Logger LOG =
-          LoggerFactory.getLogger(QueryGenerator.class);
-
-  public String generateCreateQuery(TableInfo tableInfo) {
-    String tableName = tableInfo.getTableName();
-    List<ColumnDescriptionImpl> cdList = tableInfo.getHeader();
-
-    StringBuilder query = new StringBuilder();
-    query.append("CREATE TABLE ").append(tableName).append(" (");
-    Collections.sort(cdList, new Comparator<ColumnDescription>() {
-      @Override
-      public int compare(ColumnDescription o1, ColumnDescription o2) {
-        return o1.getPosition() - o2.getPosition();
-      }
-    });
-
-    boolean first = true;
-    for (ColumnDescriptionImpl cd : cdList) {
-      if (first) {
-        first = false;
-      } else {
-        query.append(", ");
-      }
-
-      query.append(cd.getName()).append(" ").append(cd.getType());
-      if (cd.getPrecision() != null) {
-        query.append("(").append(cd.getPrecision());
-        if (cd.getScale() != null) {
-          query.append(",").append(cd.getScale());
-        }
-        query.append(")");
-      }
-
-    }
-
-    query.append(")");
-
-    if(tableInfo.getHiveFileType().equals(HiveFileType.TEXTFILE)) {
-      query.append(getRowFormatQuery(tableInfo.getRowFormat()));
-    }
-    query.append(" STORED AS ").append(tableInfo.getHiveFileType().toString());
-    String queryString = query.append(";").toString();
-    LOG.info("Query : {}", queryString);
-    return queryString;
-  }
-
-  private String getRowFormatQuery(RowFormat rowFormat) {
-    StringBuilder sb = new StringBuilder();
-    if(rowFormat != null) {
-      sb.append(" ROW FORMAT DELIMITED");
-      if(rowFormat.getFieldsTerminatedBy() != null ){
-        sb.append(" FIELDS TERMINATED BY '").append(rowFormat.getFieldsTerminatedBy()).append('\'');
-      }
-      if(rowFormat.getEscapedBy() != null){
-        String escape = String.valueOf(rowFormat.getEscapedBy());
-        if(rowFormat.getEscapedBy() == '\\'){
-          escape = escape + '\\'; // special handling of slash as its escape char for strings in hive as well.
-        }
-        sb.append(" ESCAPED BY '").append(escape).append('\'');
-      }
-    }
-
-    return sb.toString();
-  }
-
-  public String generateInsertFromQuery(InsertFromQueryInput ifqi) {
-    StringBuilder insertQuery = new StringBuilder("INSERT INTO TABLE ").append(ifqi.getToDatabase()).append(".")
-                                .append(ifqi.getToTable()).append(" SELECT ");
-
-    boolean first = true;
-    for(ColumnDescriptionImpl column : ifqi.getHeader()){
-      String type = column.getType();
-      boolean unhex = ifqi.getUnhexInsert() && (
-        ColumnDescription.DataTypes.STRING.toString().equals(type)
-          || ColumnDescription.DataTypes.VARCHAR.toString().equals(type)
-          || ColumnDescription.DataTypes.CHAR.toString().equals(type)
-      );
-
-      if(!first){
-        insertQuery.append(", ");
-      }
-
-      if(unhex) {
-        insertQuery.append("UNHEX(");
-      }
-
-      insertQuery.append(column.getName());
-
-      if(unhex) {
-        insertQuery.append(")");
-      }
-
-      first = false;
-    }
-
-    insertQuery.append(" FROM ").append(ifqi.getFromDatabase()).append(".").append(ifqi.getFromTable()).append(";");
-    String query = insertQuery.toString();
-    LOG.info("Insert Query : {}", query);
-    return query;
-  }
-
-  public String generateDropTableQuery(DeleteQueryInput deleteQueryInput) {
-    String dropQuery = new StringBuilder("DROP TABLE ").append(deleteQueryInput.getDatabase())
-                      .append(".").append(deleteQueryInput.getTable()).append(";").toString();
-    LOG.info("Drop Query : {}", dropQuery);
-    return dropQuery;
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/query/RowFormat.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/query/RowFormat.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/query/RowFormat.java
deleted file mode 100644
index 4c1cb2b..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/query/RowFormat.java
+++ /dev/null
@@ -1,57 +0,0 @@
-/**
- * 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
- * <p/>
- * http://www.apache.org/licenses/LICENSE-2.0
- * <p/>
- * 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.ambari.view.hive.resources.uploads.query;
-
-public class RowFormat {
-  private Character fieldsTerminatedBy;
-  private Character escapedBy;
-
-  private RowFormat() {
-  }
-
-  public RowFormat(Character fieldsTerminatedBy, Character escapedBy) {
-    this.fieldsTerminatedBy = fieldsTerminatedBy;
-    this.escapedBy = escapedBy;
-  }
-
-  public Character getFieldsTerminatedBy() {
-    return fieldsTerminatedBy;
-  }
-
-  public void setFieldsTerminatedBy(Character fieldsTerminatedBy) {
-    this.fieldsTerminatedBy = fieldsTerminatedBy;
-  }
-
-  public Character getEscapedBy() {
-    return escapedBy;
-  }
-
-  public void setEscapedBy(Character escapedBy) {
-    this.escapedBy = escapedBy;
-  }
-
-  @Override
-  public String toString() {
-    StringBuilder sb = new StringBuilder("RowFormat{ fieldsTerminatedBy='");
-    sb.append(fieldsTerminatedBy).append( '\'').append(", escapedBy='")
-      .append(escapedBy).append("\'}");
-
-    return sb.toString();
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/query/TableInfo.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/query/TableInfo.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/query/TableInfo.java
deleted file mode 100644
index 76f448c..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/uploads/query/TableInfo.java
+++ /dev/null
@@ -1,96 +0,0 @@
-/**
- * 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
- * <p/>
- * http://www.apache.org/licenses/LICENSE-2.0
- * <p/>
- * 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.ambari.view.hive.resources.uploads.query;
-
-import org.apache.ambari.view.hive.resources.uploads.ColumnDescriptionImpl;
-import org.apache.ambari.view.hive.resources.uploads.HiveFileType;
-
-import java.io.Serializable;
-import java.util.List;
-
-/**
- * used as input in Query generation
- */
-public class TableInfo implements Serializable{
-  private String tableName;
-  private String databaseName;
-  private List<ColumnDescriptionImpl> header;
-  private HiveFileType hiveFileType;
-
-  private RowFormat rowFormat;
-
-  public String getTableName() {
-    return tableName;
-  }
-
-  public void setTableName(String tableName) {
-    this.tableName = tableName;
-  }
-
-  public String getDatabaseName() {
-    return databaseName;
-  }
-
-  public void setDatabaseName(String databaseName) {
-    this.databaseName = databaseName;
-  }
-
-  public List<ColumnDescriptionImpl> getHeader() {
-    return header;
-  }
-
-  public void setHeader(List<ColumnDescriptionImpl> header) {
-    this.header = header;
-  }
-
-  public HiveFileType getHiveFileType() {
-    return hiveFileType;
-  }
-
-  public void setHiveFileType(HiveFileType hiveFileType) {
-    this.hiveFileType = hiveFileType;
-  }
-
-  public RowFormat getRowFormat() {
-    return rowFormat;
-  }
-
-  public void setRowFormat(RowFormat rowFormat) {
-    this.rowFormat = rowFormat;
-  }
-
-  public TableInfo(String databaseName, String tableName, List<ColumnDescriptionImpl> header, HiveFileType hiveFileType, RowFormat rowFormat) {
-    this.databaseName = databaseName;
-    this.tableName = tableName;
-    this.header = header;
-    this.hiveFileType = hiveFileType;
-    this.rowFormat = rowFormat;
-  }
-
-  public TableInfo(TableInfo tableInfo) {
-    this.tableName = tableInfo.tableName;
-    this.databaseName = tableInfo.databaseName;
-    this.header = tableInfo.header;
-    this.hiveFileType = tableInfo.hiveFileType;
-    this.rowFormat = tableInfo.rowFormat;
-  }
-
-  public TableInfo() {
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/utils/BadRequestFormattedException.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/utils/BadRequestFormattedException.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/utils/BadRequestFormattedException.java
deleted file mode 100644
index 0641af1..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/utils/BadRequestFormattedException.java
+++ /dev/null
@@ -1,27 +0,0 @@
-/**
- * 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.ambari.view.hive.utils;
-
-public class BadRequestFormattedException extends ServiceFormattedException {
-  private final static int STATUS = 400;
-
-  public BadRequestFormattedException(String message, Throwable exception) {
-    super(message, exception, STATUS);
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/utils/FilePaginator.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/utils/FilePaginator.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/utils/FilePaginator.java
deleted file mode 100644
index eb1a401..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/utils/FilePaginator.java
+++ /dev/null
@@ -1,127 +0,0 @@
-/**
- * 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.ambari.view.hive.utils;
-
-import org.apache.ambari.view.utils.hdfs.HdfsApi;
-import org.apache.hadoop.fs.FSDataInputStream;
-
-import java.io.IOException;
-import java.nio.charset.Charset;
-import java.util.Arrays;
-
-import static java.lang.Math.ceil;
-
-/**
- * Pagination for HDFS file implementation
- */
-public class FilePaginator {
-  public static int MB = 1024*1024;
-  public static int PAGE_SIZE = 1*MB;
-
-  private String filePath;
-  private HdfsApi hdfsApi;
-
-  /**
-   * Constructor
-   * @param filePath Path to file on HDFS
-   * @param hdfsApi hdfs api
-   */
-  public FilePaginator(String filePath, HdfsApi hdfsApi) {
-    this.filePath = filePath;
-    this.hdfsApi = hdfsApi;
-  }
-
-  /**
-   * Set page size
-   * @param PAGE_SIZE size
-   */
-  public static void setPageSize(int PAGE_SIZE) {
-    FilePaginator.PAGE_SIZE = PAGE_SIZE;
-  }
-
-  /**
-   * Get page count
-   * @return page count
-   * @throws java.io.IOException
-   * @throws InterruptedException
-   */
-  public long pageCount() throws IOException, InterruptedException {
-    return (long)
-        ceil( hdfsApi.getFileStatus(filePath).getLen() / ((double)PAGE_SIZE) );
-  }
-
-  /**
-   * Read one page of size PAGE_SIZE
-   * @param page page index
-   * @return data in UTF-8
-   * @throws java.io.IOException
-   * @throws InterruptedException
-   */
-  public String readPage(long page) throws IOException, InterruptedException {
-    FSDataInputStream stream = hdfsApi.open(filePath);
-    try {
-      stream.seek(page * PAGE_SIZE);
-    } catch (IOException e) {
-      throw new IllegalArgumentException("Page " + page + " does not exists");
-    }
-
-    byte[] buffer = new byte[PAGE_SIZE];
-    int readCount = 0;
-    int read = 0;
-    while(read < PAGE_SIZE) {
-      try {
-        readCount = stream.read(buffer, read, PAGE_SIZE-read);
-      } catch (IOException e) {
-        stream.close();
-        throw e;
-      }
-      if (readCount == -1)
-        break;
-      read += readCount;
-    }
-    if (read != 0) {
-      byte[] readData = Arrays.copyOfRange(buffer, 0, read);
-      return new String(readData, Charset.forName("UTF-8"));
-    } else {
-      if (page == 0) {
-        return "";
-      }
-      throw new IllegalArgumentException("Page " + page + " does not exists");
-    }
-  }
-
-  public String readFull(long sizeLimit) throws IOException, InterruptedException {
-    StringBuilder builder = new StringBuilder();
-    int i = 0;
-    while (true) {
-      try {
-        builder.append(readPage(i++));
-      } catch (IllegalArgumentException ex) {
-        break;
-      }
-      if (sizeLimit != -1 && (i+1)*PAGE_SIZE > sizeLimit)
-        break;
-    }
-    return builder.toString();
-  }
-
-  public String readFull() throws IOException, InterruptedException {
-    return readFull(-1);
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/utils/HiveClientFormattedException.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/utils/HiveClientFormattedException.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/utils/HiveClientFormattedException.java
deleted file mode 100644
index a602d22..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/utils/HiveClientFormattedException.java
+++ /dev/null
@@ -1,26 +0,0 @@
-/**
- * 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.ambari.view.hive.utils;
-
-public class HiveClientFormattedException extends ServiceFormattedException {
-
-  public HiveClientFormattedException(Throwable exception) {
-    super(exception.getMessage(), exception);
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/utils/MisconfigurationFormattedException.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/utils/MisconfigurationFormattedException.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/utils/MisconfigurationFormattedException.java
deleted file mode 100644
index 314b00b..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/utils/MisconfigurationFormattedException.java
+++ /dev/null
@@ -1,47 +0,0 @@
-/**
- * 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.ambari.view.hive.utils;
-
-import org.json.simple.JSONObject;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-import javax.ws.rs.WebApplicationException;
-import javax.ws.rs.core.MediaType;
-import javax.ws.rs.core.Response;
-import java.util.HashMap;
-
-public class MisconfigurationFormattedException extends WebApplicationException {
-  private final static int STATUS = 500;
-  private final static String message = "Parameter \"%s\" is set to null";
-  private final static Logger LOG =
-      LoggerFactory.getLogger(MisconfigurationFormattedException.class);
-
-  public MisconfigurationFormattedException(String name) {
-    super(errorEntity(name));
-  }
-
-  protected static Response errorEntity(String name) {
-    HashMap<String, Object> response = new HashMap<String, Object>();
-    response.put("message", String.format(message, name));
-    response.put("trace", null);
-    response.put("status", STATUS);
-    return Response.status(STATUS).entity(new JSONObject(response)).type(MediaType.APPLICATION_JSON).build();
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/utils/NotFoundFormattedException.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/utils/NotFoundFormattedException.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/utils/NotFoundFormattedException.java
deleted file mode 100644
index 91b11cf..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/utils/NotFoundFormattedException.java
+++ /dev/null
@@ -1,27 +0,0 @@
-/**
- * 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.ambari.view.hive.utils;
-
-public class NotFoundFormattedException extends ServiceFormattedException {
-  private final static int STATUS = 404;
-
-  public NotFoundFormattedException(String message, Throwable exception) {
-    super(message, exception, STATUS);
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/utils/ServiceFormattedException.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/utils/ServiceFormattedException.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/utils/ServiceFormattedException.java
deleted file mode 100644
index d057cdb..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/utils/ServiceFormattedException.java
+++ /dev/null
@@ -1,107 +0,0 @@
-/**
- * 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.ambari.view.hive.utils;
-
-import org.apache.ambari.view.hive.client.HiveInvalidQueryException;
-import org.apache.commons.lang.exception.ExceptionUtils;
-import org.json.simple.JSONObject;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-import javax.ws.rs.WebApplicationException;
-import javax.ws.rs.core.MediaType;
-import javax.ws.rs.core.Response;
-import java.io.PrintWriter;
-import java.io.StringWriter;
-import java.security.AccessControlException;
-import java.util.HashMap;
-
-public class ServiceFormattedException extends WebApplicationException {
-  private final static Logger LOG =
-      LoggerFactory.getLogger(ServiceFormattedException.class);
-
-  public ServiceFormattedException(String message) {
-    super(errorEntity(message, null, suggestStatus(null), null));
-  }
-
-  public ServiceFormattedException(Throwable exception) {
-    super(errorEntity(null, exception, suggestStatus(exception), null));
-  }
-
-  public ServiceFormattedException(String message, Throwable exception) {
-    super(errorEntity(message, exception, suggestStatus(exception), null));
-  }
-
-  public ServiceFormattedException(String message, Throwable exception, int status) {
-    super(errorEntity(message, exception, status, null));
-  }
-
-  public ServiceFormattedException(String message, Exception ex, String curl) {
-    super(errorEntity(message, ex, suggestStatus(ex), curl));
-  }
-
-  private static int suggestStatus(Throwable exception) {
-    int status = 500;
-    if (exception == null) {
-      return status;
-    }
-    if (exception instanceof AccessControlException) {
-      status = 403;
-    }
-    if (exception instanceof HiveInvalidQueryException) {
-      status = 400;
-    }
-    return status;
-  }
-
-  protected static Response errorEntity(String message, Throwable e, int status, String header) {
-    HashMap<String, Object> response = new HashMap<String, Object>();
-
-    String trace = null;
-
-    response.put("message", message);
-    if (e != null) {
-      trace = e.toString() + "\n\n";
-      StringWriter sw = new StringWriter();
-      e.printStackTrace(new PrintWriter(sw));
-      trace += sw.toString();
-
-      if (message == null) {
-        String innerMessage = e.getMessage();
-        String autoMessage;
-
-        if (innerMessage != null)
-          autoMessage = String.format("E090 %s [%s]", innerMessage, e.getClass().getSimpleName());
-        else
-          autoMessage = "E090 " + e.getClass().getSimpleName();
-        response.put("message", autoMessage);
-      }
-    }
-    response.put("trace", trace);
-    response.put("status", status);
-
-    if(message != null && status != 400) LOG.error(message);
-    if(trace != null && status != 400) LOG.error(trace);
-
-    Response.ResponseBuilder responseBuilder = Response.status(status).entity(new JSONObject(response)).type(MediaType.APPLICATION_JSON);
-    if (header != null)
-      responseBuilder.header("X-INFO", header);
-    return responseBuilder.build();
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/utils/SharedObjectsFactory.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/utils/SharedObjectsFactory.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/utils/SharedObjectsFactory.java
deleted file mode 100644
index 45f2fbf..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/utils/SharedObjectsFactory.java
+++ /dev/null
@@ -1,187 +0,0 @@
-/**
- * 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.ambari.view.hive.utils;
-
-import org.apache.ambari.view.ViewContext;
-import org.apache.ambari.view.hive.client.Connection;
-import org.apache.ambari.view.hive.persistence.IStorageFactory;
-import org.apache.ambari.view.hive.persistence.Storage;
-import org.apache.ambari.view.hive.persistence.utils.StorageFactory;
-import org.apache.ambari.view.hive.resources.jobs.OperationHandleControllerFactory;
-import org.apache.ambari.view.hive.resources.jobs.atsJobs.ATSParser;
-import org.apache.ambari.view.hive.resources.jobs.atsJobs.ATSParserFactory;
-import org.apache.ambari.view.hive.resources.jobs.rm.RMParser;
-import org.apache.ambari.view.hive.resources.jobs.rm.RMParserFactory;
-import org.apache.ambari.view.hive.resources.jobs.viewJobs.IJobControllerFactory;
-import org.apache.ambari.view.hive.resources.jobs.viewJobs.JobControllerFactory;
-import org.apache.ambari.view.hive.resources.savedQueries.SavedQueryResourceManager;
-import org.apache.ambari.view.utils.hdfs.HdfsApi;
-import org.apache.ambari.view.utils.hdfs.HdfsApiException;
-import org.apache.ambari.view.utils.hdfs.HdfsUtil;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-import java.util.Iterator;
-import java.util.Map;
-import java.util.concurrent.ConcurrentHashMap;
-
-/**
- * Generates shared connections. Clients with same tag will get the same connection.
- * e.g. user 'admin' using view instance 'HIVE1' will use one connection, another user
- * will use different connection.
- */
-public class SharedObjectsFactory implements IStorageFactory {
-  protected final static Logger LOG =
-      LoggerFactory.getLogger(SharedObjectsFactory.class);
-
-  private ViewContext context;
-  private final IStorageFactory storageFactory;
-  private final ATSParserFactory atsParserFactory;
-  private final RMParserFactory rmParserFactory;
-
-  private static final Map<Class, Map<String, Object>> localObjects = new ConcurrentHashMap<Class, Map<String, Object>>();
-
-  public SharedObjectsFactory(ViewContext context) {
-    this.context = context;
-    this.storageFactory = new StorageFactory(context);
-    this.atsParserFactory = new ATSParserFactory(context);
-    this.rmParserFactory = new RMParserFactory(context);
-
-    synchronized (localObjects) {
-      if (localObjects.size() == 0) {
-        localObjects.put(OperationHandleControllerFactory.class, new ConcurrentHashMap<String, Object>());
-        localObjects.put(Storage.class, new ConcurrentHashMap<String, Object>());
-        localObjects.put(IJobControllerFactory.class, new ConcurrentHashMap<String, Object>());
-        localObjects.put(ATSParser.class, new ConcurrentHashMap<String, Object>());
-        localObjects.put(SavedQueryResourceManager.class, new ConcurrentHashMap<String, Object>());
-        localObjects.put(HdfsApi.class, new ConcurrentHashMap<String, Object>());
-        localObjects.put(RMParser.class, new ConcurrentHashMap<String, Object>());
-      }
-    }
-  }
-
-  // =============================
-
-  public OperationHandleControllerFactory getOperationHandleControllerFactory() {
-    if (!localObjects.get(OperationHandleControllerFactory.class).containsKey(getTagName()))
-      localObjects.get(OperationHandleControllerFactory.class).put(getTagName(), new OperationHandleControllerFactory(context, this));
-    return (OperationHandleControllerFactory) localObjects.get(OperationHandleControllerFactory.class).get(getTagName());
-  }
-
-  // =============================
-  @Override
-  public Storage getStorage() {
-    if (!localObjects.get(Storage.class).containsKey(getTagName()))
-      localObjects.get(Storage.class).put(getTagName(), storageFactory.getStorage());
-    return (Storage) localObjects.get(Storage.class).get(getTagName());
-  }
-
-  // =============================
-  public IJobControllerFactory getJobControllerFactory() {
-    if (!localObjects.get(IJobControllerFactory.class).containsKey(getTagName()))
-      localObjects.get(IJobControllerFactory.class).put(getTagName(), new JobControllerFactory(context, this));
-    return (IJobControllerFactory) localObjects.get(IJobControllerFactory.class).get(getTagName());
-  }
-
-  // =============================
-
-  public SavedQueryResourceManager getSavedQueryResourceManager() {
-    if (!localObjects.get(SavedQueryResourceManager.class).containsKey(getTagName()))
-      localObjects.get(SavedQueryResourceManager.class).put(getTagName(), new SavedQueryResourceManager(context, this));
-    return (SavedQueryResourceManager) localObjects.get(SavedQueryResourceManager.class).get(getTagName());
-  }
-
-  // =============================
-  public ATSParser getATSParser() {
-    if (!localObjects.get(ATSParser.class).containsKey(getTagName()))
-      localObjects.get(ATSParser.class).put(getTagName(), atsParserFactory.getATSParser());
-    return (ATSParser) localObjects.get(ATSParser.class).get(getTagName());
-  }
-
-  // =============================
-  public RMParser getRMParser() {
-    if (!localObjects.get(RMParser.class).containsKey(getTagName()))
-      localObjects.get(RMParser.class).put(getTagName(), rmParserFactory.getRMParser());
-    return (RMParser) localObjects.get(RMParser.class).get(getTagName());
-  }
-
-  // =============================
-  public HdfsApi getHdfsApi() {
-    if (!localObjects.get(HdfsApi.class).containsKey(getTagName())) {
-      try {
-        localObjects.get(HdfsApi.class).put(getTagName(), HdfsUtil.connectToHDFSApi(context));
-      } catch (HdfsApiException e) {
-        String message = "F060 Couldn't open connection to HDFS";
-        LOG.error(message);
-        throw new ServiceFormattedException(message, e);
-      }
-    }
-    return (HdfsApi) localObjects.get(HdfsApi.class).get(getTagName());
-  }
-
-  /**
-   * Generates tag name. Clients with same tag will share one connection.
-   * @return tag name
-   */
-  public String getTagName() {
-    if (context == null)
-      return "<null>";
-    return String.format("%s:%s", context.getInstanceName(), context.getUsername());
-  }
-
-  /**
-   * For testing purposes, ability to substitute some local object
-   */
-  public void setInstance(Class clazz, Object object) {
-    localObjects.get(clazz).put(getTagName(), object);
-  }
-
-  /**
-   * For testing purposes, ability to clear all local objects of particular class
-   */
-  public void clear(Class clazz) {
-    localObjects.get(clazz).clear();
-  }
-
-  /**
-   * For testing purposes, ability to clear all connections
-   */
-  public void clear() {
-    for(Map<String, Object> map : localObjects.values()) {
-      map.clear();
-    }
-  }
-
-  /**
-   *
-   * Drops all objects for give instance name.
-   *
-   * @param instanceName
-   */
-  public static void dropInstanceCache(String instanceName){
-    for(Map<String,Object> cache : localObjects.values()){
-      for(Iterator<Map.Entry<String, Object>> it = cache.entrySet().iterator(); it.hasNext();){
-        Map.Entry<String, Object> entry = it.next();
-        if(entry.getKey().startsWith(instanceName+":")){
-          it.remove();
-        }
-      }
-    }
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/.bowerrc
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/.bowerrc b/contrib/views/hive/src/main/resources/ui/hive-web/.bowerrc
deleted file mode 100644
index 959e169..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/.bowerrc
+++ /dev/null
@@ -1,4 +0,0 @@
-{
-  "directory": "bower_components",
-  "analytics": false
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/.editorconfig
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/.editorconfig b/contrib/views/hive/src/main/resources/ui/hive-web/.editorconfig
deleted file mode 100644
index 47c5438..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/.editorconfig
+++ /dev/null
@@ -1,34 +0,0 @@
-# EditorConfig helps developers define and maintain consistent
-# coding styles between different editors and IDEs
-# editorconfig.org
-
-root = true
-
-
-[*]
-end_of_line = lf
-charset = utf-8
-trim_trailing_whitespace = true
-insert_final_newline = true
-indent_style = space
-indent_size = 2
-
-[*.js]
-indent_style = space
-indent_size = 2
-
-[*.hbs]
-insert_final_newline = false
-indent_style = space
-indent_size = 2
-
-[*.css]
-indent_style = space
-indent_size = 2
-
-[*.html]
-indent_style = space
-indent_size = 2
-
-[*.{diff,md}]
-trim_trailing_whitespace = false

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/.ember-cli
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/.ember-cli b/contrib/views/hive/src/main/resources/ui/hive-web/.ember-cli
deleted file mode 100644
index 3da2738..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/.ember-cli
+++ /dev/null
@@ -1,27 +0,0 @@
-/**
- * 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.
- */
-
-{
-  /**
-    Ember CLI sends analytics information by default. The data is completely
-    anonymous, but there are times when you might want to disable this behavior.
-
-    Setting `disableAnalytics` to true will prevent any data from being sent.
-  */
-  "disableAnalytics": true
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/.gitignore
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/.gitignore b/contrib/views/hive/src/main/resources/ui/hive-web/.gitignore
deleted file mode 100644
index e1b6b28..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/.gitignore
+++ /dev/null
@@ -1,37 +0,0 @@
-# Numerous always-ignore extensions
-*.diff
-*.err
-*.orig
-*.log
-*.rej
-*.swo
-*.swp
-*.vi
-*~
-*.sass-cache
-
-# OS or Editor folders
-.DS_Store
-.cache
-.project
-.settings
-.tmproj
-dist
-nbproject
-Thumbs.db
-
-# NPM packages folder.
-node_modules/
-
-bower_components/
-
-node/
-
-# Brunch folder for temporary files.
-tmp/
-
-public/
-
-_generators/
-
-coverage.json

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/.jshintrc
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/.jshintrc b/contrib/views/hive/src/main/resources/ui/hive-web/.jshintrc
deleted file mode 100644
index 0195538..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/.jshintrc
+++ /dev/null
@@ -1,33 +0,0 @@
-{
-  "predef": [
-    "document",
-    "window",
-    "-Promise",
-    "d3"
-  ],
-  "browser" : true,
-  "boss" : true,
-  "curly": true,
-  "debug": false,
-  "devel": true,
-  "eqeqeq": false,
-  "evil": true,
-  "forin": false,
-  "immed": false,
-  "laxbreak": false,
-  "newcap": true,
-  "noarg": true,
-  "noempty": false,
-  "nonew": false,
-  "nomen": false,
-  "onevar": false,
-  "plusplus": false,
-  "regexp": false,
-  "undef": true,
-  "sub": true,
-  "strict": false,
-  "white": false,
-  "eqnull": true,
-  "esnext": true,
-  "unused": true
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/.travis.yml
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/.travis.yml b/contrib/views/hive/src/main/resources/ui/hive-web/.travis.yml
deleted file mode 100644
index 5d96e28..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/.travis.yml
+++ /dev/null
@@ -1,38 +0,0 @@
-# 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.
-
----
-language: node_js
-node_js:
-  - "0.12"
-
-sudo: false
-
-cache:
-  directories:
-    - node_modules
-
-before_install:
-  - "npm config set spin false"
-  - "npm install -g npm@^2"
-
-install:
-  - npm install -g bower
-  - npm install
-  - bower install
-
-script:
-  - npm test

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/Brocfile.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/Brocfile.js b/contrib/views/hive/src/main/resources/ui/hive-web/Brocfile.js
deleted file mode 100644
index 318d1f8..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/Brocfile.js
+++ /dev/null
@@ -1,54 +0,0 @@
-/**
- * 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.
- */
-
-/* global require, module */
-
-var EmberApp = require('ember-cli/lib/broccoli/ember-app');
-
-var app = new EmberApp({
-  autoprefixer: {
-    browsers: ['last 3 version']
-  },
-  'ember-cli-selectize': {
-    //valid values are `default`, `bootstrap2`, `bootstrap3` or false
-    'theme': 'bootstrap3'
-  },
-  vendorFiles: {
-    'handlebars.js': null
-  },
-  hinting: false
-});
-
-app.import('bower_components/ember/ember-template-compiler.js');
-app.import('bower_components/bootstrap/dist/js/bootstrap.js');
-app.import('bower_components/bootstrap/dist/css/bootstrap.css');
-app.import('bower_components/bootstrap/dist/css/bootstrap.css.map', {
-  destDir: 'assets'
-});
-
-app.import('bower_components/ember-i18n/lib/i18n.js');
-app.import('bower_components/ember-i18n/lib/i18n-plurals.js');
-
-app.import('vendor/codemirror/codemirror-min.js');
-app.import('vendor/codemirror/sql-hint.js');
-app.import('vendor/codemirror/show-hint.js');
-app.import('vendor/codemirror/codemirror.css');
-app.import('vendor/codemirror/show-hint.css');
-app.import('vendor/dagre.min.js');
-
-module.exports = app.toTree();

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/README.md
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/README.md b/contrib/views/hive/src/main/resources/ui/hive-web/README.md
deleted file mode 100644
index 2237863..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/README.md
+++ /dev/null
@@ -1,14 +0,0 @@
-<!---
-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](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.
--->

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/adapters/application.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/adapters/application.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/adapters/application.js
deleted file mode 100644
index 2c68b89..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/adapters/application.js
+++ /dev/null
@@ -1,54 +0,0 @@
-/**
- * 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.
- */
-
-import DS from 'ember-data';
-import Ember from 'ember';
-import constants from 'hive/utils/constants';
-
-export default DS.RESTAdapter.extend({
-
-  init: function() {
-    Ember.$.ajaxSetup({
-      cache: false
-    })
-  },
-
-  headers: {
-    'X-Requested-By': 'ambari',
-    'Content-Type': 'application/json'
-    //,'Authorization': 'Basic YWRtaW46YWRtaW4='
-  },
-
-  buildURL: function () {
-    var version = constants.adapter.version,
-        instanceName = constants.adapter.instance;
-
-    var params = window.location.pathname.split('/').filter(function (param) {
-      return !!param;
-    });
-
-    if (params[params.length - 3] === 'HIVE') {
-      version = params[params.length - 2];
-      instanceName = params[params.length - 1];
-    }
-
-    var prefix = constants.adapter.apiPrefix + version + constants.adapter.instancePrefix + instanceName;
-    var url = this._super.apply(this, arguments);
-    return prefix + url;
-  }
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/adapters/database.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/adapters/database.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/adapters/database.js
deleted file mode 100644
index cdbd43b..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/adapters/database.js
+++ /dev/null
@@ -1,25 +0,0 @@
-/**
- * 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.
- */
-
-import application from './application';
-
-export default application.extend({
-  pathForType: function (type) {
-    return 'resources/ddl/' + type;
-  }
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/adapters/file-upload.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/adapters/file-upload.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/adapters/file-upload.js
deleted file mode 100644
index 7bb6e0b..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/adapters/file-upload.js
+++ /dev/null
@@ -1,30 +0,0 @@
-/**
- * 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.
- */
-
-import EmberUploader from 'ember-uploader';
-import Ember from 'ember';
-
-export default EmberUploader.Uploader.extend({
-  headers: {},
-
-  // Override
-  _ajax: function(settings) {
-    settings = Ember.merge(settings, this.getProperties('headers'));
-    return this._super(settings);
-  }
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/adapters/file.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/adapters/file.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/adapters/file.js
deleted file mode 100644
index 47894c1..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/adapters/file.js
+++ /dev/null
@@ -1,26 +0,0 @@
-/**
- * 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.
- */
-
-import application from './application';
-import constants from 'hive/utils/constants';
-
-export default application.extend({
-  pathForType: function (type) {
-    return constants.adapter.resourcePrefix + type;
-  }
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/adapters/upload-table.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/adapters/upload-table.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/adapters/upload-table.js
deleted file mode 100644
index 76fce50..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/adapters/upload-table.js
+++ /dev/null
@@ -1,89 +0,0 @@
-/**
- * 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.
- */
-
-import EmberUploader from 'ember-uploader';
-import Ember from 'ember';
-import application from './application';
-import FileUploader from './file-upload';
-
-export default application.extend({
-
-  buildUploadURL: function (path) {
-    return this.buildURL() + "/resources/upload/" + path;
-  },
-
-  uploadFiles: function (path, files, extras) {
-    var uploadUrl = this.buildUploadURL(path);
-
-    console.log("uplaoder : uploadURL : ", uploadUrl, " extras : ", extras , "files : ", files);
-
-    var hdrs = Ember.$.extend(true, {},this.get('headers'));
-    delete hdrs['Content-Type'];
-    var uploader = FileUploader.create({
-      headers: hdrs,
-      url: uploadUrl
-    });
-
-    if (!Ember.isEmpty(files)) {
-      var promise = uploader.upload(files[0], extras);
-      return promise;
-    }
-  },
-
-  createTable: function (tableData) {
-    console.log("creating table with data :", tableData);
-    return this.doPost("createTable",tableData);
-  },
-
-  insertIntoTable: function(insertData){
-    console.log("inserting into table with data : ", insertData);
-    return this.doPost("insertIntoTable",insertData);
-  },
-
-  deleteTable: function(deleteData){
-    console.log("delete table with info : ", deleteData);
-    return this.doPost("deleteTable",deleteData);
-  },
-
-  doPost : function(path,inputData){
-    var self = this;
-    return new Ember.RSVP.Promise(function(resolve,reject){
-                 Ember.$.ajax({
-                     url :  self.buildUploadURL(path),
-                     type : 'post',
-                     data: JSON.stringify(inputData),
-                     headers: self.get('headers'),
-                     dataType : 'json'
-                 }).done(function(data) {
-                     resolve(data);
-                 }).fail(function(error) {
-                     reject(error);
-                 });
-              });
-  },
-
-  previewFromHDFS : function(previewFromHdfsData){
-    console.log("preview from hdfs with info : ", previewFromHdfsData);
-    return this.doPost("previewFromHdfs",previewFromHdfsData)
-  },
-
-  uploadFromHDFS : function(uploadFromHdfsData){
-    console.log("upload from hdfs with info : ", uploadFromHdfsData);
-    return this.doPost("uploadFromHDFS",uploadFromHdfsData)
-  }
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/app.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/app.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/app.js
deleted file mode 100644
index f35a5a3..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/app.js
+++ /dev/null
@@ -1,34 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-import Resolver from 'ember/resolver';
-import loadInitializers from 'ember/load-initializers';
-import config from './config/environment';
-
-Ember.MODEL_FACTORY_INJECTIONS = true;
-
-var App = Ember.Application.extend({
-  modulePrefix: config.modulePrefix,
-  podModulePrefix: config.podModulePrefix,
-  Resolver: Resolver
-});
-
-loadInitializers(App, config.modulePrefix);
-
-export default App;

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/components/.gitkeep
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/components/.gitkeep b/contrib/views/hive/src/main/resources/ui/hive-web/app/components/.gitkeep
deleted file mode 100644
index e69de29..0000000

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/components/alert-message-widget.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/components/alert-message-widget.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/components/alert-message-widget.js
deleted file mode 100644
index 565d93d..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/components/alert-message-widget.js
+++ /dev/null
@@ -1,35 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-
-export default Ember.Component.extend({
-  actions: {
-    remove: function () {
-      this.sendAction('removeMessage', this.get('message'));
-    },
-
-    toggleMessage: function () {
-      this.toggleProperty('message.isExpanded');
-
-      if (!this.get('message.isExpanded')) {
-        this.sendAction('removeLater', this.get('message'));
-      }
-    }
-  }
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/components/collapsible-widget.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/components/collapsible-widget.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/components/collapsible-widget.js
deleted file mode 100644
index eb174ab..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/components/collapsible-widget.js
+++ /dev/null
@@ -1,38 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-
-export default Ember.Component.extend({
-  tagName: 'collapsible',
-
-  actions: {
-    toggle: function () {
-      this.toggleProperty('isExpanded');
-
-      if (this.get('isExpanded')) {
-        this.sendAction('expanded', this.get('heading'), this.get('toggledParam'));
-      }
-    },
-
-    sendControlAction: function (action) {
-      this.set('controlAction', action);
-      this.sendAction('controlAction', this.get('heading'), this.get('toggledParam'));
-    }
-  }
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/components/column-filter-widget.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/components/column-filter-widget.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/components/column-filter-widget.js
deleted file mode 100644
index 461dabe..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/components/column-filter-widget.js
+++ /dev/null
@@ -1,56 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-
-export default Ember.Component.extend({
-  tagName: 'column-filter',
-
-  didInsertElement: function () {
-    if (this.get('filterValue')) {
-      this.send('sendFilter');
-    }
-  },
-
-  isSorted: (function () {
-    var sortProperties = this.get('sortProperties');
-
-    if (sortProperties) {
-      return sortProperties[0] === this.get('column.property');
-    } else {
-      return false;
-    }
-  }).property('sortProperties'),
-
-  actions: {
-    sendSort: function () {
-      this.sendAction('columnSorted', this.get('column.property'));
-    },
-
-    sendFilter: function (params) {
-      if (params && (params.from || params.from === 0) && (params.to || params.to === 0)) {
-        this.set('filterValue', Ember.Object.create({
-          min: params.from,
-          max: params.to
-        }));
-      }
-
-      this.sendAction('columnFiltered', this.get('column.property'), this.get('filterValue'));
-    }
-  }
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/components/date-range-widget.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/components/date-range-widget.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/components/date-range-widget.js
deleted file mode 100644
index 8e9c074..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/components/date-range-widget.js
+++ /dev/null
@@ -1,98 +0,0 @@
-/**
- * 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.
- */
-
- /* globals moment */
-
-import Ember from 'ember';
-
-export default Ember.Component.extend({
-  displayFromDate: function () {
-    return moment(this.get('dateRange.from')).format('MM/DD/YYYY');
-  }.property('dateRange.from'),
-
-  displayToDate: function () {
-    return moment(this.get('dateRange.to')).format('MM/DD/YYYY');
-  }.property('dateRange.to'),
-
-  updateMinDate: function () {
-    if (this.get('rendered')) {
-      this.$('.toDate').datepicker("option", "minDate", new Date(this.get('dateRange.from')));
-    }
-  }.observes('dateRange.from'),
-
-  updateMaxDate: function () {
-    if (this.get('rendered')) {
-      this.$('.fromDate').datepicker("option", "maxDate", new Date(this.get('dateRange.to')));
-    }
-  }.observes('dateRange.to'),
-
-  didInsertElement: function () {
-    var self = this;
-    var dateRange = this.get('dateRange');
-
-    if (!dateRange.get('min') && !dateRange.get('max')) {
-      dateRange.set('max', new Date());
-    }
-
-    if (!dateRange.get('from') && !dateRange.get('to')) {
-      dateRange.set('from', dateRange.get('min'));
-      dateRange.set('to', dateRange.get('max'));
-    }
-
-    this.$(".fromDate").datepicker({
-      defaultDate: new Date(dateRange.get("from")),
-      maxDate: new Date(dateRange.get('to')),
-
-      onSelect: function (selectedDate) {
-        self.$(".toDate").datepicker("option", "minDate", selectedDate);
-
-        dateRange.set('from', new Date(selectedDate).getTime());
-        self.sendAction('rangeChanged', dateRange);
-      }
-    });
-
-    this.$(".toDate").datepicker({
-      defaultDate: new Date(dateRange.get('to')),
-
-      minDate: new Date(dateRange.get('from')),
-
-      onSelect: function (selectedDate) {
-        selectedDate += ' 23:59';
-
-        self.$(".fromDate").datepicker("option", "maxDate", selectedDate);
-
-        dateRange.set('to', new Date(selectedDate).getTime());
-        self.sendAction('rangeChanged', dateRange);
-      }
-    });
-
-    this.$(".fromDate").on('blur', function() {
-      if(moment(self.$(".fromDate").val(), 'MM/DD/YYYY', true).format() === 'Invalid date'){
-        self.$(".fromDate").val('')
-      }
-    });
-
-    this.$(".toDate").on('blur', function() {
-      if(moment(self.$(".toDate").val(), 'MM/DD/YYYY', true).format() === 'Invalid date'){
-        self.$(".toDate").val('')
-      }
-    });
-
-    this.set('rendered', true);
-  }
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/components/expander-widget.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/components/expander-widget.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/components/expander-widget.js
deleted file mode 100644
index 12da9ea..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/components/expander-widget.js
+++ /dev/null
@@ -1,36 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-
-export default Ember.Component.extend({
-  tagName: 'expander',
-
-  didInsertElement: function () {
-    if (this.get('isExpanded')) {
-      this.$('.accordion-body').toggle();
-    }
-  },
-
-  actions: {
-    toggle: function () {
-      this.toggleProperty('isExpanded');
-      this.$('.accordion-body').toggle(200);
-    }
-  }
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/components/extended-input.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/components/extended-input.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/components/extended-input.js
deleted file mode 100644
index 9b30201..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/components/extended-input.js
+++ /dev/null
@@ -1,50 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-
-export default Ember.TextField.extend(Ember.I18n.TranslateableProperties, {
-  didInsertElement: function () {
-    var dynamicValue = this.get('dynamicValue');
-    var dynamicContext = this.get('dynamicContext');
-
-    if (dynamicValue && dynamicContext) {
-      this.set('value', dynamicContext.get(dynamicValue));
-    }
-  },
-
-  sendValueChanged: function () {
-    var dynamicValue = this.get('dynamicValue');
-    var dynamicContext = this.get('dynamicContext');
-
-    if (dynamicValue && dynamicContext) {
-      dynamicContext.set(dynamicValue, this.get('value'));
-    }
-
-    this.sendAction('valueChanged', this.get('value'));
-  },
-
-  keyUp: function (e) {
-    //if user has pressed enter
-    if (e.keyCode === 13) {
-      this.sendAction('valueSearched', this.get('value'));
-    } else {
-      Ember.run.debounce(this, this.get('sendValueChanged'), 300);
-    }
-  }
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/components/file-upload.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/components/file-upload.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/components/file-upload.js
deleted file mode 100644
index 5dc7746..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/components/file-upload.js
+++ /dev/null
@@ -1,34 +0,0 @@
-/**
- * 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.
- */
-
-import EmberUploader from 'ember-uploader';
-
-export default EmberUploader.FileField.extend({
-  onChangeUploadFiles : function(){
-    if(!this.get("uploadFiles")){
-      // files were cleared by the controller so clear here as well.
-      this.set("files");
-      this.set("value");
-    }
-  }.observes("uploadFiles"),
-  filesDidChange: function(files) {
-    if( files ) {
-      this.sendAction('filesUploaded', files); // sends this action to controller.
-    }
-  }
-});


[20/23] ambari git commit: AMBARI-19302 : removed contrib/views/hive folder and made necessary changes in pom.xml files (nitirajrathore)

Posted by ni...@apache.org.
http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/files/FileService.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/files/FileService.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/files/FileService.java
deleted file mode 100644
index 4e1d24f..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/files/FileService.java
+++ /dev/null
@@ -1,266 +0,0 @@
-/**
- * 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.ambari.view.hive.resources.files;
-
-import com.jayway.jsonpath.JsonPath;
-import org.apache.ambari.view.ViewContext;
-import org.apache.ambari.view.ViewResourceHandler;
-import org.apache.ambari.view.hive.BaseService;
-import org.apache.ambari.view.hive.utils.*;
-import org.apache.ambari.view.utils.hdfs.HdfsApi;
-import org.apache.ambari.view.utils.hdfs.HdfsUtil;
-import org.apache.commons.codec.binary.Base64;
-import org.apache.commons.io.IOUtils;
-import org.apache.hadoop.fs.FSDataOutputStream;
-import org.apache.hadoop.fs.FileAlreadyExistsException;
-import org.json.simple.JSONObject;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-import javax.inject.Inject;
-import javax.servlet.http.HttpServletResponse;
-import javax.ws.rs.*;
-import javax.ws.rs.core.Context;
-import javax.ws.rs.core.MediaType;
-import javax.ws.rs.core.Response;
-import javax.ws.rs.core.UriInfo;
-import java.io.FileNotFoundException;
-import java.io.IOException;
-import java.io.InputStream;
-import java.net.URL;
-import java.util.HashMap;
-import org.apache.ambari.view.commons.hdfs.UserService;
-
-/**
- * File access resource
- * API:
- * GET /:path
- *      read entire file
- * POST /
- *      create new file
- *      Required: filePath
- *      file should not already exists
- * PUT /:path
- *      update file content
- */
-public class FileService extends BaseService {
-  public static final String FAKE_FILE = "fakefile://";
-  public static final String JSON_PATH_FILE = "jsonpath:";
-
-  @Inject
-  ViewResourceHandler handler;
-
-  protected final static Logger LOG =
-      LoggerFactory.getLogger(FileService.class);
-
-  /**
-   * Get single item
-   */
-  @GET
-  @Path("{filePath:.*}")
-  @Produces(MediaType.APPLICATION_JSON)
-  public Response getFilePage(@PathParam("filePath") String filePath, @QueryParam("page") Long page) throws IOException, InterruptedException {
-
-    LOG.debug("Reading file " + filePath);
-    try {
-      FileResource file = new FileResource();
-
-      if (page == null)
-        page = 0L;
-
-      if (filePath.startsWith(FAKE_FILE)) {
-        if (page > 1)
-          throw new IllegalArgumentException("There's only one page in fake files");
-
-        String encodedContent = filePath.substring(FAKE_FILE.length());
-        String content = new String(Base64.decodeBase64(encodedContent));
-
-        fillFakeFileObject(filePath, file, content);
-      } else if (filePath.startsWith(JSON_PATH_FILE)) {
-        if (page > 1)
-          throw new IllegalArgumentException("There's only one page in fake files");
-
-        String content = getJsonPathContentByUrl(filePath);
-        fillFakeFileObject(filePath, file, content);
-      } else  {
-
-        filePath = sanitizeFilePath(filePath);
-        FilePaginator paginator = new FilePaginator(filePath, getSharedObjectsFactory().getHdfsApi());
-
-        fillRealFileObject(filePath, page, file, paginator);
-      }
-
-      JSONObject object = new JSONObject();
-      object.put("file", file);
-      return Response.ok(object).status(200).build();
-    } catch (WebApplicationException ex) {
-      throw ex;
-    } catch (FileNotFoundException ex) {
-      throw new NotFoundFormattedException(ex.getMessage(), ex);
-    } catch (IllegalArgumentException ex) {
-      throw new BadRequestFormattedException(ex.getMessage(), ex);
-    } catch (Exception ex) {
-      throw new ServiceFormattedException(ex.getMessage(), ex);
-    }
-  }
-
-  protected String getJsonPathContentByUrl(String filePath) throws IOException {
-    URL url = new URL(filePath.substring(JSON_PATH_FILE.length()));
-
-    InputStream responseInputStream = context.getURLStreamProvider().readFrom(url.toString(), "GET",
-        (String)null, new HashMap<String, String>());
-    String response = IOUtils.toString(responseInputStream);
-
-    for (String ref : url.getRef().split("!")) {
-      response = JsonPath.read(response, ref);
-    }
-    return response;
-  }
-
-  public void fillRealFileObject(String filePath, Long page, FileResource file, FilePaginator paginator) throws IOException, InterruptedException {
-    file.setFilePath(filePath);
-    file.setFileContent(paginator.readPage(page));
-    file.setHasNext(paginator.pageCount() > page + 1);
-    file.setPage(page);
-    file.setPageCount(paginator.pageCount());
-  }
-
-  public void fillFakeFileObject(String filePath, FileResource file, String content) {
-    file.setFilePath(filePath);
-    file.setFileContent(content);
-    file.setHasNext(false);
-    file.setPage(0);
-    file.setPageCount(1);
-  }
-
-  /**
-   * Delete single item
-   */
-  @DELETE
-  @Path("{filePath:.*}")
-  public Response deleteFile(@PathParam("filePath") String filePath) throws IOException, InterruptedException {
-    try {
-      filePath = sanitizeFilePath(filePath);
-      LOG.debug("Deleting file " + filePath);
-      if (getSharedObjectsFactory().getHdfsApi().delete(filePath, false)) {
-        return Response.status(204).build();
-      }
-      throw new NotFoundFormattedException("FileSystem.delete returned false", null);
-    } catch (WebApplicationException ex) {
-      throw ex;
-    } catch (Exception ex) {
-      throw new ServiceFormattedException(ex.getMessage(), ex);
-    }
-  }
-
-  /**
-   * Update item
-   */
-  @PUT
-  @Path("{filePath:.*}")
-  @Consumes(MediaType.APPLICATION_JSON)
-  public Response updateFile(FileResourceRequest request,
-                             @PathParam("filePath") String filePath) throws IOException, InterruptedException {
-    try {
-      filePath = sanitizeFilePath(filePath);
-      LOG.debug("Rewriting file " + filePath);
-      FSDataOutputStream output = getSharedObjectsFactory().getHdfsApi().create(filePath, true);
-      output.writeBytes(request.file.getFileContent());
-      output.close();
-      return Response.status(204).build();
-    } catch (WebApplicationException ex) {
-      throw ex;
-    } catch (Exception ex) {
-      throw new ServiceFormattedException(ex.getMessage(), ex);
-    }
-  }
-
-  /**
-   * Create script
-   */
-  @POST
-  @Consumes(MediaType.APPLICATION_JSON)
-  public Response createFile(FileResourceRequest request,
-                             @Context HttpServletResponse response, @Context UriInfo ui)
-      throws IOException, InterruptedException {
-    try {
-      LOG.debug("Creating file " + request.file.getFilePath());
-      try {
-        FSDataOutputStream output = getSharedObjectsFactory().getHdfsApi().create(request.file.getFilePath(), false);
-        if (request.file.getFileContent() != null) {
-          output.writeBytes(request.file.getFileContent());
-        }
-        output.close();
-      } catch (FileAlreadyExistsException ex) {
-        throw new ServiceFormattedException("F020 File already exists", ex, 400);
-      }
-      response.setHeader("Location",
-          String.format("%s/%s", ui.getAbsolutePath().toString(), request.file.getFilePath()));
-      return Response.status(204).build();
-    } catch (WebApplicationException ex) {
-      throw ex;
-    } catch (Exception ex) {
-      throw new ServiceFormattedException(ex.getMessage(), ex);
-    }
-  }
-
-  /**
-   * Checks connection to HDFS
-   * @param context View Context
-   */
-  public static void hdfsSmokeTest(ViewContext context) {
-    try {
-      HdfsApi api = HdfsUtil.connectToHDFSApi(context);
-      api.getStatus();
-    } catch (WebApplicationException ex) {
-      throw ex;
-    } catch (Exception ex) {
-      throw new ServiceFormattedException(ex.getMessage(), ex);
-    }
-  }
-
-  /**
-   * Checks connection to User HomeDirectory
-   * @param context View Context
-   */
-  public static void userhomeSmokeTest(ViewContext context) {
-    try {
-      UserService  userservice = new UserService(context);
-      userservice.homeDir();
-    } catch (WebApplicationException ex) {
-      throw ex;
-    } catch (Exception ex) {
-      throw new ServiceFormattedException(ex.getMessage(), ex);
-    }
-  }
-
-  /**
-   * Wrapper object for json mapping
-   */
-  public static class FileResourceRequest {
-    public FileResource file;
-  }
-
-  private String sanitizeFilePath(String filePath){
-    if (!filePath.startsWith("/") && !filePath.startsWith(".")) {
-      filePath = "/" + filePath;  // some servers strip double slashes in URL
-    }
-    return filePath;
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/Aggregator.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/Aggregator.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/Aggregator.java
deleted file mode 100644
index 2f0138a..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/Aggregator.java
+++ /dev/null
@@ -1,417 +0,0 @@
-/**
- * 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.ambari.view.hive.resources.jobs;
-
-import org.apache.ambari.view.hive.persistence.utils.FilteringStrategy;
-import org.apache.ambari.view.hive.persistence.utils.Indexed;
-import org.apache.ambari.view.hive.persistence.utils.ItemNotFound;
-import org.apache.ambari.view.hive.persistence.utils.OnlyOwnersFilteringStrategy;
-import org.apache.ambari.view.hive.resources.IResourceManager;
-import org.apache.ambari.view.hive.resources.files.FileService;
-import org.apache.ambari.view.hive.resources.jobs.atsJobs.HiveQueryId;
-import org.apache.ambari.view.hive.resources.jobs.atsJobs.IATSParser;
-import org.apache.ambari.view.hive.resources.jobs.atsJobs.TezDagId;
-import org.apache.ambari.view.hive.resources.jobs.viewJobs.Job;
-import org.apache.ambari.view.hive.resources.jobs.viewJobs.JobImpl;
-import org.apache.ambari.view.hive.resources.jobs.viewJobs.JobInfo;
-import org.apache.commons.beanutils.PropertyUtils;
-import org.apache.commons.codec.binary.Base64;
-import org.apache.commons.codec.binary.Hex;
-import org.apache.hive.service.cli.thrift.TOperationHandle;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-import java.lang.reflect.InvocationTargetException;
-import java.util.HashMap;
-import java.util.LinkedList;
-import java.util.List;
-
-/**
- * View Jobs and ATS Jobs aggregator.
- * There are 4 options:
- * 1) ATS Job without operationId
- *    *Meaning*: executed outside of HS2
- *    - Job info only from ATS
- * 2) ATS Job with operationId
- *    a) Hive View Job with same operationId is not present
- *        *Meaning*: executed with HS2
- *      - Job info only from ATS
- *    b) Hive View Job with operationId is present (need to merge)
- *        *Meaning*: executed with HS2 through Hive View
- *      - Job info merged from ATS and from Hive View DataStorage
- * 3) Job present only in Hive View, ATS does not have it
- *   *Meaning*: executed through Hive View, but Hadoop Job was not created
- *   it can happen if user executes query without aggregation, like just "select * from TABLE"
- *   - Job info only from Hive View
- */
-public class Aggregator {
-  protected final static Logger LOG =
-    LoggerFactory.getLogger(Aggregator.class);
-
-  private final IATSParser ats;
-  private final IOperationHandleResourceManager operationHandleResourceManager;
-  private IResourceManager<Job> viewJobResourceManager;
-
-  public Aggregator(IResourceManager<Job> jobResourceManager,
-                    IOperationHandleResourceManager operationHandleResourceManager,
-                    IATSParser ats) {
-    this.viewJobResourceManager = jobResourceManager;
-    this.operationHandleResourceManager = operationHandleResourceManager;
-    this.ats = ats;
-  }
-
-  /**
-   * gets all the jobs for 'username' where the job submission time is between 'startTime' (inclusive)
-   * and endTime (exclusive).
-   * Fetches the jobs from ATS and DB merges and update DB. returns the combined list.
-   *
-   * @param username:  username for which jobs have to be fetched.
-   * @param startTime: inclusive, time in secs from epoch
-   * @param endTime:   exclusive, time in secs from epoch
-   * @return: list of jobs
-   */
-  public List<Job> readAllForUserByTime(String username, long startTime, long endTime) {
-    List<HiveQueryId> queryIdList = ats.getHiveQueryIdsForUserByTime(username, startTime, endTime);
-    List<Job> allJobs = fetchDagsAndMergeJobs(queryIdList);
-    List<Job> dbOnlyJobs = readDBOnlyJobs(username, queryIdList, startTime, endTime);
-    allJobs.addAll(dbOnlyJobs);
-
-    return allJobs;
-  }
-
-  /**
-   * fetches the new state of jobs from ATS and from DB. Does merging/updating as required.
-   * @param jobInfos: infos of job to get
-   * @return: list of updated Job
-   */
-  public List<Job> readJobsByIds(List<JobInfo> jobInfos) {
-    //categorize jobs
-    List<String> jobsWithHiveIds = new LinkedList<>();
-    List<String> dbOnlyJobs = new LinkedList<>();
-
-    for (JobInfo jobInfo : jobInfos) {
-      if (null == jobInfo.getHiveId() || jobInfo.getHiveId().trim().isEmpty()) {
-        dbOnlyJobs.add(jobInfo.getJobId());
-      } else {
-        jobsWithHiveIds.add(jobInfo.getHiveId());
-      }
-    }
-
-    List<HiveQueryId> queryIdList = ats.getHiveQueryIdByEntityList(jobsWithHiveIds);
-    List<Job> allJobs = fetchDagsAndMergeJobs(queryIdList);
-    List<Job> dbJobs = readJobsFromDbByJobId(dbOnlyJobs);
-
-    allJobs.addAll(dbJobs);
-    return allJobs;
-  }
-
-  /**
-   * gets the jobs from the Database given their id
-   * @param jobsIds: list of ids of jobs
-   * @return: list of all the jobs found
-   */
-  private List<Job> readJobsFromDbByJobId(List<String> jobsIds) {
-    List<Job> jobs = new LinkedList<>();
-    for (final String jid : jobsIds) {
-      try {
-        Job job = getJobFromDbByJobId(jid);
-        jobs.add(job);
-      } catch (ItemNotFound itemNotFound) {
-        LOG.error("Error while finding job with id : {}", jid, itemNotFound);
-      }
-    }
-
-    return jobs;
-  }
-
-  /**
-   * fetches the job from DB given its id
-   * @param jobId: the id of the job to fetch
-   * @return: the job
-   * @throws ItemNotFound: if job with given id is not found in db
-   */
-  private Job getJobFromDbByJobId(final String jobId) throws ItemNotFound {
-    if (null == jobId)
-      return null;
-
-    List<Job> jobs = viewJobResourceManager.readAll(new FilteringStrategy() {
-      @Override
-      public boolean isConform(Indexed item) {
-        return item.getId().equals(jobId);
-      }
-
-      @Override
-      public String whereStatement() {
-        return "id = '" + jobId + "'"; // even IDs are string
-      }
-    });
-
-    if (null != jobs && !jobs.isEmpty())
-      return jobs.get(0);
-
-    throw new ItemNotFound(String.format("Job with id %s not found.", jobId));
-  }
-
-  /**
-   * returns the job which is associated with the given (guid)
-   * @param optId: the operationId for which the job needs to be fetched.
-   * @return: the job
-   * @throws ItemNotFound: if no job was found to be associated with given operationId (guid) or if no
-   * StoredOperationHandle found with guid optId.
-   */
-  private Job getJobFromDbByOperationId(final String optId) throws ItemNotFound {
-    StoredOperationHandle handle = getStoredOperationHandleByGuid(optId);
-    Job job = operationHandleResourceManager.getJobByHandle(handle);
-    return job;
-  }
-
-  /**
-   * returns the StoredOperationHandle with given id
-   * @param optId: id of the StoredOperationHandle
-   * @return: StoredOperationHandle
-   * @throws ItemNotFound: if no StoredOperationHandle found for given guid (operationId).
-   */
-  private StoredOperationHandle getStoredOperationHandleByGuid(final String optId) throws ItemNotFound {
-    LOG.debug("stored procedure with operation id : {} in DB", optId);
-    List<StoredOperationHandle> operationHandles = operationHandleResourceManager.readAll(new FilteringStrategy() {
-      @Override
-      public boolean isConform(Indexed item) {
-        StoredOperationHandle soh = (StoredOperationHandle) item;
-        return soh.getGuid().equals(optId);
-      }
-
-      @Override
-      public String whereStatement() {
-        return " guid = '" + optId + "'";
-      }
-    });
-
-    if (null != operationHandles && !operationHandles.isEmpty()) {
-      return operationHandles.get(0);
-    }
-
-    throw new ItemNotFound(String.format("Stored operation handle with id %s not found", optId));
-  }
-
-  /**
-   * returns all the jobs from ATS and DB (for this instance) for the given user.
-   * @param username
-   * @return
-   */
-  public List<Job> readAll(String username) {
-    List<HiveQueryId> queries = ats.getHiveQueryIdsForUser(username);
-    LOG.debug("HiveQueryIds fetched : {}", queries);
-    List<Job> allJobs = fetchDagsAndMergeJobs(queries);
-    List<Job> dbOnlyJobs = readDBOnlyJobs(username, queries, null, null);
-    LOG.debug("Jobs only present in DB: {}", dbOnlyJobs);
-    allJobs.addAll(dbOnlyJobs);
-    return allJobs;
-  }
-
-  /**
-   * reads all the jobs from DB for username and excludes the jobs mentioned in queries list
-   * @param username : username for which the jobs are to be read.
-   * @param queries : the jobs to exclude
-   * @param startTime: can be null, if not then the window start time for job
-   * @param endTime: can be null, if not then the window end time for job
-   * @return : the jobs in db that are not in the queries
-   */
-  private List<Job> readDBOnlyJobs(String username, List<HiveQueryId> queries, Long startTime, Long endTime) {
-    List<Job> dbOnlyJobs = new LinkedList<Job>();
-    HashMap<String, String> operationIdVsHiveId = new HashMap<>();
-
-    for (HiveQueryId hqid : queries) {
-      operationIdVsHiveId.put(hqid.operationId, hqid.entity);
-    }
-    LOG.debug("operationIdVsHiveId : {} ", operationIdVsHiveId);
-    //cover case when operationId is present, but not exists in ATS
-    //e.g. optimized queries without executing jobs, like "SELECT * FROM TABLE"
-    List<Job> jobs = viewJobResourceManager.readAll(new OnlyOwnersFilteringStrategy(username));
-    for (Job job : jobs) {
-      if (null != startTime && null != endTime && null != job.getDateSubmitted()
-        && (job.getDateSubmitted() < startTime || job.getDateSubmitted() >= endTime)
-        ) {
-        continue; // don't include this in the result
-      }
-
-      List<StoredOperationHandle> operationHandles = operationHandleResourceManager.readJobRelatedHandles(job);
-
-      if (operationHandles.size() > 0) {
-        StoredOperationHandle operationHandle = operationHandles.get(0);
-
-        if (!operationIdVsHiveId.containsKey(hexStringToUrlSafeBase64(operationHandle.getGuid()))) {
-          //e.g. query without hadoop job: select * from table
-          dbOnlyJobs.add(job);
-        }
-      }
-    }
-
-    return dbOnlyJobs;
-  }
-
-  private List<Job> fetchDagsAndMergeJobs(List<HiveQueryId> queries) {
-    List<Job> allJobs = new LinkedList<Job>();
-
-    for (HiveQueryId atsHiveQuery : queries) {
-      JobImpl atsJob = null;
-      if (hasOperationId(atsHiveQuery)) {
-        try {
-          Job viewJob = getJobFromDbByOperationId(urlSafeBase64ToHexString(atsHiveQuery.operationId));
-          TezDagId atsTezDag = getTezDagFromHiveQueryId(atsHiveQuery);
-          atsJob = mergeHiveAtsTez(atsHiveQuery, atsTezDag, viewJob);
-        } catch (ItemNotFound itemNotFound) {
-          LOG.error("Ignore : {}", itemNotFound.getMessage());
-          continue;
-        }
-      } else {
-        TezDagId atsTezDag = getTezDagFromHiveQueryId(atsHiveQuery);
-        atsJob = atsOnlyJob(atsHiveQuery, atsTezDag);
-      }
-
-      atsJob.setHiveQueryId(atsHiveQuery.entity);
-      allJobs.add(atsJob);
-    }
-
-    return allJobs;
-  }
-
-  /**
-   * @param atsHiveQuery
-   * @param atsTezDag
-   * @param viewJob
-   * @return
-   */
-  private JobImpl mergeHiveAtsTez(HiveQueryId atsHiveQuery, TezDagId atsTezDag, Job viewJob) throws ItemNotFound {
-    saveJobInfoIfNeeded(atsHiveQuery, atsTezDag, viewJob);
-    return mergeAtsJobWithViewJob(atsHiveQuery, atsTezDag, viewJob);
-  }
-
-  public Job readATSJob(Job viewJob) throws ItemNotFound {
-    TOperationHandle operationHandle = operationHandleResourceManager.getHandleForJob(viewJob).toTOperationHandle();
-
-    String hexGuid = Hex.encodeHexString(operationHandle.getOperationId().getGuid());
-    HiveQueryId atsHiveQuery = ats.getHiveQueryIdByOperationId(hexStringToUrlSafeBase64(hexGuid));
-
-    TezDagId atsTezDag = getTezDagFromHiveQueryId(atsHiveQuery);
-
-    saveJobInfoIfNeeded(atsHiveQuery, atsTezDag, viewJob);
-    return mergeAtsJobWithViewJob(atsHiveQuery, atsTezDag, viewJob);
-  }
-
-  private TezDagId getTezDagFromHiveQueryId(HiveQueryId atsHiveQuery) {
-    TezDagId atsTezDag;
-    if (atsHiveQuery.version >= HiveQueryId.ATS_15_RESPONSE_VERSION) {
-      atsTezDag = ats.getTezDAGByEntity(atsHiveQuery.entity);
-    } else if (atsHiveQuery.dagNames != null && atsHiveQuery.dagNames.size() > 0) {
-      String dagName = atsHiveQuery.dagNames.get(0);
-
-      atsTezDag = ats.getTezDAGByName(dagName);
-    } else {
-      atsTezDag = new TezDagId();
-    }
-    return atsTezDag;
-  }
-
-  protected boolean hasOperationId(HiveQueryId atsHiveQuery) {
-    return atsHiveQuery.operationId != null;
-  }
-
-  protected JobImpl mergeAtsJobWithViewJob(HiveQueryId atsHiveQuery, TezDagId atsTezDag, Job viewJob) {
-    JobImpl atsJob;
-    try {
-      atsJob = new JobImpl(PropertyUtils.describe(viewJob));
-    } catch (IllegalAccessException e) {
-      LOG.error("Can't instantiate JobImpl", e);
-      return null;
-    } catch (InvocationTargetException e) {
-      LOG.error("Can't instantiate JobImpl", e);
-      return null;
-    } catch (NoSuchMethodException e) {
-      LOG.error("Can't instantiate JobImpl", e);
-      return null;
-    }
-    fillAtsJobFields(atsJob, atsHiveQuery, atsTezDag);
-    return atsJob;
-  }
-
-  protected void saveJobInfoIfNeeded(HiveQueryId hiveQueryId, TezDagId tezDagId, Job viewJob) throws ItemNotFound {
-    boolean shouldUpdate = false;
-    if (viewJob.getDagName() == null || viewJob.getDagName().isEmpty()) {
-      if (hiveQueryId.dagNames != null && hiveQueryId.dagNames.size() > 0) {
-        viewJob.setDagName(hiveQueryId.dagNames.get(0));
-        shouldUpdate = true;
-      }
-    }
-    if (tezDagId.status != null && (tezDagId.status.compareToIgnoreCase(Job.JOB_STATE_UNKNOWN) != 0) &&
-      !viewJob.getStatus().equals(tezDagId.status)) {
-      viewJob.setDagId(tezDagId.entity);
-      viewJob.setStatus(tezDagId.status);
-      shouldUpdate = true;
-    }
-
-    if (shouldUpdate) {
-      viewJobResourceManager.update(viewJob, viewJob.getId());
-    }
-  }
-
-  protected JobImpl atsOnlyJob(HiveQueryId atsHiveQuery, TezDagId atsTezDag) {
-    JobImpl atsJob = new JobImpl();
-    atsJob.setId(atsHiveQuery.entity);
-    fillAtsJobFields(atsJob, atsHiveQuery, atsTezDag);
-
-    String query = atsHiveQuery.query;
-    atsJob.setTitle(query.substring(0, (query.length() > 42) ? 42 : query.length()));
-
-    atsJob.setQueryFile(FileService.JSON_PATH_FILE + atsHiveQuery.url + "#otherinfo.QUERY!queryText");
-    return atsJob;
-  }
-
-  protected JobImpl fillAtsJobFields(JobImpl atsJob, HiveQueryId atsHiveQuery, TezDagId atsTezDag) {
-    atsJob.setApplicationId(atsTezDag.applicationId);
-
-    if (atsHiveQuery.dagNames != null && atsHiveQuery.dagNames.size() > 0)
-      atsJob.setDagName(atsHiveQuery.dagNames.get(0));
-    atsJob.setDagId(atsTezDag.entity);
-    if (atsTezDag.status != null && !atsTezDag.status.equals(TezDagId.STATUS_UNKNOWN))
-      atsJob.setStatus(atsTezDag.status);
-    if (atsHiveQuery.starttime != 0)
-      atsJob.setDateSubmitted(atsHiveQuery.starttime);
-    atsJob.setDuration(atsHiveQuery.duration);
-    return atsJob;
-  }
-
-  protected static String urlSafeBase64ToHexString(String urlsafeBase64) {
-    byte[] decoded = Base64.decodeBase64(urlsafeBase64);
-
-    StringBuilder sb = new StringBuilder();
-    for (byte b : decoded) {
-      sb.append(String.format("%02x", b));
-    }
-    return sb.toString();
-  }
-
-  protected static String hexStringToUrlSafeBase64(String hexString) {
-    byte[] decoded = new byte[hexString.length() / 2];
-
-    for (int i = 0; i < hexString.length(); i += 2) {
-      decoded[i / 2] = (byte) Integer.parseInt(String.format("%c%c", hexString.charAt(i), hexString.charAt(i + 1)), 16);
-    }
-    return Base64.encodeBase64URLSafeString(decoded);
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/ConnectionController.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/ConnectionController.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/ConnectionController.java
deleted file mode 100644
index 92cf67d..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/ConnectionController.java
+++ /dev/null
@@ -1,74 +0,0 @@
-/**
- * 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.ambari.view.hive.resources.jobs;
-
-import org.apache.ambari.view.hive.client.Connection;
-import org.apache.ambari.view.hive.client.HiveClientException;
-import org.apache.ambari.view.hive.utils.HiveClientFormattedException;
-import org.apache.ambari.view.hive.utils.ServiceFormattedException;
-import org.apache.commons.codec.binary.Hex;
-import org.apache.hive.service.cli.thrift.TOperationHandle;
-import org.apache.hive.service.cli.thrift.TSessionHandle;
-
-
-public class ConnectionController {
-  private OperationHandleControllerFactory operationHandleControllerFactory;
-  private Connection connection;
-
-  public ConnectionController(OperationHandleControllerFactory operationHandleControllerFactory, Connection connection) {
-    this.connection = connection;
-    this.operationHandleControllerFactory = operationHandleControllerFactory;
-  }
-
-  public TSessionHandle getSessionByTag(String tag) throws HiveClientException {
-    return connection.getSessionByTag(tag);
-  }
-
-  public String openSession() {
-    try {
-      TSessionHandle sessionHandle = connection.openSession();
-      return getTagBySession(sessionHandle);
-    } catch (HiveClientException e) {
-      throw new HiveClientFormattedException(e);
-    }
-  }
-
-  public static String getTagBySession(TSessionHandle sessionHandle) {
-    return Hex.encodeHexString(sessionHandle.getSessionId().getGuid());
-  }
-
-  public void selectDatabase(TSessionHandle session, String database) {
-    try {
-      connection.executeSync(session, "use " + database + ";");
-    } catch (HiveClientException e) {
-      throw new HiveClientFormattedException(e);
-    }
-  }
-
-  public OperationHandleController executeQuery(TSessionHandle session, String cmd) {
-    TOperationHandle operationHandle = null;
-    try {
-      operationHandle = connection.executeAsync(session, cmd);
-    } catch (HiveClientException e) {
-      throw new HiveClientFormattedException(e);
-    }
-    StoredOperationHandle storedOperationHandle = StoredOperationHandle.buildFromTOperationHandle(operationHandle);
-    return operationHandleControllerFactory.createControllerForHandle(storedOperationHandle);
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/FileResourceShort.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/FileResourceShort.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/FileResourceShort.java
deleted file mode 100644
index 776bf64..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/FileResourceShort.java
+++ /dev/null
@@ -1,55 +0,0 @@
-/**
- * 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.ambari.view.hive.resources.jobs;
-
-import org.apache.commons.beanutils.BeanUtils;
-
-import java.lang.reflect.InvocationTargetException;
-import java.util.Map;
-
-public class FileResourceShort {
-  public FileResourceShort() {}
-  public FileResourceShort(Map<String, Object> stringObjectMap) throws InvocationTargetException, IllegalAccessException {
-    BeanUtils.populate(this, stringObjectMap);
-  }
-
-  private Integer id;
-  private String path;
-
-  public FileResourceShort(Integer id, String path) {
-    this.id = id;
-    this.path = path;
-  }
-
-  public Integer getId() {
-    return id;
-  }
-
-  public void setId(Integer id) {
-    this.id = id;
-  }
-
-  public String getPath() {
-    return path;
-  }
-
-  public void setPath(String path) {
-    this.path = path;
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/IOperationHandleResourceManager.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/IOperationHandleResourceManager.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/IOperationHandleResourceManager.java
deleted file mode 100644
index 961d6c2..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/IOperationHandleResourceManager.java
+++ /dev/null
@@ -1,40 +0,0 @@
-/**
- * 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.ambari.view.hive.resources.jobs;
-
-import org.apache.ambari.view.hive.persistence.utils.ItemNotFound;
-import org.apache.ambari.view.hive.resources.IResourceManager;
-import org.apache.ambari.view.hive.resources.jobs.viewJobs.Job;
-import org.apache.hive.service.cli.thrift.TOperationHandle;
-
-import java.util.List;
-
-public interface IOperationHandleResourceManager extends IResourceManager<StoredOperationHandle> {
-  List<StoredOperationHandle> readJobRelatedHandles(Job job);
-
-  List<Job> getHandleRelatedJobs(StoredOperationHandle operationHandle);
-
-  Job getJobByHandle(StoredOperationHandle handle) throws ItemNotFound;
-
-  void putHandleForJob(TOperationHandle h, Job job);
-
-  boolean containsHandleForJob(Job job);
-
-  StoredOperationHandle getHandleForJob(Job job) throws ItemNotFound;
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/JobResourceProvider.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/JobResourceProvider.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/JobResourceProvider.java
deleted file mode 100644
index 2aa491e..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/JobResourceProvider.java
+++ /dev/null
@@ -1,113 +0,0 @@
-/**
- * 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.ambari.view.hive.resources.jobs;
-
-import org.apache.ambari.view.*;
-import org.apache.ambari.view.hive.persistence.utils.ItemNotFound;
-import org.apache.ambari.view.hive.persistence.utils.OnlyOwnersFilteringStrategy;
-import org.apache.ambari.view.hive.resources.jobs.viewJobs.*;
-import org.apache.ambari.view.hive.utils.SharedObjectsFactory;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-import javax.inject.Inject;
-import java.lang.reflect.InvocationTargetException;
-import java.util.HashSet;
-import java.util.Map;
-import java.util.Set;
-
-/**
- * Resource provider for job
- */
-public class JobResourceProvider implements ResourceProvider<Job> {
-  @Inject
-  ViewContext context;
-
-  protected JobResourceManager resourceManager = null;
-  protected final static Logger LOG =
-      LoggerFactory.getLogger(JobResourceProvider.class);
-
-  protected synchronized JobResourceManager getResourceManager() {
-    if (resourceManager == null) {
-      resourceManager = new JobResourceManager(new SharedObjectsFactory(context), context);
-    }
-    return resourceManager;
-  }
-
-  @Override
-  public Job getResource(String resourceId, Set<String> properties) throws SystemException, NoSuchResourceException, UnsupportedPropertyException {
-    try {
-      return getResourceManager().read(resourceId);
-    } catch (ItemNotFound itemNotFound) {
-      throw new NoSuchResourceException(resourceId);
-    }
-  }
-
-  @Override
-  public Set<Job> getResources(ReadRequest readRequest) throws SystemException, NoSuchResourceException, UnsupportedPropertyException {
-    if (context == null) {
-      return new HashSet<Job>();
-    }
-    return new HashSet<Job>(getResourceManager().readAll(
-        new OnlyOwnersFilteringStrategy(this.context.getUsername())));
-  }
-
-  @Override
-  public void createResource(String s, Map<String, Object> stringObjectMap) throws SystemException, ResourceAlreadyExistsException, NoSuchResourceException, UnsupportedPropertyException {
-    Job item = null;
-    try {
-      item = new JobImpl(stringObjectMap);
-    } catch (InvocationTargetException e) {
-      throw new SystemException("error on creating resource", e);
-    } catch (IllegalAccessException e) {
-      throw new SystemException("error on creating resource", e);
-    }
-    getResourceManager().create(item);
-    JobController jobController = new SharedObjectsFactory(context).getJobControllerFactory().createControllerForJob(item);
-    jobController.submit();
-  }
-
-  @Override
-  public boolean updateResource(String resourceId, Map<String, Object> stringObjectMap) throws SystemException, NoSuchResourceException, UnsupportedPropertyException {
-    Job item = null;
-    try {
-      item = new JobImpl(stringObjectMap);
-    } catch (InvocationTargetException e) {
-      throw new SystemException("error on updating resource", e);
-    } catch (IllegalAccessException e) {
-      throw new SystemException("error on updating resource", e);
-    }
-    try {
-      getResourceManager().update(item, resourceId);
-    } catch (ItemNotFound itemNotFound) {
-      throw new NoSuchResourceException(resourceId);
-    }
-    return true;
-  }
-
-  @Override
-  public boolean deleteResource(String resourceId) throws SystemException, NoSuchResourceException, UnsupportedPropertyException {
-    try {
-      getResourceManager().delete(resourceId);
-    } catch (ItemNotFound itemNotFound) {
-      throw new NoSuchResourceException(resourceId);
-    }
-    return true;
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/JobService.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/JobService.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/JobService.java
deleted file mode 100644
index 36c2633..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/JobService.java
+++ /dev/null
@@ -1,609 +0,0 @@
-/**
- * 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.ambari.view.hive.resources.jobs;
-
-import org.apache.ambari.view.ViewResourceHandler;
-import org.apache.ambari.view.hive.BaseService;
-import org.apache.ambari.view.hive.backgroundjobs.BackgroundJobController;
-import org.apache.ambari.view.hive.client.Connection;
-import org.apache.ambari.view.hive.client.Cursor;
-import org.apache.ambari.view.hive.client.HiveAuthCredentials;
-import org.apache.ambari.view.hive.client.HiveClientException;
-import org.apache.ambari.view.hive.client.UserLocalConnection;
-import org.apache.ambari.view.hive.client.UserLocalHiveAuthCredentials;
-import org.apache.ambari.view.hive.persistence.utils.ItemNotFound;
-import org.apache.ambari.view.hive.resources.jobs.atsJobs.IATSParser;
-import org.apache.ambari.view.hive.resources.jobs.viewJobs.Job;
-import org.apache.ambari.view.hive.resources.jobs.viewJobs.JobController;
-import org.apache.ambari.view.hive.resources.jobs.viewJobs.JobImpl;
-import org.apache.ambari.view.hive.resources.jobs.viewJobs.JobInfo;
-import org.apache.ambari.view.hive.resources.jobs.viewJobs.JobResourceManager;
-import org.apache.ambari.view.hive.utils.MisconfigurationFormattedException;
-import org.apache.ambari.view.hive.utils.NotFoundFormattedException;
-import org.apache.ambari.view.hive.utils.ServiceFormattedException;
-import org.apache.ambari.view.hive.utils.SharedObjectsFactory;
-import org.apache.commons.beanutils.PropertyUtils;
-import org.apache.commons.csv.CSVFormat;
-import org.apache.commons.csv.CSVPrinter;
-import org.apache.hadoop.fs.FSDataOutputStream;
-import org.json.simple.JSONObject;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-import javax.inject.Inject;
-import javax.servlet.http.HttpServletResponse;
-import javax.ws.rs.Consumes;
-import javax.ws.rs.DELETE;
-import javax.ws.rs.GET;
-import javax.ws.rs.POST;
-import javax.ws.rs.Path;
-import javax.ws.rs.PathParam;
-import javax.ws.rs.Produces;
-import javax.ws.rs.QueryParam;
-import javax.ws.rs.WebApplicationException;
-import javax.ws.rs.core.Context;
-import javax.ws.rs.core.MediaType;
-import javax.ws.rs.core.Response;
-import javax.ws.rs.core.StreamingOutput;
-import javax.ws.rs.core.UriInfo;
-import java.io.BufferedWriter;
-import java.io.IOException;
-import java.io.OutputStream;
-import java.io.OutputStreamWriter;
-import java.io.Writer;
-import java.lang.reflect.InvocationTargetException;
-import java.util.List;
-import java.util.Map;
-import java.util.concurrent.Callable;
-
-/**
- * Servlet for queries
- * API:
- * GET /:id
- *      read job
- * POST /
- *      create new job
- *      Required: title, queryFile
- * GET /
- *      get all Jobs of current user
- */
-public class JobService extends BaseService {
-  @Inject
-  ViewResourceHandler handler;
-
-  private JobResourceManager resourceManager;
-  private IOperationHandleResourceManager opHandleResourceManager;
-  private UserLocalConnection connectionLocal = new UserLocalConnection();
-
-  protected final static Logger LOG =
-      LoggerFactory.getLogger(JobService.class);
-  private Aggregator aggregator;
-
-  protected synchronized JobResourceManager getResourceManager() {
-    if (resourceManager == null) {
-      SharedObjectsFactory connectionsFactory = getSharedObjectsFactory();
-      resourceManager = new JobResourceManager(connectionsFactory, context);
-    }
-    return resourceManager;
-  }
-
-  protected IOperationHandleResourceManager getOperationHandleResourceManager() {
-    if (opHandleResourceManager == null) {
-      opHandleResourceManager = new OperationHandleResourceManager(getSharedObjectsFactory());
-    }
-    return opHandleResourceManager;
-  }
-
-  protected Aggregator getAggregator() {
-    if (aggregator == null) {
-      IATSParser atsParser = getSharedObjectsFactory().getATSParser();
-      aggregator = new Aggregator(getResourceManager(), getOperationHandleResourceManager(), atsParser);
-    }
-    return aggregator;
-  }
-
-  protected void setAggregator(Aggregator aggregator) {
-    this.aggregator = aggregator;
-  }
-
-  /**
-   * Get single item
-   */
-  @GET
-  @Path("{jobId}")
-  @Produces(MediaType.APPLICATION_JSON)
-  public Response getOne(@PathParam("jobId") String jobId) {
-    try {
-      JobController jobController = getResourceManager().readController(jobId);
-
-      JSONObject jsonJob = jsonObjectFromJob(jobController);
-
-      return Response.ok(jsonJob).build();
-    } catch (WebApplicationException ex) {
-      throw ex;
-    } catch (ItemNotFound itemNotFound) {
-      throw new NotFoundFormattedException(itemNotFound.getMessage(), itemNotFound);
-    } catch (Exception ex) {
-      throw new ServiceFormattedException(ex.getMessage(), ex);
-    }
-  }
-
-  private JSONObject jsonObjectFromJob(JobController jobController) throws IllegalAccessException, NoSuchMethodException, InvocationTargetException {
-    Job hiveJob = jobController.getJobPOJO();
-
-    Job mergedJob;
-    try {
-      mergedJob = getAggregator().readATSJob(hiveJob);
-    } catch (ItemNotFound itemNotFound) {
-      throw new ServiceFormattedException("E010 Job not found", itemNotFound);
-    }
-    Map createdJobMap = PropertyUtils.describe(mergedJob);
-    createdJobMap.remove("class"); // no need to show Bean class on client
-
-    JSONObject jobJson = new JSONObject();
-    jobJson.put("job", createdJobMap);
-    return jobJson;
-  }
-
-  /**
-   * Get job results in csv format
-   */
-  @GET
-  @Path("{jobId}/results/csv")
-  @Produces("text/csv")
-  public Response getResultsCSV(@PathParam("jobId") String jobId,
-                                @Context HttpServletResponse response,
-                                @QueryParam("fileName") String fileName,
-                                @QueryParam("columns") final String requestedColumns) {
-    try {
-      JobController jobController = getResourceManager().readController(jobId);
-      final Cursor resultSet = jobController.getResults();
-      resultSet.selectColumns(requestedColumns);
-
-      StreamingOutput stream = new StreamingOutput() {
-        @Override
-        public void write(OutputStream os) throws IOException, WebApplicationException {
-          Writer writer = new BufferedWriter(new OutputStreamWriter(os));
-          CSVPrinter csvPrinter = new CSVPrinter(writer, CSVFormat.DEFAULT);
-          try {
-
-            try {
-              csvPrinter.printRecord(resultSet.getHeadersRow().getRow());
-            } catch (HiveClientException e) {
-              LOG.error("Error on reading results header", e);
-            }
-
-            while (resultSet.hasNext()) {
-              csvPrinter.printRecord(resultSet.next().getRow());
-              writer.flush();
-            }
-          } finally {
-            writer.close();
-          }
-        }
-      };
-
-      if (fileName == null || fileName.isEmpty()) {
-        fileName = "results.csv";
-      }
-
-      return Response.ok(stream).
-          header("Content-Disposition", String.format("attachment; filename=\"%s\"", fileName)).
-          build();
-    } catch (WebApplicationException ex) {
-      throw ex;
-    } catch (ItemNotFound itemNotFound) {
-      throw new NotFoundFormattedException(itemNotFound.getMessage(), itemNotFound);
-    } catch (Exception ex) {
-      throw new ServiceFormattedException(ex.getMessage(), ex);
-    }
-  }
-
-  /**
-   * Get job results in csv format
-   */
-  @GET
-  @Path("{jobId}/results/csv/saveToHDFS")
-  @Produces(MediaType.APPLICATION_JSON)
-  public Response getResultsToHDFS(@PathParam("jobId") String jobId,
-                                   @QueryParam("commence") String commence,
-                                   @QueryParam("file") final String targetFile,
-                                   @QueryParam("stop") final String stop,
-                                   @QueryParam("columns") final String requestedColumns,
-                                   @Context HttpServletResponse response) {
-    try {
-      final JobController jobController = getResourceManager().readController(jobId);
-
-      String backgroundJobId = "csv" + String.valueOf(jobController.getJob().getId());
-      if (commence != null && commence.equals("true")) {
-        if (targetFile == null)
-          throw new MisconfigurationFormattedException("targetFile should not be empty");
-        BackgroundJobController.getInstance(context).startJob(String.valueOf(backgroundJobId), new Runnable() {
-          @Override
-          public void run() {
-
-            try {
-              Cursor resultSet = jobController.getResults();
-              resultSet.selectColumns(requestedColumns);
-
-              FSDataOutputStream stream = getSharedObjectsFactory().getHdfsApi().create(targetFile, true);
-              Writer writer = new BufferedWriter(new OutputStreamWriter(stream));
-              CSVPrinter csvPrinter = new CSVPrinter(writer, CSVFormat.DEFAULT);
-              try {
-                while (resultSet.hasNext() && !Thread.currentThread().isInterrupted()) {
-                  csvPrinter.printRecord(resultSet.next().getRow());
-                  writer.flush();
-                }
-              } finally {
-                writer.close();
-              }
-              stream.close();
-
-            } catch (IOException e) {
-              throw new ServiceFormattedException("F010 Could not write CSV to HDFS for job#" + jobController.getJob().getId(), e);
-            } catch (InterruptedException e) {
-              throw new ServiceFormattedException("F010 Could not write CSV to HDFS for job#" + jobController.getJob().getId(), e);
-            } catch (ItemNotFound itemNotFound) {
-              throw new NotFoundFormattedException("E020 Job results are expired", itemNotFound);
-            }
-
-          }
-        });
-      }
-
-      if (stop != null && stop.equals("true")) {
-        BackgroundJobController.getInstance(context).interrupt(backgroundJobId);
-      }
-
-      JSONObject object = new JSONObject();
-      object.put("stopped", BackgroundJobController.getInstance(context).isInterrupted(backgroundJobId));
-      object.put("jobId", jobController.getJob().getId());
-      object.put("backgroundJobId", backgroundJobId);
-      object.put("operationType", "CSV2HDFS");
-      object.put("status", BackgroundJobController.getInstance(context).state(backgroundJobId).toString());
-
-      return Response.ok(object).build();
-    } catch (WebApplicationException ex) {
-      throw ex;
-    } catch (ItemNotFound itemNotFound) {
-      throw new NotFoundFormattedException(itemNotFound.getMessage(), itemNotFound);
-    } catch (Exception ex) {
-      throw new ServiceFormattedException(ex.getMessage(), ex);
-    }
-  }
-
-
-  @Path("{jobId}/status")
-  @GET
-  @Consumes(MediaType.APPLICATION_JSON)
-  @Produces(MediaType.APPLICATION_JSON)
-  public Response fetchJobStatus(@PathParam("jobId") String jobId) throws ItemNotFound, HiveClientException, NoOperationStatusSetException {
-    JobController jobController = getResourceManager().readController(jobId);
-    String jobStatus = jobController.getStatus().status;
-    LOG.info("jobStatus : {} for jobId : {}",jobStatus, jobId);
-
-    JSONObject jsonObject = new JSONObject();
-    jsonObject.put("jobStatus", jobStatus);
-    jsonObject.put("jobId", jobId);
-
-    return Response.ok(jsonObject).build();
-  }
-
-  /**
-   * Get next results page
-   */
-  @GET
-  @Path("{jobId}/results")
-  @Produces(MediaType.APPLICATION_JSON)
-  public Response getResults(@PathParam("jobId") String jobId,
-                             @QueryParam("first") String fromBeginning,
-                             @QueryParam("count") Integer count,
-                             @QueryParam("searchId") String searchId,
-                             @QueryParam("format") String format,
-                             @QueryParam("columns") final String requestedColumns) {
-    try {
-      final JobController jobController = getResourceManager().readController(jobId);
-      LOG.info("jobController.getStatus().status : " + jobController.getStatus().status + " for job : " + jobController.getJob().getId());
-      if(jobController.getStatus().status.equals(Job.JOB_STATE_INITIALIZED)
-         || jobController.getStatus().status.equals(Job.JOB_STATE_PENDING)
-         || jobController.getStatus().status.equals(Job.JOB_STATE_RUNNING)
-         || jobController.getStatus().status.equals(Job.JOB_STATE_UNKNOWN)){
-
-         return Response.status(Response.Status.SERVICE_UNAVAILABLE).header("Retry-After","1").build();
-      }
-      if (!jobController.hasResults()) {
-        return ResultsPaginationController.emptyResponse().build();
-      }
-
-      return ResultsPaginationController.getInstance(context)
-           .request(jobId, searchId, true, fromBeginning, count, format,
-               new Callable<Cursor>() {
-                 @Override
-                 public Cursor call() throws Exception {
-                   Cursor cursor = jobController.getResults();
-                   cursor.selectColumns(requestedColumns);
-                   return cursor;
-                 }
-               }).build();
-    } catch (WebApplicationException ex) {
-      throw ex;
-    } catch (ItemNotFound itemNotFound) {
-      throw new NotFoundFormattedException(itemNotFound.getMessage(), itemNotFound);
-    } catch (Exception ex) {
-      throw new ServiceFormattedException(ex.getMessage(), ex);
-    }
-  }
-
-  /**
-   * Renew expiration time for results
-   */
-  @GET
-  @Path("{jobId}/results/keepAlive")
-  public Response keepAliveResults(@PathParam("jobId") String jobId,
-                             @QueryParam("first") String fromBeginning,
-                             @QueryParam("count") Integer count) {
-    try {
-      if (!ResultsPaginationController.getInstance(context).keepAlive(jobId, ResultsPaginationController.DEFAULT_SEARCH_ID)) {
-        throw new NotFoundFormattedException("Results already expired", null);
-      }
-      return Response.ok().build();
-    } catch (WebApplicationException ex) {
-      throw ex;
-    } catch (Exception ex) {
-      throw new ServiceFormattedException(ex.getMessage(), ex);
-    }
-  }
-
-  /**
-   * Get progress info
-   */
-  @GET
-  @Path("{jobId}/progress")
-  @Produces(MediaType.APPLICATION_JSON)
-  public Response getProgress(@PathParam("jobId") String jobId) {
-    try {
-      final JobController jobController = getResourceManager().readController(jobId);
-
-      ProgressRetriever.Progress progress = new ProgressRetriever(jobController.getJob(), getSharedObjectsFactory()).
-          getProgress();
-
-      return Response.ok(progress).build();
-    } catch (WebApplicationException ex) {
-      throw ex;
-    } catch (ItemNotFound itemNotFound) {
-      throw new NotFoundFormattedException(itemNotFound.getMessage(), itemNotFound);
-    } catch (Exception ex) {
-      throw new ServiceFormattedException(ex.getMessage(), ex);
-    }
-  }
-
-  /**
-   * Delete single item
-   */
-  @DELETE
-  @Path("{id}")
-  public Response delete(@PathParam("id") String id,
-                         @QueryParam("remove") final String remove) {
-    try {
-      JobController jobController;
-      try {
-        jobController = getResourceManager().readController(id);
-      } catch (ItemNotFound itemNotFound) {
-        throw new NotFoundFormattedException(itemNotFound.getMessage(), itemNotFound);
-      }
-      jobController.cancel();
-      if (remove != null && remove.compareTo("true") == 0) {
-        getResourceManager().delete(id);
-      }
-      return Response.status(204).build();
-    } catch (WebApplicationException ex) {
-      throw ex;
-    } catch (ItemNotFound itemNotFound) {
-      throw new NotFoundFormattedException(itemNotFound.getMessage(), itemNotFound);
-    } catch (Exception ex) {
-      throw new ServiceFormattedException(ex.getMessage(), ex);
-    }
-  }
-
-  /**
-   * Get all Jobs
-   */
-  @GET
-  @Produces(MediaType.APPLICATION_JSON)
-  public List<Job> getList(@QueryParam("startTime") long startTime, @QueryParam("endTime") long endTime) {
-    try {
-
-      LOG.debug("Getting all job: startTime: {}, endTime: {}",startTime,endTime);
-      List<Job> allJobs = getAggregator().readAllForUserByTime(context.getUsername(),startTime, endTime);
-      for(Job job : allJobs) {
-        job.setSessionTag(null);
-      }
-
-      return allJobs;
-    } catch (WebApplicationException ex) {
-      LOG.error("Exception occured while fetching all jobs.", ex);
-      throw ex;
-    } catch (Exception ex) {
-      LOG.error("Exception occured while fetching all jobs.", ex);
-      throw new ServiceFormattedException(ex.getMessage(), ex);
-    }
-  }
-
-  /**
-   * fetch the jobs with given info.
-   * provide as much info about the job so that next api can optimize the fetch process.
-   * @param jobInfos
-   * @return
-   */
-  @Path("/getList")
-  @POST
-  @Produces(MediaType.APPLICATION_JSON)
-  @Consumes(MediaType.APPLICATION_JSON)
-  public List<Job> getList(List<JobInfo> jobInfos) {
-    try {
-      LOG.debug("fetching jobs with ids :{}", jobInfos);
-      List<Job> allJobs = getAggregator().readJobsByIds(jobInfos);
-      for(Job job : allJobs) {
-        job.setSessionTag(null);
-      }
-
-      return allJobs;
-    } catch (WebApplicationException ex) {
-      LOG.error("Exception occured while fetching all jobs.", ex);
-      throw ex;
-    } catch (Exception ex) {
-      LOG.error("Exception occured while fetching all jobs.", ex);
-      throw new ServiceFormattedException(ex.getMessage(), ex);
-    }
-  }
-
-  /**
-   * Create job
-   */
-  @POST
-  @Consumes(MediaType.APPLICATION_JSON)
-  public Response create(JobRequest request, @Context HttpServletResponse response,
-                         @Context UriInfo ui) {
-    try {
-      Map jobInfo = PropertyUtils.describe(request.job);
-      Job job = new JobImpl(jobInfo);
-      getResourceManager().create(job);
-
-      JobController createdJobController = getResourceManager().readController(job.getId());
-      createdJobController.submit();
-      getResourceManager().saveIfModified(createdJobController);
-
-      response.setHeader("Location",
-          String.format("%s/%s", ui.getAbsolutePath().toString(), job.getId()));
-
-      JSONObject jobObject = jsonObjectFromJob(createdJobController);
-
-      return Response.ok(jobObject).status(201).build();
-    } catch (WebApplicationException ex) {
-      LOG.error("Error occurred while creating job : ",ex);
-      throw ex;
-    } catch (ItemNotFound itemNotFound) {
-      LOG.error("Error occurred while creating job : ",itemNotFound);
-      throw new NotFoundFormattedException(itemNotFound.getMessage(), itemNotFound);
-    } catch (Exception ex) {
-      LOG.error("Error occurred while creating job : ",ex);
-      throw new ServiceFormattedException(ex.getMessage(), ex);
-    }
-  }
-
-  /**
-   * Set password and connect to Hive
-   */
-  @POST
-  @Path("auth")
-  @Consumes(MediaType.APPLICATION_JSON)
-  public Response setupPassword(AuthRequest request) {
-    try {
-      HiveAuthCredentials authCredentials = new HiveAuthCredentials();
-      authCredentials.setPassword(request.password);
-      new UserLocalHiveAuthCredentials().set(authCredentials, context);
-
-      connectionLocal.remove(context);  // force reconnect on next get
-      connectionLocal.get(context);
-      return Response.ok().status(200).build();
-    } catch (WebApplicationException ex) {
-      throw ex;
-    } catch (Exception ex) {
-      throw new ServiceFormattedException(ex.getMessage(), ex);
-    }
-  }
-
-  /**
-   * Remove connection credentials
-   */
-  @DELETE
-  @Path("auth")
-  public Response removePassword() {
-    try {
-      new UserLocalHiveAuthCredentials().remove(context);
-      connectionLocal.remove(context);  // force reconnect on next get
-      return Response.ok().status(200).build();
-    } catch (WebApplicationException ex) {
-      throw ex;
-    } catch (Exception ex) {
-      throw new ServiceFormattedException(ex.getMessage(), ex);
-    }
-  }
-
-
-  /**
-   * Invalidate session
-   */
-  @DELETE
-  @Path("sessions/{sessionTag}")
-  public Response invalidateSession(@PathParam("sessionTag") String sessionTag) {
-    try {
-      Connection connection = connectionLocal.get(context);
-      connection.invalidateSessionByTag(sessionTag);
-      return Response.ok().build();
-    } catch (WebApplicationException ex) {
-      throw ex;
-    } catch (Exception ex) {
-      throw new ServiceFormattedException(ex.getMessage(), ex);
-    }
-  }
-
-  /**
-   * Session status
-   */
-  @GET
-  @Path("sessions/{sessionTag}")
-  @Produces(MediaType.APPLICATION_JSON)
-  public Response sessionStatus(@PathParam("sessionTag") String sessionTag) {
-    try {
-      Connection connection = connectionLocal.get(context);
-
-      JSONObject session = new JSONObject();
-      session.put("sessionTag", sessionTag);
-      try {
-        connection.getSessionByTag(sessionTag);
-        session.put("actual", true);
-      } catch (HiveClientException ex) {
-        session.put("actual", false);
-      }
-
-      JSONObject status = new JSONObject();
-      status.put("session", session);
-      return Response.ok(status).build();
-    } catch (WebApplicationException ex) {
-      throw ex;
-    } catch (Exception ex) {
-      throw new ServiceFormattedException(ex.getMessage(), ex);
-    }
-  }
-
-  /**
-   * Wrapper object for json mapping
-   */
-  public static class JobRequest {
-    public JobImpl job;
-  }
-
-  /**
-   * Wrapper for authentication json mapping
-   */
-  public static class AuthRequest {
-    public String password;
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/LogParser.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/LogParser.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/LogParser.java
deleted file mode 100644
index 54f6757..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/LogParser.java
+++ /dev/null
@@ -1,139 +0,0 @@
-/**
- * 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.ambari.view.hive.resources.jobs;
-
-import java.util.LinkedHashSet;
-import java.util.regex.Matcher;
-import java.util.regex.Pattern;
-
-public class LogParser {
-  public static final Pattern HADOOP_MR_APPS_RE = Pattern.compile("(http[^\\s]*/proxy/([a-z0-9_]+?)/)");
-  public static final Pattern HADOOP_TEZ_APPS_RE = Pattern.compile("\\(Executing on YARN cluster with App id ([a-z0-9_]+?)\\)");
-  private LinkedHashSet<AppId> appsList;
-
-  private LogParser() {}
-
-  public static LogParser parseLog(String logs) {
-    LogParser parser = new LogParser();
-
-    parser.setAppsList(parseApps(logs, parser));
-    return parser;
-  }
-
-  public static LinkedHashSet<AppId> parseApps(String logs, LogParser parser) {
-    LinkedHashSet<AppId> mrAppIds = getMRAppIds(logs);
-    LinkedHashSet<AppId> tezAppIds = getTezAppIds(logs);
-
-    LinkedHashSet<AppId> appIds = new LinkedHashSet<AppId>();
-    appIds.addAll(mrAppIds);
-    appIds.addAll(tezAppIds);
-
-    return appIds;
-  }
-
-  private static LinkedHashSet<AppId> getMRAppIds(String logs) {
-    Matcher m = HADOOP_MR_APPS_RE.matcher(logs);
-    LinkedHashSet<AppId> list = new LinkedHashSet<AppId>();
-    while (m.find()) {
-      AppId applicationInfo = new AppId();
-      applicationInfo.setTrackingUrl(m.group(1));
-      applicationInfo.setIdentifier(m.group(2));
-      list.add(applicationInfo);
-    }
-    return list;
-  }
-
-  private static LinkedHashSet<AppId> getTezAppIds(String logs) {
-    Matcher m = HADOOP_TEZ_APPS_RE.matcher(logs);
-    LinkedHashSet<AppId> list = new LinkedHashSet<AppId>();
-    while (m.find()) {
-      AppId applicationInfo = new AppId();
-      applicationInfo.setTrackingUrl("");
-      applicationInfo.setIdentifier(m.group(1));
-      list.add(applicationInfo);
-    }
-    return list;
-  }
-
-  public void setAppsList(LinkedHashSet<AppId> appsList) {
-    this.appsList = appsList;
-  }
-
-  public LinkedHashSet<AppId> getAppsList() {
-    return appsList;
-  }
-
-  public AppId getLastAppInList() {
-    Object[] appIds = appsList.toArray();
-    if (appIds.length == 0) {
-      return null;
-    }
-    return (AppId) appIds[appsList.size()-1];
-  }
-
-  public static class AppId {
-    private String trackingUrl;
-    private String identifier;
-
-    public String getTrackingUrl() {
-      return trackingUrl;
-    }
-
-    public void setTrackingUrl(String trackingUrl) {
-      this.trackingUrl = trackingUrl;
-    }
-
-    public String getIdentifier() {
-      return identifier;
-    }
-
-    public void setIdentifier(String identifier) {
-      this.identifier = identifier;
-    }
-
-    @Override
-    public boolean equals(Object o) {
-      if (this == o) return true;
-      if (!(o instanceof AppId)) return false;
-
-      AppId appId = (AppId) o;
-
-      if (!identifier.equals(appId.identifier)) return false;
-
-      return true;
-    }
-
-    @Override
-    public int hashCode() {
-      return identifier.hashCode();
-    }
-  }
-
-  public static class EmptyAppId extends AppId {
-    @Override
-    public String getTrackingUrl() {
-      return "";
-    }
-
-    @Override
-    public String getIdentifier() {
-      return "";
-    }
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/ModifyNotificationDelegate.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/ModifyNotificationDelegate.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/ModifyNotificationDelegate.java
deleted file mode 100644
index 8b48c97..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/ModifyNotificationDelegate.java
+++ /dev/null
@@ -1,23 +0,0 @@
-/**
- * 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.ambari.view.hive.resources.jobs;
-
-public interface ModifyNotificationDelegate {
-  boolean onModification(Object object);
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/ModifyNotificationInvocationHandler.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/ModifyNotificationInvocationHandler.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/ModifyNotificationInvocationHandler.java
deleted file mode 100644
index 0552a8c..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/ModifyNotificationInvocationHandler.java
+++ /dev/null
@@ -1,40 +0,0 @@
-/**
- * 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.ambari.view.hive.resources.jobs;
-
-import java.lang.reflect.InvocationHandler;
-import java.lang.reflect.Method;
-
-public class ModifyNotificationInvocationHandler implements InvocationHandler {
-  private Object proxied;
-  private ModifyNotificationDelegate modifyDelegate;
-
-  public ModifyNotificationInvocationHandler(Object proxied, ModifyNotificationDelegate delegate) {
-    this.proxied = proxied;
-    this.modifyDelegate = delegate;
-  }
-
-  @Override
-  public Object invoke(Object o, Method method, Object[] args) throws Throwable {
-    if (method.getName().startsWith("set")) {
-      modifyDelegate.onModification(proxied);
-    }
-    return method.invoke(proxied, args);
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/NoOperationStatusSetException.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/NoOperationStatusSetException.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/NoOperationStatusSetException.java
deleted file mode 100644
index 020c63e..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/NoOperationStatusSetException.java
+++ /dev/null
@@ -1,23 +0,0 @@
-/**
- * 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.ambari.view.hive.resources.jobs;
-
-
-public class NoOperationStatusSetException extends Exception {
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/OperationHandleController.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/OperationHandleController.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/OperationHandleController.java
deleted file mode 100644
index faf02b0..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/OperationHandleController.java
+++ /dev/null
@@ -1,135 +0,0 @@
-/**
- * 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.ambari.view.hive.resources.jobs;
-
-
-import org.apache.ambari.view.ViewContext;
-import org.apache.ambari.view.hive.client.Cursor;
-import org.apache.ambari.view.hive.client.HiveClientException;
-import org.apache.ambari.view.hive.client.UserLocalConnection;
-import org.apache.ambari.view.hive.resources.jobs.viewJobs.Job;
-import org.apache.ambari.view.hive.utils.HiveClientFormattedException;
-import org.apache.hive.service.cli.thrift.TGetOperationStatusResp;
-import org.apache.hive.service.cli.thrift.TOperationHandle;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-public class OperationHandleController {
-  private final static Logger LOG =
-      LoggerFactory.getLogger(OperationHandleController.class);
-  private final TOperationHandle operationHandle;
-  private ViewContext context;
-  private final StoredOperationHandle storedOperationHandle;
-  private final IOperationHandleResourceManager operationHandlesStorage;
-
-  protected UserLocalConnection connectionLocal = new UserLocalConnection();
-
-  public OperationHandleController(ViewContext context, StoredOperationHandle storedOperationHandle,
-                                   IOperationHandleResourceManager operationHandlesStorage) {
-    this.context = context;
-    this.storedOperationHandle = storedOperationHandle;
-    this.operationHandle = storedOperationHandle.toTOperationHandle();
-    this.operationHandlesStorage = operationHandlesStorage;
-  }
-
-  public StoredOperationHandle getStoredOperationHandle() {
-    return storedOperationHandle;
-  }
-
-  public OperationStatus getOperationStatus() throws NoOperationStatusSetException, HiveClientException {
-    TGetOperationStatusResp statusResp = connectionLocal.get(context).getOperationStatus(operationHandle);
-
-    if (!statusResp.isSetOperationState()) {
-      throw new NoOperationStatusSetException();
-    }
-
-    OperationStatus opStatus = new OperationStatus();
-    opStatus.sqlState = statusResp.getSqlState();
-    opStatus.message = statusResp.getErrorMessage();
-
-    switch (statusResp.getOperationState()) {
-      case INITIALIZED_STATE:
-        opStatus.status = Job.JOB_STATE_INITIALIZED;
-        break;
-      case RUNNING_STATE:
-        opStatus.status = Job.JOB_STATE_RUNNING;
-        break;
-      case FINISHED_STATE:
-        opStatus.status = Job.JOB_STATE_FINISHED;
-        break;
-      case CANCELED_STATE:
-        opStatus.status = Job.JOB_STATE_CANCELED;
-        break;
-      case CLOSED_STATE:
-        opStatus.status = Job.JOB_STATE_CLOSED;
-        break;
-      case ERROR_STATE:
-        opStatus.status = Job.JOB_STATE_ERROR;
-        break;
-      case UKNOWN_STATE:
-        opStatus.status = Job.JOB_STATE_UNKNOWN;
-        break;
-      case PENDING_STATE:
-        opStatus.status = Job.JOB_STATE_PENDING;
-        break;
-      default:
-        throw new NoOperationStatusSetException();
-    }
-
-    return opStatus;
-  }
-
-  public void cancel() {
-    try {
-      connectionLocal.get(context).cancelOperation(operationHandle);
-    } catch (HiveClientException e) {
-      throw new HiveClientFormattedException(e);
-    }
-  }
-
-  public void persistHandleForJob(Job job) {
-    operationHandlesStorage.putHandleForJob(operationHandle, job);
-  }
-
-  public String getLogs() {
-    String logs;
-    try {
-      logs = connectionLocal.get(context).getLogs(operationHandle);
-    } catch (HiveClientFormattedException ex) {
-      logs = "";
-      LOG.info(String.format("Logs are not available yet for job #%s [%s]\n%s",
-          storedOperationHandle.getJobId(), storedOperationHandle.getGuid(), ex.toString()));
-    }
-    return logs;
-  }
-
-  public Cursor getResults() {
-    return connectionLocal.get(context).getResults(operationHandle);
-  }
-
-  public boolean hasResults() {
-    return operationHandle.isHasResultSet();
-  }
-
-  public static class OperationStatus {
-    public String status;
-    public String sqlState;
-    public String message;
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/OperationHandleControllerFactory.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/OperationHandleControllerFactory.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/OperationHandleControllerFactory.java
deleted file mode 100644
index fe1b01a..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/OperationHandleControllerFactory.java
+++ /dev/null
@@ -1,43 +0,0 @@
-/**
- * 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.ambari.view.hive.resources.jobs;
-
-import org.apache.ambari.view.ViewContext;
-import org.apache.ambari.view.hive.persistence.utils.ItemNotFound;
-import org.apache.ambari.view.hive.resources.jobs.viewJobs.Job;
-import org.apache.ambari.view.hive.utils.SharedObjectsFactory;
-
-public class OperationHandleControllerFactory {
-  private IOperationHandleResourceManager operationHandlesStorage;
-  private ViewContext context;
-
-  public OperationHandleControllerFactory(ViewContext context, SharedObjectsFactory storageFactory) {
-    this.context = context;
-    this.operationHandlesStorage = new OperationHandleResourceManager(storageFactory);
-  }
-
-  public OperationHandleController createControllerForHandle(StoredOperationHandle storedOperationHandle) {
-    return new OperationHandleController(context, storedOperationHandle, operationHandlesStorage);
-  }
-
-  public OperationHandleController getHandleForJob(Job job) throws ItemNotFound {
-    StoredOperationHandle handle = operationHandlesStorage.getHandleForJob(job);
-    return createControllerForHandle(handle);
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/OperationHandleResourceManager.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/OperationHandleResourceManager.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/OperationHandleResourceManager.java
deleted file mode 100644
index c53cad5..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/OperationHandleResourceManager.java
+++ /dev/null
@@ -1,120 +0,0 @@
-/**
- * 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.ambari.view.hive.resources.jobs;
-
-import org.apache.ambari.view.hive.persistence.IStorageFactory;
-import org.apache.ambari.view.hive.persistence.utils.FilteringStrategy;
-import org.apache.ambari.view.hive.persistence.utils.Indexed;
-import org.apache.ambari.view.hive.persistence.utils.ItemNotFound;
-import org.apache.ambari.view.hive.resources.SharedCRUDResourceManager;
-import org.apache.ambari.view.hive.resources.jobs.viewJobs.Job;
-import org.apache.ambari.view.hive.resources.jobs.viewJobs.JobImpl;
-import org.apache.ambari.view.hive.utils.ServiceFormattedException;
-import org.apache.hive.service.cli.thrift.TOperationHandle;
-
-import java.util.LinkedList;
-import java.util.List;
-
-public class OperationHandleResourceManager extends SharedCRUDResourceManager<StoredOperationHandle>
-    implements IOperationHandleResourceManager {
-  /**
-   * Constructor
-   */
-  public OperationHandleResourceManager(IStorageFactory storageFabric) {
-    super(StoredOperationHandle.class, storageFabric);
-  }
-
-  @Override
-  public List<StoredOperationHandle> readJobRelatedHandles(final Job job) {
-    return storageFactory.getStorage().loadAll(StoredOperationHandle.class, new FilteringStrategy() {
-      @Override
-      public boolean isConform(Indexed item) {
-        StoredOperationHandle handle = (StoredOperationHandle) item;
-        return (handle.getJobId() != null && handle.getJobId().equals(job.getId()));
-      }
-
-      @Override
-      public String whereStatement() {
-        return "jobId = '" + job.getId() + "'";
-      }
-    });
-  }
-
-  @Override
-  public StoredOperationHandle getHandleForJob(Job job) throws ItemNotFound {
-    List<StoredOperationHandle> jobRelatedHandles = readJobRelatedHandles(job);
-    if (jobRelatedHandles.size() == 0)
-      throw new ItemNotFound();
-    return jobRelatedHandles.get(0);
-  }
-
-  @Override
-  public List<Job> getHandleRelatedJobs(final StoredOperationHandle operationHandle) {
-    List<JobImpl> list = storageFactory.getStorage().loadAll(JobImpl.class, new FilteringStrategy() {
-      @Override
-      public boolean isConform(Indexed item) {
-        Job job = (Job) item;
-        return (job.getId() != null && job.getId().equals(operationHandle.getJobId()));
-      }
-
-      @Override
-      public String whereStatement() {
-        return "id = '" + operationHandle.getJobId() + "'";
-      }
-    });
-
-    if(null == list)
-      return null;
-
-    List<Job> jobs = new LinkedList<Job>(list);
-    return jobs;
-  }
-
-  @Override
-  public Job getJobByHandle(StoredOperationHandle handle) throws ItemNotFound {
-    List<Job> handleRelatedJobs = getHandleRelatedJobs(handle);
-    if (handleRelatedJobs.size() == 0)
-      throw new ItemNotFound(String.format("Job not found for operationId %s", handle));
-    return handleRelatedJobs.get(0);
-  }
-
-  @Override
-  public void putHandleForJob(TOperationHandle h, Job job) {
-    StoredOperationHandle handle = StoredOperationHandle.buildFromTOperationHandle(h);
-    handle.setJobId(job.getId());
-
-    List<StoredOperationHandle> jobRelatedHandles = readJobRelatedHandles(job);
-    if (jobRelatedHandles.size() > 0) {
-      handle.setId(jobRelatedHandles.get(0).getId());  // update existing
-      try {
-        update(handle, jobRelatedHandles.get(0).getId());
-      } catch (ItemNotFound itemNotFound) {
-        throw new ServiceFormattedException("E050 Error when updating operation handle: " + itemNotFound.toString(), itemNotFound);
-      }
-    } else {
-      create(handle);
-    }
-  }
-
-  @Override
-  public boolean containsHandleForJob(Job job) {
-    List<StoredOperationHandle> jobRelatedHandles = readJobRelatedHandles(job);
-    return jobRelatedHandles.size() > 0;
-  }
-}


[19/23] ambari git commit: AMBARI-19302 : removed contrib/views/hive folder and made necessary changes in pom.xml files (nitirajrathore)

Posted by ni...@apache.org.
http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/ProgressRetriever.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/ProgressRetriever.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/ProgressRetriever.java
deleted file mode 100644
index 6be8147..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/ProgressRetriever.java
+++ /dev/null
@@ -1,67 +0,0 @@
-/**
- * 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.ambari.view.hive.resources.jobs;
-
-import org.apache.ambari.view.hive.resources.jobs.atsJobs.TezVertexId;
-import org.apache.ambari.view.hive.resources.jobs.rm.RMParser;
-import org.apache.ambari.view.hive.resources.jobs.viewJobs.Job;
-import org.apache.ambari.view.hive.utils.ServiceFormattedException;
-import org.apache.ambari.view.hive.utils.SharedObjectsFactory;
-
-import java.util.List;
-import java.util.Map;
-
-public class ProgressRetriever {
-  private final Progress progress;
-  private final Job job;
-  private final SharedObjectsFactory sharedObjects;
-
-  public ProgressRetriever(Job job, SharedObjectsFactory sharedObjects) {
-    this.job = job;
-    this.sharedObjects = sharedObjects;
-
-    this.progress = new Progress();
-  }
-
-  public Progress getProgress() {
-    jobCheck();
-
-    progress.dagProgress = sharedObjects.getRMParser().getDAGProgress(
-        job.getApplicationId(), job.getDagId());
-
-    List<TezVertexId> vertices = sharedObjects.getATSParser().getVerticesForDAGId(job.getDagId());
-    progress.vertexProgresses = sharedObjects.getRMParser().getDAGVerticesProgress(job.getApplicationId(), job.getDagId(), vertices);
-
-    return progress;
-  }
-
-  public void jobCheck() {
-    if (job.getApplicationId() == null || job.getApplicationId().isEmpty()) {
-      throw new ServiceFormattedException("E070 ApplicationId is not defined yet");
-    }
-    if (job.getDagId() == null || job.getDagId().isEmpty()) {
-      throw new ServiceFormattedException("E080 DagID is not defined yet");
-    }
-  }
-
-  public static class Progress {
-    public Double dagProgress;
-    public List<RMParser.VertexProgress> vertexProgresses;
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/ResultsPaginationController.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/ResultsPaginationController.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/ResultsPaginationController.java
deleted file mode 100644
index cc2ff42..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/ResultsPaginationController.java
+++ /dev/null
@@ -1,240 +0,0 @@
-/**
- * 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.ambari.view.hive.resources.jobs;
-
-
-import org.apache.ambari.view.ViewContext;
-import org.apache.ambari.view.hive.client.ColumnDescription;
-import org.apache.ambari.view.hive.client.HiveClientException;
-import org.apache.ambari.view.hive.client.Cursor;
-import org.apache.ambari.view.hive.utils.HiveClientFormattedException;
-import org.apache.ambari.view.hive.utils.ServiceFormattedException;
-import org.apache.commons.collections4.map.PassiveExpiringMap;
-
-import javax.ws.rs.core.Response;
-import java.lang.Object;
-import java.lang.String;
-import java.util.ArrayList;
-import java.util.Collections;
-import java.util.HashMap;
-import java.util.Map;
-import java.util.List;
-import java.util.concurrent.Callable;
-
-/**
- * Results Pagination Controller
- * Persists cursors for result sets
- */
-public class ResultsPaginationController {
-  public static final String DEFAULT_SEARCH_ID = "default";
-  private static Map<String, ResultsPaginationController> viewSingletonObjects = new HashMap<String, ResultsPaginationController>();
-  public static ResultsPaginationController getInstance(ViewContext context) {
-    if (!viewSingletonObjects.containsKey(context.getInstanceName()))
-      viewSingletonObjects.put(context.getInstanceName(), new ResultsPaginationController());
-    return viewSingletonObjects.get(context.getInstanceName());
-  }
-
-  public ResultsPaginationController() {
-  }
-
-  private static final long EXPIRING_TIME = 10*60*1000;  // 10 minutes
-  private static final int DEFAULT_FETCH_COUNT = 50;
-  private Map<String, Cursor> resultsCache;
-
-  public static class CustomTimeToLiveExpirationPolicy extends PassiveExpiringMap.ConstantTimeToLiveExpirationPolicy<String, Cursor> {
-    public CustomTimeToLiveExpirationPolicy(long timeToLiveMillis) {
-      super(timeToLiveMillis);
-    }
-
-    @Override
-    public long expirationTime(String key, Cursor value) {
-      if (key.startsWith("$")) {
-        return -1;  //never expire
-      }
-      return super.expirationTime(key, value);
-    }
-  }
-
-  private Map<String, Cursor> getResultsCache() {
-    if (resultsCache == null) {
-      PassiveExpiringMap<String, Cursor> resultsCacheExpiringMap =
-          new PassiveExpiringMap<String, Cursor>(new CustomTimeToLiveExpirationPolicy(EXPIRING_TIME));
-      resultsCache = Collections.synchronizedMap(resultsCacheExpiringMap);
-    }
-    return resultsCache;
-  }
-
-  /**
-   * Renew timer of cache entry.
-   * @param key name/id of results request
-   * @return false if entry not found; true if renew was ok
-   */
-  public boolean keepAlive(String key, String searchId) {
-    if (searchId == null)
-      searchId = DEFAULT_SEARCH_ID;
-    String effectiveKey = key + "?" + searchId;
-    if (!getResultsCache().containsKey(effectiveKey)) {
-      return false;
-    }
-    Cursor cursor = getResultsCache().get(effectiveKey);
-    getResultsCache().put(effectiveKey, cursor);
-    return true;
-  }
-
-  private Cursor getResultsSet(String key, Callable<Cursor> makeResultsSet) {
-    if (!getResultsCache().containsKey(key)) {
-      Cursor resultSet = null;
-      try {
-        resultSet = makeResultsSet.call();
-      } catch (HiveClientException ex) {
-        throw new HiveClientFormattedException(ex);
-      } catch (Exception ex) {
-        throw new ServiceFormattedException(ex.getMessage(), ex);
-      }
-      getResultsCache().put(key, resultSet);
-    }
-
-    return getResultsCache().get(key);
-  }
-
-  public Response.ResponseBuilder request(String key, String searchId, boolean canExpire, String fromBeginning, Integer count, String format, Callable<Cursor> makeResultsSet) throws HiveClientException {
-    if (searchId == null)
-      searchId = DEFAULT_SEARCH_ID;
-    key = key + "?" + searchId;
-    if (!canExpire)
-      key = "$" + key;
-    if (fromBeginning != null && fromBeginning.equals("true") && getResultsCache().containsKey(key))
-      getResultsCache().remove(key);
-    Cursor resultSet = getResultsSet(key, makeResultsSet);
-
-    if (count == null)
-      count = DEFAULT_FETCH_COUNT;
-
-    ArrayList<ColumnDescription> schema = resultSet.getSchema();
-    ArrayList<Object[]> rows = new ArrayList<Object[]>(count);
-    int read = resultSet.readRaw(rows, count);
-    if(format != null && format.equalsIgnoreCase("d3")) {
-      List<Map<String,Object>> results = new ArrayList<Map<String,Object>>();
-      for(int i=0; i<rows.size(); i++) {
-        Object[] row = rows.get(i);
-        Map<String, Object> keyValue = new HashMap<String, Object>(row.length);
-        for(int j=0; j<row.length; j++) {
-          //Replace dots in schema with underscore
-          String schemaName = schema.get(j).getName();
-          keyValue.put(schemaName.replace('.','_'), row[j]);
-        }
-        results.add(keyValue);
-      }
-      return Response.ok(results);
-    } else {
-      ResultsResponse resultsResponse = new ResultsResponse();
-      resultsResponse.setSchema(schema);
-      resultsResponse.setRows(rows);
-      resultsResponse.setReadCount(read);
-      resultsResponse.setHasNext(resultSet.hasNext());
-      //      resultsResponse.setSize(resultSet.size());
-      resultsResponse.setOffset(resultSet.getOffset());
-      resultsResponse.setHasResults(true);
-      return Response.ok(resultsResponse);
-    }
-  }
-
-  public static Response.ResponseBuilder emptyResponse() {
-    ResultsResponse resultsResponse = new ResultsResponse();
-    resultsResponse.setSchema(new ArrayList<ColumnDescription>());
-    resultsResponse.setRows(new ArrayList<Object[]>());
-    resultsResponse.setReadCount(0);
-    resultsResponse.setHasNext(false);
-    resultsResponse.setOffset(0);
-    resultsResponse.setHasResults(false);
-    return Response.ok(resultsResponse);
-  }
-
-  private static class ResultsResponse {
-    private ArrayList<ColumnDescription> schema;
-    private ArrayList<String[]> rows;
-    private int readCount;
-    private boolean hasNext;
-    private long offset;
-    private boolean hasResults;
-
-    public void setSchema(ArrayList<ColumnDescription> schema) {
-      this.schema = schema;
-    }
-
-    public ArrayList<ColumnDescription> getSchema() {
-      return schema;
-    }
-
-    public void setRows(ArrayList<Object[]> rows) {
-      if( null == rows ){
-        this.rows = null;
-      }
-      this.rows = new ArrayList<String[]>(rows.size());
-      for(Object[] row : rows ){
-        String[] strs = new String[row.length];
-        for( int colNum = 0 ; colNum < row.length ; colNum++ ){
-          String value = String.valueOf(row[colNum]);
-          if(row[colNum] != null && (value.isEmpty() || value.equalsIgnoreCase("null"))){
-            strs[colNum] = String.format("\"%s\"",value);
-          }else{
-            strs[colNum] = value;
-          }
-        }
-        this.rows.add(strs);
-      }
-    }
-
-    public ArrayList<String[]> getRows() {
-      return rows;
-    }
-
-    public void setReadCount(int readCount) {
-      this.readCount = readCount;
-    }
-
-    public int getReadCount() {
-      return readCount;
-    }
-
-    public void setHasNext(boolean hasNext) {
-      this.hasNext = hasNext;
-    }
-
-    public boolean isHasNext() {
-      return hasNext;
-    }
-
-    public long getOffset() {
-      return offset;
-    }
-
-    public void setOffset(long offset) {
-      this.offset = offset;
-    }
-
-    public boolean getHasResults() {
-      return hasResults;
-    }
-
-    public void setHasResults(boolean hasResults) {
-      this.hasResults = hasResults;
-    }
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/StoredOperationHandle.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/StoredOperationHandle.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/StoredOperationHandle.java
deleted file mode 100644
index a1d87ad..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/StoredOperationHandle.java
+++ /dev/null
@@ -1,146 +0,0 @@
-/**
- * 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.ambari.view.hive.resources.jobs;
-
-import org.apache.ambari.view.hive.persistence.utils.Indexed;
-import org.apache.ambari.view.hive.utils.ServiceFormattedException;
-import org.apache.commons.beanutils.PropertyUtils;
-import org.apache.commons.codec.DecoderException;
-import org.apache.commons.codec.binary.Hex;
-import org.apache.hive.service.cli.thrift.THandleIdentifier;
-import org.apache.hive.service.cli.thrift.TOperationHandle;
-import org.apache.hive.service.cli.thrift.TOperationType;
-
-import java.lang.reflect.InvocationTargetException;
-import java.util.Map;
-
-/**
- * Bean to represent TOperationHandle stored in DB
- */
-public class StoredOperationHandle implements Indexed {
-  private boolean hasResultSet;
-  private double modifiedRowCount;
-  private int operationType;
-  private String guid;
-  private String secret;
-
-  private String jobId;
-
-  private String id;
-
-  public StoredOperationHandle() {}
-  public StoredOperationHandle(Map<String, Object> stringObjectMap) throws InvocationTargetException, IllegalAccessException {
-    for (Map.Entry<String, Object> entry : stringObjectMap.entrySet())  {
-      try {
-        PropertyUtils.setProperty(this, entry.getKey(), entry.getValue());
-      } catch (NoSuchMethodException e) {
-        //do nothing, skip
-      }
-    }
-  }
-
-
-  public static StoredOperationHandle buildFromTOperationHandle(TOperationHandle handle) {
-    StoredOperationHandle storedHandle = new StoredOperationHandle();
-    //bool hasResultSet
-    storedHandle.setHasResultSet(handle.isHasResultSet());
-    //optional double modifiedRowCount
-    storedHandle.setModifiedRowCount(handle.getModifiedRowCount());
-    //TOperationType operationType
-    storedHandle.setOperationType(handle.getOperationType().getValue());
-    //THandleIdentifier operationId
-    storedHandle.setGuid(Hex.encodeHexString(handle.getOperationId().getGuid()));
-    storedHandle.setSecret(Hex.encodeHexString(handle.getOperationId().getSecret()));
-    return storedHandle;
-  }
-
-  public TOperationHandle toTOperationHandle() {
-    TOperationHandle handle = new TOperationHandle();
-    handle.setHasResultSet(isHasResultSet());
-    handle.setModifiedRowCount(getModifiedRowCount());
-    handle.setOperationType(TOperationType.findByValue(getOperationType()));
-    THandleIdentifier identifier = new THandleIdentifier();
-    try {
-      identifier.setGuid(Hex.decodeHex(getGuid().toCharArray()));
-      identifier.setSecret(Hex.decodeHex(getSecret().toCharArray()));
-    } catch (DecoderException e) {
-      throw new ServiceFormattedException("E060 Wrong identifier of OperationHandle is stored in DB");
-    }
-    handle.setOperationId(identifier);
-    return handle;
-  }
-
-  public boolean isHasResultSet() {
-    return hasResultSet;
-  }
-
-  public void setHasResultSet(boolean hasResultSet) {
-    this.hasResultSet = hasResultSet;
-  }
-
-  public double getModifiedRowCount() {
-    return modifiedRowCount;
-  }
-
-  public void setModifiedRowCount(double modifiedRowCount) {
-    this.modifiedRowCount = modifiedRowCount;
-  }
-
-  public int getOperationType() {
-    return operationType;
-  }
-
-  public void setOperationType(int operationType) {
-    this.operationType = operationType;
-  }
-
-  public String getGuid() {
-    return guid;
-  }
-
-  public void setGuid(String guid) {
-    this.guid = guid;
-  }
-
-  public String getSecret() {
-    return secret;
-  }
-
-  public void setSecret(String secret) {
-    this.secret = secret;
-  }
-
-  public String getJobId() {
-    return jobId;
-  }
-
-  public void setJobId(String jobId) {
-    this.jobId = jobId;
-  }
-
-  @Override
-  public String getId() {
-    return id;
-  }
-
-  @Override
-  public void setId(String id) {
-    this.id = id;
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/atsJobs/ATSParser.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/atsJobs/ATSParser.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/atsJobs/ATSParser.java
deleted file mode 100644
index b145df2..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/atsJobs/ATSParser.java
+++ /dev/null
@@ -1,248 +0,0 @@
-/**
- * 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.ambari.view.hive.resources.jobs.atsJobs;
-
-import org.json.simple.JSONArray;
-import org.json.simple.JSONObject;
-import org.json.simple.JSONValue;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-import java.util.LinkedList;
-import java.util.List;
-
-/**
- * Parser of ATS responses
- */
-public class ATSParser implements IATSParser {
-  protected final static Logger LOG =
-    LoggerFactory.getLogger(ATSParser.class);
-
-  private ATSRequestsDelegate delegate;
-
-  private static final long MillisInSecond = 1000L;
-
-  public ATSParser(ATSRequestsDelegate delegate) {
-    this.delegate = delegate;
-  }
-
-  /**
-   * returns all HiveQueryIDs from ATS for the given user.
-   * @param username
-   * @return
-   */
-  @Override
-  public List<HiveQueryId> getHiveQueryIdsForUser(String username) {
-    JSONObject entities = delegate.hiveQueryIdsForUser(username);
-    return parseHqidJsonFromATS(entities);
-  }
-
-  /**
-   * parses the JSONArray or hive query IDs
-   * @param entities: should contain 'entities' element as JSONArray
-   * @return
-   */
-  private List<HiveQueryId> parseHqidJsonFromATS(JSONObject entities) {
-    JSONArray jobs = (JSONArray) entities.get("entities");
-
-    return getHqidListFromJsonArray(jobs);
-  }
-
-  /**
-   * parses List of HiveQueryIds from JSON
-   * @param jobs
-   * @return
-   */
-  private List<HiveQueryId> getHqidListFromJsonArray(JSONArray jobs) {
-    List<HiveQueryId> parsedJobs = new LinkedList<>();
-    for (Object job : jobs) {
-      try {
-        HiveQueryId parsedJob = parseAtsHiveJob((JSONObject) job);
-        parsedJobs.add(parsedJob);
-      } catch (Exception ex) {
-        LOG.error("Error while parsing ATS job", ex);
-      }
-    }
-
-    return parsedJobs;
-  }
-
-  @Override
-  public List<TezVertexId> getVerticesForDAGId(String dagId) {
-    JSONObject entities = delegate.tezVerticesListForDAG(dagId);
-    JSONArray vertices = (JSONArray) entities.get("entities");
-
-    List<TezVertexId> parsedVertices = new LinkedList<TezVertexId>();
-    for(Object vertex : vertices) {
-      try {
-        TezVertexId parsedVertex = parseVertex((JSONObject) vertex);
-        parsedVertices.add(parsedVertex);
-      } catch (Exception ex) {
-        LOG.error("Error while parsing the vertex", ex);
-      }
-    }
-
-    return parsedVertices;
-  }
-
-  @Override
-  public HiveQueryId getHiveQueryIdByOperationId(String guidString) {
-    JSONObject entities = delegate.hiveQueryIdByOperationId(guidString);
-    return getHiveQueryIdFromJson(entities);
-  }
-
-  private HiveQueryId getHiveQueryIdFromJson(JSONObject entities) {
-    JSONArray jobs = (JSONArray) entities.get("entities");
-
-    if (jobs.size() == 0) {
-      return new HiveQueryId();
-    }
-
-    return parseAtsHiveJob((JSONObject) jobs.get(0));
-  }
-
-  /**
-   * returns the hive entity from ATS. empty object if not found.
-   *
-   * @param hiveId: the entityId of the hive
-   * @return: empty entity if not found else HiveQueryId
-   */
-  @Override
-  public HiveQueryId getHiveQueryIdByHiveEntityId(String hiveId) {
-    JSONObject entity = delegate.hiveQueryEntityByEntityId(hiveId);
-    return parseAtsHiveJob(entity);
-  }
-
-  @Override
-  public TezDagId getTezDAGByName(String name) {
-    JSONArray tezDagEntities = (JSONArray) delegate.tezDagByName(name).get("entities");
-    return parseTezDag(tezDagEntities);
-  }
-
-  @Override
-  public TezDagId getTezDAGByEntity(String entity) {
-    JSONArray tezDagEntities = (JSONArray) delegate.tezDagByEntity(entity).get("entities");
-    return parseTezDag(tezDagEntities);
-  }
-
-  /**
-   * fetches the HIVE_QUERY_ID from ATS for given user between given time period
-   *
-   * @param username:  username for which to fetch hive query IDs
-   * @param startTime: time in miliseconds, inclusive
-   * @param endTime:   time in miliseconds, exclusive
-   * @return: List of HIVE_QUERY_ID
-   */
-  @Override
-  public List<HiveQueryId> getHiveQueryIdsForUserByTime(String username, long startTime, long endTime) {
-    JSONObject entities = delegate.hiveQueryIdsForUserByTime(username, startTime, endTime);
-    return parseHqidJsonFromATS(entities);
-  }
-
-  @Override
-  public List<HiveQueryId> getHiveQueryIdByEntityList(List<String> hiveIds) {
-    List<HiveQueryId> hiveQueryIds = new LinkedList<>();
-    for (String id : hiveIds) {
-      HiveQueryId hqi = this.getHiveQueryIdByHiveEntityId(id);
-      if (null != hqi.entity) {
-        hiveQueryIds.add(hqi);
-      }
-    }
-    return hiveQueryIds;
-  }
-
-  private TezDagId parseTezDag(JSONArray tezDagEntities) {
-    assert tezDagEntities.size() <= 1;
-    if (tezDagEntities.size() == 0) {
-      return new TezDagId();
-    }
-    JSONObject tezDagEntity = (JSONObject) tezDagEntities.get(0);
-
-    TezDagId parsedDag = new TezDagId();
-    JSONArray applicationIds = (JSONArray) ((JSONObject) tezDagEntity.get("primaryfilters")).get("applicationId");
-    parsedDag.entity = (String) tezDagEntity.get("entity");
-    parsedDag.applicationId = (String) applicationIds.get(0);
-    parsedDag.status = (String) ((JSONObject) tezDagEntity.get("otherinfo")).get("status");
-    return parsedDag;
-  }
-
-  private HiveQueryId parseAtsHiveJob(JSONObject job) {
-    HiveQueryId parsedJob = new HiveQueryId();
-
-    parsedJob.entity = (String) job.get("entity");
-    parsedJob.url = delegate.hiveQueryIdDirectUrl((String) job.get("entity"));
-    parsedJob.starttime = ((Long) job.get("starttime"));
-
-    JSONObject primaryfilters = (JSONObject) job.get("primaryfilters");
-    JSONArray operationIds = (JSONArray) primaryfilters.get("operationid");
-    if (operationIds != null) {
-      parsedJob.operationId = (String) (operationIds).get(0);
-    }
-    JSONArray users = (JSONArray) primaryfilters.get("user");
-    if (users != null) {
-      parsedJob.user = (String) (users).get(0);
-    }
-
-    JSONObject lastEvent = getLastEvent(job);
-    long lastEventTimestamp = ((Long) lastEvent.get("timestamp"));
-
-    parsedJob.duration = (lastEventTimestamp - parsedJob.starttime) / MillisInSecond;
-
-    JSONObject otherinfo = (JSONObject) job.get("otherinfo");
-    if (otherinfo.get("QUERY") != null) {  // workaround for HIVE-10829
-      JSONObject query = (JSONObject) JSONValue.parse((String) otherinfo.get("QUERY"));
-
-      parsedJob.query = (String) query.get("queryText");
-      JSONObject stages = (JSONObject) ((JSONObject) query.get("queryPlan")).get("STAGE PLANS");
-
-      List<String> dagIds = new LinkedList<String>();
-      List<JSONObject> stagesList = new LinkedList<JSONObject>();
-
-      for (Object key : stages.keySet()) {
-        JSONObject stage = (JSONObject) stages.get(key);
-        if (stage.get("Tez") != null) {
-          String dagId = (String) ((JSONObject) stage.get("Tez")).get("DagName:");
-          dagIds.add(dagId);
-        }
-        stagesList.add(stage);
-      }
-      parsedJob.dagNames = dagIds;
-      parsedJob.stages = stagesList;
-    }
-
-    if (otherinfo.get("VERSION") != null) {
-      parsedJob.version = (Long) otherinfo.get("VERSION");
-    }
-    return parsedJob;
-  }
-
-  private TezVertexId parseVertex(JSONObject vertex) {
-    TezVertexId tezVertexId = new TezVertexId();
-    tezVertexId.entity = (String)vertex.get("entity");
-    JSONObject otherinfo = (JSONObject)vertex.get("otherinfo");
-    if (otherinfo != null)
-      tezVertexId.vertexName = (String)otherinfo.get("vertexName");
-    return tezVertexId;
-  }
-
-  private JSONObject getLastEvent(JSONObject atsEntity) {
-    JSONArray events = (JSONArray) atsEntity.get("events");
-    return (JSONObject) events.get(0);
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/atsJobs/ATSParserFactory.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/atsJobs/ATSParserFactory.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/atsJobs/ATSParserFactory.java
deleted file mode 100644
index f035f75..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/atsJobs/ATSParserFactory.java
+++ /dev/null
@@ -1,45 +0,0 @@
-/**
- * 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.ambari.view.hive.resources.jobs.atsJobs;
-
-import org.apache.ambari.view.ViewContext;
-import org.apache.ambari.view.utils.ambari.AmbariApi;
-
-import java.util.HashMap;
-import java.util.Map;
-
-public class ATSParserFactory {
-
-  private ViewContext context;
-  private final AmbariApi ambariApi;
-
-  public ATSParserFactory(ViewContext context) {
-    this.context = context;
-    this.ambariApi = new AmbariApi(context);
-  }
-
-  public ATSParser getATSParser() {
-    ATSRequestsDelegateImpl delegate = new ATSRequestsDelegateImpl(context, getATSUrl());
-    return new ATSParser(delegate);
-  }
-
-  public String getATSUrl() {
-    return ambariApi.getServices().getTimelineServerUrl();
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/atsJobs/ATSRequestsDelegate.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/atsJobs/ATSRequestsDelegate.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/atsJobs/ATSRequestsDelegate.java
deleted file mode 100644
index 6de5773..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/atsJobs/ATSRequestsDelegate.java
+++ /dev/null
@@ -1,47 +0,0 @@
-/**
- * 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.ambari.view.hive.resources.jobs.atsJobs;
-
-import org.json.simple.JSONObject;
-
-public interface ATSRequestsDelegate {
-  String hiveQueryIdDirectUrl(String entity);
-
-  String hiveQueryIdOperationIdUrl(String operationId);
-
-  String tezDagDirectUrl(String entity);
-
-  String tezDagNameUrl(String name);
-
-  String tezVerticesListForDAGUrl(String dagId);
-
-  JSONObject hiveQueryIdsForUser(String username);
-
-  JSONObject hiveQueryIdByOperationId(String operationId);
-
-  JSONObject tezDagByName(String name);
-
-  JSONObject tezVerticesListForDAG(String dagId);
-
-  JSONObject tezDagByEntity(String entity);
-
-  JSONObject hiveQueryIdsForUserByTime(String username, long startTime, long endTime);
-
-  JSONObject hiveQueryEntityByEntityId(String hiveEntityId);
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/atsJobs/ATSRequestsDelegateImpl.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/atsJobs/ATSRequestsDelegateImpl.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/atsJobs/ATSRequestsDelegateImpl.java
deleted file mode 100644
index f52c9da..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/atsJobs/ATSRequestsDelegateImpl.java
+++ /dev/null
@@ -1,175 +0,0 @@
-/**
- * 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.ambari.view.hive.resources.jobs.atsJobs;
-
-import org.apache.ambari.view.ViewContext;
-import org.apache.commons.io.IOUtils;
-import org.json.simple.JSONObject;
-import org.json.simple.JSONValue;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-import java.io.IOException;
-import java.io.InputStream;
-import java.util.HashMap;
-
-public class ATSRequestsDelegateImpl implements ATSRequestsDelegate {
-  protected final static Logger LOG =
-    LoggerFactory.getLogger(ATSRequestsDelegateImpl.class);
-  public static final String EMPTY_ENTITIES_JSON = "{ \"entities\" : [  ] }";
-
-  private ViewContext context;
-  private String atsUrl;
-
-  public ATSRequestsDelegateImpl(ViewContext context, String atsUrl) {
-    this.context = context;
-    this.atsUrl = addProtocolIfMissing(atsUrl);
-  }
-
-  private String addProtocolIfMissing(String atsUrl) {
-    if (!atsUrl.matches("^[^:]+://.*$"))
-      atsUrl = "http://" + atsUrl;
-    return atsUrl;
-  }
-
-  @Override
-  public String hiveQueryIdDirectUrl(String entity) {
-    return atsUrl + "/ws/v1/timeline/HIVE_QUERY_ID/" + entity;
-  }
-
-  @Override
-  public String hiveQueryIdOperationIdUrl(String operationId) {
-    // ATS parses operationId started with digit as integer and not returns the response.
-    // Quotation prevents this.
-    return atsUrl + "/ws/v1/timeline/HIVE_QUERY_ID?primaryFilter=operationid:%22" + operationId + "%22";
-  }
-
-  @Override
-  public String tezDagDirectUrl(String entity) {
-    return atsUrl + "/ws/v1/timeline/TEZ_DAG_ID/" + entity;
-  }
-
-  @Override
-  public String tezDagNameUrl(String name) {
-    return atsUrl + "/ws/v1/timeline/TEZ_DAG_ID?primaryFilter=dagName:" + name;
-  }
-
-  @Override
-  public String tezVerticesListForDAGUrl(String dagId) {
-    return atsUrl + "/ws/v1/timeline/TEZ_VERTEX_ID?primaryFilter=TEZ_DAG_ID:" + dagId;
-  }
-
-  @Override
-  public JSONObject hiveQueryIdsForUser(String username) {
-    String hiveQueriesListUrl = atsUrl + "/ws/v1/timeline/HIVE_QUERY_ID?primaryFilter=requestuser:" + username;
-    String response = readFromWithDefault(hiveQueriesListUrl, "{ \"entities\" : [  ] }");
-    return (JSONObject) JSONValue.parse(response);
-  }
-
-  @Override
-  public JSONObject hiveQueryIdByOperationId(String operationId) {
-    String hiveQueriesListUrl = hiveQueryIdOperationIdUrl(operationId);
-    String response = readFromWithDefault(hiveQueriesListUrl, EMPTY_ENTITIES_JSON);
-    return (JSONObject) JSONValue.parse(response);
-  }
-
-  @Override
-  public JSONObject tezDagByName(String name) {
-    String tezDagUrl = tezDagNameUrl(name);
-    String response = readFromWithDefault(tezDagUrl, EMPTY_ENTITIES_JSON);
-    return (JSONObject) JSONValue.parse(response);
-  }
-
-  @Override
-  public JSONObject tezDagByEntity(String entity) {
-    String tezDagEntityUrl = tezDagEntityUrl(entity);
-    String response = readFromWithDefault(tezDagEntityUrl, EMPTY_ENTITIES_JSON);
-    return (JSONObject) JSONValue.parse(response);
-  }
-
-  /**
-   * fetches the HIVE_QUERY_ID from ATS for given user between given time period
-   * @param username: username for which to fetch hive query IDs
-   * @param startTime: time in miliseconds, inclusive
-   * @param endTime: time in miliseconds, exclusive
-   * @return
-   */
-  @Override
-  public JSONObject hiveQueryIdsForUserByTime(String username, long startTime, long endTime) {
-    StringBuilder url = new StringBuilder();
-    url.append(atsUrl).append("/ws/v1/timeline/HIVE_QUERY_ID?")
-      .append("windowStart=").append(startTime)
-      .append("&windowEnd=").append(endTime)
-      .append("&primaryFilter=requestuser:").append(username);
-    String hiveQueriesListUrl = url.toString();
-
-    String response = readFromWithDefault(hiveQueriesListUrl, EMPTY_ENTITIES_JSON);
-    return (JSONObject) JSONValue.parse(response);
-  }
-
-  @Override
-  public JSONObject hiveQueryEntityByEntityId(String hiveEntityId) {
-    StringBuilder url = new StringBuilder();
-    url.append(atsUrl).append("/ws/v1/timeline/HIVE_QUERY_ID/").append(hiveEntityId);
-    String hiveQueriesListUrl = url.toString();
-    String response = readFromWithDefault(hiveQueriesListUrl, EMPTY_ENTITIES_JSON);
-    return (JSONObject) JSONValue.parse(response);
-  }
-
-  private String tezDagEntityUrl(String entity) {
-    return atsUrl + "/ws/v1/timeline/TEZ_DAG_ID?primaryFilter=callerId:" + entity;
-  }
-
-  public boolean checkATSStatus() throws IOException {
-    String url = atsUrl + "/ws/v1/timeline/";
-    InputStream responseInputStream = context.getURLStreamProvider().readAsCurrent(url, "GET",
-            (String)null, new HashMap<String, String>());
-     IOUtils.toString(responseInputStream);
-    return true;
-  }
-
-  @Override
-  public JSONObject tezVerticesListForDAG(String dagId) {
-    String response = readFromWithDefault(tezVerticesListForDAGUrl(dagId), "{ \"entities\" : [  ] }");
-    return (JSONObject) JSONValue.parse(response);
-  }
-
-
-
-  protected String readFromWithDefault(String atsUrl, String defaultResponse) {
-    String response;
-    try {
-      InputStream responseInputStream = context.getURLStreamProvider().readAsCurrent(atsUrl, "GET",
-          (String)null, new HashMap<String, String>());
-      response = IOUtils.toString(responseInputStream);
-    } catch (IOException e) {
-      LOG.error("Error while reading from ATS", e);
-      response = defaultResponse;
-    }
-    return response;
-  }
-
-  public String getAtsUrl() {
-    return atsUrl;
-  }
-
-  public void setAtsUrl(String atsUrl) {
-    this.atsUrl = atsUrl;
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/atsJobs/HiveQueryId.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/atsJobs/HiveQueryId.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/atsJobs/HiveQueryId.java
deleted file mode 100644
index bb81fef..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/atsJobs/HiveQueryId.java
+++ /dev/null
@@ -1,42 +0,0 @@
-/**
- * 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.ambari.view.hive.resources.jobs.atsJobs;
-
-import org.json.simple.JSONObject;
-
-import java.util.List;
-
-public class HiveQueryId {
-  public static long ATS_15_RESPONSE_VERSION = 2; // version returned from ATS 1.5 release
-
-  public String url;
-
-  public String entity;
-  public String query;
-
-  public List<String> dagNames;
-
-  public List<JSONObject> stages;
-
-  public long starttime;
-  public long duration;
-  public String operationId;
-  public String user;
-  public long version;
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/atsJobs/IATSParser.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/atsJobs/IATSParser.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/atsJobs/IATSParser.java
deleted file mode 100644
index 547dfec..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/atsJobs/IATSParser.java
+++ /dev/null
@@ -1,39 +0,0 @@
-/**
- * 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.ambari.view.hive.resources.jobs.atsJobs;
-
-import java.util.List;
-
-public interface IATSParser {
-  List<HiveQueryId> getHiveQueryIdsForUser(String username);
-
-  List<TezVertexId> getVerticesForDAGId(String dagId);
-
-  HiveQueryId getHiveQueryIdByOperationId(String guidString);
-
-  TezDagId getTezDAGByName(String name);
-
-  TezDagId getTezDAGByEntity(String entity);
-
-  List<HiveQueryId> getHiveQueryIdsForUserByTime(String username, long startTime, long endTime);
-
-  HiveQueryId getHiveQueryIdByHiveEntityId(String hiveEntityId);
-
-  List<HiveQueryId> getHiveQueryIdByEntityList(List<String> hiveEntityIds);
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/atsJobs/TezDagId.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/atsJobs/TezDagId.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/atsJobs/TezDagId.java
deleted file mode 100644
index a814286..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/atsJobs/TezDagId.java
+++ /dev/null
@@ -1,26 +0,0 @@
-/**
- * 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.ambari.view.hive.resources.jobs.atsJobs;
-
-public class TezDagId {
-  public static final String STATUS_UNKNOWN = "UNKNOWN";
-  public String applicationId = "";
-  public String entity = "";
-  public String status = STATUS_UNKNOWN;
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/atsJobs/TezVertexId.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/atsJobs/TezVertexId.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/atsJobs/TezVertexId.java
deleted file mode 100644
index 34dd996..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/atsJobs/TezVertexId.java
+++ /dev/null
@@ -1,24 +0,0 @@
-/**
- * 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.ambari.view.hive.resources.jobs.atsJobs;
-
-public class TezVertexId {
-  public String entity;
-  public String vertexName;
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/rm/RMParser.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/rm/RMParser.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/rm/RMParser.java
deleted file mode 100644
index b39be44..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/rm/RMParser.java
+++ /dev/null
@@ -1,129 +0,0 @@
-/**
- * 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.ambari.view.hive.resources.jobs.rm;
-
-import org.apache.ambari.view.hive.resources.jobs.atsJobs.TezVertexId;
-import org.json.simple.JSONArray;
-import org.json.simple.JSONObject;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-import java.util.HashMap;
-import java.util.LinkedList;
-import java.util.List;
-import java.util.Map;
-
-/**
- * Parser of Resource Manager responses
- */
-public class RMParser {
-  protected final static Logger LOG =
-      LoggerFactory.getLogger(RMParser.class);
-  private RMRequestsDelegate delegate;
-
-  public RMParser(RMRequestsDelegate delegate) {
-    this.delegate = delegate;
-  }
-
-  /**
-   * Progress of DAG
-   * @param appId App Id
-   * @param dagId DAG Id
-   * @return progress of DAG
-   */
-  public Double getDAGProgress(String appId, String dagId) {
-    String dagIdx = parseDagIdIndex(dagId);
-    JSONObject progresses = delegate.dagProgress(appId, dagIdx);
-
-    double dagProgressValue;
-    if (progresses != null) {
-      JSONObject dagProgress = (JSONObject) progresses.get("dagProgress");
-      dagProgressValue = (Double) (dagProgress.get("progress"));
-    } else {
-      LOG.error("Error while retrieving progress of " + appId + ":" + dagId + ". 0 assumed.");
-      dagProgressValue = 0;
-    }
-    return dagProgressValue;
-  }
-
-  /**
-   * Progress of vertices
-   * @param appId App Id
-   * @param dagId DAG Id
-   * @param vertices vertices list
-   * @return list of vertices
-   */
-  public List<VertexProgress> getDAGVerticesProgress(String appId, String dagId, List<TezVertexId> vertices) {
-    String dagIdx = parseDagIdIndex(dagId);
-
-    Map<String, String> vertexIdToEntityMapping = new HashMap<String, String>();
-    StringBuilder builder = new StringBuilder();
-    if (vertices.size() > 0) {
-      for (TezVertexId vertexId : vertices) {
-        String[] parts = vertexId.entity.split("_");
-        String vertexIdx = parts[parts.length - 1];
-        builder.append(vertexIdx).append(",");
-
-        vertexIdToEntityMapping.put(vertexId.entity, vertexId.vertexName);
-      }
-      builder.setLength(builder.length() - 1); // remove last comma
-    }
-
-    String commaSeparatedVertices = builder.toString();
-
-    List<VertexProgress> parsedVertexProgresses = new LinkedList<VertexProgress>();
-    JSONObject vertexProgressesResponse = delegate.verticesProgress(
-        appId, dagIdx, commaSeparatedVertices);
-    if (vertexProgressesResponse == null) {
-      LOG.error("Error while retrieving progress of vertices " +
-          appId + ":" + dagId + ":" + commaSeparatedVertices + ". 0 assumed for all vertices.");
-      for (TezVertexId vertexId : vertices) {
-        VertexProgress vertexProgressInfo = new VertexProgress();
-        vertexProgressInfo.name = vertexId.vertexName;
-        vertexProgressInfo.progress = 0.0;
-        parsedVertexProgresses.add(vertexProgressInfo);
-      }
-      return parsedVertexProgresses;
-    }
-    JSONArray vertexProgresses = (JSONArray) vertexProgressesResponse.get("vertexProgresses");
-
-    for (Object vertex : vertexProgresses) {
-      JSONObject jsonObject = (JSONObject) vertex;
-
-      VertexProgress vertexProgressInfo = new VertexProgress();
-      vertexProgressInfo.id = (String) jsonObject.get("id");
-      vertexProgressInfo.name = vertexIdToEntityMapping.get(vertexProgressInfo.id);
-      vertexProgressInfo.progress = (Double) jsonObject.get("progress");
-
-      parsedVertexProgresses.add(vertexProgressInfo);
-    }
-    return parsedVertexProgresses;
-  }
-
-  public String parseDagIdIndex(String dagId) {
-    String[] dagIdParts = dagId.split("_");
-    return dagIdParts[dagIdParts.length - 1];
-  }
-
-  public static class VertexProgress {
-    public String id;
-    public String name;
-    public Double progress;
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/rm/RMParserFactory.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/rm/RMParserFactory.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/rm/RMParserFactory.java
deleted file mode 100644
index 260b464..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/rm/RMParserFactory.java
+++ /dev/null
@@ -1,49 +0,0 @@
-/**
- * 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.ambari.view.hive.resources.jobs.rm;
-
-import org.apache.ambari.view.ViewContext;
-import org.apache.ambari.view.hive.utils.ServiceFormattedException;
-import org.apache.ambari.view.utils.ambari.AmbariApi;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-public class RMParserFactory {
-  protected final static Logger LOG =
-      LoggerFactory.getLogger(RMParserFactory.class);
-
-  private final ViewContext context;
-  private final AmbariApi ambariApi;
-
-  public RMParserFactory(ViewContext context) {
-    this.context = context;
-    this.ambariApi = new AmbariApi(context);
-  }
-
-  public RMParser getRMParser() {
-    String rmUrl = getRMUrl();
-
-    RMRequestsDelegate delegate = new RMRequestsDelegateImpl(context, rmUrl);
-    return new RMParser(delegate);
-  }
-
-  public String getRMUrl() {
-    return ambariApi.getServices().getRMUrl();
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/rm/RMRequestsDelegate.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/rm/RMRequestsDelegate.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/rm/RMRequestsDelegate.java
deleted file mode 100644
index 6114b34..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/rm/RMRequestsDelegate.java
+++ /dev/null
@@ -1,31 +0,0 @@
-/**
- * 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.ambari.view.hive.resources.jobs.rm;
-
-import org.json.simple.JSONObject;
-
-public interface RMRequestsDelegate {
-  String dagProgressUrl(String appId, String dagIdx);
-
-  String verticesProgressUrl(String appId, String dagIdx, String vertices);
-
-  JSONObject dagProgress(String appId, String dagIdx);
-
-  JSONObject verticesProgress(String appId, String dagIdx, String commaSeparatedVertices);
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/rm/RMRequestsDelegateImpl.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/rm/RMRequestsDelegateImpl.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/rm/RMRequestsDelegateImpl.java
deleted file mode 100644
index 087ef68..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/rm/RMRequestsDelegateImpl.java
+++ /dev/null
@@ -1,100 +0,0 @@
-/**
- * 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.ambari.view.hive.resources.jobs.rm;
-
-import org.apache.ambari.view.ViewContext;
-import org.apache.ambari.view.hive.utils.ServiceFormattedException;
-import org.apache.ambari.view.utils.ambari.AmbariApi;
-import org.apache.commons.io.IOUtils;
-import org.json.simple.JSONObject;
-import org.json.simple.JSONValue;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-import java.io.IOException;
-import java.io.InputStream;
-import java.util.HashMap;
-
-public class RMRequestsDelegateImpl implements RMRequestsDelegate {
-  protected final static Logger LOG =
-      LoggerFactory.getLogger(RMRequestsDelegateImpl.class);
-  public static final String EMPTY_ENTITIES_JSON = "{ \"entities\" : [  ] }";
-
-  private ViewContext context;
-  private String rmUrl;
-
-  public RMRequestsDelegateImpl(ViewContext context, String rmUrl) {
-    this.context = context;
-    this.rmUrl = rmUrl;
-  }
-
-  @Override
-  public String dagProgressUrl(String appId, String dagIdx) {
-    return rmUrl + String.format("/proxy/%s/ws/v1/tez/dagProgress?dagID=%s", appId, dagIdx);
-  }
-
-  @Override
-  public String verticesProgressUrl(String appId, String dagIdx, String vertices) {
-    return rmUrl + String.format("/proxy/%s/ws/v1/tez/vertexProgresses?dagID=%s&vertexID=%s", appId, dagIdx, vertices);
-  }
-
-  @Override
-  public JSONObject dagProgress(String appId, String dagIdx) {
-    String url = dagProgressUrl(appId, dagIdx);
-    String response;
-    try {
-      InputStream responseInputStream = context.getURLStreamProvider().readFrom(url, "GET",
-          (String)null, new HashMap<String, String>());
-      response = IOUtils.toString(responseInputStream);
-    } catch (IOException e) {
-      throw new ServiceFormattedException(
-          String.format("R010 DAG %s in app %s not found or ResourceManager is unreachable", dagIdx, appId));
-    }
-    return (JSONObject) JSONValue.parse(response);
-  }
-
-  @Override
-  public JSONObject verticesProgress(String appId, String dagIdx, String commaSeparatedVertices) {
-    String url = verticesProgressUrl(appId, dagIdx, commaSeparatedVertices);
-    String response;
-    try {
-      InputStream responseInputStream = context.getURLStreamProvider().readFrom(url, "GET",
-          (String)null, new HashMap<String, String>());
-      response = IOUtils.toString(responseInputStream);
-    } catch (IOException e) {
-      throw new ServiceFormattedException(
-          String.format("R020 DAG %s in app %s not found or ResourceManager is unreachable", dagIdx, appId));
-    }
-    return (JSONObject) JSONValue.parse(response);
-  }
-
-  protected String readFromWithDefault(String url, String defaultResponse) {
-    String response;
-    try {
-      InputStream responseInputStream = context.getURLStreamProvider().readFrom(url, "GET",
-          (String)null, new HashMap<String, String>());
-      response = IOUtils.toString(responseInputStream);
-    } catch (IOException e) {
-      LOG.error("Error while reading from RM", e);
-      response = defaultResponse;
-    }
-    return response;
-  }
-
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/viewJobs/IJobControllerFactory.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/viewJobs/IJobControllerFactory.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/viewJobs/IJobControllerFactory.java
deleted file mode 100644
index 89fbb85..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/viewJobs/IJobControllerFactory.java
+++ /dev/null
@@ -1,23 +0,0 @@
-/**
- * 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.ambari.view.hive.resources.jobs.viewJobs;
-
-public interface IJobControllerFactory {
-  JobController createControllerForJob(Job job);
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/viewJobs/Job.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/viewJobs/Job.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/viewJobs/Job.java
deleted file mode 100644
index 98d6589..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/viewJobs/Job.java
+++ /dev/null
@@ -1,130 +0,0 @@
-/**
- * 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.ambari.view.hive.resources.jobs.viewJobs;
-
-
-import org.apache.ambari.view.hive.persistence.utils.Indexed;
-import org.apache.ambari.view.hive.persistence.utils.PersonalResource;
-
-import java.beans.Transient;
-import java.io.Serializable;
-
-/**
- * Interface for Job bean to create Proxy for it
- */
-public interface Job extends Serializable,Indexed,PersonalResource {
-  String JOB_STATE_UNKNOWN = "Unknown";
-  String JOB_STATE_INITIALIZED = "Initialized";
-  String JOB_STATE_RUNNING = "Running";
-  String JOB_STATE_FINISHED = "Succeeded";
-  String JOB_STATE_CANCELED = "Canceled";
-  String JOB_STATE_CLOSED = "Closed";
-  String JOB_STATE_ERROR = "Error";
-  String JOB_STATE_PENDING = "Pending";
-
-  @Transient
-  String getHiveQueryId();
-
-  @Transient
-  void setHiveQueryId(String hiveQueryId);
-
-  String getId();
-
-  void setId(String id);
-
-  String getOwner();
-
-  void setOwner(String owner);
-
-  String getTitle();
-
-  void setTitle(String title);
-
-  String getQueryFile();
-
-  void setQueryFile(String queryFile);
-
-  Long getDateSubmitted();
-
-  void setDateSubmitted(Long dateSubmitted);
-
-  Long getDuration();
-
-  void setDuration(Long duration);
-
-  String getStatus();
-
-  void setStatus(String status);
-
-  String getForcedContent();
-
-  void setForcedContent(String forcedContent);
-
-  String getQueryId();
-
-  void setQueryId(String queryId);
-
-  String getStatusDir();
-
-  void setStatusDir(String statusDir);
-
-  String getDataBase();
-
-  void setDataBase(String dataBase);
-
-  String getLogFile();
-
-  void setLogFile(String logFile);
-
-  String getConfFile();
-
-  void setConfFile(String confFile);
-
-  String getApplicationId();
-
-  void setApplicationId(String applicationId);
-
-  String getDagName();
-
-  void setDagName(String dagName);
-
-  String getDagId();
-
-  void setDagId(String dagId);
-
-  String getSessionTag();
-
-  void setSessionTag(String sessionTag);
-
-  String getSqlState();
-
-  void setSqlState(String sqlState);
-
-  String getStatusMessage();
-
-  void setStatusMessage(String message);
-
-  String getReferrer();
-
-  void setReferrer(String referrer);
-
-  String getGlobalSettings();
-
-  void setGlobalSettings(String globalSettings);
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/viewJobs/JobController.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/viewJobs/JobController.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/viewJobs/JobController.java
deleted file mode 100644
index 3922839..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/viewJobs/JobController.java
+++ /dev/null
@@ -1,53 +0,0 @@
-/**
- * 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.ambari.view.hive.resources.jobs.viewJobs;
-
-import org.apache.ambari.view.hive.client.Cursor;
-import org.apache.ambari.view.hive.client.HiveClientException;
-import org.apache.ambari.view.hive.persistence.utils.ItemNotFound;
-import org.apache.ambari.view.hive.resources.jobs.NoOperationStatusSetException;
-import org.apache.ambari.view.hive.resources.jobs.OperationHandleController;
-
-public interface JobController {
-
-  OperationHandleController.OperationStatus getStatus() throws ItemNotFound, HiveClientException, NoOperationStatusSetException;
-
-  void submit();
-
-  void cancel() throws ItemNotFound;
-
-  Job getJob();
-
-  /**
-   * Use carefully. Returns unproxied bean object
-   * @return unproxied bean object
-   */
-  Job getJobPOJO();
-
-  Cursor getResults() throws ItemNotFound;
-  boolean hasResults() throws ItemNotFound;
-
-  void afterCreation();
-
-  void update();
-
-  boolean isModified();
-
-  void clearModified();
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/viewJobs/JobControllerFactory.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/viewJobs/JobControllerFactory.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/viewJobs/JobControllerFactory.java
deleted file mode 100644
index a2790d1..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/viewJobs/JobControllerFactory.java
+++ /dev/null
@@ -1,41 +0,0 @@
-/**
- * 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.ambari.view.hive.resources.jobs.viewJobs;
-
-import org.apache.ambari.view.ViewContext;
-import org.apache.ambari.view.hive.utils.SharedObjectsFactory;
-
-public class JobControllerFactory implements IJobControllerFactory {
-  private SharedObjectsFactory sharedObjectsFactory;
-  private ViewContext context;
-
-  public JobControllerFactory(ViewContext context, SharedObjectsFactory sharedObjectsFactory) {
-    this.sharedObjectsFactory = sharedObjectsFactory;
-    this.context = context;
-  }
-
-  @Override
-  public JobController createControllerForJob(Job job) {
-    return new JobControllerImpl(context, job,
-        sharedObjectsFactory.getOperationHandleControllerFactory(),
-        sharedObjectsFactory.getSavedQueryResourceManager(),
-        sharedObjectsFactory.getATSParser(),
-        sharedObjectsFactory.getHdfsApi());
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/viewJobs/JobControllerImpl.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/viewJobs/JobControllerImpl.java b/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/viewJobs/JobControllerImpl.java
deleted file mode 100644
index a408619..0000000
--- a/contrib/views/hive/src/main/java/org/apache/ambari/view/hive/resources/jobs/viewJobs/JobControllerImpl.java
+++ /dev/null
@@ -1,401 +0,0 @@
-/**
- * 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.ambari.view.hive.resources.jobs.viewJobs;
-
-import org.apache.ambari.view.ViewContext;
-import org.apache.ambari.view.hive.client.Cursor;
-import org.apache.ambari.view.hive.client.HiveClientException;
-import org.apache.ambari.view.hive.client.HiveClientRuntimeException;
-import org.apache.ambari.view.hive.client.HiveErrorStatusException;
-import org.apache.ambari.view.hive.client.UserLocalConnection;
-import org.apache.ambari.view.hive.persistence.utils.ItemNotFound;
-import org.apache.ambari.view.hive.resources.jobs.ConnectionController;
-import org.apache.ambari.view.hive.resources.jobs.LogParser;
-import org.apache.ambari.view.hive.resources.jobs.ModifyNotificationDelegate;
-import org.apache.ambari.view.hive.resources.jobs.ModifyNotificationInvocationHandler;
-import org.apache.ambari.view.hive.resources.jobs.NoOperationStatusSetException;
-import org.apache.ambari.view.hive.resources.jobs.OperationHandleController;
-import org.apache.ambari.view.hive.resources.jobs.OperationHandleControllerFactory;
-import org.apache.ambari.view.hive.resources.jobs.atsJobs.IATSParser;
-import org.apache.ambari.view.hive.resources.savedQueries.SavedQuery;
-import org.apache.ambari.view.hive.resources.savedQueries.SavedQueryResourceManager;
-import org.apache.ambari.view.hive.utils.BadRequestFormattedException;
-import org.apache.ambari.view.hive.utils.FilePaginator;
-import org.apache.ambari.view.hive.utils.HiveClientFormattedException;
-import org.apache.ambari.view.hive.utils.MisconfigurationFormattedException;
-import org.apache.ambari.view.hive.utils.ServiceFormattedException;
-import org.apache.ambari.view.utils.hdfs.HdfsApi;
-import org.apache.ambari.view.utils.hdfs.HdfsApiException;
-import org.apache.ambari.view.utils.hdfs.HdfsUtil;
-import org.apache.hive.service.cli.thrift.TSessionHandle;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-import java.io.IOException;
-import java.lang.reflect.Proxy;
-import java.text.SimpleDateFormat;
-import java.util.Date;
-
-public class JobControllerImpl implements JobController, ModifyNotificationDelegate {
-  private final static Logger LOG =
-      LoggerFactory.getLogger(JobControllerImpl.class);
-
-  private ViewContext context;
-  private HdfsApi hdfsApi;
-  private Job jobUnproxied;
-  private Job job;
-  private boolean modified;
-
-  private OperationHandleControllerFactory opHandleControllerFactory;
-  private ConnectionController hiveConnection;
-  private SavedQueryResourceManager savedQueryResourceManager;
-  private IATSParser atsParser;
-
-  /**
-   * JobController constructor
-   * Warning: Create JobControllers ONLY using JobControllerFactory!
-   */
-  public JobControllerImpl(ViewContext context, Job job,
-                           OperationHandleControllerFactory opHandleControllerFactory,
-                           SavedQueryResourceManager savedQueryResourceManager,
-                           IATSParser atsParser,
-                           HdfsApi hdfsApi) {
-    this.context = context;
-    setJobPOJO(job);
-    this.opHandleControllerFactory = opHandleControllerFactory;
-    this.savedQueryResourceManager = savedQueryResourceManager;
-    this.atsParser = atsParser;
-    this.hdfsApi = hdfsApi;
-
-    UserLocalConnection connectionLocal = new UserLocalConnection();
-    this.hiveConnection = new ConnectionController(opHandleControllerFactory, connectionLocal.get(context));
-  }
-
-  public String getQueryForJob() {
-    FilePaginator paginator = new FilePaginator(job.getQueryFile(), hdfsApi);
-    String query;
-    try {
-      query = paginator.readPage(0);  //warning - reading only 0 page restricts size of query to 1MB
-    } catch (IOException e) {
-      throw new ServiceFormattedException("F030 Error when reading file " + job.getQueryFile(), e);
-    } catch (InterruptedException e) {
-      throw new ServiceFormattedException("F030 Error when reading file " + job.getQueryFile(), e);
-    }
-    return query;
-  }
-
-  private static final String DEFAULT_DB = "default";
-  public String getJobDatabase() {
-    if (job.getDataBase() != null) {
-      return job.getDataBase();
-    } else {
-      return DEFAULT_DB;
-    }
-  }
-
-  @Override
-  public OperationHandleController.OperationStatus getStatus() throws ItemNotFound, HiveClientException, NoOperationStatusSetException {
-    OperationHandleController handle = opHandleControllerFactory.getHandleForJob(job);
-    return handle.getOperationStatus();
-  }
-
-  @Override
-  public void submit() {
-    setupHiveBeforeQueryExecute();
-
-    String query = getQueryForJob();
-    OperationHandleController handleController = hiveConnection.executeQuery(getSession(), query);
-
-    handleController.persistHandleForJob(job);
-  }
-
-  private void setupHiveBeforeQueryExecute() {
-    String database = getJobDatabase();
-    hiveConnection.selectDatabase(getSession(), database);
-  }
-
-  private TSessionHandle getSession() {
-    try {
-      if (job.getSessionTag() != null) {
-        return hiveConnection.getSessionByTag(getJob().getSessionTag());
-      }
-    } catch (HiveClientException ignore) {
-      LOG.debug("Stale sessionTag was provided, new session will be opened");
-    }
-
-    String tag = hiveConnection.openSession();
-    job.setSessionTag(tag);
-    try {
-      return hiveConnection.getSessionByTag(tag);
-    } catch (HiveClientException e) {
-      throw new HiveClientFormattedException(e);
-    }
-  }
-
-  @Override
-  public void cancel() throws ItemNotFound {
-    OperationHandleController handle = opHandleControllerFactory.getHandleForJob(job);
-    handle.cancel();
-  }
-
-  @Override
-  public void update() {
-    updateOperationStatus();
-    updateOperationLogs();
-
-    updateJobDuration();
-  }
-
-  public void updateOperationStatus() {
-    try {
-
-      OperationHandleController handle = opHandleControllerFactory.getHandleForJob(job);
-      OperationHandleController.OperationStatus status = handle.getOperationStatus();
-      job.setStatus(status.status);
-      job.setStatusMessage(status.message);
-      job.setSqlState(status.sqlState);
-      LOG.debug("Status of job#" + job.getId() + " is " + job.getStatus());
-
-    } catch (NoOperationStatusSetException e) {
-      LOG.info("Operation state is not set for job#" + job.getId());
-
-    } catch (HiveErrorStatusException e) {
-      LOG.debug("Error updating status for job#" + job.getId() + ": " + e.getMessage());
-      job.setStatus(Job.JOB_STATE_UNKNOWN);
-
-    } catch (HiveClientException e) {
-      throw new HiveClientFormattedException(e);
-
-    } catch (ItemNotFound itemNotFound) {
-      LOG.debug("No TOperationHandle for job#" + job.getId() + ", can't update status");
-    }
-  }
-
-  public void updateOperationLogs() {
-    try {
-      OperationHandleController handle = opHandleControllerFactory.getHandleForJob(job);
-      String logs = handle.getLogs();
-
-      LogParser info = LogParser.parseLog(logs);
-      LogParser.AppId app = info.getLastAppInList();
-      if (app != null) {
-        job.setApplicationId(app.getIdentifier());
-      }
-
-      String logFilePath = job.getLogFile();
-      HdfsUtil.putStringToFile(hdfsApi, logFilePath, logs);
-
-    } catch (HiveClientRuntimeException ex) {
-      LOG.error("Error while fetching logs: " + ex.getMessage());
-    } catch (ItemNotFound itemNotFound) {
-      LOG.debug("No TOperationHandle for job#" + job.getId() + ", can't read logs");
-    } catch (HdfsApiException e) {
-      throw new ServiceFormattedException(e);
-    }
-  }
-
-  public boolean isJobEnded() {
-    String status = job.getStatus();
-    return status.equals(Job.JOB_STATE_FINISHED) || status.equals(Job.JOB_STATE_CANCELED) ||
-        status.equals(Job.JOB_STATE_CLOSED) || status.equals(Job.JOB_STATE_ERROR) ||
-        status.equals(Job.JOB_STATE_UNKNOWN); // Unknown is not finished, but polling makes no sense
-  }
-
-  @Override
-  public Job getJob() {
-    return job;
-  }
-
-  /**
-   * Use carefully. Returns unproxied bean object
-   * @return unproxied bean object
-   */
-  @Override
-  public Job getJobPOJO() {
-    return jobUnproxied;
-  }
-
-  public void setJobPOJO(Job jobPOJO) {
-    Job jobModifyNotificationProxy = (Job) Proxy.newProxyInstance(jobPOJO.getClass().getClassLoader(),
-        new Class[]{Job.class},
-        new ModifyNotificationInvocationHandler(jobPOJO, this));
-    this.job = jobModifyNotificationProxy;
-
-    this.jobUnproxied = jobPOJO;
-  }
-
-  @Override
-  public Cursor getResults() throws ItemNotFound {
-    OperationHandleController handle = opHandleControllerFactory.getHandleForJob(job);
-    return handle.getResults();
-  }
-
-  @Override
-  public boolean hasResults() throws ItemNotFound {
-    OperationHandleController handle = opHandleControllerFactory.getHandleForJob(job);
-    return handle.hasResults();
-  }
-
-  @Override
-  public void afterCreation() {
-    setupStatusDirIfNotPresent();
-    setupQueryFileIfNotPresent();
-    setupLogFileIfNotPresent();
-
-    setCreationDate();
-  }
-
-  public void setupLogFileIfNotPresent() {
-    if (job.getLogFile() == null || job.getLogFile().isEmpty()) {
-      setupLogFile();
-    }
-  }
-
-  public void setupQueryFileIfNotPresent() {
-    if (job.getQueryFile() == null || job.getQueryFile().isEmpty()) {
-      setupQueryFile();
-    }
-  }
-
-  public void setupStatusDirIfNotPresent() {
-    if (job.getStatusDir() == null || job.getStatusDir().isEmpty()) {
-      setupStatusDir();
-    }
-  }
-
-  private static final long MillisInSecond = 1000L;
-
-  public void updateJobDuration() {
-    job.setDuration((System.currentTimeMillis() / MillisInSecond) - (job.getDateSubmitted() / MillisInSecond));
-  }
-
-  public void setCreationDate() {
-    job.setDateSubmitted(System.currentTimeMillis());
-  }
-
-  private void setupLogFile() {
-    LOG.debug("Creating log file for job#" + job.getId());
-
-    String logFile = job.getStatusDir() + "/" + "logs";
-    try {
-      HdfsUtil.putStringToFile(hdfsApi, logFile, "");
-    } catch (HdfsApiException e) {
-      throw new ServiceFormattedException(e);
-    }
-
-    job.setLogFile(logFile);
-    LOG.debug("Log file for job#" + job.getId() + ": " + logFile);
-  }
-
-  private void setupStatusDir() {
-    String newDirPrefix = makeStatusDirectoryPrefix();
-    String newDir = null;
-    try {
-      newDir = HdfsUtil.findUnallocatedFileName(hdfsApi, newDirPrefix, "");
-    } catch (HdfsApiException e) {
-      throw new ServiceFormattedException(e);
-    }
-
-    job.setStatusDir(newDir);
-    LOG.debug("Status dir for job#" + job.getId() + ": " + newDir);
-  }
-
-  private String makeStatusDirectoryPrefix() {
-    String userScriptsPath = context.getProperties().get("jobs.dir");
-
-    if (userScriptsPath == null) { // TODO: move check to initialization code
-      String msg = "jobs.dir is not configured!";
-      LOG.error(msg);
-      throw new MisconfigurationFormattedException("jobs.dir");
-    }
-
-    String normalizedName = String.format("hive-job-%s", job.getId());
-    String timestamp = new SimpleDateFormat("yyyy-MM-dd_hh-mm").format(new Date());
-    return String.format(userScriptsPath +
-        "/%s-%s", normalizedName, timestamp);
-  }
-
-  private void setupQueryFile() {
-    String statusDir = job.getStatusDir();
-    assert statusDir != null : "setupStatusDir() should be called first";
-
-    String jobQueryFilePath = statusDir + "/" + "query.hql";
-
-    try {
-
-      if (job.getForcedContent() != null) {
-
-        HdfsUtil.putStringToFile(hdfsApi, jobQueryFilePath, job.getForcedContent());
-        job.setForcedContent("");  // prevent forcedContent to be written to DB
-
-      }
-      else if (job.getQueryId() != null) {
-
-        String savedQueryFile = getRelatedSavedQueryFile();
-        hdfsApi.copy(savedQueryFile, jobQueryFilePath);
-        job.setQueryFile(jobQueryFilePath);
-
-      } else {
-
-        throw new BadRequestFormattedException("queryId or forcedContent should be passed!", null);
-
-      }
-
-    } catch (IOException e) {
-      throw new ServiceFormattedException("F040 Error when creating file " + jobQueryFilePath, e);
-    } catch (InterruptedException e) {
-      throw new ServiceFormattedException("F040 Error when creating file " + jobQueryFilePath, e);
-    } catch (HdfsApiException e) {
-      throw new ServiceFormattedException(e);
-    }
-    job.setQueryFile(jobQueryFilePath);
-
-    LOG.debug("Query file for job#" + job.getId() + ": " + jobQueryFilePath);
-  }
-
-  private String getRelatedSavedQueryFile() {
-    SavedQuery savedQuery;
-    try {
-      savedQuery = savedQueryResourceManager.read(job.getQueryId());
-    } catch (ItemNotFound itemNotFound) {
-      throw new BadRequestFormattedException("queryId not found!", itemNotFound);
-    }
-    return savedQuery.getQueryFile();
-  }
-
-  @Override
-  public boolean onModification(Object object) {
-    setModified(true);
-    return true;
-  }
-
-  @Override
-  public boolean isModified() {
-    return modified;
-  }
-
-  public void setModified(boolean modified) {
-    this.modified = modified;
-  }
-
-  @Override
-  public void clearModified() {
-    setModified(false);
-  }
-}


[15/23] ambari git commit: AMBARI-19302 : removed contrib/views/hive folder and made necessary changes in pom.xml files (nitirajrathore)

Posted by ni...@apache.org.
http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/components/input-header.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/components/input-header.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/components/input-header.js
deleted file mode 100644
index 7ff5bf7..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/components/input-header.js
+++ /dev/null
@@ -1,61 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-
-export default Ember.Component.extend({
-  tagName: '',
-  dataTypes: null,
-  column: null,
-  precisionChanged: Ember.observer('column.precision', function () {
-    var col = this.get('column');
-    if( typeof col.precision !== 'number') {
-        Ember.set(col, 'precision', Number(col.precision));
-      }
-  }),
-
-  scaleChanged: Ember.observer('column.scale', function () {
-    var col = this.get('column');
-    if( typeof col.scale !== 'number'){
-      Ember.set(col,'scale',Number(col.scale));
-    }
-  }),
-
-  typeChanged: Ember.observer('column.type', function () {
-    var col = this.get('column');
-
-    var type = col.type;
-    if( type != "DECIMAL" ){
-      Ember.set(col,'scale');
-    }
-
-    if(type != "VARCHAR" && type != "CHAR" && type != "DECIMAL" ){
-      Ember.set(col,'precision');
-    }
-  }),
-
-  noPrecision: Ember.computed('column.type', function () {
-    var type = this.get('column').type;
-    return (type == "VARCHAR" || type == "CHAR" || type == "DECIMAL" ) ? false : true;
-  }),
-
-  noScale: Ember.computed('column.type', function () {
-    return this.get('column').type == "DECIMAL" ? false : true;
-  })
-
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/components/job-tr-view.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/components/job-tr-view.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/components/job-tr-view.js
deleted file mode 100644
index f439ca2..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/components/job-tr-view.js
+++ /dev/null
@@ -1,41 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-import constants from 'hive/utils/constants';
-import utils from 'hive/utils/functions';
-
-export default Ember.Component.extend({
-  tagName: '',
-
-  canStop: function () {
-    return utils.insensitiveCompare(this.get('job.status'), constants.statuses.running, constants.statuses.initialized, constants.statuses.pending);
-  }.property('job.status'),
-
-  actions: {
-    requestFile: function () {
-      this.toggleProperty('expanded');
-
-      this.sendAction('onFileRequested', this.get('job'));
-    },
-
-    stopJob: function () {
-      this.sendAction('onStopJob', this.get('job'));
-    }
-  }
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/components/modal-widget.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/components/modal-widget.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/components/modal-widget.js
deleted file mode 100644
index ce25bf1..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/components/modal-widget.js
+++ /dev/null
@@ -1,58 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-
-export default Ember.Component.extend(Ember.I18n.TranslateableProperties, {
-  show: function () {
-    var self = this;
-
-    this.$('.modal').modal().on('hidden.bs.modal', function () {
-      self.sendAction('close');
-    });
-  }.on('didInsertElement'),
-
-  keyPress: function (e) {
-    Ember.run.debounce(this, function () {
-      if (e.which === 13) {
-        this.send('ok');
-      } else if (e.which === 27) {
-        this.send('close');
-      }
-    }, 200);
-  },
-
-  setupEvents: function () {
-    this.$(document).on('keyup', Ember.$.proxy(this.keyPress, this));
-  }.on('didInsertElement'),
-
-  destroyEvents: function () {
-    this.$(document).off('keyup', Ember.$.proxy(this.keyPress, this));
-  }.on('willDestroyElement'),
-
-  actions: {
-    ok: function () {
-      this.$('.modal').modal('hide');
-      this.sendAction('ok');
-    },
-    close: function () {
-      this.$('.modal').modal('hide');
-      this.sendAction('close');
-    }
-  }
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/components/navbar-widget.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/components/navbar-widget.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/components/navbar-widget.js
deleted file mode 100644
index 11333d0..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/components/navbar-widget.js
+++ /dev/null
@@ -1,42 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-import constants from 'hive/utils/constants';
-
-export default Ember.Component.extend({
-  tagName: 'navigation-bar',
-  title: constants.appTitle,
-
-  items: Ember.A([
-    Ember.Object.create({text: 'menus.query',
-                         path: constants.namingConventions.routes.index}),
-
-    Ember.Object.create({text: 'menus.savedQueries',
-                         path: constants.namingConventions.routes.queries}),
-
-    Ember.Object.create({text: 'menus.history',
-                         path: constants.namingConventions.routes.history}),
-
-    Ember.Object.create({text: 'menus.udfs',
-                         path: constants.namingConventions.routes.udfs}),
-
-    Ember.Object.create({text: 'menus.uploadTable',
-      path: constants.namingConventions.routes.uploadTable})
-  ])
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/components/no-bubbling.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/components/no-bubbling.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/components/no-bubbling.js
deleted file mode 100644
index 4b723b1..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/components/no-bubbling.js
+++ /dev/null
@@ -1,31 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-
-export default Ember.Component.extend({
-  didInsertElement: function () {
-    var self = this;
-
-    this.$().click(function (e) {
-      e.stopPropagation();
-
-      self.sendAction('click', self.get('data'));
-    });
-  }
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/components/notify-widget.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/components/notify-widget.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/components/notify-widget.js
deleted file mode 100644
index ba0f080..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/components/notify-widget.js
+++ /dev/null
@@ -1,31 +0,0 @@
-/**
-* 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.
-*/
-
-import Ember from 'ember';
-
-export default Ember.Component.extend({
-  tagName: 'notifications',
-  classNames: [ 'notifications-container' ],
-  removeNotificationAction: 'removeNotification',
-
-  actions: {
-    removeNotification: function (notification) {
-      this.sendAction('removeNotificationAction', notification);
-    }
-  }
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/components/number-range-widget.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/components/number-range-widget.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/components/number-range-widget.js
deleted file mode 100644
index 3b340ad..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/components/number-range-widget.js
+++ /dev/null
@@ -1,79 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-import utils from 'hive/utils/functions';
-
-export default Ember.Component.extend({
-  didInsertElement: function () {
-    var self = this;
-    var numberRange = this.get('numberRange');
-
-    if (!numberRange.get('from') && !numberRange.get('to')) {
-      numberRange.set('from', numberRange.get('min'));
-      numberRange.set('to', numberRange.get('max'));
-    }
-
-    this.$('.slider').slider({
-      range: true,
-      min: numberRange.get('min'),
-      max: numberRange.get('max'),
-      units: numberRange.get('units'),
-      values: [numberRange.get('from'), numberRange.get('to')],
-
-      slide: function (event, ui) {
-        numberRange.set('from', ui.values[0]);
-        numberRange.set('to', ui.values[1]);
-        self.updateRangeLables();
-      },
-
-      change: function () {
-        self.sendAction('rangeChanged', numberRange);
-      }
-    });
-    this.updateRangeLables();
-    this.set('rendered', true);
-  },
-  updateRangeLables: function () {
-    var numberRange = this.get('numberRange');
-    numberRange.set('fromDuration', utils.secondsToHHMMSS(numberRange.get('from')));
-    numberRange.set('toDuration', utils.secondsToHHMMSS(numberRange.get('to')));
-  },
-  updateFrom: function () {
-    if (this.get('rendered')) {
-      this.$('.slider').slider('values', 0, this.get('numberRange.from'));
-      this.updateRangeLables();
-    }
-  }.observes('numberRange.from'),
-
-  updateTo: function () {
-    if (this.get('rendered')) {
-      this.$('.slider').slider('values', 1, this.get('numberRange.to'));
-      this.updateRangeLables();
-    }
-  }.observes('numberRange.to'),
-
-  updateMin: function(){
-    this.$( ".slider" ).slider( "option", "min", this.get('numberRange.min') );
-  }.observes('numberRange.min'),
-
-  updateMax: function(){
-    this.$( ".slider" ).slider( "option", "max", this.get('numberRange.max') );
-  }.observes('numberRange.max')
-
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/components/panel-widget.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/components/panel-widget.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/components/panel-widget.js
deleted file mode 100644
index e2b4ae8..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/components/panel-widget.js
+++ /dev/null
@@ -1,30 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-
-export default Ember.Component.extend(Ember.I18n.TranslateableProperties, {
-  tagName: 'panel',
-
-  actions: {
-    sendMenuItemAction: function (action) {
-      this.set('menuItemAction', action);
-      this.sendAction('menuItemAction');
-    }
-  }
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/components/popover-widget.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/components/popover-widget.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/components/popover-widget.js
deleted file mode 100644
index cfb0c31..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/components/popover-widget.js
+++ /dev/null
@@ -1,34 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-
-export default Ember.Component.extend(Ember.I18n.TranslateableProperties, {
-  tagName: 'popover',
-  attributeBindings: [ 'title', 'content:data-content' ],
-
-  didInsertElement: function () {
-    this.$().popover({
-      html: true,
-      placement: 'left',
-      trigger: 'hover'
-    });
-
-    this.$().attr('data-content', this.$('.hide').html());
-  }
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/components/progress-widget.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/components/progress-widget.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/components/progress-widget.js
deleted file mode 100644
index 9a459c3..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/components/progress-widget.js
+++ /dev/null
@@ -1,30 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-
-export default Ember.Component.extend({
-  tagName: 'progress-bar',
-
-  updateValue: function () {
-    var progress = this.get('value') ? this.get('value').toFixed() : 0;
-
-    this.set('style', 'width: %@%'.fmt(progress));
-    this.set('percentage', '%@%'.fmt(progress));
-  }.observes('value').on('didInsertElement')
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/components/query-editor.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/components/query-editor.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/components/query-editor.js
deleted file mode 100644
index 34b293c..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/components/query-editor.js
+++ /dev/null
@@ -1,129 +0,0 @@
-/**
- * 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.
- */
-
-/* global CodeMirror */
-
-/**
-/* Copyright (C) 2014 by Marijn Haverbeke <ma...@gmail.com> and others
- *
- * Permission is hereby granted, free of charge, to any person obtaining a copy
- * of this software and associated documentation files (the "Software"), to deal
- * in the Software without restriction, including without limitation the rights
- * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
- * copies of the Software, and to permit persons to whom the Software is
- * furnished to do so, subject to the following conditions:
-
- * The above copyright notice and this permission notice shal l be included in
- * all copies or substantial portions of the Software.
-*/
-
-import Ember from 'ember';
-
-export default Ember.Component.extend({
-  tagName: 'query-editor',
-
-  tablesChanged: function () {
-    //Format hintOptions object as needed by the CodeMirror
-    //http://stackoverflow.com/questions/20023381/codemirror-how-add-tables-to-sql-hint
-    this.set('editor.options.hintOptions', { tables: this.get('tables') });
-  }.observes('tables'),
-
-  getColumnsHint: function (cm, tableName) {
-    var callback = function () {
-      CodeMirror.showHint(cm);
-    };
-
-    this.sendAction('columnsNeeded', tableName, callback);
-  },
-
-  initEditor: function () {
-    var editor,
-        updateSize,
-        self = this;
-
-    updateSize = function () {
-      editor.setSize(self.$(this).width(), self.$(this).height());
-      editor.refresh();
-    };
-
-    this.set('editor', CodeMirror.fromTextArea(document.getElementById('code-mirror'), {
-      mode: 'text/x-hive',
-      hint: CodeMirror.hint.sql,
-      indentWithTabs: true,
-      smartIndent: true,
-      lineNumbers: true,
-      matchBrackets : true,
-      autofocus: true,
-      extraKeys: {'Ctrl-Space': 'autocomplete'}
-    }));
-
-    CodeMirror.commands.autocomplete = function (cm) {
-      var lastWord = cm.getValue().split(' ').pop();
-
-      //if user wants to fill in a column
-      if (lastWord.indexOf('.') > -1) {
-        lastWord = lastWord.split('.')[0];
-
-        self.getColumnsHint(cm, lastWord);
-      } else {
-        CodeMirror.showHint(cm);
-      }
-    };
-
-    editor = this.get('editor');
-
-    editor.on('cursorActivity', function () {
-      self.set('highlightedText', editor.getSelections());
-    });
-
-    editor.setValue(this.get('query') || '');
-
-    editor.on('change', function (instance) {
-      Ember.run(function () {
-        self.set('query', instance.getValue());
-      });
-    });
-
-    this.$('.CodeMirror').resizable({
-      handles: 's',
-
-      resize: function () {
-        Ember.run.debounce(this, updateSize, 150);
-      }
-    }).find('.ui-resizable-s').addClass('grip fa fa-reorder');
-
-    this.tablesChanged();
-  }.on('didInsertElement'),
-
-  updateValue: function () {
-    var query = this.get('query');
-    var editor = this.get('editor');
-
-    var isFinalExplainQuery = (query.toUpperCase().trim().indexOf('EXPLAIN') > -1);
-    var editorQuery = editor.getValue();
-
-    if (editor.getValue() !== query) {
-      if(isFinalExplainQuery){
-        editor.setValue(editorQuery || '')
-      }else {
-        editor.setValue(query || '');
-      }
-    }
-
-  }.observes('query')
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/components/radio-button.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/components/radio-button.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/components/radio-button.js
deleted file mode 100644
index a07caaf..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/components/radio-button.js
+++ /dev/null
@@ -1,39 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-
-export default Ember.Component.extend({
-  tagName: 'input',
-  type: 'radio',
-  attributeBindings: ['type', 'htmlChecked:checked', 'value', 'name', 'disabled'],
-
-  htmlChecked: function() {
-    return this.get('value') === this.get('checked');
-  }.property('value', 'checked'),
-
-  change: function() {
-    this.set('checked', this.get('value'));
-  },
-
-  _updateElementValue: function() {
-    Ember.run.next(this, function() {
-      this.$().prop('checked', this.get('htmlChecked'));
-    });
-  }.observes('htmlChecked')
-});
\ No newline at end of file

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/components/select-widget.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/components/select-widget.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/components/select-widget.js
deleted file mode 100644
index 8bd7a22..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/components/select-widget.js
+++ /dev/null
@@ -1,66 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-
-export default Ember.Component.extend(Ember.I18n.TranslateableProperties, {
-  tagName: 'dropdown',
-
-  selectedLabel: function () {
-    var value;
-
-    //if there's an item selected, retrieve the property to be displayed as a label
-    if (this.get('selectedValue') && this.get('labelPath')) {
-      value = this.get('selectedValue').get(this.get('labelPath'));
-
-      if (value) {
-        return value;
-      }
-    }
-
-    //else if a default label has been provided, use it as the selected label.
-    if (this.get('defaultLabel')) {
-      return this.get('defaultLabel');
-    }
-  }.property('selectedValue'),
-
-  didInsertElement: function () {
-    //if no selected item nor defaultLabel, set the selected value
-    if (!this.get('selectedValue') && !this.get('defaultLabel') && this.get('items')) {
-      this.set('selectedValue', this.get('items').objectAt(0));
-    }
-  },
-
-  actions: {
-    select: function (item){
-      this.set('selectedValue', item);
-    },
-
-    add: function () {
-      this.sendAction('itemAdded');
-    },
-
-    edit: function (item) {
-      this.sendAction('itemEdited', item);
-    },
-
-    remove: function (item) {
-      this.sendAction('itemRemoved', item);
-    }
-  }
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/components/tabs-widget.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/components/tabs-widget.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/components/tabs-widget.js
deleted file mode 100644
index abb1337..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/components/tabs-widget.js
+++ /dev/null
@@ -1,68 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-
-export default Ember.Component.extend({
-  tagName: 'tabs',
-
-  didInsertElement: function () {
-    var tabToActivate,
-        tabs = this.get('tabs');
-
-    if (tabs.get('length')) {
-      tabToActivate = tabs.find(function (tab) {
-        return tab.get('active');
-      });
-
-      if (tabToActivate) {
-        this.set('selectedTab', tabToActivate);
-      } else {
-        this.set('selectedTab', tabs.objectAt(0));
-      }
-    }
-  },
-
-  activateTab: function () {
-    var selectedTab = this.get('selectedTab');
-
-    selectedTab.set('active', true);
-
-    this.get('tabs').without(selectedTab).forEach(function (tab) {
-      tab.set('active', false);
-    });
-  }.observes('selectedTab'),
-
-  removeEnabled: function () {
-    return this.get('canRemove') && this.get('tabs.length') > 1;
-  }.property('tabs.@each'),
-
-  actions: {
-    remove: function (tab) {
-      this.sendAction('removeClicked', tab);
-    },
-
-    selectTab: function (tab) {
-      this.set('selectedTab', tab);
-    },
-
-    titleClick: function(tab) {
-      this.sendAction('onActiveTitleClick', tab);
-    }
-  }
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/components/tree-view.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/components/tree-view.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/components/tree-view.js
deleted file mode 100644
index cd63f52..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/components/tree-view.js
+++ /dev/null
@@ -1,23 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-
-export default Ember.Component.extend({
-  tagName: 'tree-view'
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/components/typeahead-widget.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/components/typeahead-widget.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/components/typeahead-widget.js
deleted file mode 100644
index 5bc0bda..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/components/typeahead-widget.js
+++ /dev/null
@@ -1,108 +0,0 @@
-/**
- * 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.
- */
-
-import Typeahead from 'ember-cli-selectize/components/ember-selectize';
-import Ember from 'ember';
-
-export default Typeahead.extend(Ember.I18n.TranslateableProperties, {
-  didInsertElement: function () {
-    this._super();
-
-    if (!this.get('selection') && this.get('content.firstObject')) {
-      this.set('selection', this.get('content.firstObject'));
-    }
-
-    this.selectize.on('dropdown_close', Ember.$.proxy(this.onClose, this));
-
-    if($('.selectize-input')) {$('.selectize-input').addClass( "mozBoxSizeFix" );}
-
-    var currentKeyName = this.get('safeValue');
-    var currentTypehead = $('*[keyname="' + currentKeyName +'"]');
-
-    if (currentTypehead.find($('.selectize-input')).has('.item').length == 0) {
-      currentTypehead.find($('.selectize-input')).addClass("has-options has-items ");
-
-      currentTypehead.find($('.selectized option:selected')).val(currentKeyName);
-      currentTypehead.find($('.selectized option:selected')).text(currentKeyName);
-
-      currentTypehead.find($('.selectize-input input')).css({'opacity': 0 , 'position': 'absolute' , 'left': '-10000px'});
-
-      var itemHtml = '<div data-value=' + currentKeyName + ' class=item >' + currentKeyName + '</div>';
-      currentTypehead.find($('.selectize-input')).append( itemHtml );
-
-    }
-  },
-
-  removeExcludedObserver: function () {
-    var options = this.get('content');
-
-    if (!options) {
-      options = this.removeExcluded(true);
-      this.set('content', options);
-    } else {
-      this.removeExcluded();
-    }
-  }.observes('excluded.@each.key').on('init'),
-
-  removeExcluded: function (shouldReturn) {
-    var excluded        = this.get('excluded') || [];
-    var options         = this.get('options');
-    var selection       = this.get('selection');
-    var objectToModify  = this.get('content');
-    var objectsToRemove = [];
-    var objectsToAdd    = [];
-
-    if (!options) {
-      return;
-    }
-
-    if (shouldReturn) {
-      objectToModify = Ember.copy(options);
-    }
-
-    var valuePath = this.get('optionValuePath');
-    var selectionName = selection ? selection[valuePath] : selection;
-
-    if (options) {
-      options.forEach(function (option) {
-        if (excluded.contains(option) && option.name !== selectionName) {
-          objectsToRemove.push(option);
-        } else if (!objectToModify.contains(option)) {
-          objectsToAdd.push(option);
-        }
-      });
-    }
-
-    objectToModify.removeObjects(objectsToRemove);
-    objectToModify.pushObjects(objectsToAdd);
-
-    return objectToModify;
-  },
-
-  onClose: function () {
-    if (!this.get('selection') && this.get('prevSelection')) {
-      this.set('selection', this.get('prevSelection'));
-    }
-  },
-
-  _onItemAdd: function (value) {
-    this._super(value);
-
-    this.set('prevSelection', this.get('selection'));
-  }
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/components/udf-tr-view.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/components/udf-tr-view.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/components/udf-tr-view.js
deleted file mode 100644
index f019578..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/components/udf-tr-view.js
+++ /dev/null
@@ -1,81 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-import constants from 'hive/utils/constants';
-
-export default Ember.Component.extend({
-  tagName: 'tr',
-
-  didInsertElement: function () {
-    this._super();
-
-    if (this.get('udf.isNew')) {
-      this.set('udf.isEditing', true);
-    }
-  },
-
-  setfileBackup: function () {
-    if (!this.get('udf.isDirty')) {
-      this.set('fileBackup', this.get('udf.fileResource'));
-    }
-  }.observes('udf.isDirty').on('didInsertElement'),
-
-  actions: {
-    editUdf: function () {
-      this.set('udf.isEditing', true);
-    },
-
-    deleteUdf: function () {
-      this.sendAction('onDeleteUdf', this.get('udf'));
-    },
-
-    addFileResource: function () {
-      this.sendAction('onAddFileResource', this.get('udf'));
-    },
-
-    editFileResource: function (file) {
-      this.set('udf.fileResource', file);
-      this.set('udf.isEditingResource', true);
-    },
-
-    deleteFileResource: function (file) {
-      this.sendAction('onDeleteFileResource', file);
-    },
-
-    save: function () {
-      this.sendAction('onSaveUdf', this.get('udf'));
-    },
-
-    cancel: function () {
-      var self = this;
-
-      this.set('udf.isEditing', false);
-      this.set('udf.isEditingResource', false);
-
-      this.udf.get('fileResource').then(function (file) {
-        if (file) {
-          file.rollback();
-        }
-
-        self.udf.rollback();
-        self.udf.set('fileResource', self.get('fileBackup'));
-      });
-    }
-  }
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/components/upload-query.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/components/upload-query.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/components/upload-query.js
deleted file mode 100644
index e9a7ffa..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/components/upload-query.js
+++ /dev/null
@@ -1,32 +0,0 @@
-/**
- * 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.
- */
-
-import EmberUploader from 'ember-uploader';
-
-export default EmberUploader.FileField.extend({
-
-  attributeBindings: ['id', 'style'],
-  id: 'upload',
-  style: 'display:none',
-  initialize: function() {
-    this.$().on('change', function(e) {
-                this.sendAction('filesUploaded', e.currentTarget.files);
-                }.bind(this));
-    }.on('didInsertElement')
-  });
-

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/components/validated-text-field.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/components/validated-text-field.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/components/validated-text-field.js
deleted file mode 100644
index 2379a15..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/components/validated-text-field.js
+++ /dev/null
@@ -1,62 +0,0 @@
-/**
- * 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.
- */
-
-
-import Ember from 'ember';
-
-/** Example :
- * {{#validated-text-field
- * inputValue=bindedTextValue invalidClass='form-control red-border' validClass='form-control' regex="^[a-z]+$"
- * allowEmpty=false tooltip="Enter valid word" errorMessage="Please enter valid word" placeholder="Enter Word"}}
- * {{/validated-text-field}}
- */
-export default Ember.Component.extend({
-  classNameBindings: ['tagClassName'],
-  tagClassName : false, // set it to non false value if you want a specific class to be assigned
-  allowEmpty: true,
-  valid: true,
-  setValid: function () {
-    this.set("valid", true);
-    this.set("inputClass", this.get("validClass"));
-    this.set("message", this.get("tooltip"));
-  },
-  setInvalid: function () {
-    this.set("valid", false);
-    this.set("inputClass", this.get("invalidClass"));
-    this.set("message", this.get("errorMessage"));
-  },
-  onChangeInputValue: function () {
-    var regStr = this.get("regex");
-    var regExp = new RegExp(regStr, "g");
-    if (this.get("inputValue")) {
-      var arr = this.get("inputValue").match(regExp);
-      if (arr != null && arr.length == 1) {
-        this.setValid();
-      }
-      else {
-        this.setInvalid();
-      }
-    } else {
-      if (this.get("allowEmpty")) {
-        this.setValid();
-      } else {
-        this.setInvalid();
-      }
-    }
-  }.observes("inputValue").on('init')
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/components/visualization-tabs-widget.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/components/visualization-tabs-widget.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/components/visualization-tabs-widget.js
deleted file mode 100644
index 4980b7a..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/components/visualization-tabs-widget.js
+++ /dev/null
@@ -1,56 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-
-export default Ember.Component.extend({
-  tagName: 'tabs',
-
-  didInsertElement: function () {
-    var tabToActivate,
-        tabs = this.get('tabs');
-
-    if (tabs.get('length')) {
-      tabToActivate = tabs.find(function (tab) {
-        return tab.get('active');
-      });
-
-      if (tabToActivate) {
-        this.set('selectedTab', tabToActivate);
-      } else {
-        this.set('selectedTab', tabs.objectAt(0));
-      }
-    }
-  },
-
-  activateTab: function () {
-    var selectedTab = this.get('selectedTab');
-
-    selectedTab.set('active', true);
-
-    this.get('tabs').without(selectedTab).forEach(function (tab) {
-      tab.set('active', false);
-    });
-  }.observes('selectedTab'),
-
-  actions: {
-    selectTab: function (tab) {
-      this.set('selectedTab', tab);
-    }
-  }
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/controllers/.gitkeep
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/controllers/.gitkeep b/contrib/views/hive/src/main/resources/ui/hive-web/app/controllers/.gitkeep
deleted file mode 100644
index e69de29..0000000

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/controllers/application.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/controllers/application.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/controllers/application.js
deleted file mode 100644
index 9a01d53..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/controllers/application.js
+++ /dev/null
@@ -1,26 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-import constants from 'hive/utils/constants';
-
-export default Ember.Controller.extend({
-  notifyService: Ember.inject.service(constants.namingConventions.notify),
-
-  notifications: Ember.computed.alias('notifyService.notifications'),
-});
\ No newline at end of file

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/controllers/databases.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/controllers/databases.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/controllers/databases.js
deleted file mode 100644
index fbd726c..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/controllers/databases.js
+++ /dev/null
@@ -1,465 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-import constants from 'hive/utils/constants';
-import ENV from '../config/environment';
-
-export default Ember.Controller.extend({
-  databaseService: Ember.inject.service(constants.namingConventions.database),
-  notifyService: Ember.inject.service(constants.namingConventions.notify),
-  ldapAuthenticationService: Ember.inject.service(constants.namingConventions.ldapAuthentication),
-
-  pageCount: 10,
-
-  previousSelectedDatabaseName : "" ,
-  selectedDatabase: Ember.computed.alias('databaseService.selectedDatabase'),
-  databases: Ember.computed.alias('databaseService.databases'),
-
-  tableSearchResults: Ember.Object.create(),
-
-  isDatabaseRefreshInProgress: false,
-  showColumnsResultAlert: false,
-  textColumnSearchTerm:'',
-
-  tableControls: [
-    {
-      icon: 'fa-list',
-      action: 'loadSampleData',
-      tooltip: Ember.I18n.t('tooltips.loadSample')
-    }
-  ],
-
-  panelIconActions: [
-    {
-      icon: 'fa-refresh',
-      action: 'refreshDatabaseExplorer',
-      tooltip: Ember.I18n.t('tooltips.refresh')
-    }
-  ],
-
-  tabs: [
-    Ember.Object.create({
-      name: Ember.I18n.t('titles.explorer'),
-      visible: true,
-      view: constants.namingConventions.databaseTree
-    }),
-    Ember.Object.create({
-      name: Ember.I18n.t('titles.results'),
-      view: constants.namingConventions.databaseSearch
-    })
-  ],
-
-  _handleError: function (error) {
-    this.get('notifyService').error(error);
-    this.set('isLoading', false);
-  },
-
-  setTablePageAvailability: function (database) {
-    var result;
-
-    if (database.get('hasNext')) {
-      result = true;
-    } else if (database.tables.length > database.get('visibleTables.length')) {
-      //if there are hidden tables
-      result = true;
-    }
-
-    database.set('canGetNextPage', result);
-  },
-
-  setColumnPageAvailability: function (table) {
-    var result;
-
-    if (table.get('hasNext')) {
-      result = true;
-    } else if (table.columns.length > table.get('visibleColumns.length')) {
-      //if there are hidden columns
-      result = true;
-    }
-
-    table.set('canGetNextPage', result);
-  },
-
-  selectedDatabaseChanged: function () {
-    var self = this;
-
-    this.resetSearch();
-
-    this.set('isLoading', true);
-
-    this.get('databaseService').getAllTables().then(function () {
-      self.set('isLoading', false);
-      self.set('previousSelectedDatabaseName',self.get('selectedDatabase').get('name'));
-      self.get('notifyService').info("Selected database : "+self.get('selectedDatabase').get('name'));
-    }, function (error) {
-      self.get('notifyService').pushError("Error while selecting database : "+self.get('selectedDatabase').get('name'),error.responseJSON.message+"\n"+error.responseJSON.trace);
-      self.get('databaseService').setDatabaseByName(self.get('previousSelectedDatabaseName'));
-      self.set('isLoading', false);
-    });
-  }.observes('selectedDatabase'),
-
-  getNextColumnPage: function (database, table) {
-    var self = this;
-
-    this.set('isLoading', true);
-
-    if (!table.columns) {
-      table.columns = [];
-      table.set('visibleColumns', []);
-    }
-
-    this.get('databaseService').getColumnsPage(database.get('name'), table).then(function (result) {
-      table.columns.pushObjects(result.columns);
-      table.get('visibleColumns').pushObjects(result.columns);
-      table.set('hasNext', result.hasNext);
-
-      self.setColumnPageAvailability(table);
-      self.set('isLoading', false);
-    }, function (err) {
-      self._handleError(err);
-    });
-  },
-
-  getNextTablePage: function (database) {
-    var self = this;
-
-    this.set('isLoading', true);
-
-    if (!database.tables) {
-      database.tables = [];
-      database.set('visibleTables', []);
-    }
-
-    this.get('databaseService').getTablesPage(database).then(function (result) {
-      database.tables.pushObjects(result.tables);
-      database.get('visibleTables').pushObjects(result.tables);
-      database.set('hasNext', result.hasNext);
-
-      self.setTablePageAvailability(database);
-      self.set('isLoading', false);
-    }, function (err) {
-      self._handleError(err);
-    });
-  },
-
-  getDatabases: function () {
-    var self = this;
-    var selectedDatabase = this.get('selectedDatabase.name') || 'default';
-
-    this.set('isDatabaseRefreshInProgress', true);
-
-    this.set('isLoading', true);
-
-    this.get('databaseService').getDatabases().then(function (databases) {
-      self.set('isLoading');
-      self.get('databaseService').setDatabaseByName(selectedDatabase);
-    }).catch(function (error) {
-      self._handleError(error);
-
-      if(error.status == 401) {
-         self.send('openLdapPasswordModal');
-      }
-    }).finally(function() {
-      self.set('isDatabaseRefreshInProgress', false);
-    });
-  }.on('init'),
-
-  syncDatabases: function() {
-    this.set('isDatabaseRefreshInProgress', true);
-    var oldDatabaseNames = this.store.all('database').mapBy('name');
-    var self = this;
-    return this.get('databaseService').getDatabasesFromServer().then(function(data) {
-      // Remove the databases from store which are not in server
-      data.forEach(function(dbName) {
-        if(!oldDatabaseNames.contains(dbName)) {
-          self.store.createRecord('database', {
-            id: dbName,
-            name: dbName
-          });
-        }
-      });
-      // Add the databases in store which are new in server
-      oldDatabaseNames.forEach(function(dbName) {
-        if(!data.contains(dbName)) {
-          self.store.find('database', dbName).then(function(db) {
-            self.store.unloadRecord(db);
-          });
-        }
-      });
-    }).finally(function() {
-      self.set('isDatabaseRefreshInProgress', false);
-    });
-  },
-
-  initiateDatabaseSync: function() {
-    // This was required so that the unit test would not stall
-    if(ENV.environment !== "test") {
-      Ember.run.later(this, function() {
-        if (this.get('isDatabaseRefreshInProgress') === false) {
-          this.syncDatabases();
-          this.initiateDatabaseSync();
-        }
-      }, 15000);
-    }
-  }.on('init'),
-
-  resetSearch: function() {
-    var resultsTab = this.get('tabs').findBy('view', constants.namingConventions.databaseSearch);
-    var databaseExplorerTab = this.get('tabs').findBy('view', constants.namingConventions.databaseTree);
-    var tableSearchResults = this.get('tableSearchResults');
-    resultsTab.set('visible', false);
-    this.set('selectedTab', databaseExplorerTab);
-    this.set('tableSearchTerm', '');
-    this.set('columnSearchTerm', '');
-    tableSearchResults.set('tables', undefined);
-    tableSearchResults.set('hasNext', undefined);
-  },
-
-
-  actions: {
-    refreshDatabaseExplorer: function () {
-      if (this.get('isDatabaseRefreshInProgress') === false) {
-        this.getDatabases();
-        this.resetSearch();
-      } else {
-        console.log("Databases refresh is in progress. Skipping this request.");
-      }
-    },
-
-    openLdapPasswordModal: function(){
-
-      var self = this,
-        defer = Ember.RSVP.defer();
-
-      this.send('openModal', 'modal-save', {
-        heading: "modals.authenticationLDAP.heading",
-        text:"",
-        type: "password",
-        defer: defer
-      });
-
-      defer.promise.then(function (text) {
-        var ldapAuthPromise = self.get('ldapAuthenticationService').authenticateLdapPassword(text);
-
-        ldapAuthPromise.then(function (data) {
-          console.log( "LDAP done: " + data );
-          self.getDatabases();
-          self.syncDatabases();
-        }, function (error) {
-          console.log( "LDAP fail: " + error );
-          self.get('notifyService').error( "Wrong Credentials." );
-        })
-      });
-
-    },
-
-    loadSampleData: function (tableName, database) {
-      var self = this;
-      this.send('addQuery', Ember.I18n.t('titles.tableSample', { tableName: tableName }));
-
-      Ember.run.later(function () {
-        var query = constants.sampleDataQuery.fmt(tableName);
-
-        self.set('selectedDatabase', database);
-        self.send('executeQuery', constants.jobReferrer.sample, query);
-      });
-    },
-
-    getTables: function (dbName) {
-      var database = this.get('databases').findBy('name', dbName),
-          tables = database.tables,
-          pageCount = this.get('pageCount');
-
-      if (!tables) {
-        this.getNextTablePage(database);
-      } else {
-        database.set('visibleTables', tables.slice(0, pageCount));
-        this.setTablePageAvailability(database);
-      }
-    },
-
-    getColumns: function (tableName, database) {
-      var table = database.get('visibleTables').findBy('name', tableName),
-          pageCount = this.get('pageCount'),
-          columns = table.columns;
-
-      if (!columns) {
-        this.getNextColumnPage(database, table);
-      } else {
-        table.set('visibleColumns', columns.slice(0, pageCount));
-        this.setColumnPageAvailability(table);
-      }
-    },
-
-    showMoreTables: function (database) {
-      var tables = database.tables,
-          visibleTables = database.get('visibleTables'),
-          visibleCount = visibleTables.length;
-
-      if (!tables) {
-        this.getNextTablePage(database);
-      } else {
-        if (tables.length > visibleCount) {
-          visibleTables.pushObjects(tables.slice(visibleCount, visibleCount + this.get('pageCount')));
-          this.setTablePageAvailability(database);
-        } else {
-          this.getNextTablePage(database);
-        }
-      }
-    },
-
-    showMoreColumns: function (table, database) {
-      var columns = table.columns,
-          visibleColumns = table.get('visibleColumns'),
-          visibleCount = visibleColumns.length;
-
-      if (!columns) {
-        this.getNextColumnPage(database, table);
-      } else {
-        if (columns.length > visibleCount) {
-          visibleColumns.pushObjects(columns.slice(visibleCount, visibleCount + this.get('pageCount')));
-          this.setColumnPageAvailability(table);
-        } else {
-          this.getNextColumnPage(database, table);
-        }
-      }
-    },
-
-    searchTables: function (searchTerm) {
-      var self = this,
-          resultsTab = this.get('tabs').findBy('view', constants.namingConventions.databaseSearch),
-          tableSearchResults = this.get('tableSearchResults');
-
-      searchTerm = searchTerm ? searchTerm.toLowerCase() : '';
-
-      this.set('showColumnsResultAlert', false);
-
-      this.set('tablesSearchTerm', searchTerm);
-      resultsTab.set('visible', true);
-      this.set('selectedTab', resultsTab);
-      this.set('columnSearchTerm', '');
-      this.set('isLoading', true);
-
-      this.get('databaseService').getTablesPage(this.get('selectedDatabase'), searchTerm, true).then(function (result) {
-        tableSearchResults.set('tables', result.tables);
-        tableSearchResults.set('hasNext', result.hasNext);
-
-        self.set('isLoading', false);
-      }, function (err) {
-        self._handleError(err);
-      });
-    },
-
-    searchColumns: function (searchTerm) {
-      var self = this,
-          database = this.get('selectedDatabase'),
-          resultsTab = this.get('tabs').findBy('view', constants.namingConventions.databaseSearch),
-          tables = this.get('tableSearchResults.tables');
-
-      searchTerm = searchTerm ? searchTerm.toLowerCase() : '';
-
-      this.set('columnSearchTerm', searchTerm);
-      this.set('textColumnSearchTerm', searchTerm);
-
-      this.set('selectedTab', resultsTab);
-      this.set('isLoading', true);
-      this.set('showColumnsResultAlert', false);
-
-      var tableCount = tables.length || 0;
-      var noColumnMatchTableCount = 0;
-
-      tables.forEach(function (table) {
-        self.get('databaseService').getColumnsPage(database.get('name'), table, searchTerm, true).then(function (result) {
-
-          if(Ember.isEmpty(result.columns)){
-            noColumnMatchTableCount = noColumnMatchTableCount + 1;
-          }
-          table.set('columns', result.columns);
-          table.set('hasNext', result.hasNext);
-
-          if (tables.indexOf(table) === tables.get('length') -1) {
-            self.set('isLoading', false);
-          }
-
-          // This will execute only in the last interation
-          if(noColumnMatchTableCount === tableCount) {
-            self.set('showColumnsResultAlert', true);
-          }
-        }, function (err) {
-          self._handleError(err);
-        });
-      });
-    },
-
-    showMoreResultTables: function () {
-      var self = this,
-          database = this.get('selectedDatabase'),
-          tableSearchResults = this.get('tableSearchResults'),
-          searchTerm = this.get('tableSearchTerm');
-
-      this.set('isLoading', true);
-
-      this.get('databaseService').getTablesPage(database, searchTerm).then(function (tablesResult) {
-        var tables = tableSearchResults.get('tables');
-        var shouldGetColumns = tables.any(function (table) {
-          return table.get('columns.length') > 0;
-        });
-
-        tables.pushObjects(tablesResult.tables);
-        tableSearchResults.set('hasNext', tablesResult.hasNext);
-
-        //if user has already searched for columns for the previously loaded tables,
-        //load the columns search results for the newly loaded tables.
-        if (shouldGetColumns) {
-          tablesResult.tables.forEach(function (table) {
-            self.get('databaseService').getColumnsPage(database.get('name'), table, self.get('columnSearchTerm'), true).then(function (result) {
-              table.set('columns', result.columns);
-              table.set('hasNext', result.hasNext);
-
-              if (tablesResult.tables.indexOf(table) === tablesResult.tables.get('length') -1) {
-                self.set('isLoading', false);
-              }
-            }, function (err) {
-              self._handleError(err);
-            });
-          });
-        } else {
-          self.set('isLoading', false);
-        }
-      }, function (err) {
-        self._handleError(err);
-      });
-    },
-
-    showMoreResultColumns: function (table) {
-      var self = this;
-
-      this.set('isLoading', true);
-
-      this.get('databaseService').getColumnsPage(this.get('selectedDatabase.name'), table, this.get('columnSearchTerm')).then(function (result) {
-        table.get('columns').pushObjects(result.columns);
-        table.set('hasNext', result.hasNext);
-
-        self.set('isLoading', false);
-      }, function (err) {
-        self._handleError(err);
-      });
-    }
-  }
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/controllers/history.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/controllers/history.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/controllers/history.js
deleted file mode 100644
index fa12e3f..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/controllers/history.js
+++ /dev/null
@@ -1,257 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-import FilterableMixin from 'hive/mixins/filterable';
-import constants from 'hive/utils/constants';
-
-export default Ember.ArrayController.extend(FilterableMixin, {
-  jobService: Ember.inject.service('job'),
-  fileService: Ember.inject.service('file'),
-  historyService: Ember.inject.service('history'),
-  NUM_OF_DAYS: 5,
-  REFRESH_INTERVAL_SEC: 30000,
-  sortAscending: false,
-  sortProperties: ['dateSubmittedTimestamp'],
-
-  refresher: function () {
-    var self = this;
-    Ember.run.later(function () {
-      if (self.get('isShowing')) {
-        self.refresh();
-      }
-      self.refresher();
-    }, self.get('REFRESH_INTERVAL_SEC'));
-  },
-  onLoadRoute: function () {
-    this.set('isShowing', true);
-  },
-  onUnloadRoute: function () {
-    this.set('isShowing', false);
-  },
-  init: function () {
-    this._super();
-    var self = this;
-    var fromTime = moment().subtract(this.get('NUM_OF_DAYS'), 'days').startOf('day');
-    var time = moment();
-    var toTime = moment({
-      years: time.year(),
-      months: time.month(),
-      date: time.date(),
-      hours: 23,
-      minutes: 59,
-      seconds: 59,
-      milliseconds: 999
-    }); // next 12AM
-
-    this.set('columns', Ember.ArrayProxy.create({
-      content: Ember.A([
-        Ember.Object.create({
-          caption: 'columns.title',
-          property: 'title',
-          link: constants.namingConventions.subroutes.historyQuery
-        }),
-        Ember.Object.create({
-          caption: 'columns.status',
-          property: 'status'
-        }),
-        Ember.Object.create({
-          caption: 'columns.date',
-          property: 'dateSubmittedTimestamp',
-          dateRange: Ember.Object.create({
-            min: fromTime.toDate(),
-            max: toTime.toDate()
-          })
-        }),
-        Ember.Object.create({
-          caption: 'columns.duration',
-          property: 'duration',
-          numberRange: Ember.Object.create({
-            min: 0,
-            max: 10,
-            units: 'sec'
-          })
-        })
-      ])
-    }));
-
-    return this.updateJobs(fromTime, toTime).then(function (data) {
-      self.applyDurationFilter();
-      self.refresher();
-    });
-  },
-  applyDurationFilter: function () {
-    var self = this;
-    var durationColumn = this.get('columns').find(function (column) {
-      return column.get('caption') === 'columns.duration';
-    });
-    var from = durationColumn.get('numberRange.from');
-    var to = durationColumn.get('numberRange.to');
-    self.filterBy("duration", {min: from, max: to});
-  },
-  updateIntervals: function () {
-    var durationColumn;
-    var maxDuration;
-    var minDuration;
-
-    if (this.get('columns')) {
-      durationColumn = this.get('columns').find(function (column) {
-        return column.get('caption') === 'columns.duration';
-      });
-
-      var items = this.get('history').map(function (item) {
-        return item.get(durationColumn.get('property'));
-      });
-
-      minDuration = items.length ? Math.min.apply(Math, items) : 0;
-      maxDuration = items.length ? Math.max.apply(Math, items) : 60; //Default 1 min
-
-      durationColumn.set('numberRange.min', minDuration);
-      durationColumn.set('numberRange.max', maxDuration);
-      var from = durationColumn.get('numberRange.from');
-      var to = durationColumn.get('numberRange.to');
-      if (from > maxDuration) {
-        durationColumn.set("numberRange.from", maxDuration);
-      }
-      if (to < minDuration) {
-        durationColumn.set("numberRange.to", minDuration);
-      }
-    }
-  }.observes('history'),
-
-  model: function () {
-    return this.filter(this.get('history'));
-  }.property('history', 'filters.@each'),
-
-  updateJobs: function (fromDate, toDate) {
-    var self = this;
-    var fromTime = moment(fromDate).startOf('day').toDate().getTime();
-    var time = moment(toDate);
-    var toTime = moment({
-      years: time.year(),
-      months: time.month(),
-      date: time.date(),
-      hours: 23,
-      minutes: 59,
-      seconds: 59,
-      milliseconds: 999
-    }).toDate().getTime(); // next 12AM
-    this.set("fromTime", fromTime);
-    this.set("toTime", toTime);
-    return this.get("historyService").getJobs(fromTime, toTime).then(function (data) {
-      self.set('history', data);
-    });
-  },
-
-  filterBy: function (filterProperty, filterValue, exactMatch) {
-    var column = this.get('columns').find(function (column) {
-      return column.get('property') === filterProperty;
-    });
-
-    if (column) {
-      var isDateColumn = column.get('caption') === 'columns.date';
-      column.set('filterValue', filterValue, exactMatch);
-      if (isDateColumn) {
-        return this.updateJobs(filterValue.min, filterValue.max);
-      } else {
-        this.updateFilters(filterProperty, filterValue, exactMatch);
-      }
-    } else {
-      this.updateFilters(filterProperty, filterValue, exactMatch);
-    }
-  },
-
-  refresh: function () {
-    var self = this;
-    this.get('historyService').getUpdatedJobList(this.get('toTime')).then(function (data) {
-      self.set('history', data);
-    });
-  },
-
-  actions: {
-
-    refreshJobs: function () {
-      this.refresh();
-    },
-
-    filterUpdated: function (filterProperty, filterValue) {
-      var self = this;
-      var column = this.get('columns').find(function (column) {
-        return column.get('property') === filterProperty;
-      });
-
-      var isDateColumn = (column.get('caption') === 'columns.date');
-
-      if (column) {
-        column.set('filterValue', filterValue);
-        if (isDateColumn) {
-          return this.updateJobs(filterValue.min, filterValue.max).then(function (data) {
-            self.updateFilters(filterProperty, filterValue);
-          });
-        } else {
-          self.updateFilters(filterProperty, filterValue);
-        }
-      }
-    },
-
-    sort: function (property) {
-      //if same column has been selected, toggle flag, else default it to true
-      if (this.get('sortProperties').objectAt(0) === property) {
-        this.set('sortAscending', !this.get('sortAscending'));
-      } else {
-        this.set('sortAscending', true);
-        this.set('sortProperties', [property]);
-      }
-    },
-
-    interruptJob: function (job) {
-      this.get('jobService').stopJob(job);
-    },
-
-    loadFile: function (job) {
-      this.get('fileService').loadFile(job.get('queryFile')).then(function (file) {
-        job.set('file', file);
-      });
-    },
-
-    clearFilters: function () {
-      var columns = this.get('columns');
-
-      if (columns) {
-        columns.forEach(function (column) {
-          var filterValue = column.get('filterValue');
-          var rangeFilter;
-
-          if (filterValue) {
-            if (typeof filterValue === 'string') {
-              column.set('filterValue');
-            } else {
-              rangeFilter = column.get('numberRange') || column.get('dateRange');
-
-              rangeFilter.set('from', rangeFilter.get('min'));
-              rangeFilter.set('to', rangeFilter.get('max'));
-            }
-          }
-        });
-      }
-
-      //call clear filters from Filterable mixin
-      this.clearFilters();
-    }
-  }
-});


[08/23] ambari git commit: AMBARI-19302 : removed contrib/views/hive folder and made necessary changes in pom.xml files (nitirajrathore)

Posted by ni...@apache.org.
http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/components/query-editor-test.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/components/query-editor-test.js b/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/components/query-editor-test.js
deleted file mode 100644
index e70b5ee..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/components/query-editor-test.js
+++ /dev/null
@@ -1,52 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-import { moduleForComponent, test } from 'ember-qunit';
-
-moduleForComponent('query-editor', 'QueryEditorComponent', {
-  unit: true
-});
-
-test('initEditor sets the editor on didInsertElement', function () {
-  expect(2);
-
-  var component = this.subject();
-
-  equal(component.get('editor'), undefined, 'element not rendered. Editor not set.');
-
-  this.$();
-
-  ok(component.get('editor'), 'element rendered. Editor set.');
-});
-
-test('updateValue sets the query value on the editor.', function () {
-  expect(1);
-
-  var component = this.subject();
-
-  var query = 'select something';
-
-  this.$();
-
-  Ember.run(function () {
-    component.set(('query'), query);
-  });
-
-  equal(component.get('editor').getValue(), query, 'set query property. Updated editor value property.');
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/components/select-widget-test.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/components/select-widget-test.js b/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/components/select-widget-test.js
deleted file mode 100644
index a186508..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/components/select-widget-test.js
+++ /dev/null
@@ -1,158 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-import { moduleForComponent, test } from 'ember-qunit';
-
-moduleForComponent('select-widget', 'SelectWidgetComponent', {
-  needs: ['helper:path-binding']
-});
-
-test('selectedLabel returns the selectedValue property indicated by labelPath if selectedValue and labelPath are set.', function () {
-  expect(1);
-
-  var component = this.subject();
-
-  var selectedValue = Ember.Object.extend({
-    label: 'db'
-  }).create();
-
-  var labelPath = 'label';
-
-  Ember.run(function () {
-    component.set('labelPath', labelPath);
-    component.set('selectedValue', selectedValue);
-  });
-
-  equal(component.get('selectedLabel'), selectedValue.label, 'selectedValue and labelPath are set. selectedLabel returns selectedValue[labelPath].');
-});
-
-test('selectedLabel returns defaultLabel if selectedValue is falsy and defaultLabel is set.', function () {
-  expect(1);
-
-  var component = this.subject();
-
-  var defaultLabel = 'select...';
-
-  Ember.run(function () {
-    component.set('defaultLabel', defaultLabel);
-  });
-
-  equal(component.get('selectedLabel'), defaultLabel, 'selectedValue falsy and defaultLabel set. selectedLabel returns defaultLabel.');
-});
-
-test('selectedLabel returns undefined if neither selectedValue nor defaultLabel are set.', function () {
-  expect(1);
-
-  var component = this.subject();
-
-  equal(component.get('selectedLabel'), undefined, 'selectedValue and defaultLabel are falsy. selectedLabel returns undefined.');
-});
-
-test('selectedLabel is computed when selectedValue changes.', function () {
-  expect(2);
-
-  var component = this.subject();
-
-  var selectedValue = Ember.Object.extend({
-    label: 'db'
-  }).create();
-
-  var labelPath = 'label';
-
-  equal(component.get('selectedLabel'), undefined, 'selectedValue and defaultLabel are falsy. selectedLabel returns undefined.');
-
-  Ember.run(function () {
-    component.set('labelPath', labelPath);
-    component.set('selectedValue', selectedValue);
-  });
-
-  equal(component.get('selectedLabel'), selectedValue.label, 'selectedValue and labelPath are set. selectedLabel returns selectedValue[labelPath].');
-});
-
-test('renders an li tag for each item in the items collection.', function () {
-  expect(2);
-
-  var component = this.subject();
-  var $component = this.$();
-
-  equal($component.find('li').length, 0, 'items collection is not set. No li tags are rendered.');
-
-  Ember.run(function() {
-    var items = Ember.ArrayProxy.create({ content: Ember.A([Ember.Object.create(), Ember.Object.create()])});
-    component.set('labelPath', 'name');
-    component.set('items', items);
-  });
-
-  equal($component.find('li').length, 2, 'items collection is set containing one item. One li tag is rendered.');
-});
-
-test('if no selected item nor defaultLabel set the selected value with first item', function () {
-  expect(1);
-
-  var items = [
-    'item1',
-    'item2'
-  ];
-
-  var component = this.subject({ items: items });
-  var $component = this.$();
-
-  equal(component.get('selectedValue'), 'item1', 'selectedValue is set to first item')
-});
-
-test('component actions', function() {
-  expect(7);
-
-  var targetObject = {
-    itemAdded: function() {
-      ok(true, 'External action itemAdded called')
-    },
-    itemEdited: function(item) {
-      ok(true, 'External action itemEdited called');
-      equal(item, 'editedItem', 'Data is sent with action');
-    },
-    itemRemoved: function(item) {
-      ok(true, 'External action itemRemoved called');
-      equal(item, 'removedItem', 'Data is sent with action');
-    }
-  };
-  var component = this.subject({
-    items: ['item'],
-    itemAdded: 'itemAdded',
-    itemEdited: 'itemEdited',
-    itemRemoved: 'itemRemoved',
-    targetObject: targetObject
-  });
-
-  var $component = this.$();
-
-  equal(component.get('selectedValue'), 'item', 'selectedValue is set to first item');
-
-  Ember.run(function() {
-    component.send('select', 'newItem');
-    component.send('add');
-    component.send('edit', 'editedItem');
-    component.send('remove', 'removedItem');
-  });
-
-  equal(component.get('selectedValue'), 'newItem', 'selectedValue is set to newItem');
-
-
-
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/components/tabs-wiget-test.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/components/tabs-wiget-test.js b/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/components/tabs-wiget-test.js
deleted file mode 100644
index 17b2242..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/components/tabs-wiget-test.js
+++ /dev/null
@@ -1,117 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-import { moduleForComponent, test } from 'ember-qunit';
-
-moduleForComponent('tabs-widget', 'TabsWidgetComponent', {
-  needs: []
-});
-
-test('First tab active by default', function() {
-  expect(2);
-
-  var tabs = Ember.ArrayProxy.create({content: Ember.A([
-    Ember.Object.create(),
-    Ember.Object.create()
-  ])});
-
-  var component = this.subject({ tabs: tabs });
-  var $component = this.$();
-
-  ok(component.get('tabs.firstObject.active'), 'First tab is active');
-  ok(!component.get('tabs.lastObject.active'), 'Second tab is not active');
-});
-
-
-test('Set active tab on init', function() {
-  expect(2);
-
-  var tabs = Ember.ArrayProxy.create({content: Ember.A([
-    Ember.Object.create(),
-    Ember.Object.create(),
-    Ember.Object.create({ active: true })
-  ])});
-
-  var component = this.subject({ tabs: tabs });
-
-  ok(!component.get('tabs.firstObject.active'), 'First tab is not active');
-  ok(component.get('tabs.lastObject.active'), 'Last tab is active');
-});
-
-
-test('Set active tab', function() {
-  expect(3);
-
-  var tabs = Ember.ArrayProxy.create({content: Ember.A([
-    Ember.Object.create(),
-    Ember.Object.create(),
-    Ember.Object.create({ active: true })
-  ])});
-
-  var component = this.subject({ tabs: tabs });
-
-  ok(!component.get('tabs.firstObject.active'), 'First tab is not active');
-  ok(component.get('tabs.lastObject.active'), 'Last tab is active');
-
-  Ember.run(function() {
-    component.send('selectTab', tabs.objectAt(1));
-  });
-
-  ok(component.get('tabs').objectAt(1).get('active'), 'Second tab is active');
-});
-
-test('removeEnabled tabs', function() {
-  expect(2);
-
-  var tabs = Ember.ArrayProxy.create({content: Ember.A([
-    Ember.Object.create(),
-    Ember.Object.create(),
-    Ember.Object.create({ active: true })
-  ])});
-
-  var component = this.subject({ tabs: tabs, canRemove: true });
-
-  ok(component.get('removeEnabled'), 'More than one tab removeEnabled returns true');
-
-  Ember.run(function() {
-    component.get('tabs').popObject();
-    component.get('tabs').popObject();
-  });
-
-  ok(!component.get('removeEnabled'), 'Only one tab removeEnabled returns false');
-});
-
-test('remove tab', function () {
-  expect(1);
-
-  var targetObject = {
-    removeTabAction: function() {
-      ok(true, 'External remove tab action called');
-    }
-  };
-
-  var component = this.subject({
-    'removeClicked': 'removeTabAction',
-    'targetObject': targetObject
-  });
-
-  Ember.run(function() {
-    component.send('remove', {});
-  });
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/components/typeahead-widget-test.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/components/typeahead-widget-test.js b/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/components/typeahead-widget-test.js
deleted file mode 100644
index 7d989a4..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/components/typeahead-widget-test.js
+++ /dev/null
@@ -1,46 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-import { moduleForComponent, test } from 'ember-qunit';
-
-moduleForComponent('typeahead-widget', 'TypeaheadWidgetComponent', {
-  needs: ['component:ember-selectize']
-});
-
-test('Component is initialized correctly', function () {
-  expect(2);
-
-  var items = [
-    {name: 'item 1', id: 1},
-    {name: 'item 2', id: 2},
-    {name: 'item 3', id: 3},
-    {name: 'item 4', id: 4}
-  ];
-
-  var component = this.subject({
-    content: items,
-    optionValuePath: 'content.id',
-    optionLabelPath: 'content.name'
-  });
-
-  this.$();
-
-  equal(component.get('content.length'), items.length, 'Items are set');
-  equal(component.get('selection'), items[0], 'First object is set as default value');
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/components/udf-tr-view-test.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/components/udf-tr-view-test.js b/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/components/udf-tr-view-test.js
deleted file mode 100644
index 18916de..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/components/udf-tr-view-test.js
+++ /dev/null
@@ -1,122 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-import { moduleForComponent, test } from 'ember-qunit';
-
-moduleForComponent('udf-tr-view', 'UdfTrViewComponent', {
-  unit: true,
-  needs: ['component:select-widget']
-});
-
-test('Can send actions', function (assert) {
-  assert.expect(6);
-
-  var targetObject = {
-    onDeleteUdf: function () {
-      assert.ok(true, 'onDeleteUdf called');
-    },
-    onAddFileResource: function () {
-      assert.ok(true, 'onAddFileResource called');
-    },
-    onDeleteFileResource: function () {
-      assert.ok(true, 'onDeleteFileResource called');
-    },
-    onSaveUdf: function () {
-      assert.ok(true, 'onSaveUdf called');
-    },
-  };
-
-  var component = this.subject({
-    onDeleteUdf: 'onDeleteUdf',
-    onAddFileResource: 'onAddFileResource',
-    onDeleteFileResource: 'onDeleteFileResource',
-    onSaveUdf: 'onSaveUdf',
-
-    targetObject: targetObject,
-
-    udf: Ember.Object.create()
-  });
-
-  Ember.run(function () {
-    component.send('deleteUdf');
-    component.send('addFileResource');
-    component.send('deleteFileResource');
-    component.send('save');
-
-    component.send('editUdf');
-    component.send('editFileResource', {});
-  });
-
-  assert.ok(component.get('udf.isEditing'), 'Can edit udf');
-  assert.ok(component.get('udf.isEditingResource'), 'Can edit resource');
-});
-
-test('It sets isEditing to true if udf.isNew', function (assert) {
-  assert.expect(1);
-
-  var component = this.subject({
-    udf: Ember.Object.create({
-      isNew: true,
-      isEditing: false
-    })
-  });
-
-  var $component = this.render();
-  assert.ok(component.get('udf.isEditing'), 'isEditing set to true');
-});
-
-test('Cancel edit whould rollback changes', function (assert) {
-  assert.expect(5);
-
-  var backup = 'fileResource backup';
-  var file = Ember.Object.create({
-    rollback: function () {
-      assert.ok(true, 'file.rollback() called');
-    }
-  });
-
-  var udf = Ember.Object.create({
-    isEditing: true,
-    isEditingResource: true,
-    get: function () {
-      var defer = new Ember.RSVP.defer;
-      defer.resolve(file);
-
-      return defer.promise;
-    },
-    rollback: function () {
-      assert.ok(true, 'udf.rollback() called');
-    }
-  });
-
-  var component = this.subject({
-    file: file,
-    udf: udf,
-    fileBackup: backup
-  });
-
-  Ember.run(function () {
-    component.send('cancel');
-  });
-
-  assert.ok(!component.get('udf.isEditing'), 'isEditing set to false');
-  assert.ok(!component.get('udf.isEditingResource'), 'isEditingResource set to false');
-
-  assert.equal(component.get('udf.fileResource'), backup, 'backup is set as file resource');
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/controllers/databases-test.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/controllers/databases-test.js b/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/controllers/databases-test.js
deleted file mode 100644
index c3ac272..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/controllers/databases-test.js
+++ /dev/null
@@ -1,276 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-import { moduleFor, test } from 'ember-qunit';
-
-var controller;
-var store;
-
-moduleFor('controller:databases', 'DatabasesController', {
-  needs: [ 'adapter:database',
-           'service:database',
-           'service:notify',
-           'model:database' ],
-
-  setup: function () {
-    //mock getDatabases which is called on controller init
-    this.container.lookup('service:database').getDatabases = function () {
-      var defer = Ember.RSVP.defer();
-
-      defer.resolve();
-
-      return defer.promise;
-    };
-
-    //mock getDatabasesFromServer which is called by the poller
-    this.container.lookup('service:database').getDatabasesFromServer = function () {
-     var defer = Ember.RSVP.defer();
-
-     var databases = [ "database_a", "database_b"];
-
-     defer.resolve(databases);
-     return defer.promise;
-     };
-
-    store = this.container.lookup('store:main');
-    controller = this.subject();
-    controller.store = store;
-
-  },
-
-  teardown: function () {
-    Ember.run(controller, controller.destroy);
-  }
-});
-
-test('controller is initialized properly.', function () {
-  expect(5);
-
-  var controller = this.subject();
-
-  ok(controller.get('tableSearchResults'), 'table search results collection was initialized.');
-  ok(controller.get('tabs'), 'tabs collection was initialized.');
-  equal(controller.get('tabs.length'), 2, 'tabs collection contains two tabs');
-  equal(controller.get('tabs').objectAt(0).get('name'), Ember.I18n.t('titles.explorer'), 'first tab is database explorer.');
-  equal(controller.get('tabs').objectAt(1).get('name'), Ember.I18n.t('titles.results'), 'second tab is search results');
-});
-
-test('setTablePageAvailability sets canGetNextPage true if given database hasNext flag is true.', function () {
-  expect(1);
-
-  var database = Ember.Object.create( { hasNext: true } );
-
-  controller.setTablePageAvailability(database);
-
-  equal(database.get('canGetNextPage'), true);
-});
-
-test('setTablePageAvailability sets canGetNextPage true if given database has more loaded tables than the visible ones.', function () {
-  expect(1);
-
-  var database = Ember.Object.create({
-    tables: [1],
-    visibleTables: []
-  });
-
-  controller.setTablePageAvailability(database);
-
-  equal(database.get('canGetNextPage'), true);
-});
-
-test('setTablePageAvailability sets canGetNextPage falsy if given database hasNext flag is falsy and all loaded tables are visible.', function () {
-  expect(1);
-
-  var database = Ember.Object.create({
-    tables: [1],
-    visibleTables: [1]
-  });
-
-  controller.setTablePageAvailability(database);
-
-  ok(!database.get('canGetNextPage'));
-});
-
-test('setColumnPageAvailability sets canGetNextPage true if given table hasNext flag is true.', function () {
-  expect(1);
-
-  var table = Ember.Object.create( { hasNext: true } );
-
-  controller.setColumnPageAvailability(table);
-
-  equal(table.get('canGetNextPage'), true);
-});
-
-test('setColumnPageAvailability sets canGetNextPage true if given table has more loaded columns than the visible ones.', function () {
-  expect(1);
-
-  var table = Ember.Object.create({
-    columns: [1],
-    visibleColumns: []
-  });
-
-  controller.setColumnPageAvailability(table);
-
-  equal(table.get('canGetNextPage'), true);
-});
-
-test('setColumnPageAvailability sets canGetNextPage true if given database hasNext flag is falsy and all loaded columns are visible.', function () {
-  expect(1);
-
-  var table = Ember.Object.create({
-    columns: [1],
-    visibleColumns: [1]
-  });
-
-  controller.setColumnPageAvailability(table);
-
-  ok(!table.get('canGetNextPage'));
-});
-
-test('getTables sets the visibleTables as the first page of tables if they are already loaded', function () {
-  expect(2);
-
-  var database = Ember.Object.create({
-    name: 'test_db',
-    tables: [1, 2, 3]
-  });
-
-  controller.get('databases').pushObject(database);
-  controller.set('pageCount', 2);
-
-  controller.send('getTables', 'test_db');
-
-  equal(database.get('visibleTables.length'), controller.get('pageCount'), 'there are 2 visible tables out of 3.');
-  equal(database.get('canGetNextPage'), true, 'user can get next tables page.');
-});
-
-test('getColumns sets the visibleColumns as the first page of columns if they are already loaded.', function () {
-  expect(2);
-
-  var table = Ember.Object.create({
-    name: 'test_table',
-    columns: [1, 2, 3]
-  });
-
-  var database = Ember.Object.create({
-    name: 'test_db',
-    tables: [ table ],
-    visibleTables: [ table ]
-  });
-
-  controller.set('pageCount', 2);
-
-  controller.send('getColumns', 'test_table', database);
-
-  equal(table.get('visibleColumns.length'), controller.get('pageCount'), 'there are 2 visible columns out of 3.');
-  equal(table.get('canGetNextPage'), true, 'user can get next columns page.');
-});
-
-test('showMoreTables pushes more tables to visibleTables if there are still hidden tables loaded.', function () {
-  expect(2);
-
-  var database = Ember.Object.create({
-    name: 'test_db',
-    tables: [1, 2, 3],
-    visibleTables: [1]
-  });
-
-  controller.get('databases').pushObject(database);
-  controller.set('pageCount', 1);
-
-  controller.send('showMoreTables', database);
-
-  equal(database.get('visibleTables.length'), controller.get('pageCount') * 2, 'there are 2 visible tables out of 3.');
-  equal(database.get('canGetNextPage'), true, 'user can get next tables page.');
-});
-
-test('showMoreColumns pushes more columns to visibleColumns if there are still hidden columns loaded.', function () {
-  expect(2);
-
-  var table = Ember.Object.create({
-    name: 'test_table',
-    columns: [1, 2, 3],
-    visibleColumns: [1]
-  });
-
-  var database = Ember.Object.create({
-    name: 'test_db',
-    tables: [ table ],
-    visibleTables: [ table ]
-  });
-
-  controller.set('pageCount', 1);
-
-  controller.send('showMoreColumns', table, database);
-
-  equal(table.get('visibleColumns.length'), controller.get('pageCount') * 2, 'there are 2 visible columns out of 3.');
-  equal(table.get('canGetNextPage'), true, 'user can get next columns page.');
-});
-
-test('syncDatabases pushed more databases when new databases are added in the backend', function() {
-  expect(3);
-
-  var databaseA = {
-    id: "database_a",
-    name: "database_a"
-  };
-
-  Ember.run(function() {
-    store.createRecord('database', databaseA);
-    controller.syncDatabases();
-  });
-
-  var latestDbNames = store.all('database').mapBy('name');
-  equal(latestDbNames.length, 2, "There is 1 additional database added to hive");
-  equal(latestDbNames.contains("database_a"), true, "New database list should contain the old database name.");
-  equal(latestDbNames.contains("database_b"), true, "New database list should contain the new database name.");
-});
-
-test('syncDatabases removed database when old databases are removed in the backend', function() {
-  expect(4);
-
-  var latestDbNames;
-
-  var databaseA = {
-    id: "database_a",
-    name: "database_a"
-  };
-  var databaseB = {
-    id: "database_b",
-    name: "database_b"
-  };
-  var databaseC = {
-    id: "database_c",
-    name: "database_c"
-  };
-
-  Ember.run(function() {
-    store.createRecord('database', databaseA);
-    store.createRecord('database', databaseB);
-    store.createRecord('database', databaseC);
-    controller.syncDatabases();
-  });
-
-  latestDbNames = store.all('database').mapBy('name');
-  equal(latestDbNames.length, 2, "One database is removed from hive");
-  equal(latestDbNames.contains("database_a"), true, "New database list should contain the old database name.");
-  equal(latestDbNames.contains("database_b"), true, "New database list should contain the old database name.");
-  equal(latestDbNames.contains("database_c"), false, "New database list should not contain the database name removed in the backend.");
-
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/controllers/history-test.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/controllers/history-test.js b/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/controllers/history-test.js
deleted file mode 100644
index ab45214..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/controllers/history-test.js
+++ /dev/null
@@ -1,117 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-import { moduleFor, test } from 'ember-qunit';
-
-moduleFor('controller:history', 'HistoryController', {
-  needs: [ 'service:file', 'service:job' ]
-});
-
-test('controller is initialized correctly', function () {
-  expect(1);
-
-  var component = this.subject();
-
-  equal(component.get('columns.length'), 4, 'Columns are initialized');
-});
-
-test('date range is set correctly', function () {
-  expect(2);
-
-  var component = this.subject();
-  var min = parseInt(Date.now() / 1000) - (60 * 60 * 24 * 60);
-  var max = parseInt(Date.now() / 1000);
-
-  var history = Ember.ArrayProxy.create({ content: [
-    Ember.Object.create({
-      dateSubmittedTimestamp: min
-    }),
-    Ember.Object.create({
-      dateSubmittedTimestamp: max
-    })
-  ]});
-
-  Ember.run(function() {
-    component.set('history', history);
-  });
-
-  var dateColumn = component.get('columns').find(function (column) {
-    return column.get('caption') === 'columns.date';
-  });
-
-  equal(dateColumn.get('dateRange.min'), min, 'Min date is set correctly');
-  equal(dateColumn.get('dateRange.max'), max, 'Max date is set correctly');
-});
-
-test('interval duration is set correctly', function () {
-  expect(2);
-
-  var component = this.subject();
-
-  var history = Ember.ArrayProxy.create({ content: [
-    Ember.Object.create({
-      duration: 20
-    }),
-    Ember.Object.create({
-      duration: 300
-    })
-  ]});
-
-  Ember.run(function() {
-    component.set('history', history);
-  });
-
-  var durationColumn = component.get('columns').find(function (column) {
-    return column.get('caption') === 'columns.duration';
-  });
-
-  equal(durationColumn.get('numberRange.min'), 20, 'Min value is set correctly');
-  equal(durationColumn.get('numberRange.max'), 300, 'Max value is set correctly');
-});
-
-test('history filtering', function() {
-  expect(2);
-
-  var component = this.subject();
-
-  var history = Ember.ArrayProxy.create({
-    content: [
-      Ember.Object.create({
-        name: 'HISTORY',
-        status: 1
-      }),
-      Ember.Object.create({
-        name: '1HISTORY',
-        status: 2
-      })
-    ]
-  });
-
-  Ember.run(function() {
-    component.set('history', history);
-  });
-
-  equal(component.get('model.length'), 2, 'No filters applied we have 2 models');
-
-  Ember.run(function() {
-    component.filterBy('name', 'HISTORY', true);
-  });
-
-  equal(component.get('model.length'), 1, 'Filter by name we have 1 filtered model');
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/controllers/index-test.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/controllers/index-test.js b/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/controllers/index-test.js
deleted file mode 100644
index 290f61e..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/controllers/index-test.js
+++ /dev/null
@@ -1,328 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-import { moduleFor, test } from 'ember-qunit';
-import constants from 'hive/utils/constants';
-
-moduleFor('controller:index', 'IndexController', {
-  needs: [
-          'controller:open-queries',
-          'controller:udfs',
-          'controller:index/history-query/logs',
-          'controller:index/history-query/results',
-          'controller:index/history-query/explain',
-          'controller:settings',
-          'controller:visual-explain',
-          'controller:tez-ui',
-          'service:job',
-          'service:file',
-          'service:database',
-          'service:notify',
-          'service:job-progress',
-          'service:session',
-          'service:settings',
-          'adapter:application',
-          'adapter:database'
-        ]
-});
-
-test('modelChanged calls update on the open-queries cotnroller.', function () {
-  expect(1);
-
-  var controller = this.subject();
-
-  controller.set('openQueries.update', function () {
-    var defer = Ember.RSVP.defer();
-
-    ok(true, 'index model has changed. update was called on open-queries controller.');
-
-    defer.resolve();
-
-    return defer.promise;
-  });
-
-  Ember.run(function () {
-    controller.set('model', Ember.Object.create());
-  });
-});
-
-test('bindQueryParams replaces param placeholder with values', function() {
-  expect(1);
-
-  var controller = this.subject();
-  var queryParams = [
-    { name: '$what', value: 'color' },
-    { name: '$where', value: 'z'}
-  ];
-
-  var query = "select $what from $where";
-  var replacedQuery = "select color from z";
-
-  Ember.run(function() {
-    controller.get('queryParams').setObjects(queryParams);
-  });
-
-  equal(controller.bindQueryParams(query), replacedQuery, 'Params replaced correctly');
-});
-
-test('bindQueryParams replaces same param multiple times', function() {
-  expect(1);
-
-  var controller = this.subject();
-  var queryParams = [
-    { name: '$what', value: 'color' },
-    { name: '$where', value: 'z'}
-  ];
-
-  var query = "select $what from $where as $what";
-  var replacedQuery = "select color from z as color";
-
-  Ember.run(function() {
-    controller.get('queryParams').setObjects(queryParams);
-  });
-
-  equal(controller.bindQueryParams(query), replacedQuery, 'Params replaced correctly');
-});
-
-test('parseQueryParams sets queryParams when query changes', function() {
-  expect(4);
-
-
-  var query = Ember.Object.create({
-    id: 1,
-    fileContent: "select $what from $where"
-  });
-  var updatedQuery = "select $what from $where and $where";
-
-  var controller = this.subject({
-    model: query
-  });
-
-  Ember.run(function() {
-    controller.set('openQueries.queryTabs', [query]);
-    controller.set('openQueries.currentQuery', query);
-  });
-
-  equal(controller.get('queryParams.length'), 2, '2 queryParams parsed');
-  equal(controller.get('queryParams').objectAt(0).name, '$what', 'First param parsed correctly');
-  equal(controller.get('queryParams').objectAt(1).name, '$where', 'Second param parsed correctly');
-
-  Ember.run(function() {
-    controller.set('openQueries.currentQuery.fileContent', updatedQuery);
-  });
-
-  equal(controller.get('queryParams.length'), 2, 'Can use same param multiple times');
-});
-
-test('canExecute return false if query is executing', function() {
-  expect(2);
-  var controller = this.subject();
-
-  Ember.run(function() {
-    controller.set('openQueries.update', function () {
-      var defer = Ember.RSVP.defer();
-      defer.resolve();
-      return defer.promise;
-    });
-
-    controller.set('model', Ember.Object.create({ 'isRunning': false }));
-    controller.set('queryParams', []);
-  });
-
-  ok(controller.get('canExecute'), 'Query is not executing => canExecute return true');
-
-  Ember.run(function() {
-    controller.set('model', Ember.Object.create({ 'isRunning': true }));
-  });
-
-  ok(!controller.get('canExecute'), 'Query is executing => canExecute return false');
-});
-
-test('canExecute return false if queryParams doesnt\'t have values', function() {
-  expect(2);
-  var controller = this.subject();
-
-  var paramsWithoutValues = [
-    { name: '$what', value: '' },
-    { name: '$where', value: '' }
-  ];
-
-  var paramsWithValues = [
-    { name: '$what', value: 'value1' },
-    { name: '$where', value: 'value2' }
-  ];
-
-  Ember.run(function() {
-    controller.set('openQueries.update', function () {
-      var defer = Ember.RSVP.defer();
-      defer.resolve();
-      return defer.promise;
-    });
-    controller.set('model', Ember.Object.create({ 'isRunning': false }));
-    controller.get('queryParams').setObjects(paramsWithoutValues);
-  });
-
-  ok(!controller.get('canExecute'), 'Params without value => canExecute return false');
-
-  Ember.run(function() {
-    controller.get('queryParams').setObjects(paramsWithValues);
-  });
-
-  ok(controller.get('canExecute'), 'Params with values => canExecute return true');
-});
-
-test('Execute EXPLAIN type query', function() {
-  expect(1);
-
-  var query = Ember.Object.create({
-    id: 1,
-    fileContent: "explain select 1" // explain type query
-  });
-
-  var controller = this.subject({
-    model: query,
-    _executeQuery: function (referer) {
-      equal(referer, constants.jobReferrer.explain, 'Explain type query successful.');
-      return {then: function() {}};
-    }
-  });
-
-  Ember.run(function() {
-      controller.set('openQueries.queryTabs', [query]);
-      controller.set('openQueries.currentQuery', query);
-      controller.send('executeQuery');
-  });
-
-});
-
-test('Execute non EXPLAIN type query', function() {
-  expect(1);
-
-  var query = Ember.Object.create({
-    id: 1,
-    fileContent: "select 1" //non explain type query
-  });
-
-  var controller = this.subject({
-    model: query,
-    _executeQuery: function (referer) {
-      equal(referer, constants.jobReferrer.job , 'non Explain type query successful.');
-      return {then: function() {}};
-    }
-  });
-
-  Ember.run(function() {
-      controller.set('openQueries.queryTabs', [query]);
-      controller.set('openQueries.currentQuery', query);
-      controller.send('executeQuery');
-  });
-
-});
-
-
-test('csvUrl returns if the current query is not a job', function() {
-  expect(1);
-  var content = Ember.Object.create({
-      constructor: {
-        typeKey: 'notJob'
-      }
-  });
-
-  var controller = this.subject({ content: content });
-  ok(!controller.get('csvUrl'), 'returns if current query is not a job');
-});
-
-test('csvUrl returns is status in not SUCCEEDED', function() {
-  expect(1);
-  var content= Ember.Object.create({
-      constructor: {
-        typeKey: 'job'
-      },
-      status: 'notSuccess'
-  });
-
-  var controller = this.subject({ content: content });
-  ok(!controller.get('csvUrl'), 'returns if current status is not success');
-});
-
-test('csvUrl return the download results as csv link', function() {
-  expect(1);
-  var content = Ember.Object.create({
-      constructor: {
-        typeKey: 'job'
-      },
-      status: 'SUCCEEDED',
-      id: 1
-  });
-
-  var controller = this.subject({ content: content });
-  ok(controller.get('csvUrl'));
-});
-
-test('donwloadMenu returns null if status is not succes and results are not visible ', function() {
-  expect(1);
-  var content = Ember.Object.create({
-      status: 'notSuccess',
-      queryProcessTabs: [{
-        path: 'index.historyQuery.results',
-        visible: false
-      }]
-  });
-
-  var controller = this.subject({ content: content });
-  ok(!controller.get('downloadMenu'), 'Returns null');
-});
-
-test('donwloadMenu returns only saveToHDFS if csvUrl is false', function() {
-  expect(1);
-  var content = Ember.Object.create({
-      constructor: {
-        typeKey: 'notjob'
-      },
-      status: 'SUCCEEDED',
-  });
-
-  var controller = this.subject({ content: content });
-  Ember.run(function() {
-    var tabs = controller.get('queryProcessTabs');
-    var results = tabs.findBy('path', 'index.historyQuery.results');
-    results.set('visible', true);
-  });
-
-  equal(controller.get('downloadMenu.length'), 1, 'Returns only saveToHDFS');
-});
-
-test('donwloadMenu returns saveToHDFS and csvUrl', function() {
-  expect(1);
-  var content = Ember.Object.create({
-      constructor: {
-        typeKey: 'job'
-      },
-      status: 'SUCCEEDED',
-  });
-
-  var controller = this.subject({ content: content });
-  Ember.run(function() {
-    var tabs = controller.get('queryProcessTabs');
-    var results = tabs.findBy('path', 'index.historyQuery.results');
-    results.set('visible', true);
-  });
-
-  equal(controller.get('downloadMenu.length'), 2, 'Returns saveToHDFS and csvUrl');
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/controllers/insert-udfs-test.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/controllers/insert-udfs-test.js b/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/controllers/insert-udfs-test.js
deleted file mode 100644
index e770bdd..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/controllers/insert-udfs-test.js
+++ /dev/null
@@ -1,68 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-import { moduleFor, test } from 'ember-qunit';
-
-moduleFor('controller:insert-udfs', 'InsertUdfsController', {
-  needs: 'controller:udfs'
-});
-
-test('controller is initialized correctly', function () {
-  expect(1);
-
-  var udfs = Ember.A([
-    Ember.Object.create({ fileResource: { id: 1 } }),
-    Ember.Object.create({ fileResource: { id: 1 } }),
-    Ember.Object.create({ fileResource: { id: 2 } }),
-    Ember.Object.create({ fileResource: { id: 2 } })
-  ]);
-
-  var component = this.subject();
-
-  Ember.run(function() {
-    component.set('udfs', udfs);
-  });
-
-  equal(component.get('length'), 2, 'should contain unique file resources');
-});
-
-test('controller updates on new udfs', function () {
-  expect(2);
-
-  var udfs = Ember.A([
-    Ember.Object.create({ fileResource: { id: 1 } }),
-    Ember.Object.create({ fileResource: { id: 2 } }),
-  ]);
-
-  var component = this.subject();
-
-  Ember.run(function() {
-    component.set('udfs', udfs);
-  });
-
-  equal(component.get('length'), 2, '');
-
-  var newUdf = Ember.Object.create({ isNew: true, fileResource: { id: 3 } });
-
-  Ember.run(function() {
-    component.get('udfs').pushObject(newUdf);
-  });
-
-  equal(component.get('length'), 3, '');
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/controllers/messages-test.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/controllers/messages-test.js b/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/controllers/messages-test.js
deleted file mode 100644
index b0cdf16..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/controllers/messages-test.js
+++ /dev/null
@@ -1,53 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-import constants from 'hive/utils/constants';
-import { moduleFor, test } from 'ember-qunit';
-
-moduleFor('controller:messages', 'MessagesController', {
-});
-
-test('Controller is initialized', function() {
-  var controller = this.subject();
-
-  ok(controller, 'Controller is initialized');
-});
-
-test('Controller action', function() {
-  var controller = this.subject({
-    notifyService: Ember.Object.create({
-      removeMessage: function(message) {
-        ok(1, 'removeMessage action called');
-      },
-      removeAllMessages: function() {
-        ok(1, 'removeAllMessages action called');
-      },
-      markMessagesAsSeen: function(message) {
-        ok(1, 'markMessagesAsSeen action called');
-      }
-    })
-  });
-
-  Ember.run(function() {
-    controller.send('removeMessage');
-    controller.send('removeAllMessages');
-    controller.send('markMessagesAsSeen');
-  });
-
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/controllers/open-queries-test.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/controllers/open-queries-test.js b/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/controllers/open-queries-test.js
deleted file mode 100644
index c46134d..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/controllers/open-queries-test.js
+++ /dev/null
@@ -1,102 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-import { moduleFor, test } from 'ember-qunit';
-
-moduleFor('controller:open-queries', 'OpenQueriesController', {
-  needs: [ 'controller:index/history-query/results',
-           'controller:index/history-query/explain',
-           'controller:index',
-           'controller:settings',
-           'service:file',
-           'service:database'
-         ]
-});
-
-test('when initialized, controller sets the queryTabs.', function () {
-  expect(1);
-
-  var controller = this.subject();
-
-  ok(controller.get('queryTabs', 'queryTabs is initialized.'));
-});
-
-test('pushObject override creates a new queryFile mock and adds it to the collection if none provided.', function () {
-  expect(3);
-
-  var controller = this.subject();
-
-  var model = Ember.Object.create({
-    id: 5
-  });
-
-  controller.pushObject(null, model);
-
-  equal(controller.get('length'), 1, 'a new object was added to the open queries collection.');
-  equal(controller.objectAt(0).id, model.get('id'), 'the object id was set to the model id.');
-  equal(controller.objectAt(0).get('fileContent'), '', 'the object fileContent is initialized with empty string.');
-});
-
-test('getTabForModel retrieves the tab that has the id and the type equal to the ones of the given model.', function () {
-  expect(1);
-
-  var controller = this.subject();
-
-  var model = Ember.Object.create({
-    id: 1
-  });
-
-  controller.get('queryTabs').pushObject(Ember.Object.create({
-    id: model.get('id')
-  }));
-
-  equal(controller.getTabForModel(model), controller.get('queryTabs').objectAt(0), 'retrieves correct tab for the given model.');
-});
-
-test('getQueryForModel retrieves the query by id equality if a new record is given', function () {
-  expect(1);
-
-  var controller = this.subject();
-
-  var model = Ember.Object.create({
-    id: 1,
-    isNew: true
-  });
-
-  controller.pushObject(null, model);
-
-  equal(controller.getQueryForModel(model).get('id'), model.get('id'), 'a new record was given, the method retrieves the query by id equality');
-});
-
-test('getQueryForModel retrieves the query by record id equality with model queryFile path if a saved record is given', function () {
-  expect(1);
-
-  var controller = this.subject();
-
-  var model = Ember.Object.create({
-    id: 1,
-    queryFile: 'some/path'
-  });
-
-  controller.pushObject(Ember.Object.create({
-    id: model.get('queryFile')
-  }));
-
-  equal(controller.getQueryForModel(model).get('id'), model.get('queryFile'), 'a saved record was given, the method retrieves the query by id equality with record queryFile path.');
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/controllers/queries-test.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/controllers/queries-test.js b/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/controllers/queries-test.js
deleted file mode 100644
index 2578c33..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/controllers/queries-test.js
+++ /dev/null
@@ -1,35 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-import { moduleFor, test } from 'ember-qunit';
-
-moduleFor('controller:queries', 'QueriesController', {
-  needs: [
-    'controller:history',
-    'controller:open-queries'
-  ]
-});
-
-test('controller is initialized', function() {
-  expect(1);
-
-  var component = this.subject();
-
-  equal(component.get('columns.length'), 4, 'Columns are initialized correctly');
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/controllers/settings-test.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/controllers/settings-test.js b/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/controllers/settings-test.js
deleted file mode 100644
index 366d18c..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/controllers/settings-test.js
+++ /dev/null
@@ -1,136 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-import { moduleFor, test } from 'ember-qunit';
-
-moduleFor('controller:settings', 'SettingsController', {
-  needs: [
-    'controller:databases',
-    'controller:index',
-    'controller:open-queries',
-    'controller:index/history-query/results',
-    'controller:index/history-query/explain',
-    'controller:udfs',
-    'controller:index/history-query/logs',
-    'controller:visual-explain',
-    'controller:tez-ui',
-    'adapter:database',
-    'adapter:application',
-    'service:settings',
-    'service:notify',
-    'service:database',
-    'service:file',
-    'service:session',
-    'service:job',
-    'service:job-progress'
-  ]
-});
-
-test('can add a setting', function() {
-  var controller = this.subject();
-
-  ok(!controller.get('settings.length'), 'No initial settings');
-
-  Ember.run(function() {
-    controller.send('add');
-  });
-
-  equal(controller.get('settings.length'), 1, 'Can add settings');
-});
-
-test('validate', function() {
-  var predefinedSettings = [
-    {
-      name: 'some.key',
-      validate: new RegExp(/^\d+$/) // digits
-    }
-  ];
-
-  var controller = this.subject({
-    predefinedSettings: predefinedSettings
-  });
-
-  controller.set('openQueries.update', function () {
-    var defer = Ember.RSVP.defer();
-    defer.resolve();
-
-    return defer.promise;
-  });
-
-  var settings = [
-    Ember.Object.create({key: { name: 'some.key' }, value: 'value'}),
-    Ember.Object.create({key: { name: 'some.key' }, value: '123'})
-  ];
-
-  Ember.run(function() {
-    controller.set('settings', settings);
-  });
-
-  var currentSettings = controller.get('settings');
-  ok(!currentSettings.get('firstObject.valid'), "First setting doesn\' pass validataion");
-  ok(currentSettings.get('lastObject.valid'), 'Second setting passes validation');
-});
-
-test('Actions', function(assert) {
-  assert.expect(5);
-
-  var settingsService = Ember.Object.create({
-    add: function() {
-      assert.ok(true, 'add called');
-    },
-    remove: function(setting) {
-      assert.ok(setting, 'Setting param is sent');
-    },
-    createKey: function(name) {
-      assert.ok(name, 'Name param is sent');
-    },
-    removeAll: function() {
-      assert.ok(true, 'removeAll called');
-    },
-    saveDefaultSettings: function() {
-      assert.ok(true, 'saveDefaultSettings called');
-    }
-  });
-
-  var controller = this.subject();
-  controller.set('settingsService', settingsService);
-
-  Ember.run(function() {
-    controller.send('add');
-    controller.send('remove', {});
-    controller.send('addKey', {});
-    controller.send('removeAll');
-    controller.send('saveDefaultSettings');
-  });
-});
-
-
-test('Excluded settings', function(assert) {
-  var controller = this.subject();
-
-  console.log(controller.get('predefinedSettings'));
-  assert.equal(controller.get('excluded').length, 0, 'Initially there are no excluded settings');
-
-  Ember.run(function() {
-    controller.get('settings').pushObject(Ember.Object.create({ key: { name: 'hive.tez.container.size' }}));
-    controller.get('settings').pushObject(Ember.Object.create({ key: { name: 'hive.prewarm.enabled' }}));
-  });
-
-  assert.equal(controller.get('excluded').length, 2, 'Two settings are excluded');
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/controllers/tez-ui-test.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/controllers/tez-ui-test.js b/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/controllers/tez-ui-test.js
deleted file mode 100644
index fdf4a89..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/controllers/tez-ui-test.js
+++ /dev/null
@@ -1,98 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-import DS from 'ember-data';
-import { moduleFor, test } from 'ember-qunit';
-
-var container;
-
-moduleFor('controller:tez-ui', 'TezUIController', {
-  needs: [
-    'controller:index',
-    'service:job',
-    'service:file',
-    'controller:open-queries',
-    'controller:databases',
-    'controller:udfs',
-    'controller:index/history-query/logs',
-    'controller:index/history-query/results',
-    'controller:index/history-query/explain',
-    'controller:settings',
-    'controller:visual-explain',
-    'adapter:database',
-    'service:database',
-    'service:notify',
-    'service:job-progress',
-    'service:session',
-    'service:settings'
-  ],
-
-  setup: function() {
-    container = new Ember.Container();
-    container.register('store:main', Ember.Object.extend({
-      find: Ember.K
-    }));
-  }
-});
-
-test('controller is initialized properly.', function () {
-  expect(1);
-
-  var controller = this.subject();
-
-  ok(controller);
-});
-
-test('dagId returns false if there is  no tez view available', function() {
-  var controller = this.subject();
-
-  ok(!controller.get('dagId'), 'dagId is false without a tez view available');
-});
-
-// test('dagId returns the id if there is view available', function() {
-//   var controller = this.subject({
-//   });
-
-//   Ember.run(function() {
-//     controller.set('index.model', Ember.Object.create({
-//       id: 2,
-//       dagId: 3
-//     }));
-
-//     controller.set('isTezViewAvailable', true);
-//   });
-
-//   equal(controller.get('dagId'), 3, 'dagId is truthy');
-// });
-
-test('dagURL returns false if no dag id is available', function() {
-  var controller = this.subject();
-
-  ok(!controller.get('dagURL'), 'dagURL is false');
-});
-
-test('dagURL returns the url if dag id is available', function() {
-  var controller = this.subject({
-    tezViewURL: '1',
-    tezDagPath: '2',
-    dagId: '3'
-  });
-
-  equal(controller.get('dagURL'), '123');
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/controllers/udfs-test.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/controllers/udfs-test.js b/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/controllers/udfs-test.js
deleted file mode 100644
index 2568d4a..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/controllers/udfs-test.js
+++ /dev/null
@@ -1,82 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-import { moduleFor, test } from 'ember-qunit';
-
-moduleFor('controller:udfs', 'UdfsController', {
-  needs: [
-    'model:file-resource'
-  ]
-});
-
-test('controller is initialized', function() {
-  expect(3);
-
-  var component = this.subject();
-
-  equal(component.get('columns.length'), 2, 'Columns are initialized correctly');
-  ok(component.get('sortAscending'), 'Sort ascending is true');
-  equal(component.get('sortProperties.length'), 0, 'sortProperties is empty');
-});
-
-test('sort', function() {
- expect(2);
-
-  var component = this.subject();
-
-  Ember.run(function () {
-    component.send('sort', 'prop');
-  });
-
-  ok(component.get('sortAscending'), 'New sort prop sortAscending is set to true');
-  equal(component.get('sortProperties').objectAt(0), "prop", 'sortProperties is set to prop');
-});
-
-test('add', function() {
-  expect(1);
-
-  var store = {
-    createRecord: function(name) {
-      ok(name, 'store.createRecord called');
-    }
-  };
-  var component = this.subject({ store: store });
-
-  Ember.run(function () {
-    component.send('add');
-  });
-});
-
-test('handleAddFileResource', function (assert) {
-  assert.expect(2);
-
-  var udf = Ember.Object.create({
-    isEditingResource: false,
-    fileResource: null
-  });
-
-  var controller = this.subject();
-
-  Ember.run(function () {
-    controller.send('handleAddFileResource', udf);
-  });
-
-  assert.ok(udf.get('fileResource'), 'File Resource created');
-  assert.ok(udf.get('isEditingResource'), 'Editing mode in enabled');
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/helpers/path-binding-test.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/helpers/path-binding-test.js b/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/helpers/path-binding-test.js
deleted file mode 100644
index 22ba58a..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/helpers/path-binding-test.js
+++ /dev/null
@@ -1,35 +0,0 @@
-/**
- * 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.
- */
-
-import {
-  pathBinding
-} from 'hive/helpers/path-binding';
-
-import Ember from 'ember';
-
-module('PathBindingHelper');
-
-// Replace this with your real tests.
-test('it should retrieve property value for a given object.', function() {
-  var obj = Ember.Object.extend({
-    name: 'some name'
-  }).create();
-
-  var result = pathBinding(obj, 'name');
-  equal(result, obj.get('name'));
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/services/notify-test.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/services/notify-test.js b/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/services/notify-test.js
deleted file mode 100644
index 383bf31..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/services/notify-test.js
+++ /dev/null
@@ -1,155 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-import { moduleFor, test } from 'ember-qunit';
-
-moduleFor('service:notify', 'NotifyService');
-
-test('Service initialized correctly', function () {
-  expect(3);
-
-  var service = this.subject();
-  service.removeAllMessages();
-  service.markMessagesAsSeen();
-
-  equal(service.get('messages.length'), 0, 'No messages');
-  equal(service.get('notifications.length'), 0, 'No notifications');
-  equal(service.get('unseenMessages.length'), 0, 'No unseenMessages');
-});
-
-test('Can add notification', function() {
-  expect(3);
-  var service = this.subject();
-
-  service.add('notif', 'message', 'body');
-
-  equal(service.get('messages.length'), 1, 'one message added');
-  equal(service.get('notifications.length'), 1, 'one notifications added');
-  equal(service.get('unseenMessages.length'), 1, 'one unseenMessages added');
-});
-
-test('Can add info notification', function() {
-  expect(1);
-  var service = this.subject();
-
-  service.info('message', 'body');
-  equal(service.get('messages.lastObject.type.typeClass'), 'alert-info', 'Info notification added');
-});
-
-test('Can add warn notification', function() {
-  expect(1);
-  var service = this.subject();
-
-  service.warn('message', 'body');
-  equal(service.get('messages.lastObject.type.typeClass'), 'alert-warning', 'Warn notification added');
-});
-
-test('Can add error notification', function() {
-  expect(1);
-  var service = this.subject();
-
-  service.error('message', 'body');
-  equal(service.get('messages.lastObject.type.typeClass'), 'alert-danger', 'Error notification added');
-});
-
-test('Can add success notification', function() {
-  expect(1);
-  var service = this.subject();
-
-  service.success('message', 'body');
-  equal(service.get('messages.lastObject.type.typeClass'), 'alert-success', 'Success notification added');
-});
-
-test('Can format message body', function() {
-  expect(3);
-
-  var objectBody = {
-    k1: 'v1',
-    k2: 'v2'
-  };
-  var formatted = "\n\nk1:\nv1\n\nk2:\nv2";
-  var service = this.subject();
-
-  ok(!service.formatMessageBody(), 'Return nothing if no body is passed');
-  equal(service.formatMessageBody('some string'), 'some string', 'Return the body if it is a string');
-  equal(service.formatMessageBody(objectBody), formatted, 'Parse the keys and return a string if it is an object');
-});
-
-test('Can removeMessage', function() {
-  expect(4);
-
-  var service = this.subject();
-  var messagesCount = service.get('messages.length');
-  var notificationCount = service.get('notifications.length');
-
-  service.add('type', 'message', 'body');
-
-  equal(service.get('messages.length'), messagesCount + 1, 'Message added');
-  equal(service.get('notifications.length'), notificationCount + 1, 'Notification added');
-
-  var message = service.get('messages.lastObject');
-  service.removeMessage(message);
-
-  equal(service.get('messages.length'), messagesCount, 'Message removed');
-  equal(service.get('notifications.length'), notificationCount, 'Notification removed');
-});
-
-test('Can removeNotification', function() {
-  expect(2);
-
-  var service = this.subject();
-  var notificationCount = service.get('notifications.length');
-
-  service.add('type', 'message', 'body');
-
-  equal(service.get('notifications.length'), notificationCount + 1, 'Notification added');
-
-  var notification = service.get('notifications.lastObject');
-  service.removeNotification(notification);
-
-  equal(service.get('notifications.length'), notificationCount, 'Notification removed');
-});
-
-test('Can removeAllMessages', function() {
-  expect(2);
-
-  var service = this.subject();
-
-  service.add('type', 'message', 'body');
-  service.add('type', 'message', 'body');
-  service.add('type', 'message', 'body');
-
-  ok(service.get('messages.length'), 'Messages are present');
-  service.removeAllMessages();
-  equal(service.get('messages.length'), 0, 'No messages found');
-});
-
-test('Can markMessagesAsSeen', function() {
-  expect(2);
-
-  var service = this.subject();
-
-  service.add('type', 'message', 'body');
-  service.add('type', 'message', 'body');
-  service.add('type', 'message', 'body');
-
-  ok(service.get('unseenMessages.length'), 'There are unseen messages');
-  service.markMessagesAsSeen();
-  equal(service.get('unseenMessages.length'), 0, 'No unseen messages');
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/services/settings-test.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/services/settings-test.js b/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/services/settings-test.js
deleted file mode 100644
index cb99882..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/services/settings-test.js
+++ /dev/null
@@ -1,155 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-import { moduleFor, test } from 'ember-qunit';
-
-moduleFor('service:settings', 'SettingsService');
-
-test('Init', function(assert) {
-  var service = this.subject();
-  assert.ok(service);
-});
-
-test('Can create a setting object', function(assert) {
-  assert.expect(2);
-
-  var service = this.subject();
-
-  var setting = service._createSetting('sName', 'sValue');
-
-  assert.equal(setting.get('key.name'), 'sName', 'Settign has the correct name');
-  assert.equal(setting.get('value'), 'sValue', 'Settign has the correct value');
-
-  service.removeAll();
-});
-
-test('Can create default settings', function(assert) {
-  assert.expect(2);
-
-  var service = this.subject();
-
-  var settings = {
-    'sName1': 'sValue1',
-    'sName2': 'sValue2',
-    'sName3': 'sValue3'
-  };
-
-  service._createDefaultSettings();
-
-  assert.equal(service.get('settings.length'), 0, '0 settings created');
-
-  service._createDefaultSettings(settings);
-
-  assert.equal(service.get('settings.length'), 3, '3 settings created');
-
-  service.removeAll();
-});
-
-test('Can add a setting', function(assert) {
-  assert.expect(2);
-
-  var service = this.subject();
-  assert.equal(service.get('settings.length'), 0, 'No settings');
-  service.add();
-  service.add();
-  assert.equal(service.get('settings.length'), 2, '2 settings added');
-
-  service.removeAll();
-});
-
-test('Can remove a setting', function(assert) {
-  assert.expect(2);
-
-  var service = this.subject();
-
-  service.add();
-  service.add();
-
-  assert.equal(service.get('settings.length'), 2, '2 settings added');
-  var firstSetting = service.get('settings.firstObject');
-  service.remove(firstSetting);
-  assert.equal(service.get('settings.length'), 1, 'Setting removed');
-
-  service.removeAll();
-});
-
-test('Can create key', function(assert) {
-  assert.expect(2);
-  var service = this.subject();
-
-  assert.ok(!service.get('predefinedSettings').findBy('name', 'new.key.name'), 'Key doesn\'t exist');
-
-  var setting = service._createSetting();
-  setting.set('key', null);
-  service.get('settings').pushObject(setting);
-  service.createKey('new.key.name');
-
-  assert.ok(service.get('predefinedSettings').findBy('name', 'new.key.name'), 'Key created');
-
-  service.removeAll();
-});
-
-test('Can get settings string', function(assert) {
-  var service = this.subject();
-
-  var noSettings = service.getSettings();
-  assert.equal(noSettings, "", 'An empty string is returned if there are no settings');
-
-  var settings = {
-    'sName1': 'sValue1',
-    'sName2': 'sValue2'
-  };
-
-  service._createDefaultSettings(settings);
-
-  var expectedWithSettings = "set sName1=sValue1;\nset sName2=sValue2;\n--Global Settings--\n\n";
-  var withSettings = service.getSettings();
-
-  assert.equal(withSettings, expectedWithSettings, 'Returns correct string');
-});
-
-test('It can parse global settings', function(assert) {
-  var service = this.subject();
-
-  assert.ok(!service.parseGlobalSettings(), 'It returns if query or model is not passed');
-
-  var settings = {
-    'sName1': 'sValue1',
-    'sName2': 'sValue2'
-  };
-
-
-  var globalSettingsString = "set sName1=sValue1;\nset sName2=sValue2;\n--Global Settings--\n\n";
-
-  var model = Ember.Object.create({
-    globalSettings: globalSettingsString
-  });
-
-  var query = Ember.Object.create({
-    fileContent: globalSettingsString + "{{match}}"
-  });
-
-  assert.ok(!service.parseGlobalSettings(query, model), 'It returns if current settings don\'t match models global settings');
-
-  service._createDefaultSettings(settings);
-
-  service.parseGlobalSettings(query, model);
-
-  assert.equal(query.get('fileContent'), "{{match}}", 'It parsed global settings');
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/views/visual-explain-test.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/views/visual-explain-test.js b/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/views/visual-explain-test.js
deleted file mode 100644
index 2fa23df..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/tests/unit/views/visual-explain-test.js
+++ /dev/null
@@ -1,106 +0,0 @@
-/**
- * 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.
- */
-
-import {
-  moduleFor,
-  test
-} from 'ember-qunit';
-
-var view;
-
-moduleFor('view:visual-explain', 'VisualExplainView', {
-  setup: function() {
-    var controller = Ember.Controller.extend({}).create();
-
-    view = this.subject({
-      controller: controller
-    });
-
-    Ember.run(function() {
-      view.appendTo('#ember-testing');
-    });
-  },
-
-  teardown: function() {
-    Ember.run(view, view.destroy);
-  },
-});
-
-//select count (*) from power
-var selectCountJson = {"STAGE PLANS":{"Stage-1":{"Tez":{"DagName:":"hive_20150608120000_b930a285-dc6a-49b7-86b6-8bee5ecdeacd:96","Vertices:":{"Reducer 2":{"Reduce Operator Tree:":{"Group By Operator":{"mode:":"mergepartial","aggregations:":["count(VALUE._col0)"],"outputColumnNames:":["_col0"],"children":{"Select Operator":{"expressions:":"_col0 (type: bigint)","outputColumnNames:":["_col0"],"children":{"File Output Operator":{"Statistics:":"Num rows: 1 Data size: 8 Basic stats: COMPLETE Column stats: COMPLETE","compressed:":"false","table:":{"serde:":"org.apache.hadoop.hive.serde2.lazy.LazySimpleSerDe","input format:":"org.apache.hadoop.mapred.TextInputFormat","output format:":"org.apache.hadoop.hive.ql.io.HiveIgnoreKeyTextOutputFormat"}}},"Statistics:":"Num rows: 1 Data size: 8 Basic stats: COMPLETE Column stats: COMPLETE"}},"Statistics:":"Num rows: 1 Data size: 8 Basic stats: COMPLETE Column stats: COMPLETE"}}},"Map 1":{"Map Operator Tree:":[{"TableScan":{"alias:":"power","childre
 n":{"Select Operator":{"children":{"Group By Operator":{"mode:":"hash","aggregations:":["count()"],"outputColumnNames:":["_col0"],"children":{"Reduce Output Operator":{"sort order:":"","value expressions:":"_col0 (type: bigint)","Statistics:":"Num rows: 1 Data size: 8 Basic stats: COMPLETE Column stats: COMPLETE"}},"Statistics:":"Num rows: 1 Data size: 8 Basic stats: COMPLETE Column stats: COMPLETE"}},"Statistics:":"Num rows: 0 Data size: 132960632 Basic stats: PARTIAL Column stats: COMPLETE"}},"Statistics:":"Num rows: 0 Data size: 132960632 Basic stats: PARTIAL Column stats: COMPLETE"}}]}},"Edges:":{"Reducer 2":{"parent":"Map 1","type":"SIMPLE_EDGE"}}}},"Stage-0":{"Fetch Operator":{"limit:":"-1","Processor Tree:":{"ListSink":{}}}}},"STAGE DEPENDENCIES":{"Stage-1":{"ROOT STAGE":"TRUE"},"Stage-0":{"DEPENDENT STAGES":"Stage-1"}}};
-
-//select power.adate, power.atime from power join power2 on power.adate = power2.adate
-var joinJson = {"STAGE PLANS":{"Stage-1":{"Tez":{"DagName:":"hive_20150608124141_acde7f09-6b72-4ad4-88b0-807d499724eb:107","Vertices:":{"Reducer 2":{"Reduce Operator Tree:":{"Merge Join Operator":{"outputColumnNames:":["_col0","_col1"],"children":{"Select Operator":{"expressions:":"_col0 (type: string), _col1 (type: string)","outputColumnNames:":["_col0","_col1"],"children":{"File Output Operator":{"Statistics:":"Num rows: 731283 Data size: 73128349 Basic stats: COMPLETE Column stats: NONE","compressed:":"false","table:":{"serde:":"org.apache.hadoop.hive.serde2.lazy.LazySimpleSerDe","input format:":"org.apache.hadoop.mapred.TextInputFormat","output format:":"org.apache.hadoop.hive.ql.io.HiveIgnoreKeyTextOutputFormat"}}},"Statistics:":"Num rows: 731283 Data size: 73128349 Basic stats: COMPLETE Column stats: NONE"}},"Statistics:":"Num rows: 731283 Data size: 73128349 Basic stats: COMPLETE Column stats: NONE","condition map:":[{"":"Inner Join 0 to 1"}],"condition expressions:":{"1":"",
 "0":"{KEY.reducesinkkey0} {VALUE._col0}"}}}},"Map 1":{"Map Operator Tree:":[{"TableScan":{"filterExpr:":"adate is not null (type: boolean)","alias:":"power2","children":{"Filter Operator":{"predicate:":"adate is not null (type: boolean)","children":{"Reduce Output Operator":{"Map-reduce partition columns:":"adate (type: string)","sort order:":"+","Statistics:":"Num rows: 664803 Data size: 66480316 Basic stats: COMPLETE Column stats: NONE","key expressions:":"adate (type: string)"}},"Statistics:":"Num rows: 664803 Data size: 66480316 Basic stats: COMPLETE Column stats: NONE"}},"Statistics:":"Num rows: 1329606 Data size: 132960632 Basic stats: COMPLETE Column stats: NONE"}}]},"Map 3":{"Map Operator Tree:":[{"TableScan":{"filterExpr:":"adate is not null (type: boolean)","alias:":"power","children":{"Filter Operator":{"predicate:":"adate is not null (type: boolean)","children":{"Reduce Output Operator":{"Map-reduce partition columns:":"adate (type: string)","sort order:":"+","value expr
 essions:":"atime (type: string)","Statistics:":"Num rows: 332402 Data size: 66480416 Basic stats: COMPLETE Column stats: NONE","key expressions:":"adate (type: string)"}},"Statistics:":"Num rows: 332402 Data size: 66480416 Basic stats: COMPLETE Column stats: NONE"}},"Statistics:":"Num rows: 664803 Data size: 132960632 Basic stats: COMPLETE Column stats: NONE"}}]}},"Edges:":{"Reducer 2":[{"parent":"Map 1","type":"SIMPLE_EDGE"},{"parent":"Map 3","type":"SIMPLE_EDGE"}]}}},"Stage-0":{"Fetch Operator":{"limit:":"-1","Processor Tree:":{"ListSink":{}}}}},"STAGE DEPENDENCIES":{"Stage-1":{"ROOT STAGE":"TRUE"},"Stage-0":{"DEPENDENT STAGES":"Stage-1"}}};
-
-// Replace this with your real tests.
-test('it renders dag when controller.json changes.', function (assert) {
-  assert.expect(1);
-
-  view.renderDag = function () {
-    assert.ok(true, 'dag rendering has been called on json set.');
-  };
-
-  view.set('controller.json', selectCountJson);
-});
-
-test('renderDag generates correct number of nodes and edges.', function (assert) {
-  assert.expect(4);
-
-  Ember.run(function () {
-    view.set('controller.json', selectCountJson);
-
-    assert.equal(view.get('graph').nodes().length, 4);
-    assert.equal(view.get('graph').edges().length, 3);
-
-    view.set('controller.json', joinJson);
-
-    assert.equal(view.get('graph').nodes().length, 7);
-    assert.equal(view.get('graph').edges().length, 6);
-  });
-});
-
-test('progress gets updated for each node.', function (assert) {
-  expect(2);
-
-  Ember.run(function () {
-    view.set('controller.json', selectCountJson);
-
-    var targetNode;
-    var verticesGroups = view.get('verticesGroups');
-
-    verticesGroups.some(function (verticesGroup) {
-      var node = verticesGroup.contents.findBy('label', 'Map 1');
-
-      if (node) {
-        targetNode = node;
-        return true;
-      }
-    });
-
-    assert.equal(targetNode.get('progress'), undefined, 'initial progress is falsy.');
-
-    view.set('controller.verticesProgress', [
-      Ember.Object.create({
-        name: 'Map 1',
-        value: 1
-      })
-    ]);
-
-    assert.equal(targetNode.get('progress'), 1, 'progress gets updated to given value.');
-  });
-});
\ No newline at end of file

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/vendor/.gitkeep
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/vendor/.gitkeep b/contrib/views/hive/src/main/resources/ui/hive-web/vendor/.gitkeep
deleted file mode 100644
index e69de29..0000000


[04/23] ambari git commit: AMBARI-19302 : removed contrib/views/hive folder and made necessary changes in pom.xml files (nitirajrathore)

Posted by ni...@apache.org.
http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/view.log4j.properties
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/view.log4j.properties b/contrib/views/hive/src/main/resources/view.log4j.properties
deleted file mode 100644
index 03c3e93..0000000
--- a/contrib/views/hive/src/main/resources/view.log4j.properties
+++ /dev/null
@@ -1,27 +0,0 @@
-# Copyright 2011 The Apache Software Foundation
-#
-# 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.
-
-log4j.appender.hiveView=org.apache.log4j.RollingFileAppender
-log4j.appender.hiveView.File=${ambari.log.dir}/hive-view/hive-view.log
-log4j.appender.hiveView.MaxFileSize=80MB
-log4j.appender.hiveView.MaxBackupIndex=60
-log4j.appender.hiveView.layout=org.apache.log4j.PatternLayout
-log4j.appender.hiveView.layout.ConversionPattern=%d{DATE} %5p [%t] [%X{viewName} %X{viewVersion} %X{viewInstanceName}] %c{1}:%L - %m%n
-
-log4j.logger.org.apache.ambari.view.hive=INFO,hiveView
-log4j.additivity.org.apache.ambari.view.hive = false

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/view.xml
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/view.xml b/contrib/views/hive/src/main/resources/view.xml
deleted file mode 100644
index 36b43d5..0000000
--- a/contrib/views/hive/src/main/resources/view.xml
+++ /dev/null
@@ -1,347 +0,0 @@
-<!--
-   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.
--->
-<view>
-    <name>HIVE</name>
-    <label>Hive</label>
-    <version>1.0.0</version>
-    <build>${env.BUILD_NUMBER}</build>
-
-    <min-ambari-version>2.0.*</min-ambari-version>
-
-    <validator-class>org.apache.ambari.view.hive.PropertyValidator</validator-class>
-    <view-class>org.apache.ambari.view.hive.HiveViewImpl</view-class>
-
-    <!-- Hive Configs -->
-    <parameter>
-      <name>hive.host</name>
-      <description>Enter the HiveServer2 host. Host must be accessible from Ambari Server.</description>
-      <label>HiveServer2 Host</label>
-      <placeholder>127.0.0.1</placeholder>
-      <cluster-config>fake</cluster-config>
-      <required>true</required>
-    </parameter>
-
-    <parameter>
-      <name>hive.port</name>
-      <description>HiveServer2 Thrift port (example: 10000).</description>
-      <label>HiveServer2 Thrift port</label>
-      <placeholder>10000</placeholder>
-      <default-value>10000</default-value>
-      <cluster-config>hive-site/hive.server2.thrift.port</cluster-config>
-      <required>true</required>
-    </parameter>
-
-    <parameter>
-        <name>hive.http.port</name>
-        <description>HiveServer2 Http port (example: 10001).</description>
-        <label>HiveServer2 Http port</label>
-        <placeholder>10001</placeholder>
-        <default-value>10001</default-value>
-        <cluster-config>hive-site/hive.server2.thrift.http.port</cluster-config>
-        <required>true</required>
-    </parameter>
-
-    <parameter>
-        <name>hive.http.path</name>
-        <description>HiveServer2 Http path (example: cliservice).</description>
-        <label>HiveServer2 Http path</label>
-        <placeholder>cliservice</placeholder>
-        <default-value>cliservice</default-value>
-        <cluster-config>hive-site/hive.server2.thrift.http.path</cluster-config>
-        <required>true</required>
-    </parameter>
-
-    <parameter>
-        <name>hive.transport.mode</name>
-        <description>HiveServer2 Transport Mode (example: http/binary).</description>
-        <label>HiveServer2 Transport Mode</label>
-        <placeholder>binary</placeholder>
-        <default-value>binary</default-value>
-        <cluster-config>hive-site/hive.server2.transport.mode</cluster-config>
-        <required>true</required>
-    </parameter>
-
-    <parameter>
-      <name>hive.auth</name>
-      <description>Semicolon-separated authentication configs.</description>
-      <label>Hive Authentication</label>
-      <placeholder>auth=NONE</placeholder>
-      <required>false</required>
-    </parameter>
-
-    <parameter>
-        <name>hive.metastore.warehouse.dir</name>
-        <description>Hive Metastore directory (example: /apps/hive/warehouse)</description>
-        <label>Hive Metastore directory</label>
-        <placeholder>/apps/hive/warehouse</placeholder>
-        <default-value>/apps/hive/warehouse</default-value>
-        <cluster-config>hive-site/hive.metastore.warehouse.dir</cluster-config>
-        <required>false</required>
-    </parameter>
-
-    <!-- HDFS Configs -->
-    <parameter>
-        <name>webhdfs.url</name>
-        <description>Enter the WebHDFS FileSystem URI. Typically this is the dfs.namenode.http-address
-            property in the hdfs-site.xml configuration. URL must be accessible from Ambari Server.</description>
-        <label>WebHDFS FileSystem URI</label>
-        <placeholder>webhdfs://namenode:50070</placeholder>
-        <required>true</required>
-        <cluster-config>core-site/fs.defaultFS</cluster-config>
-    </parameter>
-    <parameter>
-        <name>webhdfs.nameservices</name>
-        <description>Comma-separated list of nameservices. Value of hdfs-site/dfs.nameservices property</description>
-        <label>Logical name of the NameNode cluster</label>
-        <required>false</required>
-        <cluster-config>hdfs-site/dfs.nameservices</cluster-config>
-    </parameter>
-    <parameter>
-        <name>webhdfs.ha.namenodes.list</name>
-        <description>Comma-separated list of namenodes for a given nameservice.
-          Value of hdfs-site/dfs.ha.namenodes.[nameservice] property</description>
-        <label>List of NameNodes</label>
-        <required>false</required>
-        <cluster-config>fake</cluster-config>
-    </parameter>
-    <parameter>
-        <name>webhdfs.ha.namenode.rpc-address.nn1</name>
-        <description>RPC address for first name node.
-          Value of hdfs-site/dfs.namenode.rpc-address.[nameservice].[namenode1] property</description>
-        <label>First NameNode RPC Address</label>
-        <required>false</required>
-        <cluster-config>fake</cluster-config>
-    </parameter>
-    <parameter>
-        <name>webhdfs.ha.namenode.rpc-address.nn2</name>
-        <description>RPC address for second name node.
-          Value of hdfs-site/dfs.namenode.rpc-address.[nameservice].[namenode2] property</description>
-        <label>Second NameNode RPC Address</label>
-        <required>false</required>
-        <cluster-config>fake</cluster-config>
-    </parameter>
-    <parameter>
-        <name>webhdfs.ha.namenode.http-address.nn1</name>
-        <description>WebHDFS address for first name node.
-          Value of hdfs-site/dfs.namenode.http-address.[nameservice].[namenode1] property</description>
-        <label>First NameNode HTTP (WebHDFS) Address</label>
-        <required>false</required>
-        <cluster-config>fake</cluster-config>
-    </parameter>
-    <parameter>
-        <name>webhdfs.ha.namenode.http-address.nn2</name>
-        <description>WebHDFS address for second name node.
-          Value of hdfs-site/dfs.namenode.http-address.[nameservice].[namenode2] property</description>
-        <label>Second NameNode HTTP (WebHDFS) Address</label>
-        <required>false</required>
-        <cluster-config>fake</cluster-config>
-    </parameter>
-    <parameter>
-        <name>webhdfs.ha.namenode.https-address.nn1</name>
-        <description>WebHDFS Https address for first name node.
-            Value of hdfs-site/dfs.namenode.https-address.[nameservice].[namenode1] property</description>
-        <label>First NameNode HTTPS (WebHDFS) Address</label>
-        <required>false</required>
-        <cluster-config>fake</cluster-config>
-    </parameter>
-    <parameter>
-        <name>webhdfs.ha.namenode.https-address.nn2</name>
-        <description>WebHDFS Https address for second name node.
-            Value of hdfs-site/dfs.namenode.https-address.[nameservice].[namenode2] property</description>
-        <label>Second NameNode HTTPS (WebHDFS) Address</label>
-        <required>false</required>
-        <cluster-config>fake</cluster-config>
-    </parameter>
-    <parameter>
-        <name>webhdfs.client.failover.proxy.provider</name>
-        <description>The Java class that HDFS clients use to contact the Active NameNode
-          Value of hdfs-site/dfs.client.failover.proxy.provider.[nameservice] property</description>
-        <label>Failover Proxy Provider</label>
-        <required>false</required>
-        <cluster-config>fake</cluster-config>
-    </parameter>
-
-    <parameter>
-        <name>webhdfs.username</name>
-        <description>doAs for proxy user for HDFS. By default, uses the currently logged-in Ambari user.</description>
-        <label>WebHDFS Username</label>
-        <default-value>${username}</default-value>
-        <required>false</required>
-    </parameter>
-
-    <parameter>
-        <name>webhdfs.auth</name>
-        <description>Semicolon-separated authentication configs.</description>
-        <label>WebHDFS Authentication</label>
-        <placeholder>auth=SIMPLE</placeholder>
-        <required>false</required>
-    </parameter>
-
-    <parameter>
-        <name>hdfs.umask-mode</name>
-        <description>The umask used when creating files and directories. Defaults to 022</description>
-        <label>Umask</label>
-        <default-value>022</default-value>
-        <required>false</required>
-        <cluster-config>hdfs-site/fs.permissions.umask-mode</cluster-config>
-    </parameter>
-
-    <parameter>
-        <name>hdfs.auth_to_local</name>
-        <description>Auth to Local Configuration</description>
-        <label>Auth To Local</label>
-        <required>false</required>
-        <cluster-config>core-site/hadoop.security.auth_to_local</cluster-config>
-    </parameter>
-
-    <!-- General Configs -->
-
-    <parameter>
-        <name>views.tez.instance</name>
-        <description>Instance name of Tez view.</description>
-        <label>Instance name of Tez view</label>
-        <required>false</required>
-    </parameter>
-
-    <parameter>
-        <name>scripts.dir</name>
-        <description>HDFS directory path to store Hive scripts.</description>
-        <label>Scripts HDFS Directory</label>
-        <placeholder>/user/${username}/hive/scripts</placeholder>
-        <default-value>/user/${username}/hive/scripts</default-value>
-        <required>true</required>
-    </parameter>
-
-    <parameter>
-        <name>jobs.dir</name>
-        <description>HDFS directory path to store Hive job status.</description>
-        <label>Jobs HDFS Directory</label>
-        <placeholder>/user/${username}/hive/jobs</placeholder>
-        <default-value>/user/${username}/hive/jobs</default-value>
-        <required>true</required>
-    </parameter>
-
-    <parameter>
-        <name>scripts.settings.defaults-file</name>
-        <description>File path for saving default settings for query</description>
-        <label>Default script settings file</label>
-        <default-value>/user/${username}/.${instanceName}.defaultSettings</default-value>
-        <required>true</required>
-    </parameter>
-
-    <parameter>
-        <name>yarn.ats.url</name>
-        <description>The URL to the YARN Application Timeline Server, used to provide Jobs information, typically, this is the yarn.timeline-service.webapp.address property in the yarn-site.xml configuration.</description>
-        <label>YARN Application Timeline Server URL</label>
-        <placeholder>http://yarn.ats.address:8188</placeholder>
-        <cluster-config>yarn-site/yarn.timeline-service.webapp.address</cluster-config>
-        <required>true</required>
-    </parameter>
-
-    <parameter>
-        <name>yarn.resourcemanager.url</name>
-        <description>The URL to the YARN ResourceManager, used to provide YARN Application data. If YARN ResourceManager HA is enabled, provide a comma separated list of URLs for all the Resource Managers.</description>
-        <label>YARN ResourceManager URL</label>
-        <placeholder>http://yarn.resourcemanager.address:8088</placeholder>
-        <cluster-config>yarn-site/yarn.resourcemanager.webapp.address</cluster-config>
-        <required>true</required>
-    </parameter>
-
-    <resource>
-        <name>savedQuery</name>
-        <plural-name>savedQueries</plural-name>
-        <id-property>id</id-property>
-        <resource-class>org.apache.ambari.view.hive.resources.savedQueries.SavedQuery</resource-class>
-        <provider-class>org.apache.ambari.view.hive.resources.savedQueries.SavedQueryResourceProvider</provider-class>
-        <service-class>org.apache.ambari.view.hive.resources.savedQueries.SavedQueryService</service-class>
-    </resource>
-
-    <resource>
-        <name>fileResource</name>
-        <plural-name>fileResources</plural-name>
-        <id-property>id</id-property>
-        <resource-class>org.apache.ambari.view.hive.resources.resources.FileResourceItem</resource-class>
-        <provider-class>org.apache.ambari.view.hive.resources.resources.FileResourceResourceProvider</provider-class>
-        <service-class>org.apache.ambari.view.hive.resources.resources.FileResourceService</service-class>
-    </resource>
-
-    <resource>
-        <name>udf</name>
-        <plural-name>udfs</plural-name>
-        <id-property>id</id-property>
-        <resource-class>org.apache.ambari.view.hive.resources.udfs.UDF</resource-class>
-        <provider-class>org.apache.ambari.view.hive.resources.udfs.UDFResourceProvider</provider-class>
-        <service-class>org.apache.ambari.view.hive.resources.udfs.UDFService</service-class>
-    </resource>
-
-    <resource>
-        <name>job</name>
-        <plural-name>jobs</plural-name>
-        <id-property>id</id-property>
-        <resource-class>org.apache.ambari.view.hive.resources.jobs.viewJobs.JobImpl</resource-class>
-        <provider-class>org.apache.ambari.view.hive.resources.jobs.JobResourceProvider</provider-class>
-        <service-class>org.apache.ambari.view.hive.resources.jobs.JobService</service-class>
-    </resource>
-
-    <resource>
-        <name>upload</name>
-        <plural-name>uploads</plural-name>
-        <service-class>org.apache.ambari.view.hive.resources.uploads.UploadService</service-class>
-    </resource>
-
-    <resource>
-        <name>file</name>
-        <service-class>org.apache.ambari.view.hive.resources.files.FileService</service-class>
-    </resource>
-
-    <resource>
-        <name>ddl</name>
-        <service-class>org.apache.ambari.view.hive.resources.browser.HiveBrowserService</service-class>
-    </resource>
-
-    <resource>
-        <name>hive</name>
-        <service-class>org.apache.ambari.view.hive.HelpService</service-class>
-    </resource>
-
-    <persistence>
-        <entity>
-            <class>org.apache.ambari.view.hive.resources.jobs.viewJobs.JobImpl</class>
-            <id-property>id</id-property>
-        </entity>
-        <entity>
-            <class>org.apache.ambari.view.hive.resources.jobs.StoredOperationHandle</class>
-            <id-property>id</id-property>
-        </entity>
-        <entity>
-            <class>org.apache.ambari.view.hive.resources.savedQueries.SavedQuery</class>
-            <id-property>id</id-property>
-        </entity>
-        <entity>
-            <class>org.apache.ambari.view.hive.resources.udfs.UDF</class>
-            <id-property>id</id-property>
-        </entity>
-        <entity>
-            <class>org.apache.ambari.view.hive.resources.resources.FileResourceItem</class>
-            <id-property>id</id-property>
-        </entity>
-        <entity>
-            <class>org.apache.ambari.view.hive.TestBean</class>
-            <id-property>id</id-property>
-        </entity>
-    </persistence>
-</view>

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/BaseHiveTest.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/BaseHiveTest.java b/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/BaseHiveTest.java
deleted file mode 100644
index adcd988..0000000
--- a/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/BaseHiveTest.java
+++ /dev/null
@@ -1,116 +0,0 @@
-/**
- * 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.ambari.view.hive;
-
-import com.google.inject.AbstractModule;
-import com.google.inject.Guice;
-import com.google.inject.Injector;
-import org.apache.ambari.view.ViewContext;
-import org.apache.ambari.view.ViewResourceHandler;
-import org.apache.hadoop.fs.FileUtil;
-import org.junit.After;
-import org.junit.AfterClass;
-import org.junit.Before;
-import org.junit.BeforeClass;
-
-import java.io.File;
-import java.util.HashMap;
-import java.util.Map;
-
-import static org.easymock.EasyMock.*;
-
-public abstract class BaseHiveTest {
-  protected ViewResourceHandler handler;
-  protected ViewContext context;
-  protected static File hiveStorageFile;
-  protected static File baseDir;
-  protected Map<String, String> properties;
-
-  protected static String DATA_DIRECTORY = "./target/HiveTest";
-
-  @BeforeClass
-  public static void startUp() throws Exception {
-    File baseDir = new File(DATA_DIRECTORY)
-        .getAbsoluteFile();
-    FileUtil.fullyDelete(baseDir);
-  }
-
-  @AfterClass
-  public static void shutDown() throws Exception {
-  }
-
-  @Before
-  public void setUp() throws Exception {
-    handler = createNiceMock(ViewResourceHandler.class);
-
-    properties = new HashMap<String, String>();
-    baseDir = new File(DATA_DIRECTORY)
-        .getAbsoluteFile();
-    hiveStorageFile = new File("./target/HiveTest/storage.dat")
-        .getAbsoluteFile();
-
-    setupDefaultContextProperties(properties);
-    setupProperties(properties, baseDir);
-
-    context = makeContext(properties, "ambari-qa", "MyHive");
-
-    replay(handler, context);
-  }
-
-  public void setupDefaultContextProperties(Map<String, String> properties) {
-    properties.put("dataworker.storagePath", hiveStorageFile.toString());
-    properties.put("scripts.dir", "/tmp/.hiveQueries");
-    properties.put("jobs.dir", "/tmp/.hiveJobs");
-    properties.put("yarn.ats.url", "http://127.0.0.1:8188");
-    properties.put("yarn.resourcemanager.url", "http://127.0.0.1:8088");
-  }
-
-  public ViewContext makeContext(Map<String, String> properties, String username, String instanceName) throws Exception {
-    setupDefaultContextProperties(properties);
-    setupProperties(properties, baseDir);
-
-    ViewContext context = createNiceMock(ViewContext.class);
-    expect(context.getProperties()).andReturn(properties).anyTimes();
-    expect(context.getUsername()).andReturn(username).anyTimes();
-    expect(context.getInstanceName()).andReturn(instanceName).anyTimes();
-    return context;
-  }
-
-  protected void setupProperties(Map<String, String> properties, File baseDir) throws Exception {
-
-  }
-
-  @After
-  public void tearDown() throws Exception {
-
-  }
-
-  protected static <T> T getService(Class<T> clazz,
-                                    final ViewResourceHandler viewResourceHandler,
-                                    final ViewContext viewInstanceContext) {
-    Injector viewInstanceInjector = Guice.createInjector(new AbstractModule() {
-      @Override
-      protected void configure() {
-        bind(ViewResourceHandler.class).toInstance(viewResourceHandler);
-        bind(ViewContext.class).toInstance(viewInstanceContext);
-      }
-    });
-    return viewInstanceInjector.getInstance(clazz);
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/HDFSTest.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/HDFSTest.java b/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/HDFSTest.java
deleted file mode 100644
index 0ee8eb3..0000000
--- a/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/HDFSTest.java
+++ /dev/null
@@ -1,64 +0,0 @@
-/**
- * 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.ambari.view.hive;
-
-import org.apache.hadoop.conf.Configuration;
-import org.apache.hadoop.fs.FileUtil;
-import org.apache.hadoop.hdfs.MiniDFSCluster;
-import org.junit.AfterClass;
-import org.junit.BeforeClass;
-
-import java.io.File;
-import java.util.Map;
-
-public abstract class HDFSTest extends BaseHiveTest {
-  protected static MiniDFSCluster hdfsCluster;
-  protected static String hdfsURI;
-
-  @BeforeClass
-  public static void startUp() throws Exception {
-    BaseHiveTest.startUp(); // super
-    File hdfsDir = new File("./target/HiveTest/hdfs/")
-        .getAbsoluteFile();
-    FileUtil.fullyDelete(hdfsDir);
-
-    Configuration conf = new Configuration();
-    conf.set(MiniDFSCluster.HDFS_MINIDFS_BASEDIR, hdfsDir.getAbsolutePath());
-    conf.set("hadoop.proxyuser." + System.getProperty("user.name") + ".groups", "*");
-    conf.set("hadoop.proxyuser." + System.getProperty("user.name") + ".hosts", "*");
-
-    MiniDFSCluster.Builder builder = new MiniDFSCluster.Builder(conf);
-    hdfsCluster = builder.build();
-    hdfsURI = hdfsCluster.getURI().toString();
-  }
-
-  @AfterClass
-  public static void shutDown() throws Exception {
-    BaseHiveTest.shutDown();
-    hdfsCluster.shutdown();
-    hdfsCluster = null;
-  }
-
-  @Override
-  protected void setupProperties(Map<String, String> properties, File baseDir) throws Exception {
-    super.setupProperties(properties, baseDir);
-    properties.put("webhdfs.url", hdfsURI);
-    properties.put("webhdfs.username", System.getProperty("user.name"));
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/PropertyValidatorTest.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/PropertyValidatorTest.java b/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/PropertyValidatorTest.java
deleted file mode 100644
index 84caae9..0000000
--- a/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/PropertyValidatorTest.java
+++ /dev/null
@@ -1,112 +0,0 @@
-/**
- * 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.ambari.view.hive;
-
-import org.apache.ambari.view.ViewInstanceDefinition;
-import org.apache.ambari.view.validation.Validator;
-import org.easymock.EasyMock;
-import org.junit.Test;
-
-import java.util.HashMap;
-import java.util.Map;
-
-import static org.easymock.EasyMock.expect;
-import static org.easymock.EasyMock.replay;
-import static org.junit.Assert.*;
-
-public class PropertyValidatorTest {
-
-  @Test
-  public void testValidatePropertyWebHDFSCom() throws Exception {
-    PropertyValidator validator = new PropertyValidator();
-    ViewInstanceDefinition definition = getViewInstanceDefinition();
-
-    definition.getPropertyMap().put(PropertyValidator.WEBHDFS_URL, "hdfs://hostname.com:8020");
-
-    assertTrue(validator.validateProperty(PropertyValidator.WEBHDFS_URL,
-        definition, Validator.ValidationContext.PRE_CREATE).isValid());
-
-    definition.getPropertyMap().put(PropertyValidator.WEBHDFS_URL, "webhdfs://hostname.com:50070");
-
-    assertTrue(validator.validateProperty(PropertyValidator.WEBHDFS_URL,
-        definition, Validator.ValidationContext.PRE_CREATE).isValid());
-
-    definition.getPropertyMap().put(PropertyValidator.WEBHDFS_URL, "http://hostname.com:50070");
-
-    assertFalse(validator.validateProperty(PropertyValidator.WEBHDFS_URL,
-        definition, Validator.ValidationContext.PRE_CREATE).isValid());
-  }
-
-  @Test
-  public void testValidatePropertyWebHDFSInternal() throws Exception {
-    PropertyValidator validator = new PropertyValidator();
-    ViewInstanceDefinition definition = getViewInstanceDefinition();
-
-    definition.getPropertyMap().put(PropertyValidator.WEBHDFS_URL, "hdfs://hostname.internal:8020");
-
-    assertTrue(validator.validateProperty(PropertyValidator.WEBHDFS_URL,
-        definition, Validator.ValidationContext.PRE_CREATE).isValid());
-
-    definition.getPropertyMap().put(PropertyValidator.WEBHDFS_URL, "webhdfs://hostname.internal:50070");
-
-    assertTrue(validator.validateProperty(PropertyValidator.WEBHDFS_URL,
-        definition, Validator.ValidationContext.PRE_CREATE).isValid());
-
-    definition.getPropertyMap().put(PropertyValidator.WEBHDFS_URL, "swebhdfs://hostname.internal:50070");
-
-    assertTrue(validator.validateProperty(PropertyValidator.WEBHDFS_URL,
-        definition, Validator.ValidationContext.PRE_CREATE).isValid());
-
-    definition.getPropertyMap().put(PropertyValidator.WEBHDFS_URL, "http://hostname.internal:50070");
-
-    assertFalse(validator.validateProperty(PropertyValidator.WEBHDFS_URL,
-        definition, Validator.ValidationContext.PRE_CREATE).isValid());
-  }
-
-  @Test
-  public void testValidatePropertyATSCom() throws Exception {
-    PropertyValidator validator = new PropertyValidator();
-    ViewInstanceDefinition definition = getViewInstanceDefinition();
-
-    definition.getPropertyMap().put(PropertyValidator.YARN_ATS_URL, "http://hostname.com:8088");
-
-    assertTrue(validator.validateProperty(PropertyValidator.YARN_ATS_URL,
-        definition, Validator.ValidationContext.PRE_CREATE).isValid());
-  }
-
-  @Test
-  public void testValidatePropertyATSInternal() throws Exception {
-    PropertyValidator validator = new PropertyValidator();
-    ViewInstanceDefinition definition = getViewInstanceDefinition();
-
-    definition.getPropertyMap().put(PropertyValidator.YARN_ATS_URL, "http://hostname.internal:8088");
-
-    assertTrue(validator.validateProperty(PropertyValidator.YARN_ATS_URL,
-        definition, Validator.ValidationContext.PRE_CREATE).isValid());
-  }
-
-  private ViewInstanceDefinition getViewInstanceDefinition() {
-    ViewInstanceDefinition definition = EasyMock.createNiceMock(ViewInstanceDefinition.class);
-    expect(definition.getClusterHandle()).andReturn(null).anyTimes();
-    Map<String, String> properties = new HashMap<String, String>();
-    expect(definition.getPropertyMap()).andReturn(properties).anyTimes();
-    replay(definition);
-    return definition;
-  }
-}
\ No newline at end of file

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/ServiceTestUtils.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/ServiceTestUtils.java b/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/ServiceTestUtils.java
deleted file mode 100644
index ac913a9..0000000
--- a/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/ServiceTestUtils.java
+++ /dev/null
@@ -1,63 +0,0 @@
-/**
- * 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.ambari.view.hive;
-
-import org.junit.Assert;
-
-import javax.servlet.http.HttpServletResponse;
-import javax.ws.rs.core.Response;
-import javax.ws.rs.core.UriBuilder;
-import javax.ws.rs.core.UriInfo;
-
-import java.net.URI;
-
-import static org.easymock.EasyMock.*;
-
-public class ServiceTestUtils {
-  public static void assertHTTPResponseOK(Response response) {
-    Assert.assertEquals(200, response.getStatus());
-  }
-
-  public static void assertHTTPResponseCreated(Response response) {
-    Assert.assertEquals(201, response.getStatus());
-  }
-
-  public static void assertHTTPResponseNoContent(Response response) {
-    Assert.assertEquals(204, response.getStatus());
-  }
-
-  public static void expectLocationHeaderInResponse(HttpServletResponse resp_obj) {
-    resp_obj.setHeader(eq("Location"), anyString());
-  }
-
-  public static UriInfo getDefaultUriInfo() {
-    UriInfo uriInfo = createNiceMock(UriInfo.class);
-    URI uri = UriBuilder.fromUri("http://host/a/b").build();
-    expect(uriInfo.getAbsolutePath()).andReturn(uri);
-    replay(uriInfo);
-    return uriInfo;
-  }
-
-  public static HttpServletResponse getResponseWithLocation() {
-    HttpServletResponse resp_obj = createNiceMock(HttpServletResponse.class);
-    expectLocationHeaderInResponse(resp_obj);
-    replay(resp_obj);
-    return resp_obj;
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/backgroundjobs/BackgroundJobControllerTest.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/backgroundjobs/BackgroundJobControllerTest.java b/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/backgroundjobs/BackgroundJobControllerTest.java
deleted file mode 100644
index ceb3677..0000000
--- a/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/backgroundjobs/BackgroundJobControllerTest.java
+++ /dev/null
@@ -1,77 +0,0 @@
-/**
- * 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.ambari.view.hive.backgroundjobs;
-
-import org.apache.ambari.view.hive.BaseHiveTest;
-import org.junit.Assert;
-import org.junit.Test;
-
-public class BackgroundJobControllerTest extends BaseHiveTest {
-
-  private static final long MAX_WAIT_TIME = 2000;
-
-  @Test
-  public void testStartJob() throws Exception {
-    BackgroundJobController backgroundJobController = new BackgroundJobController(context);
-
-    HangingRunnable runnable = new HangingRunnable();
-    backgroundJobController.startJob("key", runnable);
-
-    assertStateIs(backgroundJobController, "key", Thread.State.RUNNABLE);
-
-    runnable.goOn();
-    assertStateIs(backgroundJobController, "key", Thread.State.TERMINATED);
-  }
-
-  @Test
-  public void testInterrupt() throws Exception {
-    BackgroundJobController backgroundJobController = new BackgroundJobController(context);
-
-    HangingRunnable runnable = new HangingRunnable();
-    backgroundJobController.startJob("key", runnable);
-
-    assertStateIs(backgroundJobController, "key", Thread.State.RUNNABLE);
-
-    backgroundJobController.interrupt("key");
-    assertStateIs(backgroundJobController, "key", Thread.State.TERMINATED);
-  }
-
-  private void assertStateIs(BackgroundJobController backgroundJobController, String key, Thread.State state) throws InterruptedException {
-    long start = System.currentTimeMillis();
-    while (backgroundJobController.state(key) != state) {
-      Thread.sleep(100);
-      if (System.currentTimeMillis() - start > MAX_WAIT_TIME)
-        break;
-    }
-    Assert.assertEquals(state, backgroundJobController.state(key));
-  }
-
-  private static class HangingRunnable implements Runnable {
-    private boolean waitMe = true;
-
-    @Override
-    public void run() {
-      while(waitMe && !Thread.interrupted());
-    }
-
-    public void goOn() {
-      this.waitMe = false;
-    }
-  }
-}
\ No newline at end of file

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/client/ConnectionTest.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/client/ConnectionTest.java b/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/client/ConnectionTest.java
deleted file mode 100644
index 0b57b6a..0000000
--- a/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/client/ConnectionTest.java
+++ /dev/null
@@ -1,73 +0,0 @@
-/**
- * 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.ambari.view.hive.client;
-
-import org.junit.Rule;
-import org.junit.Test;
-import org.junit.rules.ExpectedException;
-
-import java.util.HashMap;
-
-import static org.junit.Assert.*;
-
-public class ConnectionTest {
-  @Rule
-  public ExpectedException thrown = ExpectedException.none();
-
-  @Test
-  public void testOpenConnection() throws Exception {
-    HashMap<String, String> auth = new HashMap<String, String>();
-    auth.put("auth", "NONE");
-
-    thrown.expect(HiveClientException.class);
-    thrown.expectMessage("Connection refused");
-    new Connection("127.0.0.1", 42420, auth, "ambari-qa", null);
-  }
-
-  @Test
-  public void testOpenConnectionMessage() throws Exception {
-    HashMap<String, String> auth = new HashMap<String, String>();
-    auth.put("auth", "NONE");
-
-    thrown.expect(HiveClientException.class);
-    thrown.expectMessage("H020 Could not establish connection to");
-    new Connection("127.0.0.1", 42420, auth, "ambari-qa", null);
-  }
-
-  @Test
-  public void testAskPasswordWithoutPassword() throws Exception {
-    HashMap<String, String> auth = new HashMap<String, String>();
-    auth.put("auth", "NONE");
-    auth.put("password", "${ask_password}");
-
-    thrown.expect(HiveAuthRequiredException.class);
-    new Connection("127.0.0.1", 42420, auth, "ambari-qa", null);
-  }
-
-  @Test
-  public void testAskPasswordWithPassword() throws Exception {
-    HashMap<String, String> auth = new HashMap<String, String>();
-    auth.put("auth", "NONE");
-    auth.put("password", "${ask_password}");
-
-    thrown.expect(HiveClientException.class);
-    thrown.expectMessage("Connection refused");
-    new Connection("127.0.0.1", 42420, auth, "ambari-qa", "password");
-  }
-}

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/client/UtilsTest.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/client/UtilsTest.java b/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/client/UtilsTest.java
deleted file mode 100644
index 0dafcb1..0000000
--- a/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/client/UtilsTest.java
+++ /dev/null
@@ -1,78 +0,0 @@
-/**
- * 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.ambari.view.hive.client;
-
-import org.apache.hive.service.cli.thrift.TStatus;
-import org.apache.hive.service.cli.thrift.TStatusCode;
-import org.junit.Rule;
-import org.junit.Test;
-import org.junit.rules.ExpectedException;
-
-import static org.easymock.EasyMock.createNiceMock;
-import static org.easymock.EasyMock.expect;
-import static org.easymock.EasyMock.replay;
-import static org.junit.Assert.*;
-
-public class UtilsTest {
-
-  @Rule
-  public ExpectedException thrown = ExpectedException.none();
-
-  @Test
-  public void testRemoveEmptyStrings() throws Exception {
-    String[] arrayWithSomeEmptyStrings = new String[] { "", null, "string1", null, "", "string2", "" };
-    String[] expectedStrings = Utils.removeEmptyStrings(arrayWithSomeEmptyStrings);
-
-    assertEquals(2, expectedStrings.length);
-    assertEquals("string1", expectedStrings[0]);
-    assertEquals("string2", expectedStrings[1]);
-  }
-
-  @Test
-  public void testVerifySuccessWithHiveInvalidQueryException() throws Exception{
-    String msg = "Error in compiling";
-    String comment = "H110 Unable to submit statement";
-
-    TStatus status = createMockTStatus(10000,msg,TStatusCode.ERROR_STATUS);
-    thrown.expect(HiveInvalidQueryException.class);
-    thrown.expectMessage(msg);
-
-    Utils.verifySuccess(status,comment);
-  }
-
-  @Test
-  public void testVerifySuccessWithHiveErrorStatusException() throws Exception{
-    String msg = "Error in compiling";
-    String comment = "H110 Unable to submit statement";
-
-    TStatus status = createMockTStatus(40000,msg,TStatusCode.ERROR_STATUS);
-    thrown.expect(HiveErrorStatusException.class);
-    thrown.expectMessage(String.format("%s. %s",comment,msg));
-
-    Utils.verifySuccess(status,comment);
-  }
-
-  private TStatus createMockTStatus(int errorCode,String msg,TStatusCode tStatusCode){
-    TStatus status = createNiceMock(TStatus.class);
-    expect(status.getErrorCode()).andReturn(errorCode).anyTimes();
-    expect(status.getStatusCode()).andReturn(tStatusCode).anyTimes();
-    expect(status.getErrorMessage()).andReturn(msg).anyTimes();
-    replay(status);
-    return status;
-  }
-}
\ No newline at end of file

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/resources/files/FileServiceTest.java
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/resources/files/FileServiceTest.java b/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/resources/files/FileServiceTest.java
deleted file mode 100644
index c57d2b4..0000000
--- a/contrib/views/hive/src/test/java/org/apache/ambari/view/hive/resources/files/FileServiceTest.java
+++ /dev/null
@@ -1,273 +0,0 @@
-/**
- * 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.ambari.view.hive.resources.files;
-
-import org.apache.ambari.view.URLStreamProvider;
-import org.apache.ambari.view.hive.ServiceTestUtils;
-import org.apache.ambari.view.hive.HDFSTest;
-import org.apache.ambari.view.hive.utils.*;
-import org.apache.ambari.view.utils.hdfs.HdfsApi;
-import org.apache.commons.codec.binary.Base64;
-import org.apache.commons.io.IOUtils;
-import org.apache.hadoop.fs.FSDataInputStream;
-import org.apache.hadoop.fs.Path;
-import org.easymock.EasyMock;
-import org.json.simple.JSONObject;
-import org.junit.*;
-import org.junit.rules.ExpectedException;
-
-import javax.ws.rs.core.Response;
-import java.io.IOException;
-import java.io.InputStream;
-import java.nio.charset.Charset;
-import java.util.Arrays;
-import java.util.Map;
-
-import static org.easymock.EasyMock.*;
-import static org.easymock.EasyMock.expect;
-
-public class FileServiceTest extends HDFSTest {
-  private final static int PAGINATOR_PAGE_SIZE = 4;  //4 bytes
-  private FileService fileService;
-
-  @Rule public ExpectedException thrown = ExpectedException.none();
-
-  @Override
-  @Before
-  public void setUp() throws Exception {
-    super.setUp();
-    fileService = getService(FileService.class, handler, context);
-    FilePaginator.setPageSize(PAGINATOR_PAGE_SIZE);
-  }
-
-  @BeforeClass
-  public static void startUp() throws Exception {
-    HDFSTest.startUp(); // super
-  }
-
-  @AfterClass
-  public static void shutDown() throws Exception {
-    HDFSTest.shutDown(); // super
-  }
-
-  @Override
-  @After
-  public void tearDown() throws Exception {
-    fileService.getSharedObjectsFactory().clear(HdfsApi.class);
-  }
-
-  @Test
-  public void testCreateFile() throws IOException, InterruptedException {
-    Response response = createFile("/tmp/testCreateFile", "testCreateFile content");
-
-    ServiceTestUtils.assertHTTPResponseNoContent(response);
-    assertHDFSFileContains("/tmp/testCreateFile", "testCreateFile content");
-  }
-
-  @Test
-  public void testCreateExistingFileForbidden() throws IOException, InterruptedException {
-    createFile("/tmp/testOverwriteFile", "original content");
-    thrown.expect(ServiceFormattedException.class);
-    createFile("/tmp/testOverwriteFile", "new content");
-  }
-
-  @Test
-  public void testCreateFilePathNotExists() throws IOException, InterruptedException {
-    Response response = createFile("/non/existent/path/Luke", null);
-    ServiceTestUtils.assertHTTPResponseNoContent(response);
-
-    Response response2 = createFile("/tmp/Leia", null);
-    ServiceTestUtils.assertHTTPResponseNoContent(response2);
-
-    thrown.expect(ServiceFormattedException.class);
-    Response response3 = createFile("/tmp/Leia", null); // file already exists
-    Assert.assertEquals(400, response3.getStatus());
-  }
-
-  @Test
-  public void testUpdateFileContent() throws Exception {
-    createFile("/tmp/testUpdateFileContent", "some content");
-
-    FileService.FileResourceRequest updateRequest = new FileService.FileResourceRequest();
-    updateRequest.file = new FileResource();
-    updateRequest.file.setFileContent("new content");
-
-    Response response = fileService.updateFile(updateRequest, "/tmp/testUpdateFileContent");
-
-    ServiceTestUtils.assertHTTPResponseNoContent(response);
-    assertHDFSFileContains("/tmp/testUpdateFileContent", "new content");
-  }
-
-  @Test
-  public void testPagination() throws Exception {
-    createFile("/tmp/testPagination", "1234567890");  // 10 bytes, 3 pages if 1 page is 4 bytes
-
-    Response response = fileService.getFilePage("/tmp/testPagination", 0L);
-    ServiceTestUtils.assertHTTPResponseOK(response);
-
-    JSONObject obj = ((JSONObject) response.getEntity());
-    assertFileJsonResponseSanity(obj);
-
-    FileResource firstPage = (FileResource) obj.get("file");
-    Assert.assertEquals("1234", firstPage.getFileContent());
-    Assert.assertEquals(3, firstPage.getPageCount());
-    Assert.assertEquals(0, firstPage.getPage());
-    Assert.assertTrue(firstPage.isHasNext());
-    Assert.assertEquals("/tmp/testPagination", firstPage.getFilePath());
-
-
-    response = fileService.getFilePage("/tmp/testPagination", 1L);
-    ServiceTestUtils.assertHTTPResponseOK(response);
-
-    FileResource secondPage = (FileResource) ((JSONObject) response.getEntity()).get("file");
-    Assert.assertEquals("5678", secondPage.getFileContent());
-    Assert.assertEquals(1, secondPage.getPage());
-    Assert.assertTrue(secondPage.isHasNext());
-
-
-    response = fileService.getFilePage("/tmp/testPagination", 2L);
-    ServiceTestUtils.assertHTTPResponseOK(response);
-
-    FileResource thirdPage = (FileResource) ((JSONObject) response.getEntity()).get("file");
-    Assert.assertEquals("90", thirdPage.getFileContent());
-    Assert.assertEquals(2, thirdPage.getPage());
-    Assert.assertFalse(thirdPage.isHasNext());
-
-
-    thrown.expect(BadRequestFormattedException.class);
-    fileService.getFilePage("/tmp/testPagination", 3L);
-  }
-
-  @Test
-  public void testZeroLengthFile() throws Exception {
-    createFile("/tmp/testZeroLengthFile", "");
-
-    Response response = fileService.getFilePage("/tmp/testZeroLengthFile", 0L);
-
-    ServiceTestUtils.assertHTTPResponseOK(response);
-    JSONObject obj = ((JSONObject) response.getEntity());
-    assertFileJsonResponseSanity(obj);
-
-    FileResource fileResource = (FileResource) obj.get("file");
-    Assert.assertEquals("", fileResource.getFileContent());
-    Assert.assertEquals(0, fileResource.getPage());
-    Assert.assertFalse(fileResource.isHasNext());
-  }
-
-  @Test
-  public void testFileNotFound() throws IOException, InterruptedException {
-    assertHDFSFileNotExists("/tmp/notExistentFile");
-
-    thrown.expect(NotFoundFormattedException.class);
-    fileService.getFilePage("/tmp/notExistentFile", 2L);
-  }
-
-  @Test
-  public void testDeleteFile() throws IOException, InterruptedException {
-    createFile("/tmp/testDeleteFile", "some content");
-
-    assertHDFSFileExists("/tmp/testDeleteFile");
-
-    Response response = fileService.deleteFile("/tmp/testDeleteFile");
-    ServiceTestUtils.assertHTTPResponseNoContent(response);
-
-    assertHDFSFileNotExists("/tmp/testDeleteFile");
-  }
-
-  @Test
-  public void testFakeFile() throws IOException, InterruptedException {
-    String content = "Fake file content";
-    String encodedContent = Base64.encodeBase64String(content.getBytes());
-    String filepath = "fakefile://"+encodedContent;
-    Response response = fileService.getFilePage(filepath,0l);
-
-    ServiceTestUtils.assertHTTPResponseOK(response);
-    JSONObject obj = ((JSONObject) response.getEntity());
-    assertFileJsonResponseSanity(obj);
-
-    FileResource fileResource = (FileResource) obj.get("file");
-    Assert.assertEquals(content, fileResource.getFileContent());
-    Assert.assertEquals(0, fileResource.getPage());
-    Assert.assertFalse(fileResource.isHasNext());
-  }
-
-  @Test
-  public void testJsonFakeFile() throws IOException, InterruptedException,Exception {
-    String content = "{\"queryText\":\"Query Content\"}";
-    String url = "http://fileurl/content#queryText";
-    String filepath = "jsonpath:"+url;
-
-    URLStreamProvider urlStreamProvider = createNiceMock(URLStreamProvider.class);
-    InputStream inputStream = IOUtils.toInputStream(content);
-    reset(context);
-    expect(context.getProperties()).andReturn(properties).anyTimes();
-    expect(context.getURLStreamProvider()).andReturn(urlStreamProvider);
-    expect(urlStreamProvider.readFrom(eq(url),eq("GET"),anyString(), EasyMock.<Map<String, String>>anyObject())).andReturn(inputStream);
-
-    fileService = getService(FileService.class, handler, context);
-    replay(context,urlStreamProvider);
-
-    Response response = fileService.getFilePage(filepath,0l);
-
-    ServiceTestUtils.assertHTTPResponseOK(response);
-    JSONObject obj = ((JSONObject) response.getEntity());
-    assertFileJsonResponseSanity(obj);
-
-    FileResource fileResource = (FileResource) obj.get("file");
-    Assert.assertEquals("Query Content", fileResource.getFileContent());
-    Assert.assertEquals(0, fileResource.getPage());
-    Assert.assertFalse(fileResource.isHasNext());
-  }
-
-
-  private Response createFile(String filePath, String content) throws IOException, InterruptedException {
-    FileService.FileResourceRequest request = new FileService.FileResourceRequest();
-    request.file = new FileResource();
-    request.file.setFilePath(filePath);
-    request.file.setFileContent(content);
-
-    return fileService.createFile(request,
-        ServiceTestUtils.getResponseWithLocation(), ServiceTestUtils.getDefaultUriInfo());
-  }
-
-
-  private void assertFileJsonResponseSanity(JSONObject obj) {
-    Assert.assertTrue(obj.containsKey("file"));
-  }
-
-  private void assertHDFSFileContains(String filePath, String expectedContent) throws IOException {
-    FSDataInputStream fileInputStream = hdfsCluster.getFileSystem().open(new Path(filePath));
-    byte[] buffer = new byte[256];
-    int read = fileInputStream.read(buffer);
-
-    byte[] readData = Arrays.copyOfRange(buffer, 0, read);
-    String actualContent = new String(readData, Charset.forName("UTF-8"));
-
-    Assert.assertEquals(expectedContent, actualContent);
-  }
-
-  private void assertHDFSFileExists(String filePath) throws IOException {
-    Assert.assertTrue( hdfsCluster.getFileSystem().exists(new Path(filePath)) );
-  }
-
-  private void assertHDFSFileNotExists(String filePath) throws IOException {
-    Assert.assertFalse(hdfsCluster.getFileSystem().exists(new Path(filePath)) );
-  }
-
-}


[07/23] ambari git commit: AMBARI-19302 : removed contrib/views/hive folder and made necessary changes in pom.xml files (nitirajrathore)

Posted by ni...@apache.org.
http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/vendor/codemirror/codemirror-min.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/vendor/codemirror/codemirror-min.js b/contrib/views/hive/src/main/resources/ui/hive-web/vendor/codemirror/codemirror-min.js
deleted file mode 100644
index 13d2b2b..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/vendor/codemirror/codemirror-min.js
+++ /dev/null
@@ -1,17 +0,0 @@
-/* CodeMirror - Minified & Bundled
-   Generated on 10/30/2014 with http://codemirror.net/doc/compress.html
-   Version: HEAD
-
-   CodeMirror Library:
-   - codemirror.js
-   Modes:
-   - sql.js
-   Add-ons:
-   - sql-hint.js
- */
-
-!function(a){if("object"==typeof exports&&"object"==typeof module)module.exports=a();else{if("function"==typeof define&&define.amd)return define([],a);this.CodeMirror=a()}}(function(){"use strict";function w(a,b){if(!(this instanceof w))return new w(a,b);this.options=b=b?Pg(b):{},Pg(ie,b,!1),J(b);var c=b.value;"string"==typeof c&&(c=new Kf(c,b.mode)),this.doc=c;var f=this.display=new x(a,c);f.wrapper.CodeMirror=this,F(this),D(this),b.lineWrapping&&(this.display.wrapper.className+=" CodeMirror-wrap"),b.autofocus&&!o&&_c(this),this.state={keyMaps:[],overlays:[],modeGen:0,overwrite:!1,focused:!1,suppressEdits:!1,pasteIncoming:!1,cutIncoming:!1,draggingText:!1,highlight:new Fg,keySeq:null},d&&11>e&&setTimeout(Qg($c,this,!0),20),cd(this),hh(),Ac(this),this.curOp.forceUpdate=!0,Of(this,c),b.autofocus&&!o||ah()==f.input?setTimeout(Qg(Hd,this),20):Id(this);for(var g in je)je.hasOwnProperty(g)&&je[g](this,b[g],le);P(this);for(var h=0;h<pe.length;++h)pe[h](this);Cc(this)}function x(a,b){var c
 =this,g=c.input=Xg("textarea",null,null,"position: absolute; padding: 0; width: 1px; height: 1em; outline: none");f?g.style.width="1000px":g.setAttribute("wrap","off"),n&&(g.style.border="1px solid black"),g.setAttribute("autocorrect","off"),g.setAttribute("autocapitalize","off"),g.setAttribute("spellcheck","false"),c.inputDiv=Xg("div",[g],null,"overflow: hidden; position: relative; width: 3px; height: 0px;"),c.scrollbarH=Xg("div",[Xg("div",null,null,"height: 100%; min-height: 1px")],"CodeMirror-hscrollbar"),c.scrollbarV=Xg("div",[Xg("div",null,null,"min-width: 1px")],"CodeMirror-vscrollbar"),c.scrollbarFiller=Xg("div",null,"CodeMirror-scrollbar-filler"),c.gutterFiller=Xg("div",null,"CodeMirror-gutter-filler"),c.lineDiv=Xg("div",null,"CodeMirror-code"),c.selectionDiv=Xg("div",null,null,"position: relative; z-index: 1"),c.cursorDiv=Xg("div",null,"CodeMirror-cursors"),c.measure=Xg("div",null,"CodeMirror-measure"),c.lineMeasure=Xg("div",null,"CodeMirror-measure"),c.lineSpace=Xg("div",[
 c.measure,c.lineMeasure,c.selectionDiv,c.cursorDiv,c.lineDiv],null,"position: relative; outline: none"),c.mover=Xg("div",[Xg("div",[c.lineSpace],"CodeMirror-lines")],null,"position: relative"),c.sizer=Xg("div",[c.mover],"CodeMirror-sizer"),c.heightForcer=Xg("div",null,null,"position: absolute; height: "+Ag+"px; width: 1px;"),c.gutters=Xg("div",null,"CodeMirror-gutters"),c.lineGutter=null,c.scroller=Xg("div",[c.sizer,c.heightForcer,c.gutters],"CodeMirror-scroll"),c.scroller.setAttribute("tabIndex","-1"),c.wrapper=Xg("div",[c.inputDiv,c.scrollbarH,c.scrollbarV,c.scrollbarFiller,c.gutterFiller,c.scroller],"CodeMirror"),d&&8>e&&(c.gutters.style.zIndex=-1,c.scroller.style.paddingRight=0),n&&(g.style.width="0px"),f||(c.scroller.draggable=!0),k&&(c.inputDiv.style.height="1px",c.inputDiv.style.position="absolute"),d&&8>e&&(c.scrollbarH.style.minHeight=c.scrollbarV.style.minWidth="18px"),a&&(a.appendChild?a.appendChild(c.wrapper):a(c.wrapper)),c.viewFrom=c.viewTo=b.first,c.view=[],c.external
 Measured=null,c.viewOffset=0,c.lastWrapHeight=c.lastWrapWidth=0,c.updateLineNumbers=null,c.lineNumWidth=c.lineNumInnerWidth=c.lineNumChars=null,c.prevInput="",c.alignWidgets=!1,c.pollingFast=!1,c.poll=new Fg,c.cachedCharWidth=c.cachedTextHeight=c.cachedPaddingH=null,c.inaccurateSelection=!1,c.maxLine=null,c.maxLineLength=0,c.maxLineChanged=!1,c.wheelDX=c.wheelDY=c.wheelStartX=c.wheelStartY=null,c.shift=!1,c.selForContextMenu=null}function y(a){a.doc.mode=w.getMode(a.options,a.doc.modeOption),z(a)}function z(a){a.doc.iter(function(a){a.stateAfter&&(a.stateAfter=null),a.styles&&(a.styles=null)}),a.doc.frontier=a.doc.first,Tb(a,100),a.state.modeGen++,a.curOp&&Pc(a)}function A(a){a.options.lineWrapping?(dh(a.display.wrapper,"CodeMirror-wrap"),a.display.sizer.style.minWidth=""):(ch(a.display.wrapper,"CodeMirror-wrap"),I(a)),C(a),Pc(a),kc(a),setTimeout(function(){M(a)},100)}function B(a){var b=wc(a.display),c=a.options.lineWrapping,d=c&&Math.max(5,a.display.scroller.clientWidth/xc(a.displ
 ay)-3);return function(e){if(ef(a.doc,e))return 0;var f=0;if(e.widgets)for(var g=0;g<e.widgets.length;g++)e.widgets[g].height&&(f+=e.widgets[g].height);return c?f+(Math.ceil(e.text.length/d)||1)*b:f+b}}function C(a){var b=a.doc,c=B(a);b.iter(function(a){var b=c(a);b!=a.height&&Sf(a,b)})}function D(a){a.display.wrapper.className=a.display.wrapper.className.replace(/\s*cm-s-\S+/g,"")+a.options.theme.replace(/(^|\s)\s*/g," cm-s-"),kc(a)}function E(a){F(a),Pc(a),setTimeout(function(){O(a)},20)}function F(a){var b=a.display.gutters,c=a.options.gutters;Zg(b);for(var d=0;d<c.length;++d){var e=c[d],f=b.appendChild(Xg("div",null,"CodeMirror-gutter "+e));"CodeMirror-linenumbers"==e&&(a.display.lineGutter=f,f.style.width=(a.display.lineNumWidth||1)+"px")}b.style.display=d?"":"none",G(a)}function G(a){var b=a.display.gutters.offsetWidth;a.display.sizer.style.marginLeft=b+"px",a.display.scrollbarH.style.left=a.options.fixedGutter?b+"px":0}function H(a){if(0==a.height)return 0;for(var c,b=a.text.
 length,d=a;c=Ze(d);){var e=c.find(0,!0);d=e.from.line,b+=e.from.ch-e.to.ch}for(d=a;c=$e(d);){var e=c.find(0,!0);b-=d.text.length-e.from.ch,d=e.to.line,b+=d.text.length-e.to.ch}return b}function I(a){var b=a.display,c=a.doc;b.maxLine=Pf(c,c.first),b.maxLineLength=H(b.maxLine),b.maxLineChanged=!0,c.iter(function(a){var c=H(a);c>b.maxLineLength&&(b.maxLineLength=c,b.maxLine=a)})}function J(a){var b=Mg(a.gutters,"CodeMirror-linenumbers");-1==b&&a.lineNumbers?a.gutters=a.gutters.concat(["CodeMirror-linenumbers"]):b>-1&&!a.lineNumbers&&(a.gutters=a.gutters.slice(0),a.gutters.splice(b,1))}function K(a){return a.display.scroller.clientHeight-a.display.wrapper.clientHeight<Ag-3}function L(a){var b=a.display.scroller;return{clientHeight:b.clientHeight,barHeight:a.display.scrollbarV.clientHeight,scrollWidth:b.scrollWidth,clientWidth:b.clientWidth,hScrollbarTakesSpace:K(a),barWidth:a.display.scrollbarH.clientWidth,docHeight:Math.round(a.doc.height+Yb(a.display))}}function M(a,b){b||(b=L(a));var
  c=a.display,d=lh(c.measure),e=b.docHeight+Ag,f=b.scrollWidth>b.clientWidth;f&&b.scrollWidth<=b.clientWidth+1&&d>0&&!b.hScrollbarTakesSpace&&(f=!1);var g=e>b.clientHeight;if(g?(c.scrollbarV.style.display="block",c.scrollbarV.style.bottom=f?d+"px":"0",c.scrollbarV.firstChild.style.height=Math.max(0,e-b.clientHeight+(b.barHeight||c.scrollbarV.clientHeight))+"px"):(c.scrollbarV.style.display="",c.scrollbarV.firstChild.style.height="0"),f?(c.scrollbarH.style.display="block",c.scrollbarH.style.right=g?d+"px":"0",c.scrollbarH.firstChild.style.width=b.scrollWidth-b.clientWidth+(b.barWidth||c.scrollbarH.clientWidth)+"px"):(c.scrollbarH.style.display="",c.scrollbarH.firstChild.style.width="0"),f&&g?(c.scrollbarFiller.style.display="block",c.scrollbarFiller.style.height=c.scrollbarFiller.style.width=d+"px"):c.scrollbarFiller.style.display="",f&&a.options.coverGutterNextToScrollbar&&a.options.fixedGutter?(c.gutterFiller.style.display="block",c.gutterFiller.style.height=d+"px",c.gutterFiller.st
 yle.width=c.gutters.offsetWidth+"px"):c.gutterFiller.style.display="",!a.state.checkedOverlayScrollbar&&b.clientHeight>0){if(0===d){var h=p&&!l?"12px":"18px";c.scrollbarV.style.minWidth=c.scrollbarH.style.minHeight=h;var i=function(b){og(b)!=c.scrollbarV&&og(b)!=c.scrollbarH&&Kc(a,gd)(b)};qg(c.scrollbarV,"mousedown",i),qg(c.scrollbarH,"mousedown",i)}a.state.checkedOverlayScrollbar=!0}}function N(a,b,c){var d=c&&null!=c.top?Math.max(0,c.top):a.scroller.scrollTop;d=Math.floor(d-Xb(a));var e=c&&null!=c.bottom?c.bottom:d+a.wrapper.clientHeight,f=Uf(b,d),g=Uf(b,e);if(c&&c.ensure){var h=c.ensure.from.line,i=c.ensure.to.line;if(f>h)return{from:h,to:Uf(b,Vf(Pf(b,h))+a.wrapper.clientHeight)};if(Math.min(i,b.lastLine())>=g)return{from:Uf(b,Vf(Pf(b,i))-a.wrapper.clientHeight),to:i}}return{from:f,to:Math.max(g,f+1)}}function O(a){var b=a.display,c=b.view;if(b.alignWidgets||b.gutters.firstChild&&a.options.fixedGutter){for(var d=R(b)-b.scroller.scrollLeft+a.doc.scrollLeft,e=b.gutters.offsetWidth,
 f=d+"px",g=0;g<c.length;g++)if(!c[g].hidden){a.options.fixedGutter&&c[g].gutter&&(c[g].gutter.style.left=f);var h=c[g].alignable;if(h)for(var i=0;i<h.length;i++)h[i].style.left=f}a.options.fixedGutter&&(b.gutters.style.left=d+e+"px")}}function P(a){if(!a.options.lineNumbers)return!1;var b=a.doc,c=Q(a.options,b.first+b.size-1),d=a.display;if(c.length!=d.lineNumChars){var e=d.measure.appendChild(Xg("div",[Xg("div",c)],"CodeMirror-linenumber CodeMirror-gutter-elt")),f=e.firstChild.offsetWidth,g=e.offsetWidth-f;return d.lineGutter.style.width="",d.lineNumInnerWidth=Math.max(f,d.lineGutter.offsetWidth-g),d.lineNumWidth=d.lineNumInnerWidth+g,d.lineNumChars=d.lineNumInnerWidth?c.length:-1,d.lineGutter.style.width=d.lineNumWidth+"px",G(a),!0}return!1}function Q(a,b){return String(a.lineNumberFormatter(b+a.firstLineNumber))}function R(a){return a.scroller.getBoundingClientRect().left-a.sizer.getBoundingClientRect().left}function S(a,b,c){var d=a.display;this.viewport=b,this.visible=N(d,a.doc
 ,b),this.editorIsHidden=!d.wrapper.offsetWidth,this.wrapperHeight=d.wrapper.clientHeight,this.wrapperWidth=d.wrapper.clientWidth,this.oldViewFrom=d.viewFrom,this.oldViewTo=d.viewTo,this.oldScrollerWidth=d.scroller.clientWidth,this.force=c,this.dims=$(a)}function T(a,b){var c=a.display,d=a.doc;if(b.editorIsHidden)return Rc(a),!1;if(!b.force&&b.visible.from>=c.viewFrom&&b.visible.to<=c.viewTo&&(null==c.updateLineNumbers||c.updateLineNumbers>=c.viewTo)&&0==Vc(a))return!1;P(a)&&(Rc(a),b.dims=$(a));var e=d.first+d.size,f=Math.max(b.visible.from-a.options.viewportMargin,d.first),g=Math.min(e,b.visible.to+a.options.viewportMargin);c.viewFrom<f&&f-c.viewFrom<20&&(f=Math.max(d.first,c.viewFrom)),c.viewTo>g&&c.viewTo-g<20&&(g=Math.min(e,c.viewTo)),v&&(f=cf(a.doc,f),g=df(a.doc,g));var h=f!=c.viewFrom||g!=c.viewTo||c.lastWrapHeight!=b.wrapperHeight||c.lastWrapWidth!=b.wrapperWidth;Uc(a,f,g),c.viewOffset=Vf(Pf(a.doc,c.viewFrom)),a.display.mover.style.top=c.viewOffset+"px";var i=Vc(a);if(!h&&0==i
 &&!b.force&&(null==c.updateLineNumbers||c.updateLineNumbers>=c.viewTo))return!1;var j=ah();return i>4&&(c.lineDiv.style.display="none"),_(a,c.updateLineNumbers,b.dims),i>4&&(c.lineDiv.style.display=""),j&&ah()!=j&&j.offsetHeight&&j.focus(),Zg(c.cursorDiv),Zg(c.selectionDiv),h&&(c.lastWrapHeight=b.wrapperHeight,c.lastWrapWidth=b.wrapperWidth,Tb(a,400)),c.updateLineNumbers=null,!0}function U(a,b){for(var c=b.force,d=b.viewport,e=!0;;e=!1){if(e&&a.options.lineWrapping&&b.oldScrollerWidth!=a.display.scroller.clientWidth)c=!0;else if(c=!1,d&&null!=d.top&&(d={top:Math.min(a.doc.height+Yb(a.display)-Ag-a.display.scroller.clientHeight,d.top)}),b.visible=N(a.display,a.doc,d),b.visible.from>=a.display.viewFrom&&b.visible.to<=a.display.viewTo)break;if(!T(a,b))break;Y(a);var f=L(a);Pb(a),W(a,f),M(a,f)}ug(a,"update",a),(a.display.viewFrom!=b.oldViewFrom||a.display.viewTo!=b.oldViewTo)&&ug(a,"viewportChange",a,a.display.viewFrom,a.display.viewTo)}function V(a,b){var c=new S(a,b);if(T(a,c)){Y(a),U
 (a,c);var d=L(a);Pb(a),W(a,d),M(a,d)}}function W(a,b){a.display.sizer.style.minHeight=a.display.heightForcer.style.top=b.docHeight+"px",a.display.gutters.style.height=Math.max(b.docHeight,b.clientHeight-Ag)+"px"}function X(a,b){a.display.sizer.offsetWidth+a.display.gutters.offsetWidth<a.display.scroller.clientWidth-1&&(a.display.sizer.style.minHeight=a.display.heightForcer.style.top="0px",a.display.gutters.style.height=b.docHeight+"px")}function Y(a){for(var b=a.display,c=b.lineDiv.offsetTop,f=0;f<b.view.length;f++){var h,g=b.view[f];if(!g.hidden){if(d&&8>e){var i=g.node.offsetTop+g.node.offsetHeight;h=i-c,c=i}else{var j=g.node.getBoundingClientRect();h=j.bottom-j.top}var k=g.line.height-h;if(2>h&&(h=wc(b)),(k>.001||-.001>k)&&(Sf(g.line,h),Z(g.line),g.rest))for(var l=0;l<g.rest.length;l++)Z(g.rest[l])}}}function Z(a){if(a.widgets)for(var b=0;b<a.widgets.length;++b)a.widgets[b].height=a.widgets[b].node.offsetHeight}function $(a){for(var b=a.display,c={},d={},e=b.gutters.clientLeft,f=
 b.gutters.firstChild,g=0;f;f=f.nextSibling,++g)c[a.options.gutters[g]]=f.offsetLeft+f.clientLeft+e,d[a.options.gutters[g]]=f.clientWidth;return{fixedPos:R(b),gutterTotalWidth:b.gutters.offsetWidth,gutterLeft:c,gutterWidth:d,wrapperWidth:b.wrapper.clientWidth}}function _(a,b,c){function i(b){var c=b.nextSibling;return f&&p&&a.display.currentWheelTarget==b?b.style.display="none":b.parentNode.removeChild(b),c}for(var d=a.display,e=a.options.lineNumbers,g=d.lineDiv,h=g.firstChild,j=d.view,k=d.viewFrom,l=0;l<j.length;l++){var m=j[l];if(m.hidden);else if(m.node){for(;h!=m.node;)h=i(h);var o=e&&null!=b&&k>=b&&m.lineNumber;m.changes&&(Mg(m.changes,"gutter")>-1&&(o=!1),ab(a,m,k,c)),o&&(Zg(m.lineNumber),m.lineNumber.appendChild(document.createTextNode(Q(a.options,k)))),h=m.node.nextSibling}else{var n=ib(a,m,k,c);g.insertBefore(n,h)}k+=m.size}for(;h;)h=i(h)}function ab(a,b,c,d){for(var e=0;e<b.changes.length;e++){var f=b.changes[e];"text"==f?eb(a,b):"gutter"==f?gb(a,b,c,d):"class"==f?fb(b):"wi
 dget"==f&&hb(b,d)}b.changes=null}function bb(a){return a.node==a.text&&(a.node=Xg("div",null,null,"position: relative"),a.text.parentNode&&a.text.parentNode.replaceChild(a.node,a.text),a.node.appendChild(a.text),d&&8>e&&(a.node.style.zIndex=2)),a.node}function cb(a){var b=a.bgClass?a.bgClass+" "+(a.line.bgClass||""):a.line.bgClass;if(b&&(b+=" CodeMirror-linebackground"),a.background)b?a.background.className=b:(a.background.parentNode.removeChild(a.background),a.background=null);else if(b){var c=bb(a);a.background=c.insertBefore(Xg("div",null,b),c.firstChild)}}function db(a,b){var c=a.display.externalMeasured;return c&&c.line==b.line?(a.display.externalMeasured=null,b.measure=c.measure,c.built):yf(a,b)}function eb(a,b){var c=b.text.className,d=db(a,b);b.text==b.node&&(b.node=d.pre),b.text.parentNode.replaceChild(d.pre,b.text),b.text=d.pre,d.bgClass!=b.bgClass||d.textClass!=b.textClass?(b.bgClass=d.bgClass,b.textClass=d.textClass,fb(b)):c&&(b.text.className=c)}function fb(a){cb(a),a.l
 ine.wrapClass?bb(a).className=a.line.wrapClass:a.node!=a.text&&(a.node.className="");var b=a.textClass?a.textClass+" "+(a.line.textClass||""):a.line.textClass;a.text.className=b||""}function gb(a,b,c,d){b.gutter&&(b.node.removeChild(b.gutter),b.gutter=null);var e=b.line.gutterMarkers;if(a.options.lineNumbers||e){var f=bb(b),g=b.gutter=f.insertBefore(Xg("div",null,"CodeMirror-gutter-wrapper","position: absolute; left: "+(a.options.fixedGutter?d.fixedPos:-d.gutterTotalWidth)+"px"),b.text);if(!a.options.lineNumbers||e&&e["CodeMirror-linenumbers"]||(b.lineNumber=g.appendChild(Xg("div",Q(a.options,c),"CodeMirror-linenumber CodeMirror-gutter-elt","left: "+d.gutterLeft["CodeMirror-linenumbers"]+"px; width: "+a.display.lineNumInnerWidth+"px"))),e)for(var h=0;h<a.options.gutters.length;++h){var i=a.options.gutters[h],j=e.hasOwnProperty(i)&&e[i];j&&g.appendChild(Xg("div",[j],"CodeMirror-gutter-elt","left: "+d.gutterLeft[i]+"px; width: "+d.gutterWidth[i]+"px"))}}}function hb(a,b){a.alignable&&
 (a.alignable=null);for(var d,c=a.node.firstChild;c;c=d){var d=c.nextSibling;"CodeMirror-linewidget"==c.className&&a.node.removeChild(c)}jb(a,b)}function ib(a,b,c,d){var e=db(a,b);return b.text=b.node=e.pre,e.bgClass&&(b.bgClass=e.bgClass),e.textClass&&(b.textClass=e.textClass),fb(b),gb(a,b,c,d),jb(b,d),b.node}function jb(a,b){if(kb(a.line,a,b,!0),a.rest)for(var c=0;c<a.rest.length;c++)kb(a.rest[c],a,b,!1)}function kb(a,b,c,d){if(a.widgets)for(var e=bb(b),f=0,g=a.widgets;f<g.length;++f){var h=g[f],i=Xg("div",[h.node],"CodeMirror-linewidget");h.handleMouseEvents||(i.ignoreEvents=!0),lb(h,i,b,c),d&&h.above?e.insertBefore(i,b.gutter||b.text):e.appendChild(i),ug(h,"redraw")}}function lb(a,b,c,d){if(a.noHScroll){(c.alignable||(c.alignable=[])).push(b);var e=d.wrapperWidth;b.style.left=d.fixedPos+"px",a.coverGutter||(e-=d.gutterTotalWidth,b.style.paddingLeft=d.gutterTotalWidth+"px"),b.style.width=e+"px"}a.coverGutter&&(b.style.zIndex=5,b.style.position="relative",a.noHScroll||(b.style.marg
 inLeft=-d.gutterTotalWidth+"px"))}function ob(a){return mb(a.line,a.ch)}function pb(a,b){return nb(a,b)<0?b:a}function qb(a,b){return nb(a,b)<0?a:b}function rb(a,b){this.ranges=a,this.primIndex=b}function sb(a,b){this.anchor=a,this.head=b}function tb(a,b){var c=a[b];a.sort(function(a,b){return nb(a.from(),b.from())}),b=Mg(a,c);for(var d=1;d<a.length;d++){var e=a[d],f=a[d-1];if(nb(f.to(),e.from())>=0){var g=qb(f.from(),e.from()),h=pb(f.to(),e.to()),i=f.empty()?e.from()==e.head:f.from()==f.head;b>=d&&--b,a.splice(--d,2,new sb(i?h:g,i?g:h))}}return new rb(a,b)}function ub(a,b){return new rb([new sb(a,b||a)],0)}function vb(a,b){return Math.max(a.first,Math.min(b,a.first+a.size-1))}function wb(a,b){if(b.line<a.first)return mb(a.first,0);var c=a.first+a.size-1;return b.line>c?mb(c,Pf(a,c).text.length):xb(b,Pf(a,b.line).text.length)}function xb(a,b){var c=a.ch;return null==c||c>b?mb(a.line,b):0>c?mb(a.line,0):a}function yb(a,b){return b>=a.first&&b<a.first+a.size}function zb(a,b){for(var c
 =[],d=0;d<b.length;d++)c[d]=wb(a,b[d]);return c}function Ab(a,b,c,d){if(a.cm&&a.cm.display.shift||a.extend){var e=b.anchor;if(d){var f=nb(c,e)<0;f!=nb(d,e)<0?(e=c,c=d):f!=nb(c,d)<0&&(c=d)}return new sb(e,c)}return new sb(d||c,c)}function Bb(a,b,c,d){Hb(a,new rb([Ab(a,a.sel.primary(),b,c)],0),d)}function Cb(a,b,c){for(var d=[],e=0;e<a.sel.ranges.length;e++)d[e]=Ab(a,a.sel.ranges[e],b[e],null);var f=tb(d,a.sel.primIndex);Hb(a,f,c)}function Db(a,b,c,d){var e=a.sel.ranges.slice(0);e[b]=c,Hb(a,tb(e,a.sel.primIndex),d)}function Eb(a,b,c,d){Hb(a,ub(b,c),d)}function Fb(a,b){var c={ranges:b.ranges,update:function(b){this.ranges=[];for(var c=0;c<b.length;c++)this.ranges[c]=new sb(wb(a,b[c].anchor),wb(a,b[c].head))}};return sg(a,"beforeSelectionChange",a,c),a.cm&&sg(a.cm,"beforeSelectionChange",a.cm,c),c.ranges!=b.ranges?tb(c.ranges,c.ranges.length-1):b}function Gb(a,b,c){var d=a.history.done,e=Kg(d);e&&e.ranges?(d[d.length-1]=b,Ib(a,b,c)):Hb(a,b,c)}function Hb(a,b,c){Ib(a,b,c),bg(a,a.sel,a.cm
 ?a.cm.curOp.id:0/0,c)}function Ib(a,b,c){(yg(a,"beforeSelectionChange")||a.cm&&yg(a.cm,"beforeSelectionChange"))&&(b=Fb(a,b));var d=c&&c.bias||(nb(b.primary().head,a.sel.primary().head)<0?-1:1);Jb(a,Lb(a,b,d,!0)),c&&c.scroll===!1||!a.cm||be(a.cm)}function Jb(a,b){b.equals(a.sel)||(a.sel=b,a.cm&&(a.cm.curOp.updateInput=a.cm.curOp.selectionChanged=!0,xg(a.cm)),ug(a,"cursorActivity",a))}function Kb(a){Jb(a,Lb(a,a.sel,null,!1),Cg)}function Lb(a,b,c,d){for(var e,f=0;f<b.ranges.length;f++){var g=b.ranges[f],h=Mb(a,g.anchor,c,d),i=Mb(a,g.head,c,d);(e||h!=g.anchor||i!=g.head)&&(e||(e=b.ranges.slice(0,f)),e[f]=new sb(h,i))}return e?tb(e,b.primIndex):b}function Mb(a,b,c,d){var e=!1,f=b,g=c||1;a.cantEdit=!1;a:for(;;){var h=Pf(a,f.line);if(h.markedSpans)for(var i=0;i<h.markedSpans.length;++i){var j=h.markedSpans[i],k=j.marker;if((null==j.from||(k.inclusiveLeft?j.from<=f.ch:j.from<f.ch))&&(null==j.to||(k.inclusiveRight?j.to>=f.ch:j.to>f.ch))){if(d&&(sg(k,"beforeCursorEnter"),k.explicitlyCleared)
 ){if(h.markedSpans){--i;continue}break}if(!k.atomic)continue;var l=k.find(0>g?-1:1);if(0==nb(l,f)&&(l.ch+=g,l.ch<0?l=l.line>a.first?wb(a,mb(l.line-1)):null:l.ch>h.text.length&&(l=l.line<a.first+a.size-1?mb(l.line+1,0):null),!l)){if(e)return d?(a.cantEdit=!0,mb(a.first,0)):Mb(a,b,c,!0);e=!0,l=b,g=-g}f=l;continue a}}return f}}function Nb(a){for(var b=a.display,c=a.doc,d={},e=d.cursors=document.createDocumentFragment(),f=d.selection=document.createDocumentFragment(),g=0;g<c.sel.ranges.length;g++){var h=c.sel.ranges[g],i=h.empty();(i||a.options.showCursorWhenSelecting)&&Qb(a,h,e),i||Rb(a,h,f)}if(a.options.moveInputWithCursor){var j=qc(a,c.sel.primary().head,"div"),k=b.wrapper.getBoundingClientRect(),l=b.lineDiv.getBoundingClientRect();d.teTop=Math.max(0,Math.min(b.wrapper.clientHeight-10,j.top+l.top-k.top)),d.teLeft=Math.max(0,Math.min(b.wrapper.clientWidth-10,j.left+l.left-k.left))}return d}function Ob(a,b){$g(a.display.cursorDiv,b.cursors),$g(a.display.selectionDiv,b.selection),null!=
 b.teTop&&(a.display.inputDiv.style.top=b.teTop+"px",a.display.inputDiv.style.left=b.teLeft+"px")}function Pb(a){Ob(a,Nb(a))}function Qb(a,b,c){var d=qc(a,b.head,"div",null,null,!a.options.singleCursorHeightPerLine),e=c.appendChild(Xg("div","\xa0","CodeMirror-cursor"));if(e.style.left=d.left+"px",e.style.top=d.top+"px",e.style.height=Math.max(0,d.bottom-d.top)*a.options.cursorHeight+"px",d.other){var f=c.appendChild(Xg("div","\xa0","CodeMirror-cursor CodeMirror-secondarycursor"));f.style.display="",f.style.left=d.other.left+"px",f.style.top=d.other.top+"px",f.style.height=.85*(d.other.bottom-d.other.top)+"px"}}function Rb(a,b,c){function j(a,b,c,d){0>b&&(b=0),b=Math.round(b),d=Math.round(d),f.appendChild(Xg("div",null,"CodeMirror-selected","position: absolute; left: "+a+"px; top: "+b+"px; width: "+(null==c?i-a:c)+"px; height: "+(d-b)+"px"))}function k(b,c,d){function m(c,d){return pc(a,mb(b,c),"div",f,d)}var k,l,f=Pf(e,b),g=f.text.length;return wh(Wf(f),c||0,null==d?g:d,function(a,b,
 e){var n,o,p,f=m(a,"left");if(a==b)n=f,o=p=f.left;else{if(n=m(b-1,"right"),"rtl"==e){var q=f;f=n,n=q}o=f.left,p=n.right}null==c&&0==a&&(o=h),n.top-f.top>3&&(j(o,f.top,null,f.bottom),o=h,f.bottom<n.top&&j(o,f.bottom,null,n.top)),null==d&&b==g&&(p=i),(!k||f.top<k.top||f.top==k.top&&f.left<k.left)&&(k=f),(!l||n.bottom>l.bottom||n.bottom==l.bottom&&n.right>l.right)&&(l=n),h+1>o&&(o=h),j(o,n.top,p-o,n.bottom)}),{start:k,end:l}}var d=a.display,e=a.doc,f=document.createDocumentFragment(),g=Zb(a.display),h=g.left,i=d.lineSpace.offsetWidth-g.right,l=b.from(),m=b.to();if(l.line==m.line)k(l.line,l.ch,m.ch);else{var n=Pf(e,l.line),o=Pf(e,m.line),p=af(n)==af(o),q=k(l.line,l.ch,p?n.text.length+1:null).end,r=k(m.line,p?0:null,m.ch).start;p&&(q.top<r.top-2?(j(q.right,q.top,null,q.bottom),j(h,r.top,r.left,r.bottom)):j(q.right,q.top,r.left-q.right,q.bottom)),q.bottom<r.top&&j(h,q.bottom,null,r.top)}c.appendChild(f)}function Sb(a){if(a.state.focused){var b=a.display;clearInterval(b.blinker);var c=!0;b
 .cursorDiv.style.visibility="",a.options.cursorBlinkRate>0?b.blinker=setInterval(function(){b.cursorDiv.style.visibility=(c=!c)?"":"hidden"},a.options.cursorBlinkRate):a.options.cursorBlinkRate<0&&(b.cursorDiv.style.visibility="hidden")}}function Tb(a,b){a.doc.mode.startState&&a.doc.frontier<a.display.viewTo&&a.state.highlight.set(b,Qg(Ub,a))}function Ub(a){var b=a.doc;if(b.frontier<b.first&&(b.frontier=b.first),!(b.frontier>=a.display.viewTo)){var c=+new Date+a.options.workTime,d=re(b.mode,Wb(a,b.frontier)),e=[];b.iter(b.frontier,Math.min(b.first+b.size,a.display.viewTo+500),function(f){if(b.frontier>=a.display.viewFrom){var g=f.styles,h=sf(a,f,d,!0);f.styles=h.styles;var i=f.styleClasses,j=h.classes;j?f.styleClasses=j:i&&(f.styleClasses=null);for(var k=!g||g.length!=f.styles.length||i!=j&&(!i||!j||i.bgClass!=j.bgClass||i.textClass!=j.textClass),l=0;!k&&l<g.length;++l)k=g[l]!=f.styles[l];k&&e.push(b.frontier),f.stateAfter=re(b.mode,d)}else uf(a,f.text,d),f.stateAfter=0==b.frontier%
 5?re(b.mode,d):null;return++b.frontier,+new Date>c?(Tb(a,a.options.workDelay),!0):void 0}),e.length&&Jc(a,function(){for(var b=0;b<e.length;b++)Qc(a,e[b],"text")})}}function Vb(a,b,c){for(var d,e,f=a.doc,g=c?-1:b-(a.doc.mode.innerMode?1e3:100),h=b;h>g;--h){if(h<=f.first)return f.first;var i=Pf(f,h-1);if(i.stateAfter&&(!c||h<=f.frontier))return h;var j=Gg(i.text,null,a.options.tabSize);(null==e||d>j)&&(e=h-1,d=j)}return e}function Wb(a,b,c){var d=a.doc,e=a.display;if(!d.mode.startState)return!0;var f=Vb(a,b,c),g=f>d.first&&Pf(d,f-1).stateAfter;return g=g?re(d.mode,g):se(d.mode),d.iter(f,b,function(c){uf(a,c.text,g);var h=f==b-1||0==f%5||f>=e.viewFrom&&f<e.viewTo;c.stateAfter=h?re(d.mode,g):null,++f}),c&&(d.frontier=f),g}function Xb(a){return a.lineSpace.offsetTop}function Yb(a){return a.mover.offsetHeight-a.lineSpace.offsetHeight}function Zb(a){if(a.cachedPaddingH)return a.cachedPaddingH;var b=$g(a.measure,Xg("pre","x")),c=window.getComputedStyle?window.getComputedStyle(b):b.currentS
 tyle,d={left:parseInt(c.paddingLeft),right:parseInt(c.paddingRight)};return isNaN(d.left)||isNaN(d.right)||(a.cachedPaddingH=d),d}function $b(a,b,c){var d=a.options.lineWrapping,e=d&&a.display.scroller.clientWidth;if(!b.measure.heights||d&&b.measure.width!=e){var f=b.measure.heights=[];if(d){b.measure.width=e;for(var g=b.text.firstChild.getClientRects(),h=0;h<g.length-1;h++){var i=g[h],j=g[h+1];Math.abs(i.bottom-j.bottom)>2&&f.push((i.bottom+j.top)/2-c.top)}}f.push(c.bottom-c.top)}}function _b(a,b,c){if(a.line==b)return{map:a.measure.map,cache:a.measure.cache};for(var d=0;d<a.rest.length;d++)if(a.rest[d]==b)return{map:a.measure.maps[d],cache:a.measure.caches[d]};for(var d=0;d<a.rest.length;d++)if(Tf(a.rest[d])>c)return{map:a.measure.maps[d],cache:a.measure.caches[d],before:!0}}function ac(a,b){b=af(b);var c=Tf(b),d=a.display.externalMeasured=new Nc(a.doc,b,c);d.lineN=c;var e=d.built=yf(a,d);return d.text=e.pre,$g(a.display.lineMeasure,e.pre),d}function bc(a,b,c,d){return ec(a,dc(a,b
 ),c,d)}function cc(a,b){if(b>=a.display.viewFrom&&b<a.display.viewTo)return a.display.view[Sc(a,b)];var c=a.display.externalMeasured;return c&&b>=c.lineN&&b<c.lineN+c.size?c:void 0}function dc(a,b){var c=Tf(b),d=cc(a,c);d&&!d.text?d=null:d&&d.changes&&ab(a,d,c,$(a)),d||(d=ac(a,b));var e=_b(d,b,c);return{line:b,view:d,rect:null,map:e.map,cache:e.cache,before:e.before,hasHeights:!1}}function ec(a,b,c,d,e){b.before&&(c=-1);var g,f=c+(d||"");return b.cache.hasOwnProperty(f)?g=b.cache[f]:(b.rect||(b.rect=b.view.text.getBoundingClientRect()),b.hasHeights||($b(a,b.view,b.rect),b.hasHeights=!0),g=gc(a,b,c,d),g.bogus||(b.cache[f]=g)),{left:g.left,right:g.right,top:e?g.rtop:g.top,bottom:e?g.rbottom:g.bottom}}function gc(a,b,c,f){for(var h,i,j,k,g=b.map,l=0;l<g.length;l+=3){var m=g[l],n=g[l+1];if(m>c?(i=0,j=1,k="left"):n>c?(i=c-m,j=i+1):(l==g.length-3||c==n&&g[l+3]>c)&&(j=n-m,i=j-1,c>=n&&(k="right")),null!=i){if(h=g[l+2],m==n&&f==(h.insertLeft?"left":"right")&&(k=f),"left"==f&&0==i)for(;l&&g[l
 -2]==g[l-3]&&g[l-1].insertLeft;)h=g[(l-=3)+2],k="left";if("right"==f&&i==n-m)for(;l<g.length-3&&g[l+3]==g[l+4]&&!g[l+5].insertLeft;)h=g[(l+=3)+2],k="right";break}}var o;if(3==h.nodeType){for(var l=0;4>l;l++){for(;i&&Wg(b.line.text.charAt(m+i));)--i;for(;n>m+j&&Wg(b.line.text.charAt(m+j));)++j;if(d&&9>e&&0==i&&j==n-m)o=h.parentNode.getBoundingClientRect();else if(d&&a.options.lineWrapping){var p=Yg(h,i,j).getClientRects();o=p.length?p["right"==f?p.length-1:0]:fc}else o=Yg(h,i,j).getBoundingClientRect()||fc;if(o.left||o.right||0==i)break;j=i,i-=1,k="right"}d&&11>e&&(o=hc(a.display.measure,o))}else{i>0&&(k=f="right");var p;o=a.options.lineWrapping&&(p=h.getClientRects()).length>1?p["right"==f?p.length-1:0]:h.getBoundingClientRect()}if(d&&9>e&&!i&&(!o||!o.left&&!o.right)){var q=h.parentNode.getClientRects()[0];o=q?{left:q.left,right:q.left+xc(a.display),top:q.top,bottom:q.bottom}:fc}for(var r=o.top-b.rect.top,s=o.bottom-b.rect.top,t=(r+s)/2,u=b.view.measure.heights,l=0;l<u.length-1&&!(t
 <u[l]);l++);var v=l?u[l-1]:0,w=u[l],x={left:("right"==k?o.right:o.left)-b.rect.left,right:("left"==k?o.left:o.right)-b.rect.left,top:v,bottom:w};return o.left||o.right||(x.bogus=!0),a.options.singleCursorHeightPerLine||(x.rtop=r,x.rbottom=s),x}function hc(a,b){if(!window.screen||null==screen.logicalXDPI||screen.logicalXDPI==screen.deviceXDPI||!uh(a))return b;var c=screen.logicalXDPI/screen.deviceXDPI,d=screen.logicalYDPI/screen.deviceYDPI;return{left:b.left*c,right:b.right*c,top:b.top*d,bottom:b.bottom*d}}function ic(a){if(a.measure&&(a.measure.cache={},a.measure.heights=null,a.rest))for(var b=0;b<a.rest.length;b++)a.measure.caches[b]={}}function jc(a){a.display.externalMeasure=null,Zg(a.display.lineMeasure);for(var b=0;b<a.display.view.length;b++)ic(a.display.view[b])}function kc(a){jc(a),a.display.cachedCharWidth=a.display.cachedTextHeight=a.display.cachedPaddingH=null,a.options.lineWrapping||(a.display.maxLineChanged=!0),a.display.lineNumChars=null}function lc(){return window.pag
 eXOffset||(document.documentElement||document.body).scrollLeft}function mc(){return window.pageYOffset||(document.documentElement||document.body).scrollTop}function nc(a,b,c,d){if(b.widgets)for(var e=0;e<b.widgets.length;++e)if(b.widgets[e].above){var f=jf(b.widgets[e]);c.top+=f,c.bottom+=f}if("line"==d)return c;d||(d="local");var g=Vf(b);if("local"==d?g+=Xb(a.display):g-=a.display.viewOffset,"page"==d||"window"==d){var h=a.display.lineSpace.getBoundingClientRect();g+=h.top+("window"==d?0:mc());var i=h.left+("window"==d?0:lc());c.left+=i,c.right+=i}return c.top+=g,c.bottom+=g,c}function oc(a,b,c){if("div"==c)return b;var d=b.left,e=b.top;if("page"==c)d-=lc(),e-=mc();else if("local"==c||!c){var f=a.display.sizer.getBoundingClientRect();d+=f.left,e+=f.top}var g=a.display.lineSpace.getBoundingClientRect();return{left:d-g.left,top:e-g.top}}function pc(a,b,c,d,e){return d||(d=Pf(a.doc,b.line)),nc(a,d,bc(a,d,b.ch,e),c)}function qc(a,b,c,d,e,f){function g(b,g){var h=ec(a,e,b,g?"right":"lef
 t",f);return g?h.left=h.right:h.right=h.left,nc(a,d,h,c)}function h(a,b){var c=i[b],d=c.level%2;return a==xh(c)&&b&&c.level<i[b-1].level?(c=i[--b],a=yh(c)-(c.level%2?0:1),d=!0):a==yh(c)&&b<i.length-1&&c.level<i[b+1].level&&(c=i[++b],a=xh(c)-c.level%2,d=!1),d&&a==c.to&&a>c.from?g(a-1):g(a,d)}d=d||Pf(a.doc,b.line),e||(e=dc(a,d));var i=Wf(d),j=b.ch;if(!i)return g(j);var k=Gh(i,j),l=h(j,k);return null!=Fh&&(l.other=h(j,Fh)),l}function rc(a,b){var c=0,b=wb(a.doc,b);a.options.lineWrapping||(c=xc(a.display)*b.ch);var d=Pf(a.doc,b.line),e=Vf(d)+Xb(a.display);return{left:c,right:c,top:e,bottom:e+d.height}}function sc(a,b,c,d){var e=mb(a,b);return e.xRel=d,c&&(e.outside=!0),e}function tc(a,b,c){var d=a.doc;if(c+=a.display.viewOffset,0>c)return sc(d.first,0,!0,-1);var e=Uf(d,c),f=d.first+d.size-1;if(e>f)return sc(d.first+d.size-1,Pf(d,f).text.length,!0,1);0>b&&(b=0);for(var g=Pf(d,e);;){var h=uc(a,g,e,b,c),i=$e(g),j=i&&i.find(0,!0);if(!i||!(h.ch>j.from.ch||h.ch==j.from.ch&&h.xRel>0))return h;e
 =Tf(g=j.to.line)}}function uc(a,b,c,d,e){function j(d){var e=qc(a,mb(c,d),"line",b,i);return g=!0,f>e.bottom?e.left-h:f<e.top?e.left+h:(g=!1,e.left)}var f=e-Vf(b),g=!1,h=2*a.display.wrapper.clientWidth,i=dc(a,b),k=Wf(b),l=b.text.length,m=zh(b),n=Ah(b),o=j(m),p=g,q=j(n),r=g;if(d>q)return sc(c,n,r,1);for(;;){if(k?n==m||n==Ih(b,m,1):1>=n-m){for(var s=o>d||q-d>=d-o?m:n,t=d-(s==m?o:q);Wg(b.text.charAt(s));)++s;var u=sc(c,s,s==m?p:r,-1>t?-1:t>1?1:0);return u}var v=Math.ceil(l/2),w=m+v;if(k){w=m;for(var x=0;v>x;++x)w=Ih(b,w,1)}var y=j(w);y>d?(n=w,q=y,(r=g)&&(q+=1e3),l=v):(m=w,o=y,p=g,l-=v)}}function wc(a){if(null!=a.cachedTextHeight)return a.cachedTextHeight;if(null==vc){vc=Xg("pre");for(var b=0;49>b;++b)vc.appendChild(document.createTextNode("x")),vc.appendChild(Xg("br"));vc.appendChild(document.createTextNode("x"))}$g(a.measure,vc);var c=vc.offsetHeight/50;return c>3&&(a.cachedTextHeight=c),Zg(a.measure),c||1}function xc(a){if(null!=a.cachedCharWidth)return a.cachedCharWidth;var b=Xg("sp
 an","xxxxxxxxxx"),c=Xg("pre",[b]);$g(a.measure,c);var d=b.getBoundingClientRect(),e=(d.right-d.left)/10;return e>2&&(a.cachedCharWidth=e),e||10}function Ac(a){a.curOp={cm:a,viewChanged:!1,startHeight:a.doc.height,forceUpdate:!1,updateInput:null,typing:!1,changeObjs:null,cursorActivityHandlers:null,cursorActivityCalled:0,selectionChanged:!1,updateMaxLine:!1,scrollLeft:null,scrollTop:null,scrollToPos:null,id:++zc},yc?yc.ops.push(a.curOp):a.curOp.ownsGroup=yc={ops:[a.curOp],delayedCallbacks:[]}}function Bc(a){var b=a.delayedCallbacks,c=0;do{for(;c<b.length;c++)b[c]();for(var d=0;d<a.ops.length;d++){var e=a.ops[d];if(e.cursorActivityHandlers)for(;e.cursorActivityCalled<e.cursorActivityHandlers.length;)e.cursorActivityHandlers[e.cursorActivityCalled++](e.cm)}}while(c<b.length)}function Cc(a){var b=a.curOp,c=b.ownsGroup;if(c)try{Bc(c)}finally{yc=null;for(var d=0;d<c.ops.length;d++)c.ops[d].cm.curOp=null;Dc(c)}}function Dc(a){for(var b=a.ops,c=0;c<b.length;c++)Ec(b[c]);for(var c=0;c<b.leng
 th;c++)Fc(b[c]);for(var c=0;c<b.length;c++)Gc(b[c]);for(var c=0;c<b.length;c++)Hc(b[c]);for(var c=0;c<b.length;c++)Ic(b[c])
-}function Ec(a){var b=a.cm,c=b.display;a.updateMaxLine&&I(b),a.mustUpdate=a.viewChanged||a.forceUpdate||null!=a.scrollTop||a.scrollToPos&&(a.scrollToPos.from.line<c.viewFrom||a.scrollToPos.to.line>=c.viewTo)||c.maxLineChanged&&b.options.lineWrapping,a.update=a.mustUpdate&&new S(b,a.mustUpdate&&{top:a.scrollTop,ensure:a.scrollToPos},a.forceUpdate)}function Fc(a){a.updatedDisplay=a.mustUpdate&&T(a.cm,a.update)}function Gc(a){var b=a.cm,c=b.display;a.updatedDisplay&&Y(b),a.barMeasure=L(b),c.maxLineChanged&&!b.options.lineWrapping&&(a.adjustWidthTo=bc(b,c.maxLine,c.maxLine.text.length).left+3,a.maxScrollLeft=Math.max(0,c.sizer.offsetLeft+a.adjustWidthTo+Ag-c.scroller.clientWidth)),(a.updatedDisplay||a.selectionChanged)&&(a.newSelectionNodes=Nb(b))}function Hc(a){var b=a.cm;null!=a.adjustWidthTo&&(b.display.sizer.style.minWidth=a.adjustWidthTo+"px",a.maxScrollLeft<b.doc.scrollLeft&&sd(b,Math.min(b.display.scroller.scrollLeft,a.maxScrollLeft),!0),b.display.maxLineChanged=!1),a.newSelectio
 nNodes&&Ob(b,a.newSelectionNodes),a.updatedDisplay&&W(b,a.barMeasure),(a.updatedDisplay||a.startHeight!=b.doc.height)&&M(b,a.barMeasure),a.selectionChanged&&Sb(b),b.state.focused&&a.updateInput&&$c(b,a.typing)}function Ic(a){var b=a.cm,c=b.display,d=b.doc;if(null!=a.adjustWidthTo&&Math.abs(a.barMeasure.scrollWidth-b.display.scroller.scrollWidth)>1&&M(b),a.updatedDisplay&&U(b,a.update),null==c.wheelStartX||null==a.scrollTop&&null==a.scrollLeft&&!a.scrollToPos||(c.wheelStartX=c.wheelStartY=null),null!=a.scrollTop&&(c.scroller.scrollTop!=a.scrollTop||a.forceScroll)){var e=Math.max(0,Math.min(c.scroller.scrollHeight-c.scroller.clientHeight,a.scrollTop));c.scroller.scrollTop=c.scrollbarV.scrollTop=d.scrollTop=e}if(null!=a.scrollLeft&&(c.scroller.scrollLeft!=a.scrollLeft||a.forceScroll)){var g=Math.max(0,Math.min(c.scroller.scrollWidth-c.scroller.clientWidth,a.scrollLeft));c.scroller.scrollLeft=c.scrollbarH.scrollLeft=d.scrollLeft=g,O(b)}if(a.scrollToPos){var h=Zd(b,wb(d,a.scrollToPos.fro
 m),wb(d,a.scrollToPos.to),a.scrollToPos.margin);a.scrollToPos.isCursor&&b.state.focused&&Yd(b,h)}var i=a.maybeHiddenMarkers,j=a.maybeUnhiddenMarkers;if(i)for(var k=0;k<i.length;++k)i[k].lines.length||sg(i[k],"hide");if(j)for(var k=0;k<j.length;++k)j[k].lines.length&&sg(j[k],"unhide");c.wrapper.offsetHeight&&(d.scrollTop=b.display.scroller.scrollTop),a.updatedDisplay&&f&&(b.options.lineWrapping&&X(b,a.barMeasure),a.barMeasure.scrollWidth>a.barMeasure.clientWidth&&a.barMeasure.scrollWidth<a.barMeasure.clientWidth+1&&!K(b)&&M(b)),a.changeObjs&&sg(b,"changes",b,a.changeObjs)}function Jc(a,b){if(a.curOp)return b();Ac(a);try{return b()}finally{Cc(a)}}function Kc(a,b){return function(){if(a.curOp)return b.apply(a,arguments);Ac(a);try{return b.apply(a,arguments)}finally{Cc(a)}}}function Lc(a){return function(){if(this.curOp)return a.apply(this,arguments);Ac(this);try{return a.apply(this,arguments)}finally{Cc(this)}}}function Mc(a){return function(){var b=this.cm;if(!b||b.curOp)return a.appl
 y(this,arguments);Ac(b);try{return a.apply(this,arguments)}finally{Cc(b)}}}function Nc(a,b,c){this.line=b,this.rest=bf(b),this.size=this.rest?Tf(Kg(this.rest))-c+1:1,this.node=this.text=null,this.hidden=ef(a,b)}function Oc(a,b,c){for(var e,d=[],f=b;c>f;f=e){var g=new Nc(a.doc,Pf(a.doc,f),f);e=f+g.size,d.push(g)}return d}function Pc(a,b,c,d){null==b&&(b=a.doc.first),null==c&&(c=a.doc.first+a.doc.size),d||(d=0);var e=a.display;if(d&&c<e.viewTo&&(null==e.updateLineNumbers||e.updateLineNumbers>b)&&(e.updateLineNumbers=b),a.curOp.viewChanged=!0,b>=e.viewTo)v&&cf(a.doc,b)<e.viewTo&&Rc(a);else if(c<=e.viewFrom)v&&df(a.doc,c+d)>e.viewFrom?Rc(a):(e.viewFrom+=d,e.viewTo+=d);else if(b<=e.viewFrom&&c>=e.viewTo)Rc(a);else if(b<=e.viewFrom){var f=Tc(a,c,c+d,1);f?(e.view=e.view.slice(f.index),e.viewFrom=f.lineN,e.viewTo+=d):Rc(a)}else if(c>=e.viewTo){var f=Tc(a,b,b,-1);f?(e.view=e.view.slice(0,f.index),e.viewTo=f.lineN):Rc(a)}else{var g=Tc(a,b,b,-1),h=Tc(a,c,c+d,1);g&&h?(e.view=e.view.slice(0,g.in
 dex).concat(Oc(a,g.lineN,h.lineN)).concat(e.view.slice(h.index)),e.viewTo+=d):Rc(a)}var i=e.externalMeasured;i&&(c<i.lineN?i.lineN+=d:b<i.lineN+i.size&&(e.externalMeasured=null))}function Qc(a,b,c){a.curOp.viewChanged=!0;var d=a.display,e=a.display.externalMeasured;if(e&&b>=e.lineN&&b<e.lineN+e.size&&(d.externalMeasured=null),!(b<d.viewFrom||b>=d.viewTo)){var f=d.view[Sc(a,b)];if(null!=f.node){var g=f.changes||(f.changes=[]);-1==Mg(g,c)&&g.push(c)}}}function Rc(a){a.display.viewFrom=a.display.viewTo=a.doc.first,a.display.view=[],a.display.viewOffset=0}function Sc(a,b){if(b>=a.display.viewTo)return null;if(b-=a.display.viewFrom,0>b)return null;for(var c=a.display.view,d=0;d<c.length;d++)if(b-=c[d].size,0>b)return d}function Tc(a,b,c,d){var f,e=Sc(a,b),g=a.display.view;if(!v||c==a.doc.first+a.doc.size)return{index:e,lineN:c};for(var h=0,i=a.display.viewFrom;e>h;h++)i+=g[h].size;if(i!=b){if(d>0){if(e==g.length-1)return null;f=i+g[e].size-b,e++}else f=i-b;b+=f,c+=f}for(;cf(a.doc,c)!=c;)
 {if(e==(0>d?0:g.length-1))return null;c+=d*g[e-(0>d?1:0)].size,e+=d}return{index:e,lineN:c}}function Uc(a,b,c){var d=a.display,e=d.view;0==e.length||b>=d.viewTo||c<=d.viewFrom?(d.view=Oc(a,b,c),d.viewFrom=b):(d.viewFrom>b?d.view=Oc(a,b,d.viewFrom).concat(d.view):d.viewFrom<b&&(d.view=d.view.slice(Sc(a,b))),d.viewFrom=b,d.viewTo<c?d.view=d.view.concat(Oc(a,d.viewTo,c)):d.viewTo>c&&(d.view=d.view.slice(0,Sc(a,c)))),d.viewTo=c}function Vc(a){for(var b=a.display.view,c=0,d=0;d<b.length;d++){var e=b[d];e.hidden||e.node&&!e.changes||++c}return c}function Wc(a){a.display.pollingFast||a.display.poll.set(a.options.pollInterval,function(){Zc(a),a.state.focused&&Wc(a)})}function Xc(a){function c(){var d=Zc(a);d||b?(a.display.pollingFast=!1,Wc(a)):(b=!0,a.display.poll.set(60,c))}var b=!1;a.display.pollingFast=!0,a.display.poll.set(20,c)}function Zc(a){var b=a.display.input,c=a.display.prevInput,f=a.doc;if(!a.state.focused||rh(b)&&!c||bd(a)||a.options.disableInput||a.state.keySeq)return!1;a.stat
 e.pasteIncoming&&a.state.fakedLastChar&&(b.value=b.value.substring(0,b.value.length-1),a.state.fakedLastChar=!1);var g=b.value;if(g==c&&!a.somethingSelected())return!1;if(d&&e>=9&&a.display.inputHasSelection===g||p&&/[\uf700-\uf7ff]/.test(g))return $c(a),!1;var h=!a.curOp;h&&Ac(a),a.display.shift=!1,8203!=g.charCodeAt(0)||f.sel!=a.display.selForContextMenu||c||(c="\u200b");for(var i=0,j=Math.min(c.length,g.length);j>i&&c.charCodeAt(i)==g.charCodeAt(i);)++i;var k=g.slice(i),l=qh(k),m=null;a.state.pasteIncoming&&f.sel.ranges.length>1&&(Yc&&Yc.join("\n")==k?m=0==f.sel.ranges.length%Yc.length&&Ng(Yc,qh):l.length==f.sel.ranges.length&&(m=Ng(l,function(a){return[a]})));for(var n=f.sel.ranges.length-1;n>=0;n--){var o=f.sel.ranges[n],q=o.from(),r=o.to();i<c.length?q=mb(q.line,q.ch-(c.length-i)):a.state.overwrite&&o.empty()&&!a.state.pasteIncoming&&(r=mb(r.line,Math.min(Pf(f,r.line).text.length,r.ch+Kg(l).length)));var s=a.curOp.updateInput,t={from:q,to:r,text:m?m[n%m.length]:l,origin:a.stat
 e.pasteIncoming?"paste":a.state.cutIncoming?"cut":"+input"};if(Rd(a.doc,t),ug(a,"inputRead",a,t),k&&!a.state.pasteIncoming&&a.options.electricChars&&a.options.smartIndent&&o.head.ch<100&&(!n||f.sel.ranges[n-1].head.line!=o.head.line)){var u=a.getModeAt(o.head),v=Ld(t);if(u.electricChars){for(var w=0;w<u.electricChars.length;w++)if(k.indexOf(u.electricChars.charAt(w))>-1){de(a,v.line,"smart");break}}else u.electricInput&&u.electricInput.test(Pf(f,v.line).text.slice(0,v.ch))&&de(a,v.line,"smart")}}return be(a),a.curOp.updateInput=s,a.curOp.typing=!0,g.length>1e3||g.indexOf("\n")>-1?b.value=a.display.prevInput="":a.display.prevInput=g,h&&Cc(a),a.state.pasteIncoming=a.state.cutIncoming=!1,!0}function $c(a,b){var c,f,g=a.doc;if(a.somethingSelected()){a.display.prevInput="";var h=g.sel.primary();c=sh&&(h.to().line-h.from().line>100||(f=a.getSelection()).length>1e3);var i=c?"-":f||a.getSelection();a.display.input.value=i,a.state.focused&&Lg(a.display.input),d&&e>=9&&(a.display.inputHasSele
 ction=i)}else b||(a.display.prevInput=a.display.input.value="",d&&e>=9&&(a.display.inputHasSelection=null));a.display.inaccurateSelection=c}function _c(a){"nocursor"==a.options.readOnly||o&&ah()==a.display.input||a.display.input.focus()}function ad(a){a.state.focused||(_c(a),Hd(a))}function bd(a){return a.options.readOnly||a.doc.cantEdit}function cd(a){function c(){a.state.focused&&setTimeout(Qg(_c,a),0)}function g(b){wg(a,b)||ng(b)}function h(c){if(a.somethingSelected())Yc=a.getSelections(),b.inaccurateSelection&&(b.prevInput="",b.inaccurateSelection=!1,b.input.value=Yc.join("\n"),Lg(b.input));else{for(var d=[],e=[],f=0;f<a.doc.sel.ranges.length;f++){var g=a.doc.sel.ranges[f].head.line,h={anchor:mb(g,0),head:mb(g+1,0)};e.push(h),d.push(a.getRange(h.anchor,h.head))}"cut"==c.type?a.setSelections(e,null,Cg):(b.prevInput="",b.input.value=d.join("\n"),Lg(b.input)),Yc=d}"cut"==c.type&&(a.state.cutIncoming=!0)}var b=a.display;qg(b.scroller,"mousedown",Kc(a,gd)),d&&11>e?qg(b.scroller,"dblc
 lick",Kc(a,function(b){if(!wg(a,b)){var c=fd(a,b);if(c&&!nd(a,b)&&!ed(a.display,b)){kg(b);var d=a.findWordAt(c);Bb(a.doc,d.anchor,d.head)}}})):qg(b.scroller,"dblclick",function(b){wg(a,b)||kg(b)}),qg(b.lineSpace,"selectstart",function(a){ed(b,a)||kg(a)}),t||qg(b.scroller,"contextmenu",function(b){Jd(a,b)}),qg(b.scroller,"scroll",function(){b.scroller.clientHeight&&(rd(a,b.scroller.scrollTop),sd(a,b.scroller.scrollLeft,!0),sg(a,"scroll",a))}),qg(b.scrollbarV,"scroll",function(){b.scroller.clientHeight&&rd(a,b.scrollbarV.scrollTop)}),qg(b.scrollbarH,"scroll",function(){b.scroller.clientHeight&&sd(a,b.scrollbarH.scrollLeft)}),qg(b.scroller,"mousewheel",function(b){vd(a,b)}),qg(b.scroller,"DOMMouseScroll",function(b){vd(a,b)}),qg(b.scrollbarH,"mousedown",c),qg(b.scrollbarV,"mousedown",c),qg(b.wrapper,"scroll",function(){b.wrapper.scrollTop=b.wrapper.scrollLeft=0}),qg(b.input,"keyup",function(b){Fd.call(a,b)}),qg(b.input,"input",function(){d&&e>=9&&a.display.inputHasSelection&&(a.display
 .inputHasSelection=null),Xc(a)}),qg(b.input,"keydown",Kc(a,Dd)),qg(b.input,"keypress",Kc(a,Gd)),qg(b.input,"focus",Qg(Hd,a)),qg(b.input,"blur",Qg(Id,a)),a.options.dragDrop&&(qg(b.scroller,"dragstart",function(b){qd(a,b)}),qg(b.scroller,"dragenter",g),qg(b.scroller,"dragover",g),qg(b.scroller,"drop",Kc(a,pd))),qg(b.scroller,"paste",function(c){ed(b,c)||(a.state.pasteIncoming=!0,_c(a),Xc(a))}),qg(b.input,"paste",function(){if(f&&!a.state.fakedLastChar&&!(new Date-a.state.lastMiddleDown<200)){var c=b.input.selectionStart,d=b.input.selectionEnd;b.input.value+="$",b.input.selectionEnd=d,b.input.selectionStart=c,a.state.fakedLastChar=!0}a.state.pasteIncoming=!0,Xc(a)}),qg(b.input,"cut",h),qg(b.input,"copy",h),k&&qg(b.sizer,"mouseup",function(){ah()==b.input&&b.input.blur(),_c(a)})}function dd(a){var b=a.display;(b.lastWrapHeight!=b.wrapper.clientHeight||b.lastWrapWidth!=b.wrapper.clientWidth)&&(b.cachedCharWidth=b.cachedTextHeight=b.cachedPaddingH=null,a.setSize())}function ed(a,b){for(va
 r c=og(b);c!=a.wrapper;c=c.parentNode)if(!c||c.ignoreEvents||c.parentNode==a.sizer&&c!=a.mover)return!0}function fd(a,b,c,d){var e=a.display;if(!c){var f=og(b);if(f==e.scrollbarH||f==e.scrollbarV||f==e.scrollbarFiller||f==e.gutterFiller)return null}var g,h,i=e.lineSpace.getBoundingClientRect();try{g=b.clientX-i.left,h=b.clientY-i.top}catch(b){return null}var k,j=tc(a,g,h);if(d&&1==j.xRel&&(k=Pf(a.doc,j.line).text).length==j.ch){var l=Gg(k,k.length,a.options.tabSize)-k.length;j=mb(j.line,Math.max(0,Math.round((g-Zb(a.display).left)/xc(a.display))-l))}return j}function gd(a){if(!wg(this,a)){var b=this,c=b.display;if(c.shift=a.shiftKey,ed(c,a))return f||(c.scroller.draggable=!1,setTimeout(function(){c.scroller.draggable=!0},100)),void 0;if(!nd(b,a)){var d=fd(b,a);switch(window.focus(),pg(a)){case 1:d?jd(b,a,d):og(a)==c.scroller&&kg(a);break;case 2:f&&(b.state.lastMiddleDown=+new Date),d&&Bb(b.doc,d),setTimeout(Qg(_c,b),20),kg(a);break;case 3:t&&Jd(b,a)}}}}function jd(a,b,c){setTimeout(
 Qg(ad,a),0);var e,d=+new Date;id&&id.time>d-400&&0==nb(id.pos,c)?e="triple":hd&&hd.time>d-400&&0==nb(hd.pos,c)?(e="double",id={time:d,pos:c}):(e="single",hd={time:d,pos:c});var f=a.doc.sel,g=p?b.metaKey:b.ctrlKey;a.options.dragDrop&&jh&&!bd(a)&&"single"==e&&f.contains(c)>-1&&f.somethingSelected()?kd(a,b,c,g):ld(a,b,c,e,g)}function kd(a,b,c,g){var h=a.display,i=Kc(a,function(j){f&&(h.scroller.draggable=!1),a.state.draggingText=!1,rg(document,"mouseup",i),rg(h.scroller,"drop",i),Math.abs(b.clientX-j.clientX)+Math.abs(b.clientY-j.clientY)<10&&(kg(j),g||Bb(a.doc,c),_c(a),d&&9==e&&setTimeout(function(){document.body.focus(),_c(a)},20))});f&&(h.scroller.draggable=!0),a.state.draggingText=i,h.scroller.dragDrop&&h.scroller.dragDrop(),qg(document,"mouseup",i),qg(h.scroller,"drop",i)}function ld(a,b,c,d,e){function n(b){if(0!=nb(m,b))if(m=b,"rect"==d){for(var e=[],f=a.options.tabSize,k=Gg(Pf(g,c.line).text,c.ch,f),l=Gg(Pf(g,b.line).text,b.ch,f),n=Math.min(k,l),o=Math.max(k,l),p=Math.min(c.lin
 e,b.line),q=Math.min(a.lastLine(),Math.max(c.line,b.line));q>=p;p++){var r=Pf(g,p).text,s=Hg(r,n,f);n==o?e.push(new sb(mb(p,s),mb(p,s))):r.length>s&&e.push(new sb(mb(p,s),mb(p,Hg(r,o,f))))}e.length||e.push(new sb(c,c)),Hb(g,tb(j.ranges.slice(0,i).concat(e),i),{origin:"*mouse",scroll:!1}),a.scrollIntoView(b)}else{var t=h,u=t.anchor,v=b;if("single"!=d){if("double"==d)var w=a.findWordAt(b);else var w=new sb(mb(b.line,0),wb(g,mb(b.line+1,0)));nb(w.anchor,u)>0?(v=w.head,u=qb(t.from(),w.anchor)):(v=w.anchor,u=pb(t.to(),w.head))}var e=j.ranges.slice(0);e[i]=new sb(wb(g,u),v),Hb(g,tb(e,i),Dg)}}function q(b){var c=++p,e=fd(a,b,!0,"rect"==d);if(e)if(0!=nb(e,m)){ad(a),n(e);var h=N(f,g);(e.line>=h.to||e.line<h.from)&&setTimeout(Kc(a,function(){p==c&&q(b)}),150)}else{var i=b.clientY<o.top?-20:b.clientY>o.bottom?20:0;i&&setTimeout(Kc(a,function(){p==c&&(f.scroller.scrollTop+=i,q(b))}),50)}}function r(b){p=1/0,kg(b),_c(a),rg(document,"mousemove",s),rg(document,"mouseup",t),g.history.lastSelOrigin=
 null}var f=a.display,g=a.doc;kg(b);var h,i,j=g.sel;if(e&&!b.shiftKey?(i=g.sel.contains(c),h=i>-1?g.sel.ranges[i]:new sb(c,c)):h=g.sel.primary(),b.altKey)d="rect",e||(h=new sb(c,c)),c=fd(a,b,!0,!0),i=-1;else if("double"==d){var k=a.findWordAt(c);h=a.display.shift||g.extend?Ab(g,h,k.anchor,k.head):k}else if("triple"==d){var l=new sb(mb(c.line,0),wb(g,mb(c.line+1,0)));h=a.display.shift||g.extend?Ab(g,h,l.anchor,l.head):l}else h=Ab(g,h,c);e?i>-1?Db(g,i,h,Dg):(i=g.sel.ranges.length,Hb(g,tb(g.sel.ranges.concat([h]),i),{scroll:!1,origin:"*mouse"})):(i=0,Hb(g,new rb([h],0),Dg),j=g.sel);var m=c,o=f.wrapper.getBoundingClientRect(),p=0,s=Kc(a,function(a){pg(a)?q(a):r(a)}),t=Kc(a,r);qg(document,"mousemove",s),qg(document,"mouseup",t)}function md(a,b,c,d,e){try{var f=b.clientX,g=b.clientY}catch(b){return!1}if(f>=Math.floor(a.display.gutters.getBoundingClientRect().right))return!1;d&&kg(b);var h=a.display,i=h.lineDiv.getBoundingClientRect();if(g>i.bottom||!yg(a,c))return mg(b);g-=i.top-h.viewOffs
 et;for(var j=0;j<a.options.gutters.length;++j){var k=h.gutters.childNodes[j];if(k&&k.getBoundingClientRect().right>=f){var l=Uf(a.doc,g),m=a.options.gutters[j];return e(a,c,a,l,m,b),mg(b)}}}function nd(a,b){return md(a,b,"gutterClick",!0,ug)}function pd(a){var b=this;if(!wg(b,a)&&!ed(b.display,a)){kg(a),d&&(od=+new Date);var c=fd(b,a,!0),e=a.dataTransfer.files;if(c&&!bd(b))if(e&&e.length&&window.FileReader&&window.File)for(var f=e.length,g=Array(f),h=0,i=function(a,d){var e=new FileReader;e.onload=Kc(b,function(){if(g[d]=e.result,++h==f){c=wb(b.doc,c);var a={from:c,to:c,text:qh(g.join("\n")),origin:"paste"};Rd(b.doc,a),Gb(b.doc,ub(c,Ld(a)))}}),e.readAsText(a)},j=0;f>j;++j)i(e[j],j);else{if(b.state.draggingText&&b.doc.sel.contains(c)>-1)return b.state.draggingText(a),setTimeout(Qg(_c,b),20),void 0;try{var g=a.dataTransfer.getData("Text");if(g){if(b.state.draggingText&&!(p?a.metaKey:a.ctrlKey))var k=b.listSelections();if(Ib(b.doc,ub(c,c)),k)for(var j=0;j<k.length;++j)Xd(b.doc,"",k[j].
 anchor,k[j].head,"drag");b.replaceSelection(g,"around","paste"),_c(b)}}catch(a){}}}}function qd(a,b){if(d&&(!a.state.draggingText||+new Date-od<100))return ng(b),void 0;if(!wg(a,b)&&!ed(a.display,b)&&(b.dataTransfer.setData("Text",a.getSelection()),b.dataTransfer.setDragImage&&!j)){var c=Xg("img",null,null,"position: fixed; left: 0; top: 0;");c.src="",i&&(c.width=c.height=1,a.display.wrapper.appendChild(c),c._top=c.offsetTop),b.dataTransfer.setDragImage(c,0,0),i&&c.parentNode.removeChild(c)}}function rd(b,c){Math.abs(b.doc.scrollTop-c)<2||(b.doc.scrollTop=c,a||V(b,{top:c}),b.display.scroller.scrollTop!=c&&(b.display.scroller.scrollTop=c),b.display.scrollbarV.scrollTop!=c&&(b.display.scrollbarV.scrollTop=c),a&&V(b),Tb(b,100))}function sd(a,b,c){(c?b==a.doc.scrollLeft:Math.abs(a.doc.scrollLeft-b)<2)||(b=Math.min(b,a.display.scroller.scrollWidth-a.display.scroller.clientWidth),a.doc.scrollLeft=b,O(a),a.display.sc
 roller.scrollLeft!=b&&(a.display.scroller.scrollLeft=b),a.display.scrollbarH.scrollLeft!=b&&(a.display.scrollbarH.scrollLeft=b))}function vd(b,c){var d=c.wheelDeltaX,e=c.wheelDeltaY;null==d&&c.detail&&c.axis==c.HORIZONTAL_AXIS&&(d=c.detail),null==e&&c.detail&&c.axis==c.VERTICAL_AXIS?e=c.detail:null==e&&(e=c.wheelDelta);var g=b.display,h=g.scroller;if(d&&h.scrollWidth>h.clientWidth||e&&h.scrollHeight>h.clientHeight){if(e&&p&&f)a:for(var j=c.target,k=g.view;j!=h;j=j.parentNode)for(var l=0;l<k.length;l++)if(k[l].node==j){b.display.currentWheelTarget=j;break a}if(d&&!a&&!i&&null!=ud)return e&&rd(b,Math.max(0,Math.min(h.scrollTop+e*ud,h.scrollHeight-h.clientHeight))),sd(b,Math.max(0,Math.min(h.scrollLeft+d*ud,h.scrollWidth-h.clientWidth))),kg(c),g.wheelStartX=null,void 0;if(e&&null!=ud){var m=e*ud,n=b.doc.scrollTop,o=n+g.wrapper.clientHeight;0>m?n=Math.max(0,n+m-50):o=Math.min(b.doc.height,o+m+50),V(b,{top:n,bottom:o})}20>td&&(null==g.wheelStartX?(g.wheelStartX=h.scrollLeft,g.wheelStartY
 =h.scrollTop,g.wheelDX=d,g.wheelDY=e,setTimeout(function(){if(null!=g.wheelStartX){var a=h.scrollLeft-g.wheelStartX,b=h.scrollTop-g.wheelStartY,c=b&&g.wheelDY&&b/g.wheelDY||a&&g.wheelDX&&a/g.wheelDX;g.wheelStartX=g.wheelStartY=null,c&&(ud=(ud*td+c)/(td+1),++td)}},200)):(g.wheelDX+=d,g.wheelDY+=e))}}function wd(a,b,c){if("string"==typeof b&&(b=te[b],!b))return!1;a.display.pollingFast&&Zc(a)&&(a.display.pollingFast=!1);var d=a.display.shift,e=!1;try{bd(a)&&(a.state.suppressEdits=!0),c&&(a.display.shift=!1),e=b(a)!=Bg}finally{a.display.shift=d,a.state.suppressEdits=!1}return e}function xd(a,b,c){for(var d=0;d<a.state.keyMaps.length;d++){var e=we(b,a.state.keyMaps[d],c);if(e)return e}return a.options.extraKeys&&we(b,a.options.extraKeys,c)||we(b,a.options.keyMap,c)}function zd(a,b,c,d){var e=a.state.keySeq;if(e){if(xe(b))return"handled";yd.set(50,function(){a.state.keySeq==e&&(a.state.keySeq=null,$c(a))}),b=e+" "+b}var f=xd(a,b,d);return"multi"==f&&(a.state.keySeq=b),"handled"==f&&ug(a,"
 keyHandled",a,b,c),("handled"==f||"multi"==f)&&(kg(c),Sb(a)),e&&!f&&/\'$/.test(b)?(kg(c),!0):!!f}function Ad(a,b){var c=ye(b,!0);return c?b.shiftKey&&!a.state.keySeq?zd(a,"Shift-"+c,b,function(b){return wd(a,b,!0)})||zd(a,c,b,function(b){return("string"==typeof b?/^go[A-Z]/.test(b):b.motion)?wd(a,b):void 0}):zd(a,c,b,function(b){return wd(a,b)}):!1}function Bd(a,b,c){return zd(a,"'"+c+"'",b,function(b){return wd(a,b,!0)})}function Dd(a){var b=this;if(ad(b),!wg(b,a)){d&&11>e&&27==a.keyCode&&(a.returnValue=!1);var c=a.keyCode;b.display.shift=16==c||a.shiftKey;var f=Ad(b,a);i&&(Cd=f?c:null,!f&&88==c&&!sh&&(p?a.metaKey:a.ctrlKey)&&b.replaceSelection("",null,"cut")),18!=c||/\bCodeMirror-crosshair\b/.test(b.display.lineDiv.className)||Ed(b)}}function Ed(a){function c(a){18!=a.keyCode&&a.altKey||(ch(b,"CodeMirror-crosshair"),rg(document,"keyup",c),rg(document,"mouseover",c))}var b=a.display.lineDiv;dh(b,"CodeMirror-crosshair"),qg(document,"keyup",c),qg(document,"mouseover",c)}function Fd(a
 ){16==a.keyCode&&(this.doc.sel.shift=!1),wg(this,a)}function Gd(a){var b=this;if(!(wg(b,a)||a.ctrlKey&&!a.altKey||p&&a.metaKey)){var c=a.keyCode,f=a.charCode;if(i&&c==Cd)return Cd=null,kg(a),void 0;if(!(i&&(!a.which||a.which<10)||k)||!Ad(b,a)){var g=String.fromCharCode(null==f?c:f);Bd(b,a,g)||(d&&e>=9&&(b.display.inputHasSelection=null),Xc(b))}}}function Hd(a){"nocursor"!=a.options.readOnly&&(a.state.focused||(sg(a,"focus",a),a.state.focused=!0,dh(a.display.wrapper,"CodeMirror-focused"),a.curOp||a.display.selForContextMenu==a.doc.sel||($c(a),f&&setTimeout(Qg($c,a,!0),0))),Wc(a),Sb(a))}function Id(a){a.state.focused&&(sg(a,"blur",a),a.state.focused=!1,ch(a.display.wrapper,"CodeMirror-focused")),clearInterval(a.display.blinker),setTimeout(function(){a.state.focused||(a.display.shift=!1)},150)}function Jd(a,b){function m(){if(null!=c.input.selectionStart){var b=a.somethingSelected(),d=c.input.value="\u200b"+(b?c.input.value:"");c.prevInput=b?"":"\u200b",c.input.selectionStart=1,c.input
 .selectionEnd=d.length,c.selForContextMenu=a.doc.sel}}function n(){if(c.inputDiv.style.position="relative",c.input.style.cssText=k,d&&9>e&&(c.scrollbarV.scrollTop=c.scroller.scrollTop=h),Wc(a),null!=c.input.selectionStart){(!d||d&&9>e)&&m();var b=0,f=function(){c.selForContextMenu==a.doc.sel&&0==c.input.selectionStart?Kc(a,te.selectAll)(a):b++<10?c.detectingSelectAll=setTimeout(f,500):$c(a)};c.detectingSelectAll=setTimeout(f,200)}}if(!wg(a,b,"contextmenu")){var c=a.display;if(!ed(c,b)&&!Kd(a,b)){var g=fd(a,b),h=c.scroller.scrollTop;if(g&&!i){var j=a.options.resetSelectionOnContextMenu;j&&-1==a.doc.sel.contains(g)&&Kc(a,Hb)(a.doc,ub(g),Cg);var k=c.input.style.cssText;if(c.inputDiv.style.position="absolute",c.input.style.cssText="position: fixed; width: 30px; height: 30px; top: "+(b.clientY-5)+"px; left: "+(b.clientX-5)+"px; z-index: 1000; background: "+(d?"rgba(255, 255, 255, .05)":"transparent")+"; outline: none; border-width: 0; outline: none; overflow: hidden; opacity: .05; filter
 : alpha(opacity=5);",f)var l=window.scrollY;if(_c(a),f&&window.scrollTo(null,l),$c(a),a.somethingSelected()||(c.input.value=c.prevInput=" "),c.selForContextMenu=a.doc.sel,clearTimeout(c.detectingSelectAll),d&&e>=9&&m(),t){ng(b);var o=function(){rg(window,"mouseup",o),setTimeout(n,20)};qg(window,"mouseup",o)}else setTimeout(n,50)}}}}function Kd(a,b){return yg(a,"gutterContextMenu")?md(a,b,"gutterContextMenu",!1,sg):!1}function Md(a,b){if(nb(a,b.from)<0)return a;if(nb(a,b.to)<=0)return Ld(b);var c=a.line+b.text.length-(b.to.line-b.from.line)-1,d=a.ch;return a.line==b.to.line&&(d+=Ld(b).ch-b.to.ch),mb(c,d)}function Nd(a,b){for(var c=[],d=0;d<a.sel.ranges.length;d++){var e=a.sel.ranges[d];c.push(new sb(Md(e.anchor,b),Md(e.head,b)))}return tb(c,a.sel.primIndex)}function Od(a,b,c){return a.line==b.line?mb(c.line,a.ch-b.ch+c.ch):mb(c.line+(a.line-b.line),a.ch)}function Pd(a,b,c){for(var d=[],e=mb(a.first,0),f=e,g=0;g<b.length;g++){var h=b[g],i=Od(h.from,e,f),j=Od(Ld(h),e,f);if(e=h.to,f=j,"
 around"==c){var k=a.sel.ranges[g],l=nb(k.head,k.anchor)<0;d[g]=new sb(l?j:i,l?i:j)}else d[g]=new sb(i,i)}return new rb(d,a.sel.primIndex)}function Qd(a,b,c){var d={canceled:!1,from:b.from,to:b.to,text:b.text,origin:b.origin,cancel:function(){this.canceled=!0}};return c&&(d.update=function(b,c,d,e){b&&(this.from=wb(a,b)),c&&(this.to=wb(a,c)),d&&(this.text=d),void 0!==e&&(this.origin=e)}),sg(a,"beforeChange",a,d),a.cm&&sg(a.cm,"beforeChange",a.cm,d),d.canceled?null:{from:d.from,to:d.to,text:d.text,origin:d.origin}}function Rd(a,b,c){if(a.cm){if(!a.cm.curOp)return Kc(a.cm,Rd)(a,b,c);if(a.cm.state.suppressEdits)return}if(!(yg(a,"beforeChange")||a.cm&&yg(a.cm,"beforeChange"))||(b=Qd(a,b,!0))){var d=u&&!c&&Se(a,b.from,b.to);if(d)for(var e=d.length-1;e>=0;--e)Sd(a,{from:d[e].from,to:d[e].to,text:e?[""]:b.text});else Sd(a,b)}}function Sd(a,b){if(1!=b.text.length||""!=b.text[0]||0!=nb(b.from,b.to)){var c=Nd(a,b);_f(a,b,c,a.cm?a.cm.curOp.id:0/0),Vd(a,b,c,Pe(a,b));var d=[];Nf(a,function(a,c){c
 ||-1!=Mg(d,a.history)||(jg(a.history,b),d.push(a.history)),Vd(a,b,null,Pe(a,b))})}}function Td(a,b,c){if(!a.cm||!a.cm.state.suppressEdits){for(var e,d=a.history,f=a.sel,g="undo"==b?d.done:d.undone,h="undo"==b?d.undone:d.done,i=0;i<g.length&&(e=g[i],c?!e.ranges||e.equals(a.sel):e.ranges);i++);if(i!=g.length){for(d.lastOrigin=d.lastSelOrigin=null;e=g.pop(),e.ranges;){if(cg(e,h),c&&!e.equals(a.sel))return Hb(a,e,{clearRedo:!1}),void 0;f=e}var j=[];cg(f,h),h.push({changes:j,generation:d.generation}),d.generation=e.generation||++d.maxGeneration;for(var k=yg(a,"beforeChange")||a.cm&&yg(a.cm,"beforeChange"),i=e.changes.length-1;i>=0;--i){var l=e.changes[i];if(l.origin=b,k&&!Qd(a,l,!1))return g.length=0,void 0;j.push(Yf(a,l));var m=i?Nd(a,l):Kg(g);Vd(a,l,m,Re(a,l)),!i&&a.cm&&a.cm.scrollIntoView({from:l.from,to:Ld(l)});var n=[];Nf(a,function(a,b){b||-1!=Mg(n,a.history)||(jg(a.history,l),n.push(a.history)),Vd(a,l,null,Re(a,l))})}}}}function Ud(a,b){if(0!=b&&(a.first+=b,a.sel=new rb(Ng(a.sel.r
 anges,function(a){return new sb(mb(a.anchor.line+b,a.anchor.ch),mb(a.head.line+b,a.head.ch))}),a.sel.primIndex),a.cm)){Pc(a.cm,a.first,a.first-b,b);for(var c=a.cm.display,d=c.viewFrom;d<c.viewTo;d++)Qc(a.cm,d,"gutter")}}function Vd(a,b,c,d){if(a.cm&&!a.cm.curOp)return Kc(a.cm,Vd)(a,b,c,d);if(b.to.line<a.first)return Ud(a,b.text.length-1-(b.to.line-b.from.line)),void 0;if(!(b.from.line>a.lastLine())){if(b.from.line<a.first){var e=b.text.length-1-(a.first-b.from.line);Ud(a,e),b={from:mb(a.first,0),to:mb(b.to.line+e,b.to.ch),text:[Kg(b.text)],origin:b.origin}}var f=a.lastLine();b.to.line>f&&(b={from:b.from,to:mb(f,Pf(a,f).text.length),text:[b.text[0]],origin:b.origin}),b.removed=Qf(a,b.from,b.to),c||(c=Nd(a,b)),a.cm?Wd(a.cm,b,d):Gf(a,b,d),Ib(a,c,Cg)}}function Wd(a,b,c){var d=a.doc,e=a.display,f=b.from,g=b.to,h=!1,i=f.line;a.options.lineWrapping||(i=Tf(af(Pf(d,f.line))),d.iter(i,g.line+1,function(a){return a==e.maxLine?(h=!0,!0):void 0})),d.sel.contains(b.from,b.to)>-1&&xg(a),Gf(d,b,c,B
 (a)),a.options.lineWrapping||(d.iter(i,f.line+b.text.length,function(a){var b=H(a);b>e.maxLineLength&&(e.maxLine=a,e.maxLineLength=b,e.maxLineChanged=!0,h=!1)}),h&&(a.curOp.updateMaxLine=!0)),d.frontier=Math.min(d.frontier,f.line),Tb(a,400);var j=b.text.length-(g.line-f.line)-1;f.line!=g.line||1!=b.text.length||Ff(a.doc,b)?Pc(a,f.line,g.line+1,j):Qc(a,f.line,"text");var k=yg(a,"changes"),l=yg(a,"change");if(l||k){var m={from:f,to:g,text:b.text,removed:b.removed,origin:b.origin};l&&ug(a,"change",a,m),k&&(a.curOp.changeObjs||(a.curOp.changeObjs=[])).push(m)}a.display.selForContextMenu=null}function Xd(a,b,c,d,e){if(d||(d=c),nb(d,c)<0){var f=d;d=c,c=f}"string"==typeof b&&(b=qh(b)),Rd(a,{from:c,to:d,text:b,origin:e})}function Yd(a,b){var c=a.display,d=c.sizer.getBoundingClientRect(),e=null;if(b.top+d.top<0?e=!0:b.bottom+d.top>(window.innerHeight||document.documentElement.clientHeight)&&(e=!1),null!=e&&!m){var f=Xg("div","\u200b",null,"position: absolute; top: "+(b.top-c.viewOffset-Xb(a.
 display))+"px; height: "+(b.bottom-b.top+Ag)+"px; left: "+b.left+"px; width: 2px;");a.display.lineSpace.appendChild(f),f.scrollIntoView(e),a.display.lineSpace.removeChild(f)}}function Zd(a,b,c,d){null==d&&(d=0);for(var e=0;5>e;e++){var f=!1,g=qc(a,b),h=c&&c!=b?qc(a,c):g,i=_d(a,Math.min(g.left,h.left),Math.min(g.top,h.top)-d,Math.max(g.left,h.left),Math.max(g.bottom,h.bottom)+d),j=a.doc.scrollTop,k=a.doc.scrollLeft;if(null!=i.scrollTop&&(rd(a,i.scrollTop),Math.abs(a.doc.scrollTop-j)>1&&(f=!0)),null!=i.scrollLeft&&(sd(a,i.scrollLeft),Math.abs(a.doc.scrollLeft-k)>1&&(f=!0)),!f)return g}}function $d(a,b,c,d,e){var f=_d(a,b,c,d,e);null!=f.scrollTop&&rd(a,f.scrollTop),null!=f.scrollLeft&&sd(a,f.scrollLeft)}function _d(a,b,c,d,e){var f=a.display,g=wc(a.display);0>c&&(c=0);var h=a.curOp&&null!=a.curOp.scrollTop?a.curOp.scrollTop:f.scroller.scrollTop,i=f.scroller.clientHeight-Ag,j={};e-c>i&&(e=c+i);var k=a.doc.height+Yb(f),l=g>c,m=e>k-g;if(h>c)j.scrollTop=l?0:c;else if(e>h+i){var n=Math.min(
 c,(m?k:e)-i);n!=h&&(j.scrollTop=n)}var o=a.curOp&&null!=a.curOp.scrollLeft?a.curOp.scrollLeft:f.scroller.scrollLeft,p=f.scroller.clientWidth-Ag-f.gutters.offsetWidth,q=d-b>p;return q&&(d=b+p),10>b?j.scrollLeft=0:o>b?j.scrollLeft=Math.max(0,b-(q?0:10)):d>p+o-3&&(j.scrollLeft=d+(q?0:10)-p),j}function ae(a,b,c){(null!=b||null!=c)&&ce(a),null!=b&&(a.curOp.scrollLeft=(null==a.curOp.scrollLeft?a.doc.scrollLeft:a.curOp.scrollLeft)+b),null!=c&&(a.curOp.scrollTop=(null==a.curOp.scrollTop?a.doc.scrollTop:a.curOp.scrollTop)+c)}function be(a){ce(a);var b=a.getCursor(),c=b,d=b;a.options.lineWrapping||(c=b.ch?mb(b.line,b.ch-1):b,d=mb(b.line,b.ch+1)),a.curOp.scrollToPos={from:c,to:d,margin:a.options.cursorScrollMargin,isCursor:!0}}function ce(a){var b=a.curOp.scrollToPos;if(b){a.curOp.scrollToPos=null;var c=rc(a,b.from),d=rc(a,b.to),e=_d(a,Math.min(c.left,d.left),Math.min(c.top,d.top)-b.margin,Math.max(c.right,d.right),Math.max(c.bottom,d.bottom)+b.margin);a.scrollTo(e.scrollLeft,e.scrollTop)}}fun
 ction de(a,b,c,d){var f,e=a.doc;null==c&&(c="add"),"smart"==c&&(e.mode.indent?f=Wb(a,b):c="prev");var g=a.options.tabSize,h=Pf(e,b),i=Gg(h.text,null,g);h.stateAfter&&(h.stateAfter=null);var k,j=h.text.match(/^\s*/)[0];if(d||/\S/.test(h.text)){if("smart"==c&&(k=e.mode.indent(f,h.text.slice(j.length),h.text),k==Bg||k>150)){if(!d)return;c="prev"}}else k=0,c="not";"prev"==c?k=b>e.first?Gg(Pf(e,b-1).text,null,g):0:"add"==c?k=i+a.options.indentUnit:"subtract"==c?k=i-a.options.indentUnit:"number"==typeof c&&(k=i+c),k=Math.max(0,k);var l="",m=0;if(a.options.indentWithTabs)for(var n=Math.floor(k/g);n;--n)m+=g,l+="	";if(k>m&&(l+=Jg(k-m)),l!=j)Xd(e,l,mb(b,0),mb(b,j.length),"+input");else for(var n=0;n<e.sel.ranges.length;n++){var o=e.sel.ranges[n];if(o.head.line==b&&o.head.ch<j.length){var m=mb(b,j.length);Db(e,n,new sb(m,m));break}}h.stateAfter=null}function ee(a,b,c,d){var e=b,f=b;return"number"==typeof b?f=Pf(a,vb(a,b)):e=Tf(b),null==e?null:(d(f,e)&&a.cm&&Qc(a.cm,e,c),f)}function fe(a,b){fo
 r(var c=a.doc.sel.ranges,d=[],e=0;e<c.length;e++){for(var f=b(c[e]);d.length&&nb(f.from,Kg(d).to)<=0;){var g=d.pop();if(nb(g.from,f.from)<0){f.from=g.from;break}}d.push(f)}Jc(a,function(){for(var b=d.length-1;b>=0;b--)Xd(a.doc,"",d[b].from,d[b].to,"+delete");be(a)})}function ge(a,b,c,d,e){function k(){var b=f+c;return b<a.first||b>=a.first+a.size?j=!1:(f=b,i=Pf(a,b))}function l(a){var b=(e?Ih:Jh)(i,g,c,!0);if(null==b){if(a||!k())return j=!1;g=e?(0>c?Ah:zh)(i):0>c?i.text.length:0}else g=b;return!0}var f=b.line,g=b.ch,h=c,i=Pf(a,f),j=!0;if("char"==d)l();else if("column"==d)l(!0);else if("word"==d||"group"==d)for(var m=null,n="group"==d,o=a.cm&&a.cm.getHelper(b,"wordChars"),p=!0;!(0>c)||l(!p);p=!1){var q=i.text.charAt(g)||"\n",r=Tg(q,o)?"w":n&&"\n"==q?"n":!n||/\s/.test(q)?null:"p";if(!n||p||r||(r="s"),m&&m!=r){0>c&&(c=1,l());break}if(r&&(m=r),c>0&&!l(!p))break}var s=Mb(a,mb(f,g),h,!0);return j||(s.hitSide=!0),s}function he(a,b,c,d){var g,e=a.doc,f=b.left;if("page"==d){var h=Math.min(a.
 display.wrapper.clientHeight,window.innerHeight||document.documentElement.clientHeight);g=b.top+c*(h-(0>c?1.5:.5)*wc(a.display))}else"line"==d&&(g=c>0?b.bottom+3:b.top-3);for(;;){var i=tc(a,f,g);if(!i.outside)break;if(0>c?0>=g:g>=e.height){i.hitSide=!0;break}g+=5*c}return i}function ke(a,b,c,d){w.defaults[a]=b,c&&(je[a]=d?function(a,b,d){d!=le&&c(a,b,d)}:c)}function ve(a){for(var c,d,e,f,b=a.split(/-(?!$)/),a=b[b.length-1],g=0;g<b.length-1;g++){var h=b[g];if(/^(cmd|meta|m)$/i.test(h))f=!0;else if(/^a(lt)?$/i.test(h))c=!0;else if(/^(c|ctrl|control)$/i.test(h))d=!0;else{if(!/^s(hift)$/i.test(h))throw new Error("Unrecognized modifier name: "+h);e=!0}}return c&&(a="Alt-"+a),d&&(a="Ctrl-"+a),f&&(a="Cmd-"+a),e&&(a="Shift-"+a),a}function ze(a){return"string"==typeof a?ue[a]:a}function De(a,b,c,d,e){if(d&&d.shared)return Fe(a,b,c,d,e);if(a.cm&&!a.cm.curOp)return Kc(a.cm,De)(a,b,c,d,e);var f=new Be(a,e),g=nb(b,c);if(d&&Pg(d,f,!1),g>0||0==g&&f.clearWhenEmpty!==!1)return f;if(f.replacedWith&&(
 f.collapsed=!0,f.widgetNode=Xg("span",[f.replacedWith],"CodeMirror-widget"),d.handleMouseEvents||(f.widgetNode.ignoreEvents=!0),d.insertLeft&&(f.widgetNode.insertLeft=!0)),f.collapsed){if(_e(a,b.line,b,c,f)||b.line!=c.line&&_e(a,c.line,b,c,f))throw new Error("Inserting collapsed marker partially overlapping an existing one");
-v=!0}f.addToHistory&&_f(a,{from:b,to:c,origin:"markText"},a.sel,0/0);var j,h=b.line,i=a.cm;if(a.iter(h,c.line+1,function(a){i&&f.collapsed&&!i.options.lineWrapping&&af(a)==i.display.maxLine&&(j=!0),f.collapsed&&h!=b.line&&Sf(a,0),Me(a,new Je(f,h==b.line?b.ch:null,h==c.line?c.ch:null)),++h}),f.collapsed&&a.iter(b.line,c.line+1,function(b){ef(a,b)&&Sf(b,0)}),f.clearOnEnter&&qg(f,"beforeCursorEnter",function(){f.clear()}),f.readOnly&&(u=!0,(a.history.done.length||a.history.undone.length)&&a.clearHistory()),f.collapsed&&(f.id=++Ce,f.atomic=!0),i){if(j&&(i.curOp.updateMaxLine=!0),f.collapsed)Pc(i,b.line,c.line+1);else if(f.className||f.title||f.startStyle||f.endStyle)for(var k=b.line;k<=c.line;k++)Qc(i,k,"text");f.atomic&&Kb(i.doc),ug(i,"markerAdded",i,f)}return f}function Fe(a,b,c,d,e){d=Pg(d),d.shared=!1;var f=[De(a,b,c,d,e)],g=f[0],h=d.widgetNode;return Nf(a,function(a){h&&(d.widgetNode=h.cloneNode(!0)),f.push(De(a,wb(a,b),wb(a,c),d,e));for(var i=0;i<a.linked.length;++i)if(a.linked[i]
 .isParent)return;g=Kg(f)}),new Ee(f,g)}function Ge(a){return a.findMarks(mb(a.first,0),a.clipPos(mb(a.lastLine())),function(a){return a.parent})}function He(a,b){for(var c=0;c<b.length;c++){var d=b[c],e=d.find(),f=a.clipPos(e.from),g=a.clipPos(e.to);if(nb(f,g)){var h=De(a,f,g,d.primary,d.primary.type);d.markers.push(h),h.parent=d}}}function Ie(a){for(var b=0;b<a.length;b++){var c=a[b],d=[c.primary.doc];Nf(c.primary.doc,function(a){d.push(a)});for(var e=0;e<c.markers.length;e++){var f=c.markers[e];-1==Mg(d,f.doc)&&(f.parent=null,c.markers.splice(e--,1))}}}function Je(a,b,c){this.marker=a,this.from=b,this.to=c}function Ke(a,b){if(a)for(var c=0;c<a.length;++c){var d=a[c];if(d.marker==b)return d}}function Le(a,b){for(var c,d=0;d<a.length;++d)a[d]!=b&&(c||(c=[])).push(a[d]);return c}function Me(a,b){a.markedSpans=a.markedSpans?a.markedSpans.concat([b]):[b],b.marker.attachLine(a)}function Ne(a,b,c){if(a)for(var e,d=0;d<a.length;++d){var f=a[d],g=f.marker,h=null==f.from||(g.inclusiveLeft?f
 .from<=b:f.from<b);if(h||f.from==b&&"bookmark"==g.type&&(!c||!f.marker.insertLeft)){var i=null==f.to||(g.inclusiveRight?f.to>=b:f.to>b);(e||(e=[])).push(new Je(g,f.from,i?null:f.to))}}return e}function Oe(a,b,c){if(a)for(var e,d=0;d<a.length;++d){var f=a[d],g=f.marker,h=null==f.to||(g.inclusiveRight?f.to>=b:f.to>b);if(h||f.from==b&&"bookmark"==g.type&&(!c||f.marker.insertLeft)){var i=null==f.from||(g.inclusiveLeft?f.from<=b:f.from<b);(e||(e=[])).push(new Je(g,i?null:f.from-b,null==f.to?null:f.to-b))}}return e}function Pe(a,b){var c=yb(a,b.from.line)&&Pf(a,b.from.line).markedSpans,d=yb(a,b.to.line)&&Pf(a,b.to.line).markedSpans;if(!c&&!d)return null;var e=b.from.ch,f=b.to.ch,g=0==nb(b.from,b.to),h=Ne(c,e,g),i=Oe(d,f,g),j=1==b.text.length,k=Kg(b.text).length+(j?e:0);if(h)for(var l=0;l<h.length;++l){var m=h[l];if(null==m.to){var n=Ke(i,m.marker);n?j&&(m.to=null==n.to?null:n.to+k):m.to=e}}if(i)for(var l=0;l<i.length;++l){var m=i[l];if(null!=m.to&&(m.to+=k),null==m.from){var n=Ke(h,m.mark
 er);n||(m.from=k,j&&(h||(h=[])).push(m))}else m.from+=k,j&&(h||(h=[])).push(m)}h&&(h=Qe(h)),i&&i!=h&&(i=Qe(i));var o=[h];if(!j){var q,p=b.text.length-2;if(p>0&&h)for(var l=0;l<h.length;++l)null==h[l].to&&(q||(q=[])).push(new Je(h[l].marker,null,null));for(var l=0;p>l;++l)o.push(q);o.push(i)}return o}function Qe(a){for(var b=0;b<a.length;++b){var c=a[b];null!=c.from&&c.from==c.to&&c.marker.clearWhenEmpty!==!1&&a.splice(b--,1)}return a.length?a:null}function Re(a,b){var c=fg(a,b),d=Pe(a,b);if(!c)return d;if(!d)return c;for(var e=0;e<c.length;++e){var f=c[e],g=d[e];if(f&&g)a:for(var h=0;h<g.length;++h){for(var i=g[h],j=0;j<f.length;++j)if(f[j].marker==i.marker)continue a;f.push(i)}else g&&(c[e]=g)}return c}function Se(a,b,c){var d=null;if(a.iter(b.line,c.line+1,function(a){if(a.markedSpans)for(var b=0;b<a.markedSpans.length;++b){var c=a.markedSpans[b].marker;!c.readOnly||d&&-1!=Mg(d,c)||(d||(d=[])).push(c)}}),!d)return null;for(var e=[{from:b,to:c}],f=0;f<d.length;++f)for(var g=d[f],h=
 g.find(0),i=0;i<e.length;++i){var j=e[i];if(!(nb(j.to,h.from)<0||nb(j.from,h.to)>0)){var k=[i,1],l=nb(j.from,h.from),m=nb(j.to,h.to);(0>l||!g.inclusiveLeft&&!l)&&k.push({from:j.from,to:h.from}),(m>0||!g.inclusiveRight&&!m)&&k.push({from:h.to,to:j.to}),e.splice.apply(e,k),i+=k.length-1}}return e}function Te(a){var b=a.markedSpans;if(b){for(var c=0;c<b.length;++c)b[c].marker.detachLine(a);a.markedSpans=null}}function Ue(a,b){if(b){for(var c=0;c<b.length;++c)b[c].marker.attachLine(a);a.markedSpans=b}}function Ve(a){return a.inclusiveLeft?-1:0}function We(a){return a.inclusiveRight?1:0}function Xe(a,b){var c=a.lines.length-b.lines.length;if(0!=c)return c;var d=a.find(),e=b.find(),f=nb(d.from,e.from)||Ve(a)-Ve(b);if(f)return-f;var g=nb(d.to,e.to)||We(a)-We(b);return g?g:b.id-a.id}function Ye(a,b){var d,c=v&&a.markedSpans;if(c)for(var e,f=0;f<c.length;++f)e=c[f],e.marker.collapsed&&null==(b?e.from:e.to)&&(!d||Xe(d,e.marker)<0)&&(d=e.marker);return d}function Ze(a){return Ye(a,!0)}function
  $e(a){return Ye(a,!1)}function _e(a,b,c,d,e){var f=Pf(a,b),g=v&&f.markedSpans;if(g)for(var h=0;h<g.length;++h){var i=g[h];if(i.marker.collapsed){var j=i.marker.find(0),k=nb(j.from,c)||Ve(i.marker)-Ve(e),l=nb(j.to,d)||We(i.marker)-We(e);if(!(k>=0&&0>=l||0>=k&&l>=0)&&(0>=k&&(nb(j.to,c)>0||i.marker.inclusiveRight&&e.inclusiveLeft)||k>=0&&(nb(j.from,d)<0||i.marker.inclusiveLeft&&e.inclusiveRight)))return!0}}}function af(a){for(var b;b=Ze(a);)a=b.find(-1,!0).line;return a}function bf(a){for(var b,c;b=$e(a);)a=b.find(1,!0).line,(c||(c=[])).push(a);return c}function cf(a,b){var c=Pf(a,b),d=af(c);return c==d?b:Tf(d)}function df(a,b){if(b>a.lastLine())return b;var d,c=Pf(a,b);if(!ef(a,c))return b;for(;d=$e(c);)c=d.find(1,!0).line;return Tf(c)+1}function ef(a,b){var c=v&&b.markedSpans;if(c)for(var d,e=0;e<c.length;++e)if(d=c[e],d.marker.collapsed){if(null==d.from)return!0;if(!d.marker.widgetNode&&0==d.from&&d.marker.inclusiveLeft&&ff(a,b,d))return!0}}function ff(a,b,c){if(null==c.to){var d=c
 .marker.find(1,!0);return ff(a,d.line,Ke(d.line.markedSpans,c.marker))}if(c.marker.inclusiveRight&&c.to==b.text.length)return!0;for(var e,f=0;f<b.markedSpans.length;++f)if(e=b.markedSpans[f],e.marker.collapsed&&!e.marker.widgetNode&&e.from==c.to&&(null==e.to||e.to!=c.from)&&(e.marker.inclusiveLeft||c.marker.inclusiveRight)&&ff(a,b,e))return!0}function hf(a,b,c){Vf(b)<(a.curOp&&a.curOp.scrollTop||a.doc.scrollTop)&&ae(a,null,c)}function jf(a){if(null!=a.height)return a.height;if(!_g(document.body,a.node)){var b="position: relative;";a.coverGutter&&(b+="margin-left: -"+a.cm.getGutterElement().offsetWidth+"px;"),$g(a.cm.display.measure,Xg("div",[a.node],null,b))}return a.height=a.node.offsetHeight}function kf(a,b,c,d){var e=new gf(a,c,d);return e.noHScroll&&(a.display.alignWidgets=!0),ee(a.doc,b,"widget",function(b){var c=b.widgets||(b.widgets=[]);if(null==e.insertAt?c.push(e):c.splice(Math.min(c.length-1,Math.max(0,e.insertAt)),0,e),e.line=b,!ef(a.doc,b)){var d=Vf(b)<a.doc.scrollTop;Sf
 (b,b.height+jf(e)),d&&ae(a,null,e.height),a.curOp.forceUpdate=!0}return!0}),e}function mf(a,b,c,d){a.text=b,a.stateAfter&&(a.stateAfter=null),a.styles&&(a.styles=null),null!=a.order&&(a.order=null),Te(a),Ue(a,c);var e=d?d(a):1;e!=a.height&&Sf(a,e)}function nf(a){a.parent=null,Te(a)}function of(a,b){if(a)for(;;){var c=a.match(/(?:^|\s+)line-(background-)?(\S+)/);if(!c)break;a=a.slice(0,c.index)+a.slice(c.index+c[0].length);var d=c[1]?"bgClass":"textClass";null==b[d]?b[d]=c[2]:new RegExp("(?:^|s)"+c[2]+"(?:$|s)").test(b[d])||(b[d]+=" "+c[2])}return a}function pf(a,b){if(a.blankLine)return a.blankLine(b);if(a.innerMode){var c=w.innerMode(a,b);return c.mode.blankLine?c.mode.blankLine(c.state):void 0}}function qf(a,b,c){for(var d=0;10>d;d++){var e=a.token(b,c);if(b.pos>b.start)return e}throw new Error("Mode "+a.name+" failed to advance stream.")}function rf(a,b,c,d,e,f,g){var h=c.flattenSpans;null==h&&(h=a.options.flattenSpans);var l,i=0,j=null,k=new Ae(b,a.options.tabSize);for(""==b&&of
 (pf(c,d),f);!k.eol();){if(k.pos>a.options.maxHighlightLength?(h=!1,g&&uf(a,b,d,k.pos),k.pos=b.length,l=null):l=of(qf(c,k,d),f),a.options.addModeClass){var m=w.innerMode(c,d).mode.name;m&&(l="m-"+(l?m+" "+l:m))}h&&j==l||(i<k.start&&e(k.start,j),i=k.start,j=l),k.start=k.pos}for(;i<k.pos;){var n=Math.min(k.pos,i+5e4);e(n,j),i=n}}function sf(a,b,c,d){var e=[a.state.modeGen],f={};rf(a,b.text,a.doc.mode,c,function(a,b){e.push(a,b)},f,d);for(var g=0;g<a.state.overlays.length;++g){var h=a.state.overlays[g],i=1,j=0;rf(a,b.text,h.mode,!0,function(a,b){for(var c=i;a>j;){var d=e[i];d>a&&e.splice(i,1,a,e[i+1],d),i+=2,j=Math.min(a,d)}if(b)if(h.opaque)e.splice(c,i-c,a,"cm-overlay "+b),i=c+2;else for(;i>c;c+=2){var f=e[c+1];e[c+1]=(f?f+" ":"")+"cm-overlay "+b}},f)}return{styles:e,classes:f.bgClass||f.textClass?f:null}}function tf(a,b,c){if(!b.styles||b.styles[0]!=a.state.modeGen){var d=sf(a,b,b.stateAfter=Wb(a,Tf(b)));b.styles=d.styles,d.classes?b.styleClasses=d.classes:b.styleClasses&&(b.styleClas
 ses=null),c===a.doc.frontier&&a.doc.frontier++}return b.styles}function uf(a,b,c,d){var e=a.doc.mode,f=new Ae(b,a.options.tabSize);for(f.start=f.pos=d||0,""==b&&pf(e,c);!f.eol()&&f.pos<=a.options.maxHighlightLength;)qf(e,f,c),f.start=f.pos}function xf(a,b){if(!a||/^\s*$/.test(a))return null;var c=b.addModeClass?wf:vf;return c[a]||(c[a]=a.replace(/\S+/g,"cm-$&"))}function yf(a,b){var c=Xg("span",null,null,f?"padding-right: .1px":null),e={pre:Xg("pre",[c]),content:c,col:0,pos:0,cm:a};b.measure={};for(var g=0;g<=(b.rest?b.rest.length:0);g++){var i,h=g?b.rest[g-1]:b.line;e.pos=0,e.addToken=Af,(d||f)&&a.getOption("lineWrapping")&&(e.addToken=Bf(e.addToken)),ph(a.display.measure)&&(i=Wf(h))&&(e.addToken=Cf(e.addToken,i)),e.map=[];var j=b!=a.display.externalMeasured&&Tf(h);Ef(h,e,tf(a,h,j)),h.styleClasses&&(h.styleClasses.bgClass&&(e.bgClass=eh(h.styleClasses.bgClass,e.bgClass||"")),h.styleClasses.textClass&&(e.textClass=eh(h.styleClasses.textClass,e.textClass||""))),0==e.map.length&&e.map
 .push(0,0,e.content.appendChild(nh(a.display.measure))),0==g?(b.measure.map=e.map,b.measure.cache={}):((b.measure.maps||(b.measure.maps=[])).push(e.map),(b.measure.caches||(b.measure.caches=[])).push({}))}return sg(a,"renderLine",a,b.line,e.pre),e.pre.className&&(e.textClass=eh(e.pre.className,e.textClass||"")),e}function zf(a){var b=Xg("span","\u2022","cm-invalidchar");return b.title="\\u"+a.charCodeAt(0).toString(16),b}function Af(a,b,c,f,g,h){if(b){var i=a.cm.options.specialChars,j=!1;if(i.test(b))for(var k=document.createDocumentFragment(),l=0;;){i.lastIndex=l;var m=i.exec(b),n=m?m.index-l:b.length-l;if(n){var o=document.createTextNode(b.slice(l,l+n));d&&9>e?k.appendChild(Xg("span",[o])):k.appendChild(o),a.map.push(a.pos,a.pos+n,o),a.col+=n,a.pos+=n}if(!m)break;if(l+=n+1,"	"==m[0]){var p=a.cm.options.tabSize,q=p-a.col%p,o=k.appendChild(Xg("span",Jg(q),"cm-tab"));a.col+=q}else{var o=a.cm.options.specialCharPlaceholder(m[0]);d&&9>e?k.appendChild(Xg("span",[o])):k.appendChild(o),a.
 col+=1}a.map.push(a.pos,a.pos+1,o),a.pos++}else{a.col+=b.length;var k=document.createTextNode(b);a.map.push(a.pos,a.pos+b.length,k),d&&9>e&&(j=!0),a.pos+=b.length}if(c||f||g||j){var r=c||"";f&&(r+=f),g&&(r+=g);var s=Xg("span",[k],r);return h&&(s.title=h),a.content.appendChild(s)}a.content.appendChild(k)}}function Bf(a){function b(a){for(var b=" ",c=0;c<a.length-2;++c)b+=c%2?" ":"\xa0";return b+=" "}return function(c,d,e,f,g,h){a(c,d.replace(/ {3,}/g,b),e,f,g,h)}}function Cf(a,b){return function(c,d,e,f,g,h){e=e?e+" cm-force-border":"cm-force-border";for(var i=c.pos,j=i+d.length;;){for(var k=0;k<b.length;k++){var l=b[k];if(l.to>i&&l.from<=i)break}if(l.to>=j)return a(c,d,e,f,g,h);a(c,d.slice(0,l.to-i),e,f,null,h),f=null,d=d.slice(l.to-i),i=l.to}}}function Df(a,b,c,d){var e=!d&&c.widgetNode;e&&(a.map.push(a.pos,a.pos+b,e),a.content.appendChild(e)),a.pos+=b}function Ef(a,b,c){var d=a.markedSpans,e=a.text,f=0;if(d)for(var k,m,n,o,p,q,h=e.length,i=0,g=1,j="",l=0;;){if(l==i){m=n=o=p="",q=n
 ull,l=1/0;for(var r=[],s=0;s<d.length;++s){var t=d[s],u=t.marker;t.from<=i&&(null==t.to||t.to>i)?(null!=t.to&&l>t.to&&(l=t.to,n=""),u.className&&(m+=" "+u.className),u.startStyle&&t.from==i&&(o+=" "+u.startStyle),u.endStyle&&t.to==l&&(n+=" "+u.endStyle),u.title&&!p&&(p=u.title),u.collapsed&&(!q||Xe(q.marker,u)<0)&&(q=t)):t.from>i&&l>t.from&&(l=t.from),"bookmark"==u.type&&t.from==i&&u.widgetNode&&r.push(u)}if(q&&(q.from||0)==i&&(Df(b,(null==q.to?h+1:q.to)-i,q.marker,null==q.from),null==q.to))return;if(!q&&r.length)for(var s=0;s<r.length;++s)Df(b,0,r[s])}if(i>=h)break;for(var v=Math.min(h,l);;){if(j){var w=i+j.length;if(!q){var x=w>v?j.slice(0,v-i):j;b.addToken(b,x,k?k+m:m,o,i+x.length==l?n:"",p)}if(w>=v){j=j.slice(v-i),i=v;break}i=w,o=""}j=e.slice(f,f=c[g++]),k=xf(c[g++],b.cm.options)}}else for(var g=1;g<c.length;g+=2)b.addToken(b,e.slice(f,f=c[g]),xf(c[g+1],b.cm.options))}function Ff(a,b){return 0==b.from.ch&&0==b.to.ch&&""==Kg(b.text)&&(!a.cm||a.cm.options.wholeLineUpdateBefore)}fu
 nction Gf(a,b,c,d){function e(a){return c?c[a]:null}function f(a,c,e){mf(a,c,e,d),ug(a,"change",a,b)}var g=b.from,h=b.to,i=b.text,j=Pf(a,g.line),k=Pf(a,h.line),l=Kg(i),m=e(i.length-1),n=h.line-g.line;if(Ff(a,b)){for(var o=0,p=[];o<i.length-1;++o)p.push(new lf(i[o],e(o),d));f(k,k.text,m),n&&a.remove(g.line,n),p.length&&a.insert(g.line,p)}else if(j==k)if(1==i.length)f(j,j.text.slice(0,g.ch)+l+j.text.slice(h.ch),m);else{for(var p=[],o=1;o<i.length-1;++o)p.push(new lf(i[o],e(o),d));p.push(new lf(l+j.text.slice(h.ch),m,d)),f(j,j.text.slice(0,g.ch)+i[0],e(0)),a.insert(g.line+1,p)}else if(1==i.length)f(j,j.text.slice(0,g.ch)+i[0]+k.text.slice(h.ch),e(0)),a.remove(g.line+1,n);else{f(j,j.text.slice(0,g.ch)+i[0],e(0)),f(k,l+k.text.slice(h.ch),m);for(var o=1,p=[];o<i.length-1;++o)p.push(new lf(i[o],e(o),d));n>1&&a.remove(g.line+1,n-1),a.insert(g.line+1,p)}ug(a,"change",a,b)}function Hf(a){this.lines=a,this.parent=null;for(var b=0,c=0;b<a.length;++b)a[b].parent=this,c+=a[b].height;this.height=c
 }function If(a){this.children=a;for(var b=0,c=0,d=0;d<a.length;++d){var e=a[d];b+=e.chunkSize(),c+=e.height,e.parent=this}this.size=b,this.height=c,this.parent=null}function Nf(a,b,c){function d(a,e,f){if(a.linked)for(var g=0;g<a.linked.length;++g){var h=a.linked[g];if(h.doc!=e){var i=f&&h.sharedHist;(!c||i)&&(b(h.doc,i),d(h.doc,a,i))}}}d(a,null,!0)}function Of(a,b){if(b.cm)throw new Error("This document is already in use.");a.doc=b,b.cm=a,C(a),y(a),a.options.lineWrapping||I(a),a.options.mode=b.modeOption,Pc(a)}function Pf(a,b){if(b-=a.first,0>b||b>=a.size)throw new Error("There is no line "+(b+a.first)+" in the document.");for(var c=a;!c.lines;)for(var d=0;;++d){var e=c.children[d],f=e.chunkSize();if(f>b){c=e;break}b-=f}return c.lines[b]}function Qf(a,b,c){var d=[],e=b.line;return a.iter(b.line,c.line+1,function(a){var f=a.text;e==c.line&&(f=f.slice(0,c.ch)),e==b.line&&(f=f.slice(b.ch)),d.push(f),++e}),d}function Rf(a,b,c){var d=[];return a.iter(b,c,function(a){d.push(a.text)}),d}f
 unction Sf(a,b){var c=b-a.height;if(c)for(var d=a;d;d=d.parent)d.height+=c}function Tf(a){if(null==a.parent)return null;for(var b=a.parent,c=Mg(b.lines,a),d=b.parent;d;b=d,d=d.parent)for(var e=0;d.children[e]!=b;++e)c+=d.children[e].chunkSize();return c+b.first}function Uf(a,b){var c=a.first;a:do{for(var d=0;d<a.children.length;++d){var e=a.children[d],f=e.height;if(f>b){a=e;continue a}b-=f,c+=e.chunkSize()}return c}while(!a.lines);for(var d=0;d<a.lines.length;++d){var g=a.lines[d],h=g.height;if(h>b)break;b-=h}return c+d}function Vf(a){a=af(a);for(var b=0,c=a.parent,d=0;d<c.lines.length;++d){var e=c.lines[d];if(e==a)break;b+=e.height}for(var f=c.parent;f;c=f,f=c.parent)for(var d=0;d<f.children.length;++d){var g=f.children[d];if(g==c)break;b+=g.height}return b}function Wf(a){var b=a.order;return null==b&&(b=a.order=Kh(a.text)),b}function Xf(a){this.done=[],this.undone=[],this.undoDepth=1/0,this.lastModTime=this.lastSelTime=0,this.lastOp=this.lastSelOp=null,this.lastOrigin=this.lastSe
 lOrigin=null,this.generation=this.maxGeneration=a||1}function Yf(a,b){var c={from:ob(b.from),to:Ld(b),text:Qf(a,b.from,b.to)};return dg(a,c,b.from.line,b.to.line+1),Nf(a,function(a){dg(a,c,b.from.line,b.to.line+1)},!0),c}function Zf(a){for(;a.length;){var b=Kg(a);if(!b.ranges)break;a.pop()}}function $f(a,b){return b?(Zf(a.done),Kg(a.done)):a.done.length&&!Kg(a.done).ranges?Kg(a.done):a.done.length>1&&!a.done[a.done.length-2].ranges?(a.done.pop(),Kg(a.done)):void 0}function _f(a,b,c,d){var e=a.history;e.undone.length=0;var g,f=+new Date;if((e.lastOp==d||e.lastOrigin==b.origin&&b.origin&&("+"==b.origin.charAt(0)&&a.cm&&e.lastModTime>f-a.cm.options.historyEventDelay||"*"==b.origin.charAt(0)))&&(g=$f(e,e.lastOp==d))){var h=Kg(g.changes);0==nb(b.from,b.to)&&0==nb(b.from,h.to)?h.to=Ld(b):g.changes.push(Yf(a,b))}else{var i=Kg(e.done);for(i&&i.ranges||cg(a.sel,e.done),g={changes:[Yf(a,b)],generation:e.generation},e.done.push(g);e.done.length>e.undoDepth;)e.done.shift(),e.done[0].ranges||e.d
 one.shift()}e.done.push(c),e.generation=++e.maxGeneration,e.lastModTime=e.lastSelTime=f,e.lastOp=e.lastSelOp=d,e.lastOrigin=e.lastSelOrigin=b.origin,h||sg(a,"historyAdded")}function ag(a,b,c,d){var e=b.charAt(0);return"*"==e||"+"==e&&c.ranges.length==d.ranges.length&&c.somethingSelected()==d.somethingSelected()&&new Date-a.history.lastSelTime<=(a.cm?a.cm.options.historyEventDelay:500)}function bg(a,b,c,d){var e=a.history,f=d&&d.origin;c==e.lastSelOp||f&&e.lastSelOrigin==f&&(e.lastModTime==e.lastSelTime&&e.lastOrigin==f||ag(a,f,Kg(e.done),b))?e.done[e.done.length-1]=b:cg(b,e.done),e.lastSelTime=+new Date,e.lastSelOrigin=f,e.lastSelOp=c,d&&d.clearRedo!==!1&&Zf(e.undone)}function cg(a,b){var c=Kg(b);c&&c.ranges&&c.equals(a)||b.push(a)}function dg(a,b,c,d){var e=b["spans_"+a.id],f=0;a.iter(Math.max(a.first,c),Math.min(a.first+a.size,d),function(c){c.markedSpans&&((e||(e=b["spans_"+a.id]={}))[f]=c.markedSpans),++f})}function eg(a){if(!a)return null;for(var c,b=0;b<a.length;++b)a[b].marke
 r.explicitlyCleared?c||(c=a.slice(0,b)):c&&c.push(a[b]);return c?c.length?c:null:a}function fg(a,b){var c=b["spans_"+a.id];if(!c)return null;for(var d=0,e=[];d<b.text.length;++d)e.push(eg(c[d]));return e}function gg(a,b,c){for(var d=0,e=[];d<a.length;++d){var f=a[d];if(f.ranges)e.push(c?rb.prototype.deepCopy.call(f):f);else{var g=f.changes,h=[];e.push({changes:h});for(var i=0;i<g.length;++i){var k,j=g[i];if(h.push({from:j.from,to:j.to,text:j.text}),b)for(var l in j)(k=l.match(/^spans_(\d+)$/))&&Mg(b,Number(k[1]))>-1&&(Kg(h)[l]=j[l],delete j[l])}}}return e}function hg(a,b,c,d){c<a.line?a.line+=d:b<a.line&&(a.line=b,a.ch=0)}function ig(a,b,c,d){for(var e=0;e<a.length;++e){var f=a[e],g=!0;if(f.ranges){f.copied||(f=a[e]=f.deepCopy(),f.copied=!0);for(var h=0;h<f.ranges.length;h++)hg(f.ranges[h].anchor,b,c,d),hg(f.ranges[h].head,b,c,d)}else{for(var h=0;h<f.changes.length;++h){var i=f.changes[h];if(c<i.from.line)i.from=mb(i.from.line+d,i.from.ch),i.to=mb(i.to.line+d,i.to.ch);else if(b<=i.t
 o.line){g=!1;break}}g||(a.splice(0,e+1),e=0)}}}function jg(a,b){var c=b.from.line,d=b.to.line,e=b.text.length-(d-c)-1;ig(a.done,c,d,e),ig(a.undone,c,d,e)}function mg(a){return null!=a.defaultPrevented?a.defaultPrevented:0==a.returnValue}function og(a){return a.target||a.srcElement}function pg(a){var b=a.which;return null==b&&(1&a.button?b=1:2&a.button?b=3:4&a.button&&(b=2)),p&&a.ctrlKey&&1==b&&(b=3),b}function ug(a,b){function f(a){return function(){a.apply(null,d)}}var c=a._handlers&&a._handlers[b];if(c){var e,d=Array.prototype.slice.call(arguments,2);yc?e=yc.delayedCallbacks:tg?e=tg:(e=tg=[],setTimeout(vg,0));for(var g=0;g<c.length;++g)e.push(f(c[g]))}}function vg(){var a=tg;tg=null;for(var b=0;b<a.length;++b)a[b]()}function wg(a,b,c){return sg(a,c||b.type,a,b),mg(b)||b.codemirrorIgnore}function xg(a){var b=a._handlers&&a._handlers.cursorActivity;if(b)for(var c=a.curOp.cursorActivityHandlers||(a.curOp.cursorActivityHandlers=[]),d=0;d<b.length;++d)-1==Mg(c,b[d])&&c.push(b[d])}funct
 ion yg(a,b){var c=a._handlers&&a._handlers[b];return c&&c.length>0}function zg(a){a.prototype.on=function(a,b){qg(this,a,b)},a.prototype.off=function(a,b){rg(this,a,b)}}function Fg(){this.id=null}function Hg(a,b,c){for(var d=0,e=0;;){var f=a.indexOf("	",d);-1==f&&(f=a.length);var g=f-d;if(f==a.length||e+g>=b)return d+Math.min(g,b-e);if(e+=f-d,e+=c-e%c,d=f+1,e>=b)return d}}function Jg(a){for(;Ig.length<=a;)Ig.push(Kg(Ig)+" ");return Ig[a]}function Kg(a){return a[a.length-1]}function Mg(a,b){for(var c=0;c<a.length;++c)if(a[c]==b)return c;return-1}function Ng(a,b){for(var c=[],d=0;d<a.length;d++)c[d]=b(a[d],d);return c}function Og(a,b){var c;if(Object.create)c=Object.create(a);else{var d=function(){};d.prototype=a,c=new d}return b&&Pg(b,c),c}function Pg(a,b,c){b||(b={});for(var d in a)!a.hasOwnProperty(d)||c===!1&&b.hasOwnProperty(d)||(b[d]=a[d]);return b}function Qg(a){var b=Array.prototype.slice.call(arguments,1);return function(){return a.apply(null,b)}}function Tg(a,b){return b?b.s
 ource.indexOf("\\w")>-1&&Sg(a)?!0:b.test(a):Sg(a)}function Ug(a){for(var b in a)if(a.hasOwnProperty(b)&&a[b])return!1;return!0}function Wg(a){return a.charCodeAt(0)>=768&&Vg.test(a)}function Xg(a,b,c,d){var e=document.createElement(a);if(c&&(e.className=c),d&&(e.style.cssText=d),"string"==typeof b)e.appendChild(document.createTextNode(b));else if(b)for(var f=0;f<b.length;++f)e.appendChild(b[f]);return e}function Zg(a){for(var b=a.childNodes.length;b>0;--b)a.removeChild(a.firstChild);return a}function $g(a,b){return Zg(a).appendChild(b)}function _g(a,b){if(a.contains)return a.contains(b);for(;b=b.parentNode;)if(b==a)return!0}function ah(){return document.activeElement}function bh(a){return new RegExp("\\b"+a+"\\b\\s*")}function eh(a,b){for(var c=a.split(" "),d=0;d<c.length;d++)c[d]&&!bh(c[d]).test(b)&&(b+=" "+c[d]);return b}function fh(a){if(document.body.getElementsByClassName)for(var b=document.body.getElementsByClassName("CodeMirror"),c=0;c<b.length;c++){var d=b[c].CodeMirror;d&&a
 (d)}}function hh(){gh||(ih(),gh=!0)}function ih(){var a;qg(window,"resize",function(){null==a&&(a=setTimeout(function(){a=null,kh=null,fh(dd)},100))}),qg(window,"blur",function(){fh(Id)})}function lh(a){if(null!=kh)return kh;var b=Xg("div",null,null,"width: 50px; height: 50px; overflow-x: scroll");return $g(a,b),b.offsetWidth&&(kh=b.offsetHeight-b.clientHeight),kh||0}function nh(a){if(null==mh){var b=Xg("span","\u200b");$g(a,Xg("span",[b,document.createTextNode("x")])),0!=a.firstChild.offsetHeight&&(mh=b.offsetWidth<=1&&b.offsetHeight>2&&!(d&&8>e))}return mh?Xg("span","\u200b"):Xg("span","\xa0",null,"display: inline-block; width: 1px; margin-right: -1px")}function ph(a){if(null!=oh)return oh;var b=$g(a,document.createTextNode("A\u062eA")),c=Yg(b,0,1).getBoundingClientRect();if(!c||c.left==c.right)return!1;var d=Yg(b,1,2).getBoundingClientRect();return oh=d.right-c.right<3}function uh(a){if(null!=th)return th;var b=$g(a,Xg("span","x")),c=b.getBoundingClientRect(),d=Yg(b,0,1).getBound
 ingClientRect();return th=Math.abs(c.left-d.left)>1}function wh(a,b,c,d){if(!a)return d(b,c,"ltr");for(var e=!1,f=0;f<a.length;++f){var g=a[f];(g.from<c&&g.to>b||b==c&&g.to==b)&&(d(Math.max(g.from,b),Math.min(g.to,c),1==g.level?"rtl":"ltr"),e=!0)}e||d(b,c,"ltr")}function xh(a){return a.level%2?a.to:a.from}function yh(a){return a.level%2?a.from:a.to}function zh(a){var b=Wf(a);return b?xh(b[0]):0}function Ah(a){var b=Wf(a);return b?yh(Kg(b)):a.text.length}function Bh(a,b){var c=Pf(a.doc,b),d=af(c);d!=c&&(b=Tf(d));var e=Wf(d),f=e?e[0].level%2?Ah(d):zh(d):0;return mb(b,f)}function Ch(a,b){for(var c,d=Pf(a.doc,b);c=$e(d);)d=c.find(1,!0).line,b=null;var e=Wf(d),f=e?e[0].level%2?zh(d):Ah(d):d.text.length;return mb(null==b?Tf(d):b,f)}function Dh(a,b){var c=Bh(a,b.line),d=Pf(a.doc,c.line),e=Wf(d);if(!e||0==e[0].level){var f=Math.max(0,d.text.search(/\S/)),g=b.line==c.line&&b.ch<=f&&b.ch;return mb(c.line,g?0:f)}return c}function Eh(a,b,c){var d=a[0].level;return b==d?!0:c==d?!1:c>b}function G
 h(a,b){Fh=null;for(var d,c=0;c<a.length;++c){var e=a[c];if(e.from<b&&e.to>b)return c;if(e.from==b||e.to==b){if(null!=d)return Eh(a,e.level,a[d].level)?(e.from!=e.to&&(Fh=d),c):(e.from!=e.to&&(Fh=c),d);d=c}}return d}function Hh(a,b,c,d){if(!d)return b+c;do b+=c;while(b>0&&Wg(a.text.charAt(b)));return b}function Ih(a,b,c,d){var e=Wf(a);if(!e)return Jh(a,b,c,d);for(var f=Gh(e,b),g=e[f],h=Hh(a,b,g.level%2?-c:c,d);;){if(h>g.from&&h<g.to)return h;if(h==g.from||h==g.to)return Gh(e,h)==f?h:

<TRUNCATED>

[13/23] ambari git commit: AMBARI-19302 : removed contrib/views/hive folder and made necessary changes in pom.xml files (nitirajrathore)

Posted by ni...@apache.org.
http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/controllers/tez-ui.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/controllers/tez-ui.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/controllers/tez-ui.js
deleted file mode 100644
index 43835e0..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/controllers/tez-ui.js
+++ /dev/null
@@ -1,106 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-import constants from 'hive/utils/constants';
-
-export default Ember.Controller.extend({
-  needs: [ constants.namingConventions.index ],
-
-  index: Ember.computed.alias('controllers.' + constants.namingConventions.index),
-
-  tezViewURL: null,
-  tezApiURL: '/api/v1/views/TEZ',
-  tezURLPrefix: '/views/TEZ',
-  tezDagPath: '?viewPath=/#/dag/',
-
-  isTezViewAvailable: Ember.computed.bool('tezViewURL'),
-
-  dagId: function () {
-    if (this.get('isTezViewAvailable')) {
-      return this.get('index.model.dagId');
-    }
-
-    return false;
-  }.property('index.model.dagId', 'isTezViewAvailable'),
-
-  dagURL: function () {
-    if (this.get('dagId')) {
-      return "%@%@%@".fmt(this.get('tezViewURL'), this.get('tezDagPath'), this.get('dagId'));
-    }
-
-    return false;
-  }.property('dagId'),
-
-  getTezView: function () {
-    if (this.get('isTezViewAvailable')) {
-      return;
-    }
-
-    var self = this;
-    Ember.$.getJSON(this.get('tezApiURL'))
-      .then(function (response) {
-        self.getTezViewInstance(response);
-      })
-      .fail(function (response) {
-        self.setTezViewError(response);
-      });
-  }.on('init'),
-
-  getTezViewInstance: function (data) {
-    var self = this;
-    var url = this.get('tezApiURL') + '/versions/' + data.versions[0].ViewVersionInfo.version;
-
-    Ember.$.getJSON(url)
-      .then(function (response) {
-        if (!response.instances.length) {
-          self.setTezViewError(response);
-          return;
-        }
-
-        self.set('isTezViewAvailable', true);
-
-        var instance = response.instances[0].ViewInstanceInfo;
-        self.setTezViewURL(instance);
-      });
-  },
-
-  setTezViewURL: function (instance) {
-    var url = "%@/%@/%@/".fmt(
-      this.get('tezURLPrefix'),
-      instance.version,
-      instance.instance_name
-    );
-
-    this.set('tezViewURL', url);
-  },
-
-  setTezViewError: function (data) {
-    // status: 404 => Tev View isn't deployed
-    if (data.status && data.status === 404) {
-      this.set('error', 'tez.errors.not.deployed');
-      return;
-    }
-
-    // no instance created
-    if (data.instances && !data.instances.length) {
-      this.set('error', 'tez.errors.no.instance');
-      return;
-    }
-  }
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/controllers/udfs.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/controllers/udfs.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/controllers/udfs.js
deleted file mode 100644
index 3aec378..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/controllers/udfs.js
+++ /dev/null
@@ -1,143 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-import FilterableMixin from 'hive/mixins/filterable';
-import constants from 'hive/utils/constants';
-
-export default Ember.ArrayController.extend(FilterableMixin, {
-  fileResources: [],
-
-  sortAscending: true,
-  sortProperties: [],
-
-  columns: [
-    Ember.Object.create({
-      caption: 'placeholders.udfs.name',
-      property: 'name'
-    }),
-    Ember.Object.create({
-      caption: 'placeholders.udfs.className',
-      property: 'classname'
-    })
-  ],
-
-  model: function () {
-    return this.filter(this.get('udfs'));
-  }.property('udfs', 'filters.@each'),
-
-  actions: {
-    handleAddFileResource: function (udf) {
-      var file = this.store.createRecord(constants.namingConventions.fileResource);
-      udf.set('fileResource', file);
-      udf.set('isEditingResource', true);
-    },
-
-    handleDeleteFileResource: function (file) {
-      var defer = Ember.RSVP.defer();
-
-      this.send('openModal',
-                'modal-delete',
-                 {
-                    heading: 'modals.delete.heading',
-                    text: 'modals.delete.message',
-                    defer: defer
-                 });
-
-      defer.promise.then(function () {
-        file.destroyRecord();
-      });
-    },
-
-    handleSaveUdf: function (udf) {
-      var self = this,
-          saveUdf = function () {
-            udf.save().then(function () {
-              udf.set('isEditing', false);
-              udf.set('isEditingResource', false);
-            });
-          };
-
-      //replace with a validation system if needed.
-      if (!udf.get('name') || !udf.get('classname')) {
-        return;
-      }
-
-      udf.get('fileResource').then(function (file) {
-        if (file) {
-          if (!file.get('name') || !file.get('path')) {
-            return;
-          }
-
-          file.save().then(function () {
-            saveUdf();
-          });
-        } else {
-          saveUdf();
-        }
-      });
-    },
-
-    handleDeleteUdf: function (udf) {
-      var defer = Ember.RSVP.defer();
-
-      this.send('openModal',
-                'modal-delete',
-                 {
-                    heading: 'modals.delete.heading',
-                    text: 'modals.delete.message',
-                    defer: defer
-                 });
-
-      defer.promise.then(function () {
-        udf.destroyRecord();
-      });
-    },
-
-    sort: function (property) {
-      //if same column has been selected, toggle flag, else default it to true
-      if (this.get('sortProperties').objectAt(0) === property) {
-        this.set('sortAscending', !this.get('sortAscending'));
-      } else {
-        this.set('sortAscending', true);
-        this.set('sortProperties', [ property ]);
-      }
-    },
-
-    add: function () {
-      this.store.createRecord(constants.namingConventions.udf);
-    },
-
-    clearFilters: function () {
-      var columns = this.get('columns');
-
-      if (columns) {
-        columns.forEach(function (column) {
-          var filterValue = column.get('filterValue');
-
-          if (filterValue && typeof filterValue === 'string') {
-            column.set('filterValue');
-          }
-        });
-      }
-
-      //call clear filters from Filterable mixin
-      this.clearFilters();
-    }
-  }
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/controllers/upload-table.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/controllers/upload-table.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/controllers/upload-table.js
deleted file mode 100644
index e217e7d..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/controllers/upload-table.js
+++ /dev/null
@@ -1,965 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-import Uploader from 'hive/adapters/upload-table'
-import constants from 'hive/utils/constants';
-
-
-export default Ember.Controller.extend({
-  DEFAULT_CSV_DELIMITER: ',',
-  DEFAULT_CSV_QUOTE: '"',
-  DEFAULT_CSV_ESCAPE: '\\',
-  NON_PRINTABLE_CHARS:[{"id":"0", "name":"NUL", "description":"(null)"},
-    {"id":"1", "name":"SOH", "description":"(start of heading)"},
-    {"id":"2", "name":"STX", "description":"(start of text)"},
-    {"id":"3", "name":"ETX", "description":"(end of text)"},
-    {"id":"4", "name":"EOT", "description":"(end of transmission)"},
-    {"id":"5", "name":"ENQ", "description":"(enquiry)"},
-    {"id":"6", "name":"ACK", "description":"(acknowledge)"},
-    {"id":"7", "name":"BEL", "description":"(bell)"},
-    {"id":"8", "name":"BS", "description":"(backspace)"},
-    {"id":"9", "name":"TAB", "description":"(horizontal tab)"},
-    {"id":"11", "name":"VT", "description":"(vertical tab)"},
-    {"id":"12", "name":"FF", "description":"(NP form feed - new page)"},
-    {"id":"14", "name":"SO", "description":"(shift out)"},
-    {"id":"15", "name":"SI", "description":"(shift in)"},
-    {"id":"16", "name":"DLE", "description":"(data link escape)"},
-    {"id":"17", "name":"DC1", "description":"(device control 1)"},
-    {"id":"18", "name":"DC2", "description":"(device control 2)"},
-    {"id":"19", "name":"DC3", "description":"(device control 3)"},
-    {"id":"20", "name":"DC4", "description":"(device control 4)"},
-    {"id":"21", "name":"NAK", "description":"(negative ackowledge)"},
-    {"id":"22", "name":"SYN", "description":"(synchronous idle)"},
-    {"id":"23", "name":"ETB", "description":"(end of trans. block)"},
-    {"id":"24", "name":"CAN", "description":"(cancel)"},
-    {"id":"25", "name":"EM", "description":"(end of medium)"},
-    {"id":"26", "name":"SUB", "description":"(substitute)"},
-    {"id":"27", "name":"ESC", "description":"(escape)"},
-    {"id":"28", "name":"FS", "description":"(file separator)"},
-    {"id":"29", "name":"GS", "description":"(group separator)"},
-    {"id":"30", "name":"RS", "description":"(record separator)"},
-    {"id":"31", "name":"US", "description":"(unit separator)"},
-    {"id":"32", "name":"Space", "description":""},
-    {"id":"127", "name":"DEL", "description":""}
-  ],
-  COLUMN_NAME_REGEX: "^[a-zA-Z]{1}[a-zA-Z0-9_]*$",
-  TABLE_NAME_REGEX: "^[a-zA-Z]{1}[a-zA-Z0-9_]*$",
-  HDFS_PATH_REGEX: "^[/]{1}.+",  // unix path allows everything but here we have to mention full path so starts with /
-  isLocalUpload: Ember.computed.equal("uploadSource", "local"),
-  uploadSource: "local",
-  COLUMN_NAME_PREFIX : "column",
-  hdfsPath: "",
-  jobService: Ember.inject.service(constants.namingConventions.job),
-  notifyService: Ember.inject.service(constants.namingConventions.notify),
-  databaseService : Ember.inject.service(constants.namingConventions.database),
-  databases : Ember.computed.alias("databaseService.databases"),
-  showErrors: false,
-  uploader: Uploader.create(),
-  baseUrl: "/resources/upload",
-  isFirstRowHeader: false, // is first row  header
-  header: null,  // header received from server
-  files: null, // files that need to be uploaded only file[0] is relevant
-  firstRow: [], // the actual first row of the table.
-  rows: null,  // preview rows received from server
-  databaseName: null,
-  selectedDatabase: null,
-  filePath: null,
-  tableName: null,
-  uploadProgressInfos : [],
-  DEFAULT_DB_NAME : 'default',
-  showPreview : false,
-  containsEndlines: false,
-  inputFileTypes :[
-    {id : "CSV", name : "CSV"},
-    {id : "JSON", name : "JSON"},
-    {id : "XML", name : "XML"}
-  ],
-  inputFileType: null,
-  inputFileTypeCSV : Ember.computed.equal('inputFileType.id',"CSV"),
-  storedAsTextFile : Ember.computed.equal("selectedFileType","TEXTFILE"),
-  storedAsNotTextFile : Ember.computed.not("storedAsTextFile"),
-  csvDelimiter: null,
-  csvQuote : null,
-  csvEscape : null,
-  asciiList:[],
-  fieldsTerminatedBy: null,
-  escapedBy: null,
-  fileTypes:[
-    "SEQUENCEFILE",
-    "TEXTFILE"    ,
-    "RCFILE"      ,
-    "ORC"         ,
-    "PARQUET"     ,
-    "AVRO"
-  ],
-  selectedFileType: null,
-  onChangeSelectedFileType: function(){
-    if(this.get('selectedFileType') === this.get('fileTypes')[1] && this.get('containsEndlines') === true){
-      this.set('containsEndlines', false);
-    }
-  }.observes("selectedFileType", "containsEndlines"),
-  dataTypes: [
-    "TINYINT", //
-    "SMALLINT", //
-    "INT", //
-    "BIGINT", //
-    "BOOLEAN", //
-    "FLOAT", //
-    "DOUBLE", //
-    "STRING", //
-    "BINARY", // -- (Note: Available in Hive 0.8.0 and later)
-    "TIMESTAMP", // -- (Note: Available in Hive 0.8.0 and later)
-    "DECIMAL", // -- (Note: Available in Hive 0.11.0 and later)
-    "DATE", // -- (Note: Available in Hive 0.12.0 and later)
-    "VARCHAR", // -- (Note: Available in Hive 0.12.0 and later)
-    "CHAR" // -- (Note: Available in Hive 0.13.0 and later)
-  ],
-  setDefaultDB : function(){
-    var self = this;
-    var defaultDatabase = this.get('databases').find(
-      function(item,index){
-        if(item.id == self.DEFAULT_DB_NAME )
-          return true;
-      }
-    );
-
-    console.log("setting the initial database to : " + defaultDatabase);
-    self.set("selectedDatabase",defaultDatabase);
-  },
-  init: function () {
-    this.setDefaultDB();
-    this.fillAsciiList();
-    this.set("selectedFileType", this.get("fileTypes")[3]);
-    this.set("inputFileType", this.get("inputFileTypes")[0]);
-  },
-  onChangeUploadSource : function(){
-    this.clearFields();
-  }.observes("uploadSource"),
-  asciiFormatter: function( option, escape ){
-    if( option.data.id  != -1 )
-      return "<div><span style='font-weight: bold;margin: 5px'>" + option.data.id + "</span><span style='font-style: italic; color: grey; margin: 5px'>" + option.data.name + "</span></div>";
-    else
-      return "<div></div>";
-  },
-  fillAsciiList: function(){
-    var list = this.get('asciiList');
-    list.push({"id": -1, "name": ""});
-    var nonPrintable = this.get('NON_PRINTABLE_CHARS');
-    for( var i = 0 ; i <= 127 ; i++ ){
-      if( i == 10 || i == 13 ) continue;
-      var charInfo = nonPrintable.find(function(item){
-        return item.id == i;
-      });
-      if(!charInfo){
-        charInfo = {"id": i, "name": String.fromCodePoint(i), "description":"" };
-      }
-      var option = {"id": i, "name": charInfo.name + charInfo.description};
-      list.push(option);
-      if(i === 44){
-        this.set("csvDelimiter", option);
-      }
-      else if(i === 34){
-        this.set("csvQuote", option);
-      }
-      else if(i === 92){
-        this.set("csvEscape", option);
-      }
-    }
-  },
-  uploadProgressInfo : Ember.computed("uploadProgressInfos.[]",function(){
-    var info = "";
-    for( var i = 0 ; i < this.get('uploadProgressInfos').length ; i++)
-      info += this.get('uploadProgressInfos').objectAt(i);
-
-    return new Ember.Handlebars.SafeString(info);
-  }),
-  _setHeaderElements : function(header,valueArray){
-    header.forEach(function (item, index) {
-      Ember.set(item, 'name',  valueArray[index]);
-    }, this);
-  },
-  isFirstRowHeaderDidChange: function () {
-    if (this.get('isFirstRowHeader') != null && typeof this.get('isFirstRowHeader') !== 'undefined') {
-      if (this.get('isFirstRowHeader') == false) {
-        if (this.get('rows')) {
-          this.get('rows').unshiftObject({row: this.get('firstRow')});
-          this._setHeaderElements(this.get('header'),this.get('defaultColumnNames'));
-        }
-      } else if (this.get('header')) { // headers are available
-        // take first row of
-        this._setHeaderElements(this.get('header'),this.get('firstRow'));
-        this.get('rows').removeAt(0);
-      }
-
-      this.printValues();
-    }
-  }.observes('isFirstRowHeader'),
-
-  popUploadProgressInfos: function () {
-    var msg = this.get('uploadProgressInfos').popObject();
-  },
-
-  pushUploadProgressInfos : function(info){
-    this.get('uploadProgressInfos').pushObject(info);
-  },
-
-  clearUploadProgressModal : function(){
-    var len = this.get('uploadProgressInfos').length;
-    for( var i = 0 ; i < len ; i++){
-      this.popUploadProgressInfos();
-    }
-  },
-
-  hideUploadModal : function(){
-    this.clearUploadProgressModal();
-    Ember.$("#uploadProgressModal").modal("hide");
-  },
-
-  showUploadModal : function(){
-    Ember.$("#uploadProgressModal").modal("show");
-  },
-
-  clearFields: function () {
-    this.set("showPreview",false);
-    this.set("hdfsPath");
-    this.set("header");
-    this.set("rows");
-    this.set("escapedBy");
-    this.set("fieldsTerminatedBy");
-    this.set("error");
-    this.set('files');
-    this.set("firstRow");
-    this.set("selectedDatabase",null);
-    this.set("databaseName");
-    this.set("filePath");
-    this.set('tableName');
-    this.clearUploadProgressModal();
-    this.setDefaultDB();
-    this.printValues();
-  },
-
-  printValues: function () {
-    console.log("header : ", this.get('header'),
-      ". rows : ",this.get('rows'),". error : ", this.get('error'),
-      " isFirstRowHeader : ", this.get('isFirstRowHeader'),
-      "firstRow : ", this.get('firstRow'));
-  },
-
-  generateTempTableName: function () {
-    var text = "";
-    var possible = "abcdefghijklmnopqrstuvwxyz";
-
-    for (var i = 0; i < 30; i++)
-      text += possible.charAt(Math.floor(Math.random() * possible.length));
-
-    return text;
-  },
-
-  waitForJobStatus: function (jobId, resolve, reject) {
-    console.log("finding status of job: ", jobId);
-    var self = this;
-    var fetchJobPromise = this.get('jobService').fetchJob(jobId);
-      fetchJobPromise.then(function (data) {
-        console.log("waitForJobStatus : data : ", data);
-        var job = data.job;
-        var status = job.status.toUpperCase();
-        if (status == constants.statuses.succeeded ) {
-          console.log("resolving waitForJobStatus with : " , status);
-          resolve(job);
-        } else if (status == constants.statuses.canceled || status == constants.statuses.closed || status == constants.statuses.error) {
-          console.log("rejecting waitForJobStatus with : " + status);
-          reject(new Error(job.statusMessage));
-        } else {
-          Ember.run.later(function(){
-            console.log("retrying waitForJobStatus : ", jobId);
-            self.waitForJobStatus(jobId, resolve, reject);
-          },1000);
-        }
-      }, function (error) {
-        console.log("rejecting waitForJobStatus with : " + error);
-        reject(error);
-    })
-  },
-
-  uploadForPreview: function (files) {
-    console.log("uploaderForPreview called.");
-    var self = this;
-    var csvParams = this.getCSVParams();
-
-    return this.get('uploader').uploadFiles('preview', files, {
-      "isFirstRowHeader": self.get("isFirstRowHeader"),
-      "inputFileType": self.get("inputFileType").id,
-      "csvDelimiter": csvParams.csvDelimiter,
-      "csvEscape": csvParams.csvEscape,
-      "csvQuote": csvParams.csvQuote
-    });
-  },
-
-  getAsciiChar : function(key){
-    if(!key){
-      return null;
-    }
-
-    var value = this.get(key);
-    if(value && value.id != -1) {
-      return String.fromCharCode(value.id);
-    }else{
-      return null;
-    }
-  },
-  getCSVParams : function(){
-    var csvd = this.getAsciiChar('csvDelimiter');
-    if(!csvd && csvd != 0) csvd = this.get('DEFAULT_CSV_DELIMITER');
-
-    var csvq = this.getAsciiChar('csvQuote');
-    if(!csvq && csvq != 0) csvq = this.get('DEFAULT_CSV_QUOTE');
-
-    var csve = this.getAsciiChar('csvEscape');
-    if(!csve && csve != 0) csve = this.get('DEFAULT_CSV_ESCAPE');
-
-    return {"csvDelimiter": csvd, "csvQuote" : csvq, "csvEscape": csve};
-  },
-
-  uploadForPreviewFromHDFS: function () {
-    console.log("uploadForPreviewFromHDFS called.");
-    var self = this;
-    var hdfsPath = this.get("hdfsPath");
-    this.validateHDFSPath(hdfsPath);
-    var csvParams = this.getCSVParams();
-
-    return this.get('uploader').previewFromHDFS({
-      "isFirstRowHeader": this.get("isFirstRowHeader"),
-      "inputFileType": this.get("inputFileType").id,
-      "hdfsPath": hdfsPath,
-      "csvDelimiter": csvParams.csvDelimiter,
-      "csvEscape": csvParams.csvEscape ,
-      "csvQuote": csvParams.csvQuote
-    });
-  },
-
-  generatePreview: function (files) {
-    var self = this;
-    var promise = null;
-    try {
-      this.waitForGeneratingPreview();
-      if (this.get('isLocalUpload')) {
-        promise = this.uploadForPreview(files);
-      } else {
-        promise = this.uploadForPreviewFromHDFS();
-      }
-
-      return promise.then(function (data) {
-        self.onGeneratePreviewSuccess(data);
-      }, function (error) {
-        self.onGeneratePreviewFailure(error);
-      }).catch(function (error) {
-        console.log("inside catch : ", error);
-      }).finally(function () {
-        console.log("finally hide the modal always after preview.");
-        self.hideUploadModal();
-      });
-    }catch(e){
-      // exception before promise will be caught here.
-      console.log("exception before promise : ", e);
-      self.setError(e);
-    }finally{
-      console.log("finally hide the modal always after preview.");
-      self.hideUploadModal();
-    }
-  },
-
-  waitForGeneratingPreview: function () {
-    console.log("waitForGeneratingPreview");
-    this.showUploadModal();
-    this.pushUploadProgressInfos(this.formatMessage('hive.messages.generatingPreview'))
-  },
-
-  previewTable: function (data) {
-    console.log('inside previewTable');
-    var self = this;
-    var defaultColumnNames = data.header.map(function(item,index){
-      return self.COLUMN_NAME_PREFIX + (index + 1);
-    });
-    this.set("defaultColumnNames",defaultColumnNames);
-    this.set("header", data.header);
-    this.set('isFirstRowHeader', data.isFirstRowHeader);
-    this.set('tableName', data.tableName);
-    var firstRow = null;
-    if (data.isFirstRowHeader == true) {
-      firstRow = data.header.map(function(columnDesc){
-        return columnDesc.name;
-      });
-    }else {
-      if(data.rows.length > 0){
-        firstRow = data.rows[0].row;
-      }else{
-        firstRow = [];
-      }
-    }
-    this.set("firstRow", firstRow);
-    this.set("rows", data.rows);
-  },
-
-  onGeneratePreviewSuccess: function (data) {
-    console.log("onGeneratePreviewSuccess");
-    this.set("showPreview",true);
-    this.hideUploadModal();
-    this.previewTable(data);
-  },
-
-  onGeneratePreviewFailure: function (error) {
-    console.log("onGeneratePreviewFailure");
-    this.set("showPreview",false);
-    this.hideUploadModal();
-    this.setError(error);
-  },
-
-  createActualTable: function () {
-    console.log("createActualTable");
-    var self = this;
-    this.pushUploadProgressInfos(this.formatMessage('hive.messages.startingToCreateActualTable'));
-    var headers = this.get('header');
-    var selectedDatabase = this.get('selectedDatabase');
-    if (!selectedDatabase) {
-      throw new Error(this.translate('hive.errors.emptyDatabase', {database : this.translate("hive.words.database")}));
-    }
-
-    this.set('databaseName', this.get('selectedDatabase.id'));
-    var databaseName = this.get('databaseName');
-    var tableName = this.get('tableName');
-    var isFirstRowHeader = this.get('isFirstRowHeader');
-    var filetype = this.get("selectedFileType");
-
-    this.validateInput(headers,tableName,databaseName,isFirstRowHeader);
-    this.showUploadModal();
-    var rowFormat = this.getRowFormat();
-    return this.get('uploader').createTable({
-      "isFirstRowHeader": isFirstRowHeader,
-      "header": headers,
-      "tableName": tableName,
-      "databaseName": databaseName,
-      "hiveFileType":filetype,
-      "rowFormat": { "fieldsTerminatedBy" : rowFormat.fieldsTerminatedBy, "escapedBy" : rowFormat.escapedBy}
-    });
-  },
-  getRowFormat : function(){
-    var fieldsTerminatedBy = this.getAsciiChar('fieldsTerminatedBy');
-    var escapedBy = this.getAsciiChar('escapedBy');
-    return {"fieldsTerminatedBy": fieldsTerminatedBy, "escapedBy" : escapedBy};
-  },
-  waitForCreateActualTable: function (jobId) {
-    console.log("waitForCreateActualTable");
-    this.popUploadProgressInfos();
-    this.pushUploadProgressInfos(this.formatMessage('hive.messages.waitingToCreateActualTable'));
-    var self = this;
-    var p = new Ember.RSVP.Promise(function (resolve, reject) {
-      self.waitForJobStatus(jobId, resolve, reject);
-    });
-
-    return p;
-  },
-  onCreateActualTableSuccess: function () {
-    console.log("onCreateTableSuccess");
-    this.popUploadProgressInfos();
-    this.pushUploadProgressInfos(this.formatMessage('hive.messages.successfullyCreatedActualTable'));
-  },
-  onCreateActualTableFailure: function (error) {
-    console.log("onCreateActualTableFailure");
-    this.popUploadProgressInfos();
-    this.pushUploadProgressInfos(this.formatMessage('hive.messages.failedToCreateActualTable'));
-    this.setError(error);
-  },
-  createTempTable: function () {
-    var self = this;
-    console.log("createTempTable");
-    this.pushUploadProgressInfos(this.formatMessage('hive.messages.startingToCreateTemporaryTable'));
-    var tempTableName = this.generateTempTableName();
-    this.set('tempTableName', tempTableName);
-
-    var headers = this.get("header");
-    if(this.get("containsEndlines")){
-      headers = this.get("header").map(function(item){
-        var header = JSON.parse(JSON.stringify(item));
-        header.type = "STRING";
-        return header;
-      });
-    }
-    return this.get('uploader').createTable({
-      "isFirstRowHeader": this.get("isFirstRowHeader"),
-      "header": headers,
-      "tableName": tempTableName,
-      "databaseName": this.get('databaseName'),
-      "hiveFileType":"TEXTFILE",
-      "rowFormat": { "fieldsTerminatedBy" : parseInt('1', 10), "escapedBy" : null}
-    });
-  },
-
-  waitForCreateTempTable: function (jobId) {
-    console.log("waitForCreateTempTable");
-    this.popUploadProgressInfos();
-    this.pushUploadProgressInfos(this.formatMessage('hive.messages.waitingToCreateTemporaryTable'));
-    var self = this;
-    var p = new Ember.RSVP.Promise(function (resolve, reject) {
-      self.waitForJobStatus(jobId, resolve, reject);
-    });
-
-    return p;
-  },
-
-  onCreateTempTableSuccess: function () {
-    console.log("onCreateTempTableSuccess");
-    this.popUploadProgressInfos();
-    this.pushUploadProgressInfos(this.formatMessage('hive.messages.successfullyCreatedTemporaryTable'));
-  },
-
-  deleteTable : function(databaseName, tableName){
-    console.log("deleting table ", databaseName , "." , tableName);
-
-    return this.get('uploader').deleteTable({
-      "database":  databaseName,
-      "table": tableName
-    });
-  },
-
-  deleteTableOnError: function (databaseName, tableName, tableLabel) {
-    //delete table and wait for delete job
-    var self = this;
-    this.pushUploadProgressInfos(this.formatMessage('hive.messages.deletingTable',{table:tableLabel}));
-
-    return this.deleteTable(databaseName, tableName).then(function (job) {
-      return new Ember.RSVP.Promise(function (resolve, reject) {
-        self.waitForJobStatus(job.id, resolve, reject);
-      });
-    }).then(function () {
-      self.popUploadProgressInfos();
-      self.pushUploadProgressInfos(this.formatMessage('hive.messages.succesfullyDeletedTable',{table:tableLabel}));
-      return Ember.RSVP.Promise.resolve();
-    }, function (err) {
-      self.popUploadProgressInfos();
-      self.pushUploadProgressInfos(this.formatMessage('hive.messages.failedToDeleteTable',{table:tableLabel}));
-      self.setError(err);
-      return Ember.RSVP.Promise.reject();
-    });
-  },
-
-  rollBackActualTableCreation : function(){
-    return this.deleteTableOnError(this.get("databaseName"),this.get("tableName"),this.translate('hive.words.actual'));
-  },
-
-  translate : function(str,vars){
-    return Ember.I18n.t(str,vars);
-  },
-  formatMessage : function(messageId, vars){
-    return "<li>" + this.translate(messageId,vars) + "</li>";
-  },
-  onCreateTempTableFailure : function(error){
-    console.log("onCreateTempTableFailure");
-    this.setError(error);
-    this.popUploadProgressInfos();
-    this.pushUploadProgressInfos(this.formatMessage('hive.messages.failedToCreateTemporaryTable'));
-    return this.rollBackActualTableCreation().then(function(data){
-      return Ember.RSVP.Promise.reject(error); // always reject for the flow to stop
-    }, function (err) {
-      return Ember.RSVP.Promise.reject(error); // always reject for the flow to stop
-    });
-  },
-
-  uploadFile: function () {
-    console.log("uploadFile");
-    this.pushUploadProgressInfos(this.formatMessage('hive.messages.startingToUploadFile'));
-    if( this.get("isLocalUpload")){
-      return this.uploadTable();
-    }else{
-      return this.uploadTableFromHdfs();
-    }
-  },
-
-  waitForUploadingFile: function (data) {
-    console.log("waitForUploadingFile");
-    this.popUploadProgressInfos();
-    this.pushUploadProgressInfos(this.formatMessage('hive.messages.waitingToUploadFile'));
-    if( data.jobId ){
-      var self = this;
-          var p = new Ember.RSVP.Promise(function (resolve, reject) {
-            self.waitForJobStatus(data.jobId, resolve, reject);
-          });
-      return p;
-    }else{
-      return  Ember.RSVP.Promise.resolve(data);
-    }
-  },
-
-  onUploadingFileSuccess: function () {
-    console.log("onUploadingFileSuccess");
-    this.popUploadProgressInfos();
-    this.pushUploadProgressInfos(this.formatMessage('hive.messages.successfullyUploadedFile') );
-  },
-
-  rollBackTempTableCreation: function () {
-    var self = this;
-    return this.deleteTableOnError(this.get("databaseName"),this.get("tempTableName"),this.translate('hive.words.temporary')).then(function(data){
-      return self.rollBackActualTableCreation();
-    },function(err){
-      return self.rollBackActualTableCreation();
-    })
-  },
-
-  onUploadingFileFailure: function (error) {
-    console.log("onUploadingFileFailure");
-    this.setError(error);
-    this.popUploadProgressInfos();
-    this.pushUploadProgressInfos(this.formatMessage('hive.messages.failedToUploadFile'));
-    return this.rollBackTempTableCreation().then(function(data){
-      return Ember.RSVP.Promise.reject(error); // always reject for the flow to stop
-    },function(err){
-      return Ember.RSVP.Promise.reject(error); // always reject for the flow to stop
-    });
-  },
-
-  rollBackUploadFile : function(){
-    return this.rollBackTempTableCreation();
-  },
-
-  insertIntoTable : function(){
-    console.log("insertIntoTable");
-    this.pushUploadProgressInfos(this.formatMessage('hive.messages.startingToInsertRows'));
-
-    return this.get('uploader').insertIntoTable({
-      "fromDatabase": this.get("databaseName"),
-      "fromTable": this.get("tempTableName"),
-      "toDatabase": this.get("databaseName"),
-      "toTable": this.get("tableName"),
-      "header": this.get("header"),
-      "unhexInsert": this.get("containsEndlines")
-    });
-  },
-
-  waitForInsertIntoTable: function (jobId) {
-    console.log("waitForInsertIntoTable");
-    this.popUploadProgressInfos();
-    this.pushUploadProgressInfos(this.formatMessage('hive.messages.waitingToInsertRows'));
-    var self = this;
-    var p = new Ember.RSVP.Promise(function (resolve, reject) {
-      self.waitForJobStatus(jobId, resolve, reject);
-    });
-
-    return p;
-  },
-
-  onInsertIntoTableSuccess: function () {
-    console.log("onInsertIntoTableSuccess");
-    this.popUploadProgressInfos();
-    this.pushUploadProgressInfos(this.formatMessage('hive.messages.successfullyInsertedRows'));
-  },
-
-  onInsertIntoTableFailure: function (error) {
-    console.log("onInsertIntoTableFailure");
-    this.setError(error);
-    this.popUploadProgressInfos();
-    this.pushUploadProgressInfos(this.formatMessage('hive.messages.failedToInsertRows'));
-    return this.rollBackUploadFile().then(function(data){
-      return Ember.RSVP.Promise.reject(error); // always reject for the flow to stop
-    },function(err){
-      return Ember.RSVP.Promise.reject(error); // always reject for the flow to stop
-    });
-  },
-
-  deleteTempTable : function(){
-    console.log("deleteTempTable");
-    this.pushUploadProgressInfos(this.formatMessage('hive.messages.startingToDeleteTemporaryTable'));
-
-    return this.deleteTable(
-      this.get("databaseName"),
-      this.get("tempTableName")
-    );
-  },
-  waitForDeleteTempTable: function (jobId) {
-    console.log("waitForDeleteTempTable");
-    this.popUploadProgressInfos();
-    this.pushUploadProgressInfos(this.formatMessage('hive.messages.waitingToDeleteTemporaryTable'));
-    var self = this;
-    var p = new Ember.RSVP.Promise(function (resolve, reject) {
-      self.waitForJobStatus(jobId, resolve, reject);
-    });
-
-    return p;
-  },
-  onDeleteTempTableSuccess: function () {
-    console.log("onDeleteTempTableSuccess");
-    this.popUploadProgressInfos();
-    this.pushUploadProgressInfos(this.formatMessage('hive.messages.successfullyDeletedTemporaryTable'));
-    this.onUploadSuccessfull();
-  },
-  onDeleteTempTableFailure: function (error) {
-    console.log("onDeleteTempTableFailure");
-    this.setError(error);
-    this.setError(this.formatMessage('hive.messages.manuallyDeleteTable',{databaseName:this.get('databaseName'), tableName: this.get("tempTableName")}));
-  },
-  validateHDFSPath: function (hdfsPath) {
-    if (null == hdfsPath || hdfsPath == "") throw new Error(this.translate('hive.errors.emptyHdfsPath'));
-    var hdfsRegex = new RegExp(this.get("HDFS_PATH_REGEX"), "g");
-    var mArr = hdfsPath.match(hdfsRegex);
-    if (mArr == null || mArr.length != 1) throw new Error(this.translate('hive.errors.illegalHdfPath', {"hdfsPath": hdfsPath} ));
-  },
-  createTableAndUploadFile: function () {
-    var self = this;
-    self.setError();
-    self.createActualTable()
-      .then(function(job){
-        console.log("1. received job : ", job);
-        return self.waitForCreateActualTable(job.id);
-      },function(error){
-        console.log("Error occurred: ", error);
-        self.onCreateActualTableFailure(error);
-        throw error;
-      })
-      .then(function(data){
-        self.onCreateActualTableSuccess(data);
-        return self.createTempTable(data);
-      },function(error){
-        if(!self.get('error')){
-          console.log("Error occurred: ", error);
-          self.onCreateActualTableFailure(error);
-        }
-        throw error;
-      })
-      .then(function(job){
-        return self.waitForCreateTempTable(job.id);
-      },function(error){
-        if(!self.get('error')){
-          console.log("Error occurred: ", error);
-          return self.onCreateTempTableFailure(error);
-        }
-        throw error;
-      })
-      .then(function(data){
-        self.onCreateTempTableSuccess(data);
-        return self.uploadFile(data);
-      },function(error){
-        if(!self.get('error')){
-          console.log("Error occurred: ", error);
-          return self.onCreateTempTableFailure(error);
-        }
-        throw error;
-      }).then(function(data){
-        return self.waitForUploadingFile(data);
-      },function(error){
-        if(!self.get('error')){
-          console.log("Error occurred: ", error);
-          return self.onUploadingFileFailure(error);
-        }
-        throw error;
-      })
-      .then(function(data){
-        self.onUploadingFileSuccess(data);
-        return self.insertIntoTable(data);
-      },function(error){
-        if(!self.get('error')){
-          console.log("Error occurred: ", error);
-          return self.onUploadingFileFailure(error);
-        }
-        throw error;
-      })
-      .then(function(job){
-        return self.waitForInsertIntoTable(job.id);
-      },function(error){
-        if(!self.get('error')){
-          console.log("Error occurred: ", error);
-          return self.onInsertIntoTableFailure(error);
-        }
-        throw error;
-      })
-      .then(function(data){
-        self.onInsertIntoTableSuccess(data);
-        return self.deleteTempTable(data);
-      },function(error){
-        if(!self.get('error')){
-          console.log("Error occurred: ", error);
-          return self.onInsertIntoTableFailure(error);
-        }
-        throw error;
-      })
-      .then(function(job){
-        return self.waitForDeleteTempTable(job.id);
-      },function(error){
-        if(!self.get('error')){
-          console.log("Error occurred: ", error);
-          self.onDeleteTempTableFailure(error);
-        }
-        throw error;
-      })
-      .then(function(data){
-        self.onDeleteTempTableSuccess(data);
-      },function(error){
-        if(!self.get('error')){
-          console.log("Error occurred: ", error);
-          self.onDeleteTempTableFailure(error);
-        }
-        throw error;
-      })
-     .catch(function(error){
-        console.log("inside catch : ", error);
-      })
-      .finally(function(){
-        console.log("finally hide the modal always");
-        self.hideUploadModal();
-      });
-  },
-  validateInput: function (headers,tableName,databaseName,isFirstRowHeader) {
-    // throw exception if invalid.
-    if(!headers || headers.length == 0) throw new Error(this.translate('hive.errors.emptyHeaders'));
-
-    var regex = new RegExp(this.get("COLUMN_NAME_REGEX"),"g");
-
-    headers.forEach(function(column,index){
-      if( !column  ) throw new Error(this.translate('hive.errors.emptyColumnName'));
-      var matchArr = column.name.match(regex);
-      if(matchArr == null || matchArr.length != 1 ) throw new Error(this.translate('hive.errors.illegalColumnName',{ columnName : column.name, index : (index + 1)}));
-    },this);
-
-    if(!tableName) throw new Error(this.translate('hive.errors.emptyTableName', {tableNameField : this.translate('hive.ui.tableName')}));
-    var tableRegex = new RegExp(this.get("TABLE_NAME_REGEX"),"g");
-    var mArr = tableName.match(tableRegex);
-    if(mArr == null || mArr.length != 1 ) throw new Error(this.translate('hive.errors.illegalTableName', {tableNameField:this.translate('hive.ui.tableName'),tableName:tableName}) );
-
-    if(!databaseName) throw new Error(this.translate('hive.errors.emptyDatabase', {database:this.translate('hive.words.database')}));
-
-    if (null == isFirstRowHeader || typeof isFirstRowHeader === 'undefined') { //this can be true or false. so explicitly checking for null/ undefined.
-      throw new Error(this.translate('hive.errors.emptyIsFirstRow', {isFirstRowHeaderField:this.translate('hive.ui.isFirstRowHeader')}));
-    }
-  },
-  setError: function (error) {
-    if(error){
-      console.log(" error : ", error);
-      this.set('error', JSON.stringify(error));
-      this.get('notifyService').error(error);
-    }else{
-      this.set("error");
-    }
-  },
-  previewError: function (error) {
-    this.setError(error);
-  },
-  uploadTableFromHdfs : function(){
-    console.log("uploadTableFromHdfs called.");
-    if(!(this.get("inputFileTypeCSV") == true && this.get("isFirstRowHeader") == false) ){
-      this.pushUploadProgressInfos(this.formatMessage('uploadingFromHdfs'));
-    }
-    var csvParams = this.getCSVParams();
-
-    return this.get('uploader').uploadFromHDFS({
-      "isFirstRowHeader": this.get("isFirstRowHeader"),
-      "databaseName": this.get('databaseName'),
-      "tableName": this.get("tempTableName"),
-      "inputFileType": this.get("inputFileType").id,
-      "hdfsPath": this.get("hdfsPath"),
-      "header": this.get("header"),
-      "containsEndlines": this.get("containsEndlines"),
-      "csvDelimiter": csvParams.csvDelimiter,
-      "csvEscape": csvParams.csvEscape,
-      "csvQuote": csvParams.csvQuote
-    });
-  },
-  uploadTable: function () {
-    this.printValues();
-    var csvParams = this.getCSVParams();
-
-    return this.get('uploader').uploadFiles('upload', this.get('files'), {
-      "isFirstRowHeader": this.get("isFirstRowHeader"),
-      "databaseName" :  this.get('databaseName'),
-      "tableName" : this.get("tempTableName"),
-      "inputFileType" : this.get("inputFileType").id,
-      "header": JSON.stringify(this.get("header")),
-      "containsEndlines": this.get("containsEndlines"),
-      "csvDelimiter": csvParams.csvDelimiter,
-      "csvEscape": csvParams.csvEscape ,
-      "csvQuote": csvParams.csvQuote
-    });
-  },
-
-  onUploadSuccessfull: function (data) {
-    console.log("onUploadSuccessfull : ", data);
-    this.get('notifyService').success(this.translate('hive.messages.successfullyUploadedTableHeader'),
-      this.translate('hive.messages.successfullyUploadedTableMessage' ,{tableName:this.get('tableName') ,databaseName:this.get("databaseName")}));
-    this.clearFields();
-  },
-
-  onUploadError: function (error) {
-    console.log("onUploadError : ", error);
-    this.setError(error);
-  },
-  showOrHide: function () {
-    if (this.get('show') == false) {
-      this.set("displayOption", "display:none");
-      this.set("showMoreOrLess", "Show More");
-    } else {
-      this.set("displayOption", "display:table-row");
-      this.set("showMoreOrLess", "Show Less");
-    }
-  },
-  displayOption: "display:none",
-  actions: {
-    hideInputParamModal : function(){
-      Ember.$("#inputParamsModal").modal("hide");
-    },
-    showInputParamModal : function(){
-      if(this.get('inputFileTypeCSV')){
-        Ember.$("#inputParamsModal").modal("show");
-      }
-    },
-    hideRowFormatModal : function(){
-      Ember.$("#rowFormatModal").modal("hide");
-    },
-    showRowFormatModal : function(){
-      if(this.get('storedAsTextFile')) {
-        Ember.$("#rowFormatModal").modal("show");
-      }
-    },
-    toggleErrors: function () {
-      this.toggleProperty('showErrors');
-    },
-    filesUploaded: function (files) {
-      console.log("upload-table.js : uploaded new files : ", files);
-      this.clearFields();
-
-      this.set('files', files);
-      var name = files[0].name;
-      var i = name.indexOf(".");
-      var tableName = name.substr(0, i);
-      this.set('tableName', tableName);
-      var self = this;
-      return this.generatePreview(files)
-    },
-    previewFromHdfs: function () {
-      return this.generatePreview();
-    },
-    uploadTable: function () {
-      try {
-        this.createTableAndUploadFile();
-      } catch (e) {
-        console.log("exception occured : ", e);
-        this.setError(e);
-        this.hideUploadModal();
-      }
-    },
-    uploadFromHDFS: function () {
-      this.set("isLocalUpload", false);
-    }
-  }
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/controllers/visual-explain.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/controllers/visual-explain.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/controllers/visual-explain.js
deleted file mode 100644
index 272aa11..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/controllers/visual-explain.js
+++ /dev/null
@@ -1,64 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-import constants from 'hive/utils/constants';
-
-export default Ember.Controller.extend({
-  jobProgressService: Ember.inject.service(constants.namingConventions.jobProgress),
-  openQueries   : Ember.inject.controller(constants.namingConventions.openQueries),
-  notifyService: Ember.inject.service(constants.namingConventions.notify),
-
-  index: Ember.inject.controller(),
-  verticesProgress: Ember.computed.alias('jobProgressService.currentJob.stages'),
-
-  actions: {
-    onTabOpen: function () {
-      var self = this;
-
-      // Empty query
-      if(this.get('openQueries.currentQuery.fileContent').length == 0){
-        this.set('json', undefined);
-        this.set('noquery', 'hive.errors.no.query');
-        return;
-      } else {
-        this.set('noquery', undefined);
-      }
-      // Introducing a common function
-      var getVisualExplainJson = function(){
-        self.set('showSpinner', undefined);
-        self.set('rerender');
-        self.get('index')._executeQuery(constants.jobReferrer.visualExplain, true, true).then(function (json) {
-          //this condition should be changed once we change the way of retrieving this json
-          if (json['STAGE PLANS']['Stage-1']) {
-            self.set('json', json);
-          } else {
-            self.set('json', {})
-          }
-        }, function (error) {
-          self.set('json', undefined);
-          self.get('notifyService').error(error);
-        });
-        self.toggleProperty('shouldChangeGraph');
-      }
-
-      getVisualExplainJson();
-
-    }
-  }
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/controllers/visualization-ui.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/controllers/visualization-ui.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/controllers/visualization-ui.js
deleted file mode 100644
index c908afd..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/controllers/visualization-ui.js
+++ /dev/null
@@ -1,134 +0,0 @@
-/**
-* 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.
-*/
-
-import Ember from 'ember';
-import constants from 'hive/utils/constants';
-
-export default Ember.Controller.extend({
-  selectedRowCount: constants.defaultVisualizationRowCount,
-  needs: [ constants.namingConventions.index,
-            constants.namingConventions.openQueries,
-            constants.namingConventions.jobResults
-          ],
-  index         : Ember.computed.alias('controllers.' + constants.namingConventions.index),
-  openQueries   : Ember.computed.alias('controllers.' + constants.namingConventions.openQueries),
-  results   : Ember.computed.alias('controllers.' + constants.namingConventions.jobResults),
-  notifyService: Ember.inject.service(constants.namingConventions.notify),
-
-  polestarUrl: '',
-  voyagerUrl: '',
-  polestarPath: 'polestar/#/',
-  voyagerPath: 'voyager/#/',
-
-  showDataExplorer: true,
-  showAdvVisulization: false,
-
-  visualizationTabs: function () {
-    return [
-      Ember.Object.create({
-        name: 'Data Visualization',
-        id: 'visualization',
-        url: this.get('polestarUrl')
-      }),
-      Ember.Object.create({
-        name: 'Data Explorer',
-        id: 'data_explorer',
-        url: this.get('voyagerUrl')
-      })
-    ]
-  }.property('polestarUrl', 'voyagerUrl'),
-
-  activeTab: function () {
-    console.log("I am in activeTab function.");
-    this.get('visualizationTabs')[0].active = this.get("showDataExplorer");
-    this.get('visualizationTabs')[1].active = this.get("showAdvVisulization");
-  }.observes('polestarUrl', 'voyagerUrl'),
-
-  alterIframe: function () {
-    Ember.$("#visualization_frame").height(Ember.$("#visualization").height());
-  },
-
-  actions: {
-    onTabOpen: function () {
-      var self = this;
-      var model = this.get('index.model');
-      if (model) {
-        var existingJob = this.get('results').get('cachedResults').findBy('id', model.get('id'));
-        var url = this.container.lookup('adapter:application').buildURL();
-        url += '/' + constants.namingConventions.jobs + '/' + model.get('id') + '/results?&first=true';
-        url += '&count='+self.get('selectedRowCount')+'&job_id='+model.get('id')
-        if (existingJob) {
-          if(existingJob.results[0].rows.length === 0){
-            this.set("error", "Query has insufficient results to visualize the data.");
-            return;
-          }
-          this.set("error", null);
-          var id = model.get('id');
-          this.set("polestarUrl", this.get('polestarPath') + "?url=" + url);
-          this.set("voyagerUrl", this.get('voyagerPath') + "?url=" + url);
-          Ember.run.scheduleOnce('afterRender', this, function(){
-            self.alterIframe();
-          });
-        } else {
-          this.set("error", "No visualization available. Please execute a query and wait for the results to visualize the data.");
-        }
-      }
-    },
-
-      changeRowCount: function () {
-        var self = this;
-        if(isNaN(self.get('selectedRowCount')) || !(self.get('selectedRowCount')%1 === 0) || (self.get('selectedRowCount') <= 0)){
-          self.get('notifyService').error("Please enter a posive integer number.");
-          return;
-        }
-        var model = this.get('index.model');
-        if (model) {
-          var existingJob = this.get('results').get('cachedResults').findBy('id', model.get('id'));
-          var url = this.container.lookup('adapter:application').buildURL();
-          url += '/' + constants.namingConventions.jobs + '/' + model.get('id') + '/results?&first=true';
-          url += '&count='+self.get('selectedRowCount')+'&job_id='+model.get('id');
-          if (existingJob) {
-            this.set("error", null);
-            var id = model.get('id');
-
-            $('.nav-tabs.visualization-tabs li.active').each(function( index ) {
-
-              if($(this)[index].innerText.indexOf("Data Explorer") > -1){
-                self.set("showDataExplorer",true);
-                self.set("showAdvVisulization",false);
-                self.set("voyagerUrl", self.get('voyagerPath') + "?url=" + url);
-                self.set("polestarUrl", self.get('polestarPath') + "?url=" + url);
-                document.getElementById("visualization_frame").src =  self.get("voyagerUrl");
-              }
-              if($(this)[index].innerText.indexOf("Advanced Visualization") > -1){
-                self.set("showAdvVisulization",true);
-                self.set("showDataExplorer",false);
-                self.set("voyagerUrl", self.get('voyagerPath') + "?url=" + url);
-                self.set("polestarUrl", self.get('polestarPath') + "?url=" + url);
-                document.getElementById("visualization_frame").src = self.get("polestarUrl");
-              }
-            })
-            document.getElementById("visualization_frame").contentWindow.location.reload();
-          } else {
-            this.set("error", "No visualization available. Please execute a query and wait for the results to visualize data.");
-          }
-        }
-
-      }
-  }
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/helpers/.gitkeep
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/helpers/.gitkeep b/contrib/views/hive/src/main/resources/ui/hive-web/app/helpers/.gitkeep
deleted file mode 100644
index e69de29..0000000

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/helpers/all-uppercase.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/helpers/all-uppercase.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/helpers/all-uppercase.js
deleted file mode 100644
index 92930a9..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/helpers/all-uppercase.js
+++ /dev/null
@@ -1,25 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-
-export function allUppercase (input) {
-  return input ? input.toUpperCase() : input;
-}
-
-export default Ember.Handlebars.makeBoundHelper(allUppercase);

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/helpers/code-helper.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/helpers/code-helper.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/helpers/code-helper.js
deleted file mode 100644
index 8bbd19e..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/helpers/code-helper.js
+++ /dev/null
@@ -1,28 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-
-export function code (text) {
-  text = Ember.Handlebars.Utils.escapeExpression(text);
-  text = text.replace(/(\r\n|\n|\r)/gm, '<br>');
-
-  return new Ember.Handlebars.SafeString('<code>' + text + '</code>');
-}
-
-export default Ember.Handlebars.makeBoundHelper(code);

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/helpers/date-binding.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/helpers/date-binding.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/helpers/date-binding.js
deleted file mode 100644
index 61251f8..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/helpers/date-binding.js
+++ /dev/null
@@ -1,27 +0,0 @@
-/**
- * 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.
- */
-
-/* globals moment */
-
-import Ember from 'ember';
-
-export function pathBinding (data, key) {
-  return moment(data.get(key)).fromNow();
-}
-
-export default Ember.Handlebars.makeBoundHelper(pathBinding);

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/helpers/format-column-type.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/helpers/format-column-type.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/helpers/format-column-type.js
deleted file mode 100644
index 13528b7..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/helpers/format-column-type.js
+++ /dev/null
@@ -1,39 +0,0 @@
-/**
- * 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.
- */
-
-/**
- used to format the precision and scale of type in database's table's columns
-**/
-
-import Ember from "ember";
-
-var columnTypeFormatter = function(column) {
-  var type = column.type;
-  var ext = type;
-  if( type === "VARCHAR" || type === "CHAR" || type == "DECIMAL"  ) {
-      ext += '(' + column.precision;
-    if (type == "DECIMAL") {
-        ext += "," + column.scale;
-    }
-    ext += ")";
-  }
-
-  return ext;
-};
-
-export default Ember.Handlebars.makeBoundHelper(columnTypeFormatter);

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/helpers/log-helper.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/helpers/log-helper.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/helpers/log-helper.js
deleted file mode 100644
index c29d129..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/helpers/log-helper.js
+++ /dev/null
@@ -1,28 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-
-export function log (text) {
-  text = Ember.Handlebars.Utils.escapeExpression(text);
-  text = text.replace(/(\r\n|\n|\r)/gm, '<br>');
-
-  return new Ember.Handlebars.SafeString(text);
-}
-
-export default Ember.Handlebars.makeBoundHelper(log);

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/helpers/path-binding.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/helpers/path-binding.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/helpers/path-binding.js
deleted file mode 100644
index 926aaaa..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/helpers/path-binding.js
+++ /dev/null
@@ -1,29 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-
-export function pathBinding (data, key) {
-  if (!data || !key) {
-    return;
-  }
-
-  return data.get ? data.get(key) : data[key];
-}
-
-export default Ember.Handlebars.makeBoundHelper(pathBinding);

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/helpers/preformatted-string.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/helpers/preformatted-string.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/helpers/preformatted-string.js
deleted file mode 100644
index 4ab6a2e..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/helpers/preformatted-string.js
+++ /dev/null
@@ -1,28 +0,0 @@
-/**
-* 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.
-*/
-import Ember from 'ember';
-
-export function preformattedString (string) {
-  string = string.replace(/\\n/g, '&#10;'); // newline
-  string = string.replace(/\\t/g, '&#09;'); // tabs
-  string = string.replace(/^\s+|\s+$/g, ''); // trim
-
-  return new Ember.Handlebars.SafeString(string);
-}
-
-export default Ember.Handlebars.makeBoundHelper(preformattedString);

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/helpers/tb-helper.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/helpers/tb-helper.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/helpers/tb-helper.js
deleted file mode 100644
index 81af5ff..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/helpers/tb-helper.js
+++ /dev/null
@@ -1,33 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-
-export function tb (key, data) {
-  var path = data.get ? data.get(key) : data[key];
-
-  if (!path && key) {
-    return Ember.I18n.t(key);
-  }
-
-  if (path) {
-    return Ember.I18n.t(path);
-  }
-}
-
-export default Ember.Handlebars.makeBoundHelper(tb);

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/index.html
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/index.html b/contrib/views/hive/src/main/resources/ui/hive-web/app/index.html
deleted file mode 100644
index 2cbf9f0..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/index.html
+++ /dev/null
@@ -1,42 +0,0 @@
-<!--
- * 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.
--->
-<!DOCTYPE html>
-<html>
-  <head>
-    <meta charset="utf-8">
-    <meta http-equiv="X-UA-Compatible" content="IE=edge">
-    <title>Hive</title>
-    <meta name="description" content="">
-    <meta name="viewport" content="width=device-width, initial-scale=1">
-
-    {{content-for 'head'}}
-
-    <link rel="stylesheet" href="assets/vendor.css">
-    <link rel="stylesheet" href="assets/hive.css">
-
-    {{content-for 'head-footer'}}
-  </head>
-  <body>
-    {{content-for 'body'}}
-
-    <script src="assets/vendor.js"></script>
-    <script src="assets/hive.js"></script>
-
-    {{content-for 'body-footer'}}
-  </body>
-</html>

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/initializers/i18n.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/initializers/i18n.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/initializers/i18n.js
deleted file mode 100644
index 3f4812b..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/initializers/i18n.js
+++ /dev/null
@@ -1,348 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-
-var TRANSLATIONS;
-
-export default {
-  name: 'i18n',
-  initialize: function () {
-    Ember.ENV.I18N_COMPILE_WITHOUT_HANDLEBARS = true;
-    Ember.FEATURES.I18N_TRANSLATE_HELPER_SPAN = false;
-    Ember.I18n.translations = TRANSLATIONS;
-    Ember.TextField.reopen(Ember.I18n.TranslateableAttributes);
-  }
-};
-
-TRANSLATIONS = {
-  tooltips: {
-    refresh: 'Refresh database',
-    loadSample: 'Load sample data',
-    query: 'Query',
-    settings: 'Settings',
-    visualExplain: 'Visual Explain',
-    tez: 'Tez',
-    visualization: 'Visualization',
-    notifications: 'Notifications',
-    expand: 'Expand query panel',
-    makeSettingGlobal: 'Make setting global',
-    overwriteGlobalValue: 'Overwrite global setting value'
-  },
-
-  alerts: {
-    errors: {
-      save: {
-        query: "Error when trying to execute the query",
-        results: "Error when trying to save the results."
-      },
-      get: {
-        tables: 'Error when trying to retrieve the tables for the selected database',
-        columns: 'Error when trying to retrieve the table columns.'
-      },
-      sessions: {
-        delete: 'Error invalidating sessions'
-      },
-      job: {
-        status: "An error occured while processing the job."
-      }
-    },
-    success: {
-      sessions: {
-        deleted: 'Session invalidated.'
-      },
-      settings: {
-        saved: 'Settings have been saved.'
-      },
-      query: {
-        execution: 'Query has been submitted.',
-        save: 'The query has been saved.',
-        update: 'The query has been updated.'
-      }
-    }
-  },
-
-  modals: {
-    delete: {
-      heading: 'Confirm deletion',
-      message: 'Are you sure you want to delete this item?',
-      emptyQueryMessage: "Your query is empty. Do you want to delete this item?"
-    },
-
-    save: {
-      heading: 'Saving item',
-      saveBeforeCloseHeading: "Save item before closing?",
-      message: 'Enter name:',
-      overwrite: 'Saving will overwrite previously saved query'
-    },
-
-    download: {
-      csv: 'Download results as CSV',
-      hdfs: 'Please enter save path and name'
-    },
-    downloadQuery: {
-      heading: 'Download Query'
-    },
-    changeTitle: {
-      heading: 'Rename worksheet'
-    },
-    authenticationLDAP: {
-       heading: 'Enter the LDAP password'
-    }
-  },
-
-  titles: {
-    database: 'Database Explorer',
-    explorer: 'Databases',
-    results: 'Search Results',
-    settings: 'Database Settings',
-    query: {
-      tab: 'Worksheet',
-      editor: 'Query Editor',
-      process: 'Query Process Results',
-      parameters: 'Parameters',
-      visualExplain: 'Visual Explain',
-      tez: 'TEZ',
-      status: 'Status: ',
-      messages: 'Messages',
-      visualization: 'Visualization'
-    },
-    download: 'Save results...',
-    tableSample: '{{tableName}} sample'
-  },
-
-  placeholders: {
-    search: {
-      tables: 'Search tables...',
-      columns: 'Search columns in result tables...',
-      results: 'Filter columns...'
-    },
-    select: {
-      database: 'Select Database...',
-      udfs: 'Insert udfs',
-      file: 'Select File Resource...',
-      noFileResource: '(no file)',
-      value: "Select value..."
-    },
-    fileResource: {
-      name: "resource name",
-      path: "resource path"
-    },
-    udfs: {
-      name: 'udf name',
-      className: 'udf class name',
-      path: "resource path",
-      database: 'Select Database...'
-    },
-    settings: {
-      key: 'mapred.reduce.tasks',
-      value: '1'
-    }
-  },
-
-  menus: {
-    query: 'Query',
-    savedQueries: 'Saved Queries',
-    history: 'History',
-    udfs: 'UDFs',
-    uploadTable: 'Upload Table',
-    logs: 'Logs',
-    results: 'Results',
-    explain: 'Explain'
-  },
-
-  columns: {
-    id: 'id',
-    shortQuery: 'preview',
-    fileResource: 'file resource',
-    title: 'title',
-    database: 'database',
-    owner: 'owner',
-    user: 'user',
-    date: 'date submitted',
-    duration: 'duration',
-    status: 'status',
-    expand: '',
-    actions: ''
-  },
-
-  buttons: {
-    addItem: 'Add new item...',
-    insert: 'Insert',
-    delete: 'Delete',
-    cancel: 'Cancel',
-    edit: 'Edit',
-    execute: 'Execute',
-    explain: 'Explain',
-    saveAs: 'Save as...',
-    save: 'Save',
-    downloadQuery: 'Download',
-    newQuery: 'New Worksheet',
-    uploadQuery: 'Upload',
-    newUdf: 'New UDF',
-    history: 'History',
-    ok: 'OK',
-    stopJob: 'Stop execution',
-    stoppingJob: 'Stopping...',
-    close: 'Close',
-    clearFilters: 'Clear filters',
-    refresh: 'Refresh',
-    expand: 'Expand message',
-    collapse: 'Collapse message',
-    previousPage: 'previous',
-    uploadTable: 'Upload Table',
-    showPreview: 'Preview',
-    nextPage: 'next',
-    loadMore: 'Load more...',
-    saveHdfs: 'Save to HDFS',
-    saveCsv: 'Download as CSV',
-    runOnTez: 'Run on Tez',
-    killSession: 'Kill Session'
-  },
-
-  labels: {
-    noTablesMatch: 'No tables match',
-    noColumnsMatch: 'No columns match',
-    table: 'Table ',
-    hrsShort: "{{hours}} hrs",
-    minsShort: "{{minutes}} mins",
-    secsShort: "{{seconds}} secs"
-  },
-
-  popover: {
-    visualExplain: {
-      statistics: "Statistics"
-    },
-    queryEditorHelp: {
-      title: "Did you know?",
-      content: {
-        line1: "Press CTRL + Space to autocomplete",
-        line2: "You can execute queries with multiple SQL statements delimited by a semicolon ';'",
-        line3: "You can highlight and run a fragment of a query"
-      }
-    },
-    add: 'Add'
-  },
-
-  tez: {
-    errors: {
-      'not.deployed': "Tez View isn't deployed.",
-      'no.instance': "No instance of Tez View found.",
-      'no.dag': "No DAG available"
-    }
-  },
-
-  hive: {
-    errors: {
-      'no.query': "No query to process.",
-      'emptyDatabase' : "Please select {{ database }}.",
-      'emptyTableName' : "Please enter {{ tableNameField }}.",
-      'illegalTableName': "Illegal {{ tableNameField }} : '{{ tableName }}'",
-      'emptyIsFirstRow' : "{{isFirstRowHeaderField}} cannot be null.",
-      'emptyHeaders': "Headers (containing column names) cannot be null.",
-      'emptyColumnName': "Column name cannot be null.",
-      'illegalColumnName': "Illegal column name : '{{columnName}}' in column number {{index}}",
-      'emptyHdfsPath': "HdfsPath Name cannot be null or empty.",
-      'illegalHdfPath': "Illegal hdfs path : {{hdfsPath}}"
-    },
-    messages : {
-      'generatingPreview':"Generating Preview.",
-      'startingToCreateActualTable' : "Starting to create Actual table",
-      'waitingToCreateActualTable' : "Waiting for creation of Actual table",
-      'successfullyCreatedActualTable' : "Successfully created Actual table.",
-      'failedToCreateActualTable' : "Failed to create Actual table.",
-      'startingToCreateTemporaryTable' : "Starting to create Temporary table.",
-      'waitingToCreateTemporaryTable' : "Waiting for creation of Temporary table.",
-      'successfullyCreatedTemporaryTable' : "Successfully created Temporary table.",
-      'failedToCreateTemporaryTable' : " Failed to create temporary table.",
-      'deletingTable' :  "Deleting {{table}} table.",
-      'succesfullyDeletedTable' :  "Successfully deleted {{ table}} table.",
-      'failedToDeleteTable' :  "Failed to delete {{table}} table.",
-      'startingToUploadFile' :  "Starting to upload the file.",
-      'waitingToUploadFile' :  "Waiting for uploading file.",
-      'successfullyUploadedFile' :  "Successfully uploaded file.",
-      'failedToUploadFile' :  "Failed to upload file.",
-      'startingToInsertRows' :  "Starting to insert rows from temporary table to actual table.",
-      'waitingToInsertRows' :  "Waiting for insertion of rows from temporary table to actual table.",
-      'successfullyInsertedRows' :  "Successfully inserted rows from temporary table to actual table.",
-      'failedToInsertRows' :  "Failed to insert rows from temporary table to actual table.",
-      'startingToDeleteTemporaryTable' :  "Starting to delete temporary table.",
-      'waitingToDeleteTemporaryTable' :  "Waiting for deletion of temporary table.",
-      'successfullyDeletedTemporaryTable' :  "Successfully deleted temporary table",
-      'manuallyDeleteTable' :  "You will have to manually delete the table {{databaseName}}.{{tableName}}",
-      'uploadingFromHdfs' :  "Uploading file from HDFS ",
-      'successfullyUploadedTableMessage' : "Table {{tableName}} created in database {{databaseName}}",
-      'successfullyUploadedTableHeader' : "Uploaded Successfully"
-    },
-    words :{
-      temporary : "Temporary",
-      actual : "Actual",
-      database : "Database"
-    },
-    ui : {
-      'uploadProgress' : "Upload Progress",
-      'uploading': "Uploading..",
-      'uploadFromLocal':"Upload from Local",
-      'uploadFromHdfs':"Upload from HDFS",
-      'selectFileType':"Select File Type",
-      'fileType':"File type",
-      'selectFromLocal':"Select from local",
-      'hdfsPath':"HDFS Path",
-      'selectDatabase':"Select a Database",
-      'tableName':"Table name",
-      'tableNameErrorMessage':"Only alphanumeric and underscore characters are allowed in table name.",
-      'tableNameTooltip':"Enter valid (alphanumeric + underscore) table name.",
-      'storedAs':"Stored as",
-      'isFirstRowHeader':"Is first row header ?",
-      'columnNameTooltip':"Enter valid (alphanumeric + underscore) column name.",
-      'columnNameErrorMessage':"Only alphanumeric and underscore characters are allowed in column names.",
-      'hdfsFieldTooltip':"Enter full HDFS path",
-      'hdfsFieldPlaceholder':"Enter full HDFS path",
-      'hdfsFieldErrorMessage':"Please enter complete path of hdfs file to upload.",
-      'containsEndlines': "Contains endlines?",
-      'columnDelimiterTooltip': "Delimiter for the column values. Default is comman (,).",
-      'escapeCharacterTooltip': "Escape character. Default is backslash (\).",
-      'quoteCharacterTooltip': 'Quote character. Default is double quote (").',
-      'quoteCharacterField': "Quote Character",
-      'escapeCharacterField': "Escape Character",
-      'columnDelimterField': "Field Delimiter",
-      'fieldsTerminatedByField': "Fields Terminated By",
-      'escapedByField': "Escape By",
-      'escapedByTooltip': "Escaped By character for Hive table.",
-      'fieldsTerminatedByTooltip': "Fields Terminated By character for Hive table.",
-      'isFirstRowHeaderTooltip': "Check if the first row of CSV is a header."
-    }
-  },
-
-  emptyList: {
-    history: {
-      noItems: "No queries were run.",
-      noMatches: "No jobs match your filtering criteria",
-    },
-    savedQueries: {
-      noItems: "No queries were saved.",
-      noMatches: "No queries match your filtering criteria"
-    }
-  },
-
-  settings: {
-    parsed: "Query settings added"
-  },
-
-  generalError: 'Unexpected error'
-};

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/mixins/filterable.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/mixins/filterable.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/mixins/filterable.js
deleted file mode 100644
index aa1f4cd..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/mixins/filterable.js
+++ /dev/null
@@ -1,106 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-import utils from 'hive/utils/functions';
-
-export default Ember.Mixin.create({
-  init: function () {
-    this._super();
-    this.clearFilters();
-  },
-
-  filter: function (items) {
-    var self = this;
-
-    if (items && this.get('filters.length')) {
-      items = items.filter(function (item) {
-        return self.get('filters').every(function (filter) {
-          var propValue = item.get(filter.property);
-
-          if (!!filter.value) {
-            if (filter.min !== undefined && filter.max !== undefined) {
-              if (utils.isInteger(propValue)) {
-                return +propValue >= +filter.min && +propValue <= +filter.max;
-              } else if (utils.isDate(propValue)) {
-                return propValue >= filter.min && propValue <= filter.max;
-              } else {
-                return false;
-              }
-            } else if (filter.exactMatch) {
-              return propValue == filter.value;
-            } else {
-              return propValue && propValue.toLowerCase().indexOf(filter.value.toLowerCase()) > -1;
-            }
-          }
-
-          return false;
-        });
-      });
-    }
-
-    return items;
-  },
-
-  updateFilters: function (property, filterValue, exactMatch) {
-    var addFilter = function () {
-      if (!filterValue) {
-        return;
-      }
-
-      this.get('filters').pushObject(Ember.Object.create({
-        property: property,
-        exactMatch: exactMatch,
-        min: filterValue.min,
-        max: filterValue.max,
-        value: filterValue
-      }));
-    };
-
-    var existentFilter = this.get('filters').find(function (filter) {
-      return filter.property === property;
-    });
-
-    if (existentFilter) {
-      if (filterValue) {
-        //remove and add again for triggering collection change thus avoiding to add observers on individual properties of a filter
-        this.get('filters').removeObject(existentFilter);
-        addFilter.apply(this);
-      } else {
-        //ensures removal of the filterValue when it's an empty string
-        this.set('filters', this.get('filters').without(existentFilter));
-      }
-    } else {
-       addFilter.apply(this);
-    }
-  },
-
-  clearFilters: function () {
-    var filters = this.get('filters');
-
-    if (!filters || filters.get('length')) {
-      this.set('filters', Ember.A());
-    }
-  },
-
-  actions: {
-    filter: function (property, filterValue) {
-      this.updateFilters(property, filterValue);
-    }
-  }
-});

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/mixins/sortable.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/mixins/sortable.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/mixins/sortable.js
deleted file mode 100644
index f766032..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/mixins/sortable.js
+++ /dev/null
@@ -1,31 +0,0 @@
-/**
- * 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.
- */
-
-import Ember from 'ember';
-
-export default Ember.SortableMixin.reopen({
-  sort: function (property) {
-    //if same column has been selected, toggle flag, else default it to true
-    if (this.get('sortProperties').objectAt(0) === property) {
-      this.set('sortAscending', !this.get('sortAscending'));
-    } else {
-      this.set('sortAscending', true);
-      this.set('sortProperties', [ property ]);
-    }
-  }
-});
\ No newline at end of file

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/models/.gitkeep
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/models/.gitkeep b/contrib/views/hive/src/main/resources/ui/hive-web/app/models/.gitkeep
deleted file mode 100644
index e69de29..0000000

http://git-wip-us.apache.org/repos/asf/ambari/blob/c0f9621f/contrib/views/hive/src/main/resources/ui/hive-web/app/models/database.js
----------------------------------------------------------------------
diff --git a/contrib/views/hive/src/main/resources/ui/hive-web/app/models/database.js b/contrib/views/hive/src/main/resources/ui/hive-web/app/models/database.js
deleted file mode 100644
index 11ee144..0000000
--- a/contrib/views/hive/src/main/resources/ui/hive-web/app/models/database.js
+++ /dev/null
@@ -1,25 +0,0 @@
-/**
- * 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.
- */
-
-import DS from 'ember-data';
-
-var Database = DS.Model.extend({
-  name: DS.attr()
-});
-
-export default Database;