diff --git a/conf/shiro.ini b/conf/shiro.ini.template similarity index 100% rename from conf/shiro.ini rename to conf/shiro.ini.template diff --git a/pom.xml b/pom.xml index efcf526f889..3ebc42976b4 100644 --- a/pom.xml +++ b/pom.xml @@ -32,6 +32,7 @@ smart-engine smart-server smart-rule + smart-interpreter smart-zeppelin smart-agent smart-hdfs diff --git a/smart-interpreter/pom.xml b/smart-interpreter/pom.xml new file mode 100644 index 00000000000..73b0173efec --- /dev/null +++ b/smart-interpreter/pom.xml @@ -0,0 +1,42 @@ + + + + + smartdata-project + org.smartdata + 1.0-SNAPSHOT + ../pom.xml + + 4.0.0 + + org.smartdata + smart-interpreter + 1.0-SNAPSHOT + jar + + + org.smartdata + smart-engine + 1.0-SNAPSHOT + + + Interpreter + + \ No newline at end of file diff --git a/smart-zeppelin/zeppelin-server/src/test/java/org/apache/zeppelin/display/AngularObjectBuilder.java b/smart-interpreter/src/main/java/org/smartdata/interpreter/SmartInterpreter.java similarity index 62% rename from smart-zeppelin/zeppelin-server/src/test/java/org/apache/zeppelin/display/AngularObjectBuilder.java rename to smart-interpreter/src/main/java/org/smartdata/interpreter/SmartInterpreter.java index a6aaae6d9c2..f9e565a3739 100644 --- a/smart-zeppelin/zeppelin-server/src/test/java/org/apache/zeppelin/display/AngularObjectBuilder.java +++ b/smart-interpreter/src/main/java/org/smartdata/interpreter/SmartInterpreter.java @@ -14,13 +14,26 @@ * See the License for the specific language governing permissions and * limitations under the License. */ +package org.smartdata.interpreter; -package org.apache.zeppelin.display; +import org.smartdata.server.SmartEngine; -public class AngularObjectBuilder { +import java.io.IOException; + +/** + * Created by zhiqiangx on 17-7-31. + */ +public abstract class SmartInterpreter { + private SmartEngine smartEngine; + + public SmartInterpreter(SmartEngine smartEngine) { + this.smartEngine = smartEngine; + } + + protected SmartEngine getSmartEngine() { + return smartEngine; + } + + public abstract String excute(String cmd) throws IOException; - public static AngularObject build(String varName, T value, String noteId, - String paragraphId) { - return new AngularObject<>(varName, value, noteId, paragraphId, null); - } } diff --git a/smart-zeppelin/zeppelin-server/src/test/scala/org/apache/zeppelin/WelcomePageSuite.scala b/smart-interpreter/src/main/java/org/smartdata/interpreter/impl/ActionInterpreter.java similarity index 60% rename from smart-zeppelin/zeppelin-server/src/test/scala/org/apache/zeppelin/WelcomePageSuite.scala rename to smart-interpreter/src/main/java/org/smartdata/interpreter/impl/ActionInterpreter.java index 1798214aecb..0e29efc3a1b 100644 --- a/smart-zeppelin/zeppelin-server/src/test/scala/org/apache/zeppelin/WelcomePageSuite.scala +++ b/smart-interpreter/src/main/java/org/smartdata/interpreter/impl/ActionInterpreter.java @@ -14,24 +14,22 @@ * See the License for the specific language governing permissions and * limitations under the License. */ +package org.smartdata.interpreter.impl; -package org.apache.zeppelin +import org.smartdata.interpreter.SmartInterpreter; +import org.smartdata.server.SmartEngine; -import org.openqa.selenium.WebDriver -import org.scalatest.concurrent.Eventually._ -import org.scalatest.time._ -import org.scalatest.selenium.WebBrowser -import org.scalatest.{DoNotDiscover, FunSuite} -import AbstractFunctionalSuite.SERVER_ADDRESS +import java.io.IOException; -@DoNotDiscover -class WelcomePageSuite(implicit driver: WebDriver) extends FunSuite with WebBrowser { +public class ActionInterpreter extends SmartInterpreter { - test("Welcome sign is correct") { - eventually (timeout(Span(180, Seconds))) { - go to SERVER_ADDRESS - assert(find("welcome").isDefined) + public ActionInterpreter(SmartEngine smartEngine) { + super(smartEngine); } - } + @Override + public String excute(String cmd) throws IOException { + getSmartEngine().getCmdletManager().submitCmdlet(cmd); + return "Success to add action"; + } } diff --git a/smart-interpreter/src/main/java/org/smartdata/interpreter/impl/RuleInterpreter.java b/smart-interpreter/src/main/java/org/smartdata/interpreter/impl/RuleInterpreter.java new file mode 100644 index 00000000000..bb23c394ebd --- /dev/null +++ b/smart-interpreter/src/main/java/org/smartdata/interpreter/impl/RuleInterpreter.java @@ -0,0 +1,39 @@ +/* + * Licensed to the Apache Software Foundation (ASF) under one or more + * contributor license agreements. See the NOTICE file distributed with + * this work for additional information regarding copyright ownership. + * The ASF licenses this file to You under the Apache License, Version 2.0 + * (the "License"); you may not use this file except in compliance with + * the License. You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT 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.smartdata.interpreter.impl; + +import org.smartdata.interpreter.SmartInterpreter; +import org.smartdata.model.RuleState; +import org.smartdata.server.SmartEngine; + +import java.io.IOException; + +/** + * Created by zhiqiangx on 17-7-31. + */ +public class RuleInterpreter extends SmartInterpreter { + + public RuleInterpreter(SmartEngine smartEngine) { + super(smartEngine); + } + + @Override + public String excute(String cmd) throws IOException { + long t =getSmartEngine().getRuleManager().submitRule(cmd, RuleState.DISABLED); + return "Success to add rule : " + t; + } +} diff --git a/smart-zeppelin/notebook/2BWJFTXKJ/note.json b/smart-zeppelin/notebook/2BWJFTXKJ/note.json deleted file mode 100644 index 7196dd0bd85..00000000000 --- a/smart-zeppelin/notebook/2BWJFTXKJ/note.json +++ /dev/null @@ -1,1309 +0,0 @@ -{ - "paragraphs": [ - { - "title": "Hello R", - "text": "%r\nfoo \u003c- TRUE\nprint(foo)\nbare \u003c- c(1, 2.5, 4)\nprint(bare)\ndouble \u003c- 15.0\nprint(double)", - "user": "anonymous", - "dateUpdated": "Jan 29, 2017 2:45:40 AM", - "config": { - "colWidth": 12.0, - "editorMode": "ace/mode/r", - "enabled": true, - "title": true, - "results": [ - { - "graph": { - "mode": "table", - "height": 84.64583587646484, - "optionOpen": false, - "keys": [], - "values": [], - "groups": [], - "scatter": {} - } - } - ], - "editorSetting": { - "language": "r", - "editOnDblClick": false - } - }, - "settings": { - "params": {}, - "forms": {} - }, - "results": { - "code": "SUCCESS", - "msg": [ - { - "type": "TEXT", - "data": "\n[1] TRUE\n[1] 1.0 2.5 4.0\n[1] 15\n\n\n\n" - } - ] - }, - "apps": [], - "jobName": "paragraph_1429882946244_-381648689", - "id": "20150424-154226_261270952", - "dateCreated": "Apr 24, 2015 3:42:26 AM", - "dateStarted": "Jan 29, 2017 2:42:27 AM", - "dateFinished": "Jan 29, 2017 2:42:40 AM", - "status": "FINISHED", - "progressUpdateIntervalMs": 500 - }, - { - "title": "Load R Librairies", - "text": "%r\nlibrary(data.table)\ndt \u003c- data.table(1:3)\nprint(dt)\nfor (i in 1:5) {\n print(i*2)\n}\nprint(1:50)", - "user": "anonymous", - "dateUpdated": "Jan 29, 2017 2:45:44 AM", - "config": { - "colWidth": 12.0, - "editorMode": "ace/mode/r", - "enabled": true, - "title": true, - "results": [ - { - "graph": { - "mode": "table", - "height": 193.33334350585938, - "optionOpen": false, - "keys": [], - "values": [], - "groups": [], - "scatter": {} - } - } - ], - "editorSetting": { - "language": "r", - "editOnDblClick": false - } - }, - "settings": { - "params": {}, - "forms": {} - }, - "results": { - "code": "SUCCESS", - "msg": [ - { - "type": "TEXT", - "data": "\nV1\n1: 1\n2: 2\n3: 3\n[1] 2\n[1] 4\n[1] 6\n[1] 8\n[1] 10\n [1] 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23\n[24] 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46\n[47] 47 48 49 50\n\n\n\n" - } - ] - }, - "apps": [], - "jobName": "paragraph_1429882976611_1352445253", - "id": "20150424-154256_645296307", - "dateCreated": "Apr 24, 2015 3:42:56 AM", - "dateStarted": "Jan 29, 2017 2:42:43 AM", - "dateFinished": "Jan 29, 2017 2:42:43 AM", - "status": "FINISHED", - "progressUpdateIntervalMs": 500 - }, - { - "text": "%md\n\n## Zeppelin SparkR Tutorial\n\n##### This is a live tutorial, you can run the code yourself. (Shift-Enter to Run)", - "user": "anonymous", - "dateUpdated": "Jan 29, 2017 3:17:08 AM", - "config": { - "colWidth": 12.0, - "enabled": true, - "results": {}, - "editorSetting": { - "language": "markdown", - "editOnDblClick": true - }, - "editorMode": "ace/mode/markdown", - "editorHide": true, - "tableHide": false - }, - "settings": { - "params": {}, - "forms": {} - }, - "results": { - "code": "SUCCESS", - "msg": [ - { - "type": "HTML", - "data": "\u003cdiv class\u003d\"markdown-body\"\u003e\n\u003ch2\u003eZeppelin SparkR Tutorial\u003c/h2\u003e\n\u003ch5\u003eThis is a live tutorial, you can run the code yourself. (Shift-Enter to Run)\u003c/h5\u003e\n\u003c/div\u003e" - } - ] - }, - "apps": [], - "jobName": "paragraph_1485571833509_-1037808822", - "id": "20170128-115033_693473992", - "dateCreated": "Jan 28, 2017 11:50:33 AM", - "dateStarted": "Jan 29, 2017 3:17:08 AM", - "dateFinished": "Jan 29, 2017 3:17:08 AM", - "status": "FINISHED", - "progressUpdateIntervalMs": 500 - }, - { - "title": "Load Iris Dataset", - "text": "%r\ncolnames(iris)\niris$Petal.Length\niris$Sepal.Length", - "user": "anonymous", - "dateUpdated": "Jan 29, 2017 2:45:47 AM", - "config": { - "colWidth": 12.0, - "enabled": true, - "editorMode": "ace/mode/r", - "title": true, - "results": [ - { - "graph": { - "mode": "table", - "height": 169.33334350585938, - "optionOpen": false, - "keys": [], - "values": [], - "groups": [], - "scatter": {} - } - } - ], - "editorSetting": { - "language": "r", - "editOnDblClick": false - } - }, - "settings": { - "params": {}, - "forms": {} - }, - "results": { - "code": "SUCCESS", - "msg": [ - { - "type": "TEXT", - "data": "\n[1] “Sepal.Length” “Sepal.Width” “Petal.Length” “Petal.Width” \n[5] “Species”\n [1] 1.4 1.4 1.3 1.5 1.4 1.7 1.4 1.5 1.4 1.5 1.5 1.6 1.4 1.1 1.2 1.5 1.3\n [18] 1.4 1.7 1.5 1.7 1.5 1.0 1.7 1.9 1.6 1.6 1.5 1.4 1.6 1.6 1.5 1.5 1.4\n [35] 1.5 1.2 1.3 1.4 1.3 1.5 1.3 1.3 1.3 1.6 1.9 1.4 1.6 1.4 1.5 1.4 4.7\n [52] 4.5 4.9 4.0 4.6 4.5 4.7 3.3 4.6 3.9 3.5 4.2 4.0 4.7 3.6 4.4 4.5 4.1\n [69] 4.5 3.9 4.8 4.0 4.9 4.7 4.3 4.4 4.8 5.0 4.5 3.5 3.8 3.7 3.9 5.1 4.5\n [86] 4.5 4.7 4.4 4.1 4.0 4.4 4.6 4.0 3.3 4.2 4.2 4.2 4.3 3.0 4.1 6.0 5.1\n[103] 5.9 5.6 5.8 6.6 4.5 6.3 5.8 6.1 5.1 5.3 5.5 5.0 5.1 5.3 5.5 6.7 6.9\n[120] 5.0 5.7 4.9 6.7 4.9 5.7 6.0 4.8 4.9 5.6 5.8 6.1 6.4 5.6 5.1 5.6 6.1\n[137] 5.6 5.5 4.8 5.4 5.6 5.1 5.1 5.9 5.7 5.2 5.0 5.2 5.4 5.1\n [1] 5.1 4.9 4.7 4.6 5.0 5.4 4.6 5.0 4.4 4.9 5.4 4.8 4.8 4.3 5.8 5.7 5.4\n [18] 5.1 5.7 5.1 5.4 5.1 4.6 5.1 4.8 5.0 5.0 5.2 5.2 4.7 4.8 5.4 5.2 5.5\n [35] 4.9 5.0 5.5 4.9 4.4 5.1 5.0 4.5 4.4 5.0 5.1 4.8 5.1 4.6 5.3 5.0 7.0\n [52] 6.4 6.9 5.5 6.5 5.7 6.3 4.9 6.6 5.2 5.0 5.9 6.0 6.1 5.6 6.7 5.6 5.8\n [69] 6.2 5.6 5.9 6.1 6.3 6.1 6.4 6.6 6.8 6.7 6.0 5.7 5.5 5.5 5.8 6.0 5.4\n [86] 6.0 6.7 6.3 5.6 5.5 5.5 6.1 5.8 5.0 5.6 5.7 5.7 6.2 5.1 5.7 6.3 5.8\n[103] 7.1 6.3 6.5 7.6 4.9 7.3 6.7 7.2 6.5 6.4 6.8 5.7 5.8 6.4 6.5 7.7 7.7\n[120] 6.0 6.9 5.6 7.7 6.3 6.7 7.2 6.2 6.1 6.4 7.2 7.4 7.9 6.4 6.3 6.1 7.7\n[137] 6.3 6.4 6.0 6.9 6.7 6.9 5.8 6.8 6.7 6.7 6.3 6.5 6.2 5.9\n\n\n\n" - } - ] - }, - "apps": [], - "jobName": "paragraph_1455138077044_161383897", - "id": "20160210-220117_115873183", - "dateCreated": "Feb 10, 2016 10:01:17 AM", - "dateStarted": "Jan 29, 2017 2:42:46 AM", - "dateFinished": "Jan 29, 2017 2:42:46 AM", - "status": "FINISHED", - "progressUpdateIntervalMs": 500 - }, - { - "title": "TABLE Display", - "text": "%r print(\"%table name\\tsize\\nsmall\\t100\\nlarge\\t1000\")", - "user": "anonymous", - "dateUpdated": "Jan 29, 2017 3:20:33 AM", - "config": { - "colWidth": 6.0, - "enabled": true, - "title": true, - "editorMode": "ace/mode/r", - "results": [ - { - "graph": { - "mode": "table", - "height": 408.6458435058594, - "optionOpen": false, - "keys": [ - { - "name": "name", - "index": 0.0, - "aggr": "sum" - } - ], - "values": [ - { - "name": "size", - "index": 1.0, - "aggr": "sum" - } - ], - "groups": [], - "scatter": { - "xAxis": { - "name": "name", - "index": 0.0, - "aggr": "sum" - }, - "yAxis": { - "name": "size", - "index": 1.0, - "aggr": "sum" - } - } - }, - "helium": {} - } - ], - "editorSetting": { - "language": "r", - "editOnDblClick": false - } - }, - "settings": { - "params": {}, - "forms": {} - }, - "results": { - "code": "SUCCESS", - "msg": [ - { - "type": "TABLE", - "data": "name\tsize\nsmall\t100\nlarge\t1000" - } - ] - }, - "apps": [], - "jobName": "paragraph_1456216582752_6855525", - "id": "20160223-093622_330111284", - "dateCreated": "Feb 23, 2016 9:36:22 AM", - "dateStarted": "Jan 29, 2017 2:42:50 AM", - "dateFinished": "Jan 29, 2017 2:42:50 AM", - "status": "FINISHED", - "progressUpdateIntervalMs": 500 - }, - { - "title": "HTML Display", - "text": "%r \n\nprint(\"%html \u003ch3\u003eHello HTML\u003c/h3\u003e\")\nprint(\"\u003cfont color\u003d\u0027blue\u0027\u003e\u003cspan class\u003d\u0027fa fa-bars\u0027\u003e Easy...\u003c/font\u003e\u003c/span\u003e\")\nfor (i in 1:10) {\n print(paste0(\"\u003ch4\u003e\", i, \" * 2 \u003d \", i*2, \"\u003c/h4\u003e\"))\n}", - "user": "anonymous", - "dateUpdated": "Jan 29, 2017 2:52:20 AM", - "config": { - "colWidth": 6.0, - "enabled": true, - "editorMode": "ace/mode/r", - "title": true, - "results": [ - { - "graph": { - "mode": "table", - "height": 361.66668701171875, - "optionOpen": false, - "keys": [], - "values": [], - "groups": [], - "scatter": {} - } - } - ], - "editorSetting": { - "language": "r", - "editOnDblClick": false - } - }, - "settings": { - "params": {}, - "forms": {} - }, - "results": { - "code": "SUCCESS", - "msg": [ - { - "type": "HTML", - "data": "\u003cp\u003e\u003c/p\u003e\u003ch3\u003eHello HTML\u003c/h3\u003e\u003cfont color\u003d\"blue\"\u003e\u003cspan class\u003d\"fa fa-bars\"\u003e Easy…\u003c/span\u003e\u003c/font\u003e\u003ch4\u003e1 * 2 \u003d 2\u003c/h4\u003e\u003ch4\u003e2 * 2 \u003d 4\u003c/h4\u003e\u003ch4\u003e3 * 2 \u003d 6\u003c/h4\u003e\u003ch4\u003e4 * 2 \u003d 8\u003c/h4\u003e\u003ch4\u003e5 * 2 \u003d 10\u003c/h4\u003e\u003ch4\u003e6 * 2 \u003d 12\u003c/h4\u003e\u003ch4\u003e7 * 2 \u003d 14\u003c/h4\u003e\u003ch4\u003e8 * 2 \u003d 16\u003c/h4\u003e\u003ch4\u003e9 * 2 \u003d 18\u003c/h4\u003e\u003ch4\u003e10 * 2 \u003d 20\u003c/h4\u003e\u003cp\u003e\u003c/p\u003e" - } - ] - }, - "apps": [], - "jobName": "paragraph_1456140102445_51059930", - "id": "20160222-122142_1323614681", - "dateCreated": "Feb 22, 2016 12:21:42 PM", - "dateStarted": "Jan 29, 2017 2:42:48 AM", - "dateFinished": "Jan 29, 2017 2:42:48 AM", - "status": "FINISHED", - "progressUpdateIntervalMs": 500 - }, - { - "title": "Write Scala To R", - "text": "%spark\nval s \u003d \"Hello R from Scala\"\nz.put(\"s\", s)\nval b \u003d new Integer(42)\nz.put(\"b\", b)\nval a: Array[Double] \u003d Array[Double](30.1, 20.0)\nz.put(\"a\", a)\nval m \u003d Array(Array(1, 4), Array(8, 16))\nz.put(\"m\", m)\nval v \u003d Vector(1, 2, 3, 4)\nz.put(\"v\", v)", - "user": "anonymous", - "dateUpdated": "Jan 29, 2017 2:52:50 AM", - "config": { - "colWidth": 3.0, - "editorMode": "ace/mode/scala", - "enabled": true, - "title": true, - "results": [ - { - "graph": { - "mode": "table", - "height": 91.3125, - "optionOpen": false, - "keys": [], - "values": [], - "groups": [], - "scatter": {} - } - } - ], - "editorSetting": { - "language": "scala", - "editOnDblClick": false - }, - "editorHide": false, - "tableHide": false - }, - "settings": { - "params": {}, - "forms": {} - }, - "results": { - "code": "SUCCESS", - "msg": [ - { - "type": "TEXT", - "data": "\ns: String \u003d Hello R from Scala\n\nb: Integer \u003d 42\n\na: Array[Double] \u003d Array(30.1, 20.0)\n\nm: Array[Array[Int]] \u003d Array(Array(1, 4), Array(8, 16))\n\nv: scala.collection.immutable.Vector[Int] \u003d Vector(1, 2, 3, 4)\n" - } - ] - }, - "apps": [], - "jobName": "paragraph_1429862281402_-79250404", - "id": "20150424-095801_125725189", - "dateCreated": "Apr 24, 2015 9:58:01 AM", - "dateStarted": "Jan 29, 2017 2:43:19 AM", - "dateFinished": "Jan 29, 2017 2:43:21 AM", - "status": "FINISHED", - "progressUpdateIntervalMs": 500 - }, - { - "title": "Read from R the Scala Variables", - "text": "%r\nz.get(\"s\")\nz.get(\"b\")\nprint(unlist(z.get(\"a\")))\nprint(unlist(z.get(\"m\")))\nz.get(\"v\")", - "user": "anonymous", - "dateUpdated": "Jan 29, 2017 2:52:53 AM", - "config": { - "colWidth": 3.0, - "editorMode": "ace/mode/r", - "enabled": true, - "title": true, - "results": [ - { - "graph": { - "mode": "table", - "height": 86.64583587646484, - "optionOpen": false, - "keys": [], - "values": [], - "groups": [], - "scatter": {} - } - } - ], - "editorSetting": { - "language": "r", - "editOnDblClick": false - }, - "editorHide": false - }, - "settings": { - "params": {}, - "forms": {} - }, - "results": { - "code": "SUCCESS", - "msg": [ - { - "type": "TEXT", - "data": "\n[1] “Hello R from Scala”\n[1] 42\n[1] 30.1 20.0\n[1] 1 4 8 16\nJava ref type scala.collection.immutable.Vector id 97 \n\n\n\n" - } - ] - }, - "apps": [], - "jobName": "paragraph_1438930802740_-1781296534", - "id": "20150807-090002_1514685133", - "dateCreated": "Aug 7, 2015 9:00:02 AM", - "dateStarted": "Jan 29, 2017 2:51:36 AM", - "dateFinished": "Jan 29, 2017 2:51:36 AM", - "status": "FINISHED", - "progressUpdateIntervalMs": 500 - }, - { - "title": "Write R to Scala", - "text": "%r\ns \u003c- \"Hello Scala from R\"\nprint(s)\nz.put(\"rs\", s)\nb \u003c- TRUE\nprint(b)\nz.put(\"rb\", b)\nd \u003c- 15.0\nprint(d)\nz.put(\"rd\", d)\nm \u003c- c(2.4, 2.5, 4)\nprint(m)\nz.put(\"rm\", m)", - "user": "anonymous", - "dateUpdated": "Jan 29, 2017 2:52:55 AM", - "config": { - "colWidth": 3.0, - "enabled": true, - "editorMode": "ace/mode/r", - "title": true, - "results": [ - { - "graph": { - "mode": "table", - "height": 92.58333587646484, - "optionOpen": false, - "keys": [], - "values": [], - "groups": [], - "scatter": {} - } - } - ], - "editorSetting": { - "language": "r", - "editOnDblClick": false - }, - "editorHide": false - }, - "settings": { - "params": {}, - "forms": {} - }, - "results": { - "code": "SUCCESS", - "msg": [ - { - "type": "TEXT", - "data": "\n[1] “Hello Scala from R”\nNULL\n[1] TRUE\nNULL\n[1] 15\nNULL\n[1] 2.4 2.5 4.0\nNULL\n\n\n\n" - } - ] - }, - "apps": [], - "jobName": "paragraph_1455137934157_-1786381957", - "id": "20160210-215854_620520530", - "dateCreated": "Feb 10, 2016 9:58:54 AM", - "dateStarted": "Jan 29, 2017 2:43:28 AM", - "dateFinished": "Jan 29, 2017 2:43:28 AM", - "status": "FINISHED", - "progressUpdateIntervalMs": 500 - }, - { - "title": "Read from Scala the R Variables", - "text": "%spark\nprintln(\"rs \u003d \"+ z.get(\"rs\"))\nprintln(\"rb \u003d \"+ z.get(\"rb\"))\nprintln(\"rd \u003d \"+ z.get(\"rd\"))\nprintln(\"rm \u003d \"+ z.get(\"rm\"))\n// println(z.get(\"rm\").getClass)\n// println(\"rm \u003d \"+ z.get(\"rm\").asInstanceOf[Array[Double]].toSeq)", - "user": "anonymous", - "dateUpdated": "Jan 29, 2017 2:52:58 AM", - "config": { - "colWidth": 3.0, - "enabled": true, - "editorMode": "ace/mode/scala", - "title": true, - "results": [ - { - "graph": { - "mode": "table", - "height": 90.64583587646484, - "optionOpen": false, - "keys": [], - "values": [], - "groups": [], - "scatter": {} - } - } - ], - "editorSetting": { - "language": "scala", - "editOnDblClick": false - }, - "editorHide": false, - "tableHide": false - }, - "settings": { - "params": {}, - "forms": {} - }, - "results": { - "code": "SUCCESS", - "msg": [ - { - "type": "TEXT", - "data": "rs \u003d Hello Scala from R\nrb \u003d true\nrd \u003d 15.0\nrm \u003d 2.4\n" - } - ] - }, - "apps": [], - "jobName": "paragraph_1455138066039_1048230112", - "id": "20160210-220106_141884849", - "dateCreated": "Feb 10, 2016 10:01:06 AM", - "dateStarted": "Jan 29, 2017 2:43:35 AM", - "dateFinished": "Jan 29, 2017 2:43:35 AM", - "status": "FINISHED", - "progressUpdateIntervalMs": 500 - }, - { - "title": "Create a Spark Dataframe", - "text": "%spark\nimport org.apache.commons.io.IOUtils\nimport java.net.URL\nimport java.nio.charset.Charset\n\nval bankText \u003d sc.parallelize(\n IOUtils.toString(\n new URL(\"https://s3.amazonaws.com/apache-zeppelin/tutorial/bank/bank.csv\"),\n Charset.forName(\"utf8\")).split(\"\\n\"))\n\ncase class Bank(age: Integer, job: String, marital: String, education: String, balance: Integer)\n\nval bank \u003d bankText.map(s \u003d\u003e s.split(\";\")).filter(s \u003d\u003e s(0) !\u003d \"\\\"age\\\"\").map(\n s \u003d\u003e Bank(s(0).toInt, \n s(1).replaceAll(\"\\\"\", \"\"),\n s(2).replaceAll(\"\\\"\", \"\"),\n s(3).replaceAll(\"\\\"\", \"\"),\n s(5).replaceAll(\"\\\"\", \"\").toInt\n )\n).toDF()\nbank.registerTempTable(\"bank\")", - "user": "anonymous", - "dateUpdated": "Jan 29, 2017 2:46:25 AM", - "config": { - "colWidth": 6.0, - "enabled": true, - "lineNumbers": false, - "title": true, - "results": [ - { - "graph": { - "mode": "table", - "height": 91.27083587646484, - "optionOpen": false, - "keys": [], - "values": [], - "groups": [], - "scatter": {} - } - } - ], - "editorSetting": { - "language": "scala", - "editOnDblClick": false - }, - "editorMode": "ace/mode/scala", - "editorHide": false, - "tableHide": false - }, - "settings": { - "params": {}, - "forms": {} - }, - "results": { - "code": "SUCCESS", - "msg": [ - { - "type": "TEXT", - "data": "\nimport org.apache.commons.io.IOUtils\n\nimport java.net.URL\n\nimport java.nio.charset.Charset\n\nbankText: org.apache.spark.rdd.RDD[String] \u003d ParallelCollectionRDD[0] at parallelize at \u003cconsole\u003e:32\n\ndefined class Bank\n\nbank: org.apache.spark.sql.DataFrame \u003d [age: int, job: string, marital: string, education: string, balance: int]\n" - } - ] - }, - "apps": [], - "jobName": "paragraph_1455142039343_-233762796", - "id": "20160210-230719_2111095838", - "dateCreated": "Feb 10, 2016 11:07:19 AM", - "dateStarted": "Jan 29, 2017 2:43:40 AM", - "dateFinished": "Jan 29, 2017 2:43:45 AM", - "status": "FINISHED", - "progressUpdateIntervalMs": 500 - }, - { - "title": "Read the Spark Dataframe from R", - "text": "%r\n\ndf \u003c- sql(sqlContext, \"select count(*) from bank\")\nprintSchema(df)\nSparkR::head(df)", - "user": "anonymous", - "dateUpdated": "Jan 29, 2017 2:43:46 AM", - "config": { - "colWidth": 6.0, - "enabled": true, - "editorMode": "ace/mode/r", - "tableHide": false, - "title": true, - "results": [ - { - "graph": { - "mode": "table", - "height": 110.64583587646484, - "optionOpen": false, - "keys": [], - "values": [], - "groups": [], - "scatter": {} - } - } - ], - "editorSetting": { - "language": "r", - "editOnDblClick": false - } - }, - "settings": { - "params": {}, - "forms": {} - }, - "results": { - "code": "SUCCESS", - "msg": [ - { - "type": "TEXT", - "data": "\nroot\n |– _c0: long (nullable \u003d false)\n _c0\n1 4521\n\n\n\n" - } - ] - }, - "apps": [], - "jobName": "paragraph_1455142043062_1598026718", - "id": "20160210-230723_1811469598", - "dateCreated": "Feb 10, 2016 11:07:23 AM", - "dateStarted": "Jan 29, 2017 2:43:47 AM", - "dateFinished": "Jan 29, 2017 2:43:49 AM", - "status": "FINISHED", - "progressUpdateIntervalMs": 500 - }, - { - "title": "Query with Spark Dataframe with SQL", - "text": "%sql select count(*) as count from bank", - "user": "anonymous", - "dateUpdated": "Jan 29, 2017 2:47:05 AM", - "config": { - "colWidth": 6.0, - "enabled": true, - "editorMode": "ace/mode/sql", - "title": true, - "results": [ - { - "graph": { - "mode": "table", - "height": 126.25, - "optionOpen": true, - "keys": [], - "values": [], - "groups": [], - "scatter": {} - }, - "helium": {} - } - ], - "editorSetting": { - "language": "sql", - "editOnDblClick": false - } - }, - "settings": { - "params": {}, - "forms": {} - }, - "results": { - "code": "SUCCESS", - "msg": [ - { - "type": "TABLE", - "data": "count\n4521\n" - } - ] - }, - "apps": [], - "jobName": "paragraph_1455142050697_-1353382095", - "id": "20160210-230730_1259663883", - "dateCreated": "Feb 10, 2016 11:07:30 AM", - "dateStarted": "Jan 29, 2017 2:43:55 AM", - "dateFinished": "Jan 29, 2017 2:43:55 AM", - "status": "FINISHED", - "progressUpdateIntervalMs": 500 - }, - { - "title": "Create a R Dataframe", - "text": "%r \n\nlocalNames \u003c- data.frame(name\u003dc(\"John\", \"Smith\", \"Sarah\"), budget\u003dc(19, 53, 18))\nnames \u003c- createDataFrame(sqlContext, localNames)\nprintSchema(names)\nregisterTempTable(names, \"names\")\n\n# SparkR::head(names)", - "user": "anonymous", - "dateUpdated": "Jan 29, 2017 3:19:59 AM", - "config": { - "colWidth": 12.0, - "enabled": true, - "title": true, - "editorMode": "ace/mode/r", - "results": [ - { - "graph": { - "mode": "table", - "height": 84.64583587646484, - "optionOpen": false, - "keys": [], - "values": [], - "groups": [], - "scatter": {} - } - } - ], - "editorSetting": { - "language": "r", - "editOnDblClick": false - }, - "editorHide": false - }, - "settings": { - "params": {}, - "forms": {} - }, - "results": { - "code": "SUCCESS", - "msg": [ - { - "type": "TEXT", - "data": "\nroot\n |– name: string (nullable \u003d true)\n |– budget: double (nullable \u003d true)\n\n\n\n" - } - ] - }, - "apps": [], - "jobName": "paragraph_1455142112413_519883679", - "id": "20160210-230832_1847721959", - "dateCreated": "Feb 10, 2016 11:08:32 AM", - "dateStarted": "Jan 29, 2017 2:43:58 AM", - "dateFinished": "Jan 29, 2017 2:43:58 AM", - "status": "FINISHED", - "progressUpdateIntervalMs": 500 - }, - { - "title": "Read the R Dataframe from Spark", - "text": "sqlc.sql(\"select * from names\").head", - "user": "anonymous", - "dateUpdated": "Jan 29, 2017 2:47:18 AM", - "config": { - "colWidth": 12.0, - "enabled": true, - "editorMode": "ace/mode/scala", - "title": true, - "results": [ - { - "graph": { - "mode": "table", - "height": 92.64583587646484, - "optionOpen": false, - "keys": [], - "values": [], - "groups": [], - "scatter": {} - } - } - ], - "editorSetting": { - "language": "scala", - "editOnDblClick": true - }, - "editorHide": false, - "tableHide": false - }, - "settings": { - "params": {}, - "forms": {} - }, - "results": { - "code": "SUCCESS", - "msg": [ - { - "type": "TEXT", - "data": "\nres11: org.apache.spark.sql.Row \u003d [John,19.0]\n" - } - ] - }, - "apps": [], - "jobName": "paragraph_1455188357108_95477841", - "id": "20160211-115917_445850505", - "dateCreated": "Feb 11, 2016 11:59:17 AM", - "dateStarted": "Jan 29, 2017 2:44:08 AM", - "dateFinished": "Jan 29, 2017 2:44:09 AM", - "status": "FINISHED", - "progressUpdateIntervalMs": 500 - }, - { - "title": "Query the R Datafame with SQL", - "text": "%sql select * from names\n", - "user": "anonymous", - "dateUpdated": "Jan 29, 2017 2:47:29 AM", - "config": { - "colWidth": 12.0, - "enabled": true, - "editorMode": "ace/mode/sql", - "title": true, - "results": [ - { - "graph": { - "mode": "pieChart", - "height": 263.3125, - "optionOpen": false, - "keys": [ - { - "name": "name", - "index": 0.0, - "aggr": "sum" - } - ], - "values": [ - { - "name": "budget", - "index": 1.0, - "aggr": "sum" - } - ], - "groups": [], - "scatter": { - "xAxis": { - "name": "name", - "index": 0.0, - "aggr": "sum" - } - }, - "setting": { - "multiBarChart": {} - }, - "commonSetting": {} - }, - "helium": {} - } - ], - "editorSetting": { - "language": "sql", - "editOnDblClick": false - } - }, - "settings": { - "params": {}, - "forms": {} - }, - "results": { - "code": "SUCCESS", - "msg": [ - { - "type": "TABLE", - "data": "name\tbudget\nJohn\t19.0\nSmith\t53.0\nSarah\t18.0\n" - } - ] - }, - "apps": [], - "jobName": "paragraph_1455142115582_-1840950897", - "id": "20160210-230835_19876971", - "dateCreated": "Feb 10, 2016 11:08:35 AM", - "dateStarted": "Jan 29, 2017 2:44:11 AM", - "dateFinished": "Jan 29, 2017 2:44:11 AM", - "status": "FINISHED", - "progressUpdateIntervalMs": 500 - }, - { - "title": "GoogleVis: Bar Chart", - "text": "%r\nlibrary(googleVis)\ndf\u003ddata.frame(country\u003dc(\"US\", \"GB\", \"BR\"), \n val1\u003dc(10,13,14), \n val2\u003dc(23,12,32))\nBar \u003c- gvisBarChart(df)\nprint(Bar, tag \u003d \u0027chart\u0027)\n", - "user": "anonymous", - "dateUpdated": "Jan 29, 2017 3:16:38 AM", - "config": { - "colWidth": 4.0, - "enabled": true, - "results": { - "0": { - "graph": { - "mode": "table", - "height": 300.0, - "optionOpen": false - } - } - }, - "editorSetting": { - "language": "r", - "editOnDblClick": false - }, - "editorMode": "ace/mode/r", - "editorHide": false, - "tableHide": false, - "title": true - }, - "settings": { - "params": {}, - "forms": {} - }, - "results": { - "code": "SUCCESS", - "msg": [ - { - "type": "HTML", - "data": "\n\u003c!-- BarChart generated in R 3.3.2 by googleVis 0.6.2 package --\u003e\n\n\u003c!-- Sun Jan 29 03:11:34 2017 --\u003e\n\n\u003c!-- jsHeader --\u003e\n\n\u003cscript type\u003d\"text/javascript\"\u003e\n \n// jsData \nfunction gvisDataBarChartID17e4878cf808c () {\nvar data \u003d new google.visualization.DataTable();\nvar datajson \u003d\n[\n [\n\"US\",\n10,\n23\n],\n[\n\"GB\",\n13,\n12\n],\n[\n\"BR\",\n14,\n32\n] \n];\ndata.addColumn(\u0027string\u0027,\u0027country\u0027);\ndata.addColumn(\u0027number\u0027,\u0027val1\u0027);\ndata.addColumn(\u0027number\u0027,\u0027val2\u0027);\ndata.addRows(datajson);\nreturn(data);\n}\n \n// jsDrawChart\nfunction drawChartBarChartID17e4878cf808c() {\nvar data \u003d gvisDataBarChartID17e4878cf808c();\nvar options \u003d {};\noptions[\"allowHtml\"] \u003d true;\n\n var chart \u003d new google.visualization.BarChart(\n document.getElementById(\u0027BarChartID17e4878cf808c\u0027)\n );\n chart.draw(data,options);\n \n\n}\n \n \n// jsDisplayChart\n(function() {\nvar pkgs \u003d window.__gvisPackages \u003d window.__gvisPackages || [];\nvar callbacks \u003d window.__gvisCallbacks \u003d window.__gvisCallbacks || [];\nvar chartid \u003d \"corechart\";\n \n// Manually see if chartid is in pkgs (not all browsers support Array.indexOf)\nvar i, newPackage \u003d true;\nfor (i \u003d 0; newPackage \u0026\u0026 i \u003c pkgs.length; i++) {\nif (pkgs[i] \u003d\u003d\u003d chartid)\nnewPackage \u003d false;\n}\nif (newPackage)\n pkgs.push(chartid);\n \n// Add the drawChart function to the global list of callbacks\ncallbacks.push(drawChartBarChartID17e4878cf808c);\n})();\nfunction displayChartBarChartID17e4878cf808c() {\n var pkgs \u003d window.__gvisPackages \u003d window.__gvisPackages || [];\n var callbacks \u003d window.__gvisCallbacks \u003d window.__gvisCallbacks || [];\n window.clearTimeout(window.__gvisLoad);\n // The timeout is set to 100 because otherwise the container div we are\n // targeting might not be part of the document yet\n window.__gvisLoad \u003d setTimeout(function() {\n var pkgCount \u003d pkgs.length;\n google.load(\"visualization\", \"1\", { packages:pkgs, callback: function() {\n if (pkgCount !\u003d pkgs.length) {\n // Race condition where another setTimeout call snuck in after us; if\n // that call added a package, we must not shift its callback\n return;\n}\nwhile (callbacks.length \u003e 0)\ncallbacks.shift()();\n} });\n}, 100);\n}\n \n// jsFooter\n\u003c/script\u003e\n \n\n\u003c!-- jsChart --\u003e \n\n\u003cscript type\u003d\"text/javascript\" src\u003d\"https://www.google.com/jsapi?callback\u003ddisplayChartBarChartID17e4878cf808c\"\u003e\u003c/script\u003e\n \n\n\u003c!-- divChart --\u003e\n\n\u003cdiv id\u003d\"BarChartID17e4878cf808c\" style\u003d\"width: 500; height: automatic;\"\u003e\n\u003c/div\u003e\n\n\n\n" - } - ] - }, - "apps": [], - "jobName": "paragraph_1485626417184_-1153542135", - "id": "20170129-030017_426747323", - "dateCreated": "Jan 29, 2017 3:00:17 AM", - "dateStarted": "Jan 29, 2017 3:11:33 AM", - "dateFinished": "Jan 29, 2017 3:11:34 AM", - "status": "FINISHED", - "progressUpdateIntervalMs": 500 - }, - { - "title": "GoogleVis: Candlestick Chart", - "text": "%r\nlibrary(googleVis)\n\nCandle \u003c- gvisCandlestickChart(OpenClose, \n options\u003dlist(legend\u003d\u0027none\u0027))\n\nprint(Candle, tag \u003d \u0027chart\u0027)", - "user": "anonymous", - "dateUpdated": "Jan 29, 2017 3:16:35 AM", - "config": { - "colWidth": 4.0, - "enabled": true, - "results": { - "0": { - "graph": { - "mode": "table", - "height": 84.64583587646484, - "optionOpen": false - } - } - }, - "editorSetting": { - "language": "r", - "editOnDblClick": true - }, - "editorMode": "ace/mode/r", - "editorHide": false, - "tableHide": false, - "title": true - }, - "settings": { - "params": {}, - "forms": {} - }, - "results": { - "code": "SUCCESS", - "msg": [ - { - "type": "HTML", - "data": "\n\u003c!-- CandlestickChart generated in R 3.3.2 by googleVis 0.6.2 package --\u003e\n\n\u003c!-- Sun Jan 29 03:16:15 2017 --\u003e\n\n\u003c!-- jsHeader --\u003e\n\n\u003cscript type\u003d\"text/javascript\"\u003e\n \n// jsData \nfunction gvisDataCandlestickChartID17e4862e18e15 () {\nvar data \u003d new google.visualization.DataTable();\nvar datajson \u003d\n[\n [\n\"Mon\",\n20,\n28,\n38,\n45\n],\n[\n\"Tues\",\n31,\n38,\n55,\n66\n],\n[\n\"Wed\",\n50,\n55,\n77,\n80\n],\n[\n\"Thurs\",\n50,\n77,\n66,\n77\n],\n[\n\"Fri\",\n15,\n66,\n22,\n68\n] \n];\ndata.addColumn(\u0027string\u0027,\u0027Weekday\u0027);\ndata.addColumn(\u0027number\u0027,\u0027Low\u0027);\ndata.addColumn(\u0027number\u0027,\u0027Open\u0027);\ndata.addColumn(\u0027number\u0027,\u0027Close\u0027);\ndata.addColumn(\u0027number\u0027,\u0027High\u0027);\ndata.addRows(datajson);\nreturn(data);\n}\n \n// jsDrawChart\nfunction drawChartCandlestickChartID17e4862e18e15() {\nvar data \u003d gvisDataCandlestickChartID17e4862e18e15();\nvar options \u003d {};\noptions[\"allowHtml\"] \u003d true;\noptions[\"legend\"] \u003d \"none\";\n\n var chart \u003d new google.visualization.CandlestickChart(\n document.getElementById(\u0027CandlestickChartID17e4862e18e15\u0027)\n );\n chart.draw(data,options);\n \n\n}\n \n \n// jsDisplayChart\n(function() {\nvar pkgs \u003d window.__gvisPackages \u003d window.__gvisPackages || [];\nvar callbacks \u003d window.__gvisCallbacks \u003d window.__gvisCallbacks || [];\nvar chartid \u003d \"corechart\";\n \n// Manually see if chartid is in pkgs (not all browsers support Array.indexOf)\nvar i, newPackage \u003d true;\nfor (i \u003d 0; newPackage \u0026\u0026 i \u003c pkgs.length; i++) {\nif (pkgs[i] \u003d\u003d\u003d chartid)\nnewPackage \u003d false;\n}\nif (newPackage)\n pkgs.push(chartid);\n \n// Add the drawChart function to the global list of callbacks\ncallbacks.push(drawChartCandlestickChartID17e4862e18e15);\n})();\nfunction displayChartCandlestickChartID17e4862e18e15() {\n var pkgs \u003d window.__gvisPackages \u003d window.__gvisPackages || [];\n var callbacks \u003d window.__gvisCallbacks \u003d window.__gvisCallbacks || [];\n window.clearTimeout(window.__gvisLoad);\n // The timeout is set to 100 because otherwise the container div we are\n // targeting might not be part of the document yet\n window.__gvisLoad \u003d setTimeout(function() {\n var pkgCount \u003d pkgs.length;\n google.load(\"visualization\", \"1\", { packages:pkgs, callback: function() {\n if (pkgCount !\u003d pkgs.length) {\n // Race condition where another setTimeout call snuck in after us; if\n // that call added a package, we must not shift its callback\n return;\n}\nwhile (callbacks.length \u003e 0)\ncallbacks.shift()();\n} });\n}, 100);\n}\n \n// jsFooter\n\u003c/script\u003e\n \n\n\u003c!-- jsChart --\u003e \n\n\u003cscript type\u003d\"text/javascript\" src\u003d\"https://www.google.com/jsapi?callback\u003ddisplayChartCandlestickChartID17e4862e18e15\"\u003e\u003c/script\u003e\n \n\n\u003c!-- divChart --\u003e\n\n\u003cdiv id\u003d\"CandlestickChartID17e4862e18e15\" style\u003d\"width: 500; height: automatic;\"\u003e\n\u003c/div\u003e\n\n\n\n" - } - ] - }, - "apps": [], - "jobName": "paragraph_1485627113560_-130863711", - "id": "20170129-031153_758721410", - "dateCreated": "Jan 29, 2017 3:11:53 AM", - "dateStarted": "Jan 29, 2017 3:16:15 AM", - "dateFinished": "Jan 29, 2017 3:16:15 AM", - "status": "FINISHED", - "progressUpdateIntervalMs": 500 - }, - { - "title": "GoogleVis: Line chart", - "text": "%r\nlibrary(googleVis)\ndf\u003ddata.frame(country\u003dc(\"US\", \"GB\", \"BR\"), \n val1\u003dc(10,13,14), \n val2\u003dc(23,12,32))\n\nLine \u003c- gvisLineChart(df)\n\nprint(Line, tag \u003d \u0027chart\u0027)\n", - "user": "anonymous", - "dateUpdated": "Jan 29, 2017 3:17:31 AM", - "config": { - "colWidth": 4.0, - "enabled": true, - "editorMode": "ace/mode/r", - "results": [ - { - "graph": { - "mode": "table", - "height": 61.458335876464844, - "optionOpen": false - } - } - ], - "editorSetting": { - "language": "r", - "editOnDblClick": true - }, - "editorHide": false, - "tableHide": false, - "title": true - }, - "settings": { - "params": {}, - "forms": {} - }, - "results": { - "code": "SUCCESS", - "msg": [ - { - "type": "HTML", - "data": "\n\u003c!-- LineChart generated in R 3.3.2 by googleVis 0.6.2 package --\u003e\n\n\u003c!-- Sun Jan 29 03:17:08 2017 --\u003e\n\n\u003c!-- jsHeader --\u003e\n\n\u003cscript type\u003d\"text/javascript\"\u003e\n \n// jsData \nfunction gvisDataLineChartID17e4818619a5d () {\nvar data \u003d new google.visualization.DataTable();\nvar datajson \u003d\n[\n [\n\"US\",\n10,\n23\n],\n[\n\"GB\",\n13,\n12\n],\n[\n\"BR\",\n14,\n32\n] \n];\ndata.addColumn(\u0027string\u0027,\u0027country\u0027);\ndata.addColumn(\u0027number\u0027,\u0027val1\u0027);\ndata.addColumn(\u0027number\u0027,\u0027val2\u0027);\ndata.addRows(datajson);\nreturn(data);\n}\n \n// jsDrawChart\nfunction drawChartLineChartID17e4818619a5d() {\nvar data \u003d gvisDataLineChartID17e4818619a5d();\nvar options \u003d {};\noptions[\"allowHtml\"] \u003d true;\n\n var chart \u003d new google.visualization.LineChart(\n document.getElementById(\u0027LineChartID17e4818619a5d\u0027)\n );\n chart.draw(data,options);\n \n\n}\n \n \n// jsDisplayChart\n(function() {\nvar pkgs \u003d window.__gvisPackages \u003d window.__gvisPackages || [];\nvar callbacks \u003d window.__gvisCallbacks \u003d window.__gvisCallbacks || [];\nvar chartid \u003d \"corechart\";\n \n// Manually see if chartid is in pkgs (not all browsers support Array.indexOf)\nvar i, newPackage \u003d true;\nfor (i \u003d 0; newPackage \u0026\u0026 i \u003c pkgs.length; i++) {\nif (pkgs[i] \u003d\u003d\u003d chartid)\nnewPackage \u003d false;\n}\nif (newPackage)\n pkgs.push(chartid);\n \n// Add the drawChart function to the global list of callbacks\ncallbacks.push(drawChartLineChartID17e4818619a5d);\n})();\nfunction displayChartLineChartID17e4818619a5d() {\n var pkgs \u003d window.__gvisPackages \u003d window.__gvisPackages || [];\n var callbacks \u003d window.__gvisCallbacks \u003d window.__gvisCallbacks || [];\n window.clearTimeout(window.__gvisLoad);\n // The timeout is set to 100 because otherwise the container div we are\n // targeting might not be part of the document yet\n window.__gvisLoad \u003d setTimeout(function() {\n var pkgCount \u003d pkgs.length;\n google.load(\"visualization\", \"1\", { packages:pkgs, callback: function() {\n if (pkgCount !\u003d pkgs.length) {\n // Race condition where another setTimeout call snuck in after us; if\n // that call added a package, we must not shift its callback\n return;\n}\nwhile (callbacks.length \u003e 0)\ncallbacks.shift()();\n} });\n}, 100);\n}\n \n// jsFooter\n\u003c/script\u003e\n \n\n\u003c!-- jsChart --\u003e \n\n\u003cscript type\u003d\"text/javascript\" src\u003d\"https://www.google.com/jsapi?callback\u003ddisplayChartLineChartID17e4818619a5d\"\u003e\u003c/script\u003e\n \n\n\u003c!-- divChart --\u003e\n\n\u003cdiv id\u003d\"LineChartID17e4818619a5d\" style\u003d\"width: 500; height: automatic;\"\u003e\n\u003c/div\u003e\n\n\n\n" - } - ] - }, - "apps": [], - "jobName": "paragraph_1455138857313_92355963", - "id": "20160210-221417_1400405266", - "dateCreated": "Feb 10, 2016 10:14:17 AM", - "dateStarted": "Jan 29, 2017 3:17:08 AM", - "dateFinished": "Jan 29, 2017 3:17:08 AM", - "status": "FINISHED", - "progressUpdateIntervalMs": 500 - }, - { - "text": "%r pairs(iris)", - "user": "anonymous", - "dateUpdated": "Jan 29, 2017 2:58:27 AM", - "config": { - "colWidth": 4.0, - "enabled": true, - "editorMode": "ace/mode/r", - "results": [ - { - "graph": { - "mode": "table", - "height": 1857.0, - "optionOpen": false, - "keys": [], - "values": [], - "groups": [], - "scatter": {} - } - } - ], - "editorSetting": { - "language": "r", - "editOnDblClick": false - } - }, - "settings": { - "params": {}, - "forms": {} - }, - "results": { - "code": "SUCCESS", - "msg": [ - { - "type": "HTML", - "data": "\u003cp\u003e\u003cimg src\u003d\"\" alt\u003d\"plot of chunk unnamed-chunk-1\" width\u003d\"100%\"\u003e\u003c/p\u003e" - } - ] - }, - "apps": [], - "jobName": "paragraph_1455137735427_-1023869289", - "id": "20160210-215535_1815168219", - "dateCreated": "Feb 10, 2016 9:55:35 AM", - "dateStarted": "Jan 29, 2017 2:58:27 AM", - "dateFinished": "Jan 29, 2017 2:58:28 AM", - "status": "FINISHED", - "progressUpdateIntervalMs": 500 - }, - { - "text": "%r \nplot(iris, col \u003d heat.colors(3))", - "user": "anonymous", - "dateUpdated": "Jan 29, 2017 2:58:24 AM", - "config": { - "colWidth": 4.0, - "enabled": true, - "editorMode": "ace/mode/r", - "results": [ - { - "graph": { - "mode": "table", - "height": 399.66668701171875, - "optionOpen": false, - "keys": [], - "values": [], - "groups": [], - "scatter": {} - } - } - ], - "editorSetting": { - "language": "r", - "editOnDblClick": false - } - }, - "settings": { - "params": {}, - "forms": {} - }, - "results": { - "code": "SUCCESS", - "msg": [ - { - "type": "HTML", - "data": "\u003cp\u003e\u003cimg src\u003d\"\u003d\" alt\u003d\"plot of chunk unnamed-chunk-1\" width\u003d\"100%\"\u003e\u003c/p\u003e" - } - ] - }, - "apps": [], - "jobName": "paragraph_1455137737773_-549089146", - "id": "20160210-215537_582262164", - "dateCreated": "Feb 10, 2016 9:55:37 AM", - "dateStarted": "Jan 29, 2017 2:58:24 AM", - "dateFinished": "Jan 29, 2017 2:58:25 AM", - "status": "FINISHED", - "progressUpdateIntervalMs": 500 - }, - { - "text": "%r\nlibrary(ggplot2)\npres_rating \u003c- data.frame(\n rating \u003d as.numeric(presidents),\n year \u003d as.numeric(floor(time(presidents))),\n quarter \u003d as.numeric(cycle(presidents))\n)\np \u003c- ggplot(pres_rating, aes(x\u003dyear, y\u003dquarter, fill\u003drating))\np + geom_raster()", - "user": "anonymous", - "dateUpdated": "Jan 29, 2017 3:04:03 AM", - "config": { - "colWidth": 4.0, - "enabled": true, - "editorMode": "ace/mode/r", - "results": [ - { - "graph": { - "mode": "table", - "height": 449.66668701171875, - "optionOpen": false, - "keys": [], - "values": [], - "groups": [], - "scatter": {} - } - } - ], - "editorSetting": { - "language": "r", - "editOnDblClick": false - }, - "editorHide": false - }, - "settings": { - "params": {}, - "forms": {} - }, - "results": { - "code": "SUCCESS", - "msg": [ - { - "type": "HTML", - "data": "\u003cp\u003e\u003cimg src\u003d\"\u003d\" alt\u003d\"plot of chunk unnamed-chunk-1\" width\u003d\"100%\"\u003e\u003c/p\u003e" - } - ] - }, - "apps": [], - "jobName": "paragraph_1438930880648_-1572054429", - "id": "20150807-090120_1060568667", - "dateCreated": "Aug 7, 2015 9:01:20 AM", - "dateStarted": "Jan 29, 2017 3:04:03 AM", - "dateFinished": "Jan 29, 2017 3:04:04 AM", - "status": "FINISHED", - "progressUpdateIntervalMs": 500 - }, - { - "title": "GoogleViz: Bubble Chart", - "text": "%r\nlibrary(googleVis)\nbubble \u003c- gvisBubbleChart(Fruits, idvar\u003d\"Fruit\", \n xvar\u003d\"Sales\", yvar\u003d\"Expenses\",\n colorvar\u003d\"Year\", sizevar\u003d\"Profit\",\n options\u003dlist(\n hAxis\u003d\u0027{minValue:75, maxValue:125}\u0027))\nprint(bubble, tag \u003d \u0027chart\u0027)", - "user": "anonymous", - "dateUpdated": "Jan 29, 2017 3:14:35 AM", - "config": { - "colWidth": 6.0, - "enabled": true, - "editorMode": "ace/mode/r", - "title": true, - "results": [ - { - "graph": { - "mode": "table", - "height": 189.6666717529297, - "optionOpen": false, - "keys": [], - "values": [], - "groups": [], - "scatter": {} - } - } - ], - "editorSetting": { - "language": "r", - "editOnDblClick": false - }, - "editorHide": false - }, - "settings": { - "params": {}, - "forms": {} - }, - "results": { - "code": "SUCCESS", - "msg": [ - { - "type": "HTML", - "data": "\n\u003c!-- BubbleChart generated in R 3.3.2 by googleVis 0.6.2 package --\u003e\n\n\u003c!-- Sun Jan 29 03:14:35 2017 --\u003e\n\n\u003c!-- jsHeader --\u003e\n\n\u003cscript type\u003d\"text/javascript\"\u003e\n \n// jsData \nfunction gvisDataBubbleChartID17e4815dd498c () {\nvar data \u003d new google.visualization.DataTable();\nvar datajson \u003d\n[\n [\n\"Apples\",\n98,\n78,\n\"2008\",\n20\n],\n[\n\"Apples\",\n111,\n79,\n\"2009\",\n32\n],\n[\n\"Apples\",\n89,\n76,\n\"2010\",\n13\n],\n[\n\"Oranges\",\n96,\n81,\n\"2008\",\n15\n],\n[\n\"Bananas\",\n85,\n76,\n\"2008\",\n9\n],\n[\n\"Oranges\",\n93,\n80,\n\"2009\",\n13\n],\n[\n\"Bananas\",\n94,\n78,\n\"2009\",\n16\n],\n[\n\"Oranges\",\n98,\n91,\n\"2010\",\n7\n],\n[\n\"Bananas\",\n81,\n71,\n\"2010\",\n10\n] \n];\ndata.addColumn(\u0027string\u0027,\u0027Fruit\u0027);\ndata.addColumn(\u0027number\u0027,\u0027Sales\u0027);\ndata.addColumn(\u0027number\u0027,\u0027Expenses\u0027);\ndata.addColumn(\u0027string\u0027,\u0027Year\u0027);\ndata.addColumn(\u0027number\u0027,\u0027Profit\u0027);\ndata.addRows(datajson);\nreturn(data);\n}\n \n// jsDrawChart\nfunction drawChartBubbleChartID17e4815dd498c() {\nvar data \u003d gvisDataBubbleChartID17e4815dd498c();\nvar options \u003d {};\noptions[\"hAxis\"] \u003d {minValue:75, maxValue:125};\n\n var chart \u003d new google.visualization.BubbleChart(\n document.getElementById(\u0027BubbleChartID17e4815dd498c\u0027)\n );\n chart.draw(data,options);\n \n\n}\n \n \n// jsDisplayChart\n(function() {\nvar pkgs \u003d window.__gvisPackages \u003d window.__gvisPackages || [];\nvar callbacks \u003d window.__gvisCallbacks \u003d window.__gvisCallbacks || [];\nvar chartid \u003d \"corechart\";\n \n// Manually see if chartid is in pkgs (not all browsers support Array.indexOf)\nvar i, newPackage \u003d true;\nfor (i \u003d 0; newPackage \u0026\u0026 i \u003c pkgs.length; i++) {\nif (pkgs[i] \u003d\u003d\u003d chartid)\nnewPackage \u003d false;\n}\nif (newPackage)\n pkgs.push(chartid);\n \n// Add the drawChart function to the global list of callbacks\ncallbacks.push(drawChartBubbleChartID17e4815dd498c);\n})();\nfunction displayChartBubbleChartID17e4815dd498c() {\n var pkgs \u003d window.__gvisPackages \u003d window.__gvisPackages || [];\n var callbacks \u003d window.__gvisCallbacks \u003d window.__gvisCallbacks || [];\n window.clearTimeout(window.__gvisLoad);\n // The timeout is set to 100 because otherwise the container div we are\n // targeting might not be part of the document yet\n window.__gvisLoad \u003d setTimeout(function() {\n var pkgCount \u003d pkgs.length;\n google.load(\"visualization\", \"1\", { packages:pkgs, callback: function() {\n if (pkgCount !\u003d pkgs.length) {\n // Race condition where another setTimeout call snuck in after us; if\n // that call added a package, we must not shift its callback\n return;\n}\nwhile (callbacks.length \u003e 0)\ncallbacks.shift()();\n} });\n}, 100);\n}\n \n// jsFooter\n\u003c/script\u003e\n \n\n\u003c!-- jsChart --\u003e \n\n\u003cscript type\u003d\"text/javascript\" src\u003d\"https://www.google.com/jsapi?callback\u003ddisplayChartBubbleChartID17e4815dd498c\"\u003e\u003c/script\u003e\n \n\n\u003c!-- divChart --\u003e\n\n\u003cdiv id\u003d\"BubbleChartID17e4815dd498c\" style\u003d\"width: 500; height: automatic;\"\u003e\n\u003c/div\u003e\n\n\n\n" - } - ] - }, - "apps": [], - "jobName": "paragraph_1455141578555_-1713165000", - "id": "20160210-225938_1538591791", - "dateCreated": "Feb 10, 2016 10:59:38 AM", - "dateStarted": "Jan 29, 2017 3:14:35 AM", - "dateFinished": "Jan 29, 2017 3:14:35 AM", - "status": "FINISHED", - "progressUpdateIntervalMs": 500 - }, - { - "title": "GoogleViz: Geo Chart", - "text": "%r\nlibrary(googleVis)\ngeo \u003d gvisGeoChart(Exports, locationvar \u003d \"Country\", colorvar\u003d\"Profit\", options\u003dlist(Projection \u003d \"kavrayskiy-vii\"))\nprint(geo, tag \u003d \u0027chart\u0027)", - "user": "anonymous", - "dateUpdated": "Jan 29, 2017 3:14:38 AM", - "config": { - "colWidth": 6.0, - "enabled": true, - "editorMode": "ace/mode/r", - "results": [ - { - "graph": { - "mode": "table", - "height": 336.66668701171875, - "optionOpen": false, - "keys": [], - "values": [], - "groups": [], - "scatter": {} - } - } - ], - "editorSetting": { - "language": "r", - "editOnDblClick": false - }, - "editorHide": false, - "title": true - }, - "settings": { - "params": {}, - "forms": {} - }, - "results": { - "code": "SUCCESS", - "msg": [ - { - "type": "HTML", - "data": "\n\u003c!-- GeoChart generated in R 3.3.2 by googleVis 0.6.2 package --\u003e\n\n\u003c!-- Sun Jan 29 03:14:38 2017 --\u003e\n\n\u003c!-- jsHeader --\u003e\n\n\u003cscript type\u003d\"text/javascript\"\u003e\n \n// jsData \nfunction gvisDataGeoChartID17e485996beba () {\nvar data \u003d new google.visualization.DataTable();\nvar datajson \u003d\n[\n [\n\"Germany\",\n3\n],\n[\n\"Brazil\",\n4\n],\n[\n\"United States\",\n5\n],\n[\n\"France\",\n4\n],\n[\n\"Hungary\",\n3\n],\n[\n\"India\",\n2\n],\n[\n\"Iceland\",\n1\n],\n[\n\"Norway\",\n4\n],\n[\n\"Spain\",\n5\n],\n[\n\"Turkey\",\n1\n] \n];\ndata.addColumn(\u0027string\u0027,\u0027Country\u0027);\ndata.addColumn(\u0027number\u0027,\u0027Profit\u0027);\ndata.addRows(datajson);\nreturn(data);\n}\n \n// jsDrawChart\nfunction drawChartGeoChartID17e485996beba() {\nvar data \u003d gvisDataGeoChartID17e485996beba();\nvar options \u003d {};\noptions[\"width\"] \u003d 556;\noptions[\"height\"] \u003d 347;\noptions[\"Projection\"] \u003d \"kavrayskiy-vii\";\n\n var chart \u003d new google.visualization.GeoChart(\n document.getElementById(\u0027GeoChartID17e485996beba\u0027)\n );\n chart.draw(data,options);\n \n\n}\n \n \n// jsDisplayChart\n(function() {\nvar pkgs \u003d window.__gvisPackages \u003d window.__gvisPackages || [];\nvar callbacks \u003d window.__gvisCallbacks \u003d window.__gvisCallbacks || [];\nvar chartid \u003d \"geochart\";\n \n// Manually see if chartid is in pkgs (not all browsers support Array.indexOf)\nvar i, newPackage \u003d true;\nfor (i \u003d 0; newPackage \u0026\u0026 i \u003c pkgs.length; i++) {\nif (pkgs[i] \u003d\u003d\u003d chartid)\nnewPackage \u003d false;\n}\nif (newPackage)\n pkgs.push(chartid);\n \n// Add the drawChart function to the global list of callbacks\ncallbacks.push(drawChartGeoChartID17e485996beba);\n})();\nfunction displayChartGeoChartID17e485996beba() {\n var pkgs \u003d window.__gvisPackages \u003d window.__gvisPackages || [];\n var callbacks \u003d window.__gvisCallbacks \u003d window.__gvisCallbacks || [];\n window.clearTimeout(window.__gvisLoad);\n // The timeout is set to 100 because otherwise the container div we are\n // targeting might not be part of the document yet\n window.__gvisLoad \u003d setTimeout(function() {\n var pkgCount \u003d pkgs.length;\n google.load(\"visualization\", \"1\", { packages:pkgs, callback: function() {\n if (pkgCount !\u003d pkgs.length) {\n // Race condition where another setTimeout call snuck in after us; if\n // that call added a package, we must not shift its callback\n return;\n}\nwhile (callbacks.length \u003e 0)\ncallbacks.shift()();\n} });\n}, 100);\n}\n \n// jsFooter\n\u003c/script\u003e\n \n\n\u003c!-- jsChart --\u003e \n\n\u003cscript type\u003d\"text/javascript\" src\u003d\"https://www.google.com/jsapi?callback\u003ddisplayChartGeoChartID17e485996beba\"\u003e\u003c/script\u003e\n \n\n\u003c!-- divChart --\u003e\n\n\u003cdiv id\u003d\"GeoChartID17e485996beba\" style\u003d\"width: 556; height: 347;\"\u003e\n\u003c/div\u003e\n\n\n\n" - } - ] - }, - "apps": [], - "jobName": "paragraph_1455140544963_1486338978", - "id": "20160210-224224_735421242", - "dateCreated": "Feb 10, 2016 10:42:24 AM", - "dateStarted": "Jan 29, 2017 3:14:38 AM", - "dateFinished": "Jan 29, 2017 3:14:38 AM", - "status": "FINISHED", - "progressUpdateIntervalMs": 500 - }, - { - "text": "%md\n\n## Congratulations, it\u0027s done.\n### You can create your own notebook in \u0027Notebook\u0027 menu. Good luck!", - "user": "anonymous", - "dateUpdated": "Jan 29, 2017 3:12:06 AM", - "config": { - "colWidth": 12.0, - "enabled": true, - "results": {}, - "editorSetting": { - "language": "markdown", - "editOnDblClick": true - }, - "editorMode": "ace/mode/markdown", - "editorHide": true, - "tableHide": false - }, - "settings": { - "params": {}, - "forms": {} - }, - "results": { - "code": "SUCCESS", - "msg": [ - { - "type": "HTML", - "data": "\u003cdiv class\u003d\"markdown-body\"\u003e\n\u003ch2\u003eCongratulations, it\u0026rsquo;s done.\u003c/h2\u003e\n\u003ch3\u003eYou can create your own notebook in \u0026lsquo;Notebook\u0026rsquo; menu. Good luck!\u003c/h3\u003e\n\u003c/div\u003e" - } - ] - }, - "apps": [], - "jobName": "paragraph_1485626988585_-946362813", - "id": "20170129-030948_1379298104", - "dateCreated": "Jan 29, 2017 3:09:48 AM", - "dateStarted": "Jan 29, 2017 3:12:06 AM", - "dateFinished": "Jan 29, 2017 3:12:06 AM", - "status": "FINISHED", - "progressUpdateIntervalMs": 500 - } - ], - "name": "Zeppelin Tutorial/R (SparkR)", - "id": "2BWJFTXKJ", - "angularObjects": { - "2C9A5UJ3F:shared_process": [], - "2C8D7ETGW:shared_process": [], - "2C9S19J4N:shared_process": [], - "2C734G5GU:shared_process": [], - "2C7F9HJVB:shared_process": [], - "2C7RMKT4T:shared_process": [], - "2C6UPN6XS:shared_process": [], - "2C8MCDYHM:shared_process": [], - "2C7GPJHE2:shared_process": [], - "2C81DYM51:shared_process": [], - "2C7Z5PJKA:shared_process": [], - "2C7KKEX6R:shared_process": [], - "2C8G679A7:shared_process": [], - "2C96T367K:shared_process": [], - "2C79TYUDA:shared_process": [], - "2C82EG3YP:shared_process": [], - "2C8C4BYC9:shared_process": [], - "2C77RB7Q2:shared_process": [], - "2C9ENJ461:shared_process": [] - }, - "config": { - "looknfeel": "default" - }, - "info": {} -} diff --git a/smart-zeppelin/notebook/2BYEZ5EVK/note.json b/smart-zeppelin/notebook/2BYEZ5EVK/note.json deleted file mode 100644 index 83a79135f7e..00000000000 --- a/smart-zeppelin/notebook/2BYEZ5EVK/note.json +++ /dev/null @@ -1,887 +0,0 @@ -{ - "paragraphs": [ - { - "text": "%md\n\n### The [Apache Mahout](http://mahout.apache.org/)™ project\u0027s goal is to build an environment for quickly creating scalable performant machine learning applications.\n\n#### Apache Mahout software provides three major features:\n\n- A simple and extensible programming environment and framework for building scalable algorithms\n- A wide variety of premade algorithms for Scala + Apache Spark, H2O, Apache Flink\n- Samsara, a vector math experimentation environment with R-like syntax which works at scale\n\n#### In other words:\n\n*Apache Mahout provides a unified API for quickly creating machine learning algorithms on a variety of engines.*\n\n#### Getting Started\n\nApache Mahout is a collection of Libraries that enhance Apache Flink, Apache Spark, and others. Currently Zeppelin support the Flink and Spark Engines. A convenience script is provided to setup the nessecary imports and configurations to run Mahout on Spark and Flink. \n\nWe can use Apache Mahout\u0027s R-Like Domain Specific Language (DSL) inline with native Flink or Spark code. We must however, first declare a few imports that are different for Spark and Flink\n\n__References:__\n\n[Mahout-Samsara\u0027s In-Core Linear Algebra DSL Reference](http://mahout.apache.org/users/environment/in-core-reference.html)\n[Mahout-Samsara\u0027s Distributed Linear Algebra DSL Reference](http://mahout.apache.org/users/environment/out-of-core-reference.html)\n[Getting Started with the Mahout-Samsara Shell](http://mahout.apache.org/users/sparkbindings/play-with-shell.html)\n", - "dateUpdated": "Sep 28, 2016 10:01:52 AM", - "config": { - "colWidth": 12.0, - "enabled": true, - "editorMode": "ace/mode/scala", - "editorHide": true, - "results": [ - { - "graph": { - "mode": "table", - "height": 300.0, - "optionOpen": false, - "keys": [], - "values": [], - "groups": [], - "scatter": {}, - "map": { - "baseMapType": "Streets", - "isOnline": true, - "pinCols": [] - } - } - } - ] - }, - "settings": { - "params": {}, - "forms": {} - }, - "apps": [], - "jobName": "paragraph_1475013396125_39313566", - "id": "20160927-155636_1798325301", - "results": { - "code": "SUCCESS", - "msg": [ - { - "type": "HTML", - "data": "\u003ch3\u003eThe \u003ca href\u003d\"http://mahout.apache.org/\"\u003eApache Mahout\u003c/a\u003e™ project\u0027s goal is to build an environment for quickly creating scalable performant machine learning applications.\u003c/h3\u003e\n\u003ch4\u003eApache Mahout software provides three major features:\u003c/h4\u003e\n\u003cul\u003e\n\u003cli\u003eA simple and extensible programming environment and framework for building scalable algorithms\u003c/li\u003e\n\u003cli\u003eA wide variety of premade algorithms for Scala + Apache Spark, H2O, Apache Flink\u003c/li\u003e\n\u003cli\u003eSamsara, a vector math experimentation environment with R-like syntax which works at scale\u003c/li\u003e\n\u003c/ul\u003e\n\u003ch4\u003eIn other words:\u003c/h4\u003e\n\u003cp\u003e\u003cem\u003eApache Mahout provides a unified API for quickly creating machine learning algorithms on a variety of engines.\u003c/em\u003e\u003c/p\u003e\n\u003cp\u003e\u003cstrong\u003eReferences:\u003c/strong\u003e\u003c/p\u003e\n\u003cp\u003e\u003ca href\u003d\"http://mahout.apache.org/users/environment/in-core-reference.html\"\u003eMahout-Samsara\u0027s In-Core Linear Algebra DSL Reference\u003c/a\u003e\n\u003cbr /\u003e\u003ca href\u003d\"http://mahout.apache.org/users/environment/out-of-core-reference.html\"\u003eMahout-Samsara\u0027s Distributed Linear Algebra DSL Reference\u003c/a\u003e\n\u003cbr /\u003e\u003ca href\u003d\"http://mahout.apache.org/users/sparkbindings/play-with-shell.html\"\u003eGetting Started with the Mahout-Samsara Shell\u003c/a\u003e\u003c/p\u003e\n" - } - ] - }, - "dateCreated": "Sep 27, 2016 3:56:36 AM", - "dateStarted": "Sep 27, 2016 4:02:55 AM", - "dateFinished": "Sep 27, 2016 4:02:55 AM", - "status": "FINISHED", - "progressUpdateIntervalMs": 500 - }, - { - "text": "%md\n\n#### \"Installing\" the Apache Mahout dependencies and configuring a new Spark and Flink interpreter\n\nThe following two paragraphs are convenience paragraphs. You **only need to run them once** to create two new interpreters `%spark.mahout` and `%flink.mahout`. These are intended for users who don\u0027t have Apache Mahout already installed. They assume you started Apache Zeppelin from the top level directory or from the bin. You can tell which one is you by weather you started Zeppelin by typing `./zeppelin-daemon.sh start` or `bin/zeppelin-daemon.sh start`. If you started Zeppelin from somewhere else you will also need to run them from the command line.\n\nThey both run a python script which may be found at `ZEPPELIN_HOME/scripts/mahout/add_mahout.py`\n\nIn short this script:\n- Downloads Apache Mahout\n- Creates a new Flink interpreter with dependencies.\n- Creates a new Spark interpreter with dependencies and modified configuration to use Kryo serialization.\n\n__You only need to run this script once ever.__ (Maybe again if for some reason you delete `conf/interpreter.json`) \n", - "dateUpdated": "Sep 27, 2016 4:31:15 AM", - "config": { - "colWidth": 12.0, - "enabled": true, - "editorMode": "ace/mode/scala", - "editorHide": true, - "results": [ - { - "graph": { - "mode": "table", - "height": 300.0, - "optionOpen": false, - "keys": [], - "values": [], - "groups": [], - "scatter": {}, - "map": { - "baseMapType": "Streets", - "isOnline": true, - "pinCols": [] - } - } - } - ] - }, - "settings": { - "params": {}, - "forms": {} - }, - "apps": [], - "jobName": "paragraph_1475015019489_-1704057033", - "id": "20160927-162339_341514150", - "results": { - "code": "SUCCESS", - "msg": [ - { - "type": "HTML", - "data": "\u003ch4\u003e\u0026ldquo;Installing\u0026rdquo; the Apache Mahout dependencies and configuring a new Spark and Flink interpreter\u003c/h4\u003e\n\u003cp\u003eThe following two paragraphs are convenience paragraphs. You \u003cstrong\u003eonly need to run them once\u003c/strong\u003e to create two new interpreters \u003ccode\u003e%spark.mahout\u003c/code\u003e and \u003ccode\u003e%flink.mahout\u003c/code\u003e. These are intended for users who don\u0027t have Apache Mahout already installed. They assume you started Apache Zeppelin from the top level directory or from the bin. You can tell which one is you by weather you started Zeppelin by typing \u003ccode\u003e./zeppelin-daemon.sh start\u003c/code\u003e or \u003ccode\u003ebin/zeppelin-daemon.sh start\u003c/code\u003e. If you started Zeppelin from somewhere else you will also need to run them from the command line.\u003c/p\u003e\n\u003cp\u003eThey both run a python script which may be found at \u003ccode\u003eZEPPELIN_HOME/scripts/mahout/add_mahout.py\u003c/code\u003e\u003c/p\u003e\n\u003cp\u003eIn short this script:\u003c/p\u003e\n\u003cul\u003e\n\u003cli\u003eDownloads Apache Mahout\u003c/li\u003e\n\u003cli\u003eCreates a new Flink interpreter with dependencies.\u003c/li\u003e\n\u003cli\u003eCreates a new Spark interpreter with dependencies and modified configuration to use Kryo serialization.\u003c/li\u003e\n\u003c/ul\u003e\n\u003cp\u003e\u003cstrong\u003eYou only need to run this script once ever.\u003c/strong\u003e (Maybe again if for some reason you delete \u003ccode\u003econf/interpreter.json\u003c/code\u003e)\u003c/p\u003e\n" - } - ] - }, - "dateCreated": "Sep 27, 2016 4:23:39 AM", - "dateStarted": "Sep 27, 2016 4:31:12 AM", - "dateFinished": "Sep 27, 2016 4:31:13 AM", - "status": "FINISHED", - "progressUpdateIntervalMs": 500 - }, - { - "title": "Convenience Paragraph if you started Zeppelin by \u0027./zeppelin-daemon.sh start\u0027", - "text": "%sh\n\npython ../scripts/mahout/add_mahout.py", - "dateUpdated": "Dec 17, 2016 3:41:45 PM", - "config": { - "colWidth": 12.0, - "graph": { - "mode": "table", - "height": 300.0, - "optionOpen": false, - "keys": [], - "values": [], - "groups": [], - "scatter": {}, - "map": { - "baseMapType": "Streets", - "isOnline": true, - "pinCols": [] - } - }, - "enabled": true, - "editorMode": "ace/mode/sh", - "title": true, - "results": {}, - "editorSetting": { - "language": "sh", - "editOnDblClick": false - } - }, - "settings": { - "params": {}, - "forms": {} - }, - "apps": [], - "jobName": "paragraph_1475014957043_-748248820", - "id": "20160927-162237_1864782562", - "dateCreated": "Sep 27, 2016 4:22:37 AM", - "status": "READY", - "progressUpdateIntervalMs": 500 - }, - { - "title": "Convenience Paragraph if you started Zeppelin by \u0027bin/zeppelin-daemon.sh start\u0027", - "text": "%sh\npython scripts/mahout/add_mahout_interpreters.py", - "dateUpdated": "Dec 17, 2016 3:41:46 PM", - "config": { - "colWidth": 12.0, - "graph": { - "mode": "table", - "height": 300.0, - "optionOpen": false, - "keys": [], - "values": [], - "groups": [], - "scatter": {}, - "map": { - "baseMapType": "Streets", - "isOnline": true, - "pinCols": [] - } - }, - "enabled": true, - "editorMode": "ace/mode/sh", - "title": true, - "results": {}, - "editorSetting": { - "language": "sh", - "editOnDblClick": false - } - }, - "settings": { - "params": {}, - "forms": {} - }, - "apps": [], - "jobName": "paragraph_1475018789604_-139338572", - "id": "20160927-172629_1189436716", - "dateCreated": "Sep 27, 2016 5:26:29 AM", - "status": "READY", - "progressUpdateIntervalMs": 500 - }, - { - "text": "%md\n\nAfter the interpreters are created you will need to \u0027bind\u0027 them by clicking on the little gear in the top right corner, scrolling to the top, and clicking on `mahoutFlink` and `mahoutSpark` so that they are highlighted in blue.\n\n#### Running Mahout code\n\nYou will need to import certain libraries, and declare the _Mahout Distributed Context_ when you first start your notebook using the interpreters. \n\nIf using Apache Flink the code you need to run is:\n```scala\n%flinkMahout\n\nimport org.apache.flink.api.scala._\nimport org.apache.mahout.math.drm._\nimport org.apache.mahout.math.drm.RLikeDrmOps._\nimport org.apache.mahout.flinkbindings._\nimport org.apache.mahout.math._\nimport scalabindings._\nimport RLikeOps._\n\n\nimplicit val ctx \u003d new FlinkDistributedContext(benv)\n```\n\nIf using Apache Spark the code you need to run is\n```scala\n%sparkMahout\n\nimport org.apache.mahout.math._\nimport org.apache.mahout.math.scalabindings._\nimport org.apache.mahout.math.drm._\nimport org.apache.mahout.math.scalabindings.RLikeOps._\nimport org.apache.mahout.math.drm.RLikeDrmOps._\nimport org.apache.mahout.sparkbindings._\n\nimplicit val sdc: org.apache.mahout.sparkbindings.SparkDistributedContext \u003d sc2sdc(sc)\n```\n\n__Note: For Apache Mahout on Apache Spark you must be running Spark 1.5.x or 1.6.x. We are working hard on supporting Spark 2.0__\nIn the meantime, feel free to play with Mahout on Flink and then simple _copy and paste your Mahout code to Spark once it is supported!_\n\n### A Side by Side Example\n", - "dateUpdated": "Sep 28, 2016 12:36:44 PM", - "config": { - "colWidth": 12.0, - "enabled": true, - "editorMode": "ace/mode/markdown", - "editorHide": true, - "results": [ - { - "graph": { - "mode": "table", - "height": 300.0, - "optionOpen": false, - "keys": [], - "values": [], - "groups": [], - "scatter": {}, - "map": { - "baseMapType": "Streets", - "isOnline": true, - "pinCols": [] - } - } - } - ] - }, - "settings": { - "params": {}, - "forms": {} - }, - "apps": [], - "jobName": "paragraph_1475014730618_1513783554", - "id": "20160927-161850_1560940440", - "results": { - "code": "SUCCESS", - "msg": [ - { - "type": "HTML", - "data": "\u003cp\u003eAfter the interpreters are created you will need to \u0027bind\u0027 them by clicking on the little gear in the top right corner, scrolling to the top, and clicking on \u003ccode\u003emahoutFlink\u003c/code\u003e and \u003ccode\u003emahoutSpark\u003c/code\u003e so that they are highlighted in blue.\u003c/p\u003e\n\u003ch4\u003eRunning Mahout code\u003c/h4\u003e\n\u003cp\u003eYou will need to import certain libraries, and declare the \u003cem\u003eMahout Distributed Context\u003c/em\u003e when you first start your notebook using the interpreters.\u003c/p\u003e\n\u003cp\u003eIf using Apache Flink the code you need to run is:\u003c/p\u003e\n\u003cpre\u003e\u003ccode class\u003d\"scala\"\u003e%flinkMahout\n\nimport org.apache.flink.api.scala._\nimport org.apache.mahout.math.drm._\nimport org.apache.mahout.math.drm.RLikeDrmOps._\nimport org.apache.mahout.flinkbindings._\nimport org.apache.mahout.math._\nimport scalabindings._\nimport RLikeOps._\n\n\n@transient implicit val ctx \u003d new FlinkDistributedContext(benv)\n\u003c/code\u003e\u003c/pre\u003e\n\u003cp\u003eIf using Apache Spark the code you need to run is\u003c/p\u003e\n\u003cpre\u003e\u003ccode class\u003d\"scala\"\u003e%sparkMahout\n\nimport org.apache.mahout.math._\nimport org.apache.mahout.math.scalabindings._\nimport org.apache.mahout.math.drm._\nimport org.apache.mahout.math.scalabindings.RLikeOps._\nimport org.apache.mahout.math.drm.RLikeDrmOps._\nimport org.apache.mahout.sparkbindings._\n\nimplicit val sdc: org.apache.mahout.sparkbindings.SparkDistributedContext \u003d sc2sdc(sc)\n\u003c/code\u003e\u003c/pre\u003e\n\u003cp\u003e\u003cstrong\u003eNote: For Apache Mahout on Apache Spark you must be running Spark 1.5.x or 1.6.x. We are working hard on supporting Spark 2.0\u003c/strong\u003e\n\u003cbr /\u003eIn the meantime, feel free to play with Mahout on Flink and then simple \u003cem\u003ecopy and paste your Mahout code to Spark once it is supported!\u003c/em\u003e\u003c/p\u003e\n\u003ch3\u003eA Side by Side Example\u003c/h3\u003e\n" - } - ] - }, - "dateCreated": "Sep 27, 2016 4:18:50 AM", - "dateStarted": "Sep 28, 2016 10:17:05 AM", - "dateFinished": "Sep 28, 2016 10:17:06 AM", - "status": "FINISHED", - "progressUpdateIntervalMs": 500 - }, - { - "text": "%flinkMahout\n\n// Imports and creating the distributed context, similar but not exactly the same ///////////////////////////////////////////\nimport org.apache.flink.api.scala._\nimport org.apache.mahout.math.drm._\nimport org.apache.mahout.math.drm.RLikeDrmOps._\nimport org.apache.mahout.flinkbindings._\nimport org.apache.mahout.math._\nimport scalabindings._\nimport RLikeOps._\n\n\nimplicit val ctx \u003d new FlinkDistributedContext(benv)\n\n// CODE IS EXACTLY THE SAME FROM HERE ON - R-Like DSL ////////////////////////////////////////////////////////////////////////////////\n\nval drmData \u003d drmParallelize(dense(\n (2, 2, 10.5, 10, 29.509541), // Apple Cinnamon Cheerios\n (1, 2, 12, 12, 18.042851), // Cap\u0027n\u0027Crunch\n (1, 1, 12, 13, 22.736446), // Cocoa Puffs\n (2, 1, 11, 13, 32.207582), // Froot Loops\n (1, 2, 12, 11, 21.871292), // Honey Graham Ohs\n (2, 1, 16, 8, 36.187559), // Wheaties Honey Gold\n (6, 2, 17, 1, 50.764999), // Cheerios\n (3, 2, 13, 7, 40.400208), // Clusters\n (3, 3, 13, 4, 45.811716)), numPartitions \u003d 2)\n \ndrmData.collect(::, 0 until 4)\n\nval drmX \u003d drmData(::, 0 until 4)\nval y \u003d drmData.collect(::, 4)\nval drmXtX \u003d drmX.t %*% drmX\nval drmXty \u003d drmX.t %*% y\n\n\nval XtX \u003d drmXtX.collect\nval Xty \u003d drmXty.collect(::, 0)\nval beta \u003d solve(XtX, Xty)\n\n", - "dateUpdated": "Sep 28, 2016 1:41:59 PM", - "config": { - "colWidth": 6.0, - "enabled": true, - "editorMode": "ace/mode/markdown", - "results": [ - { - "graph": { - "mode": "table", - "height": 300.0, - "optionOpen": false, - "keys": [], - "values": [], - "groups": [], - "scatter": {}, - "map": { - "baseMapType": "Streets", - "isOnline": true, - "pinCols": [] - } - } - } - ] - }, - "settings": { - "params": {}, - "forms": {} - }, - "apps": [], - "jobName": "paragraph_1475015779325_-1869239670", - "id": "20160927-163619_899520006", - "results": { - "code": "SUCCESS", - "msg": [ - { - "type": "TEXT", - "data": "import org.apache.flink.api.scala._\nimport org.apache.mahout.math.drm._\nimport org.apache.mahout.math.drm.RLikeDrmOps._\nimport org.apache.mahout.flinkbindings._\nimport org.apache.mahout.math._\nimport scalabindings._\nimport RLikeOps._\nctx: org.apache.mahout.flinkbindings.FlinkDistributedContext \u003d org.apache.mahout.flinkbindings.FlinkDistributedContext@4452b0a5\nwarning: Class it.unimi.dsi.fastutil.ints.Int2DoubleOpenHashMap not found - continuing with a stub.\ndrmData: org.apache.mahout.math.drm.CheckpointedDrm[Int] \u003d org.apache.mahout.flinkbindings.drm.CheckpointedFlinkDrm@445242be\n(5,9)\nres1: org.apache.mahout.math.Matrix \u003d \n{\n 0 \u003d\u003e\t{0:2.0,1:2.0,2:10.5,3:10.0}\n 1 \u003d\u003e\t{0:1.0,1:2.0,2:12.0,3:12.0}\n 2 \u003d\u003e\t{0:1.0,1:1.0,2:12.0,3:13.0}\n 3 \u003d\u003e\t{0:2.0,1:1.0,2:11.0,3:13.0}\n 4 \u003d\u003e\t{0:1.0,1:2.0,2:12.0,3:11.0}\n 5 \u003d\u003e\t{0:2.0,1:1.0,2:16.0,3:8.0}\n 6 \u003d\u003e\t{0:6.0,1:2.0,2:17.0,3:1.0}\n 7 \u003d\u003e\t{0:3.0,1:2.0,2:13.0,3:7.0}\n 8 \u003d\u003e\t{0:3.0,1:3.0,2:13.0,3:4.0}\n}\ndrmX: org.apache.mahout.math.drm.DrmLike[Int] \u003d OpMapBlock(org.apache.mahout.flinkbindings.drm.CheckpointedFlinkDrm@445242be,\u003cfunction1\u003e,4,-1,true)\n(5,9)\ny: org.apache.mahout.math.Vector \u003d {0:29.509541,1:18.042851,2:22.736446,3:32.207582,4:21.871292,5:36.187559,6:50.764999,7:40.400208,8:45.811716}\ndrmXtX: org.apache.mahout.math.drm.DrmLike[Int] \u003d OpABAnyKey(OpAt(OpMapBlock(org.apache.mahout.flinkbindings.drm.CheckpointedFlinkDrm@445242be,\u003cfunction1\u003e,4,-1,true)),OpMapBlock(org.apache.mahout.flinkbindings.drm.CheckpointedFlinkDrm@445242be,\u003cfunction1\u003e,4,-1,true))\ndrmXty: org.apache.mahout.math.drm.DrmLike[Int] \u003d OpAx(OpAt(OpMapBlock(org.apache.mahout.flinkbindings.drm.CheckpointedFlinkDrm@445242be,\u003cfunction1\u003e,4,-1,true)),{0:29.509541,1:18.042851,2:22.736446,3:32.207582,4:21.871292,5:36.187559,6:50.764999,7:40.400208,8:45.811716})\n(4,4)\nXtX: org.apache.mahout.math.Matrix \u003d \n{\n 0 \u003d\u003e\t{0:69.0,1:40.0,2:291.0,3:137.0}\n 1 \u003d\u003e\t{0:40.0,1:32.0,2:207.0,3:128.0}\n 2 \u003d\u003e\t{0:291.0,1:207.0,2:1546.25,3:968.0}\n 3 \u003d\u003e\t{0:137.0,1:128.0,2:968.0,3:833.0}\n}\n(1,4)\nXty: org.apache.mahout.math.Vector \u003d {0:821.6857190000001,1:549.744517,2:3978.7015895000004,3:2272.7799889999997}\nbeta: org.apache.mahout.math.Vector \u003d {0:5.247349465378393,1:2.7507945784675067,2:1.1527813010791783,3:0.10312017617607437}\n" - } - ] - }, - "dateCreated": "Sep 27, 2016 4:36:19 AM", - "dateStarted": "Sep 28, 2016 1:41:59 PM", - "dateFinished": "Sep 28, 2016 1:42:25 PM", - "status": "FINISHED", - "progressUpdateIntervalMs": 500 - }, - { - "text": "%sparkMahout\n\n// Imports and creating the distributed context, similar but not exactly the same ///////////////////////////////////////////\n\nimport org.apache.mahout.math._\nimport org.apache.mahout.math.scalabindings._\nimport org.apache.mahout.math.drm._\nimport org.apache.mahout.math.scalabindings.RLikeOps._\nimport org.apache.mahout.math.drm.RLikeDrmOps._\nimport org.apache.mahout.sparkbindings._\n\nimplicit val sdc: org.apache.mahout.sparkbindings.SparkDistributedContext \u003d sc2sdc(sc)\n\n\n// CODE IS EXACTLY THE SAME FROM HERE ON - R-Like DSL ////////////////////////////////////////////////////////////////////////////////\n\nval drmData \u003d drmParallelize(dense(\n (2, 2, 10.5, 10, 29.509541), // Apple Cinnamon Cheerios\n (1, 2, 12, 12, 18.042851), // Cap\u0027n\u0027Crunch\n (1, 1, 12, 13, 22.736446), // Cocoa Puffs\n (2, 1, 11, 13, 32.207582), // Froot Loops\n (1, 2, 12, 11, 21.871292), // Honey Graham Ohs\n (2, 1, 16, 8, 36.187559), // Wheaties Honey Gold\n (6, 2, 17, 1, 50.764999), // Cheerios\n (3, 2, 13, 7, 40.400208), // Clusters\n (3, 3, 13, 4, 45.811716)), numPartitions \u003d 2)\n \ndrmData.collect(::, 0 until 4)\n\nval drmX \u003d drmData(::, 0 until 4)\nval y \u003d drmData.collect(::, 4)\nval drmXtX \u003d drmX.t %*% drmX\nval drmXty \u003d drmX.t %*% y\n\n\nval XtX \u003d drmXtX.collect\nval Xty \u003d drmXty.collect(::, 0)\nval beta \u003d solve(XtX, Xty)\n", - "dateUpdated": "Sep 28, 2016 1:45:09 PM", - "config": { - "colWidth": 6.0, - "enabled": true, - "editorMode": "ace/mode/scala", - "results": [ - { - "graph": { - "mode": "table", - "height": 300.0, - "optionOpen": false, - "keys": [], - "values": [], - "groups": [], - "scatter": {}, - "map": { - "baseMapType": "Streets", - "isOnline": true, - "pinCols": [] - } - } - } - ] - }, - "settings": { - "params": {}, - "forms": {} - }, - "apps": [], - "jobName": "paragraph_1475016737629_-774084480", - "id": "20160927-165217_1266863511", - "results": { - "code": "SUCCESS", - "msg": [ - { - "type": "TEXT", - "data": "\nimport org.apache.mahout.math._\n\nimport org.apache.mahout.math.scalabindings._\n\nimport org.apache.mahout.math.drm._\n\nimport org.apache.mahout.math.scalabindings.RLikeOps._\n\nimport org.apache.mahout.math.drm.RLikeDrmOps._\n\nimport org.apache.mahout.sparkbindings._\n\nsdc: org.apache.mahout.sparkbindings.SparkDistributedContext \u003d org.apache.mahout.sparkbindings.SparkDistributedContext@32c46474\n\ndrmData: org.apache.mahout.math.drm.CheckpointedDrm[Int] \u003d org.apache.mahout.sparkbindings.drm.CheckpointedDrmSpark@783484b9\n\n\n\n\n\n\n\n\n\n\n\n\nres2: org.apache.mahout.math.Matrix \u003d \n{\n 0 \u003d\u003e\t{0:2.0,1:2.0,2:10.5,3:10.0}\n 1 \u003d\u003e\t{0:1.0,1:2.0,2:12.0,3:12.0}\n 2 \u003d\u003e\t{0:1.0,1:1.0,2:12.0,3:13.0}\n 3 \u003d\u003e\t{0:2.0,1:1.0,2:11.0,3:13.0}\n 4 \u003d\u003e\t{0:1.0,1:2.0,2:12.0,3:11.0}\n 5 \u003d\u003e\t{0:2.0,1:1.0,2:16.0,3:8.0}\n 6 \u003d\u003e\t{0:6.0,1:2.0,2:17.0,3:1.0}\n 7 \u003d\u003e\t{0:3.0,1:2.0,2:13.0,3:7.0}\n 8 \u003d\u003e\t{0:3.0,1:3.0,2:13.0,3:4.0}\n}\n\ndrmX: org.apache.mahout.math.drm.DrmLike[Int] \u003d OpMapBlock(org.apache.mahout.sparkbindings.drm.CheckpointedDrmSpark@783484b9,\u003cfunction1\u003e,4,-1,true)\n\ny: org.apache.mahout.math.Vector \u003d {0:29.509541,1:18.042851,2:22.736446,3:32.207582,4:21.871292,5:36.187559,6:50.764999,7:40.400208,8:45.811716}\n\ndrmXtX: org.apache.mahout.math.drm.DrmLike[Int] \u003d OpABAnyKey(OpAt(OpMapBlock(org.apache.mahout.sparkbindings.drm.CheckpointedDrmSpark@783484b9,\u003cfunction1\u003e,4,-1,true)),OpMapBlock(org.apache.mahout.sparkbindings.drm.CheckpointedDrmSpark@783484b9,\u003cfunction1\u003e,4,-1,true))\n\ndrmXty: org.apache.mahout.math.drm.DrmLike[Int] \u003d OpAx(OpAt(OpMapBlock(org.apache.mahout.sparkbindings.drm.CheckpointedDrmSpark@783484b9,\u003cfunction1\u003e,4,-1,true)),{0:29.509541,1:18.042851,2:22.736446,3:32.207582,4:21.871292,5:36.187559,6:50.764999,7:40.400208,8:45.811716})\n\n\n\n\n\n\n\nXtX: org.apache.mahout.math.Matrix \u003d \n{\n 0 \u003d\u003e\t{0:69.0,1:40.0,2:291.0,3:137.0}\n 1 \u003d\u003e\t{0:40.0,1:32.0,2:207.0,3:128.0}\n 2 \u003d\u003e\t{0:291.0,1:207.0,2:1546.25,3:968.0}\n 3 \u003d\u003e\t{0:137.0,1:128.0,2:968.0,3:833.0}\n}\n\nXty: org.apache.mahout.math.Vector \u003d {0:821.6857190000001,1:549.744517,2:3978.7015894999995,3:2272.779989}\n\nbeta: org.apache.mahout.math.Vector \u003d {0:5.247349465378446,1:2.750794578467531,2:1.1527813010791554,3:0.10312017617608908}\n" - } - ] - }, - "dateCreated": "Sep 27, 2016 4:52:17 AM", - "dateStarted": "Sep 28, 2016 1:45:09 PM", - "dateFinished": "Sep 28, 2016 1:45:23 PM", - "status": "FINISHED", - "progressUpdateIntervalMs": 500 - }, - { - "title": "Use Resource Pools with Zeppelin", - "text": "%md\n\n### Taking advantage of Zeppelin Resource Pools\n\nOne of the major motivations for integrating Apache Mahout with Apache Zeppelin was the many benefits that come from leveraging the resource pools. A resource pool is a block of memory that can be acccessed by all interpreters and is useful for sharing small variables between the interpreters. \n\nThe Spark interpreter has a simple interface for accessing the ResourcePools, the Flink interface is less documented but can be reverse engineered from code (thanks open source!)\n\n\nCollect betas from Spark and Flink- compare in Python\n\nCreate Matrix in Flink and Spark - visualize with R", - "dateUpdated": "Sep 27, 2016 5:55:31 AM", - "config": { - "colWidth": 12.0, - "enabled": true, - "title": true, - "editorMode": "ace/mode/markdown", - "editorHide": true, - "results": [ - { - "graph": { - "mode": "table", - "height": 300.0, - "optionOpen": false, - "keys": [], - "values": [], - "groups": [], - "scatter": {}, - "map": { - "baseMapType": "Streets", - "isOnline": true, - "pinCols": [] - } - } - } - ] - }, - "settings": { - "params": {}, - "forms": {} - }, - "apps": [], - "jobName": "paragraph_1475016792277_-1100474141", - "id": "20160927-165312_1668894932", - "results": { - "code": "SUCCESS", - "msg": [ - { - "type": "HTML", - "data": "\u003ch3\u003eTaking advantage of Zeppelin Resource Pools\u003c/h3\u003e\n\u003cp\u003eOne of the major motivations for integrating Apache Mahout with Apache Zeppelin was the many benefits that come from leveraging the resource pools. A resource pool is a block of memory that can be acccessed by all interpreters and is useful for sharing small variables between the interpreters.\u003c/p\u003e\n\u003cp\u003eThe Spark interpreter has a simple interface for accessing the ResourcePools, the Flink interface is less documented but can be reverse engineered from code (thanks open source!)\u003c/p\u003e\n\u003cp\u003eCollect betas from Spark and Flink- compare in Python\u003c/p\u003e\n\u003cp\u003eCreate Matrix in Flink and Spark - visualize with R\u003c/p\u003e\n" - } - ] - }, - "dateCreated": "Sep 27, 2016 4:53:12 AM", - "dateStarted": "Sep 27, 2016 5:40:35 AM", - "dateFinished": "Sep 27, 2016 5:40:36 AM", - "status": "FINISHED", - "progressUpdateIntervalMs": 500 - }, - { - "title": "Flink ResourcePools", - "text": "%flinkMahout\n\nimport org.apache.zeppelin.interpreter.InterpreterContext\n\nval resourcePool \u003d InterpreterContext.get().getResourcePool()\n\nresourcePool.put(\"flinkBeta\", beta.asFormatString)\n", - "dateUpdated": "Sep 28, 2016 1:42:35 PM", - "config": { - "colWidth": 6.0, - "enabled": true, - "editorMode": "ace/mode/scala", - "title": true, - "results": [ - { - "graph": { - "mode": "table", - "height": 300.0, - "optionOpen": false, - "keys": [], - "values": [], - "groups": [], - "scatter": {}, - "map": { - "baseMapType": "Streets", - "isOnline": true, - "pinCols": [] - } - } - } - ] - }, - "settings": { - "params": {}, - "forms": {} - }, - "apps": [], - "jobName": "paragraph_1475019635571_-1705373112", - "id": "20160927-174035_1591078106", - "results": { - "code": "SUCCESS", - "msg": [ - { - "type": "TEXT", - "data": "import org.apache.zeppelin.interpreter.InterpreterContext\nresourcePool: org.apache.zeppelin.resource.ResourcePool \u003d org.apache.zeppelin.resource.DistributedResourcePool@3fdd93cc\n" - } - ] - }, - "dateCreated": "Sep 27, 2016 5:40:35 AM", - "dateStarted": "Sep 28, 2016 1:42:35 PM", - "dateFinished": "Sep 28, 2016 1:42:36 PM", - "status": "FINISHED", - "progressUpdateIntervalMs": 500 - }, - { - "title": "Spark ResourcePools", - "text": "%sparkMahout\n\n\n\n\nz.put(\"sparkBeta\", beta.asFormatString)", - "dateUpdated": "Sep 28, 2016 1:45:35 PM", - "config": { - "colWidth": 6.0, - "enabled": true, - "editorMode": "ace/mode/scala", - "title": true, - "results": [] - }, - "settings": { - "params": {}, - "forms": {} - }, - "apps": [], - "jobName": "paragraph_1475019751650_-1885234738", - "id": "20160927-174231_1288588876", - "results": { - "code": "SUCCESS", - "msg": [] - }, - "dateCreated": "Sep 27, 2016 5:42:31 AM", - "dateStarted": "Sep 28, 2016 1:45:35 PM", - "dateFinished": "Sep 28, 2016 1:45:36 PM", - "status": "FINISHED", - "progressUpdateIntervalMs": 500 - }, - { - "title": "Collect Results in Python and Evaluate Differences", - "text": "%spark.pyspark\n\nimport ast\n\nflinkBetaDict \u003d ast.literal_eval(z.get(\"flinkBeta\"))\nsparkBetaDict \u003d ast.literal_eval(z.get(\"sparkBeta\"))\n\nprint \"----------------- differences between betas calulated in Flink and Spark-----------------\"\nfor i in range(0,4):\n print \"beta\", i, \": \" , flinkBetaDict[i] - sparkBetaDict[i]", - "dateUpdated": "Sep 28, 2016 1:45:37 PM", - "config": { - "colWidth": 12.0, - "enabled": true, - "editorMode": "ace/mode/python", - "title": true, - "results": [ - { - "graph": { - "mode": "table", - "height": 300.0, - "optionOpen": false, - "keys": [], - "values": [], - "groups": [], - "scatter": {}, - "map": { - "baseMapType": "Streets", - "isOnline": true, - "pinCols": [] - } - } - } - ] - }, - "settings": { - "params": {}, - "forms": {} - }, - "apps": [], - "jobName": "paragraph_1475020470280_1661203311", - "id": "20160927-175430_1451783515", - "results": { - "code": "SUCCESS", - "msg": [ - { - "type": "TEXT", - "data": "----------------- differences between betas calulated in Flink and Spark-----------------\nbeta 0 : -5.24025267623e-14\nbeta 1 : -2.44249065418e-14\nbeta 2 : 2.28705943073e-14\nbeta 3 : -1.47104550763e-14\n" - } - ] - }, - "dateCreated": "Sep 27, 2016 5:54:30 AM", - "dateStarted": "Sep 28, 2016 1:45:38 PM", - "dateFinished": "Sep 28, 2016 1:45:38 PM", - "status": "FINISHED", - "progressUpdateIntervalMs": 500 - }, - { - "text": "%md\n\n## Plotting Mahout with R\n\nThe following examples show how we can leverage R to plot our results from Mahout\n", - "dateUpdated": "Sep 28, 2016 12:34:33 PM", - "config": { - "colWidth": 12.0, - "enabled": true, - "editorMode": "ace/mode/markdown", - "editorHide": true, - "results": [ - { - "graph": { - "mode": "table", - "height": 300.0, - "optionOpen": false, - "keys": [], - "values": [], - "groups": [], - "scatter": {}, - "map": { - "baseMapType": "Streets", - "isOnline": true, - "pinCols": [] - } - } - } - ] - }, - "settings": { - "params": {}, - "forms": {} - }, - "apps": [], - "jobName": "paragraph_1475087633007_-566041383", - "id": "20160928-123353_147363530", - "results": { - "code": "SUCCESS", - "msg": [ - { - "type": "HTML", - "data": "\u003ch2\u003ePlotting Mahout with R\u003c/h2\u003e\n\u003cp\u003eThe following examples show how we can leverage R to plot our results from Mahout\u003c/p\u003e\n" - } - ] - }, - "dateCreated": "Sep 28, 2016 12:33:53 PM", - "dateStarted": "Sep 28, 2016 12:34:30 PM", - "dateFinished": "Sep 28, 2016 12:34:30 PM", - "status": "FINISHED", - "progressUpdateIntervalMs": 500 - }, - { - "text": "%flinkMahout\nval mxRnd \u003d Matrices.symmetricUniformView(5000, 2, 1234)\nval drmRand \u003d drmParallelize(mxRnd)\n\n\nval drmSin \u003d drmRand.mapBlock() {case (keys, block) \u003d\u003e \n val blockB \u003d block.like()\n for (i \u003c- 0 until block.nrow) {\n blockB(i, 0) \u003d block(i, 0) \n blockB(i, 1) \u003d Math.sin((block(i, 0) * 8))\n }\n keys -\u003e blockB\n}\n\nresourcePool.put(\"flinkSinDrm\", drm.drmSampleToTSV(drmSin, 0.85))", - "dateUpdated": "Sep 28, 2016 1:52:44 PM", - "config": { - "colWidth": 6.0, - "enabled": true, - "editorMode": "ace/mode/scala", - "results": [ - { - "graph": { - "mode": "table", - "height": 284.0, - "optionOpen": false, - "keys": [], - "values": [], - "groups": [], - "scatter": {}, - "map": { - "baseMapType": "Streets", - "isOnline": true, - "pinCols": [] - } - } - } - ] - }, - "settings": { - "params": {}, - "forms": {} - }, - "apps": [], - "jobName": "paragraph_1475020580886_2102494975", - "id": "20160927-175620_816809523", - "results": { - "code": "SUCCESS", - "msg": [ - { - "type": "TEXT", - "data": "mxRnd: org.apache.mahout.math.Matrix \u003d \n{\n 0 \u003d\u003e\t{0:0.4586377101191827,1:0.07261898163580698}\n 1 \u003d\u003e\t{0:0.48977896201757654,1:0.2695201068510176}\n 2 \u003d\u003e\t{0:0.33215452109376786,1:0.2148377346657124}\n 3 \u003d\u003e\t{0:0.4497098649240723,1:0.4331127334380502}\n 4 \u003d\u003e\t{0:-0.03782634247193647,1:-0.32353833540588983}\n 5 \u003d\u003e\t{0:0.15137106418749705,1:0.422446220403861}\n 6 \u003d\u003e\t{0:0.2714115385692545,1:-0.4495233989067956}\n 7 \u003d\u003e\t{0:0.02468155133492185,1:0.49474128114887833}\n 8 \u003d\u003e\t{0:-0.2269662536373416,1:-0.14808249195411455}\n 9 \u003d\u003e\t{0:0.050870692759856756,1:-0.4797329808849356}\n... }\ndrmRand: org.apache.mahout.math.drm.CheckpointedDrm[Int] \u003d org.apache.mahout.flinkbindings.drm.CheckpointedFlinkDrm@72c5b7be\ndrmSin: org.apache.mahout.math.drm.DrmLike[Int] \u003d OpMapBlock(org.apache.mahout.flinkbindings.drm.CheckpointedFlinkDrm@72c5b7be,\u003cfunction1\u003e,-1,-1,true)\n(2,5000)\n" - } - ] - }, - "dateCreated": "Sep 27, 2016 5:56:20 AM", - "dateStarted": "Sep 28, 2016 1:42:42 PM", - "dateFinished": "Sep 28, 2016 1:42:52 PM", - "status": "FINISHED", - "progressUpdateIntervalMs": 500 - }, - { - "text": "%sparkMahout\nval mxRnd \u003d Matrices.symmetricUniformView(5000, 2, 1234)\nval drmRand \u003d drmParallelize(mxRnd)\n\n\nval drmSin \u003d drmRand.mapBlock() {case (keys, block) \u003d\u003e \n val blockB \u003d block.like()\n for (i \u003c- 0 until block.nrow) {\n blockB(i, 0) \u003d block(i, 0) \n blockB(i, 1) \u003d Math.sin((block(i, 0) * 8))\n }\n keys -\u003e blockB\n}\n\nz.put(\"sparkSinDrm\", org.apache.mahout.math.drm.drmSampleToTSV(drmSin, 0.85))\n", - "dateUpdated": "Sep 27, 2016 6:38:39 AM", - "config": { - "colWidth": 6.0, - "enabled": true, - "editorMode": "ace/mode/scala", - "results": [ - { - "graph": { - "mode": "table", - "height": 300.0, - "optionOpen": false, - "keys": [], - "values": [], - "groups": [], - "scatter": {}, - "map": { - "baseMapType": "Streets", - "isOnline": true, - "pinCols": [] - } - } - } - ] - }, - "settings": { - "params": {}, - "forms": {} - }, - "apps": [], - "jobName": "paragraph_1475021390512_-2030189316", - "id": "20160927-180950_1754833838", - "results": { - "code": "SUCCESS", - "msg": [ - { - "type": "TEXT", - "data": "\n\n\n\n\n\n\n\n\n\n\n\n\nmxRnd: org.apache.mahout.math.Matrix \u003d \n{\n 0 \u003d\u003e\t{0:0.4586377101191827,1:0.07261898163580698}\n 1 \u003d\u003e\t{0:0.48977896201757654,1:0.2695201068510176}\n 2 \u003d\u003e\t{0:0.33215452109376786,1:0.2148377346657124}\n 3 \u003d\u003e\t{0:0.4497098649240723,1:0.4331127334380502}\n 4 \u003d\u003e\t{0:-0.03782634247193647,1:-0.32353833540588983}\n 5 \u003d\u003e\t{0:0.15137106418749705,1:0.422446220403861}\n 6 \u003d\u003e\t{0:0.2714115385692545,1:-0.4495233989067956}\n 7 \u003d\u003e\t{0:0.02468155133492185,1:0.49474128114887833}\n 8 \u003d\u003e\t{0:-0.2269662536373416,1:-0.14808249195411455}\n 9 \u003d\u003e\t{0:0.050870692759856756,1:-0.4797329808849356}\n... }\n\ndrmRand: org.apache.mahout.math.drm.CheckpointedDrm[Int] \u003d org.apache.mahout.sparkbindings.drm.CheckpointedDrmSpark@1d6a6ecf\n\ndrmSin: org.apache.mahout.math.drm.DrmLike[Int] \u003d OpMapBlock(org.apache.mahout.sparkbindings.drm.CheckpointedDrmSpark@1d6a6ecf,\u003cfunction1\u003e,-1,-1,true)\n" - } - ] - }, - "dateCreated": "Sep 27, 2016 6:09:50 AM", - "dateStarted": "Sep 27, 2016 6:38:39 AM", - "dateFinished": "Sep 27, 2016 6:38:40 AM", - "status": "FINISHED", - "progressUpdateIntervalMs": 500 - }, - { - "text": "%spark.r {\"imageWidth\": \"400px\"}\n\nlibrary(\"ggplot2\")\n\nflinkSinStr \u003d z.get(\"flinkSinDrm\")\nsparkSinStr \u003d z.get(\"sparkSinDrm\")\n\nflinkData \u003c- read.table(text\u003d flinkSinStr, sep\u003d\"\\t\", header\u003dFALSE)\nsparkData \u003c- read.table(text\u003d sparkSinStr, sep\u003d\"\\t\", header\u003dFALSE)\n\nplot(flinkData, col\u003d\"red\")\n# Graph trucks with red dashed line and square points\npoints(sparkData, col\u003d\"blue\")\n\n# Create a title with a red, bold/italic font\ntitle(main\u003d\"Sampled Mahout Sin Graph in R\", col.main\u003d\"black\", font.main\u003d4)\n\nlegend(\"bottomright\", c(\"Apache Flink\", \"Apache Spark\"), col\u003d c(\"red\", \"blue\"), pch\u003d c(22, 22)) \n\n", - "dateUpdated": "Sep 28, 2016 1:52:26 PM", - "config": { - "colWidth": 6.0, - "enabled": true, - "editorMode": "ace/mode/r", - "results": [ - { - "graph": { - "mode": "table", - "height": 300.0, - "optionOpen": false, - "keys": [], - "values": [], - "groups": [], - "scatter": {}, - "map": { - "baseMapType": "Streets", - "isOnline": true, - "pinCols": [] - } - } - } - ] - }, - "settings": { - "params": {}, - "forms": {} - }, - "apps": [], - "jobName": "paragraph_1475021654999_1062405375", - "id": "20160927-181414_1420533932", - "results": { - "code": "SUCCESS", - "msg": [ - { - "type": "HTML", - "data": "\u003cp\u003e\u003cimg src\u003d\"\" alt\u003d\"plot of chunk unnamed-chunk-1\" width\u003d\"400px\" /\u003e\u003c/p\u003e" - } - ] - }, - "dateCreated": "Sep 27, 2016 6:14:14 AM", - "dateStarted": "Sep 27, 2016 6:42:20 AM", - "dateFinished": "Sep 27, 2016 6:42:20 AM", - "status": "FINISHED", - "progressUpdateIntervalMs": 500 - }, - { - "title": "Create a Gaussian Matrix", - "text": "%flinkMahout\n\nval mxRnd3d \u003d Matrices.symmetricUniformView(5000, 3, 1234)\nval drmRand3d \u003d drmParallelize(mxRnd3d)\n\nval drmGauss \u003d drmRand3d.mapBlock() {case (keys, block) \u003d\u003e\n val blockB \u003d block.like()\n for (i \u003c- 0 until block.nrow) {\n val x: Double \u003d block(i, 0)\n val y: Double \u003d block(i, 1)\n val z: Double \u003d block(i, 2)\n\n blockB(i, 0) \u003d x\n blockB(i, 1) \u003d y\n blockB(i, 2) \u003d Math.exp(-((Math.pow(x, 2)) + (Math.pow(y, 2)))/2)\n }\n keys -\u003e blockB\n}\n\nresourcePool.put(\"flinkGaussDrm\", drm.drmSampleToTSV(drmGauss, 50.0))", - "dateUpdated": "Sep 28, 2016 1:53:22 PM", - "config": { - "colWidth": 6.0, - "enabled": true, - "editorMode": "ace/mode/scala", - "tableHide": true, - "title": true, - "results": [ - { - "graph": { - "mode": "table", - "height": 300.0, - "optionOpen": false, - "keys": [], - "values": [], - "groups": [], - "scatter": {}, - "map": { - "baseMapType": "Streets", - "isOnline": true, - "pinCols": [] - } - } - } - ] - }, - "settings": { - "params": {}, - "forms": {} - }, - "apps": [], - "jobName": "paragraph_1475021740078_127388926", - "id": "20160927-181540_1706054053", - "results": { - "code": "SUCCESS", - "msg": [ - { - "type": "TEXT", - "data": "mxRnd3d: org.apache.mahout.math.Matrix \u003d \n{\n 0 \u003d\u003e\t{0:0.4586377101191827,1:0.07261898163580698,2:-0.4120814898385057}\n 1 \u003d\u003e\t{0:0.48977896201757654,1:0.2695201068510176,2:0.2035624121801051}\n 2 \u003d\u003e\t{0:0.33215452109376786,1:0.2148377346657124,2:0.22923597484837382}\n 3 \u003d\u003e\t{0:0.4497098649240723,1:0.4331127334380502,2:-0.26063522630725094}\n 4 \u003d\u003e\t{0:-0.03782634247193647,1:-0.32353833540588983,2:-0.4423256266785404}\n 5 \u003d\u003e\t{0:0.15137106418749705,1:0.422446220403861,2:-0.20452218901606223}\n 6 \u003d\u003e\t{0:0.2714115385692545,1:-0.4495233989067956,2:0.13402344186662743}\n 7 \u003d\u003e\t{0:0.02468155133492185,1:0.49474128114887833,2:-0.484577970998106}\n 8 \u003d\u003e\t{0:-0.2269662536373416,1:-0.14808249195411455,2:-0.16159073199184967}\n 9 \u003d\u003e\t{0:0.050870692759856756,1:-0.4797329808849356,2:0.30230792168515175}\n... }\ndrmRand3d: org.apache.mahout.math.drm.CheckpointedDrm[Int] \u003d org.apache.mahout.flinkbindings.drm.CheckpointedFlinkDrm@448a1f4e\ndrmGauss: org.apache.mahout.math.drm.DrmLike[Int] \u003d OpMapBlock(org.apache.mahout.flinkbindings.drm.CheckpointedFlinkDrm@448a1f4e,\u003cfunction1\u003e,-1,-1,true)\n(3,5000)\n" - } - ] - }, - "dateCreated": "Sep 27, 2016 6:15:40 AM", - "dateStarted": "Sep 28, 2016 1:50:54 PM", - "dateFinished": "Sep 28, 2016 1:51:00 PM", - "status": "FINISHED", - "progressUpdateIntervalMs": 500 - }, - { - "text": "%spark.r {\"imageWidth\": \"400px\"}\n\nlibrary(scatterplot3d)\n\n\nflinkGaussStr \u003d z.get(\"flinkGaussDrm\")\nflinkData \u003c- read.table(text\u003d flinkGaussStr, sep\u003d\"\\t\", header\u003dFALSE)\n\nscatterplot3d(flinkData, color\u003d\"green\")\n\n", - "dateUpdated": "Sep 28, 2016 1:54:56 PM", - "config": { - "colWidth": 6.0, - "enabled": true, - "editorMode": "ace/mode/r", - "results": [ - { - "graph": { - "mode": "table", - "height": 300.0, - "optionOpen": false, - "keys": [], - "values": [], - "groups": [], - "scatter": {}, - "map": { - "baseMapType": "Streets", - "isOnline": true, - "pinCols": [] - } - } - } - ] - }, - "settings": { - "params": {}, - "forms": {} - }, - "apps": [], - "jobName": "paragraph_1475023444293_-1038534869", - "id": "20160927-184404_773885252", - "results": { - "code": "SUCCESS", - "msg": [ - { - "type": "HTML", - "data": "\u003cp\u003e\u003cimg src\u003d\"\u003d\u003d\" alt\u003d\"plot of chunk unnamed-chunk-1\" width\u003d\"400px\" /\u003e\u003c/p\u003e" - } - ] - }, - "dateCreated": "Sep 27, 2016 6:44:04 AM", - "dateStarted": "Sep 28, 2016 1:52:10 PM", - "dateFinished": "Sep 28, 2016 1:52:10 PM", - "status": "FINISHED", - "progressUpdateIntervalMs": 500 - }, - { - "text": "%md\n\n**NOTE** To install `scatterplot3d` on Ubuntu use:\n\n```sh\nsudo apt-get install r-cran-scatterplot3d\n```\n\n", - "dateUpdated": "Sep 28, 2016 1:54:37 PM", - "config": { - "colWidth": 6.0, - "enabled": true, - "editorMode": "ace/mode/markdown", - "editorHide": true, - "results": [ - { - "graph": { - "mode": "table", - "height": 300.0, - "optionOpen": false, - "keys": [], - "values": [], - "groups": [], - "scatter": {}, - "map": { - "baseMapType": "Streets", - "isOnline": true, - "pinCols": [] - } - } - } - ] - }, - "settings": { - "params": {}, - "forms": {} - }, - "apps": [], - "jobName": "paragraph_1475091302527_1223653372", - "id": "20160928-133502_1743267136", - "results": { - "code": "SUCCESS", - "msg": [ - { - "type": "HTML", - "data": "\u003cp\u003e\u003cstrong\u003eNOTE\u003c/strong\u003e To install \u003ccode\u003escatterplot3d\u003c/code\u003e on Ubuntu use:\u003c/p\u003e\n\u003cpre\u003e\u003ccode class\u003d\"sh\"\u003esudo apt-get install r-cran-scatterplot3d\n\u003c/code\u003e\u003c/pre\u003e\n" - } - ] - }, - "dateCreated": "Sep 28, 2016 1:35:02 AM", - "dateStarted": "Sep 28, 2016 1:54:32 PM", - "dateFinished": "Sep 28, 2016 1:54:33 PM", - "status": "FINISHED", - "progressUpdateIntervalMs": 500 - }, - { - "text": "%md\n", - "dateUpdated": "Sep 28, 2016 1:54:32 PM", - "config": {}, - "settings": { - "params": {}, - "forms": {} - }, - "apps": [], - "jobName": "paragraph_1475092472681_-955530461", - "id": "20160928-135432_2099340527", - "dateCreated": "Sep 28, 2016 1:54:32 PM", - "status": "READY", - "progressUpdateIntervalMs": 500 - } - ], - "name": "Zeppelin Tutorial/Using Mahout", - "id": "2BYEZ5EVK", - "angularObjects": { - "2C6WUGPNH:shared_process": [], - "2C4A8RJNB:shared_process": [], - "2C4DTK2ZT:shared_process": [], - "2C6XKJWBR:shared_process": [], - "2C6AHZPMK:shared_process": [], - "2C5SU66WQ:shared_process": [], - "2C6AMJ98Q:shared_process": [], - "2C4AJZK72:shared_process": [], - "2C3STPSD7:shared_process": [], - "2C4FJN9CK:shared_process": [], - "2C3CW6JBY:shared_process": [], - "2C5UPQX6Q:shared_process": [], - "2C5873KN4:shared_process": [], - "2C5719XN4:shared_process": [], - "2C52DE5G3:shared_process": [], - "2C4G28E63:shared_process": [], - "2C6CU96BC:shared_process": [], - "2C49A6WY3:shared_process": [], - "2C3NE73HG:shared_process": [] - }, - "config": {}, - "info": {} -} diff --git a/smart-zeppelin/notebook/2C2AUG798/note.json b/smart-zeppelin/notebook/2C2AUG798/note.json deleted file mode 100644 index 23ab3df67c8..00000000000 --- a/smart-zeppelin/notebook/2C2AUG798/note.json +++ /dev/null @@ -1,779 +0,0 @@ -{ - "paragraphs": [ - { - "text": "%md\n## Introduction\nIn this tutorial we will go through some of the basic features of Zeppelin\u0027s built-in matplotlib integration. \n\n### Prerequisites\n`matplotlib` must be installed to your local python installation. (use `pip install matplotlib` or `conda install matplotlib` if you have `conda`). Additionally, you will need Zeppelin\u0027s matplotlib backend files which are usually found in `$ZEPPELIN_HOME/lib/python`. Although Zeppelin should automatically find this directory, it might be a good idea to add it to your `PYTHONPATH` just in case. \n\n### Interpreters\nMost of the examples shown in this tutorial can be used interchangeably with either the `python` or `pyspark` interpreters. Iterative plotting using the Angular Display System is currently only available for `pyspark`, but this functionality will eventually be added to the base `python` interpreter. \n\n### macOS\nMake sure locale is set, to avoid `ValueError: unknown locale: UTF-8`\n\n### virtualenv\nIn case you want to use virtualenv or conda env:\n - configure python interpreter property -\u003e `absolute/path/to/venv/bin/python`\n - see *Working with Matplotlib in Virtual environments* in the [Matplotlib FAQ](http://matplotlib.org/faq/virtualenv_faq.html)\n \n### A simple example\nLet\u0027s start by making a very simple line plot:", - "user": "anonymous", - "dateUpdated": "Dec 17, 2016 3:33:25 PM", - "config": { - "tableHide": false, - "colWidth": 12.0, - "editorMode": "ace/mode/text", - "editorHide": true, - "enabled": true, - "results": [ - { - "graph": { - "mode": "table", - "height": 300.0, - "optionOpen": false, - "keys": [], - "values": [], - "groups": [], - "scatter": {} - } - } - ], - "editorSetting": { - "language": "text", - "editOnDblClick": false - } - }, - "settings": { - "params": {}, - "forms": {} - }, - "apps": [], - "jobName": "paragraph_1478123627954_-1473548609", - "id": "20160614-174657_1772993700", - "results": { - "code": "SUCCESS", - "msg": [ - { - "type": "HTML", - "data": "\u003cdiv class\u003d\"markdown-body\"\u003e\n\u003ch2\u003eIntroduction\u003c/h2\u003e\n\u003cp\u003eIn this tutorial we will go through some of the basic features of Zeppelin\u0026rsquo;s built-in matplotlib integration. \u003c/p\u003e\n\u003ch3\u003ePrerequisites\u003c/h3\u003e\n\u003cp\u003e\u003ccode\u003ematplotlib\u003c/code\u003e must be installed to your local python installation. (use \u003ccode\u003epip install matplotlib\u003c/code\u003e or \u003ccode\u003econda install matplotlib\u003c/code\u003e if you have \u003ccode\u003econda\u003c/code\u003e). Additionally, you will need Zeppelin\u0026rsquo;s matplotlib backend files which are usually found in \u003ccode\u003e$ZEPPELIN_HOME/interpreter/lib/python\u003c/code\u003e. Although Zeppelin should automatically find this directory, it might be a good idea to add it to your \u003ccode\u003ePYTHONPATH\u003c/code\u003e just in case. \u003c/p\u003e\n\u003ch3\u003eInterpreters\u003c/h3\u003e\n\u003cp\u003eMost of the examples shown in this tutorial can be used interchangeably with either the \u003ccode\u003epython\u003c/code\u003e or \u003ccode\u003epyspark\u003c/code\u003e interpreters. Iterative plotting using the Angular Display System is currently only available for \u003ccode\u003epyspark\u003c/code\u003e, but this functionality will eventually be added to the base \u003ccode\u003epython\u003c/code\u003e interpreter. \u003c/p\u003e\n\u003ch3\u003emacOS\u003c/h3\u003e\n\u003cp\u003eMake sure locale is set, to avoid \u003ccode\u003eValueError: unknown locale: UTF-8\u003c/code\u003e\u003c/p\u003e\n\u003ch3\u003evirtualenv\u003c/h3\u003e\n\u003cp\u003eIn case you want to use virtualenv or conda env:\u003cbr/\u003e - configure python interpreter property -\u0026gt; \u003ccode\u003eabsolute/path/to/venv/bin/python\u003c/code\u003e\u003cbr/\u003e - see \u003cem\u003eWorking with Matplotlib in Virtual environments\u003c/em\u003e in the \u003ca href\u003d\"http://matplotlib.org/faq/virtualenv_faq.html\"\u003eMatplotlib FAQ\u003c/a\u003e\u003c/p\u003e\n\u003ch3\u003eA simple example\u003c/h3\u003e\n\u003cp\u003eLet\u0026rsquo;s start by making a very simple line plot:\u003c/p\u003e\n\u003c/div\u003e" - } - ] - }, - "dateCreated": "Nov 2, 2016 2:53:47 PM", - "dateStarted": "Dec 17, 2016 3:33:25 PM", - "dateFinished": "Dec 17, 2016 3:33:25 PM", - "status": "FINISHED", - "progressUpdateIntervalMs": 500 - }, - { - "text": "%python\nimport matplotlib.pyplot as plt\nplt.plot([1, 2, 3])", - "dateUpdated": "Nov 2, 2016 2:53:47 PM", - "config": { - "colWidth": 12.0, - "editorMode": "ace/mode/python", - "enabled": true, - "results": [ - { - "graph": { - "mode": "table", - "height": 300.0, - "optionOpen": false, - "keys": [], - "values": [], - "groups": [], - "scatter": {} - } - } - ] - }, - "settings": { - "params": {}, - "forms": {} - }, - "apps": [], - "jobName": "paragraph_1478123627958_-1475087605", - "id": "20161101-192232_289486976", - "results": { - "code": "SUCCESS", - "msg": [ - { - "type": "HTML", - "data": "\u003cdiv style\u003d\u0027width:auto;height:auto\u0027\u003e\u003cimg src\u003d\u003d\u003d style\u003d\u0027width\u003dauto;height:auto\u0027\u003e\u003cdiv\u003e\n" - } - ] - }, - "dateCreated": "Nov 2, 2016 2:53:47 PM", - "status": "READY", - "errorMessage": "", - "progressUpdateIntervalMs": 500 - }, - { - "text": "%md\nNotice how an explicit call to `show()` is not necessary. This is accomplished via a post-execute hook which tells Zeppelin to plot all currently open matplotlib figures after executing the rest of the paragraph.\n### Plotting multiple figures\nWe can easily plot multiple figures at once too:", - "dateUpdated": "Nov 2, 2016 2:53:47 PM", - "config": { - "colWidth": 12.0, - "editorMode": "ace/mode/markdown", - "editorHide": true, - "enabled": true, - "results": [ - { - "graph": { - "mode": "table", - "height": 300.0, - "optionOpen": false, - "keys": [], - "values": [], - "groups": [], - "scatter": {} - } - } - ] - }, - "settings": { - "params": {}, - "forms": {} - }, - "apps": [], - "jobName": "paragraph_1478123627958_-1475087605", - "id": "20160617-002131_1552178409", - "results": { - "code": "SUCCESS", - "msg": [ - { - "type": "HTML", - "data": "\u003cp\u003eNotice how an explicit call to \u003ccode\u003eshow()\u003c/code\u003e is not necessary. This is accomplished via a post-execute hook which tells Zeppelin to plot all currently open matplotlib figures after executing the rest of the paragraph.\u003c/p\u003e\n\u003ch3\u003ePlotting multiple figures\u003c/h3\u003e\n\u003cp\u003eWe can easily plot multiple figures at once too:\u003c/p\u003e\n" - } - ] - }, - "dateCreated": "Nov 2, 2016 2:53:47 PM", - "status": "READY", - "errorMessage": "", - "progressUpdateIntervalMs": 500 - }, - { - "text": "%python\n# Figure 1\nplt.plot([1, 2, 3])\n\n# Figure 2\nplt.figure()\nplt.plot([3, 2, 1])", - "dateUpdated": "Nov 2, 2016 2:53:47 PM", - "config": { - "colWidth": 12.0, - "editorMode": "ace/mode/python", - "enabled": true, - "results": [ - { - "graph": { - "mode": "table", - "height": 300.0, - "optionOpen": false, - "keys": [], - "values": [], - "groups": [], - "scatter": {} - } - } - ] - }, - "settings": { - "params": {}, - "forms": {} - }, - "apps": [], - "jobName": "paragraph_1478123627959_-1475472354", - "id": "20161101-193533_2096366908", - "results": { - "code": "SUCCESS", - "msg": [ - { - "type": "HTML", - "data": "\u003cdiv style\u003d\u0027width:auto;height:auto\u0027\u003e\u003cimg src\u003d\u003d\u003d style\u003d\u0027width\u003dauto;height:auto\u0027\u003e\u003cdiv\u003e\n\u003cdiv style\u003d\u0027width:auto;height:auto\u0027\u003e\u003cimg src\u003d style\u003d\u0027width\u003dauto;height:auto\u0027\u003e\u003cdiv\u003e\n" - } - ] - }, - "dateCreated": "Nov 2, 2016 2:53:47 PM", - "status": "READY", - "errorMessage": "", - "progressUpdateIntervalMs": 500 - }, - { - "text": "%md\n### Changing the default inline plotting behavior\nBoth the `python` and `pyspark` include a built-in function for changing some default inline plotting behavior. For example, we can change the default size of each figure in pixels to 400x300 in svg format using: ", - "dateUpdated": "Nov 2, 2016 2:53:47 PM", - "config": { - "tableHide": false, - "colWidth": 12.0, - "editorMode": "ace/mode/markdown", - "editorHide": true, - "enabled": true, - "results": [ - { - "graph": { - "mode": "table", - "height": 300.0, - "optionOpen": false, - "keys": [], - "values": [], - "groups": [], - "scatter": {} - } - } - ] - }, - "settings": { - "params": {}, - "forms": {} - }, - "apps": [], - "jobName": "paragraph_1478123627959_-1475472354", - "id": "20160614-174421_274483707", - "results": { - "code": "SUCCESS", - "msg": [ - { - "type": "HTML", - "data": "\u003ch3\u003eChanging the default inline plotting behavior\u003c/h3\u003e\n\u003cp\u003eBoth the \u003ccode\u003epython\u003c/code\u003e and \u003ccode\u003epyspark\u003c/code\u003e include a built-in function for changing some default inline plotting behavior. For example, we can change the default size of each figure in pixels to 400x300 in svg format using:\u003c/p\u003e\n" - } - ] - }, - "dateCreated": "Nov 2, 2016 2:53:47 PM", - "status": "READY", - "errorMessage": "", - "progressUpdateIntervalMs": 500 - }, - { - "text": "%python\nz.configure_mpl(width\u003d400, height\u003d300, fmt\u003d\u0027svg\u0027)\nplt.plot([1, 2, 3])", - "dateUpdated": "Nov 2, 2016 2:53:47 PM", - "config": { - "colWidth": 12.0, - "editorMode": "ace/mode/scala", - "enabled": true, - "results": [ - { - "graph": { - "mode": "table", - "height": 300.0, - "optionOpen": false, - "keys": [], - "values": [], - "groups": [], - "scatter": {} - } - } - ] - }, - "settings": { - "params": { - "f1": "defaultValue" - }, - "forms": {} - }, - "apps": [], - "jobName": "paragraph_1478123627959_-1475472354", - "id": "20160616-234947_579056637", - "results": { - "code": "SUCCESS", - "msg": [ - { - "type": "HTML", - "data": "\u003cdiv style\u003d\u0027width:auto;height:auto\u0027\u003e\u003cimg src\u003d\u003d style\u003d\u0027width\u003dauto;height:auto\u0027\u003e\u003cdiv\u003e\n" - } - ] - }, - "dateCreated": "Nov 2, 2016 2:53:47 PM", - "status": "READY", - "errorMessage": "", - "progressUpdateIntervalMs": 500 - }, - { - "text": "%md\n### Iteratively updating a plot\n#### (a) Using multiple plots\nNow let\u0027s show an example where we update each element of the plot in a separate paragraph. However, you may have noticed that each matplotlib figure instance gets closed immediately after its shown. To fix this, we set the `close` property to `False` in our configuration:", - "dateUpdated": "Nov 2, 2016 2:53:47 PM", - "config": { - "colWidth": 12.0, - "editorMode": "ace/mode/markdown", - "editorHide": true, - "enabled": true, - "results": [ - { - "graph": { - "mode": "table", - "height": 394.0, - "optionOpen": false, - "keys": [], - "values": [], - "groups": [], - "scatter": {} - } - } - ] - }, - "settings": { - "params": {}, - "forms": {} - }, - "apps": [], - "jobName": "paragraph_1478123627960_-1477396098", - "id": "20160617-140439_1111727405", - "results": { - "code": "SUCCESS", - "msg": [ - { - "type": "HTML", - "data": "\u003ch3\u003eIteratively updating a plot\u003c/h3\u003e\n\u003ch4\u003e(a) Using multiple plots\u003c/h4\u003e\n\u003cp\u003eNow let\u0027s show an example where we update each element of the plot in a separate paragraph. However, you may have noticed that each matplotlib figure instance gets closed immediately after its shown. To fix this, we set the \u003ccode\u003eclose\u003c/code\u003e property to \u003ccode\u003eFalse\u003c/code\u003e in our configuration:\u003c/p\u003e\n" - } - ] - }, - "dateCreated": "Nov 2, 2016 2:53:47 PM", - "status": "READY", - "errorMessage": "", - "progressUpdateIntervalMs": 500 - }, - { - "title": "First line", - "text": "%python\nplt.close() # Added here to reset the first plot when rerunning the paragraph\nz.configure_mpl(width\u003d600, height\u003d400, fmt\u003d\u0027png\u0027, close\u003dFalse)\nplt.plot([1, 2, 3], label\u003dr\u0027$y\u003dx$\u0027)", - "dateUpdated": "Nov 2, 2016 2:53:47 PM", - "config": { - "colWidth": 12.0, - "title": true, - "enabled": true, - "results": [ - { - "graph": { - "mode": "table", - "height": 389.0, - "optionOpen": false, - "keys": [], - "values": [], - "groups": [], - "scatter": {} - } - } - ] - }, - "settings": { - "params": {}, - "forms": {} - }, - "apps": [], - "jobName": "paragraph_1478123627960_-1477396098", - "id": "20161101-195657_1336292109", - "results": { - "code": "SUCCESS", - "msg": [ - { - "type": "HTML", - "data": "\u003cdiv style\u003d\u0027width:auto;height:auto\u0027\u003e\u003cimg src\u003d\u003d\u003d style\u003d\u0027width\u003dauto;height:auto\u0027\u003e\u003cdiv\u003e\n" - } - ] - }, - "dateCreated": "Nov 2, 2016 2:53:47 PM", - "status": "READY", - "errorMessage": "", - "progressUpdateIntervalMs": 500 - }, - { - "title": "Second line", - "text": "%python\nplt.plot([3, 2, 1], label\u003dr\u0027$y\u003d3-x$\u0027)", - "dateUpdated": "Nov 2, 2016 2:53:47 PM", - "config": { - "colWidth": 12.0, - "editorMode": "ace/mode/python", - "title": true, - "enabled": true, - "results": [ - { - "graph": { - "mode": "table", - "height": 289.0, - "optionOpen": false, - "keys": [], - "values": [], - "groups": [], - "scatter": {} - } - } - ] - }, - "settings": { - "params": {}, - "forms": {} - }, - "apps": [], - "jobName": "paragraph_1478123627961_-1477780847", - "id": "20161101-195937_907325325", - "results": { - "code": "SUCCESS", - "msg": [ - { - "type": "HTML", - "data": "\u003cdiv style\u003d\u0027width:auto;height:auto\u0027\u003e\u003cimg src\u003d\u003d\u003d style\u003d\u0027width\u003dauto;height:auto\u0027\u003e\u003cdiv\u003e\n" - } - ] - }, - "dateCreated": "Nov 2, 2016 2:53:47 PM", - "status": "READY", - "errorMessage": "", - "progressUpdateIntervalMs": 500 - }, - { - "title": "Label axes", - "text": "%python\nplt.xlabel(r\u0027$x$\u0027, fontsize\u003d20)\nplt.ylabel(r\u0027$y$\u0027, fontsize\u003d20)", - "dateUpdated": "Nov 2, 2016 2:53:47 PM", - "config": { - "colWidth": 12.0, - "editorMode": "ace/mode/python", - "title": true, - "enabled": true, - "results": [ - { - "graph": { - "mode": "table", - "height": 300.0, - "optionOpen": false, - "keys": [], - "values": [], - "groups": [], - "scatter": {} - } - } - ] - }, - "settings": { - "params": {}, - "forms": {} - }, - "apps": [], - "jobName": "paragraph_1478123627962_-1476626600", - "id": "20161101-200014_2113468597", - "results": { - "code": "SUCCESS", - "msg": [ - { - "type": "HTML", - "data": "\u003cdiv style\u003d\u0027width:auto;height:auto\u0027\u003e\u003cimg src\u003d style\u003d\u0027width\u003dauto;height:auto\u0027\u003e\u003cdiv\u003e\n" - } - ] - }, - "dateCreated": "Nov 2, 2016 2:53:47 PM", - "status": "READY", - "errorMessage": "", - "progressUpdateIntervalMs": 500 - }, - { - "title": "Add legend", - "text": "%python\nplt.legend(loc\u003d\u0027upper center\u0027, fontsize\u003d20)", - "dateUpdated": "Nov 2, 2016 2:53:47 PM", - "config": { - "colWidth": 12.0, - "editorMode": "ace/mode/python", - "title": true, - "enabled": true, - "results": [ - { - "graph": { - "mode": "table", - "height": 86.0, - "optionOpen": false, - "keys": [], - "values": [], - "groups": [], - "scatter": {} - } - } - ] - }, - "settings": { - "params": {}, - "forms": {} - }, - "apps": [], - "jobName": "paragraph_1478123627962_-1476626600", - "id": "20161101-200141_1493024813", - "results": { - "code": "SUCCESS", - "msg": [ - { - "type": "HTML", - "data": "\u003cdiv style\u003d\u0027width:auto;height:auto\u0027\u003e\u003cimg src\u003d\u003d\u003d style\u003d\u0027width\u003dauto;height:auto\u0027\u003e\u003cdiv\u003e\n" - } - ] - }, - "dateCreated": "Nov 2, 2016 2:53:47 PM", - "status": "READY", - "errorMessage": "", - "progressUpdateIntervalMs": 500 - }, - { - "title": "Add title", - "text": "%python\nplt.title(\u0027Inline plotting example\u0027, fontsize\u003d20)", - "dateUpdated": "Nov 2, 2016 2:53:47 PM", - "config": { - "colWidth": 12.0, - "editorMode": "ace/mode/python", - "title": true, - "enabled": true, - "results": [ - { - "graph": { - "mode": "table", - "height": 300.0, - "optionOpen": false, - "keys": [], - "values": [], - "groups": [], - "scatter": {} - } - } - ] - }, - "settings": { - "params": {}, - "forms": {} - }, - "apps": [], - "jobName": "paragraph_1478123627963_-1477011349", - "id": "20161101-200445_78775142", - "results": { - "code": "SUCCESS", - "msg": [ - { - "type": "HTML", - "data": "\u003cdiv style\u003d\u0027width:auto;height:auto\u0027\u003e\u003cimg src\u003d style\u003d\u0027width\u003dauto;height:auto\u0027\u003e\u003cdiv\u003e\n" - } - ] - }, - "dateCreated": "Nov 2, 2016 2:53:47 PM", - "status": "READY", - "errorMessage": "", - "progressUpdateIntervalMs": 500 - }, - { - "text": "%md\n####(b) Using a single plot\nTo iteratively update a single plot, we can leverage Zeppelin\u0027s built-in Angular Display System. Currently this feature is only available for the `pyspark` interpreter for raster (png and jpg) formats. To enable this, we must set a special `angular` flag to `True` in our configuration:", - "dateUpdated": "Nov 2, 2016 2:53:47 PM", - "config": { - "colWidth": 12.0, - "editorMode": "ace/mode/markdown", - "editorHide": true, - "enabled": true, - "results": [ - { - "graph": { - "mode": "table", - "height": 300.0, - "optionOpen": false, - "keys": [], - "values": [], - "groups": [], - "scatter": {} - } - } - ] - }, - "settings": { - "params": {}, - "forms": {} - }, - "apps": [], - "jobName": "paragraph_1478123627963_-1477011349", - "id": "20161101-200541_1283841564", - "results": { - "code": "SUCCESS", - "msg": [ - { - "type": "HTML", - "data": "\u003ch4\u003e(b) Using a single plot\u003c/h4\u003e\n\u003cp\u003eTo iteratively update a single plot, we can leverage Zeppelin\u0027s built-in Angular Display System. Currently this feature is only available for the \u003ccode\u003epyspark\u003c/code\u003e interpreter for raster (png and jpg) formats. To enable this, we must set a special \u003ccode\u003eangular\u003c/code\u003e flag to \u003ccode\u003eTrue\u003c/code\u003e in our configuration.\u003c/p\u003e\n" - } - ] - }, - "dateCreated": "Nov 2, 2016 2:53:47 PM", - "status": "READY", - "errorMessage": "", - "progressUpdateIntervalMs": 500 - }, - { - "title": "First line (figure will be displayed here)", - "text": "%pyspark\nimport matplotlib.pyplot as plt\nplt.close() # Added here to reset the plot when rerunning the paragraph\nz.configure_mpl(angular\u003dTrue, close\u003dFalse)\nplt.plot([1, 2, 3], label\u003dr\u0027$y\u003dx$\u0027)", - "user": "anonymous", - "dateUpdated": "Nov 2, 2016 2:55:37 PM", - "config": { - "colWidth": 7.0, - "editorMode": "ace/mode/python", - "title": true, - "enabled": true, - "results": [ - { - "graph": { - "mode": "table", - "height": 389.0, - "optionOpen": false, - "keys": [], - "values": [], - "groups": [], - "scatter": {} - } - } - ] - }, - "settings": { - "params": {}, - "forms": {} - }, - "apps": [], - "jobName": "paragraph_1478123627963_-1477011349", - "id": "20161101-200754_739212093", - "results": { - "code": "SUCCESS", - "msg": [ - { - "type": "HTML", - "data": "\u003cdiv style\u003d\u0027width:auto;height:auto\u0027\u003e\u003cimg src\u003d\u003d\u003d style\u003d\u0027width\u003dauto;height:auto\u0027\u003e\u003cdiv\u003e\n" - } - ] - }, - "dateCreated": "Nov 2, 2016 2:53:47 PM", - "dateStarted": "Nov 2, 2016 2:54:53 PM", - "dateFinished": "Nov 2, 2016 2:55:04 PM", - "status": "FINISHED", - "progressUpdateIntervalMs": 500 - }, - { - "title": "Second line", - "text": "%pyspark\nplt.plot([3, 2, 1], label\u003dr\u0027$y\u003d3-x$\u0027)", - "dateUpdated": "Nov 2, 2016 2:53:47 PM", - "config": { - "colWidth": 5.0, - "title": true, - "enabled": true, - "results": [] - }, - "settings": { - "params": {}, - "forms": {} - }, - "apps": [], - "jobName": "paragraph_1478123627964_-1478935094", - "id": "20161101-200854_1676504884", - "results": { - "code": "SUCCESS", - "msg": [] - }, - "dateCreated": "Nov 2, 2016 2:53:47 PM", - "status": "READY", - "errorMessage": "", - "progressUpdateIntervalMs": 500 - }, - { - "title": "Label axes", - "text": "%pyspark\nplt.xlabel(r\u0027$x$\u0027, fontsize\u003d20)\nplt.ylabel(r\u0027$y$\u0027, fontsize\u003d20)", - "dateUpdated": "Nov 2, 2016 2:53:47 PM", - "config": { - "colWidth": 5.0, - "title": true, - "enabled": true, - "results": [] - }, - "settings": { - "params": {}, - "forms": {} - }, - "apps": [], - "jobName": "paragraph_1478123627964_-1478935094", - "id": "20161101-200851_314384892", - "results": { - "code": "SUCCESS", - "msg": [] - }, - "dateCreated": "Nov 2, 2016 2:53:47 PM", - "status": "READY", - "errorMessage": "", - "progressUpdateIntervalMs": 500 - }, - { - "title": "Add legend", - "text": "%pyspark\nplt.legend(loc\u003d\u0027upper center\u0027, fontsize\u003d20)", - "dateUpdated": "Nov 2, 2016 2:53:47 PM", - "config": { - "colWidth": 5.0, - "editorMode": "ace/mode/python", - "title": true, - "enabled": true, - "results": [] - }, - "settings": { - "params": {}, - "forms": {} - }, - "apps": [], - "jobName": "paragraph_1478123627964_-1478935094", - "id": "20161101-201552_651686132", - "results": { - "code": "SUCCESS", - "msg": [] - }, - "dateCreated": "Nov 2, 2016 2:53:47 PM", - "status": "READY", - "errorMessage": "", - "progressUpdateIntervalMs": 500 - }, - { - "title": "Add title", - "text": "%pyspark\nplt.title(\u0027Inline plotting example\u0027, fontsize\u003d20)", - "dateUpdated": "Nov 2, 2016 2:53:47 PM", - "config": { - "colWidth": 5.0, - "editorMode": "ace/mode/python", - "title": true, - "enabled": true, - "results": [] - }, - "settings": { - "params": {}, - "forms": {} - }, - "apps": [], - "jobName": "paragraph_1478123627965_-1479319843", - "id": "20161101-202024_1645454710", - "results": { - "code": "SUCCESS", - "msg": [] - }, - "dateCreated": "Nov 2, 2016 2:53:47 PM", - "status": "READY", - "errorMessage": "", - "progressUpdateIntervalMs": 500 - }, - { - "text": "", - "dateUpdated": "Nov 2, 2016 2:53:47 PM", - "config": { - "colWidth": 12.0, - "graph": { - "mode": "table", - "height": 300.0, - "optionOpen": false, - "keys": [], - "values": [], - "groups": [], - "scatter": {} - }, - "enabled": true - }, - "settings": { - "params": {}, - "forms": {} - }, - "apps": [], - "jobName": "paragraph_1478123627965_-1479319843", - "id": "20161102-124716_1703649609", - "dateCreated": "Nov 2, 2016 2:53:47 PM", - "status": "READY", - "errorMessage": "", - "progressUpdateIntervalMs": 500 - } - ], - "name": "Zeppelin Tutorial/Matplotlib (Python • PySpark)", - "id": "2C2AUG798", - "angularObjects": { - "2C6WUGPNH:shared_process": [], - "2C4A8RJNB:shared_process": [], - "2C4DTK2ZT:shared_process": [], - "2C6XKJWBR:shared_process": [], - "2C6AHZPMK:shared_process": [], - "2C5SU66WQ:shared_process": [], - "2C6AMJ98Q:shared_process": [], - "2C4AJZK72:shared_process": [], - "2C3STPSD7:shared_process": [], - "2C4FJN9CK:shared_process": [], - "2C3CW6JBY:shared_process": [], - "2C5UPQX6Q:shared_process": [], - "2C5873KN4:shared_process": [], - "2C5719XN4:shared_process": [], - "2C52DE5G3:shared_process": [], - "2C4G28E63:shared_process": [], - "2C6CU96BC:shared_process": [], - "2C49A6WY3:shared_process": [], - "2C3NE73HG:shared_process": [] - }, - "config": {}, - "info": {} -} diff --git a/smart-zeppelin/notebook/2C35YU814/note.json b/smart-zeppelin/notebook/2C35YU814/note.json deleted file mode 100644 index 09ed8c6e01c..00000000000 --- a/smart-zeppelin/notebook/2C35YU814/note.json +++ /dev/null @@ -1,806 +0,0 @@ -{ - "paragraphs": [ - { - "text": "%md\n### Intro\nThis notebook is an example of how to use **Apache Flink** for processing simple data sets. We will take an open airline data set from [stat-computing.org](http://stat-computing.org) and find out who was the most popular carrier during 1998-2000 years. Next we will build a chart that shows flights distribution by months and look how it changes from year to year. We will use Zeppelin `%table` display system to build charts.", - "user": "anonymous", - "dateUpdated": "Jan 9, 2017 11:55:42 AM", - "config": { - "colWidth": 12.0, - "enabled": true, - "results": {}, - "editorSetting": { - "language": "markdown", - "editOnDblClick": true - }, - "editorMode": "ace/mode/markdown", - "editorHide": true, - "tableHide": false - }, - "settings": { - "params": {}, - "forms": {} - }, - "apps": [], - "jobName": "paragraph_1483952101049_-1120777567", - "id": "20170109-115501_192763014", - "results": { - "code": "SUCCESS", - "msg": [ - { - "type": "HTML", - "data": "\u003cdiv class\u003d\"markdown-body\"\u003e\n\u003ch3\u003eIntro\u003c/h3\u003e\n\u003cp\u003eThis notebook is an example of how to use \u003cstrong\u003eApache Flink\u003c/strong\u003e for processing simple data sets. We will take an open airline data set from \u003ca href\u003d\"http://stat-computing.org\"\u003estat-computing.org\u003c/a\u003e and find out who was the most popular carrier during 1998-2000 years. Next we will build a chart that shows flights distribution by months and look how it changes from year to year. We will use Zeppelin \u003ccode\u003e%table\u003c/code\u003e display system to build charts.\u003c/p\u003e\n\u003c/div\u003e" - } - ] - }, - "dateCreated": "Jan 9, 2017 11:55:01 AM", - "dateStarted": "Jan 9, 2017 11:55:42 AM", - "dateFinished": "Jan 9, 2017 11:55:44 AM", - "status": "FINISHED", - "progressUpdateIntervalMs": 500 - }, - { - "text": "%md\n### Getting the data\nFirst we need to download and unpack the data. We will get three big data sets with flight details (one pack for each year) and a small one with carriers names. In total we will get for about 1,5 GB of data. To be able to process such amount of data it is recommended to increase `shell.command.timeout.millisecs` value in `%sh` interpreter settings up to several minutes. You can find interpreters configuration by clicking on `Interpreter` in a drop-down menu from the top right corner of the Zeppelin web-ui.", - "user": "anonymous", - "dateUpdated": "Jan 9, 2017 11:56:08 AM", - "config": { - "colWidth": 12.0, - "enabled": true, - "results": {}, - "editorSetting": { - "language": "scala", - "editOnDblClick": false - }, - "editorMode": "ace/mode/scala", - "editorHide": true - }, - "settings": { - "params": {}, - "forms": {} - }, - "apps": [], - "jobName": "paragraph_1483952142017_284386712", - "id": "20170109-115542_1487437739", - "results": { - "code": "SUCCESS", - "msg": [ - { - "type": "HTML", - "data": "\u003cdiv class\u003d\"markdown-body\"\u003e\n\u003ch3\u003eGetting the data\u003c/h3\u003e\n\u003cp\u003eFirst we need to download and unpack the data. We will get three big data sets with flight details (one pack for each year) and a small one with carriers names. In total we will get for about 1,5 GB of data. To be able to process such amount of data it is recommended to increase \u003ccode\u003eshell.command.timeout.millisecs\u003c/code\u003e value in \u003ccode\u003e%sh\u003c/code\u003e interpreter settings up to several minutes. You can find interpreters configuration by clicking on \u003ccode\u003eInterpreter\u003c/code\u003e in a drop-down menu from the top right corner of the Zeppelin web-ui.\u003c/p\u003e\n\u003c/div\u003e" - } - ] - }, - "dateCreated": "Jan 9, 2017 11:55:42 AM", - "dateStarted": "Jan 9, 2017 11:56:07 AM", - "dateFinished": "Jan 9, 2017 11:56:07 AM", - "status": "FINISHED", - "progressUpdateIntervalMs": 500 - }, - { - "text": "%sh\n\nrm /tmp/flights98.csv.bz2\ncurl -o /tmp/flights98.csv.bz2 \"http://stat-computing.org/dataexpo/2009/1998.csv.bz2\"\nrm /tmp/flights98.csv\nbzip2 -d /tmp/flights98.csv.bz2\nchmod 666 /tmp/flights98.csv", - "user": "anonymous", - "dateUpdated": "Jan 9, 2017 11:59:02 AM", - "config": { - "colWidth": 12.0, - "enabled": true, - "results": {}, - "editorSetting": { - "language": "sh", - "editOnDblClick": false - }, - "editorMode": "ace/mode/sh", - "tableHide": true - }, - "settings": { - "params": {}, - "forms": {} - }, - "apps": [], - "jobName": "paragraph_1483952167547_-566831096", - "id": "20170109-115607_1634441713", - "results": { - "code": "SUCCESS", - "msg": [ - { - "type": "TEXT", - "data": "rm: cannot remove \u0027/tmp/flights98.csv.bz2\u0027: No such file or directory\n % Total % Received % Xferd Average Speed Time Time Time Current\n Dload Upload Total Spent Left Speed\n\r 0 0 0 0 0 0 0 0 --:--:-- --:--:-- --:--:-- 0\r 0 0 0 0 0 0 0 0 --:--:-- --:--:-- --:--:-- 0\r 0 73.1M 0 64295 0 0 51646 0 0:24:44 0:00:01 0:24:43 51642\r 0 73.1M 0 358k 0 0 160k 0 0:07:47 0:00:02 0:07:45 160k\r 1 73.1M 1 1209k 0 0 373k 0 0:03:20 0:00:03 0:03:17 373k\r 4 73.1M 4 3204k 0 0 773k 0 0:01:36 0:00:04 0:01:32 773k\r 7 73.1M 7 5508k 0 0 1071k 0 0:01:09 0:00:05 0:01:04 1145k\r 10 73.1M 10 7875k 0 0 1280k 0 0:00:58 0:00:06 0:00:52 1592k\r 13 73.1M 13 10.1M 0 0 1458k 0 0:00:51 0:00:07 0:00:44 2049k\r 17 73.1M 17 12.7M 0 0 1608k 0 0:00:46 0:00:08 0:00:38 2422k\r 20 73.1M 20 14.9M 0 0 1671k 0 0:00:44 0:00:09 0:00:35 2413k\r 23 73.1M 23 17.1M 0 0 1728k 0 0:00:43 0:00:10 0:00:33 2403k\r 26 73.1M 26 19.4M 0 0 1787k 0 0:00:41 0:00:11 0:00:30 2411k\r 29 73.1M 29 21.7M 0 0 1837k 0 0:00:40 0:00:12 0:00:28 2379k\r 32 73.1M 32 24.1M 0 0 1879k 0 0:00:39 0:00:13 0:00:26 2322k\r 36 73.1M 36 26.4M 0 0 1916k 0 0:00:39 0:00:14 0:00:25 2365k\r 39 73.1M 39 28.5M 0 0 1930k 0 0:00:38 0:00:15 0:00:23 2341k\r 41 73.1M 41 30.6M 0 0 1943k 0 0:00:38 0:00:16 0:00:22 2292k\r 44 73.1M 44 32.6M 0 0 1947k 0 0:00:38 0:00:17 0:00:21 2215k\r 47 73.1M 47 34.6M 0 0 1952k 0 0:00:38 0:00:18 0:00:20 2145k\r 50 73.1M 50 36.6M 0 0 1960k 0 0:00:38 0:00:19 0:00:19 2082k\r 52 73.1M 52 38.3M 0 0 1947k 0 0:00:38 0:00:20 0:00:18 1998k\r 55 73.1M 55 40.4M 0 0 1956k 0 0:00:38 0:00:21 0:00:17 1996k\r 57 73.1M 57 42.2M 0 0 1951k 0 0:00:38 0:00:22 0:00:16 1965k\r 60 73.1M 60 44.0M 0 0 1948k 0 0:00:38 0:00:23 0:00:15 1932k\r 62 73.1M 62 45.4M 0 0 1927k 0 0:00:38 0:00:24 0:00:14 1803k\r 63 73.1M 63 46.5M 0 0 1896k 0 0:00:39 0:00:25 0:00:14 1688k\r 65 73.1M 65 47.7M 0 0 1868k 0 0:00:40 0:00:26 0:00:14 1496k\r 66 73.1M 66 48.8M 0 0 1843k 0 0:00:40 0:00:27 0:00:13 1363k\r 68 73.1M 68 50.0M 0 0 1820k 0 0:00:41 0:00:28 0:00:13 1227k\r 69 73.1M 69 51.1M 0 0 1786k 0 0:00:41 0:00:29 0:00:12 1126k\r 71 73.1M 71 52.0M 0 0 1769k 0 0:00:42 0:00:30 0:00:12 1131k\r 72 73.1M 72 53.0M 0 0 1744k 0 0:00:42 0:00:31 0:00:11 1098k\r 73 73.1M 73 54.0M 0 0 1723k 0 0:00:43 0:00:32 0:00:11 1070k\r 75 73.1M 75 55.1M 0 0 1702k 0 0:00:43 0:00:33 0:00:10 1040k\r 76 73.1M 76 56.0M 0 0 1681k 0 0:00:44 0:00:34 0:00:10 1048k\r 77 73.1M 77 56.9M 0 0 1659k 0 0:00:45 0:00:35 0:00:10 993k\r 79 73.1M 79 57.8M 0 0 1638k 0 0:00:45 0:00:36 0:00:09 972k\r 80 73.1M 80 58.7M 0 0 1618k 0 0:00:46 0:00:37 0:00:09 946k\r 81 73.1M 81 59.6M 0 0 1600k 0 0:00:46 0:00:38 0:00:08 921k\r 82 73.1M 82 60.5M 0 0 1582k 0 0:00:47 0:00:39 0:00:08 906k\r 83 73.1M 83 61.4M 0 0 1566k 0 0:00:47 0:00:40 0:00:07 917k\r 85 73.1M 85 62.1M 0 0 1546k 0 0:00:48 0:00:41 0:00:07 887k\r 86 73.1M 86 63.0M 0 0 1532k 0 0:00:48 0:00:42 0:00:06 892k\r 87 73.1M 87 63.9M 0 0 1517k 0 0:00:49 0:00:43 0:00:06 882k\r 88 73.1M 88 64.8M 0 0 1503k 0 0:00:49 0:00:44 0:00:05 878k\r 89 73.1M 89 65.6M 0 0 1489k 0 0:00:50 0:00:45 0:00:05 872k\r 91 73.1M 91 66.5M 0 0 1477k 0 0:00:50 0:00:46 0:00:04 904k\r 92 73.1M 92 67.4M 0 0 1465k 0 0:00:51 0:00:47 0:00:04 897k\r 93 73.1M 93 68.2M 0 0 1451k 0 0:00:51 0:00:48 0:00:03 889k\r 94 73.1M 94 69.2M 0 0 1441k 0 0:00:51 0:00:49 0:00:02 897k\r 95 73.1M 95 70.1M 0 0 1430k 0 0:00:52 0:00:50 0:00:02 904k\r 97 73.1M 97 71.0M 0 0 1421k 0 0:00:52 0:00:51 0:00:01 910k\r 98 73.1M 98 71.9M 0 0 1413k 0 0:00:52 0:00:52 --:--:-- 923k\r 99 73.1M 99 72.8M 0 0 1403k 0 0:00:53 0:00:53 --:--:-- 941k\r100 73.1M 100 73.1M 0 0 1401k 0 0:00:53 0:00:53 --:--:-- 941k\nrm: cannot remove \u0027/tmp/flights98.csv\u0027: No such file or directory\n" - } - ] - }, - "dateCreated": "Jan 9, 2017 11:56:07 AM", - "dateStarted": "Jan 9, 2017 11:57:37 AM", - "dateFinished": "Jan 9, 2017 11:58:50 AM", - "status": "FINISHED", - "progressUpdateIntervalMs": 500 - }, - { - "text": "%sh\n\nrm /tmp/flights99.csv.bz2\ncurl -o /tmp/flights99.csv.bz2 \"http://stat-computing.org/dataexpo/2009/1999.csv.bz2\"\nrm /tmp/flights99.csv\nbzip2 -d /tmp/flights99.csv.bz2\nchmod 666 /tmp/flights99.csv", - "user": "anonymous", - "dateUpdated": "Jan 9, 2017 11:59:59 AM", - "config": { - "colWidth": 12.0, - "enabled": true, - "results": {}, - "editorSetting": { - "language": "sh", - "editOnDblClick": false - }, - "editorMode": "ace/mode/sh", - "tableHide": true - }, - "settings": { - "params": {}, - "forms": {} - }, - "apps": [], - "jobName": "paragraph_1483952257873_-1874269156", - "id": "20170109-115737_1346880844", - "results": { - "code": "SUCCESS", - "msg": [ - { - "type": "TEXT", - "data": "rm: cannot remove \u0027/tmp/flights99.csv.bz2\u0027: No such file or directory\n % Total % Received % Xferd Average Speed Time Time Time Current\n Dload Upload Total Spent Left Speed\n\r 0 0 0 0 0 0 0 0 --:--:-- --:--:-- --:--:-- 0\r 0 75.7M 0 5520 0 0 9851 0 2:14:25 --:--:-- 2:14:25 9839\r 0 75.7M 0 88819 0 0 64302 0 0:20:35 0:00:01 0:20:34 64268\r 0 75.7M 0 181k 0 0 25316 0 0:52:18 0:00:07 0:52:11 25316\r 0 75.7M 0 548k 0 0 67331 0 0:19:39 0:00:08 0:19:31 67327\r 1 75.7M 1 817k 0 0 89344 0 0:14:49 0:00:09 0:14:40 89337\r 1 75.7M 1 1042k 0 0 100k 0 0:12:54 0:00:10 0:12:44 105k\r 3 75.7M 3 2461k 0 0 218k 0 0:05:55 0:00:11 0:05:44 239k\r 6 75.7M 6 5069k 0 0 412k 0 0:03:08 0:00:12 0:02:56 985k\r 11 75.7M 11 9165k 0 0 690k 0 0:01:52 0:00:13 0:01:39 1744k\r 14 75.7M 14 11.2M 0 0 796k 0 0:01:37 0:00:14 0:01:23 2109k\r 19 75.7M 19 14.8M 0 0 995k 0 0:01:17 0:00:15 0:01:02 2910k\r 24 75.7M 24 18.6M 0 0 1174k 0 0:01:06 0:00:16 0:00:50 3331k\r 29 75.7M 29 22.5M 0 0 1338k 0 0:00:57 0:00:17 0:00:40 3613k\r 35 75.7M 35 26.5M 0 0 1486k 0 0:00:52 0:00:18 0:00:34 3603k\r 40 75.7M 40 30.3M 0 0 1610k 0 0:00:48 0:00:19 0:00:29 4025k\r 45 75.7M 45 34.2M 0 0 1731k 0 0:00:44 0:00:20 0:00:24 3980k\r 50 75.7M 50 38.2M 0 0 1840k 0 0:00:42 0:00:21 0:00:21 4011k\r 55 75.7M 55 42.2M 0 0 1940k 0 0:00:39 0:00:22 0:00:17 4020k\r 60 75.7M 60 46.2M 0 0 2032k 0 0:00:38 0:00:23 0:00:15 4026k\r 65 75.7M 65 49.9M 0 0 2106k 0 0:00:36 0:00:24 0:00:12 4017k\r 70 75.7M 70 53.5M 0 0 2169k 0 0:00:35 0:00:25 0:00:10 3945k\r 75 75.7M 75 57.2M 0 0 2229k 0 0:00:34 0:00:26 0:00:08 3884k\r 80 75.7M 80 61.1M 0 0 2293k 0 0:00:33 0:00:27 0:00:06 3868k\r 86 75.7M 86 65.5M 0 0 2372k 0 0:00:32 0:00:28 0:00:04 3956k\r 92 75.7M 92 70.4M 0 0 2464k 0 0:00:31 0:00:29 0:00:02 4200k\r100 75.7M 100 75.7M 0 0 2565k 0 0:00:30 0:00:30 --:--:-- 4585k\nrm: cannot remove \u0027/tmp/flights99.csv\u0027: No such file or directory\n" - } - ] - }, - "dateCreated": "Jan 9, 2017 11:57:37 AM", - "dateStarted": "Jan 9, 2017 11:59:04 AM", - "dateFinished": "Jan 9, 2017 11:59:53 AM", - "status": "FINISHED", - "progressUpdateIntervalMs": 500 - }, - { - "text": "%sh\n\nrm /tmp/flights00.csv.bz2\ncurl -o /tmp/flights00.csv.bz2 \"http://stat-computing.org/dataexpo/2009/2000.csv.bz2\"\nrm /tmp/flights00.csv\nbzip2 -d /tmp/flights00.csv.bz2\nchmod 666 /tmp/flights00.csv", - "user": "anonymous", - "dateUpdated": "Jan 9, 2017 12:01:42 PM", - "config": { - "colWidth": 12.0, - "enabled": true, - "results": {}, - "editorSetting": { - "language": "sh", - "editOnDblClick": false - }, - "editorMode": "ace/mode/sh", - "tableHide": true - }, - "settings": { - "params": {}, - "forms": {} - }, - "apps": [], - "jobName": "paragraph_1483952312038_-1315320949", - "id": "20170109-115832_608069986", - "results": { - "code": "SUCCESS", - "msg": [ - { - "type": "TEXT", - "data": "rm: cannot remove \u0027/tmp/flights00.csv.bz2\u0027: No such file or directory\n % Total % Received % Xferd Average Speed Time Time Time Current\n Dload Upload Total Spent Left Speed\n\r 0 0 0 0 0 0 0 0 --:--:-- --:--:-- --:--:-- 0\r 0 0 0 0 0 0 0 0 --:--:-- 0:00:01 --:--:-- 0\r 0 78.7M 0 5520 0 0 3016 0 7:36:06 0:00:01 7:36:05 3014\r 0 78.7M 0 39987 0 0 15337 0 1:29:41 0:00:02 1:29:39 15332\r 0 78.7M 0 87755 0 0 24531 0 0:56:04 0:00:03 0:56:01 24526\r 0 78.7M 0 157k 0 0 33950 0 0:40:31 0:00:04 0:40:27 33944\r 0 78.7M 0 221k 0 0 40878 0 0:33:39 0:00:05 0:33:34 53734\r 0 78.7M 0 308k 0 0 47250 0 0:29:06 0:00:06 0:29:00 63943\r 0 78.7M 0 398k 0 0 52806 0 0:26:03 0:00:07 0:25:56 71903\r 0 78.7M 0 437k 0 0 36667 0 0:37:31 0:00:12 0:37:19 41697\r 0 78.7M 0 703k 0 0 57158 0 0:24:04 0:00:12 0:23:52 71137\r 1 78.7M 1 851k 0 0 64259 0 0:21:24 0:00:13 0:21:11 80471\r 1 78.7M 1 1171k 0 0 82442 0 0:16:41 0:00:14 0:16:27 109k\r 1 78.7M 1 1546k 0 0 79861 0 0:17:13 0:00:19 0:16:54 97134\r 3 78.7M 3 3181k 0 0 154k 0 0:08:41 0:00:20 0:08:21 327k\r 4 78.7M 4 3466k 0 0 160k 0 0:08:21 0:00:21 0:08:00 308k\r 4 78.7M 4 3565k 0 0 136k 0 0:09:50 0:00:26 0:09:24 216k\r 8 78.7M 8 7196k 0 0 270k 0 0:04:57 0:00:26 0:04:31 501k\r 10 78.7M 10 8459k 0 0 307k 0 0:04:22 0:00:27 0:03:55 894k\r 11 78.7M 11 9386k 0 0 327k 0 0:04:06 0:00:28 0:03:38 768k\r 15 78.7M 15 11.9M 0 0 413k 0 0:03:14 0:00:29 0:02:45 1093k\r 18 78.7M 18 14.5M 0 0 487k 0 0:02:45 0:00:30 0:02:15 2553k\r 22 78.7M 22 17.7M 0 0 574k 0 0:02:20 0:00:31 0:01:49 2195k\r 25 78.7M 25 19.9M 0 0 626k 0 0:02:08 0:00:32 0:01:36 2375k\r 28 78.7M 28 22.1M 0 0 676k 0 0:01:59 0:00:33 0:01:26 2726k\r 31 78.7M 31 24.7M 0 0 734k 0 0:01:49 0:00:34 0:01:15 2643k\r 34 78.7M 34 27.3M 0 0 789k 0 0:01:42 0:00:35 0:01:07 2638k\r 38 78.7M 38 30.0M 0 0 841k 0 0:01:35 0:00:36 0:00:59 2513k\r 40 78.7M 40 32.1M 0 0 874k 0 0:01:32 0:00:37 0:00:55 2457k\r 43 78.7M 43 34.1M 0 0 906k 0 0:01:28 0:00:38 0:00:50 2445k\r 45 78.7M 45 35.7M 0 0 925k 0 0:01:27 0:00:39 0:00:48 2250k\r 47 78.7M 47 37.4M 0 0 946k 0 0:01:25 0:00:40 0:00:45 2062k\r 49 78.7M 49 39.3M 0 0 968k 0 0:01:23 0:00:41 0:00:42 1907k\r 52 78.7M 52 41.0M 0 0 987k 0 0:01:21 0:00:42 0:00:39 1859k\r 54 78.7M 54 42.5M 0 0 1000k 0 0:01:20 0:00:43 0:00:37 1729k\r 55 78.7M 55 43.9M 0 0 1008k 0 0:01:19 0:00:44 0:00:35 1651k\r 57 78.7M 57 45.4M 0 0 1020k 0 0:01:18 0:00:45 0:00:33 1625k\r 59 78.7M 59 46.6M 0 0 1027k 0 0:01:18 0:00:46 0:00:32 1512k\r 60 78.7M 60 47.7M 0 0 1027k 0 0:01:18 0:00:47 0:00:31 1376k\r 61 78.7M 61 48.6M 0 0 1024k 0 0:01:18 0:00:48 0:00:30 1236k\r 62 78.7M 62 49.5M 0 0 1020k 0 0:01:18 0:00:49 0:00:29 1125k\r 64 78.7M 64 50.4M 0 0 1021k 0 0:01:18 0:00:50 0:00:28 1027k\r 65 78.7M 65 51.3M 0 0 1018k 0 0:01:19 0:00:51 0:00:28 941k\r 66 78.7M 66 52.1M 0 0 1016k 0 0:01:19 0:00:52 0:00:27 910k\r 67 78.7M 67 53.0M 0 0 1014k 0 0:01:19 0:00:53 0:00:26 909k\r 68 78.7M 68 53.7M 0 0 1006k 0 0:01:20 0:00:54 0:00:26 868k\r 69 78.7M 69 54.6M 0 0 1006k 0 0:01:20 0:00:55 0:00:25 858k\r 70 78.7M 70 55.3M 0 0 1002k 0 0:01:20 0:00:56 0:00:24 831k\r 71 78.7M 71 56.1M 0 0 998k 0 0:01:20 0:00:57 0:00:23 807k\r 72 78.7M 72 56.9M 0 0 994k 0 0:01:21 0:00:58 0:00:23 787k\r 73 78.7M 73 57.6M 0 0 991k 0 0:01:21 0:00:59 0:00:22 823k\r 74 78.7M 74 58.4M 0 0 988k 0 0:01:21 0:01:00 0:00:21 784k\r 75 78.7M 75 59.2M 0 0 985k 0 0:01:21 0:01:01 0:00:20 791k\r 76 78.7M 76 60.0M 0 0 982k 0 0:01:22 0:01:02 0:00:20 797k\r 77 78.7M 77 60.8M 0 0 980k 0 0:01:22 0:01:03 0:00:19 808k\r 78 78.7M 78 61.6M 0 0 977k 0 0:01:22 0:01:04 0:00:18 812k\r 79 78.7M 79 62.4M 0 0 975k 0 0:01:22 0:01:05 0:00:17 824k\r 80 78.7M 80 63.4M 0 0 976k 0 0:01:22 0:01:06 0:00:16 870k\r 82 78.7M 82 64.9M 0 0 984k 0 0:01:21 0:01:07 0:00:14 1006k\r 85 78.7M 85 66.9M 0 0 1000k 0 0:01:20 0:01:08 0:00:12 1254k\r 88 78.7M 88 69.4M 0 0 1022k 0 0:01:18 0:01:09 0:00:09 1602k\r 92 78.7M 92 72.5M 0 0 1053k 0 0:01:16 0:01:10 0:00:06 2064k\r 96 78.7M 96 76.1M 0 0 1089k 0 0:01:13 0:01:11 0:00:02 2600k\r100 78.7M 100 78.7M 0 0 1116k 0 0:01:12 0:01:12 --:--:-- 3022k\nrm: cannot remove \u0027/tmp/flights00.csv\u0027: No such file or directory\n" - } - ] - }, - "dateCreated": "Jan 9, 2017 11:58:32 AM", - "dateStarted": "Jan 9, 2017 12:00:01 PM", - "dateFinished": "Jan 9, 2017 12:01:34 PM", - "status": "FINISHED", - "progressUpdateIntervalMs": 500 - }, - { - "text": "%sh\n\nrm /tmp/carriers.csv\ncurl -o /tmp/carriers.csv \"http://stat-computing.org/dataexpo/2009/carriers.csv\"\nchmod 666 /tmp/carriers.csv", - "user": "anonymous", - "dateUpdated": "Jan 9, 2017 12:01:48 PM", - "config": { - "colWidth": 12.0, - "enabled": true, - "results": {}, - "editorSetting": { - "language": "sh", - "editOnDblClick": false - }, - "editorMode": "ace/mode/sh", - "tableHide": true - }, - "settings": { - "params": {}, - "forms": {} - }, - "apps": [], - "jobName": "paragraph_1483952329229_2136292082", - "id": "20170109-115849_1794095031", - "results": { - "code": "SUCCESS", - "msg": [ - { - "type": "TEXT", - "data": "rm: cannot remove \u0027/tmp/carriers.csv\u0027: No such file or directory\n % Total % Received % Xferd Average Speed Time Time Time Current\n Dload Upload Total Spent Left Speed\n\r 0 0 0 0 0 0 0 0 --:--:-- --:--:-- --:--:-- 0\r 9 43758 9 4140 0 0 7588 0 0:00:05 --:--:-- 0:00:05 7582\r100 43758 100 43758 0 0 46357 0 --:--:-- --:--:-- --:--:-- 46353\n" - } - ] - }, - "dateCreated": "Jan 9, 2017 11:58:49 AM", - "dateStarted": "Jan 9, 2017 12:01:44 PM", - "dateFinished": "Jan 9, 2017 12:01:45 PM", - "status": "FINISHED", - "progressUpdateIntervalMs": 500 - }, - { - "text": "%md\n### Preparing the data\nThe `flights\u003cYY\u003e.csv` contains various data but we only need the information about the year, the month and the carrier who served the flight. Let\u0027s retrieve this information and create `DataSets`.", - "user": "anonymous", - "dateUpdated": "Jan 9, 2017 12:01:51 PM", - "config": { - "colWidth": 12.0, - "enabled": true, - "results": {}, - "editorSetting": { - "language": "markdown", - "editOnDblClick": true - }, - "editorMode": "ace/mode/markdown", - "editorHide": true, - "tableHide": false - }, - "settings": { - "params": {}, - "forms": {} - }, - "apps": [], - "jobName": "paragraph_1483952363836_-1769111757", - "id": "20170109-115923_963126574", - "results": { - "code": "SUCCESS", - "msg": [ - { - "type": "HTML", - "data": "\u003cdiv class\u003d\"markdown-body\"\u003e\n\u003ch3\u003ePreparing the data\u003c/h3\u003e\n\u003cp\u003eThe \u003ccode\u003eflights\u0026lt;YY\u0026gt;.csv\u003c/code\u003e contains various data but we only need the information about the year, the month and the carrier who served the flight. Let\u0026rsquo;s retrieve this information and create \u003ccode\u003eDataSets\u003c/code\u003e.\u003c/p\u003e\n\u003c/div\u003e" - } - ] - }, - "dateCreated": "Jan 9, 2017 11:59:23 AM", - "dateStarted": "Jan 9, 2017 12:01:51 PM", - "dateFinished": "Jan 9, 2017 12:01:53 PM", - "status": "FINISHED", - "progressUpdateIntervalMs": 500 - }, - { - "text": "%flink\n\ncase class Flight(year: Int, month: Int, carrierCode: String)\ncase class Carrier(code: String, name: String)\n\nval flights98 \u003d benv.readCsvFile[Flight](\"/tmp/flights98.csv\", ignoreFirstLine \u003d true, includedFields \u003d Array(0, 1, 8))\nval flights99 \u003d benv.readCsvFile[Flight](\"/tmp/flights99.csv\", ignoreFirstLine \u003d true, includedFields \u003d Array(0, 1, 8))\nval flights00 \u003d benv.readCsvFile[Flight](\"/tmp/flights00.csv\", ignoreFirstLine \u003d true, includedFields \u003d Array(0, 1, 8))\nval flights \u003d flights98.union(flights99).union(flights00)\nval carriers \u003d benv.readCsvFile[Carrier](\"/tmp/carriers.csv\", ignoreFirstLine \u003d true, quoteCharacter \u003d \u0027\"\u0027)", - "user": "anonymous", - "dateUpdated": "Jan 9, 2017 12:02:38 PM", - "config": { - "colWidth": 12.0, - "enabled": true, - "results": {}, - "editorSetting": { - "language": "scala", - "editOnDblClick": false - }, - "editorMode": "ace/mode/scala", - "lineNumbers": true, - "tableHide": true - }, - "settings": { - "params": {}, - "forms": {} - }, - "apps": [], - "jobName": "paragraph_1483952511284_-589624871", - "id": "20170109-120151_872852428", - "results": { - "code": "SUCCESS", - "msg": [ - { - "type": "TEXT", - "data": "defined class Flight\ndefined class Carrier\nflights98: org.apache.flink.api.scala.DataSet[Flight] \u003d org.apache.flink.api.scala.DataSet@7cd81fd5\nflights99: org.apache.flink.api.scala.DataSet[Flight] \u003d org.apache.flink.api.scala.DataSet@58242e79\nflights00: org.apache.flink.api.scala.DataSet[Flight] \u003d org.apache.flink.api.scala.DataSet@13f866c0\nflights: org.apache.flink.api.scala.DataSet[Flight] \u003d org.apache.flink.api.scala.DataSet@2aad2530\ncarriers: org.apache.flink.api.scala.DataSet[Carrier] \u003d org.apache.flink.api.scala.DataSet@148c977b\n" - } - ] - }, - "dateCreated": "Jan 9, 2017 12:01:51 PM", - "dateStarted": "Jan 9, 2017 12:02:10 PM", - "dateFinished": "Jan 9, 2017 12:02:29 PM", - "status": "FINISHED", - "progressUpdateIntervalMs": 500 - }, - { - "text": "%md\n### Choosing the carrier\nNow we will search for the most popular carrier during the whole time period.", - "user": "anonymous", - "dateUpdated": "Jan 9, 2017 12:03:08 PM", - "config": { - "colWidth": 12.0, - "enabled": true, - "results": {}, - "editorSetting": { - "language": "markdown", - "editOnDblClick": true - }, - "editorMode": "ace/mode/markdown", - "editorHide": true, - "tableHide": false - }, - "settings": { - "params": {}, - "forms": {} - }, - "apps": [], - "jobName": "paragraph_1483952530113_212237809", - "id": "20170109-120210_773710997", - "results": { - "code": "SUCCESS", - "msg": [ - { - "type": "HTML", - "data": "\u003cdiv class\u003d\"markdown-body\"\u003e\n\u003ch3\u003eChoosing the carrier\u003c/h3\u003e\n\u003cp\u003eNow we will search for the most popular carrier during the whole time period.\u003c/p\u003e\n\u003c/div\u003e" - } - ] - }, - "dateCreated": "Jan 9, 2017 12:02:10 PM", - "dateStarted": "Jan 9, 2017 12:03:08 PM", - "dateFinished": "Jan 9, 2017 12:03:08 PM", - "status": "FINISHED", - "progressUpdateIntervalMs": 500 - }, - { - "text": "%flink\n\nimport org.apache.flink.api.common.operators.Order\nimport org.apache.flink.api.java.aggregation.Aggregations\n\ncase class CarrierFlightsCount(carrierCode: String, count: Int)\ncase class CountByMonth(month: Int, count: Int)\n\nval carriersFlights \u003d flights\n .map(f \u003d\u003e CarrierFlightsCount(f.carrierCode, 1))\n .groupBy(\"carrierCode\")\n .sum(\"count\")\n\nval maxFlights \u003d carriersFlights\n .aggregate(Aggregations.MAX, \"count\")\n\nval bestCarrier \u003d carriersFlights\n .join(maxFlights)\n .where(\"count\")\n .equalTo(\"count\")\n .map(_._1)\n \nval carrierName \u003d bestCarrier\n .join(carriers)\n .where(\"carrierCode\")\n .equalTo(\"code\")\n .map(_._2.name)\n .collect\n .head", - "user": "anonymous", - "dateUpdated": "Jan 9, 2017 12:04:04 PM", - "config": { - "colWidth": 12.0, - "enabled": true, - "results": {}, - "editorSetting": { - "language": "scala", - "editOnDblClick": false - }, - "editorMode": "ace/mode/scala", - "lineNumbers": true, - "tableHide": true - }, - "settings": { - "params": {}, - "forms": {} - }, - "apps": [], - "jobName": "paragraph_1483952588708_-1770095793", - "id": "20170109-120308_1328511597", - "results": { - "code": "SUCCESS", - "msg": [ - { - "type": "TEXT", - "data": "import org.apache.flink.api.common.operators.Order\nimport org.apache.flink.api.java.aggregation.Aggregations\ndefined class CarrierFlightsCount\ndefined class CountByMonth\ncarriersFlights: org.apache.flink.api.scala.AggregateDataSet[CarrierFlightsCount] \u003d org.apache.flink.api.scala.AggregateDataSet@2c59be0b\nmaxFlights: org.apache.flink.api.scala.AggregateDataSet[CarrierFlightsCount] \u003d org.apache.flink.api.scala.AggregateDataSet@53e5fad9\nbestCarrier: org.apache.flink.api.scala.DataSet[CarrierFlightsCount] \u003d org.apache.flink.api.scala.DataSet@64b7b1b3\ncarrierName: String \u003d Delta Air Lines Inc.\n" - } - ] - }, - "dateCreated": "Jan 9, 2017 12:03:08 PM", - "dateStarted": "Jan 9, 2017 12:03:41 PM", - "dateFinished": "Jan 9, 2017 12:03:58 PM", - "status": "FINISHED", - "progressUpdateIntervalMs": 500 - }, - { - "text": "%flink\n\nprintln(s\"\"\"The most popular carrier is:\n$carrierName\n\"\"\")", - "user": "anonymous", - "dateUpdated": "Jan 9, 2017 12:09:18 PM", - "config": { - "colWidth": 12.0, - "enabled": true, - "results": {}, - "editorSetting": { - "language": "scala", - "editOnDblClick": false - }, - "editorMode": "ace/mode/scala", - "lineNumbers": true - }, - "settings": { - "params": {}, - "forms": {} - }, - "apps": [], - "jobName": "paragraph_1483952621624_-1222400539", - "id": "20170109-120341_952212268", - "results": { - "code": "SUCCESS", - "msg": [ - { - "type": "TEXT", - "data": "The most popular carrier is:\nDelta Air Lines Inc.\n\n" - } - ] - }, - "dateCreated": "Jan 9, 2017 12:03:41 PM", - "dateStarted": "Jan 9, 2017 12:04:09 PM", - "dateFinished": "Jan 9, 2017 12:04:10 PM", - "status": "FINISHED", - "progressUpdateIntervalMs": 500 - }, - { - "text": "%md\n### Calculating flights\nThe last step is to filter **Delta Air Lines** flights and group them by months.", - "user": "anonymous", - "dateUpdated": "Jan 9, 2017 12:04:26 PM", - "config": { - "colWidth": 12.0, - "enabled": true, - "results": {}, - "editorSetting": { - "language": "markdown", - "editOnDblClick": true - }, - "editorMode": "ace/mode/markdown", - "editorHide": true, - "tableHide": false - }, - "settings": { - "params": {}, - "forms": {} - }, - "apps": [], - "jobName": "paragraph_1483952649646_-1553253944", - "id": "20170109-120409_2003276881", - "results": { - "code": "SUCCESS", - "msg": [ - { - "type": "HTML", - "data": "\u003cdiv class\u003d\"markdown-body\"\u003e\n\u003ch3\u003eCalculating flights\u003c/h3\u003e\n\u003cp\u003eThe last step is to filter \u003cstrong\u003eDelta Air Lines\u003c/strong\u003e flights and group them by months.\u003c/p\u003e\n\u003c/div\u003e" - } - ] - }, - "dateCreated": "Jan 9, 2017 12:04:09 PM", - "dateStarted": "Jan 9, 2017 12:04:26 PM", - "dateFinished": "Jan 9, 2017 12:04:26 PM", - "status": "FINISHED", - "progressUpdateIntervalMs": 500 - }, - { - "title": "flights grouping", - "text": "%flink\n\ndef countFlightsPerMonth(flights: DataSet[Flight],\n carrier: DataSet[CarrierFlightsCount]) \u003d {\n val carrierFlights \u003d flights\n .join(carrier)\n .where(\"carrierCode\")\n .equalTo(\"carrierCode\")\n .map(_._1)\n \n carrierFlights\n .map(flight \u003d\u003e CountByMonth(flight.month, 1))\n .groupBy(\"month\")\n .sum(\"count\")\n .sortPartition(\"month\", Order.ASCENDING)\n}\n\nval bestCarrierFlights_98 \u003d countFlightsPerMonth(flights98, bestCarrier)\nval bestCarrierFlights_99 \u003d countFlightsPerMonth(flights99, bestCarrier)\nval bestCarrierFlights_00 \u003d countFlightsPerMonth(flights00, bestCarrier)", - "user": "anonymous", - "dateUpdated": "Jan 9, 2017 12:05:06 PM", - "config": { - "colWidth": 12.0, - "enabled": true, - "results": {}, - "editorSetting": { - "language": "scala", - "editOnDblClick": false - }, - "editorMode": "ace/mode/scala", - "lineNumbers": true, - "title": true, - "tableHide": true - }, - "settings": { - "params": {}, - "forms": {} - }, - "apps": [], - "jobName": "paragraph_1483952665972_667547355", - "id": "20170109-120425_2018337048", - "results": { - "code": "SUCCESS", - "msg": [ - { - "type": "TEXT", - "data": "countFlightsPerMonth: (flights: org.apache.flink.api.scala.DataSet[Flight], carrier: org.apache.flink.api.scala.DataSet[CarrierFlightsCount])org.apache.flink.api.scala.DataSet[CountByMonth]\nbestCarrierFlights_98: org.apache.flink.api.scala.DataSet[CountByMonth] \u003d org.apache.flink.api.scala.PartitionSortedDataSet@2aa64309\nbestCarrierFlights_99: org.apache.flink.api.scala.DataSet[CountByMonth] \u003d org.apache.flink.api.scala.PartitionSortedDataSet@35fe60c4\nbestCarrierFlights_00: org.apache.flink.api.scala.DataSet[CountByMonth] \u003d org.apache.flink.api.scala.PartitionSortedDataSet@4621410f\n" - } - ] - }, - "dateCreated": "Jan 9, 2017 12:04:25 PM", - "dateStarted": "Jan 9, 2017 12:04:50 PM", - "dateFinished": "Jan 9, 2017 12:04:51 PM", - "status": "FINISHED", - "progressUpdateIntervalMs": 500 - }, - { - "title": "making a results table", - "text": "%flink\n\ndef monthAsString(month: Int): String \u003d {\n month match {\n case 1 \u003d\u003e \"Jan\"\n case 2 \u003d\u003e \"Feb\"\n case 3 \u003d\u003e \"Mar\"\n case 4 \u003d\u003e \"Apr\"\n case 5 \u003d\u003e \"May\"\n case 6 \u003d\u003e \"Jun\"\n case 7 \u003d\u003e \"Jul\"\n case 8 \u003d\u003e \"Aug\"\n case 9 \u003d\u003e \"Sept\"\n case 10 \u003d\u003e \"Oct\"\n case 11 \u003d\u003e \"Nov\"\n case 12 \u003d\u003e \"Dec\"\n }\n}\n\n// We should put all the results into a common DataFrame\n// to show them in a common picture\nval bestCarrierFlights \u003d bestCarrierFlights_98\n .join(bestCarrierFlights_99)\n .where(\"month\")\n .equalTo(\"month\")\n .map(tuple \u003d\u003e (tuple._1.month, tuple._1.count, tuple._2.count))\n .join(bestCarrierFlights_00)\n .where(0)\n .equalTo(\"month\")\n .map(tuple \u003d\u003e (tuple._1._1, tuple._1._2, tuple._1._3, tuple._2.count))\n .collect\n \nvar flightsByMonthTable \u003d s\"Month\\t1998\\t1999\\t2000\\n\"\nbestCarrierFlights.foreach(data \u003d\u003e flightsByMonthTable +\u003d s\"${monthAsString(data._1)}\\t${data._2}\\t${data._3}\\t${data._4}\\n\")", - "user": "anonymous", - "dateUpdated": "Jan 9, 2017 12:06:03 PM", - "config": { - "colWidth": 12.0, - "enabled": true, - "results": {}, - "editorSetting": { - "language": "scala", - "editOnDblClick": false - }, - "editorMode": "ace/mode/scala", - "lineNumbers": true, - "title": true, - "tableHide": true - }, - "settings": { - "params": {}, - "forms": {} - }, - "apps": [], - "jobName": "paragraph_1483952690164_-1061667443", - "id": "20170109-120450_1574916350", - "results": { - "code": "SUCCESS", - "msg": [ - { - "type": "TEXT", - "data": "monthAsString: (month: Int)String\nbestCarrierFlights: Seq[(Int, Int, Int, Int)] \u003d Buffer((1,78523,77745,78055), (2,71101,70498,71090), (3,78906,77812,78453), (4,75726,75343,75247), (5,77937,77226,76797), (6,75432,75840,74846), (7,77521,77264,75776), (8,78104,78141,77654), (9,74840,75067,73696), (10,76145,77829,77425), (11,73552,74411,73659), (12,77308,76954,75331))\nflightsByMonthTable: String \u003d \n\"Month\t1998\t1999\t2000\n\"\n" - } - ] - }, - "dateCreated": "Jan 9, 2017 12:04:50 PM", - "dateStarted": "Jan 9, 2017 12:05:24 PM", - "dateFinished": "Jan 9, 2017 12:05:59 PM", - "status": "FINISHED", - "progressUpdateIntervalMs": 500 - }, - { - "title": "\"Delta Air Lines\" flights count by months", - "text": "%flink\n\nprintln(s\"\"\"%table\n$flightsByMonthTable\n\"\"\")", - "user": "anonymous", - "dateUpdated": "Jan 9, 2017 12:06:17 PM", - "config": { - "colWidth": 12.0, - "enabled": true, - "results": { - "0": { - "graph": { - "mode": "lineChart", - "height": 300.0, - "optionOpen": false, - "setting": { - "lineChart": {} - }, - "commonSetting": {}, - "keys": [ - { - "name": "Month", - "index": 0.0, - "aggr": "sum" - } - ], - "groups": [], - "values": [ - { - "name": "1998", - "index": 1.0, - "aggr": "sum" - }, - { - "name": "1999", - "index": 2.0, - "aggr": "sum" - }, - { - "name": "2000", - "index": 3.0, - "aggr": "sum" - } - ] - }, - "helium": {} - } - }, - "editorSetting": { - "language": "scala", - "editOnDblClick": false - }, - "editorMode": "ace/mode/scala", - "title": true, - "lineNumbers": true - }, - "settings": { - "params": {}, - "forms": {} - }, - "apps": [], - "jobName": "paragraph_1483952724460_191505697", - "id": "20170109-120524_2037622815", - "results": { - "code": "SUCCESS", - "msg": [ - { - "type": "TABLE", - "data": "Month\t1998\t1999\t2000\nJan\t78523\t77745\t78055\nFeb\t71101\t70498\t71090\nMar\t78906\t77812\t78453\nApr\t75726\t75343\t75247\nMay\t77937\t77226\t76797\nJun\t75432\t75840\t74846\nJul\t77521\t77264\t75776\nAug\t78104\t78141\t77654\nSept\t74840\t75067\t73696\nOct\t76145\t77829\t77425\nNov\t73552\t74411\t73659\nDec\t77308\t76954\t75331\n" - } - ] - }, - "dateCreated": "Jan 9, 2017 12:05:24 PM", - "dateStarted": "Jan 9, 2017 12:06:07 PM", - "dateFinished": "Jan 9, 2017 12:06:08 PM", - "status": "FINISHED", - "progressUpdateIntervalMs": 500 - }, - { - "text": "%md\n### Results\nLooking at this chart we can say that February is the most unpopular month, but this is only because it has less days (28 or 29) than the other months (30 or 31). To receive more fair picture we should calculate the average flights count per day for each month.", - "user": "anonymous", - "dateUpdated": "Jan 9, 2017 12:06:34 PM", - "config": { - "colWidth": 12.0, - "enabled": true, - "results": {}, - "editorSetting": { - "language": "markdown", - "editOnDblClick": true - }, - "editorMode": "ace/mode/markdown", - "editorHide": true, - "tableHide": false - }, - "settings": { - "params": {}, - "forms": {} - }, - "apps": [], - "jobName": "paragraph_1483952767719_-1010557136", - "id": "20170109-120607_67673280", - "results": { - "code": "SUCCESS", - "msg": [ - { - "type": "HTML", - "data": "\u003cdiv class\u003d\"markdown-body\"\u003e\n\u003ch3\u003eResults\u003c/h3\u003e\n\u003cp\u003eLooking at this chart we can say that February is the most unpopular month, but this is only because it has less days (28 or 29) than the other months (30 or 31). To receive more fair picture we should calculate the average flights count per day for each month.\u003c/p\u003e\n\u003c/div\u003e" - } - ] - }, - "dateCreated": "Jan 9, 2017 12:06:07 PM", - "dateStarted": "Jan 9, 2017 12:06:34 PM", - "dateFinished": "Jan 9, 2017 12:06:34 PM", - "status": "FINISHED", - "progressUpdateIntervalMs": 500 - }, - { - "text": "%flink\n\ndef daysInMonth(month: Int, year: Int): Int \u003d {\n month match {\n case 1 \u003d\u003e 31\n case 2 \u003d\u003e if (year % 4 \u003d\u003d 0) {\n 29\n } else {\n 28\n }\n case 3 \u003d\u003e 31\n case 4 \u003d\u003e 30\n case 5 \u003d\u003e 31\n case 6 \u003d\u003e 30\n case 7 \u003d\u003e 31\n case 8 \u003d\u003e 31\n case 9 \u003d\u003e 30\n case 10 \u003d\u003e 31\n case 11 \u003d\u003e 30\n case 12 \u003d\u003e 31\n }\n}\n\n\nvar flightsByDayTable \u003d s\"Month\\t1998\\t1999\\t2000\\n\"\n\nbestCarrierFlights.foreach(data \u003d\u003e flightsByDayTable +\u003d s\"${monthAsString(data._1)}\\t${data._2/daysInMonth(data._1,1998)}\\t${data._3/daysInMonth(data._1,1999)}\\t${data._4/daysInMonth(data._1,2000)}\\n\")", - "user": "anonymous", - "dateUpdated": "Jan 9, 2017 12:06:58 PM", - "config": { - "colWidth": 12.0, - "enabled": true, - "results": {}, - "editorSetting": { - "language": "scala", - "editOnDblClick": false - }, - "editorMode": "ace/mode/scala", - "lineNumbers": true, - "tableHide": true - }, - "settings": { - "params": {}, - "forms": {} - }, - "apps": [], - "jobName": "paragraph_1483952794097_-785833130", - "id": "20170109-120634_492170963", - "results": { - "code": "SUCCESS", - "msg": [ - { - "type": "TEXT", - "data": "daysInMonth: (month: Int, year: Int)Int\nflightsByDayTable: String \u003d \n\"Month\t1998\t1999\t2000\n\"\n" - } - ] - }, - "dateCreated": "Jan 9, 2017 12:06:34 PM", - "dateStarted": "Jan 9, 2017 12:06:53 PM", - "dateFinished": "Jan 9, 2017 12:06:53 PM", - "status": "FINISHED", - "progressUpdateIntervalMs": 500 - }, - { - "title": "\"Delta Air Lines\" flights count by days", - "text": "%flink\n\nprintln(s\"\"\"%table\n$flightsByDayTable\n\"\"\")", - "user": "anonymous", - "dateUpdated": "Jan 9, 2017 12:10:56 PM", - "config": { - "colWidth": 12.0, - "enabled": true, - "results": { - "0": { - "graph": { - "mode": "lineChart", - "height": 300.0, - "optionOpen": false, - "setting": { - "lineChart": {} - }, - "commonSetting": {}, - "keys": [ - { - "name": "Month", - "index": 0.0, - "aggr": "sum" - } - ], - "groups": [], - "values": [ - { - "name": "1998", - "index": 1.0, - "aggr": "sum" - }, - { - "name": "1999", - "index": 2.0, - "aggr": "sum" - }, - { - "name": "2000", - "index": 3.0, - "aggr": "sum" - } - ] - }, - "helium": {} - } - }, - "editorSetting": { - "language": "scala", - "editOnDblClick": false - }, - "editorMode": "ace/mode/scala", - "title": true, - "lineNumbers": true - }, - "settings": { - "params": {}, - "forms": {} - }, - "apps": [], - "jobName": "paragraph_1483952813391_1847418990", - "id": "20170109-120653_1870236569", - "results": { - "code": "SUCCESS", - "msg": [ - { - "type": "TABLE", - "data": "Month\t1998\t1999\t2000\nJan\t2533\t2507\t2517\nFeb\t2539\t2517\t2451\nMar\t2545\t2510\t2530\nApr\t2524\t2511\t2508\nMay\t2514\t2491\t2477\nJun\t2514\t2528\t2494\nJul\t2500\t2492\t2444\nAug\t2519\t2520\t2504\nSept\t2494\t2502\t2456\nOct\t2456\t2510\t2497\nNov\t2451\t2480\t2455\nDec\t2493\t2482\t2430\n" - } - ] - }, - "dateCreated": "Jan 9, 2017 12:06:53 PM", - "dateStarted": "Jan 9, 2017 12:07:22 PM", - "dateFinished": "Jan 9, 2017 12:07:23 PM", - "status": "FINISHED", - "progressUpdateIntervalMs": 500 - }, - { - "text": "%flink\n", - "dateUpdated": "Jan 9, 2017 12:07:22 PM", - "config": {}, - "settings": { - "params": {}, - "forms": {} - }, - "apps": [], - "jobName": "paragraph_1483952842919_587228425", - "id": "20170109-120722_939892827", - "dateCreated": "Jan 9, 2017 12:07:22 PM", - "status": "READY", - "progressUpdateIntervalMs": 500 - } - ], - "name": "Zeppelin Tutorial/Using Flink for batch processing", - "id": "2C35YU814", - "angularObjects": { - "2C4PVECE6:shared_process": [], - "2C4US9MUF:shared_process": [], - "2C4FYNB4G:shared_process": [], - "2C4GX28KP:shared_process": [], - "2C648AXXN:shared_process": [], - "2C3MSEJ2F:shared_process": [], - "2C6F2N6BT:shared_process": [], - "2C3US2RTN:shared_process": [], - "2C3TYMD6K:shared_process": [], - "2C3FDPZRX:shared_process": [], - "2C5TEARYX:shared_process": [], - "2C5D6NSNG:shared_process": [], - "2C6FVVEAD:shared_process": [], - "2C582KNWG:shared_process": [], - "2C6ZMVGM7:shared_process": [], - "2C6UYQG8R:shared_process": [], - "2C666VZT2:shared_process": [], - "2C4JRCY3K:shared_process": [], - "2C64W5T9D:shared_process": [] - }, - "config": { - "looknfeel": "default" - }, - "info": {} -} diff --git a/smart-zeppelin/notebook/2C57UKYWR/note.json b/smart-zeppelin/notebook/2C57UKYWR/note.json deleted file mode 100644 index 22afb2a5701..00000000000 --- a/smart-zeppelin/notebook/2C57UKYWR/note.json +++ /dev/null @@ -1,334 +0,0 @@ -{ - "paragraphs": [ - { - "text": "%md\n\n\n### [Apache Pig](http://pig.apache.org/) is a platform for analyzing large data sets that consists of a high-level language for expressing data analysis programs, coupled with infrastructure for evaluating these programs. The salient property of Pig programs is that their structure is amenable to substantial parallelization, which in turns enables them to handle very large data sets.\n\nPig\u0027s language layer currently consists of a textual language called Pig Latin, which has the following key properties:\n\n* Ease of programming. It is trivial to achieve parallel execution of simple, \"embarrassingly parallel\" data analysis tasks. Complex tasks comprised of multiple interrelated data transformations are explicitly encoded as data flow sequences, making them easy to write, understand, and maintain.\n* Optimization opportunities. The way in which tasks are encoded permits the system to optimize their execution automatically, allowing the user to focus on semantics rather than efficiency.\n* Extensibility. Users can create their own functions to do special-purpose processing.\n", - "user": "anonymous", - "dateUpdated": "Jan 22, 2017 12:48:50 PM", - "config": { - "colWidth": 12.0, - "enabled": true, - "results": {}, - "editorSetting": { - "language": "markdown", - "editOnDblClick": true - }, - "editorMode": "ace/mode/markdown", - "editorHide": true, - "tableHide": false - }, - "settings": { - "params": {}, - "forms": {} - }, - "results": { - "code": "SUCCESS", - "msg": [ - { - "type": "HTML", - "data": "\u003cdiv class\u003d\"markdown-body\"\u003e\n\u003ch3\u003e\u003ca href\u003d\"http://pig.apache.org/\"\u003eApache Pig\u003c/a\u003e is a platform for analyzing large data sets that consists of a high-level language for expressing data analysis programs, coupled with infrastructure for evaluating these programs. The salient property of Pig programs is that their structure is amenable to substantial parallelization, which in turns enables them to handle very large data sets.\u003c/h3\u003e\n\u003cp\u003ePig\u0026rsquo;s language layer currently consists of a textual language called Pig Latin, which has the following key properties:\u003c/p\u003e\n\u003cul\u003e\n \u003cli\u003eEase of programming. It is trivial to achieve parallel execution of simple, \u0026ldquo;embarrassingly parallel\u0026rdquo; data analysis tasks. Complex tasks comprised of multiple interrelated data transformations are explicitly encoded as data flow sequences, making them easy to write, understand, and maintain.\u003c/li\u003e\n \u003cli\u003eOptimization opportunities. The way in which tasks are encoded permits the system to optimize their execution automatically, allowing the user to focus on semantics rather than efficiency.\u003c/li\u003e\n \u003cli\u003eExtensibility. Users can create their own functions to do special-purpose processing.\u003c/li\u003e\n\u003c/ul\u003e\n\u003c/div\u003e" - } - ] - }, - "apps": [], - "jobName": "paragraph_1483277502513_1156234051", - "id": "20170101-213142_1565013608", - "dateCreated": "Jan 1, 2017 9:31:42 PM", - "dateStarted": "Jan 22, 2017 12:48:50 PM", - "dateFinished": "Jan 22, 2017 12:48:51 PM", - "status": "FINISHED", - "progressUpdateIntervalMs": 500 - }, - { - "text": "%md\n\nThis pig tutorial use pig to do the same thing as spark tutorial. The default mode is mapreduce, you can also use other modes like local/tez_local/tez. For mapreduce mode, you need to have hadoop installed and export `HADOOP_CONF_DIR` in `zeppelin-env.sh`\n\nThe tutorial consists of 3 steps.\n\n* Use shell interpreter to download bank.csv and upload it to hdfs\n* use `%pig` to process the data\n* use `%pig.query` to query the data", - "user": "anonymous", - "dateUpdated": "Jan 22, 2017 12:48:55 PM", - "config": { - "colWidth": 12.0, - "enabled": true, - "results": {}, - "editorSetting": { - "language": "markdown", - "editOnDblClick": true - }, - "editorMode": "ace/mode/markdown", - "editorHide": true, - "tableHide": false - }, - "settings": { - "params": {}, - "forms": {} - }, - "results": { - "code": "SUCCESS", - "msg": [ - { - "type": "HTML", - "data": "\u003cdiv class\u003d\"markdown-body\"\u003e\n\u003cp\u003eThis pig tutorial use pig to do the same thing as spark tutorial. The default mode is mapreduce, you can also use other modes like local/tez_local/tez. For mapreduce mode, you need to have hadoop installed and export \u003ccode\u003eHADOOP_CONF_DIR\u003c/code\u003e in \u003ccode\u003ezeppelin-env.sh\u003c/code\u003e\u003c/p\u003e\n\u003cp\u003eThe tutorial consists of 3 steps.\u003c/p\u003e\n\u003cul\u003e\n \u003cli\u003eUse shell interpreter to download bank.csv and upload it to hdfs\u003c/li\u003e\n \u003cli\u003euse \u003ccode\u003e%pig\u003c/code\u003e to process the data\u003c/li\u003e\n \u003cli\u003euse \u003ccode\u003e%pig.query\u003c/code\u003e to query the data\u003c/li\u003e\n\u003c/ul\u003e\n\u003c/div\u003e" - } - ] - }, - "apps": [], - "jobName": "paragraph_1483689316217_-629483391", - "id": "20170106-155516_1050601059", - "dateCreated": "Jan 6, 2017 3:55:16 PM", - "dateStarted": "Jan 22, 2017 12:48:55 PM", - "dateFinished": "Jan 22, 2017 12:48:55 PM", - "status": "FINISHED", - "progressUpdateIntervalMs": 500 - }, - { - "text": "%sh\n\nwget https://s3.amazonaws.com/apache-zeppelin/tutorial/bank/bank.csv\nhadoop fs -put bank.csv .\n", - "user": "anonymous", - "dateUpdated": "Jan 22, 2017 12:51:48 PM", - "config": { - "colWidth": 12.0, - "enabled": true, - "results": {}, - "editorSetting": { - "language": "text", - "editOnDblClick": false - }, - "editorMode": "ace/mode/text" - }, - "settings": { - "params": {}, - "forms": {} - }, - "results": { - "code": "SUCCESS", - "msg": [ - { - "type": "TEXT", - "data": "--2017-01-22 12:51:48-- https://s3.amazonaws.com/apache-zeppelin/tutorial/bank/bank.csv\nResolving s3.amazonaws.com... 52.216.80.227\nConnecting to s3.amazonaws.com|52.216.80.227|:443... connected.\nHTTP request sent, awaiting response... 200 OK\nLength: 461474 (451K) [application/octet-stream]\nSaving to: \u0027bank.csv.3\u0027\n\n 0K .......... .......... .......... .......... .......... 11% 141K 3s\n 50K .......... .......... .......... .......... .......... 22% 243K 2s\n 100K .......... .......... .......... .......... .......... 33% 449K 1s\n 150K .......... .......... .......... .......... .......... 44% 413K 1s\n 200K .......... .......... .......... .......... .......... 55% 746K 1s\n 250K .......... .......... .......... .......... .......... 66% 588K 0s\n 300K .......... .......... .......... .......... .......... 77% 840K 0s\n 350K .......... .......... .......... .......... .......... 88% 795K 0s\n 400K .......... .......... .......... .......... .......... 99% 1.35M 0s\n 450K 100% 13.2K\u003d1.1s\n\n2017-01-22 12:51:50 (409 KB/s) - \u0027bank.csv.3\u0027 saved [461474/461474]\n\n17/01/22 12:51:51 WARN util.NativeCodeLoader: Unable to load native-hadoop library for your platform... using builtin-java classes where applicable\n" - } - ] - }, - "apps": [], - "jobName": "paragraph_1485058437578_-1906301827", - "id": "20170122-121357_640055590", - "dateCreated": "Jan 22, 2017 12:13:57 PM", - "dateStarted": "Jan 22, 2017 12:51:48 PM", - "dateFinished": "Jan 22, 2017 12:51:52 PM", - "status": "FINISHED", - "progressUpdateIntervalMs": 500 - }, - { - "text": "%pig\n\nbankText \u003d load \u0027bank.csv\u0027 using PigStorage(\u0027;\u0027);\nbank \u003d foreach bankText generate $0 as age, $1 as job, $2 as marital, $3 as education, $5 as balance; \nbank \u003d filter bank by age !\u003d \u0027\"age\"\u0027;\nbank \u003d foreach bank generate (int)age, REPLACE(job,\u0027\"\u0027,\u0027\u0027) as job, REPLACE(marital, \u0027\"\u0027, \u0027\u0027) as marital, (int)(REPLACE(balance, \u0027\"\u0027, \u0027\u0027)) as balance;\n\n-- The following statement is optional, it depends on whether your needs.\n-- store bank into \u0027clean_bank.csv\u0027 using PigStorage(\u0027;\u0027);\n\n\n", - "user": "anonymous", - "dateUpdated": "Feb 24, 2017 5:08:08 PM", - "config": { - "colWidth": 12.0, - "editorMode": "ace/mode/pig", - "results": {}, - "enabled": true, - "editorSetting": { - "language": "pig", - "editOnDblClick": false - } - }, - "settings": { - "params": {}, - "forms": {} - }, - "results": { - "code": "SUCCESS", - "msg": [] - }, - "apps": [], - "jobName": "paragraph_1483277250237_-466604517", - "id": "20161228-140640_1560978333", - "dateCreated": "Jan 1, 2017 9:27:30 PM", - "dateStarted": "Feb 24, 2017 5:08:08 PM", - "dateFinished": "Feb 24, 2017 5:08:11 PM", - "status": "FINISHED", - "progressUpdateIntervalMs": 500 - }, - { - "text": "%pig.query\n\nbank_data \u003d filter bank by age \u003c 30;\nb \u003d group bank_data by age;\nforeach b generate group, COUNT($1);\n\n", - "user": "anonymous", - "dateUpdated": "Feb 24, 2017 5:08:13 PM", - "config": { - "colWidth": 4.0, - "editorMode": "ace/mode/pig", - "results": { - "0": { - "graph": { - "mode": "multiBarChart", - "height": 300.0, - "optionOpen": false - }, - "helium": {} - } - }, - "enabled": true, - "editorSetting": { - "language": "pig", - "editOnDblClick": false - } - }, - "settings": { - "params": {}, - "forms": {} - }, - "results": { - "code": "SUCCESS", - "msg": [ - { - "type": "TABLE", - "data": "group\tcol_1\n19\t4\n20\t3\n21\t7\n22\t9\n23\t20\n24\t24\n25\t44\n26\t77\n27\t94\n28\t103\n29\t97\n" - } - ] - }, - "apps": [], - "jobName": "paragraph_1483277250238_-465450270", - "id": "20161228-140730_1903342877", - "dateCreated": "Jan 1, 2017 9:27:30 PM", - "dateStarted": "Feb 24, 2017 5:08:13 PM", - "dateFinished": "Feb 24, 2017 5:08:26 PM", - "status": "FINISHED", - "progressUpdateIntervalMs": 500 - }, - { - "text": "%pig.query\n\nbank_data \u003d filter bank by age \u003c ${maxAge\u003d40};\nb \u003d group bank_data by age;\nforeach b generate group, COUNT($1) as count;", - "user": "anonymous", - "dateUpdated": "Feb 24, 2017 5:08:14 PM", - "config": { - "colWidth": 4.0, - "editorMode": "ace/mode/pig", - "results": { - "0": { - "graph": { - "mode": "pieChart", - "height": 300.0, - "optionOpen": false - }, - "helium": {} - } - }, - "enabled": true, - "editorSetting": { - "language": "pig", - "editOnDblClick": false - } - }, - "settings": { - "params": { - "maxAge": "36" - }, - "forms": { - "maxAge": { - "name": "maxAge", - "defaultValue": "40", - "hidden": false - } - } - }, - "results": { - "code": "SUCCESS", - "msg": [ - { - "type": "TABLE", - "data": "group\tcount\n19\t4\n20\t3\n21\t7\n22\t9\n23\t20\n24\t24\n25\t44\n26\t77\n27\t94\n28\t103\n29\t97\n30\t150\n31\t199\n32\t224\n33\t186\n34\t231\n35\t180\n" - } - ] - }, - "apps": [], - "jobName": "paragraph_1483277250239_-465835019", - "id": "20161228-154918_1551591203", - "dateCreated": "Jan 1, 2017 9:27:30 PM", - "dateStarted": "Feb 24, 2017 5:08:14 PM", - "dateFinished": "Feb 24, 2017 5:08:29 PM", - "status": "FINISHED", - "progressUpdateIntervalMs": 500 - }, - { - "text": "%pig.query\n\nbank_data \u003d filter bank by marital\u003d\u003d\u0027${marital\u003dsingle,single|divorced|married}\u0027;\nb \u003d group bank_data by age;\nforeach b generate group, COUNT($1) as count;\n\n\n", - "user": "anonymous", - "dateUpdated": "Feb 24, 2017 5:08:15 PM", - "config": { - "colWidth": 4.0, - "editorMode": "ace/mode/pig", - "results": { - "0": { - "graph": { - "mode": "scatterChart", - "height": 300.0, - "optionOpen": false - }, - "helium": {} - } - }, - "enabled": true, - "editorSetting": { - "language": "pig", - "editOnDblClick": false - } - }, - "settings": { - "params": { - "marital": "married" - }, - "forms": { - "marital": { - "name": "marital", - "defaultValue": "single", - "options": [ - { - "value": "single" - }, - { - "value": "divorced" - }, - { - "value": "married" - } - ], - "hidden": false - } - } - }, - "results": { - "code": "SUCCESS", - "msg": [ - { - "type": "TABLE", - "data": "group\tcount\n23\t3\n24\t11\n25\t11\n26\t18\n27\t26\n28\t23\n29\t37\n30\t56\n31\t104\n32\t105\n33\t103\n34\t142\n35\t109\n36\t117\n37\t100\n38\t99\n39\t88\n40\t105\n41\t97\n42\t91\n43\t79\n44\t68\n45\t76\n46\t82\n47\t78\n48\t91\n49\t87\n50\t74\n51\t63\n52\t66\n53\t75\n54\t56\n55\t68\n56\t50\n57\t78\n58\t67\n59\t56\n60\t36\n61\t15\n62\t5\n63\t7\n64\t6\n65\t4\n66\t7\n67\t5\n68\t1\n69\t5\n70\t5\n71\t5\n72\t4\n73\t6\n74\t2\n75\t3\n76\t1\n77\t5\n78\t2\n79\t3\n80\t6\n81\t1\n83\t2\n86\t1\n87\t1\n" - } - ] - }, - "apps": [], - "jobName": "paragraph_1483277250240_-480070728", - "id": "20161228-142259_575675591", - "dateCreated": "Jan 1, 2017 9:27:30 PM", - "dateStarted": "Feb 24, 2017 5:08:27 PM", - "dateFinished": "Feb 24, 2017 5:08:31 PM", - "status": "FINISHED", - "progressUpdateIntervalMs": 500 - }, - { - "text": "%pig\n", - "dateUpdated": "Jan 1, 2017 9:27:30 PM", - "config": {}, - "settings": { - "params": {}, - "forms": {} - }, - "apps": [], - "jobName": "paragraph_1483277250240_-480070728", - "id": "20161228-155036_1854903164", - "dateCreated": "Jan 1, 2017 9:27:30 PM", - "status": "READY", - "errorMessage": "", - "progressUpdateIntervalMs": 500 - } - ], - "name": "Zeppelin Tutorial/Using Pig for querying data", - "id": "2C57UKYWR", - "angularObjects": { - "2C3RWCVAG:shared_process": [], - "2C9KGCHDE:shared_process": [], - "2C8X2BS16:shared_process": [] - }, - "config": {}, - "info": {} -} \ No newline at end of file diff --git a/smart-zeppelin/notebook/2CM8SHUUZ/note.json b/smart-zeppelin/notebook/2CM8SHUUZ/note.json deleted file mode 100644 index 11b025aaeb5..00000000000 --- a/smart-zeppelin/notebook/2CM8SHUUZ/note.json +++ /dev/null @@ -1,36 +0,0 @@ -{ - "paragraphs": [ - { - "text": "ll", - "user": "admin", - "dateUpdated": "Jul 6, 2017 1:15:06 PM", - "config": { - "colWidth": 12.0, - "enabled": true, - "results": {}, - "editorSetting": { - "language": "scala", - "editOnDblClick": false - }, - "editorMode": "ace/mode/scala" - }, - "settings": { - "params": {}, - "forms": {} - }, - "apps": [], - "jobName": "paragraph_1499310084885_-290637029", - "id": "20170706-110124_1728747823", - "dateCreated": "Jul 6, 2017 11:01:24 AM", - "status": "READY", - "progressUpdateIntervalMs": 500 - } - ], - "name": "Untitled Note 2", - "id": "2CM8SHUUZ", - "angularObjects": { - "2CPWJC381:shared_process": [] - }, - "config": {}, - "info": {} -} \ No newline at end of file diff --git a/smart-zeppelin/notebook/2CM9DW8NW/note.json b/smart-zeppelin/notebook/2CM9DW8NW/note.json index 2387cf3e1d3..36264710d52 100644 --- a/smart-zeppelin/notebook/2CM9DW8NW/note.json +++ b/smart-zeppelin/notebook/2CM9DW8NW/note.json @@ -15,7 +15,7 @@ "progressUpdateIntervalMs": 500 } ], - "name": "Untitled Note 3", + "name": "Smart", "id": "2CM9DW8NW", "angularObjects": { "2CPWJC381:shared_process": [] diff --git a/smart-zeppelin/pom.xml b/smart-zeppelin/pom.xml index 0e72c733792..5b0fad96780 100644 --- a/smart-zeppelin/pom.xml +++ b/smart-zeppelin/pom.xml @@ -56,8 +56,6 @@ zeppelin-interpreter zeppelin-zengine zeppelin-display - spark - zeppelin-web zeppelin-server diff --git a/smart-zeppelin/zeppelin-server/pom.xml b/smart-zeppelin/zeppelin-server/pom.xml index a79cf3dce26..30659a761b8 100644 --- a/smart-zeppelin/zeppelin-server/pom.xml +++ b/smart-zeppelin/zeppelin-server/pom.xml @@ -403,6 +403,11 @@ smart-common 1.0-SNAPSHOT + + org.smartdata + smart-interpreter + 1.0-SNAPSHOT + diff --git a/smart-zeppelin/zeppelin-server/src/main/java/org/apache/zeppelin/server/SmartZeppelinServer.java b/smart-zeppelin/zeppelin-server/src/main/java/org/apache/zeppelin/server/SmartZeppelinServer.java index 551553db6b2..5cbccd4c81d 100644 --- a/smart-zeppelin/zeppelin-server/src/main/java/org/apache/zeppelin/server/SmartZeppelinServer.java +++ b/smart-zeppelin/zeppelin-server/src/main/java/org/apache/zeppelin/server/SmartZeppelinServer.java @@ -327,7 +327,7 @@ private static Server setupJettyServer(ZeppelinConfiguration zconf) { } private void setupNotebookServer(WebAppContext webapp) { - notebookWsServer = new NotebookServer(); + notebookWsServer = new NotebookServer(engine); String maxTextMessageSize = zconf.getWebsocketMaxTextMessageSize(); final ServletHolder servletHolder = new ServletHolder(notebookWsServer); diff --git a/smart-zeppelin/zeppelin-server/src/main/java/org/apache/zeppelin/server/ZeppelinServer.java b/smart-zeppelin/zeppelin-server/src/main/java/org/apache/zeppelin/server/ZeppelinServer.java deleted file mode 100644 index 672a6bd6fa7..00000000000 --- a/smart-zeppelin/zeppelin-server/src/main/java/org/apache/zeppelin/server/ZeppelinServer.java +++ /dev/null @@ -1,415 +0,0 @@ -/* - * Licensed to the Apache Software Foundation (ASF) under one or more - * contributor license agreements. See the NOTICE file distributed with - * this work for additional information regarding copyright ownership. - * The ASF licenses this file to You under the Apache License, Version 2.0 - * (the "License"); you may not use this file except in compliance with - * the License. You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT 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.zeppelin.server; - -import java.io.File; -import java.io.IOException; -import java.util.EnumSet; -import java.util.HashSet; -import java.util.Set; - -import javax.servlet.DispatcherType; -import javax.ws.rs.core.Application; - -import com.sun.jersey.api.core.ApplicationAdapter; -import com.sun.jersey.api.core.PackagesResourceConfig; -import com.sun.jersey.api.core.ResourceConfig; -import com.sun.jersey.spi.container.servlet.ServletContainer; -import org.apache.commons.lang.StringUtils; -import org.apache.cxf.jaxrs.servlet.CXFNonSpringJaxrsServlet; -import org.apache.shiro.web.env.EnvironmentLoaderListener; -import org.apache.shiro.web.servlet.ShiroFilter; -import org.apache.zeppelin.conf.ZeppelinConfiguration; -import org.apache.zeppelin.conf.ZeppelinConfiguration.ConfVars; -import org.apache.zeppelin.dep.DependencyResolver; -import org.apache.zeppelin.helium.Helium; -import org.apache.zeppelin.helium.HeliumApplicationFactory; -import org.apache.zeppelin.helium.HeliumVisualizationFactory; -import org.apache.zeppelin.interpreter.InterpreterFactory; -import org.apache.zeppelin.interpreter.InterpreterOption; -import org.apache.zeppelin.interpreter.InterpreterOutput; -import org.apache.zeppelin.interpreter.InterpreterSettingManager; -import org.apache.zeppelin.notebook.Notebook; -import org.apache.zeppelin.notebook.NotebookAuthorization; -import org.apache.zeppelin.notebook.repo.NotebookRepoSync; -import org.apache.zeppelin.rest.ConfigurationsRestApi; -import org.apache.zeppelin.rest.CredentialRestApi; -import org.apache.zeppelin.rest.HeliumRestApi; -import org.apache.zeppelin.rest.InterpreterRestApi; -import org.apache.zeppelin.rest.LoginRestApi; -import org.apache.zeppelin.rest.NotebookRepoRestApi; -import org.apache.zeppelin.rest.NotebookRestApi; -import org.apache.zeppelin.rest.SecurityRestApi; -import org.apache.zeppelin.rest.ZeppelinRestApi; -import org.apache.zeppelin.scheduler.SchedulerFactory; -import org.apache.zeppelin.search.LuceneSearch; -import org.apache.zeppelin.search.SearchService; -import org.apache.zeppelin.socket.NotebookServer; -import org.apache.zeppelin.user.Credentials; -import org.apache.zeppelin.utils.SecurityUtils; -import org.eclipse.jetty.http.HttpVersion; -import org.eclipse.jetty.server.HttpConfiguration; -import org.eclipse.jetty.server.HttpConnectionFactory; -import org.eclipse.jetty.server.SecureRequestCustomizer; -import org.eclipse.jetty.server.Server; -import org.eclipse.jetty.server.ServerConnector; -import org.eclipse.jetty.server.SslConnectionFactory; -import org.eclipse.jetty.server.handler.ContextHandlerCollection; -import org.eclipse.jetty.server.session.SessionHandler; -import org.eclipse.jetty.servlet.DefaultServlet; -import org.eclipse.jetty.servlet.FilterHolder; -import org.eclipse.jetty.servlet.ServletContextHandler; -import org.eclipse.jetty.servlet.ServletHolder; -import org.eclipse.jetty.util.ssl.SslContextFactory; -import org.eclipse.jetty.webapp.WebAppContext; -import org.slf4j.Logger; -import org.slf4j.LoggerFactory; - -/** - * Main class of Zeppelin. - */ -public class ZeppelinServer extends Application { - private static final Logger LOG = LoggerFactory.getLogger(ZeppelinServer.class); - - public static Notebook notebook; - public static Server jettyWebServer; - public static NotebookServer notebookWsServer; - public static Helium helium; - - private final InterpreterSettingManager interpreterSettingManager; - private SchedulerFactory schedulerFactory; - private InterpreterFactory replFactory; - private SearchService noteSearchService; - private NotebookRepoSync notebookRepo; - private NotebookAuthorization notebookAuthorization; - private Credentials credentials; - private DependencyResolver depResolver; - - public ZeppelinServer() throws Exception { - ZeppelinConfiguration conf = ZeppelinConfiguration.create(); - - this.depResolver = new DependencyResolver( - conf.getString(ConfVars.ZEPPELIN_INTERPRETER_LOCALREPO)); - - InterpreterOutput.limit = conf.getInt(ConfVars.ZEPPELIN_INTERPRETER_OUTPUT_LIMIT); - - HeliumApplicationFactory heliumApplicationFactory = new HeliumApplicationFactory(); - HeliumVisualizationFactory heliumVisualizationFactory; - - if (isBinaryPackage(conf)) { - /* In binary package, zeppelin-web/src/app/visualization and zeppelin-web/src/app/tabledata - * are copied to lib/node_modules/zeppelin-vis, lib/node_modules/zeppelin-tabledata directory. - * Check zeppelin/zeppelin-distribution/src/assemble/distribution.xml to see how they're - * packaged into binary package. - */ - heliumVisualizationFactory = new HeliumVisualizationFactory( - conf, - new File(conf.getRelativeDir(ConfVars.ZEPPELIN_DEP_LOCALREPO)), - new File(conf.getRelativeDir("lib/node_modules/zeppelin-tabledata")), - new File(conf.getRelativeDir("lib/node_modules/zeppelin-vis"))); - } else { - heliumVisualizationFactory = new HeliumVisualizationFactory( - conf, - new File(conf.getRelativeDir(ConfVars.ZEPPELIN_DEP_LOCALREPO)), - new File(conf.getRelativeDir("zeppelin-web/src/app/tabledata")), - new File(conf.getRelativeDir("zeppelin-web/src/app/visualization"))); - } - - this.helium = new Helium( - conf.getHeliumConfPath(), - conf.getHeliumDefaultLocalRegistryPath(), - heliumVisualizationFactory, - heliumApplicationFactory); - - // create visualization bundle - try { - heliumVisualizationFactory.bundle(helium.getVisualizationPackagesToBundle()); - } catch (Exception e) { - LOG.error(e.getMessage(), e); - } - - this.schedulerFactory = new SchedulerFactory(); - this.interpreterSettingManager = new InterpreterSettingManager(conf, depResolver, - new InterpreterOption(true)); - this.replFactory = new InterpreterFactory(conf, notebookWsServer, - notebookWsServer, heliumApplicationFactory, depResolver, SecurityUtils.isAuthenticated(), - interpreterSettingManager); - this.notebookRepo = new NotebookRepoSync(conf); - this.noteSearchService = new LuceneSearch(); - this.notebookAuthorization = NotebookAuthorization.init(conf); - this.credentials = new Credentials(conf.credentialsPersist(), conf.getCredentialsPath()); - notebook = new Notebook(conf, - notebookRepo, schedulerFactory, replFactory, interpreterSettingManager, notebookWsServer, - noteSearchService, notebookAuthorization, credentials); - - // to update notebook from application event from remote process. - heliumApplicationFactory.setNotebook(notebook); - // to update fire websocket event on application event. - heliumApplicationFactory.setApplicationEventListener(notebookWsServer); - - notebook.addNotebookEventListener(heliumApplicationFactory); - notebook.addNotebookEventListener(notebookWsServer.getNotebookInformationListener()); - } - - public static void main(String[] args) throws InterruptedException { - ZeppelinConfiguration conf = ZeppelinConfiguration.create(); - conf.setProperty("args", args); - - try { - startZeppelinServer(conf); - } catch (Exception e) { - e.printStackTrace(); - } - } - - public static void startZeppelinServer(ZeppelinConfiguration conf) throws Exception { - jettyWebServer = setupJettyServer(conf); - - ContextHandlerCollection contexts = new ContextHandlerCollection(); - jettyWebServer.setHandler(contexts); - - // Web UI - final WebAppContext webApp = setupWebAppContext(contexts, conf); - - // Notebook server - setupNotebookServer(webApp, conf); - - // REST api - setupRestApiContextHandler(webApp, conf); - - //Below is commented since zeppelin-docs module is removed. - //final WebAppContext webAppSwagg = setupWebAppSwagger(conf); - - LOG.info("Starting zeppelin server"); - try { - jettyWebServer.start(); //Instantiates ZeppelinServer - } catch (Exception e) { - LOG.error("Error while running jettyServer", e); - System.exit(-1); - } - LOG.info("Done, zeppelin server started"); - - Runtime.getRuntime().addShutdownHook(new Thread(){ - @Override public void run() { - LOG.info("Shutting down Zeppelin Server ... "); - try { - jettyWebServer.stop(); - notebook.getInterpreterSettingManager().shutdown(); - notebook.close(); - Thread.sleep(3000); - } catch (Exception e) { - LOG.error("Error while stopping servlet container", e); - } - LOG.info("Bye"); - } - }); - - - // when zeppelin is started inside of ide (especially for eclipse) - // for graceful shutdown, input any key in console window - if (System.getenv("ZEPPELIN_IDENT_STRING") == null) { - try { - System.in.read(); - } catch (IOException e) { - LOG.error("Exception in ZeppelinServer while main ", e); - } - System.exit(0); - } - - jettyWebServer.join(); - ZeppelinServer.notebook.getInterpreterSettingManager().close(); - } - - private static Server setupJettyServer(ZeppelinConfiguration conf) { - - final Server server = new Server(); - ServerConnector connector; - - if (conf.useSsl()) { - LOG.debug("Enabling SSL for Zeppelin Server on port " + conf.getServerSslPort()); - HttpConfiguration httpConfig = new HttpConfiguration(); - httpConfig.setSecureScheme("https"); - httpConfig.setSecurePort(conf.getServerSslPort()); - httpConfig.setOutputBufferSize(32768); - httpConfig.setRequestHeaderSize(8192); - httpConfig.setResponseHeaderSize(8192); - httpConfig.setSendServerVersion(true); - - HttpConfiguration httpsConfig = new HttpConfiguration(httpConfig); - SecureRequestCustomizer src = new SecureRequestCustomizer(); - // Only with Jetty 9.3.x - // src.setStsMaxAge(2000); - // src.setStsIncludeSubDomains(true); - httpsConfig.addCustomizer(src); - - connector = new ServerConnector( - server, - new SslConnectionFactory(getSslContextFactory(conf), HttpVersion.HTTP_1_1.asString()), - new HttpConnectionFactory(httpsConfig)); - } else { - connector = new ServerConnector(server); - } - - // Set some timeout options to make debugging easier. - int timeout = 1000 * 30; - connector.setIdleTimeout(timeout); - connector.setSoLingerTime(-1); - connector.setHost(conf.getServerAddress()); - if (conf.useSsl()) { - connector.setPort(conf.getServerSslPort()); - } else { - connector.setPort(conf.getServerPort()); - } - - server.addConnector(connector); - - return server; - } - - private static void setupNotebookServer(WebAppContext webapp, - ZeppelinConfiguration conf) { - notebookWsServer = new NotebookServer(); - String maxTextMessageSize = conf.getWebsocketMaxTextMessageSize(); - final ServletHolder servletHolder = new ServletHolder(notebookWsServer); - servletHolder.setInitParameter("maxTextMessageSize", maxTextMessageSize); - - final ServletContextHandler cxfContext = new ServletContextHandler( - ServletContextHandler.SESSIONS); - - webapp.addServlet(servletHolder, "/ws/*"); - } - - private static SslContextFactory getSslContextFactory(ZeppelinConfiguration conf) { - SslContextFactory sslContextFactory = new SslContextFactory(); - - // Set keystore - sslContextFactory.setKeyStorePath(conf.getKeyStorePath()); - sslContextFactory.setKeyStoreType(conf.getKeyStoreType()); - sslContextFactory.setKeyStorePassword(conf.getKeyStorePassword()); - sslContextFactory.setKeyManagerPassword(conf.getKeyManagerPassword()); - - if (conf.useClientAuth()) { - sslContextFactory.setNeedClientAuth(conf.useClientAuth()); - - // Set truststore - sslContextFactory.setTrustStorePath(conf.getTrustStorePath()); - sslContextFactory.setTrustStoreType(conf.getTrustStoreType()); - sslContextFactory.setTrustStorePassword(conf.getTrustStorePassword()); - } - - return sslContextFactory; - } - - private static void setupRestApiContextHandler(WebAppContext webapp, - ZeppelinConfiguration conf) throws Exception { - ResourceConfig config = new ApplicationAdapter(new ZeppelinServer()); - ServletHolder restServletHolder = new ServletHolder(new ServletContainer(config)); - - webapp.setSessionHandler(new SessionHandler()); - webapp.addServlet(restServletHolder, "/api/*"); - - String shiroIniPath = conf.getShiroPath(); - if (!StringUtils.isBlank(shiroIniPath)) { - webapp.setInitParameter("shiroConfigLocations", new File(shiroIniPath).toURI().toString()); - SecurityUtils.initSecurityManager(shiroIniPath); - webapp.addFilter(ShiroFilter.class, "/api/*", EnumSet.allOf(DispatcherType.class)); - webapp.addEventListener(new EnvironmentLoaderListener()); - } - } - - private static WebAppContext setupWebAppContext(ContextHandlerCollection contexts, - ZeppelinConfiguration conf) { - - WebAppContext webApp = new WebAppContext(); - webApp.setContextPath(conf.getServerContextPath()); - - File warPath = new File("../dist/zeppelin-web-0.7.2.war"); - //File(conf.getString(ConfVars.ZEPPELIN_WAR)); - if (warPath.isDirectory()) { - // Development mode, read from FS - // webApp.setDescriptor(warPath+"/WEB-INF/web.xml"); - webApp.setResourceBase(warPath.getPath()); - webApp.setParentLoaderPriority(true); - } else { - // use packaged WAR - webApp.setWar(warPath.getAbsolutePath()); - File warTempDirectory = new File(conf.getRelativeDir(ConfVars.ZEPPELIN_WAR_TEMPDIR)); - warTempDirectory.mkdir(); - LOG.info("ZeppelinServer Webapp path: {}", warTempDirectory.getPath()); - webApp.setTempDirectory(warTempDirectory); - } - // Explicit bind to root - webApp.addServlet(new ServletHolder(new DefaultServlet()), "/*"); - contexts.addHandler(webApp); - - webApp.addFilter(new FilterHolder(CorsFilter.class), "/*", - EnumSet.allOf(DispatcherType.class)); - - return webApp; - } - - @Override - public Set> getClasses() { - Set> classes = new HashSet<>(); - return classes; - } - - @Override - public Set getSingletons() { - Set singletons = new HashSet<>(); - - /** Rest-api root endpoint */ - ZeppelinRestApi root = new ZeppelinRestApi(); - singletons.add(root); - - NotebookRestApi notebookApi - = new NotebookRestApi(notebook, notebookWsServer, noteSearchService); - singletons.add(notebookApi); - - NotebookRepoRestApi notebookRepoApi = new NotebookRepoRestApi(notebookRepo, notebookWsServer); - singletons.add(notebookRepoApi); - - HeliumRestApi heliumApi = new HeliumRestApi(helium, notebook); - singletons.add(heliumApi); - - InterpreterRestApi interpreterApi = new InterpreterRestApi(interpreterSettingManager); - singletons.add(interpreterApi); - - CredentialRestApi credentialApi = new CredentialRestApi(credentials); - singletons.add(credentialApi); - - SecurityRestApi securityApi = new SecurityRestApi(); - singletons.add(securityApi); - - LoginRestApi loginRestApi = new LoginRestApi(); - singletons.add(loginRestApi); - - ConfigurationsRestApi settingsApi = new ConfigurationsRestApi(notebook); - singletons.add(settingsApi); - - return singletons; - } - - /** - * Check if it is source build or binary package - * @return - */ - private static boolean isBinaryPackage(ZeppelinConfiguration conf) { - return !new File(conf.getRelativeDir("zeppelin-web")).isDirectory(); - } -} diff --git a/smart-zeppelin/zeppelin-server/src/main/java/org/apache/zeppelin/socket/NotebookServer.java b/smart-zeppelin/zeppelin-server/src/main/java/org/apache/zeppelin/socket/NotebookServer.java index 3e3670a466c..c746cab8553 100644 --- a/smart-zeppelin/zeppelin-server/src/main/java/org/apache/zeppelin/socket/NotebookServer.java +++ b/smart-zeppelin/zeppelin-server/src/main/java/org/apache/zeppelin/socket/NotebookServer.java @@ -88,6 +88,10 @@ import com.google.common.collect.Queues; import com.google.gson.reflect.TypeToken; +import org.smartdata.interpreter.SmartInterpreter; +import org.smartdata.interpreter.impl.ActionInterpreter; +import org.smartdata.interpreter.impl.RuleInterpreter; +import org.smartdata.server.SmartEngine; /** * Zeppelin websocket service. @@ -95,7 +99,6 @@ public class NotebookServer extends WebSocketServlet implements NotebookSocketListener, JobListenerFactory, AngularObjectRegistryListener, RemoteInterpreterProcessListener, ApplicationEventListener { - /** * Job manager service type */ @@ -118,7 +121,7 @@ String getKey() { final Map> noteSocketMap = new HashMap<>(); final Queue connectedSockets = new ConcurrentLinkedQueue<>(); final Map> userConnectedSockets = new ConcurrentHashMap<>(); - + private SmartEngine smartEngine; /** * This is a special endpoint in the notebook websoket, Every connection in this Queue * will be able to watch every websocket event, it doesnt need to be listed into the map of @@ -127,6 +130,10 @@ String getKey() { */ final Queue watcherSockets = Queues.newConcurrentLinkedQueue(); + public NotebookServer(SmartEngine smartEngine) { + this.smartEngine = smartEngine; + } + private Notebook notebook() { return SmartZeppelinServer.notebook; } @@ -167,7 +174,7 @@ public void onMessage(NotebookSocket conn, String msg) { LOG.debug("RECEIVE PRINCIPAL << " + messagereceived.principal); LOG.debug("RECEIVE TICKET << " + messagereceived.ticket); LOG.debug("RECEIVE ROLES << " + messagereceived.roles); - + LOG.info("messagereceived.op = " + messagereceived.op); if (LOG.isTraceEnabled()) { LOG.trace("RECEIVE MSG = " + messagereceived); } @@ -259,10 +266,11 @@ public void onMessage(NotebookSocket conn, String msg) { importNote(conn, userAndRoles, notebook, messagereceived); break; case COMMIT_PARAGRAPH: - updateParagraph(conn, userAndRoles, notebook, messagereceived); + LOG.info("COMMIT_PARAGRAPH.........................."); break; case RUN_PARAGRAPH: - runParagraph(conn, userAndRoles, notebook, messagereceived); + updateParagraph(conn, userAndRoles, notebook, messagereceived); +// runParagraph(conn, userAndRoles, notebook, messagereceived); break; case RUN_ALL_PARAGRAPHS: runAllParagraphs(conn, userAndRoles, notebook, messagereceived); @@ -1025,7 +1033,6 @@ private void moveFolderToTrash(NotebookSocket conn, HashSet userAndRoles if (folderId == null) { return; } - Folder folder = notebook.getFolder(folderId); if (folder != null && !folder.isTrash()) { String trashFolderId = Folder.TRASH_FOLDER_ID + "/" + folderId; @@ -1103,6 +1110,7 @@ private void updateParagraph(NotebookSocket conn, HashSet userAndRoles, Notebook notebook, Message fromMessage) throws IOException { String paragraphId = (String) fromMessage.get("id"); if (paragraphId == null) { + LOG.error("paragraphId is null."); return; } @@ -1118,6 +1126,15 @@ private void updateParagraph(NotebookSocket conn, HashSet userAndRoles, return; } + String text = (String) fromMessage.get("paragraph"); + String[] items = text.trim().split("\\s+"); + + StringBuilder sb = new StringBuilder(); + for (int i = 1; i < items.length; i++) { + sb.append(items[i]); + sb.append(" "); + } + Paragraph p = note.getParagraph(paragraphId); if (note.isPersonalizedMode()) { @@ -1137,10 +1154,27 @@ private void updateParagraph(NotebookSocket conn, HashSet userAndRoles, p.setTitle((String) fromMessage.get("title")); p.setText((String) fromMessage.get("paragraph")); } - - note.persist(subject); + SmartInterpreter smartInterpreter = null; + if (items[0].equals("%action")) { + smartInterpreter = new ActionInterpreter(smartEngine); + } else if (items[0].equals("%rule")) { + smartInterpreter = new RuleInterpreter(smartEngine); + } else { + p.setResult(new InterpreterResult(InterpreterResult.Code.SUCCESS, "%html " + + "Can not format " + items[0])); + broadcastParagraph(note, p); + return; + } + try { + String result = smartInterpreter.excute(sb.toString()); + p.setResult(new InterpreterResult(InterpreterResult.Code.SUCCESS, "%html " + result)); + } catch (IOException e) { + p.setReturn(new InterpreterResult(InterpreterResult.Code.ERROR, e.getMessage()), e); + p.setStatus(Status.ERROR); + } + if (note.isPersonalizedMode()) { Map userParagraphMap = note.getParagraph(paragraphId).getUserParagraphMap(); diff --git a/smart-zeppelin/zeppelin-server/src/test/java/com/webautomation/ScreenCaptureHtmlUnitDriver.java b/smart-zeppelin/zeppelin-server/src/test/java/com/webautomation/ScreenCaptureHtmlUnitDriver.java deleted file mode 100644 index adad8075e21..00000000000 --- a/smart-zeppelin/zeppelin-server/src/test/java/com/webautomation/ScreenCaptureHtmlUnitDriver.java +++ /dev/null @@ -1,224 +0,0 @@ -/* - * Licensed to the Apache Software Foundation (ASF) under one or more - * contributor license agreements. See the NOTICE file distributed with - * this work for additional information regarding copyright ownership. - * The ASF licenses this file to You under the Apache License, Version 2.0 - * (the "License"); you may not use this file except in compliance with - * the License. You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT 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 com.webautomation; - -import java.io.ByteArrayOutputStream; -import java.io.File; -import java.io.FileOutputStream; -import java.io.IOException; -import java.net.URL; -import java.util.Collections; -import java.util.HashMap; -import java.util.Iterator; -import java.util.LinkedList; -import java.util.List; -import java.util.Map; -import java.util.regex.Matcher; -import java.util.regex.Pattern; -import java.util.zip.ZipEntry; -import java.util.zip.ZipOutputStream; - -import org.apache.commons.io.FilenameUtils; -import org.apache.commons.io.IOUtils; -import org.openqa.selenium.Capabilities; -import org.openqa.selenium.OutputType; -import org.openqa.selenium.TakesScreenshot; -import org.openqa.selenium.WebDriverException; -import org.openqa.selenium.htmlunit.HtmlUnitDriver; -import org.openqa.selenium.internal.Base64Encoder; -import org.openqa.selenium.remote.CapabilityType; -import org.openqa.selenium.remote.DesiredCapabilities; - -import com.gargoylesoftware.htmlunit.BrowserVersion; -import com.gargoylesoftware.htmlunit.WebClient; -import com.gargoylesoftware.htmlunit.WebRequest; -import com.gargoylesoftware.htmlunit.WebWindow; -import com.gargoylesoftware.htmlunit.html.HtmlElement; -import com.gargoylesoftware.htmlunit.html.HtmlPage; -import org.slf4j.Logger; -import org.slf4j.LoggerFactory; - -/** - * from https://code.google.com/p/selenium/issues/detail?id=1361 - */ -public class ScreenCaptureHtmlUnitDriver extends HtmlUnitDriver implements TakesScreenshot { - - private static Map imagesCache = Collections.synchronizedMap(new HashMap()); - - private static Map cssjsCache = Collections.synchronizedMap(new HashMap()); - - // http://stackoverflow.com/questions/4652777/java-regex-to-get-the-urls-from-css - private final static Pattern cssUrlPattern = Pattern.compile("background(-image)?[\\s]*:[^url]*url[\\s]*\\([\\s]*([^\\)]*)[\\s]*\\)[\\s]*");// ? - - static Logger LOGGER = LoggerFactory.getLogger(ScreenCaptureHtmlUnitDriver.class); - - public ScreenCaptureHtmlUnitDriver() { - super(); - } - - public ScreenCaptureHtmlUnitDriver(boolean enableJavascript) { - super(enableJavascript); - } - - public ScreenCaptureHtmlUnitDriver(Capabilities capabilities) { - super(capabilities); - } - - public ScreenCaptureHtmlUnitDriver(BrowserVersion version) { - super(version); - DesiredCapabilities var = ((DesiredCapabilities) getCapabilities()); - var.setCapability(CapabilityType.TAKES_SCREENSHOT, true); - } - - @Override - @SuppressWarnings("unchecked") - public X getScreenshotAs(OutputType target) throws WebDriverException { - byte[] archive = new byte[0]; - try { - archive = downloadCssAndImages(getWebClient(), (HtmlPage) getCurrentWindow().getEnclosedPage()); - } catch (Exception e) { - LOGGER.error("Exception in ScreenCaptureHtmlUnitDriver while getScreenshotAs ", e); - } - if(target.equals(OutputType.BASE64)){ - return target.convertFromBase64Png(new Base64Encoder().encode(archive)); - } - if(target.equals(OutputType.FILE)){ - File f = new File("screen.tmp"); - try { - FileOutputStream scr = new FileOutputStream(f); - scr.write(archive); - scr.close(); - } catch (IOException e) { - throw new WebDriverException(e); - } - return (X) f; - } - return (X) archive; - } - - // http://stackoverflow.com/questions/2244272/how-can-i-tell-htmlunits-webclient-to-download-images-and-css - protected byte[] downloadCssAndImages(WebClient webClient, HtmlPage page) throws Exception { - WebWindow currentWindow = webClient.getCurrentWindow(); - Map urlMapping = new HashMap<>(); - Map files = new HashMap<>(); - WebWindow window = null; - try { - window = webClient.getWebWindowByName(page.getUrl().toString()+"_screenshot"); - webClient.getPage(window, new WebRequest(page.getUrl())); - } catch (Exception e) { - LOGGER.error("Exception in ScreenCaptureHtmlUnitDriver while downloadCssAndImages ", e); - window = webClient.openWindow(page.getUrl(), page.getUrl().toString()+"_screenshot"); - } - - String xPathExpression = "//*[name() = 'img' or name() = 'link' and (@type = 'text/css' or @type = 'image/x-icon') or @type = 'text/javascript']"; - List resultList = page.getByXPath(xPathExpression); - - Iterator i = resultList.iterator(); - while (i.hasNext()) { - try { - HtmlElement el = (HtmlElement) i.next(); - String resourceSourcePath = el.getAttribute("src").equals("") ? el.getAttribute("href") : el - .getAttribute("src"); - if (resourceSourcePath == null || resourceSourcePath.equals("")) - continue; - URL resourceRemoteLink = page.getFullyQualifiedUrl(resourceSourcePath); - String resourceLocalPath = mapLocalUrl(page, resourceRemoteLink, resourceSourcePath, urlMapping); - urlMapping.put(resourceSourcePath, resourceLocalPath); - if (!resourceRemoteLink.toString().endsWith(".css")) { - byte[] image = downloadImage(webClient, window, resourceRemoteLink); - files.put(resourceLocalPath, image); - } else { - String css = downloadCss(webClient, window, resourceRemoteLink); - for (String cssImagePath : getLinksFromCss(css)) { - URL cssImagelink = page.getFullyQualifiedUrl(cssImagePath.replace("\"", "").replace("\'", "") - .replace(" ", "")); - String cssImageLocalPath = mapLocalUrl(page, cssImagelink, cssImagePath, urlMapping); - files.put(cssImageLocalPath, downloadImage(webClient, window, cssImagelink)); - } - files.put(resourceLocalPath, replaceRemoteUrlsWithLocal(css, urlMapping) - .replace("resources/", "./").getBytes()); - } - } catch (Exception e) { - LOGGER.error("Exception in ScreenCaptureHtmlUnitDriver while resultList.iterator ", e); - } - } - String pagesrc = replaceRemoteUrlsWithLocal(page.getWebResponse().getContentAsString(), urlMapping); - files.put("page.html", pagesrc.getBytes()); - webClient.setCurrentWindow(currentWindow); - return createZip(files); - } - - String downloadCss(WebClient webClient, WebWindow window, URL resourceUrl) throws Exception { - if (cssjsCache.get(resourceUrl.toString()) == null) { - cssjsCache.put(resourceUrl.toString(), webClient.getPage(window, new WebRequest(resourceUrl)) - .getWebResponse().getContentAsString()); - - } - return cssjsCache.get(resourceUrl.toString()); - } - - byte[] downloadImage(WebClient webClient, WebWindow window, URL resourceUrl) throws Exception { - if (imagesCache.get(resourceUrl.toString()) == null) { - imagesCache.put( - resourceUrl.toString(), - IOUtils.toByteArray(webClient.getPage(window, new WebRequest(resourceUrl)).getWebResponse() - .getContentAsStream())); - } - return imagesCache.get(resourceUrl.toString()); - } - - public static byte[] createZip(Map files) throws IOException { - ByteArrayOutputStream bos = new ByteArrayOutputStream(); - ZipOutputStream zipfile = new ZipOutputStream(bos); - Iterator i = files.keySet().iterator(); - String fileName = null; - ZipEntry zipentry = null; - while (i.hasNext()) { - fileName = i.next(); - zipentry = new ZipEntry(fileName); - zipfile.putNextEntry(zipentry); - zipfile.write(files.get(fileName)); - } - zipfile.close(); - return bos.toByteArray(); - } - - List getLinksFromCss(String css) { - List result = new LinkedList<>(); - Matcher m = cssUrlPattern.matcher(css); - while (m.find()) { // find next match - result.add( m.group(2)); - } - return result; - } - - String replaceRemoteUrlsWithLocal(String source, Map replacement) { - for (String object : replacement.keySet()) { - // background:url(http://org.com/images/image.gif) - source = source.replace(object, replacement.get(object)); - } - return source; - } - - String mapLocalUrl(HtmlPage page, URL link, String path, Map replacementToAdd) throws Exception { - String resultingFileName = "resources/" + FilenameUtils.getName(link.getFile()); - replacementToAdd.put(path, resultingFileName); - return resultingFileName; - } - -} \ No newline at end of file diff --git a/smart-zeppelin/zeppelin-server/src/test/java/org/apache/zeppelin/AbstractZeppelinIT.java b/smart-zeppelin/zeppelin-server/src/test/java/org/apache/zeppelin/AbstractZeppelinIT.java deleted file mode 100644 index f8498685580..00000000000 --- a/smart-zeppelin/zeppelin-server/src/test/java/org/apache/zeppelin/AbstractZeppelinIT.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.zeppelin; - - -import com.google.common.base.Function; -import org.apache.commons.codec.binary.Base64; -import org.apache.commons.io.FileUtils; -import org.openqa.selenium.*; -import org.openqa.selenium.logging.LogEntries; -import org.openqa.selenium.logging.LogEntry; -import org.openqa.selenium.logging.LogType; -import org.openqa.selenium.support.ui.ExpectedConditions; -import org.openqa.selenium.support.ui.FluentWait; -import org.openqa.selenium.support.ui.Wait; -import org.openqa.selenium.support.ui.WebDriverWait; -import org.slf4j.Logger; -import org.slf4j.LoggerFactory; - -import java.io.File; -import java.util.Date; -import java.util.concurrent.TimeUnit; - -abstract public class AbstractZeppelinIT { - protected static WebDriver driver; - - protected final static Logger LOG = LoggerFactory.getLogger(AbstractZeppelinIT.class); - protected static final long MAX_IMPLICIT_WAIT = 30; - protected static final long MAX_BROWSER_TIMEOUT_SEC = 30; - protected static final long MAX_PARAGRAPH_TIMEOUT_SEC = 60; - - protected void setTextOfParagraph(int paragraphNo, String text) { - String editorId = driver.findElement(By.xpath(getParagraphXPath(paragraphNo) + "//div[contains(@class, 'editor')]")).getAttribute("id"); - if (driver instanceof JavascriptExecutor) { - ((JavascriptExecutor) driver).executeScript("ace.edit('" + editorId + "'). setValue('" + text + "')"); - } else { - throw new IllegalStateException("This driver does not support JavaScript!"); - } - } - - protected void runParagraph(int paragraphNo) { - driver.findElement(By.xpath(getParagraphXPath(paragraphNo) + "//span[@class='icon-control-play']")).click(); - } - - - protected String getParagraphXPath(int paragraphNo) { - return "(//div[@ng-controller=\"ParagraphCtrl\"])[" + paragraphNo + "]"; - } - - protected boolean waitForParagraph(final int paragraphNo, final String state) { - By locator = By.xpath(getParagraphXPath(paragraphNo) - + "//div[contains(@class, 'control')]//span[1][contains(.,'" + state + "')]"); - WebElement element = pollingWait(locator, MAX_PARAGRAPH_TIMEOUT_SEC); - return element.isDisplayed(); - } - - protected String getParagraphStatus(final int paragraphNo) { - By locator = By.xpath(getParagraphXPath(paragraphNo) - + "//div[contains(@class, 'control')]//span[1]"); - - return driver.findElement(locator).getText(); - } - - protected boolean waitForText(final String txt, final By locator) { - try { - WebElement element = pollingWait(locator, MAX_BROWSER_TIMEOUT_SEC); - return txt.equals(element.getText()); - } catch (TimeoutException e) { - return false; - } - } - - protected WebElement pollingWait(final By locator, final long timeWait) { - Wait wait = new FluentWait<>(driver) - .withTimeout(timeWait, TimeUnit.SECONDS) - .pollingEvery(1, TimeUnit.SECONDS) - .ignoring(NoSuchElementException.class); - - return wait.until(new Function() { - public WebElement apply(WebDriver driver) { - return driver.findElement(locator); - } - }); - } - - protected static boolean endToEndTestEnabled() { - return null != System.getenv("TEST_SELENIUM"); - } - - protected void createNewNote() { - clickAndWait(By.xpath("//div[contains(@class, \"col-md-4\")]/div/h5/a[contains(.,'Create new" + - " note')]")); - - WebDriverWait block = new WebDriverWait(driver, MAX_BROWSER_TIMEOUT_SEC); - block.until(ExpectedConditions.visibilityOfElementLocated(By.id("noteNameModal"))); - clickAndWait(By.id("createNoteButton")); - block.until(ExpectedConditions.invisibilityOfElementLocated(By.className("pull-right"))); - } - - protected void deleteTestNotebook(final WebDriver driver) { - WebDriverWait block = new WebDriverWait(driver, MAX_BROWSER_TIMEOUT_SEC); - driver.findElement(By.xpath(".//*[@id='main']//button[@ng-click='moveNoteToTrash(note.id)']")) - .sendKeys(Keys.ENTER); - block.until(ExpectedConditions.visibilityOfElementLocated(By.xpath(".//*[@id='main']//button[@ng-click='moveNoteToTrash(note.id)']"))); - driver.findElement(By.xpath("//div[@class='modal-dialog'][contains(.,'This note will be moved to trash')]" + - "//div[@class='modal-footer']//button[contains(.,'OK')]")).click(); - ZeppelinITUtils.sleep(100, true); - } - - protected void clickAndWait(final By locator) { - pollingWait(locator, MAX_IMPLICIT_WAIT).click(); - ZeppelinITUtils.sleep(1000, true); - } - - protected void handleException(String message, Exception e) throws Exception { - LOG.error(message, e); - LogEntries logEntries = driver.manage().logs().get(LogType.BROWSER); - for (LogEntry entry : logEntries) { - LOG.error(new Date(entry.getTimestamp()) + " " + entry.getLevel() + " " + entry.getMessage()); - } - File scrFile = ((TakesScreenshot) driver).getScreenshotAs(OutputType.FILE); - LOG.error("ScreenShot::\ndata:image/png;base64," + new String(Base64.encodeBase64(FileUtils.readFileToByteArray(scrFile)))); - throw e; - } - -} diff --git a/smart-zeppelin/zeppelin-server/src/test/java/org/apache/zeppelin/CommandExecutor.java b/smart-zeppelin/zeppelin-server/src/test/java/org/apache/zeppelin/CommandExecutor.java deleted file mode 100644 index 9ac222a0848..00000000000 --- a/smart-zeppelin/zeppelin-server/src/test/java/org/apache/zeppelin/CommandExecutor.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.zeppelin; - -import org.apache.commons.lang3.StringUtils; -import org.slf4j.Logger; -import org.slf4j.LoggerFactory; - -import java.io.IOException; -import java.util.ArrayList; -import java.util.Arrays; -import java.util.List; - -public class CommandExecutor { - - public final static Logger LOG = LoggerFactory.getLogger(CommandExecutor.class); - - public enum IGNORE_ERRORS { - TRUE, - FALSE - } - - public static int NORMAL_EXIT = 0; - - private static IGNORE_ERRORS DEFAULT_BEHAVIOUR_ON_ERRORS = IGNORE_ERRORS.TRUE; - - public static Object executeCommandLocalHost(String[] command, boolean printToConsole, ProcessData.Types_Of_Data type, IGNORE_ERRORS ignore_errors) { - List subCommandsAsList = new ArrayList<>(Arrays.asList(command)); - String mergedCommand = StringUtils.join(subCommandsAsList, " "); - - LOG.info("Sending cmdlet \"" + mergedCommand + "\" to localhost"); - - ProcessBuilder processBuilder = new ProcessBuilder(command); - Process process = null; - try { - process = processBuilder.start(); - } catch (IOException e) { - throw new RuntimeException(e); - } - - ProcessData data_of_process = new ProcessData(process, printToConsole); - Object output_of_process = data_of_process.getData(type); - int exit_code = data_of_process.getExitCodeValue(); - - if (!printToConsole) - LOG.trace(output_of_process.toString()); - else - LOG.debug(output_of_process.toString()); - if (ignore_errors == IGNORE_ERRORS.FALSE && exit_code != NORMAL_EXIT) { - LOG.error(String.format("*********************Command '%s' failed with exitcode %s *********************", mergedCommand, exit_code)); - } - return output_of_process; - } - - public static Object executeCommandLocalHost(String command, boolean printToConsole, ProcessData.Types_Of_Data type) { - return executeCommandLocalHost(new String[]{"bash", "-c", command}, printToConsole, type, DEFAULT_BEHAVIOUR_ON_ERRORS); - } - -} diff --git a/smart-zeppelin/zeppelin-server/src/test/java/org/apache/zeppelin/ProcessData.java b/smart-zeppelin/zeppelin-server/src/test/java/org/apache/zeppelin/ProcessData.java deleted file mode 100644 index 39e40747657..00000000000 --- a/smart-zeppelin/zeppelin-server/src/test/java/org/apache/zeppelin/ProcessData.java +++ /dev/null @@ -1,249 +0,0 @@ -/* - * Licensed to the Apache Software Foundation (ASF) under one or more - * contributor license agreements. See the NOTICE file distributed with - * this work for additional information regarding copyright ownership. - * The ASF licenses this file to You under the Apache License, Version 2.0 - * (the "License"); you may not use this file except in compliance with - * the License. You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT 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.zeppelin; - - -import org.slf4j.Logger; -import org.slf4j.LoggerFactory; - -import java.io.*; -import java.util.concurrent.TimeUnit; - -public class ProcessData { - public enum Types_Of_Data { - OUTPUT, - ERROR, - EXIT_CODE, - STREAMS_MERGED, - PROCESS_DATA_OBJECT - } - - public final static Logger LOG = LoggerFactory.getLogger(ProcessData.class); - - private Process checked_process; - private boolean printToConsole = false; - private boolean removeRedundantOutput = true; - - public ProcessData(Process connected_process, boolean printToConsole, int silenceTimeout, TimeUnit timeUnit) { - this.checked_process = connected_process; - this.printToConsole = printToConsole; - this.silenceTimeout = TimeUnit.MILLISECONDS.convert(silenceTimeout, timeUnit); - } - - public ProcessData(Process connected_process, boolean printToConsole, int silenceTimeoutSec) { - this.checked_process = connected_process; - this.printToConsole = printToConsole; - this.silenceTimeout = TimeUnit.MILLISECONDS.convert(silenceTimeoutSec, TimeUnit.SECONDS); - } - - public ProcessData(Process connected_process, boolean printToConsole) { - this.checked_process = connected_process; - this.printToConsole = printToConsole; - } - - public ProcessData(Process connected_process) { - this.checked_process = connected_process; - this.printToConsole = true; - } - - - boolean returnCodeRetrieved = false; - - private String outPutStream = null; - private String errorStream = null; - private int returnCode; - private long silenceTimeout = 10 * 60 * 1000; - private final long unconditionalExitDelayMinutes = 30; - - public static boolean isRunning(Process process) { - try { - process.exitValue(); - return false; - } catch (IllegalThreadStateException e) { - return true; - } - } - - public Object getData(Types_Of_Data type) { - //TODO get rid of Pseudo-terminal will not be allocated because stdin is not a terminal. - switch (type) { - case OUTPUT: { - return this.getOutPutStream(); - } - case ERROR: { - return this.getErrorStream(); - } - case EXIT_CODE: { - return this.getExitCodeValue(); - } - case STREAMS_MERGED: { - return this.getOutPutStream() + "\n" + this.getErrorStream(); - } - case PROCESS_DATA_OBJECT: { - this.getErrorStream(); - return this; - } - default: { - throw new IllegalArgumentException("Data Type " + type + " not supported yet!"); - } - } - } - - public int getExitCodeValue() { - try { - if (!returnCodeRetrieved) { - this.checked_process.waitFor(); - this.returnCode = this.checked_process.exitValue(); - this.returnCodeRetrieved = true; - this.checked_process.destroy(); - } - } catch (Exception inter) { - throw new RuntimeException("Couldn't finish waiting for process " + this.checked_process + " termination", inter); - } - return this.returnCode; - } - - public String getOutPutStream() { - if (this.outPutStream == null) { - try { - buildOutputAndErrorStreamData(); - } catch (Exception e) { - throw new RuntimeException("Couldn't retrieve Output Stream data from process: " + this.checked_process.toString(), e); - - } - } - this.outPutStream = this.outPutStream.replace("Pseudo-terminal will not be allocated because stdin is not a terminal.", ""); - this.errorStream = this.errorStream.replace("Pseudo-terminal will not be allocated because stdin is not a terminal.", ""); - return this.outPutStream; - } - - public String getErrorStream() { - if (this.errorStream == null) { - try { - buildOutputAndErrorStreamData(); - } catch (Exception e) { - throw new RuntimeException("Couldn't retrieve Error Stream data from process: " + this.checked_process.toString(), e); - - } - } - this.outPutStream = this.outPutStream.replace("Pseudo-terminal will not be allocated because stdin is not a terminal.", ""); - this.errorStream = this.errorStream.replace("Pseudo-terminal will not be allocated because stdin is not a terminal.", ""); - return this.errorStream; - } - - public String toString() { - StringBuilder result = new StringBuilder(); - result.append(String.format("[OUTPUT STREAM]\n%s\n", this.outPutStream)); - result.append(String.format("[ERROR STREAM]\n%s\n", this.errorStream)); - result.append(String.format("[EXIT CODE]\n%d", this.returnCode)); - return result.toString(); - } - - private void buildOutputAndErrorStreamData() throws IOException { - StringBuilder sbInStream = new StringBuilder(); - StringBuilder sbErrorStream = new StringBuilder(); - - try { - InputStream in = this.checked_process.getInputStream(); - InputStream inErrors = this.checked_process.getErrorStream(); - BufferedReader inReader = new BufferedReader(new InputStreamReader(in)); - BufferedReader inReaderErrors = new BufferedReader(new InputStreamReader(inErrors)); - LOG.trace("Started retrieving data from streams of attached process: " + this.checked_process); - - long lastStreamDataTime = System.currentTimeMillis(); //Store start time to be able to finish method if cmdlet hangs - long unconditionalExitTime = System.currentTimeMillis() + TimeUnit.MILLISECONDS.convert(unconditionalExitDelayMinutes, TimeUnit.MINUTES); // Stop after 'unconditionalExitDelayMinutes' even if process is alive and sending output - final int BUFFER_LEN = 300; - char charBuffer[] = new char[BUFFER_LEN]; //Use char buffer to read output, size can be tuned. - boolean outputProduced = true; //Flag to check if previous iteration produced any output - while (isRunning(this.checked_process) || outputProduced) { //Continue if process is alive or some output was produced on previous iteration and there may be still some data to read. - outputProduced = false; - ZeppelinITUtils.sleep(100, false); //Some local commands can exit fast, but immediate stream reading will give no output and after iteration, 'while' condition will be false so we will not read out any output while it is still there, just need to wait for some time for it to appear in streams. - - StringBuilder tempSB = new StringBuilder(); - while (inReader.ready()) { - tempSB.setLength(0); // clean temporary StringBuilder - int readCount = inReader.read(charBuffer, 0, BUFFER_LEN); //read up to 'BUFFER_LEN' chars to buffer - if (readCount < 1) { // if nothing read or error occurred - break; - } - tempSB.append(charBuffer, 0, readCount); - - sbInStream.append(tempSB); - if (tempSB.length() > 0) { - outputProduced = true; //set flag to know that we read something and there may be moire data, even if process already exited - } - - lastStreamDataTime = System.currentTimeMillis(); //remember last time data was read from streams to be sure we are not looping infinitely - } - - tempSB = new StringBuilder(); //Same, but for error stream - while (inReaderErrors.ready()) { - tempSB.setLength(0); - int readCount = inReaderErrors.read(charBuffer, 0, BUFFER_LEN); - if (readCount < 1) { - break; - } - tempSB.append(charBuffer, 0, readCount); - sbErrorStream.append(tempSB); - if (tempSB.length() > 0) { - outputProduced = true; - String temp = new String(tempSB); - temp = temp.replaceAll("Pseudo-terminal will not be allocated because stdin is not a terminal.", ""); - //TODO : error stream output need to be improved, because it outputs downloading information. - if (printToConsole) { - if (!temp.trim().equals("")) { - if (temp.toLowerCase().contains("error") || temp.toLowerCase().contains("failed")) { - LOG.warn(temp.trim()); - } else { - LOG.debug(temp.trim()); - } - } - } - } - lastStreamDataTime = System.currentTimeMillis(); - } - - - if ((System.currentTimeMillis() - lastStreamDataTime > silenceTimeout) || //Exit if silenceTimeout ms has passed from last stream read. Means process is alive but not sending any data. - (System.currentTimeMillis() > unconditionalExitTime)) { //Exit unconditionally - guards against alive process continuously sending data. - LOG.info("Conditions: " + (System.currentTimeMillis() - lastStreamDataTime > silenceTimeout) + " " + - (System.currentTimeMillis() > unconditionalExitTime)); - this.checked_process.destroy(); - try { - if ((System.currentTimeMillis() > unconditionalExitTime)) - LOG.error("!@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@Unconditional exit occured@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@!\nsome process hag up for more than " + unconditionalExitDelayMinutes + " minutes."); - LOG.error("!##################################!"); - StringWriter sw = new StringWriter(); - new Exception("Exited from buildOutputAndErrorStreamData by timeout").printStackTrace(new PrintWriter(sw)); //Get stack trace - String exceptionAsString = sw.toString(); - LOG.error(exceptionAsString); - } catch (Exception ignore) { - LOG.info("Exception in ProcessData while buildOutputAndErrorStreamData ", ignore); - } - break; - } - } - - in.close(); - inErrors.close(); - } finally { - this.outPutStream = sbInStream.toString(); - this.errorStream = sbErrorStream.toString(); - } - } -} diff --git a/smart-zeppelin/zeppelin-server/src/test/java/org/apache/zeppelin/WebDriverManager.java b/smart-zeppelin/zeppelin-server/src/test/java/org/apache/zeppelin/WebDriverManager.java deleted file mode 100644 index da34e7299a6..00000000000 --- a/smart-zeppelin/zeppelin-server/src/test/java/org/apache/zeppelin/WebDriverManager.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.zeppelin; - -import org.apache.commons.io.FileUtils; -import org.openqa.selenium.By; -import org.openqa.selenium.TimeoutException; -import org.openqa.selenium.WebDriver; -import org.openqa.selenium.chrome.ChromeDriver; -import org.openqa.selenium.firefox.FirefoxBinary; -import org.openqa.selenium.firefox.FirefoxDriver; -import org.openqa.selenium.firefox.FirefoxProfile; -import org.openqa.selenium.safari.SafariDriver; -import org.openqa.selenium.support.ui.ExpectedCondition; -import org.openqa.selenium.support.ui.WebDriverWait; -import org.slf4j.Logger; -import org.slf4j.LoggerFactory; - -import java.io.File; -import java.io.IOException; -import java.net.URL; -import java.util.concurrent.TimeUnit; - -import static org.junit.Assert.fail; - - -public class WebDriverManager { - - public final static Logger LOG = LoggerFactory.getLogger(WebDriverManager.class); - - private static String downLoadsDir = ""; - - public static WebDriver getWebDriver() { - WebDriver driver = null; - - if (driver == null) { - try { - FirefoxBinary ffox = new FirefoxBinary(); - if ("true".equals(System.getenv("TRAVIS"))) { - ffox.setEnvironmentProperty("DISPLAY", ":99"); // xvfb is supposed to - // run with DISPLAY 99 - } - int firefoxVersion = WebDriverManager.getFirefoxVersion(); - LOG.info("Firefox version " + firefoxVersion + " detected"); - - downLoadsDir = FileUtils.getTempDirectory().toString(); - - String tempPath = downLoadsDir + "/firebug/"; - - downloadFireBug(firefoxVersion, tempPath); - - final String firebugPath = tempPath + "firebug.xpi"; - final String firepathPath = tempPath + "firepath.xpi"; - - FirefoxProfile profile = new FirefoxProfile(); - profile.setPreference("browser.download.folderList", 2); - profile.setPreference("browser.download.dir", downLoadsDir); - profile.setPreference("browser.helperApps.alwaysAsk.force", false); - profile.setPreference("browser.download.manager.showWhenStarting", false); - profile.setPreference("browser.download.manager.showAlertOnComplete", false); - profile.setPreference("browser.download.manager.closeWhenDone", true); - profile.setPreference("app.update.auto", false); - profile.setPreference("app.update.enabled", false); - profile.setPreference("dom.max_script_run_time", 0); - profile.setPreference("dom.max_chrome_script_run_time", 0); - profile.setPreference("browser.helperApps.neverAsk.saveToDisk", "application/x-ustar,application/octet-stream,application/zip,text/csv,text/plain"); - profile.setPreference("network.proxy.type", 0); - - profile.addExtension(new File(firebugPath)); - profile.addExtension(new File(firepathPath)); - - driver = new FirefoxDriver(ffox, profile); - } catch (Exception e) { - LOG.error("Exception in WebDriverManager while FireFox Driver ", e); - } - } - - if (driver == null) { - try { - driver = new ChromeDriver(); - } catch (Exception e) { - LOG.error("Exception in WebDriverManager while ChromeDriver ", e); - } - } - - if (driver == null) { - try { - driver = new SafariDriver(); - } catch (Exception e) { - LOG.error("Exception in WebDriverManager while SafariDriver ", e); - } - } - - String url; - if (System.getenv("url") != null) { - url = System.getenv("url"); - } else { - url = "http://localhost:8080"; - } - - long start = System.currentTimeMillis(); - boolean loaded = false; - driver.manage().timeouts().implicitlyWait(AbstractZeppelinIT.MAX_IMPLICIT_WAIT, - TimeUnit.SECONDS); - driver.get(url); - - while (System.currentTimeMillis() - start < 60 * 1000) { - // wait for page load - try { - (new WebDriverWait(driver, 30)).until(new ExpectedCondition() { - @Override - public Boolean apply(WebDriver d) { - return d.findElement(By.xpath("//i[@uib-tooltip='WebSocket Connected']")) - .isDisplayed(); - } - }); - loaded = true; - break; - } catch (TimeoutException e) { - LOG.info("Exception in WebDriverManager while WebDriverWait ", e); - driver.navigate().to(url); - } - } - - if (loaded == false) { - fail(); - } - - return driver; - } - - private static void downloadFireBug(int firefoxVersion, String tempPath) { - String firebugUrlString = null; - if (firefoxVersion < 23) - firebugUrlString = "http://getfirebug.com/releases/firebug/1.11/firebug-1.11.4.xpi"; - else if (firefoxVersion >= 23 && firefoxVersion < 30) - firebugUrlString = "http://getfirebug.com/releases/firebug/1.12/firebug-1.12.8.xpi"; - else if (firefoxVersion >= 30 && firefoxVersion < 33) - firebugUrlString = "http://getfirebug.com/releases/firebug/2.0/firebug-2.0.7.xpi"; - else if (firefoxVersion >= 33) - firebugUrlString = "http://getfirebug.com/releases/firebug/2.0/firebug-2.0.17.xpi"; - - - LOG.info("firebug version: " + firefoxVersion + ", will be downloaded to " + tempPath); - try { - File firebugFile = new File(tempPath + "firebug.xpi"); - URL firebugUrl = new URL(firebugUrlString); - if (!firebugFile.exists()) { - FileUtils.copyURLToFile(firebugUrl, firebugFile); - } - - - File firepathFile = new File(tempPath + "firepath.xpi"); - URL firepathUrl = new URL("https://addons.cdn.mozilla.net/user-media/addons/11900/firepath-0.9.7.1-fx.xpi"); - if (!firepathFile.exists()) { - FileUtils.copyURLToFile(firepathUrl, firepathFile); - } - - } catch (IOException e) { - LOG.error("Download of firebug version: " + firefoxVersion + ", falied in path " + tempPath); - } - LOG.info("Download of firebug version: " + firefoxVersion + ", successful"); - } - - public static int getFirefoxVersion() { - try { - String firefoxVersionCmd = "firefox -v"; - if (System.getProperty("os.name").startsWith("Mac OS")) { - firefoxVersionCmd = "/Applications/Firefox.app/Contents/MacOS/" + firefoxVersionCmd; - } - String versionString = (String) CommandExecutor.executeCommandLocalHost(firefoxVersionCmd, false, ProcessData.Types_Of_Data.OUTPUT); - return Integer.valueOf(versionString.replaceAll("Mozilla Firefox", "").trim().substring(0, 2)); - } catch (Exception e) { - LOG.error("Exception in WebDriverManager while getWebDriver ", e); - return -1; - } - } -} diff --git a/smart-zeppelin/zeppelin-server/src/test/java/org/apache/zeppelin/ZeppelinITUtils.java b/smart-zeppelin/zeppelin-server/src/test/java/org/apache/zeppelin/ZeppelinITUtils.java deleted file mode 100644 index 402a18d4270..00000000000 --- a/smart-zeppelin/zeppelin-server/src/test/java/org/apache/zeppelin/ZeppelinITUtils.java +++ /dev/null @@ -1,60 +0,0 @@ -/* - * Licensed to the Apache Software Foundation (ASF) under one or more - * contributor license agreements. See the NOTICE file distributed with - * this work for additional information regarding copyright ownership. - * The ASF licenses this file to You under the Apache License, Version 2.0 - * (the "License"); you may not use this file except in compliance with - * the License. You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT 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.zeppelin; - - -import org.slf4j.Logger; -import org.slf4j.LoggerFactory; -import org.openqa.selenium.WebDriver; -import java.util.concurrent.TimeUnit; - -public class ZeppelinITUtils { - - public final static Logger LOG = LoggerFactory.getLogger(ZeppelinITUtils.class); - - public static void sleep(long millis, boolean logOutput) { - if (logOutput) { - LOG.info("Starting sleeping for " + (millis / 1000) + " seconds..."); - LOG.info("Caller: " + Thread.currentThread().getStackTrace()[2]); - } - try { - Thread.sleep(millis); - } catch (InterruptedException e) { - LOG.error("Exception in WebDriverManager while getWebDriver ", e); - } - if (logOutput) { - LOG.info("Finished."); - } - } - - public static void restartZeppelin() { - CommandExecutor.executeCommandLocalHost("../bin/zeppelin-daemon.sh restart", - false, ProcessData.Types_Of_Data.OUTPUT); - //wait for server to start. - sleep(5000, false); - } - - public static void turnOffImplicitWaits(WebDriver driver) { - driver.manage().timeouts().implicitlyWait(0, TimeUnit.SECONDS); - } - - public static void turnOnImplicitWaits(WebDriver driver) { - driver.manage().timeouts().implicitlyWait(AbstractZeppelinIT.MAX_IMPLICIT_WAIT, - TimeUnit.SECONDS); - } -} diff --git a/smart-zeppelin/zeppelin-server/src/test/java/org/apache/zeppelin/integration/AuthenticationIT.java b/smart-zeppelin/zeppelin-server/src/test/java/org/apache/zeppelin/integration/AuthenticationIT.java deleted file mode 100644 index 9abbe28525f..00000000000 --- a/smart-zeppelin/zeppelin-server/src/test/java/org/apache/zeppelin/integration/AuthenticationIT.java +++ /dev/null @@ -1,261 +0,0 @@ -/* - * Licensed to the Apache Software Foundation (ASF) under one or more - * contributor license agreements. See the NOTICE file distributed with - * this work for additional information regarding copyright ownership. - * The ASF licenses this file to You under the Apache License, Version 2.0 - * (the "License"); you may not use this file except in compliance with - * the License. You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT 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.zeppelin.integration; - -import static org.junit.Assert.assertTrue; - -import java.io.File; -import java.io.IOException; -import java.net.URI; -import java.net.URISyntaxException; -import java.util.List; - -import org.apache.commons.io.FileUtils; -import org.apache.commons.lang3.StringUtils; -import org.apache.zeppelin.AbstractZeppelinIT; -import org.apache.zeppelin.WebDriverManager; -import org.apache.zeppelin.ZeppelinITUtils; -import org.apache.zeppelin.conf.ZeppelinConfiguration; -import org.hamcrest.CoreMatchers; -import org.junit.AfterClass; -import org.junit.BeforeClass; -import org.junit.Rule; -import org.junit.Test; -import org.junit.rules.ErrorCollector; -import org.openqa.selenium.By; -import org.openqa.selenium.Keys; -import org.openqa.selenium.WebElement; -import org.slf4j.Logger; -import org.slf4j.LoggerFactory; - - -/** - * Created for org.apache.zeppelin.integration on 13/06/16. - */ -public class AuthenticationIT extends AbstractZeppelinIT { - private static final Logger LOG = LoggerFactory.getLogger(AuthenticationIT.class); - - @Rule - public ErrorCollector collector = new ErrorCollector(); - static String shiroPath; - static String authShiro = "[users]\n" + - "admin = password1, admin\n" + - "finance1 = finance1, finance\n" + - "finance2 = finance2, finance\n" + - "hr1 = hr1, hr\n" + - "hr2 = hr2, hr\n" + - "[main]\n" + - "sessionManager = org.apache.shiro.web.session.mgt.DefaultWebSessionManager\n" + - "securityManager.sessionManager = $sessionManager\n" + - "securityManager.sessionManager.globalSessionTimeout = 86400000\n" + - "shiro.loginUrl = /api/login\n" + - "[roles]\n" + - "admin = *\n" + - "hr = *\n" + - "finance = *\n" + - "[urls]\n" + - "/api/version = anon\n" + - "/** = authc"; - - static String originalShiro = ""; - - - @BeforeClass - public static void startUp() { - if (!endToEndTestEnabled()) { - return; - } - - try { - System.setProperty(ZeppelinConfiguration.ConfVars.ZEPPELIN_HOME.getVarName(), "../"); - ZeppelinConfiguration conf = ZeppelinConfiguration.create(); - shiroPath = conf.getRelativeDir(String.format("%s/shiro.ini", conf.getConfDir())); - File file = new File(shiroPath); - if (file.exists()) { - originalShiro = StringUtils.join(FileUtils.readLines(file, "UTF-8"), "\n"); - } - FileUtils.write(file, authShiro, "UTF-8"); - } catch (IOException e) { - LOG.error("Error in AuthenticationIT startUp::", e); - } - ZeppelinITUtils.restartZeppelin(); - driver = WebDriverManager.getWebDriver(); - } - - - @AfterClass - public static void tearDown() { - if (!endToEndTestEnabled()) { - return; - } - try { - if (!StringUtils.isBlank(shiroPath)) { - File file = new File(shiroPath); - if (StringUtils.isBlank(originalShiro)) { - FileUtils.deleteQuietly(file); - } else { - FileUtils.write(file, originalShiro, "UTF-8"); - } - } - } catch (IOException e) { - LOG.error("Error in AuthenticationIT tearDown::", e); - } - ZeppelinITUtils.restartZeppelin(); - driver.quit(); - } - - private void authenticationUser(String userName, String password) { - pollingWait(By.xpath( - "//div[contains(@class, 'navbar-collapse')]//li//button[contains(.,'Login')]"), - MAX_BROWSER_TIMEOUT_SEC).click(); - ZeppelinITUtils.sleep(1000, false); - pollingWait(By.xpath("//*[@id='userName']"), MAX_BROWSER_TIMEOUT_SEC).sendKeys(userName); - pollingWait(By.xpath("//*[@id='password']"), MAX_BROWSER_TIMEOUT_SEC).sendKeys(password); - pollingWait(By.xpath("//*[@id='NoteImportCtrl']//button[contains(.,'Login')]"), - MAX_BROWSER_TIMEOUT_SEC).click(); - ZeppelinITUtils.sleep(1000, false); - } - - private void testShowNotebookListOnNavbar() throws Exception { - if (!endToEndTestEnabled()) { - return; - } - try { - pollingWait(By.xpath("//li[@class='dropdown notebook-list-dropdown']"), - MAX_BROWSER_TIMEOUT_SEC).click(); - assertTrue(driver.findElements(By.xpath("//a[@class=\"notebook-list-item ng-scope\"]")).size() > 0); - pollingWait(By.xpath("//li[@class='dropdown notebook-list-dropdown']"), - MAX_BROWSER_TIMEOUT_SEC).click(); - pollingWait(By.xpath("//li[@class='dropdown notebook-list-dropdown']"), - MAX_BROWSER_TIMEOUT_SEC).click(); - } catch (Exception e) { - handleException("Exception in ParagraphActionsIT while testShowNotebookListOnNavbar ", e); - } - } - - private void logoutUser(String userName) throws URISyntaxException { - ZeppelinITUtils.sleep(500, false); - driver.findElement(By.xpath("//div[contains(@class, 'navbar-collapse')]//li[contains(.,'" + - userName + "')]")).click(); - ZeppelinITUtils.sleep(500, false); - driver.findElement(By.xpath("//div[contains(@class, 'navbar-collapse')]//li[contains(.,'" + - userName + "')]//a[@ng-click='navbar.logout()']")).click(); - ZeppelinITUtils.sleep(2000, false); - if (driver.findElement(By.xpath("//*[@id='loginModal']//div[contains(@class, 'modal-header')]/button")) - .isDisplayed()) { - driver.findElement(By.xpath("//*[@id='loginModal']//div[contains(@class, 'modal-header')]/button")).click(); - } - driver.get(new URI(driver.getCurrentUrl()).resolve("/#/").toString()); - ZeppelinITUtils.sleep(500, false); - } - - // @Test - public void testSimpleAuthentication() throws Exception { - if (!endToEndTestEnabled()) { - return; - } - try { - AuthenticationIT authenticationIT = new AuthenticationIT(); - authenticationIT.authenticationUser("admin", "password1"); - - collector.checkThat("Check is user logged in", true, - CoreMatchers.equalTo(driver.findElement(By.partialLinkText("Create new note")) - .isDisplayed())); - - authenticationIT.logoutUser("admin"); - } catch (Exception e) { - handleException("Exception in AuthenticationIT while testCreateNewButton ", e); - } - } - - @Test - public void testGroupPermission() throws Exception { - if (!endToEndTestEnabled()) { - return; - } - try { - AuthenticationIT authenticationIT = new AuthenticationIT(); - authenticationIT.authenticationUser("finance1", "finance1"); - createNewNote(); - - String noteId = driver.getCurrentUrl().substring(driver.getCurrentUrl().lastIndexOf("/") + 1); - - pollingWait(By.xpath("//span[@uib-tooltip='Note permissions']"), - MAX_BROWSER_TIMEOUT_SEC).click(); - pollingWait(By.xpath(".//*[@id='selectOwners']/following::span//input"), - MAX_BROWSER_TIMEOUT_SEC).sendKeys("finance "); - pollingWait(By.xpath(".//*[@id='selectReaders']/following::span//input"), - MAX_BROWSER_TIMEOUT_SEC).sendKeys("finance "); - pollingWait(By.xpath(".//*[@id='selectWriters']/following::span//input"), - MAX_BROWSER_TIMEOUT_SEC).sendKeys("finance "); - pollingWait(By.xpath("//button[@ng-click='savePermissions()']"), MAX_BROWSER_TIMEOUT_SEC) - .sendKeys(Keys.ENTER); - - pollingWait(By.xpath("//div[@class='modal-dialog'][contains(.,'Permissions Saved ')]" + - "//div[@class='modal-footer']//button[contains(.,'OK')]"), - MAX_BROWSER_TIMEOUT_SEC).click(); - authenticationIT.logoutUser("finance1"); - - authenticationIT.authenticationUser("hr1", "hr1"); - try { - WebElement element = pollingWait(By.xpath("//*[@id='notebook-names']//a[contains(@href, '" + noteId + "')]"), - MAX_BROWSER_TIMEOUT_SEC); - collector.checkThat("Check is user has permission to view this note link", false, - CoreMatchers.equalTo(element.isDisplayed())); - } catch (Exception e) { - //This should have failed, nothing to worry. - } - - driver.get(new URI(driver.getCurrentUrl()).resolve("/#/notebook/" + noteId).toString()); - - List privilegesModal = driver.findElements( - By.xpath("//div[@class='modal-content']//div[@class='bootstrap-dialog-header']" + - "//div[contains(.,'Insufficient privileges')]")); - collector.checkThat("Check is user has permission to view this note", 1, - CoreMatchers.equalTo(privilegesModal.size())); - driver.findElement( - By.xpath("//div[@class='modal-content'][contains(.,'Insufficient privileges')]" + - "//div[@class='modal-footer']//button[2]")).click(); - authenticationIT.logoutUser("hr1"); - - authenticationIT.authenticationUser("finance2", "finance2"); - try { - WebElement element = pollingWait(By.xpath("//*[@id='notebook-names']//a[contains(@href, '" + noteId + "')]"), - MAX_BROWSER_TIMEOUT_SEC); - collector.checkThat("Check is user has permission to view this note link", true, - CoreMatchers.equalTo(element.isDisplayed())); - } catch (Exception e) { - //This should have failed, nothing to worry. - } - - driver.get(new URI(driver.getCurrentUrl()).resolve("/#/notebook/" + noteId).toString()); - - privilegesModal = driver.findElements( - By.xpath("//div[@class='modal-content']//div[@class='bootstrap-dialog-header']" + - "//div[contains(.,'Insufficient privileges')]")); - collector.checkThat("Check is user has permission to view this note", 0, - CoreMatchers.equalTo(privilegesModal.size())); - deleteTestNotebook(driver); - authenticationIT.logoutUser("finance2"); - - - } catch (Exception e) { - handleException("Exception in ParagraphActionsIT while testGroupPermission ", e); - } - } - -} diff --git a/smart-zeppelin/zeppelin-server/src/test/java/org/apache/zeppelin/integration/InterpreterIT.java b/smart-zeppelin/zeppelin-server/src/test/java/org/apache/zeppelin/integration/InterpreterIT.java deleted file mode 100644 index 9587cd689d0..00000000000 --- a/smart-zeppelin/zeppelin-server/src/test/java/org/apache/zeppelin/integration/InterpreterIT.java +++ /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. - */ - -package org.apache.zeppelin.integration; - -import org.apache.zeppelin.AbstractZeppelinIT; -import org.apache.zeppelin.WebDriverManager; -import org.hamcrest.CoreMatchers; -import org.junit.After; -import org.junit.Before; -import org.junit.Rule; -import org.junit.Test; -import org.junit.rules.ErrorCollector; -import org.openqa.selenium.By; -import org.openqa.selenium.WebElement; -import org.openqa.selenium.support.ui.Select; -import org.slf4j.Logger; -import org.slf4j.LoggerFactory; - -public class InterpreterIT extends AbstractZeppelinIT { - private static final Logger LOG = LoggerFactory.getLogger(InterpreterIT.class); - - @Rule - public ErrorCollector collector = new ErrorCollector(); - - @Before - public void startUp() { - if (!endToEndTestEnabled()) { - return; - } - driver = WebDriverManager.getWebDriver(); - } - - @After - public void tearDown() { - if (!endToEndTestEnabled()) { - return; - } - driver.quit(); - } - - @Test - public void testShowDescriptionOnInterpreterCreate() throws Exception { - if (!endToEndTestEnabled()) { - return; - } - try { - // navigate to interpreter page - WebElement settingButton = driver.findElement(By.xpath("//button[@class='nav-btn dropdown-toggle ng-scope']")); - settingButton.click(); - WebElement interpreterLink = driver.findElement(By.xpath("//a[@href='#/interpreter']")); - interpreterLink.click(); - - WebElement createButton = driver.findElement(By.xpath("//button[contains(., 'Create')]")); - createButton.click(); - - Select select = new Select(driver.findElement(By.xpath("//select[@ng-change='newInterpreterGroupChange()']"))); - select.selectByVisibleText("spark"); - - collector.checkThat("description of interpreter property is displayed", - driver.findElement(By.xpath("//tr/td[contains(text(), 'spark.app.name')]/following-sibling::td[2]")).getText(), - CoreMatchers.equalTo("The name of spark application.")); - - } catch (Exception e) { - handleException("Exception in InterpreterIT while testShowDescriptionOnInterpreterCreate ", e); - } - } -} \ No newline at end of file diff --git a/smart-zeppelin/zeppelin-server/src/test/java/org/apache/zeppelin/integration/ParagraphActionsIT.java b/smart-zeppelin/zeppelin-server/src/test/java/org/apache/zeppelin/integration/ParagraphActionsIT.java deleted file mode 100644 index ca1da0ffa3e..00000000000 --- a/smart-zeppelin/zeppelin-server/src/test/java/org/apache/zeppelin/integration/ParagraphActionsIT.java +++ /dev/null @@ -1,702 +0,0 @@ -/* - * Licensed to the Apache Software Foundation (ASF) under one or more - * contributor license agreements. See the NOTICE file distributed with - * this work for additional information regarding copyright ownership. - * The ASF licenses this file to You under the Apache License, Version 2.0 - * (the "License"); you may not use this file except in compliance with - * the License. You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT 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.zeppelin.integration; - - -import org.apache.commons.lang.StringUtils; -import org.apache.zeppelin.AbstractZeppelinIT; -import org.apache.zeppelin.WebDriverManager; -import org.apache.zeppelin.ZeppelinITUtils; -import org.hamcrest.CoreMatchers; -import org.junit.After; -import org.junit.Before; -import org.junit.Rule; -import org.junit.Test; -import org.junit.rules.ErrorCollector; -import org.openqa.selenium.By; -import org.openqa.selenium.Keys; -import org.openqa.selenium.WebElement; -import org.openqa.selenium.interactions.Actions; -import org.openqa.selenium.support.ui.Select; -import org.slf4j.Logger; -import org.slf4j.LoggerFactory; - -public class ParagraphActionsIT extends AbstractZeppelinIT { - private static final Logger LOG = LoggerFactory.getLogger(ParagraphActionsIT.class); - - - @Rule - public ErrorCollector collector = new ErrorCollector(); - - @Before - public void startUp() { - if (!endToEndTestEnabled()) { - return; - } - driver = WebDriverManager.getWebDriver(); - } - - @After - public void tearDown() { - if (!endToEndTestEnabled()) { - return; - } - - driver.quit(); - } - - @Test - public void testCreateNewButton() throws Exception { - if (!endToEndTestEnabled()) { - return; - } - try { - createNewNote(); - Actions action = new Actions(driver); - waitForParagraph(1, "READY"); - Integer oldNosOfParas = driver.findElements(By.xpath("//div[@ng-controller=\"ParagraphCtrl\"]")).size(); - collector.checkThat("Before Insert New : the number of paragraph ", - oldNosOfParas, - CoreMatchers.equalTo(1)); - driver.findElement(By.xpath(getParagraphXPath(1) + "//span[@class='icon-settings']")).click(); - driver.findElement(By.xpath(getParagraphXPath(1) + "//ul/li/a[@ng-click=\"insertNew('below')\"]")).click(); - waitForParagraph(2, "READY"); - Integer newNosOfParas = driver.findElements(By.xpath("//div[@ng-controller=\"ParagraphCtrl\"]")).size(); - collector.checkThat("After Insert New (using Insert New button) : number of paragraph", - oldNosOfParas + 1, - CoreMatchers.equalTo(newNosOfParas)); - - driver.findElement(By.xpath(getParagraphXPath(1) + "//span[@class='icon-settings']")).click(); - driver.findElement(By.xpath(getParagraphXPath(1) + "//ul/li/a[@ng-click='removeParagraph(paragraph)']")).click(); - ZeppelinITUtils.sleep(1000, false); - driver.findElement(By.xpath("//div[@class='modal-dialog'][contains(.,'delete this paragraph')]" + - "//div[@class='modal-footer']//button[contains(.,'OK')]")).click(); - ZeppelinITUtils.sleep(1000, false); - - setTextOfParagraph(1, " original paragraph "); - - WebElement newPara = driver.findElement(By.xpath(getParagraphXPath(1) + "//div[contains(@class,'new-paragraph')][1]")); - action.moveToElement(newPara).click().build().perform(); - ZeppelinITUtils.sleep(1000, false); - waitForParagraph(1, "READY"); - - collector.checkThat("Paragraph is created above", - driver.findElement(By.xpath(getParagraphXPath(1) + "//div[contains(@class, 'editor')]")).getText(), - CoreMatchers.equalTo(StringUtils.EMPTY)); - setTextOfParagraph(1, " this is above "); - - newPara = driver.findElement(By.xpath(getParagraphXPath(2) + "//div[contains(@class,'new-paragraph')][2]")); - action.moveToElement(newPara).click().build().perform(); - - waitForParagraph(3, "READY"); - - collector.checkThat("Paragraph is created below", - driver.findElement(By.xpath(getParagraphXPath(3) + "//div[contains(@class, 'editor')]")).getText(), - CoreMatchers.equalTo(StringUtils.EMPTY)); - setTextOfParagraph(3, " this is below "); - - collector.checkThat("The output field of paragraph1 contains", - driver.findElement(By.xpath(getParagraphXPath(1) + "//div[contains(@class, 'editor')]")).getText(), - CoreMatchers.equalTo(" this is above ")); - collector.checkThat("The output field paragraph2 contains", - driver.findElement(By.xpath(getParagraphXPath(2) + "//div[contains(@class, 'editor')]")).getText(), - CoreMatchers.equalTo(" original paragraph ")); - collector.checkThat("The output field paragraph3 contains", - driver.findElement(By.xpath(getParagraphXPath(3) + "//div[contains(@class, 'editor')]")).getText(), - CoreMatchers.equalTo(" this is below ")); - collector.checkThat("The current number of paragraphs after creating paragraph above and below", - driver.findElements(By.xpath("//div[@ng-controller=\"ParagraphCtrl\"]")).size(), - CoreMatchers.equalTo(3)); - - deleteTestNotebook(driver); - - } catch (Exception e) { - handleException("Exception in ParagraphActionsIT while testCreateNewButton ", e); - } - - } - - @Test - public void testRemoveButton() throws Exception { - if (!endToEndTestEnabled()) { - return; - } - try { - createNewNote(); - - waitForParagraph(1, "READY"); - driver.findElement(By.xpath(getParagraphXPath(1) + "//span[@class='icon-settings']")).click(); - driver.findElement(By.xpath(getParagraphXPath(1) + "//ul/li/a[@ng-click=\"insertNew('below')\"]")) - .click(); - waitForParagraph(2, "READY"); - Integer oldNosOfParas = driver.findElements(By.xpath - ("//div[@ng-controller=\"ParagraphCtrl\"]")).size(); - collector.checkThat("Before Remove : Number of paragraphs are ", - oldNosOfParas, - CoreMatchers.equalTo(2)); - driver.findElement(By.xpath(getParagraphXPath(1) + "//span[@class='icon-settings']")).click(); - - clickAndWait(By.xpath(getParagraphXPath(1) + "//ul/li/a[@ng-click='removeParagraph(paragraph)']")); - - clickAndWait(By.xpath("//div[@class='modal-dialog'][contains(.,'delete this paragraph')" + - "]//div[@class='modal-footer']//button[contains(.,'OK')]")); - - Integer newNosOfParas = driver.findElements(By.xpath - ("//div[@ng-controller=\"ParagraphCtrl\"]")).size(); - collector.checkThat("After Remove : Number of paragraphs are", - newNosOfParas, - CoreMatchers.equalTo(oldNosOfParas - 1)); - deleteTestNotebook(driver); - - } catch (Exception e) { - handleException("Exception in ParagraphActionsIT while testRemoveButton ", e); - } - } - - @Test - public void testMoveUpAndDown() throws Exception { - if (!endToEndTestEnabled()) { - return; - } - try { - createNewNote(); - - waitForParagraph(1, "READY"); - setTextOfParagraph(1, "1"); - - driver.findElement(By.xpath(getParagraphXPath(1) + "//span[@class='icon-settings']")).click(); - driver.findElement(By.xpath(getParagraphXPath(1) + "//ul/li/a[@ng-click=\"insertNew('below')\"]")).click(); - - - waitForParagraph(2, "READY"); - setTextOfParagraph(2, "2"); - - - collector.checkThat("The paragraph1 value contains", - driver.findElement(By.xpath(getParagraphXPath(1) + "//div[contains(@class, 'editor')]")).getText(), - CoreMatchers.equalTo("1")); - collector.checkThat("The paragraph1 value contains", - driver.findElement(By.xpath(getParagraphXPath(2) + "//div[contains(@class, 'editor')]")).getText(), - CoreMatchers.equalTo("2")); - - driver.findElement(By.xpath(getParagraphXPath(1) + "//span[@class='icon-settings']")).click(); - clickAndWait(By.xpath(getParagraphXPath(1) + "//ul/li/a[@ng-click='moveDown(paragraph)']")); - - collector.checkThat("The paragraph1 value contains", - driver.findElement(By.xpath(getParagraphXPath(1) + "//div[contains(@class, 'editor')]")).getText(), - CoreMatchers.equalTo("2")); - collector.checkThat("The paragraph1 value contains", - driver.findElement(By.xpath(getParagraphXPath(2) + "//div[contains(@class, 'editor')]")).getText(), - CoreMatchers.equalTo("1")); - - driver.findElement(By.xpath(getParagraphXPath(2) + "//span[@class='icon-settings']")).click(); - clickAndWait(By.xpath(getParagraphXPath(2) + "//ul/li/a[@ng-click='moveUp(paragraph)']")); - - collector.checkThat("The paragraph1 value contains", - driver.findElement(By.xpath(getParagraphXPath(1) + "//div[contains(@class, 'editor')]")).getText(), - CoreMatchers.equalTo("1")); - collector.checkThat("The paragraph1 value contains", - driver.findElement(By.xpath(getParagraphXPath(2) + "//div[contains(@class, 'editor')]")).getText(), - CoreMatchers.equalTo("2")); - deleteTestNotebook(driver); - - } catch (Exception e) { - handleException("Exception in ParagraphActionsIT while testMoveUpAndDown ", e); - } - - } - - @Test - public void testDisableParagraphRunButton() throws Exception { - if (!endToEndTestEnabled()) { - return; - } - try { - createNewNote(); - - waitForParagraph(1, "READY"); - setTextOfParagraph(1, "println (\"abcd\")"); - - driver.findElement(By.xpath(getParagraphXPath(1) + "//span[@class='icon-settings']")).click(); - clickAndWait(By.xpath(getParagraphXPath(1) + "//ul/li/a[@ng-click='toggleEnableDisable(paragraph)']")); - collector.checkThat("The play button class was ", - driver.findElement(By.xpath(getParagraphXPath(1) + "//span[@class='icon-control-play shortcut-icon']")).isDisplayed(), CoreMatchers.equalTo(false) - ); - - driver.findElement(By.xpath(".//*[@id='main']//button[contains(@ng-click, 'runAllParagraphs')]")).sendKeys(Keys.ENTER); - ZeppelinITUtils.sleep(1000, true); - driver.findElement(By.xpath("//div[@class='modal-dialog'][contains(.,'Run all paragraphs?')]" + - "//div[@class='modal-footer']//button[contains(.,'OK')]")).click(); - ZeppelinITUtils.sleep(2000, false); - - collector.checkThat("Paragraph status is ", - getParagraphStatus(1), CoreMatchers.equalTo("READY") - ); - - deleteTestNotebook(driver); - - } catch (Exception e) { - handleException("Exception in ParagraphActionsIT while testDisableParagraphRunButton ", e); - } - - } - - @Test - public void testRunOnSelectionChange() throws Exception { - if (!endToEndTestEnabled()) { - return; - } - try { - String xpathToRunOnSelectionChangeCheckbox = getParagraphXPath(1) + "//ul/li/form/input[contains(@ng-checked, 'true')]"; - String xpathToDropdownMenu = getParagraphXPath(1) + "//select"; - String xpathToResultText = getParagraphXPath(1) + "//div[contains(@id,\"_html\")]"; - - createNewNote(); - - waitForParagraph(1, "READY"); - setTextOfParagraph(1, "%md My selection is ${my selection=1,1|2|3}"); - runParagraph(1); - waitForParagraph(1, "FINISHED"); - - // 1. 'RunOnSelectionChange' is true by default - driver.findElement(By.xpath(getParagraphXPath(1) + "//span[@class='icon-settings']")).click(); - collector.checkThat("'Run on selection change' checkbox will be shown under dropdown menu ", - driver.findElement(By.xpath(getParagraphXPath(1) + "//ul/li/form/input[contains(@ng-click, 'turnOnAutoRun(paragraph)')]")).isDisplayed(), - CoreMatchers.equalTo(true)); - - Select dropDownMenu = new Select(driver.findElement(By.xpath((xpathToDropdownMenu)))); - dropDownMenu.selectByVisibleText("2"); - waitForParagraph(1, "FINISHED"); - collector.checkThat("If 'RunOnSelectionChange' is true, the paragraph result will be updated right after click any options in the dropdown menu ", - driver.findElement(By.xpath(xpathToResultText)).getText(), - CoreMatchers.equalTo("My selection is 2")); - - // 2. set 'RunOnSelectionChange' to false - driver.findElement(By.xpath(getParagraphXPath(1) + "//span[@class='icon-settings']")).click(); - driver.findElement(By.xpath(xpathToRunOnSelectionChangeCheckbox)).click(); - collector.checkThat("If 'Run on selection change' checkbox is unchecked, 'paragraph.config.runOnSelectionChange' will be false ", - driver.findElement(By.xpath(getParagraphXPath(1) + "//ul/li/span[contains(@ng-if, 'paragraph.config.runOnSelectionChange == false')]")).isDisplayed(), - CoreMatchers.equalTo(true)); - - Select sameDropDownMenu = new Select(driver.findElement(By.xpath((xpathToDropdownMenu)))); - sameDropDownMenu.selectByVisibleText("1"); - waitForParagraph(1, "FINISHED"); - collector.checkThat("If 'RunOnSelectionChange' is false, the paragraph result won't be updated even if we select any options in the dropdown menu ", - driver.findElement(By.xpath(xpathToResultText)).getText(), - CoreMatchers.equalTo("My selection is 2")); - - // run paragraph manually by pressing ENTER - driver.findElement(By.xpath(xpathToDropdownMenu)).sendKeys(Keys.ENTER); - waitForParagraph(1, "FINISHED"); - collector.checkThat("Even if 'RunOnSelectionChange' is set as false, still can run the paragraph by pressing ENTER ", - driver.findElement(By.xpath(xpathToResultText)).getText(), - CoreMatchers.equalTo("My selection is 1")); - - } catch (Exception e) { - handleException("Exception in ParagraphActionsIT while testRunOnSelectionChange ", e); - } - } - - @Test - public void testClearOutputButton() throws Exception { - if (!endToEndTestEnabled()) { - return; - } - try { - createNewNote(); - - waitForParagraph(1, "READY"); - String xpathToOutputField = getParagraphXPath(1) + "//div[contains(@id,\"_text\")]"; - setTextOfParagraph(1, "println (\"abcd\")"); - collector.checkThat("Before Run Output field contains ", - driver.findElements(By.xpath(xpathToOutputField)).size(), - CoreMatchers.equalTo(0)); - driver.findElement(By.xpath(getParagraphXPath(1) + "//span[@ng-click='runParagraph(getEditorValue())']")).click(); - waitForParagraph(1, "FINISHED"); - collector.checkThat("After Run Output field contains ", - driver.findElement(By.xpath(xpathToOutputField)).getText(), - CoreMatchers.equalTo("abcd")); - driver.findElement(By.xpath(getParagraphXPath(1) + "//span[@class='icon-settings']")).click(); - clickAndWait(By.xpath(getParagraphXPath(1) + - "//ul/li/a[@ng-click='clearParagraphOutput(paragraph)']")); - collector.checkThat("After Clear Output field contains ", - driver.findElements(By.xpath(xpathToOutputField)).size(), - CoreMatchers.equalTo(0)); - deleteTestNotebook(driver); - - } catch (Exception e) { - handleException("Exception in ParagraphActionsIT while testClearOutputButton ", e); - } - - } - - @Test - public void testWidth() throws Exception { - if (!endToEndTestEnabled()) { - return; - } - try { - createNewNote(); - waitForParagraph(1, "READY"); - - collector.checkThat("Default Width is 12 ", - driver.findElement(By.xpath("//div[contains(@class,'col-md-12')]")).isDisplayed(), - CoreMatchers.equalTo(true)); - for (Integer newWidth = 1; newWidth <= 11; newWidth++) { - clickAndWait(By.xpath(getParagraphXPath(1) + "//span[@class='icon-settings']")); - String visibleText = newWidth.toString(); - new Select(driver.findElement(By.xpath(getParagraphXPath(1) - + "//ul/li/a/form/select[(@ng-model='paragraph.config.colWidth')]"))).selectByVisibleText(visibleText); - collector.checkThat("New Width is : " + newWidth, - driver.findElement(By.xpath("//div[contains(@class,'col-md-" + newWidth + "')]")).isDisplayed(), - CoreMatchers.equalTo(true)); - } - deleteTestNotebook(driver); - } catch (Exception e) { - handleException("Exception in ParagraphActionsIT while testWidth ", e); - } - - } - - @Test - public void testTitleButton() throws Exception { - if (!endToEndTestEnabled()) { - return; - } - try { - createNewNote(); - - waitForParagraph(1, "READY"); - - String xpathToTitle = getParagraphXPath(1) + "//div[contains(@class, 'title')]/div"; - String xpathToSettingIcon = getParagraphXPath(1) + "//span[@class='icon-settings']"; - String xpathToShowTitle = getParagraphXPath(1) + "//ul/li/a[@ng-show='!paragraph.config.title']"; - String xpathToHideTitle = getParagraphXPath(1) + "//ul/li/a[@ng-show='paragraph.config.title']"; - - ZeppelinITUtils.turnOffImplicitWaits(driver); - Integer titleElems = driver.findElements(By.xpath(xpathToTitle)).size(); - collector.checkThat("Before Show Title : The title doesn't exist", - titleElems, - CoreMatchers.equalTo(0)); - ZeppelinITUtils.turnOnImplicitWaits(driver); - - clickAndWait(By.xpath(xpathToSettingIcon)); - collector.checkThat("Before Show Title : The title option in option panel of paragraph is labeled as", - driver.findElement(By.xpath(xpathToShowTitle)).getText(), - CoreMatchers.allOf(CoreMatchers.startsWith("Show title"), CoreMatchers.containsString("Ctrl+"), - CoreMatchers.anyOf(CoreMatchers.containsString("Option"), CoreMatchers.containsString("Alt")), - CoreMatchers.containsString("+T"))); - - clickAndWait(By.xpath(xpathToShowTitle)); - collector.checkThat("After Show Title : The title field contains", - driver.findElement(By.xpath(xpathToTitle)).getText(), - CoreMatchers.equalTo("Untitled")); - - clickAndWait(By.xpath(xpathToSettingIcon)); - collector.checkThat("After Show Title : The title option in option panel of paragraph is labeled as", - driver.findElement(By.xpath(xpathToHideTitle)).getText(), - CoreMatchers.allOf(CoreMatchers.startsWith("Hide title"), CoreMatchers.containsString("Ctrl+"), - CoreMatchers.anyOf(CoreMatchers.containsString("Option"), CoreMatchers.containsString("Alt")), - CoreMatchers.containsString("+T"))); - - clickAndWait(By.xpath(xpathToHideTitle)); - ZeppelinITUtils.turnOffImplicitWaits(driver); - titleElems = driver.findElements(By.xpath(xpathToTitle)).size(); - collector.checkThat("After Hide Title : The title field is hidden", - titleElems, - CoreMatchers.equalTo(0)); - ZeppelinITUtils.turnOnImplicitWaits(driver); - - driver.findElement(By.xpath(xpathToSettingIcon)).click(); - driver.findElement(By.xpath(xpathToShowTitle)).click(); - - driver.findElement(By.xpath(getParagraphXPath(1) + "//div[contains(@class, 'title')]")).click(); - driver.findElement(By.xpath(getParagraphXPath(1) + "//input")).sendKeys("NEW TITLE" + Keys.ENTER); - ZeppelinITUtils.sleep(500, false); - collector.checkThat("After Editing the Title : The title field contains ", - driver.findElement(By.xpath(xpathToTitle)).getText(), - CoreMatchers.equalTo("NEW TITLE")); - driver.navigate().refresh(); - ZeppelinITUtils.sleep(1000, false); - collector.checkThat("After Page Refresh : The title field contains ", - driver.findElement(By.xpath(xpathToTitle)).getText(), - CoreMatchers.equalTo("NEW TITLE")); - deleteTestNotebook(driver); - - } catch (Exception e) { - handleException("Exception in ParagraphActionsIT while testTitleButton ", e); - } - - } - - @Test - public void testShowAndHideLineNumbers() throws Exception { - if (!endToEndTestEnabled()) { - return; - } - try { - createNewNote(); - - waitForParagraph(1, "READY"); - String xpathToLineNumberField = getParagraphXPath(1) + "//div[contains(@class, 'ace_gutter-layer')]"; - String xpathToShowLineNumberButton = getParagraphXPath(1) + "//ul/li/a[@ng-click='showLineNumbers(paragraph)']"; - String xpathToHideLineNumberButton = getParagraphXPath(1) + "//ul/li/a[@ng-click='hideLineNumbers(paragraph)']"; - - collector.checkThat("Before \"Show line number\" the Line Number is Enabled ", - driver.findElement(By.xpath(xpathToLineNumberField)).isDisplayed(), - CoreMatchers.equalTo(false)); - - driver.findElement(By.xpath(getParagraphXPath(1) + "//span[@class='icon-settings']")).click(); - collector.checkThat("Before \"Show line number\" The option panel in paragraph has button labeled ", - driver.findElement(By.xpath(xpathToShowLineNumberButton)).getText(), - CoreMatchers.allOf(CoreMatchers.startsWith("Show line numbers"), CoreMatchers.containsString("Ctrl+"), - CoreMatchers.anyOf(CoreMatchers.containsString("Option"), CoreMatchers.containsString("Alt")), - CoreMatchers.containsString("+M"))); - - - clickAndWait(By.xpath(xpathToShowLineNumberButton)); - collector.checkThat("After \"Show line number\" the Line Number is Enabled ", - driver.findElement(By.xpath(xpathToLineNumberField)).isDisplayed(), - CoreMatchers.equalTo(true)); - - clickAndWait(By.xpath(getParagraphXPath(1) + "//span[@class='icon-settings']")); - collector.checkThat("After \"Show line number\" The option panel in paragraph has button labeled ", - driver.findElement(By.xpath(xpathToHideLineNumberButton)).getText(), - CoreMatchers.allOf(CoreMatchers.startsWith("Hide line numbers"), CoreMatchers.containsString("Ctrl+"), - CoreMatchers.anyOf(CoreMatchers.containsString("Option"), CoreMatchers.containsString("Alt")), - CoreMatchers.containsString("+M"))); - - clickAndWait(By.xpath(xpathToHideLineNumberButton)); - collector.checkThat("After \"Hide line number\" the Line Number is Enabled", - driver.findElement(By.xpath(xpathToLineNumberField)).isDisplayed(), - CoreMatchers.equalTo(false)); - deleteTestNotebook(driver); - - } catch (Exception e) { - handleException("Exception in ParagraphActionsIT while testShowAndHideLineNumbers ", e); - } - } - - @Test - public void testEditOnDoubleClick() throws Exception { - if (!endToEndTestEnabled()) { - return; - } - try { - createNewNote(); - Actions action = new Actions(driver); - - waitForParagraph(1, "READY"); - - setTextOfParagraph(1, "%md"); - driver.findElement(By.xpath(getParagraphXPath(1) + "//textarea")).sendKeys(Keys.ARROW_RIGHT); - driver.findElement(By.xpath(getParagraphXPath(1) + "//textarea")).sendKeys(Keys.ENTER); - driver.findElement(By.xpath(getParagraphXPath(1) + "//textarea")).sendKeys(Keys.SHIFT + "3"); - driver.findElement(By.xpath(getParagraphXPath(1) + "//textarea")).sendKeys(" abc"); - - runParagraph(1); - waitForParagraph(1, "FINISHED"); - - collector.checkThat("Markdown editor is hidden after run ", - driver.findElements(By.xpath(getParagraphXPath(1) + "//div[contains(@ng-if, 'paragraph.config.editorHide')]")).size(), - CoreMatchers.equalTo(0)); - - collector.checkThat("Markdown editor is shown after run ", - driver.findElement(By.xpath(getParagraphXPath(1) + "//div[contains(@ng-show, 'paragraph.config.tableHide')]")).isDisplayed(), - CoreMatchers.equalTo(true)); - - // to check if editOnDblClick field is fetched correctly after refresh - driver.navigate().refresh(); - waitForParagraph(1, "FINISHED"); - - action.doubleClick(driver.findElement(By.xpath(getParagraphXPath(1)))).perform(); - ZeppelinITUtils.sleep(1000, false); - collector.checkThat("Markdown editor is shown after double click ", - driver.findElement(By.xpath(getParagraphXPath(1) + "//div[contains(@ng-if, 'paragraph.config.editorHide')]")).isDisplayed(), - CoreMatchers.equalTo(true)); - - collector.checkThat("Markdown editor is hidden after double click ", - driver.findElement(By.xpath(getParagraphXPath(1) + "//div[contains(@ng-show, 'paragraph.config.tableHide')]")).isDisplayed(), - CoreMatchers.equalTo(false)); - - deleteTestNotebook(driver); - - } catch (Exception e) { - handleException("Exception in ParagraphActionsIT while testEditOnDoubleClick ", e); - } - } - - @Test - public void testSingleDynamicFormTextInput() throws Exception { - if (!endToEndTestEnabled()) { - return; - } - try { - createNewNote(); - - setTextOfParagraph(1, "%spark println(\"Hello \"+z.input(\"name\", \"world\")) "); - - runParagraph(1); - waitForParagraph(1, "FINISHED"); - collector.checkThat("Output text is equal to value specified initially", - driver.findElement(By.xpath(getParagraphXPath(1) + "//div[contains(@class, 'text plainTextContent')]")).getText(), - CoreMatchers.equalTo("Hello world")); - - driver.findElement(By.xpath(getParagraphXPath(1) + "//input")).clear(); - driver.findElement(By.xpath(getParagraphXPath(1) + "//input")).sendKeys("Zeppelin"); - - collector.checkThat("After new data in text input form, output should not be changed", - driver.findElement(By.xpath(getParagraphXPath(1) + "//div[contains(@class, 'text plainTextContent')]")).getText(), - CoreMatchers.equalTo("Hello world")); - - runParagraph(1); - waitForParagraph(1, "FINISHED"); - collector.checkThat("Only after running the paragraph, we can see the newly updated output", - driver.findElement(By.xpath(getParagraphXPath(1) + "//div[contains(@class, 'text plainTextContent')]")).getText(), - CoreMatchers.equalTo("Hello Zeppelin")); - - deleteTestNotebook(driver); - - } catch (Exception e) { - handleException("Exception in ParagraphActionsIT while testSingleDynamicFormTextInput ", e); - } - } - - @Test - public void testSingleDynamicFormSelectForm() throws Exception { - if (!endToEndTestEnabled()) { - return; - } - try { - createNewNote(); - - setTextOfParagraph(1, "%spark println(\"Howdy \"+z.select(\"names\", Seq((\"1\",\"Alice\"), " + - "(\"2\",\"Bob\"),(\"3\",\"stranger\"))))"); - - runParagraph(1); - waitForParagraph(1, "FINISHED"); - collector.checkThat("Output text should not display any of the options in select form", - driver.findElement(By.xpath(getParagraphXPath(1) + "//div[contains(@class, 'text plainTextContent')]")).getText(), - CoreMatchers.equalTo("Howdy ")); - - Select dropDownMenu = new Select(driver.findElement(By.xpath("(" + (getParagraphXPath(1) + "//select)[1]")))); - dropDownMenu.selectByVisibleText("Alice"); - collector.checkThat("After selection in drop down menu, output should display the newly selected option", - driver.findElement(By.xpath(getParagraphXPath(1) + "//div[contains(@class, 'text plainTextContent')]")).getText(), - CoreMatchers.equalTo("Howdy 1")); - - driver.findElement(By.xpath(getParagraphXPath(1) + "//span[@class='icon-settings']")).click(); - clickAndWait(By.xpath(getParagraphXPath(1) + "//ul/li/form/input[contains(@ng-checked, 'true')]")); - - Select sameDropDownMenu = new Select(driver.findElement(By.xpath("(" + (getParagraphXPath(1) + "//select)[1]")))); - sameDropDownMenu.selectByVisibleText("Bob"); - collector.checkThat("After 'Run on selection change' checkbox is unchecked, the paragraph should not run if selecting a different option", - driver.findElement(By.xpath(getParagraphXPath(1) + "//div[contains(@class, 'text plainTextContent')]")).getText(), - CoreMatchers.equalTo("Howdy 1")); - - deleteTestNotebook(driver); - - } catch (Exception e) { - handleException("Exception in ParagraphActionsIT while testSingleDynamicFormSelectForm ", e); - } - } - - @Test - public void testSingleDynamicFormCheckboxForm() throws Exception { - if (!endToEndTestEnabled()) { - return; - } - try { - createNewNote(); - - setTextOfParagraph(1, "%spark val options = Seq((\"han\",\"Han\"), (\"leia\",\"Leia\"), " + - "(\"luke\",\"Luke\")); println(\"Greetings \"+z.checkbox(\"skywalkers\",options).mkString(\" and \"))"); - - runParagraph(1); - waitForParagraph(1, "FINISHED"); - collector.checkThat("Output text should display all of the options included in check boxes", - driver.findElement(By.xpath(getParagraphXPath(1) + "//div[contains(@class, 'text plainTextContent')]")).getText(), - CoreMatchers.containsString("Greetings han and leia and luke")); - - WebElement firstCheckbox = driver.findElement(By.xpath("(" + getParagraphXPath(1) + "//input[@type='checkbox'])[1]")); - firstCheckbox.click(); - collector.checkThat("After unchecking one of the boxes, we can see the newly updated output without the option we unchecked", - driver.findElement(By.xpath(getParagraphXPath(1) + "//div[contains(@class, 'text plainTextContent')]")).getText(), - CoreMatchers.containsString("Greetings leia and luke")); - - driver.findElement(By.xpath(getParagraphXPath(1) + "//span[@class='icon-settings']")).click(); - clickAndWait(By.xpath(getParagraphXPath(1) + "//ul/li/form/input[contains(@ng-checked, 'true')]")); - - WebElement secondCheckbox = driver.findElement(By.xpath("(" + getParagraphXPath(1) + "//input[@type='checkbox'])[2]")); - secondCheckbox.click(); - collector.checkThat("After 'Run on selection change' checkbox is unchecked, the paragraph should not run if check box state is modified", - driver.findElement(By.xpath(getParagraphXPath(1) + "//div[contains(@class, 'text plainTextContent')]")).getText(), - CoreMatchers.containsString("Greetings leia and luke")); - - runParagraph(1); - waitForParagraph(1, "FINISHED"); - - - deleteTestNotebook(driver); - - } catch (Exception e) { - handleException("Exception in ParagraphActionsIT while testSingleDynamicFormCheckboxForm ", e); - } - } - - @Test - public void testMultipleDynamicFormsSameType() throws Exception { - if (!endToEndTestEnabled()) { - return; - } - try { - createNewNote(); - - setTextOfParagraph(1, "%spark println(\"Howdy \"+z.select(\"fruits\", Seq((\"1\",\"Apple\")," + - "(\"2\",\"Orange\"),(\"3\",\"Peach\")))); println(\"Howdy \"+z.select(\"planets\", " + - "Seq((\"1\",\"Venus\"),(\"2\",\"Earth\"),(\"3\",\"Mars\"))))"); - - runParagraph(1); - waitForParagraph(1, "FINISHED"); - collector.checkThat("Output text should not display any of the options in select form", - driver.findElement(By.xpath(getParagraphXPath(1) + "//div[contains(@class, 'text plainTextContent')]")).getText(), - CoreMatchers.equalTo("Howdy \nHowdy ")); - - Select dropDownMenu = new Select(driver.findElement(By.xpath("(" + (getParagraphXPath(1) + "//select)[1]")))); - dropDownMenu.selectByVisibleText("Apple"); - collector.checkThat("After selection in drop down menu, output should display the new option we selected", - driver.findElement(By.xpath(getParagraphXPath(1) + "//div[contains(@class, 'text plainTextContent')]")).getText(), - CoreMatchers.equalTo("Howdy 1\nHowdy ")); - - driver.findElement(By.xpath(getParagraphXPath(1) + "//span[@class='icon-settings']")).click(); - clickAndWait(By.xpath(getParagraphXPath(1) + "//ul/li/form/input[contains(@ng-checked, 'true')]")); - - Select sameDropDownMenu = new Select(driver.findElement(By.xpath("(" + (getParagraphXPath(1) + "//select)[2]")))); - sameDropDownMenu.selectByVisibleText("Earth"); - waitForParagraph(1, "FINISHED"); - collector.checkThat("After 'Run on selection change' checkbox is unchecked, the paragraph should not run if selecting a different option", - driver.findElement(By.xpath(getParagraphXPath(1) + "//div[contains(@class, 'text plainTextContent')]")).getText(), - CoreMatchers.equalTo("Howdy 1\nHowdy ")); - - deleteTestNotebook(driver); - - } catch (Exception e) { - handleException("Exception in ParagraphActionsIT while testMultipleDynamicFormsSameType ", e); - } - } -} \ No newline at end of file diff --git a/smart-zeppelin/zeppelin-server/src/test/java/org/apache/zeppelin/integration/SparkParagraphIT.java b/smart-zeppelin/zeppelin-server/src/test/java/org/apache/zeppelin/integration/SparkParagraphIT.java deleted file mode 100644 index 2cc6a6c8a22..00000000000 --- a/smart-zeppelin/zeppelin-server/src/test/java/org/apache/zeppelin/integration/SparkParagraphIT.java +++ /dev/null @@ -1,242 +0,0 @@ -/* - * Licensed to the Apache Software Foundation (ASF) under one or more - * contributor license agreements. See the NOTICE file distributed with - * this work for additional information regarding copyright ownership. - * The ASF licenses this file to You under the Apache License, Version 2.0 - * (the "License"); you may not use this file except in compliance with - * the License. You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT 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.zeppelin.integration; - - -import org.apache.zeppelin.AbstractZeppelinIT; -import org.apache.zeppelin.WebDriverManager; -import org.hamcrest.CoreMatchers; -import org.junit.After; -import org.junit.Before; -import org.junit.Rule; -import org.junit.Test; -import org.junit.rules.ErrorCollector; -import org.openqa.selenium.By; -import org.openqa.selenium.TimeoutException; -import org.openqa.selenium.WebElement; -import org.slf4j.Logger; -import org.slf4j.LoggerFactory; - -public class SparkParagraphIT extends AbstractZeppelinIT { - private static final Logger LOG = LoggerFactory.getLogger(SparkParagraphIT.class); - - @Rule - public ErrorCollector collector = new ErrorCollector(); - - @Before - public void startUp() { - if (!endToEndTestEnabled()) { - return; - } - driver = WebDriverManager.getWebDriver(); - createNewNote(); - waitForParagraph(1, "READY"); - } - - @After - public void tearDown() { - if (!endToEndTestEnabled()) { - return; - } - deleteTestNotebook(driver); - driver.quit(); - } - - @Test - public void testSpark() throws Exception { - if (!endToEndTestEnabled()) { - return; - } - try { - setTextOfParagraph(1, "sc.version"); - runParagraph(1); - - waitForParagraph(1, "FINISHED"); - - /* - equivalent of - import org.apache.commons.io.IOUtils - import java.net.URL - import java.nio.charset.Charset - val bankText = sc.parallelize(IOUtils.toString(new URL("https://s3.amazonaws.com/apache-zeppelin/tutorial/bank/bank.csv"),Charset.forName("utf8")).split("\n")) - case class Bank(age: Integer, job: String, marital: String, education: String, balance: Integer) - - val bank = bankText.map(s => s.split(";")).filter(s => s(0) != "\"age\"").map(s => Bank(s(0).toInt,s(1).replaceAll("\"", ""),s(2).replaceAll("\"", ""),s(3).replaceAll("\"", ""),s(5).replaceAll("\"", "").toInt)).toDF() - bank.registerTempTable("bank") - */ - setTextOfParagraph(2, "import org.apache.commons.io.IOUtils\\n" + - "import java.net.URL\\n" + - "import java.nio.charset.Charset\\n" + - "val bankText = sc.parallelize(IOUtils.toString(new URL(\"https://s3.amazonaws.com/apache-zeppelin/tutorial/bank/bank.csv\"),Charset.forName(\"utf8\")).split(\"\\\\n\"))\\n" + - "case class Bank(age: Integer, job: String, marital: String, education: String, balance: Integer)\\n" + - "\\n" + - "val bank = bankText.map(s => s.split(\";\")).filter(s => s(0) != \"\\\\\"age\\\\\"\").map(s => Bank(s(0).toInt,s(1).replaceAll(\"\\\\\"\", \"\"),s(2).replaceAll(\"\\\\\"\", \"\"),s(3).replaceAll(\"\\\\\"\", \"\"),s(5).replaceAll(\"\\\\\"\", \"\").toInt)).toDF()\\n" + - "bank.registerTempTable(\"bank\")"); - runParagraph(2); - - try { - waitForParagraph(2, "FINISHED"); - } catch (TimeoutException e) { - waitForParagraph(2, "ERROR"); - collector.checkThat("2nd Paragraph from SparkParagraphIT of testSpark status:", - "ERROR", CoreMatchers.equalTo("FINISHED") - ); - } - - WebElement paragraph2Result = driver.findElement(By.xpath( - getParagraphXPath(2) + "//div[contains(@id,\"_text\")]")); - - collector.checkThat("2nd Paragraph from SparkParagraphIT of testSpark result: ", - paragraph2Result.getText().toString(), CoreMatchers.containsString( - "import org.apache.commons.io.IOUtils" - ) - ); - - } catch (Exception e) { - handleException("Exception in SparkParagraphIT while testSpark", e); - } - } - - @Test - public void testPySpark() throws Exception { - if (!endToEndTestEnabled()) { - return; - } - try { - setTextOfParagraph(1, "%pyspark\\n" + - "for x in range(0, 3):\\n" + - " print \"test loop %d\" % (x)"); - - runParagraph(1); - - try { - waitForParagraph(1, "FINISHED"); - } catch (TimeoutException e) { - waitForParagraph(1, "ERROR"); - collector.checkThat("Paragraph from SparkParagraphIT of testPySpark status: ", - "ERROR", CoreMatchers.equalTo("FINISHED") - ); - } - - WebElement paragraph1Result = driver.findElement(By.xpath( - getParagraphXPath(1) + "//div[contains(@id,\"_text\")]")); - collector.checkThat("Paragraph from SparkParagraphIT of testPySpark result: ", - paragraph1Result.getText().toString(), CoreMatchers.equalTo("test loop 0\ntest loop 1\ntest loop 2") - ); - - // the last statement's evaluation result is printed - setTextOfParagraph(2, "%pyspark\\n" + - "sc.version\\n" + - "1+1"); - runParagraph(2); - try { - waitForParagraph(2, "FINISHED"); - } catch (TimeoutException e) { - waitForParagraph(2, "ERROR"); - collector.checkThat("Paragraph from SparkParagraphIT of testPySpark status: ", - "ERROR", CoreMatchers.equalTo("FINISHED") - ); - } - WebElement paragraph2Result = driver.findElement(By.xpath( - getParagraphXPath(2) + "//div[contains(@id,\"_text\")]")); - collector.checkThat("Paragraph from SparkParagraphIT of testPySpark result: ", - paragraph2Result.getText().toString(), CoreMatchers.equalTo("2") - ); - - } catch (Exception e) { - handleException("Exception in SparkParagraphIT while testPySpark", e); - } - } - - @Test - public void testSqlSpark() throws Exception { - if (!endToEndTestEnabled()) { - return; - } - try { - setTextOfParagraph(1,"%sql\\n" + - "select * from bank limit 1"); - runParagraph(1); - - try { - waitForParagraph(1, "FINISHED"); - } catch (TimeoutException e) { - waitForParagraph(1, "ERROR"); - collector.checkThat("Paragraph from SparkParagraphIT of testSqlSpark status: ", - "ERROR", CoreMatchers.equalTo("FINISHED") - ); - } - - WebElement paragraph1Result = driver.findElement(By.xpath( - getParagraphXPath(1) + "//div[contains(@id,\"_graph\")]/div/div/div/div/div[1]")); - collector.checkThat("Paragraph from SparkParagraphIT of testSqlSpark result: ", - paragraph1Result.getText().toString(), CoreMatchers.equalTo("age\n▼\njob\n▼\nmarital\n▼\neducation\n▼\nbalance\n▼\n30 unemployed married primary 1787")); - } catch (Exception e) { - handleException("Exception in SparkParagraphIT while testSqlSpark", e); - } - } - - @Test - public void testDep() throws Exception { - if (!endToEndTestEnabled()) { - return; - } - try { - // restart spark interpreter before running %dep - clickAndWait(By.xpath("//span[@uib-tooltip='Interpreter binding']")); - clickAndWait(By.xpath("//div[font[contains(text(), 'spark')]]/preceding-sibling::a[@uib-tooltip='Restart']")); - clickAndWait(By.xpath("//button[contains(.,'OK')]")); - - setTextOfParagraph(1,"%dep z.load(\"org.apache.commons:commons-csv:1.1\")"); - runParagraph(1); - - try { - waitForParagraph(1, "FINISHED"); - WebElement paragraph1Result = driver.findElement(By.xpath(getParagraphXPath(1) + - "//div[contains(@id,'_text')]")); - collector.checkThat("Paragraph from SparkParagraphIT of testSqlSpark result: ", - paragraph1Result.getText(), CoreMatchers.containsString("res0: org.apache.zeppelin.dep.Dependency = org.apache.zeppelin.dep.Dependency")); - - setTextOfParagraph(2, "import org.apache.commons.csv.CSVFormat"); - runParagraph(2); - - try { - waitForParagraph(2, "FINISHED"); - WebElement paragraph2Result = driver.findElement(By.xpath(getParagraphXPath(2) + - "//div[contains(@id,'_text')]")); - collector.checkThat("Paragraph from SparkParagraphIT of testSqlSpark result: ", - paragraph2Result.getText(), CoreMatchers.equalTo("import org.apache.commons.csv.CSVFormat")); - - } catch (TimeoutException e) { - waitForParagraph(2, "ERROR"); - collector.checkThat("Second paragraph from SparkParagraphIT of testDep status: ", - "ERROR", CoreMatchers.equalTo("FINISHED") - ); - } - - } catch (TimeoutException e) { - waitForParagraph(1, "ERROR"); - collector.checkThat("First paragraph from SparkParagraphIT of testDep status: ", - "ERROR", CoreMatchers.equalTo("FINISHED") - ); - } - } catch (Exception e) { - handleException("Exception in SparkParagraphIT while testDep", e); - } - } -} diff --git a/smart-zeppelin/zeppelin-server/src/test/java/org/apache/zeppelin/integration/ZeppelinIT.java b/smart-zeppelin/zeppelin-server/src/test/java/org/apache/zeppelin/integration/ZeppelinIT.java deleted file mode 100644 index 63c3ab1ffe8..00000000000 --- a/smart-zeppelin/zeppelin-server/src/test/java/org/apache/zeppelin/integration/ZeppelinIT.java +++ /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. - */ - -package org.apache.zeppelin.integration; - -import org.apache.zeppelin.AbstractZeppelinIT; -import org.apache.zeppelin.WebDriverManager; -import org.apache.zeppelin.ZeppelinITUtils; -import org.hamcrest.CoreMatchers; -import org.junit.After; -import org.junit.Before; -import org.junit.Rule; -import org.junit.Test; -import org.junit.rules.ErrorCollector; -import org.openqa.selenium.By; -import org.openqa.selenium.Keys; -import org.openqa.selenium.StaleElementReferenceException; -import org.openqa.selenium.TimeoutException; -import org.openqa.selenium.WebElement; -import org.slf4j.Logger; -import org.slf4j.LoggerFactory; - -import static org.apache.commons.lang3.StringUtils.isNotBlank; -import static org.junit.Assert.assertEquals; -import static org.junit.Assert.assertTrue; - -/** - * Test Zeppelin with web browser. - * - * To test, ZeppelinServer should be running on port 8080 - * On OSX, you'll need firefox 42.0 installed, then you can run with - * - * PATH=~/Applications/Firefox.app/Contents/MacOS/:$PATH TEST_SELENIUM="" \ - * mvn -Dtest=org.apache.zeppelin.integration.ZeppelinIT -Denforcer.skip=true \ - * test -pl zeppelin-server - * - */ -public class ZeppelinIT extends AbstractZeppelinIT { - private static final Logger LOG = LoggerFactory.getLogger(ZeppelinIT.class); - - @Rule - public ErrorCollector collector = new ErrorCollector(); - - @Before - public void startUp() { - if (!endToEndTestEnabled()) { - return; - } - driver = WebDriverManager.getWebDriver(); - } - - @After - public void tearDown() { - if (!endToEndTestEnabled()) { - return; - } - - driver.quit(); - } - - @Test - public void testAngularDisplay() throws Exception { - if (!endToEndTestEnabled()) { - return; - } - try { - createNewNote(); - - // wait for first paragraph's " READY " status text - waitForParagraph(1, "READY"); - - /* - * print angular template - * %angular
BindingTest_{{myVar}}_
- */ - setTextOfParagraph(1, "println(\"%angular
BindingTest_{{myVar}}_
\")"); - runParagraph(1); - waitForParagraph(1, "FINISHED"); - - // check expected text - waitForText("BindingTest__", By.xpath( - getParagraphXPath(1) + "//div[@id=\"angularTestButton\"]")); - - /* - * Bind variable - * z.angularBind("myVar", 1) - */ - assertEquals(1, driver.findElements(By.xpath(getParagraphXPath(2) + "//textarea")).size()); - setTextOfParagraph(2, "z.angularBind(\"myVar\", 1)"); - runParagraph(2); - waitForParagraph(2, "FINISHED"); - - // check expected text - waitForText("BindingTest_1_", By.xpath( - getParagraphXPath(1) + "//div[@id=\"angularTestButton\"]")); - - - /* - * print variable - * print("myVar="+z.angular("myVar")) - */ - setTextOfParagraph(3, "print(\"myVar=\"+z.angular(\"myVar\"))"); - runParagraph(3); - waitForParagraph(3, "FINISHED"); - - // check expected text - waitForText("myVar=1", By.xpath( - getParagraphXPath(3) + "//div[contains(@id,\"_text\") and @class=\"text\"]")); - - /* - * Click element - */ - driver.findElement(By.xpath( - getParagraphXPath(1) + "//div[@id=\"angularTestButton\"]")).click(); - - // check expected text - waitForText("BindingTest_2_", By.xpath( - getParagraphXPath(1) + "//div[@id=\"angularTestButton\"]")); - - /* - * Register watcher - * z.angularWatch("myVar", (before:Object, after:Object, context:org.apache.zeppelin.interpreter.InterpreterContext) => { - * z.run(2, context) - * } - */ - setTextOfParagraph(4, "z.angularWatch(\"myVar\", (before:Object, after:Object, context:org.apache.zeppelin.interpreter.InterpreterContext)=>{ z.run(2)})"); - runParagraph(4); - waitForParagraph(4, "FINISHED"); - - - /* - * Click element, again and see watcher works - */ - driver.findElement(By.xpath( - getParagraphXPath(1) + "//div[@id=\"angularTestButton\"]")).click(); - - // check expected text - waitForText("BindingTest_3_", By.xpath( - getParagraphXPath(1) + "//div[@id=\"angularTestButton\"]")); - waitForParagraph(3, "FINISHED"); - - // check expected text by watcher - waitForText("myVar=3", By.xpath( - getParagraphXPath(3) + "//div[contains(@id,\"_text\") and @class=\"text\"]")); - - /* - * Unbind - * z.angularUnbind("myVar") - */ - setTextOfParagraph(5, "z.angularUnbind(\"myVar\")"); - runParagraph(5); - waitForParagraph(5, "FINISHED"); - - // check expected text - waitForText("BindingTest__", - By.xpath(getParagraphXPath(1) + "//div[@id=\"angularTestButton\"]")); - - /* - * Bind again and see rebind works. - */ - runParagraph(2); - waitForParagraph(2, "FINISHED"); - - // check expected text - waitForText("BindingTest_1_", - By.xpath(getParagraphXPath(1) + "//div[@id=\"angularTestButton\"]")); - - driver.findElement(By.xpath(".//*[@id='main']//button[@ng-click='moveNoteToTrash(note.id)']")) - .sendKeys(Keys.ENTER); - ZeppelinITUtils.sleep(1000, true); - driver.findElement(By.xpath("//div[@class='modal-dialog'][contains(.,'This note will be moved to trash')]" + - "//div[@class='modal-footer']//button[contains(.,'OK')]")).click(); - ZeppelinITUtils.sleep(100, true); - - LOG.info("testCreateNotebook Test executed"); - } catch (Exception e) { - handleException("Exception in ZeppelinIT while testAngularDisplay ", e); - } - } - - @Test - public void testSparkInterpreterDependencyLoading() throws Exception { - if (!endToEndTestEnabled()) { - return; - } - try { - // navigate to interpreter page - WebElement settingButton = driver.findElement(By.xpath("//button[@class='nav-btn dropdown-toggle ng-scope']")); - settingButton.click(); - WebElement interpreterLink = driver.findElement(By.xpath("//a[@href='#/interpreter']")); - interpreterLink.click(); - - // add new dependency to spark interpreter - driver.findElement(By.xpath("//div[@id='spark']//button[contains(.,'edit')]")).sendKeys(Keys.ENTER); - - WebElement depArtifact = pollingWait(By.xpath("//input[@ng-model='setting.depArtifact']"), - MAX_BROWSER_TIMEOUT_SEC); - String artifact = "org.apache.commons:commons-csv:1.1"; - depArtifact.sendKeys(artifact); - driver.findElement(By.xpath("//div[@id='spark']//form//button[1]")).click(); - clickAndWait(By.xpath("//div[@class='modal-dialog'][contains(.,'Do you want to update this interpreter and restart with new settings?')]" + - "//div[@class='modal-footer']//button[contains(.,'OK')]")); - - try { - clickAndWait(By.xpath("//div[@class='modal-dialog'][contains(.,'Do you want to " + - "update this interpreter and restart with new settings?')]//" + - "div[@class='bootstrap-dialog-close-button']/button")); - } catch (TimeoutException | StaleElementReferenceException e) { - //Modal dialog got closed earlier than expected nothing to worry. - } - - driver.navigate().back(); - createNewNote(); - - // wait for first paragraph's " READY " status text - waitForParagraph(1, "READY"); - - setTextOfParagraph(1, "import org.apache.commons.csv.CSVFormat"); - runParagraph(1); - waitForParagraph(1, "FINISHED"); - - // check expected text - WebElement paragraph1Result = driver.findElement(By.xpath( - getParagraphXPath(1) + "//div[contains(@id,\"_text\")]")); - - collector.checkThat("Paragraph from ZeppelinIT of testSparkInterpreterDependencyLoading result: ", - paragraph1Result.getText().toString(), CoreMatchers.containsString( - "import org.apache.commons.csv.CSVFormat" - ) - ); - - //delete created notebook for cleanup. - deleteTestNotebook(driver); - ZeppelinITUtils.sleep(1000, false); - - // reset dependency - settingButton.click(); - interpreterLink.click(); - driver.findElement(By.xpath("//div[@id='spark']//button[contains(.,'edit')]")).sendKeys(Keys.ENTER); - WebElement testDepRemoveBtn = pollingWait(By.xpath("//tr[descendant::text()[contains(.,'" + - artifact + "')]]/td[3]/button"), MAX_IMPLICIT_WAIT); - testDepRemoveBtn.sendKeys(Keys.ENTER); - driver.findElement(By.xpath("//div[@id='spark']//form//button[1]")).click(); - driver.findElement(By.xpath("//div[@class='modal-dialog'][contains(.,'Do you want to update this interpreter and restart with new settings?')]" + - "//div[@class='modal-footer']//button[contains(.,'OK')]")).click(); - } catch (Exception e) { - handleException("Exception in ZeppelinIT while testSparkInterpreterDependencyLoading ", e); - } - } - - @Test - public void testAngularRunParagraph() throws Exception { - if (!endToEndTestEnabled()) { - return; - } - - try { - createNewNote(); - - // wait for first paragraph's " READY " status text - waitForParagraph(1, "READY"); - - // Create 1st paragraph - setTextOfParagraph(1, - "%angular
Run second paragraph
"); - runParagraph(1); - waitForParagraph(1, "FINISHED"); - waitForText("Run second paragraph", By.xpath( - getParagraphXPath(1) + "//div[@id=\"angularRunParagraph\"]")); - - // Create 2nd paragraph - setTextOfParagraph(2, "%sh echo TEST"); - runParagraph(2); - waitForParagraph(2, "FINISHED"); - - // Get 2nd paragraph id - final String secondParagraphId = driver.findElement(By.xpath(getParagraphXPath(2) - + "//div[@class=\"control ng-scope\"]//ul[@class=\"dropdown-menu dropdown-menu-right\"]/li[1]")) - .getAttribute("textContent"); - - assertTrue("Cannot find paragraph id for the 2nd paragraph", isNotBlank(secondParagraphId)); - - // Update first paragraph to call z.runParagraph() with 2nd paragraph id - setTextOfParagraph(1, - "%angular
Run second paragraph
"); - runParagraph(1); - waitForParagraph(1, "FINISHED"); - - // Set new text value for 2nd paragraph - setTextOfParagraph(2, "%sh echo NEW_VALUE"); - - // Click on 1 paragraph to trigger z.runParagraph() function - driver.findElement(By.xpath( - getParagraphXPath(1) + "//div[@id=\"angularRunParagraph\"]")).click(); - - waitForParagraph(2, "FINISHED"); - - // Check that 2nd paragraph has been executed - waitForText("NEW_VALUE", By.xpath( - getParagraphXPath(2) + "//div[contains(@id,\"_text\") and @class=\"text\"]")); - - //delete created notebook for cleanup. - deleteTestNotebook(driver); - ZeppelinITUtils.sleep(1000, true); - - LOG.info("testAngularRunParagraph Test executed"); - } catch (Exception e) { - handleException("Exception in ZeppelinIT while testAngularRunParagraph", e); - } - - } -} diff --git a/smart-zeppelin/zeppelin-server/src/test/java/org/apache/zeppelin/interpreter/mock/MockInterpreter1.java b/smart-zeppelin/zeppelin-server/src/test/java/org/apache/zeppelin/interpreter/mock/MockInterpreter1.java deleted file mode 100644 index b8343c0633a..00000000000 --- a/smart-zeppelin/zeppelin-server/src/test/java/org/apache/zeppelin/interpreter/mock/MockInterpreter1.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.zeppelin.interpreter.mock; - -import java.util.HashMap; -import java.util.List; -import java.util.Map; -import java.util.Properties; - -import org.apache.zeppelin.interpreter.Interpreter; -import org.apache.zeppelin.interpreter.InterpreterContext; -import org.apache.zeppelin.interpreter.InterpreterResult; -import org.apache.zeppelin.interpreter.thrift.InterpreterCompletion; -import org.apache.zeppelin.scheduler.Scheduler; -import org.apache.zeppelin.scheduler.SchedulerFactory; - -public class MockInterpreter1 extends Interpreter{ - Map vars = new HashMap<>(); - - public MockInterpreter1(Properties property) { - super(property); - } - - @Override - public void open() { - } - - @Override - public void close() { - } - - @Override - public InterpreterResult interpret(String st, InterpreterContext context) { - return new InterpreterResult(InterpreterResult.Code.SUCCESS, "repl1: "+st); - } - - @Override - public void cancel(InterpreterContext context) { - } - - @Override - public FormType getFormType() { - return FormType.SIMPLE; - } - - @Override - public int getProgress(InterpreterContext context) { - return 0; - } - - @Override - public Scheduler getScheduler() { - return SchedulerFactory.singleton().createOrGetFIFOScheduler("test_"+this.hashCode()); - } - - @Override - public List completion(String buf, int cursor) { - return null; - } -} diff --git a/smart-zeppelin/zeppelin-server/src/test/java/org/apache/zeppelin/realm/PamRealmTest.java b/smart-zeppelin/zeppelin-server/src/test/java/org/apache/zeppelin/realm/PamRealmTest.java deleted file mode 100644 index 55448bdbece..00000000000 --- a/smart-zeppelin/zeppelin-server/src/test/java/org/apache/zeppelin/realm/PamRealmTest.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 - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT 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.zeppelin.realm; - -import org.apache.shiro.authc.AuthenticationInfo; -import org.apache.shiro.authc.UsernamePasswordToken; -import org.junit.Test; - -import static org.junit.Assert.assertTrue; -import static org.junit.Assume.assumeTrue; -import static org.mockito.Mockito.mock; -import static org.mockito.Mockito.when; - -/** - * The test will only be executed if the environment variables PAM_USER and PAM_PASS are present. They should - * contain username and password of an valid system user to make the test pass. The service needs to be configured - * under /etc/pam.d/sshd to resolve and authenticate the system user. - * - * Contains main() function so the test can be executed manually. - * - * Set in MacOS to run in IDE(A): - * $ launchctl setenv PAM_USER user - * $ launchctl setenv PAM_PASS xxxxx - */ -public class PamRealmTest { - - @Test - public void testDoGetAuthenticationInfo() { - PamRealm realm = new PamRealm(); - realm.setService("sshd"); - - String pam_user = System.getenv("PAM_USER"); - String pam_pass = System.getenv("PAM_PASS"); - assumeTrue(pam_user != null); - assumeTrue(pam_pass != null); - - // mock shiro auth token - UsernamePasswordToken authToken = mock(UsernamePasswordToken.class); - when(authToken.getUsername()).thenReturn(pam_user); - when(authToken.getPassword()).thenReturn(pam_pass.toCharArray()); - when(authToken.getCredentials()).thenReturn(pam_pass); - - AuthenticationInfo authInfo = realm.doGetAuthenticationInfo(authToken); - - assertTrue(authInfo.getCredentials() != null); - } - - public static void main(String[] args) { - PamRealmTest test = new PamRealmTest(); - test.testDoGetAuthenticationInfo(); - } -} \ No newline at end of file diff --git a/smart-zeppelin/zeppelin-server/src/test/java/org/apache/zeppelin/rest/AbstractTestRestApi.java b/smart-zeppelin/zeppelin-server/src/test/java/org/apache/zeppelin/rest/AbstractTestRestApi.java deleted file mode 100644 index 7ea2774c9d7..00000000000 --- a/smart-zeppelin/zeppelin-server/src/test/java/org/apache/zeppelin/rest/AbstractTestRestApi.java +++ /dev/null @@ -1,571 +0,0 @@ -/* - * Licensed to the Apache Software Foundation (ASF) under one or more - * contributor license agreements. See the NOTICE file distributed with - * this work for additional information regarding copyright ownership. - * The ASF licenses this file to You under the Apache License, Version 2.0 - * (the "License"); you may not use this file except in compliance with - * the License. You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT 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.zeppelin.rest; - -import java.io.File; -import java.io.IOException; -import java.lang.ref.WeakReference; -import java.net.InetAddress; -import java.net.UnknownHostException; -import java.util.List; -import java.util.Properties; -import java.util.concurrent.ExecutorService; -import java.util.concurrent.Executors; -import java.util.regex.Pattern; - -import org.apache.commons.exec.CommandLine; -import org.apache.commons.exec.DefaultExecutor; -import org.apache.commons.exec.PumpStreamHandler; -import org.apache.commons.httpclient.Header; -import org.apache.commons.httpclient.HttpClient; -import org.apache.commons.httpclient.HttpMethodBase; -import org.apache.commons.httpclient.cookie.CookiePolicy; -import org.apache.commons.httpclient.methods.ByteArrayRequestEntity; -import org.apache.commons.httpclient.methods.DeleteMethod; -import org.apache.commons.httpclient.methods.GetMethod; -import org.apache.commons.httpclient.methods.PostMethod; -import org.apache.commons.httpclient.methods.PutMethod; -import org.apache.commons.httpclient.methods.RequestEntity; -import org.apache.commons.io.FileUtils; -import org.apache.commons.lang3.StringUtils; -import org.apache.zeppelin.conf.ZeppelinConfiguration; -import org.apache.zeppelin.interpreter.InterpreterSetting; -import org.apache.zeppelin.server.ZeppelinServer; -import org.hamcrest.Description; -import org.hamcrest.Matcher; -import org.hamcrest.TypeSafeMatcher; -import org.slf4j.Logger; -import org.slf4j.LoggerFactory; - -import com.google.gson.Gson; -import com.google.gson.JsonElement; -import com.google.gson.JsonParseException; -import com.google.gson.JsonParser; - -public abstract class AbstractTestRestApi { - - protected static final Logger LOG = LoggerFactory.getLogger(AbstractTestRestApi.class); - - static final String restApiUrl = "/api"; - static final String url = getUrlToTest(); - protected static final boolean wasRunning = checkIfServerIsRunning(); - static boolean pySpark = false; - static boolean sparkR = false; - static Gson gson = new Gson(); - static boolean isRunningWithAuth = false; - - private static File shiroIni = null; - private static String zeppelinShiro = - "[users]\n" + - "admin = password1, admin\n" + - "user1 = password2, role1, role2\n" + - "user2 = password3, role3\n" + - "user3 = password4, role2\n" + - "[main]\n" + - "sessionManager = org.apache.shiro.web.session.mgt.DefaultWebSessionManager\n" + - "securityManager.sessionManager = $sessionManager\n" + - "securityManager.sessionManager.globalSessionTimeout = 86400000\n" + - "shiro.loginUrl = /api/login\n" + - "[roles]\n" + - "role1 = *\n" + - "role2 = *\n" + - "role3 = *\n" + - "admin = *\n" + - "[urls]\n" + - "/api/version = anon\n" + - "/** = authc"; - - private String getUrl(String path) { - String url; - if (System.getProperty("url") != null) { - url = System.getProperty("url"); - } else { - url = "http://localhost:8080"; - } - url += restApiUrl; - if (path != null) - url += path; - return url; - } - - protected static String getUrlToTest() { - String url = "http://localhost:8080" + restApiUrl; - if (System.getProperty("url") != null) { - url = System.getProperty("url"); - } - return url; - } - - static ExecutorService executor; - protected static final Runnable server = new Runnable() { - @Override - public void run() { - try { - ZeppelinServer.main(new String[] {""}); - } catch (Exception e) { - LOG.error("Exception in WebDriverManager while getWebDriver ", e); - throw new RuntimeException(e); - } - } - }; - - private static void start(boolean withAuth) throws Exception { - if (!wasRunning) { - System.setProperty(ZeppelinConfiguration.ConfVars.ZEPPELIN_HOME.getVarName(), "../"); - System.setProperty(ZeppelinConfiguration.ConfVars.ZEPPELIN_WAR.getVarName(), "../zeppelin-web/dist"); - - // some test profile does not build zeppelin-web. - // to prevent zeppelin starting up fail, create zeppelin-web/dist directory - new File("../zeppelin-web/dist").mkdirs(); - - LOG.info("Staring test Zeppelin up..."); - ZeppelinConfiguration conf = ZeppelinConfiguration.create(); - - if (withAuth) { - isRunningWithAuth = true; - // Set Anonymous session to false. - System.setProperty(ZeppelinConfiguration.ConfVars.ZEPPELIN_ANONYMOUS_ALLOWED.getVarName(), "false"); - - // Create a shiro env test. - shiroIni = new File("../conf/shiro.ini"); - if (!shiroIni.exists()) { - shiroIni.createNewFile(); - } - FileUtils.writeStringToFile(shiroIni, zeppelinShiro); - } - - // exclude org.apache.zeppelin.rinterpreter.* for scala 2.11 test - String interpreters = conf.getString(ZeppelinConfiguration.ConfVars.ZEPPELIN_INTERPRETERS); - String interpretersCompatibleWithScala211Test = null; - - for (String intp : interpreters.split(",")) { - if (intp.startsWith("org.apache.zeppelin.rinterpreter")) { - continue; - } - - if (interpretersCompatibleWithScala211Test == null) { - interpretersCompatibleWithScala211Test = intp; - } else { - interpretersCompatibleWithScala211Test += "," + intp; - } - } - - System.setProperty( - ZeppelinConfiguration.ConfVars.ZEPPELIN_INTERPRETERS.getVarName(), - interpretersCompatibleWithScala211Test); - - - executor = Executors.newSingleThreadExecutor(); - executor.submit(server); - long s = System.currentTimeMillis(); - boolean started = false; - while (System.currentTimeMillis() - s < 1000 * 60 * 3) { // 3 minutes - Thread.sleep(2000); - started = checkIfServerIsRunning(); - if (started == true) { - break; - } - } - if (started == false) { - throw new RuntimeException("Can not start Zeppelin server"); - } - LOG.info("Test Zeppelin stared."); - - - // assume first one is spark - InterpreterSetting sparkIntpSetting = null; - for(InterpreterSetting intpSetting : - ZeppelinServer.notebook.getInterpreterSettingManager().get()) { - if (intpSetting.getName().equals("spark")) { - sparkIntpSetting = intpSetting; - } - } - - Properties sparkProperties = (Properties) sparkIntpSetting.getProperties(); - // ci environment runs spark cluster for testing - // so configure zeppelin use spark cluster - if ("true".equals(System.getenv("CI"))) { - // set spark master and other properties - sparkProperties.setProperty("master", "local[2]"); - sparkProperties.setProperty("spark.cores.max", "2"); - sparkProperties.setProperty("zeppelin.spark.useHiveContext", "false"); - // set spark home for pyspark - sparkProperties.setProperty("spark.home", getSparkHome()); - - sparkIntpSetting.setProperties(sparkProperties); - pySpark = true; - sparkR = true; - ZeppelinServer.notebook.getInterpreterSettingManager().restart(sparkIntpSetting.getId()); - } else { - String sparkHome = getSparkHome(); - if (sparkHome != null) { - if (System.getenv("SPARK_MASTER") != null) { - sparkProperties.setProperty("master", System.getenv("SPARK_MASTER")); - } else { - sparkProperties.setProperty("master", "local[2]"); - } - sparkProperties.setProperty("spark.cores.max", "2"); - // set spark home for pyspark - sparkProperties.setProperty("spark.home", sparkHome); - sparkProperties.setProperty("zeppelin.spark.useHiveContext", "false"); - pySpark = true; - sparkR = true; - } - - ZeppelinServer.notebook.getInterpreterSettingManager().restart(sparkIntpSetting.getId()); - } - } - } - - protected static void startUpWithAuthenticationEnable() throws Exception { - start(true); - } - - protected static void startUp() throws Exception { - start(false); - } - - private static String getHostname() { - try { - return InetAddress.getLocalHost().getHostName(); - } catch (UnknownHostException e) { - LOG.error("Exception in WebDriverManager while getWebDriver ", e); - return "localhost"; - } - } - - private static String getSparkHome() { - String sparkHome = System.getenv("SPARK_HOME"); - if (sparkHome != null) { - return sparkHome; - } - sparkHome = getSparkHomeRecursively(new File(System.getProperty(ZeppelinConfiguration.ConfVars.ZEPPELIN_HOME.getVarName()))); - System.out.println("SPARK HOME detected " + sparkHome); - return sparkHome; - } - - boolean isPyspark() { - return pySpark; - } - - boolean isSparkR() { - return sparkR; - } - - private static String getSparkHomeRecursively(File dir) { - if (dir == null) return null; - File files [] = dir.listFiles(); - if (files == null) return null; - - File homeDetected = null; - for (File f : files) { - if (isActiveSparkHome(f)) { - homeDetected = f; - break; - } - } - - if (homeDetected != null) { - return homeDetected.getAbsolutePath(); - } else { - return getSparkHomeRecursively(dir.getParentFile()); - } - } - - private static boolean isActiveSparkHome(File dir) { - return dir.getName().matches("spark-[0-9\\.]+[A-Za-z-]*-bin-hadoop[0-9\\.]+"); - } - - protected static void shutDown() throws Exception { - if (!wasRunning) { - // restart interpreter to stop all interpreter processes - List settingList = ZeppelinServer.notebook.getInterpreterSettingManager() - .getDefaultInterpreterSettingList(); - for (String setting : settingList) { - ZeppelinServer.notebook.getInterpreterSettingManager().restart(setting); - } - if (shiroIni != null) { - FileUtils.deleteQuietly(shiroIni); - } - LOG.info("Terminating test Zeppelin..."); - ZeppelinServer.jettyWebServer.stop(); - executor.shutdown(); - - long s = System.currentTimeMillis(); - boolean started = true; - while (System.currentTimeMillis() - s < 1000 * 60 * 3) { // 3 minutes - Thread.sleep(2000); - started = checkIfServerIsRunning(); - if (started == false) { - break; - } - } - if (started == true) { - throw new RuntimeException("Can not stop Zeppelin server"); - } - - LOG.info("Test Zeppelin terminated."); - - System.clearProperty(ZeppelinConfiguration.ConfVars.ZEPPELIN_INTERPRETERS.getVarName()); - if (isRunningWithAuth) { - isRunningWithAuth = false; - System - .clearProperty(ZeppelinConfiguration.ConfVars.ZEPPELIN_ANONYMOUS_ALLOWED.getVarName()); - } - } - } - - protected static boolean checkIfServerIsRunning() { - GetMethod request = null; - boolean isRunning = true; - try { - request = httpGet("/version"); - isRunning = request.getStatusCode() == 200; - } catch (IOException e) { - LOG.error("AbstractTestRestApi.checkIfServerIsRunning() fails .. ZeppelinServer is not running"); - isRunning = false; - } finally { - if (request != null) { - request.releaseConnection(); - } - } - return isRunning; - } - - protected static GetMethod httpGet(String path) throws IOException { - return httpGet(path, StringUtils.EMPTY, StringUtils.EMPTY); - } - - protected static GetMethod httpGet(String path, String user, String pwd) throws IOException { - LOG.info("Connecting to {}", url + path); - HttpClient httpClient = new HttpClient(); - GetMethod getMethod = new GetMethod(url + path); - getMethod.addRequestHeader("Origin", url); - if (userAndPasswordAreNotBlank(user, pwd)) { - getMethod.setRequestHeader("Cookie", "JSESSIONID="+ getCookie(user, pwd)); - } - httpClient.executeMethod(getMethod); - LOG.info("{} - {}", getMethod.getStatusCode(), getMethod.getStatusText()); - return getMethod; - } - - protected static DeleteMethod httpDelete(String path) throws IOException { - return httpDelete(path, StringUtils.EMPTY, StringUtils.EMPTY); - } - - protected static DeleteMethod httpDelete(String path, String user, String pwd) throws IOException { - LOG.info("Connecting to {}", url + path); - HttpClient httpClient = new HttpClient(); - DeleteMethod deleteMethod = new DeleteMethod(url + path); - deleteMethod.addRequestHeader("Origin", url); - if (userAndPasswordAreNotBlank(user, pwd)) { - deleteMethod.setRequestHeader("Cookie", "JSESSIONID="+ getCookie(user, pwd)); - } - httpClient.executeMethod(deleteMethod); - LOG.info("{} - {}", deleteMethod.getStatusCode(), deleteMethod.getStatusText()); - return deleteMethod; - } - - protected static PostMethod httpPost(String path, String body) throws IOException { - return httpPost(path, body, StringUtils.EMPTY, StringUtils.EMPTY); - } - - protected static PostMethod httpPost(String path, String request, String user, String pwd) - throws IOException { - LOG.info("Connecting to {}", url + path); - HttpClient httpClient = new HttpClient(); - PostMethod postMethod = new PostMethod(url + path); - postMethod.setRequestBody(request); - postMethod.getParams().setCookiePolicy(CookiePolicy.IGNORE_COOKIES); - if (userAndPasswordAreNotBlank(user, pwd)) { - postMethod.setRequestHeader("Cookie", "JSESSIONID="+ getCookie(user, pwd)); - } - httpClient.executeMethod(postMethod); - LOG.info("{} - {}", postMethod.getStatusCode(), postMethod.getStatusText()); - return postMethod; - } - - protected static PutMethod httpPut(String path, String body) throws IOException { - return httpPut(path, body, StringUtils.EMPTY, StringUtils.EMPTY); - } - - protected static PutMethod httpPut(String path, String body, String user, String pwd) throws IOException { - LOG.info("Connecting to {}", url + path); - HttpClient httpClient = new HttpClient(); - PutMethod putMethod = new PutMethod(url + path); - putMethod.addRequestHeader("Origin", url); - RequestEntity entity = new ByteArrayRequestEntity(body.getBytes("UTF-8")); - putMethod.setRequestEntity(entity); - if (userAndPasswordAreNotBlank(user, pwd)) { - putMethod.setRequestHeader("Cookie", "JSESSIONID="+ getCookie(user, pwd)); - } - httpClient.executeMethod(putMethod); - LOG.info("{} - {}", putMethod.getStatusCode(), putMethod.getStatusText()); - return putMethod; - } - - private static String getCookie(String user, String password) throws IOException { - HttpClient httpClient = new HttpClient(); - PostMethod postMethod = new PostMethod(url + "/login"); - postMethod.addRequestHeader("Origin", url); - postMethod.setParameter("password", password); - postMethod.setParameter("userName", user); - httpClient.executeMethod(postMethod); - LOG.info("{} - {}", postMethod.getStatusCode(), postMethod.getStatusText()); - Pattern pattern = Pattern.compile("JSESSIONID=([a-zA-Z0-9-]*)"); - Header[] setCookieHeaders = postMethod.getResponseHeaders("Set-Cookie"); - for (Header setCookie : setCookieHeaders) { - java.util.regex.Matcher matcher = pattern.matcher(setCookie.toString()); - if (matcher.find()) { - return matcher.group(1); - } - } - return StringUtils.EMPTY; - } - - protected static boolean userAndPasswordAreNotBlank(String user, String pwd) { - if (StringUtils.isBlank(user) && StringUtils.isBlank(pwd)) { - return false; - } - return true; - } - - protected Matcher responsesWith(final int expectedStatusCode) { - return new TypeSafeMatcher() { - WeakReference method; - - @Override - public boolean matchesSafely(HttpMethodBase httpMethodBase) { - method = (method == null) ? new WeakReference<>(httpMethodBase) : method; - return httpMethodBase.getStatusCode() == expectedStatusCode; - } - - @Override - public void describeTo(Description description) { - description.appendText("HTTP response ").appendValue(expectedStatusCode) - .appendText(" from ").appendText(method.get().getPath()); - } - - @Override - protected void describeMismatchSafely(HttpMethodBase item, Description description) { - description.appendText("got ").appendValue(item.getStatusCode()).appendText(" ") - .appendText(item.getStatusText()); - } - }; - } - - protected TypeSafeMatcher isJSON() { - return new TypeSafeMatcher() { - @Override - public boolean matchesSafely(String body) { - String b = body.trim(); - return (b.startsWith("{") && b.endsWith("}")) || (b.startsWith("[") && b.endsWith("]")); - } - - @Override - public void describeTo(Description description) { - description.appendText("response in JSON format "); - } - - @Override - protected void describeMismatchSafely(String item, Description description) { - description.appendText("got ").appendText(item); - } - }; - } - - protected TypeSafeMatcher isValidJSON() { - return new TypeSafeMatcher() { - @Override - public boolean matchesSafely(String body) { - boolean isValid = true; - try { - new JsonParser().parse(body); - } catch (JsonParseException e) { - LOG.error("Exception in AbstractTestRestApi while matchesSafely ", e); - isValid = false; - } - return isValid; - } - - @Override - public void describeTo(Description description) { - description.appendText("response in JSON format "); - } - - @Override - protected void describeMismatchSafely(String item, Description description) { - description.appendText("got ").appendText(item); - } - }; - } - - protected TypeSafeMatcher hasRootElementNamed(final String memberName) { - return new TypeSafeMatcher() { - @Override - protected boolean matchesSafely(JsonElement item) { - return item.isJsonObject() && item.getAsJsonObject().has(memberName); - } - - @Override - public void describeTo(Description description) { - description.appendText("response in JSON format with \"").appendText(memberName) - .appendText("\" beeing a root element "); - } - - @Override - protected void describeMismatchSafely(JsonElement root, Description description) { - description.appendText("got ").appendText(root.toString()); - } - }; - } - - - public static void ps() { - DefaultExecutor executor = new DefaultExecutor(); - executor.setStreamHandler(new PumpStreamHandler(System.out, System.err)); - - CommandLine cmd = CommandLine.parse("ps"); - cmd.addArgument("aux", false); - - try { - executor.execute(cmd); - } catch (IOException e) { - LOG.error(e.getMessage(), e); - } - } - - - /** Status code matcher */ - protected Matcher isForbidden() { return responsesWith(403); } - - protected Matcher isAllowed() { - return responsesWith(200); - } - - protected Matcher isCreated() { return responsesWith(201); } - - protected Matcher isBadRequest() { return responsesWith(400); } - - protected Matcher isNotFound() { return responsesWith(404); } - - protected Matcher isNotAllowed() { - return responsesWith(405); - } - -} diff --git a/smart-zeppelin/zeppelin-server/src/test/java/org/apache/zeppelin/rest/ConfigurationsRestApiTest.java b/smart-zeppelin/zeppelin-server/src/test/java/org/apache/zeppelin/rest/ConfigurationsRestApiTest.java deleted file mode 100644 index 1c1ebacd249..00000000000 --- a/smart-zeppelin/zeppelin-server/src/test/java/org/apache/zeppelin/rest/ConfigurationsRestApiTest.java +++ /dev/null @@ -1,80 +0,0 @@ -/* - * Licensed to the Apache Software Foundation (ASF) under one or more - * contributor license agreements. See the NOTICE file distributed with - * this work for additional information regarding copyright ownership. - * The ASF licenses this file to You under the Apache License, Version 2.0 - * (the "License"); you may not use this file except in compliance with - * the License. You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT 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.zeppelin.rest; - -import com.google.common.base.Predicate; -import com.google.common.collect.Iterators; -import com.google.gson.Gson; -import com.google.gson.reflect.TypeToken; -import org.apache.commons.httpclient.methods.GetMethod; -import org.junit.AfterClass; -import org.junit.BeforeClass; -import org.junit.Test; - -import java.io.IOException; -import java.util.Map; - -import static org.junit.Assert.assertTrue; - -public class ConfigurationsRestApiTest extends AbstractTestRestApi { - Gson gson = new Gson(); - - @BeforeClass - public static void init() throws Exception { - AbstractTestRestApi.startUp(); - } - - @AfterClass - public static void destroy() throws Exception { - AbstractTestRestApi.shutDown(); - } - - @Test - public void testGetAll() throws IOException { - GetMethod get = httpGet("/configurations/all"); - Map resp = gson.fromJson(get.getResponseBodyAsString(), - new TypeToken>(){}.getType()); - Map body = (Map) resp.get("body"); - assertTrue(body.size() > 0); - // it shouldn't have key/value pair which key contains "password" - assertTrue(Iterators.all(body.keySet().iterator(), new Predicate() { - @Override - public boolean apply(String key) { - return !key.contains("password"); - } - } - )); - } - - @Test - public void testGetViaPrefix() throws IOException { - final String prefix = "zeppelin.server"; - GetMethod get = httpGet("/configurations/prefix/" + prefix); - Map resp = gson.fromJson(get.getResponseBodyAsString(), - new TypeToken>(){}.getType()); - Map body = (Map) resp.get("body"); - assertTrue(body.size() > 0); - assertTrue(Iterators.all(body.keySet().iterator(), new Predicate() { - @Override - public boolean apply(String key) { - return !key.contains("password") && key.startsWith(prefix); - } - } - )); - } -} diff --git a/smart-zeppelin/zeppelin-server/src/test/java/org/apache/zeppelin/rest/CredentialsRestApiTest.java b/smart-zeppelin/zeppelin-server/src/test/java/org/apache/zeppelin/rest/CredentialsRestApiTest.java deleted file mode 100644 index 29c2914991d..00000000000 --- a/smart-zeppelin/zeppelin-server/src/test/java/org/apache/zeppelin/rest/CredentialsRestApiTest.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.zeppelin.rest; - -import com.google.gson.Gson; -import com.google.gson.reflect.TypeToken; -import org.apache.commons.httpclient.methods.DeleteMethod; -import org.apache.commons.httpclient.methods.GetMethod; -import org.apache.commons.httpclient.methods.PutMethod; -import org.apache.zeppelin.notebook.Note; -import org.apache.zeppelin.server.ZeppelinServer; -import org.apache.zeppelin.user.UserCredentials; -import org.apache.zeppelin.utils.SecurityUtils; -import org.junit.AfterClass; -import org.junit.BeforeClass; -import org.junit.Test; -import org.slf4j.Logger; -import org.slf4j.LoggerFactory; - -import java.io.IOException; -import java.util.Map; - -import static org.junit.Assert.*; - -public class CredentialsRestApiTest extends AbstractTestRestApi { - protected static final Logger LOG = LoggerFactory.getLogger(CredentialsRestApiTest.class); - Gson gson = new Gson(); - - @BeforeClass - public static void init() throws Exception { - AbstractTestRestApi.startUp(); - } - - @AfterClass - public static void destroy() throws Exception { - AbstractTestRestApi.shutDown(); - } - - @Test - public void testInvalidRequest() throws IOException { - String jsonInvalidRequestEntityNull = "{\"entity\" : null, \"username\" : \"test\", \"password\" : \"testpass\"}"; - String jsonInvalidRequestNameNull = "{\"entity\" : \"test\", \"username\" : null, \"password\" : \"testpass\"}"; - String jsonInvalidRequestPasswordNull = "{\"entity\" : \"test\", \"username\" : \"test\", \"password\" : null}"; - String jsonInvalidRequestAllNull = "{\"entity\" : null, \"username\" : null, \"password\" : null}"; - - PutMethod entityNullPut = httpPut("/credential", jsonInvalidRequestEntityNull); - entityNullPut.addRequestHeader("Origin", "http://localhost"); - assertThat(entityNullPut, isBadRequest()); - entityNullPut.releaseConnection(); - - PutMethod nameNullPut = httpPut("/credential", jsonInvalidRequestNameNull); - nameNullPut.addRequestHeader("Origin", "http://localhost"); - assertThat(nameNullPut, isBadRequest()); - nameNullPut.releaseConnection(); - - PutMethod passwordNullPut = httpPut("/credential", jsonInvalidRequestPasswordNull); - passwordNullPut.addRequestHeader("Origin", "http://localhost"); - assertThat(passwordNullPut, isBadRequest()); - passwordNullPut.releaseConnection(); - - PutMethod allNullPut = httpPut("/credential", jsonInvalidRequestAllNull); - allNullPut.addRequestHeader("Origin", "http://localhost"); - assertThat(allNullPut, isBadRequest()); - allNullPut.releaseConnection(); - } - - public Map testGetUserCredentials() throws IOException { - GetMethod getMethod = httpGet("/credential"); - getMethod.addRequestHeader("Origin", "http://localhost"); - Map resp = gson.fromJson(getMethod.getResponseBodyAsString(), - new TypeToken>(){}.getType()); - Map body = (Map) resp.get("body"); - Map credentialMap = (Map)body.get("userCredentials"); - getMethod.releaseConnection(); - return credentialMap; - } - - public void testPutUserCredentials(String requestData) throws IOException { - PutMethod putMethod = httpPut("/credential", requestData); - putMethod.addRequestHeader("Origin", "http://localhost"); - assertThat(putMethod, isAllowed()); - putMethod.releaseConnection(); - } - - public void testRemoveUserCredentials() throws IOException { - DeleteMethod deleteMethod = httpDelete("/credential/"); - assertThat("Test delete method:", deleteMethod, isAllowed()); - deleteMethod.releaseConnection(); - } - - public void testRemoveCredentialEntity(String entity) throws IOException { - DeleteMethod deleteMethod = httpDelete("/credential/" + entity); - assertThat("Test delete method:", deleteMethod, isAllowed()); - deleteMethod.releaseConnection(); - } - - @Test - public void testCredentialsAPIs() throws IOException { - String requestData1 = "{\"entity\" : \"entityname\", \"username\" : \"myuser\", \"password\" : \"mypass\"}"; - String entity = "entityname"; - Map credentialMap; - - testPutUserCredentials(requestData1); - credentialMap = testGetUserCredentials(); - assertNotNull("CredentialMap should be null", credentialMap); - - testRemoveCredentialEntity(entity); - credentialMap = testGetUserCredentials(); - assertNull("CredentialMap should be null", credentialMap.get("entity1")); - - testRemoveUserCredentials(); - credentialMap = testGetUserCredentials(); - assertEquals("Compare CredentialMap", credentialMap.toString(), "{}"); - } -} diff --git a/smart-zeppelin/zeppelin-server/src/test/java/org/apache/zeppelin/rest/InterpreterRestApiTest.java b/smart-zeppelin/zeppelin-server/src/test/java/org/apache/zeppelin/rest/InterpreterRestApiTest.java deleted file mode 100644 index 8be4574c709..00000000000 --- a/smart-zeppelin/zeppelin-server/src/test/java/org/apache/zeppelin/rest/InterpreterRestApiTest.java +++ /dev/null @@ -1,378 +0,0 @@ -/* - * Licensed to the Apache Software Foundation (ASF) under one or more - * contributor license agreements. See the NOTICE file distributed with - * this work for additional information regarding copyright ownership. - * The ASF licenses this file to You under the Apache License, Version 2.0 - * (the "License"); you may not use this file except in compliance with - * the License. You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT 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.zeppelin.rest; - -import java.io.IOException; -import java.util.ArrayList; -import java.util.List; -import java.util.Map; - -import com.google.gson.JsonArray; -import com.google.gson.JsonElement; -import com.google.gson.JsonObject; -import com.google.gson.reflect.TypeToken; -import org.apache.commons.httpclient.methods.DeleteMethod; -import org.apache.commons.httpclient.methods.GetMethod; -import org.apache.commons.httpclient.methods.PostMethod; -import org.apache.commons.httpclient.methods.PutMethod; -import org.apache.zeppelin.interpreter.InterpreterOption; -import org.apache.zeppelin.interpreter.InterpreterSetting; -import org.apache.zeppelin.notebook.Note; -import org.apache.zeppelin.notebook.Paragraph; -import org.apache.zeppelin.scheduler.Job.Status; -import org.apache.zeppelin.server.ZeppelinServer; -import org.apache.zeppelin.user.AuthenticationInfo; -import org.junit.AfterClass; -import org.junit.Before; -import org.junit.BeforeClass; -import org.junit.FixMethodOrder; -import org.junit.Test; -import org.junit.runners.MethodSorters; - -import com.google.gson.Gson; - -import static org.junit.Assert.*; -import static org.hamcrest.MatcherAssert.assertThat; - -/** - * Zeppelin interpreter rest api tests - */ -@FixMethodOrder(MethodSorters.NAME_ASCENDING) -public class InterpreterRestApiTest extends AbstractTestRestApi { - Gson gson = new Gson(); - AuthenticationInfo anonymous; - - @BeforeClass - public static void init() throws Exception { - AbstractTestRestApi.startUp(); - } - - @AfterClass - public static void destroy() throws Exception { - AbstractTestRestApi.shutDown(); - } - - @Before - public void setUp() { - anonymous = new AuthenticationInfo("anonymous"); - } - - @Test - public void getAvailableInterpreters() throws IOException { - // when - GetMethod get = httpGet("/interpreter"); - JsonObject body = getBodyFieldFromResponse(get.getResponseBodyAsString()); - - // then - assertThat(get, isAllowed()); - assertEquals(ZeppelinServer.notebook.getInterpreterSettingManager().getAvailableInterpreterSettings().size(), - body.entrySet().size()); - get.releaseConnection(); - } - - @Test - public void getSettings() throws IOException { - // when - GetMethod get = httpGet("/interpreter/setting"); - // then - assertThat(get, isAllowed()); - // DO NOT REMOVE: implies that body is properly parsed as an array - JsonArray body = getArrayBodyFieldFromResponse(get.getResponseBodyAsString()); - get.releaseConnection(); - } - - @Test - public void testGetNonExistInterpreterSetting() throws IOException { - // when - String nonExistInterpreterSettingId = "apache_.zeppelin_1s_.aw3some$"; - GetMethod get = httpGet("/interpreter/setting/" + nonExistInterpreterSettingId); - - // then - assertThat("Test get method:", get, isNotFound()); - get.releaseConnection(); - } - - @Test - public void testSettingsCRUD() throws IOException { - // when: call create setting API - String rawRequest = "{\"name\":\"md2\",\"group\":\"md\",\"properties\":{\"propname\":\"propvalue\"}," + - "\"interpreterGroup\":[{\"class\":\"org.apache.zeppelin.markdown.Markdown\",\"name\":\"md\"}]," + - "\"dependencies\":[]," + - "\"option\": { \"remote\": true, \"session\": false }}"; - JsonObject jsonRequest = gson.fromJson(rawRequest, JsonElement.class).getAsJsonObject(); - PostMethod post = httpPost("/interpreter/setting/", jsonRequest.toString()); - String postResponse = post.getResponseBodyAsString(); - LOG.info("testSettingCRUD create response\n" + post.getResponseBodyAsString()); - InterpreterSetting created = convertResponseToInterpreterSetting(postResponse); - String newSettingId = created.getId(); - // then : call create setting API - assertThat("test create method:", post, isCreated()); - post.releaseConnection(); - - // when: call read setting API - GetMethod get = httpGet("/interpreter/setting/" + newSettingId); - String getResponse = get.getResponseBodyAsString(); - LOG.info("testSettingCRUD get response\n" + getResponse); - InterpreterSetting previouslyCreated = convertResponseToInterpreterSetting(getResponse); - // then : read Setting API - assertThat("Test get method:", get, isAllowed()); - assertEquals(newSettingId, previouslyCreated.getId()); - get.releaseConnection(); - - // when: call update setting API - jsonRequest.getAsJsonObject("properties").addProperty("propname2", "this is new prop"); - PutMethod put = httpPut("/interpreter/setting/" + newSettingId, jsonRequest.toString()); - LOG.info("testSettingCRUD update response\n" + put.getResponseBodyAsString()); - // then: call update setting API - assertThat("test update method:", put, isAllowed()); - put.releaseConnection(); - - // when: call delete setting API - DeleteMethod delete = httpDelete("/interpreter/setting/" + newSettingId); - LOG.info("testSettingCRUD delete response\n" + delete.getResponseBodyAsString()); - // then: call delete setting API - assertThat("Test delete method:", delete, isAllowed()); - delete.releaseConnection(); - } - - @Test - public void testCreatedInterpreterDependencies() throws IOException { - // when: Create 2 interpreter settings `md1` and `md2` which have different dep. - - String md1Name = "md1"; - String md2Name = "md2"; - - String md1Dep = "org.apache.drill.exec:drill-jdbc:jar:1.7.0"; - String md2Dep = "org.apache.drill.exec:drill-jdbc:jar:1.6.0"; - - String reqBody1 = "{\"name\":\"" + md1Name + "\",\"group\":\"md\",\"properties\":{\"propname\":\"propvalue\"}," + - "\"interpreterGroup\":[{\"class\":\"org.apache.zeppelin.markdown.Markdown\",\"name\":\"md\"}]," + - "\"dependencies\":[ {\n" + - " \"groupArtifactVersion\": \"" + md1Dep + "\",\n" + - " \"exclusions\":[]\n" + - " }]," + - "\"option\": { \"remote\": true, \"session\": false }}"; - PostMethod post = httpPost("/interpreter/setting", reqBody1); - assertThat("test create method:", post, isCreated()); - post.releaseConnection(); - - String reqBody2 = "{\"name\":\"" + md2Name + "\",\"group\":\"md\",\"properties\":{\"propname\":\"propvalue\"}," + - "\"interpreterGroup\":[{\"class\":\"org.apache.zeppelin.markdown.Markdown\",\"name\":\"md\"}]," + - "\"dependencies\":[ {\n" + - " \"groupArtifactVersion\": \"" + md2Dep + "\",\n" + - " \"exclusions\":[]\n" + - " }]," + - "\"option\": { \"remote\": true, \"session\": false }}"; - post = httpPost("/interpreter/setting", reqBody2); - assertThat("test create method:", post, isCreated()); - post.releaseConnection(); - - // 1. Call settings API - GetMethod get = httpGet("/interpreter/setting"); - String rawResponse = get.getResponseBodyAsString(); - get.releaseConnection(); - - // 2. Parsing to List - JsonObject responseJson = gson.fromJson(rawResponse, JsonElement.class).getAsJsonObject(); - JsonArray bodyArr = responseJson.getAsJsonArray("body"); - List settings = new Gson().fromJson(bodyArr, - new TypeToken>() { - }.getType()); - - // 3. Filter interpreters out we have just created - InterpreterSetting md1 = null; - InterpreterSetting md2 = null; - for (InterpreterSetting setting : settings) { - if (md1Name.equals(setting.getName())) { - md1 = setting; - } else if (md2Name.equals(setting.getName())) { - md2 = setting; - } - } - - // then: should get created interpreters which have different dependencies - - // 4. Validate each md interpreter has its own dependencies - assertEquals(1, md1.getDependencies().size()); - assertEquals(1, md2.getDependencies().size()); - assertEquals(md1Dep, md1.getDependencies().get(0).getGroupArtifactVersion()); - assertEquals(md2Dep, md2.getDependencies().get(0).getGroupArtifactVersion()); - } - - @Test - public void testSettingsCreateWithEmptyJson() throws IOException { - // Call Create Setting REST API - PostMethod post = httpPost("/interpreter/setting/", ""); - LOG.info("testSettingCRUD create response\n" + post.getResponseBodyAsString()); - assertThat("test create method:", post, isBadRequest()); - post.releaseConnection(); - } - - @Test - public void testInterpreterAutoBinding() throws IOException { - // when - Note note = ZeppelinServer.notebook.createNote(anonymous); - GetMethod get = httpGet("/notebook/interpreter/bind/" + note.getId()); - assertThat(get, isAllowed()); - get.addRequestHeader("Origin", "http://localhost"); - JsonArray body = getArrayBodyFieldFromResponse(get.getResponseBodyAsString()); - - // then: check interpreter is binded - assertTrue(0 < body.size()); - get.releaseConnection(); - ZeppelinServer.notebook.removeNote(note.getId(), anonymous); - } - - @Test - public void testInterpreterRestart() throws IOException, InterruptedException { - // when: create new note - Note note = ZeppelinServer.notebook.createNote(anonymous); - note.addParagraph(AuthenticationInfo.ANONYMOUS); - Paragraph p = note.getLastParagraph(); - Map config = p.getConfig(); - config.put("enabled", true); - - // when: run markdown paragraph - p.setConfig(config); - p.setText("%md markdown"); - p.setAuthenticationInfo(anonymous); - note.run(p.getId()); - while (p.getStatus() != Status.FINISHED) { - Thread.sleep(100); - } - assertEquals(p.getResult().message().get(0).getData(), getSimulatedMarkdownResult("markdown")); - - // when: restart interpreter - for (InterpreterSetting setting : ZeppelinServer.notebook.getInterpreterSettingManager().getInterpreterSettings(note.getId())) { - if (setting.getName().equals("md")) { - // call restart interpreter API - PutMethod put = httpPut("/interpreter/setting/restart/" + setting.getId(), ""); - assertThat("test interpreter restart:", put, isAllowed()); - put.releaseConnection(); - break; - } - } - - // when: run markdown paragraph, again - p = note.addParagraph(AuthenticationInfo.ANONYMOUS); - p.setConfig(config); - p.setText("%md markdown restarted"); - p.setAuthenticationInfo(anonymous); - note.run(p.getId()); - while (p.getStatus() != Status.FINISHED) { - Thread.sleep(100); - } - - // then - assertEquals(p.getResult().message().get(0).getData(), getSimulatedMarkdownResult("markdown restarted")); - ZeppelinServer.notebook.removeNote(note.getId(), anonymous); - } - - @Test - public void testRestartInterpreterPerNote() throws IOException, InterruptedException { - // when: create new note - Note note = ZeppelinServer.notebook.createNote(anonymous); - note.addParagraph(AuthenticationInfo.ANONYMOUS); - Paragraph p = note.getLastParagraph(); - Map config = p.getConfig(); - config.put("enabled", true); - - // when: run markdown paragraph. - p.setConfig(config); - p.setText("%md markdown"); - p.setAuthenticationInfo(anonymous); - note.run(p.getId()); - while (p.getStatus() != Status.FINISHED) { - Thread.sleep(100); - } - assertEquals(p.getResult().message().get(0).getData(), getSimulatedMarkdownResult("markdown")); - - // when: get md interpreter - InterpreterSetting mdIntpSetting = null; - for (InterpreterSetting setting : ZeppelinServer.notebook.getInterpreterSettingManager().getInterpreterSettings(note.getId())) { - if (setting.getName().equals("md")) { - mdIntpSetting = setting; - break; - } - } - - String jsonRequest = "{\"noteId\":\"" + note.getId() + "\"}"; - - // Restart isolated mode of Interpreter for note. - mdIntpSetting.getOption().setPerNote(InterpreterOption.ISOLATED); - PutMethod put = httpPut("/interpreter/setting/restart/" + mdIntpSetting.getId(), jsonRequest); - assertThat("isolated interpreter restart:", put, isAllowed()); - put.releaseConnection(); - - // Restart scoped mode of Interpreter for note. - mdIntpSetting.getOption().setPerNote(InterpreterOption.SCOPED); - put = httpPut("/interpreter/setting/restart/" + mdIntpSetting.getId(), jsonRequest); - assertThat("scoped interpreter restart:", put, isAllowed()); - put.releaseConnection(); - - // Restart shared mode of Interpreter for note. - mdIntpSetting.getOption().setPerNote(InterpreterOption.SHARED); - put = httpPut("/interpreter/setting/restart/" + mdIntpSetting.getId(), jsonRequest); - assertThat("shared interpreter restart:", put, isAllowed()); - put.releaseConnection(); - - ZeppelinServer.notebook.removeNote(note.getId(), anonymous); - } - - @Test - public void testListRepository() throws IOException { - GetMethod get = httpGet("/interpreter/repository"); - assertThat(get, isAllowed()); - get.releaseConnection(); - } - - @Test - public void testAddDeleteRepository() throws IOException { - // Call create repository API - String repoId = "securecentral"; - String jsonRequest = "{\"id\":\"" + repoId + - "\",\"url\":\"https://repo1.maven.org/maven2\",\"snapshot\":\"false\"}"; - - PostMethod post = httpPost("/interpreter/repository/", jsonRequest); - assertThat("Test create method:", post, isCreated()); - post.releaseConnection(); - - // Call delete repository API - DeleteMethod delete = httpDelete("/interpreter/repository/" + repoId); - assertThat("Test delete method:", delete, isAllowed()); - delete.releaseConnection(); - } - - public JsonObject getBodyFieldFromResponse(String rawResponse) { - JsonObject response = gson.fromJson(rawResponse, JsonElement.class).getAsJsonObject(); - return response.getAsJsonObject("body"); - } - - public JsonArray getArrayBodyFieldFromResponse(String rawResponse) { - JsonObject response = gson.fromJson(rawResponse, JsonElement.class).getAsJsonObject(); - return response.getAsJsonArray("body"); - } - - public InterpreterSetting convertResponseToInterpreterSetting(String rawResponse) { - return gson.fromJson(getBodyFieldFromResponse(rawResponse), InterpreterSetting.class); - } - - public static String getSimulatedMarkdownResult(String markdown) { - return String.format("
\n

%s

\n
", markdown); - } -} diff --git a/smart-zeppelin/zeppelin-server/src/test/java/org/apache/zeppelin/rest/NotebookRepoRestApiTest.java b/smart-zeppelin/zeppelin-server/src/test/java/org/apache/zeppelin/rest/NotebookRepoRestApiTest.java deleted file mode 100644 index 307339d7697..00000000000 --- a/smart-zeppelin/zeppelin-server/src/test/java/org/apache/zeppelin/rest/NotebookRepoRestApiTest.java +++ /dev/null @@ -1,128 +0,0 @@ -/* - * Licensed to the Apache Software Foundation (ASF) under one or more - * contributor license agreements. See the NOTICE file distributed with - * this work for additional information regarding copyright ownership. - * The ASF licenses this file to You under the Apache License, Version 2.0 - * (the "License"); you may not use this file except in compliance with - * the License. You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT 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.zeppelin.rest; - -import static org.hamcrest.CoreMatchers.is; -import static org.hamcrest.CoreMatchers.not; -import static org.hamcrest.CoreMatchers.anyOf; -import static org.junit.Assert.assertThat; - -import java.io.IOException; -import java.util.List; -import java.util.Map; - -import org.apache.commons.httpclient.methods.GetMethod; -import org.apache.commons.httpclient.methods.PutMethod; -import org.apache.commons.lang.StringUtils; -import org.apache.zeppelin.user.AuthenticationInfo; -import org.junit.AfterClass; -import org.junit.Before; -import org.junit.BeforeClass; -import org.junit.FixMethodOrder; -import org.junit.Test; -import org.junit.runners.MethodSorters; - -import com.google.gson.Gson; -import com.google.gson.reflect.TypeToken; - -/** - * NotebookRepo rest api test. - */ -@FixMethodOrder(MethodSorters.NAME_ASCENDING) -public class NotebookRepoRestApiTest extends AbstractTestRestApi { - - Gson gson = new Gson(); - AuthenticationInfo anonymous; - - @BeforeClass - public static void init() throws Exception { - AbstractTestRestApi.startUp(); - } - - @AfterClass - public static void destroy() throws Exception { - AbstractTestRestApi.shutDown(); - } - - @Before - public void setUp() { - anonymous = new AuthenticationInfo("anonymous"); - } - - private List> getListOfReposotiry() throws IOException { - GetMethod get = httpGet("/notebook-repositories"); - Map responce = gson.fromJson(get.getResponseBodyAsString(), new TypeToken>() {}.getType()); - get.releaseConnection(); - return (List>) responce.get("body"); - } - - private void updateNotebookRepoWithNewSetting(String payload) throws IOException { - PutMethod put = httpPut("/notebook-repositories", payload); - int status = put.getStatusCode(); - put.releaseConnection(); - assertThat(status, is(200)); - } - - @Test public void ThatCanGetNotebookRepositoiesSettings() throws IOException { - List> listOfRepositories = getListOfReposotiry(); - assertThat(listOfRepositories.size(), is(not(0))); - } - - @Test public void reloadRepositories() throws IOException { - GetMethod get = httpGet("/notebook-repositories/reload"); - int status = get.getStatusCode(); - get.releaseConnection(); - assertThat(status, is(200)); - } - - @Test public void setNewDirectoryForLocalDirectory() throws IOException { - List> listOfRepositories = getListOfReposotiry(); - String localVfs = StringUtils.EMPTY; - String className = StringUtils.EMPTY; - - for (int i = 0; i < listOfRepositories.size(); i++) { - if (listOfRepositories.get(i).get("name").equals("VFSNotebookRepo")) { - localVfs = (String) ((List>)listOfRepositories.get(i).get("settings")).get(0).get("selected"); - className = (String) listOfRepositories.get(i).get("className"); - break; - } - } - - if (StringUtils.isBlank(localVfs)) { - // no local VFS set... - return; - } - - String payload = "{ \"name\": \"" + className + "\", \"settings\" : { \"Notebook Path\" : \"/tmp/newDir\" } }"; - updateNotebookRepoWithNewSetting(payload); - - // Verify - listOfRepositories = getListOfReposotiry(); - String updatedPath = StringUtils.EMPTY; - for (int i = 0; i < listOfRepositories.size(); i++) { - if (listOfRepositories.get(i).get("name").equals("VFSNotebookRepo")) { - updatedPath = (String) ((List>)listOfRepositories.get(i).get("settings")).get(0).get("selected"); - break; - } - } - assertThat(updatedPath, anyOf(is("/tmp/newDir"),is("/tmp/newDir/"))); - - // go back to normal - payload = "{ \"name\": \"" + className + "\", \"settings\" : { \"Notebook Path\" : \"" + localVfs + "\" } }"; - updateNotebookRepoWithNewSetting(payload); - } -} diff --git a/smart-zeppelin/zeppelin-server/src/test/java/org/apache/zeppelin/rest/NotebookRestApiTest.java b/smart-zeppelin/zeppelin-server/src/test/java/org/apache/zeppelin/rest/NotebookRestApiTest.java deleted file mode 100644 index 5c7aec2760f..00000000000 --- a/smart-zeppelin/zeppelin-server/src/test/java/org/apache/zeppelin/rest/NotebookRestApiTest.java +++ /dev/null @@ -1,211 +0,0 @@ -/* - * Licensed to the Apache Software Foundation (ASF) under one or more - * contributor license agreements. See the NOTICE file distributed with - * this work for additional information regarding copyright ownership. - * The ASF licenses this file to You under the Apache License, Version 2.0 - * (the "License"); you may not use this file except in compliance with - * the License. You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT 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.zeppelin.rest; - -import com.google.common.collect.Lists; -import com.google.gson.Gson; -import com.google.gson.reflect.TypeToken; -import org.apache.commons.httpclient.methods.GetMethod; -import org.apache.commons.httpclient.methods.PostMethod; -import org.apache.commons.httpclient.methods.PutMethod; -import org.apache.zeppelin.interpreter.InterpreterResult; -import org.apache.zeppelin.notebook.Note; -import org.apache.zeppelin.notebook.Paragraph; -import org.apache.zeppelin.scheduler.Job; -import org.apache.zeppelin.server.ZeppelinServer; -import org.apache.zeppelin.user.AuthenticationInfo; -import org.junit.AfterClass; -import org.junit.Before; -import org.junit.BeforeClass; -import org.junit.FixMethodOrder; -import org.junit.Test; -import org.junit.runners.MethodSorters; - -import java.io.IOException; -import java.util.Map; -import java.util.Set; - -import static org.junit.Assert.assertEquals; -import static org.junit.Assert.assertNotEquals; -import static org.junit.Assert.assertNotNull; -import static org.junit.Assert.assertNull; -import static org.junit.Assert.assertThat; - -/** - * Zeppelin notebook rest api tests - */ -@FixMethodOrder(MethodSorters.NAME_ASCENDING) -public class NotebookRestApiTest extends AbstractTestRestApi { - Gson gson = new Gson(); - AuthenticationInfo anonymous; - - @BeforeClass - public static void init() throws Exception { - AbstractTestRestApi.startUp(); - } - - @AfterClass - public static void destroy() throws Exception { - AbstractTestRestApi.shutDown(); - } - - @Before - public void setUp() { - anonymous = new AuthenticationInfo("anonymous"); - } - - @Test - public void testGetNoteParagraphJobStatus() throws IOException { - Note note1 = ZeppelinServer.notebook.createNote(anonymous); - note1.addParagraph(AuthenticationInfo.ANONYMOUS); - - String paragraphId = note1.getLastParagraph().getId(); - - GetMethod get = httpGet("/notebook/job/" + note1.getId() + "/" + paragraphId); - assertThat(get, isAllowed()); - Map resp = gson.fromJson(get.getResponseBodyAsString(), new TypeToken>() { - }.getType()); - Map> paragraphStatus = (Map>) resp.get("body"); - - // Check id and status have proper value - assertEquals(paragraphStatus.get("id"), paragraphId); - assertEquals(paragraphStatus.get("status"), "READY"); - - //cleanup - ZeppelinServer.notebook.removeNote(note1.getId(), anonymous); - - } - - @Test - public void testRunParagraphJob() throws IOException { - Note note1 = ZeppelinServer.notebook.createNote(anonymous); - note1.addParagraph(AuthenticationInfo.ANONYMOUS); - - Paragraph p = note1.addParagraph(AuthenticationInfo.ANONYMOUS); - - // run blank paragraph - PostMethod post = httpPost("/notebook/job/" + note1.getId() + "/" + p.getId(), ""); - assertThat(post, isAllowed()); - Map resp = gson.fromJson(post.getResponseBodyAsString(), new TypeToken>() { - }.getType()); - assertEquals(resp.get("status"), "OK"); - post.releaseConnection(); - assertEquals(p.getStatus(), Job.Status.FINISHED); - - // run non-blank paragraph - p.setText("test"); - post = httpPost("/notebook/job/" + note1.getId() + "/" + p.getId(), ""); - assertThat(post, isAllowed()); - resp = gson.fromJson(post.getResponseBodyAsString(), new TypeToken>() { - }.getType()); - assertEquals(resp.get("status"), "OK"); - post.releaseConnection(); - assertNotEquals(p.getStatus(), Job.Status.READY); - - //cleanup - ZeppelinServer.notebook.removeNote(note1.getId(), anonymous); - } - - @Test - public void testCloneNote() throws IOException { - Note note1 = ZeppelinServer.notebook.createNote(anonymous); - PostMethod post = httpPost("/notebook/" + note1.getId(), ""); - LOG.info("testCloneNote response\n" + post.getResponseBodyAsString()); - assertThat(post, isCreated()); - Map resp = gson.fromJson(post.getResponseBodyAsString(), new TypeToken>() { - }.getType()); - String clonedNoteId = (String) resp.get("body"); - post.releaseConnection(); - - GetMethod get = httpGet("/notebook/" + clonedNoteId); - assertThat(get, isAllowed()); - Map resp2 = gson.fromJson(get.getResponseBodyAsString(), new TypeToken>() { - }.getType()); - Map resp2Body = (Map) resp2.get("body"); - - assertEquals((String)resp2Body.get("name"), "Note " + clonedNoteId); - get.releaseConnection(); - - //cleanup - ZeppelinServer.notebook.removeNote(note1.getId(), anonymous); - ZeppelinServer.notebook.removeNote(clonedNoteId, anonymous); - } - - @Test - public void testUpdateParagraphConfig() throws IOException { - Note note = ZeppelinServer.notebook.createNote(anonymous); - String noteId = note.getId(); - Paragraph p = note.addParagraph(AuthenticationInfo.ANONYMOUS); - assertNull(p.getConfig().get("colWidth")); - String paragraphId = p.getId(); - String jsonRequest = "{\"colWidth\": 6.0}"; - - PutMethod put = httpPut("/notebook/" + noteId + "/paragraph/" + paragraphId +"/config", jsonRequest); - assertThat("test testUpdateParagraphConfig:", put, isAllowed()); - - Map resp = gson.fromJson(put.getResponseBodyAsString(), new TypeToken>() { - }.getType()); - Map respBody = (Map) resp.get("body"); - Map config = (Map) respBody.get("config"); - put.releaseConnection(); - - assertEquals(config.get("colWidth"), 6.0); - note = ZeppelinServer.notebook.getNote(noteId); - assertEquals(note.getParagraph(paragraphId).getConfig().get("colWidth"), 6.0); - - //cleanup - ZeppelinServer.notebook.removeNote(noteId, anonymous); - } - - @Test - public void testClearAllParagraphOutput() throws IOException { - // Create note and set result explicitly - Note note = ZeppelinServer.notebook.createNote(anonymous); - Paragraph p1 = note.addParagraph(AuthenticationInfo.ANONYMOUS); - InterpreterResult result = new InterpreterResult(InterpreterResult.Code.SUCCESS, InterpreterResult.Type.TEXT, "result"); - p1.setResult(result); - - Paragraph p2 = note.addParagraph(AuthenticationInfo.ANONYMOUS); - p2.setReturn(result, new Throwable()); - - // clear paragraph result - PutMethod put = httpPut("/notebook/" + note.getId() + "/clear", ""); - LOG.info("test clear paragraph output response\n" + put.getResponseBodyAsString()); - assertThat(put, isAllowed()); - put.releaseConnection(); - - // check if paragraph results are cleared - GetMethod get = httpGet("/notebook/" + note.getId() + "/paragraph/" + p1.getId()); - assertThat(get, isAllowed()); - Map resp1 = gson.fromJson(get.getResponseBodyAsString(), new TypeToken>() { - }.getType()); - Map resp1Body = (Map) resp1.get("body"); - assertNull(resp1Body.get("result")); - - get = httpGet("/notebook/" + note.getId() + "/paragraph/" + p2.getId()); - assertThat(get, isAllowed()); - Map resp2 = gson.fromJson(get.getResponseBodyAsString(), new TypeToken>() { - }.getType()); - Map resp2Body = (Map) resp2.get("body"); - assertNull(resp2Body.get("result")); - get.releaseConnection(); - - //cleanup - ZeppelinServer.notebook.removeNote(note.getId(), anonymous); - } -} diff --git a/smart-zeppelin/zeppelin-server/src/test/java/org/apache/zeppelin/rest/NotebookSecurityRestApiTest.java b/smart-zeppelin/zeppelin-server/src/test/java/org/apache/zeppelin/rest/NotebookSecurityRestApiTest.java deleted file mode 100644 index 0f4a44083b7..00000000000 --- a/smart-zeppelin/zeppelin-server/src/test/java/org/apache/zeppelin/rest/NotebookSecurityRestApiTest.java +++ /dev/null @@ -1,218 +0,0 @@ -/* - * Licensed to the Apache Software Foundation (ASF) under one or more - * contributor license agreements. See the NOTICE file distributed with - * this work for additional information regarding copyright ownership. - * The ASF licenses this file to You under the Apache License, Version 2.0 - * (the "License"); you may not use this file except in compliance with - * the License. You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT 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.zeppelin.rest; - -import static org.hamcrest.CoreMatchers.is; -import static org.junit.Assert.*; -import static org.junit.Assert.assertEquals; - -import java.io.IOException; -import java.util.ArrayList; -import java.util.Map; - -import org.apache.commons.httpclient.HttpMethodBase; -import org.apache.commons.httpclient.methods.DeleteMethod; -import org.apache.commons.httpclient.methods.GetMethod; -import org.apache.commons.httpclient.methods.PostMethod; -import org.apache.commons.httpclient.methods.PutMethod; -import org.apache.zeppelin.notebook.Note; -import org.apache.zeppelin.server.ZeppelinServer; -import org.hamcrest.Matcher; -import org.junit.AfterClass; -import org.junit.Before; -import org.junit.BeforeClass; -import org.junit.Test; - -import com.google.gson.Gson; -import com.google.gson.reflect.TypeToken; - -public class NotebookSecurityRestApiTest extends AbstractTestRestApi { - - Gson gson = new Gson(); - - @BeforeClass - public static void init() throws Exception { - AbstractTestRestApi.startUpWithAuthenticationEnable(); - } - - @AfterClass - public static void destroy() throws Exception { - AbstractTestRestApi.shutDown(); - } - - @Before - public void setUp() {} - - - @Test - public void testThatUserCanCreateAndRemoveNote() throws IOException { - String noteId = createNoteForUser("test", "admin", "password1"); - assertNotNull(noteId); - String id = getNoteIdForUser(noteId, "admin", "password1"); - assertThat(id, is(noteId)); - deleteNoteForUser(noteId, "admin", "password1"); - } - - @Test - public void testThatOtherUserCanAccessNoteIfPermissionNotSet() throws IOException { - String noteId = createNoteForUser("test", "admin", "password1"); - - userTryGetNote(noteId, "user1", "password2", isAllowed()); - - deleteNoteForUser(noteId, "admin", "password1"); - } - - @Test - public void testThatOtherUserCannotAccessNoteIfPermissionSet() throws IOException { - String noteId = createNoteForUser("test", "admin", "password1"); - - //set permission - String payload = "{ \"owners\": [\"admin\"], \"readers\": [\"user2\"], \"writers\": [\"user2\"] }"; - PutMethod put = httpPut("/notebook/" + noteId + "/permissions", payload , "admin", "password1"); - assertThat("test set note permission method:", put, isAllowed()); - put.releaseConnection(); - - userTryGetNote(noteId, "user1", "password2", isForbidden()); - - userTryGetNote(noteId, "user2", "password3", isAllowed()); - - deleteNoteForUser(noteId, "admin", "password1"); - } - - @Test - public void testThatWriterCannotRemoveNote() throws IOException { - String noteId = createNoteForUser("test", "admin", "password1"); - - //set permission - String payload = "{ \"owners\": [\"admin\", \"user1\"], \"readers\": [\"user2\"], \"writers\": [\"user2\"] }"; - PutMethod put = httpPut("/notebook/" + noteId + "/permissions", payload , "admin", "password1"); - assertThat("test set note permission method:", put, isAllowed()); - put.releaseConnection(); - - userTryRemoveNote(noteId, "user2", "password3", isForbidden()); - userTryRemoveNote(noteId, "user1", "password2", isAllowed()); - - Note deletedNote = ZeppelinServer.notebook.getNote(noteId); - assertNull("Deleted note should be null", deletedNote); - } - - @Test - public void testThatUserCanSearchNote() throws IOException { - String noteId1 = createNoteForUser("test1", "admin", "password1"); - createParagraphForUser(noteId1, "admin", "password1", "title1", "ThisIsToTestSearchMethodWithPermissions 1"); - - String noteId2 = createNoteForUser("test2", "user1", "password2"); - createParagraphForUser(noteId1, "admin", "password1", "title2", "ThisIsToTestSearchMethodWithPermissions 2"); - - //set permission for each note - setPermissionForNote(noteId1, "admin", "password1"); - setPermissionForNote(noteId1, "user1", "password2"); - - searchNoteBasedOnPermission("ThisIsToTestSearchMethodWithPermissions", "admin", "password1"); - - deleteNoteForUser(noteId1, "admin", "password1"); - deleteNoteForUser(noteId2, "user1", "password2"); - } - - private void userTryRemoveNote(String noteId, String user, String pwd, Matcher m) throws IOException { - DeleteMethod delete = httpDelete(("/notebook/" + noteId), user, pwd); - assertThat(delete, m); - delete.releaseConnection(); - } - - private void userTryGetNote(String noteId, String user, String pwd, Matcher m) throws IOException { - GetMethod get = httpGet("/notebook/" + noteId, user, pwd); - assertThat(get, m); - get.releaseConnection(); - } - - private String getNoteIdForUser(String noteId, String user, String pwd) throws IOException { - GetMethod get = httpGet("/notebook/" + noteId, user, pwd); - assertThat("test note create method:", get, isAllowed()); - Map resp = gson.fromJson(get.getResponseBodyAsString(), new TypeToken>() { - }.getType()); - get.releaseConnection(); - return (String) ((Map)resp.get("body")).get("id"); - } - - private String createNoteForUser(String noteName, String user, String pwd) throws IOException { - String jsonRequest = "{\"name\":\"" + noteName + "\"}"; - PostMethod post = httpPost("/notebook/", jsonRequest, user, pwd); - assertThat("test note create method:", post, isCreated()); - Map resp = gson.fromJson(post.getResponseBodyAsString(), new TypeToken>() { - }.getType()); - post.releaseConnection(); - String newNoteId = (String) resp.get("body"); - Note newNote = ZeppelinServer.notebook.getNote(newNoteId); - assertNotNull("Can not find new note by id", newNote); - return newNoteId; - } - - private void deleteNoteForUser(String noteId, String user, String pwd) throws IOException { - DeleteMethod delete = httpDelete(("/notebook/" + noteId), user, pwd); - assertThat("Test delete method:", delete, isAllowed()); - delete.releaseConnection(); - // make sure note is deleted - if (!noteId.isEmpty()) { - Note deletedNote = ZeppelinServer.notebook.getNote(noteId); - assertNull("Deleted note should be null", deletedNote); - } - } - - private void createParagraphForUser(String noteId, String user, String pwd, String title, String text) throws IOException { - String payload = "{\"title\": \"" + title + "\",\"text\": \"" + text + "\"}"; - PostMethod post = httpPost(("/notebook/" + noteId + "/paragraph"), payload, user, pwd); - post.releaseConnection(); - } - - private void setPermissionForNote(String noteId, String user, String pwd) throws IOException { - String payload = "{\"owners\":[\"" + user + "\"],\"readers\":[\"" + user + "\"],\"writers\":[\"" + user + "\"]}"; - PutMethod put = httpPut(("/notebook/" + noteId + "/permissions"), payload, user, pwd); - put.releaseConnection(); - } - - - private void searchNoteBasedOnPermission(String searchText, String user, String pwd) throws IOException{ - GetMethod searchNote = httpGet(("/notebook/search?q=" + searchText), user, pwd); - Map respSearchResult = gson.fromJson(searchNote.getResponseBodyAsString(), - new TypeToken>() { - }.getType()); - ArrayList searchBody = (ArrayList) respSearchResult.get("body"); - assertEquals("At-least one search results is there", true, searchBody.size() >= 1); - - for (int i = 0; i < searchBody.size(); i++) { - Map searchResult = (Map) searchBody.get(i); - String userId = searchResult.get("id").split("/", 2)[0]; - - GetMethod getPermission = httpGet(("/notebook/" + userId + "/permissions"), user, pwd); - Map resp = gson.fromJson(getPermission.getResponseBodyAsString(), - new TypeToken>() { - }.getType()); - Map permissions = (Map) resp.get("body"); - ArrayList owners = permissions.get("owners"); - ArrayList readers = permissions.get("readers"); - ArrayList writers = permissions.get("writers"); - - if (owners.size() != 0 && readers.size() != 0 && writers.size() != 0) { - assertEquals("User has permissions ", true, (owners.contains(user) || readers.contains(user) || - writers.contains(user))); - } - getPermission.releaseConnection(); - } - searchNote.releaseConnection(); - } -} diff --git a/smart-zeppelin/zeppelin-server/src/test/java/org/apache/zeppelin/rest/SecurityRestApiTest.java b/smart-zeppelin/zeppelin-server/src/test/java/org/apache/zeppelin/rest/SecurityRestApiTest.java deleted file mode 100644 index bc38f740328..00000000000 --- a/smart-zeppelin/zeppelin-server/src/test/java/org/apache/zeppelin/rest/SecurityRestApiTest.java +++ /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. - */ - -package org.apache.zeppelin.rest; - -import java.io.IOException; -import java.util.List; -import java.util.Map; - -import org.apache.commons.httpclient.methods.GetMethod; -import org.hamcrest.CoreMatchers; -import org.junit.AfterClass; -import org.junit.BeforeClass; -import org.junit.Rule; -import org.junit.Test; -import org.junit.rules.ErrorCollector; - -import com.google.gson.Gson; -import com.google.gson.reflect.TypeToken; - -public class SecurityRestApiTest extends AbstractTestRestApi { - Gson gson = new Gson(); - - @Rule - public ErrorCollector collector = new ErrorCollector(); - - @BeforeClass - public static void init() throws Exception { - AbstractTestRestApi.startUpWithAuthenticationEnable(); - } - - @AfterClass - public static void destroy() throws Exception { - AbstractTestRestApi.shutDown(); - } - - @Test - public void testTicket() throws IOException { - GetMethod get = httpGet("/security/ticket", "admin", "password1"); - get.addRequestHeader("Origin", "http://localhost"); - Map resp = gson.fromJson(get.getResponseBodyAsString(), - new TypeToken>(){}.getType()); - Map body = (Map) resp.get("body"); - collector.checkThat("Paramater principal", body.get("principal"), - CoreMatchers.equalTo("admin")); - collector.checkThat("Paramater ticket", body.get("ticket"), - CoreMatchers.not("anonymous")); - get.releaseConnection(); - } - - @Test - public void testGetUserList() throws IOException { - GetMethod get = httpGet("/security/userlist/admi", "admin", "password1"); - get.addRequestHeader("Origin", "http://localhost"); - Map resp = gson.fromJson(get.getResponseBodyAsString(), - new TypeToken>(){}.getType()); - List userList = (List) ((Map) resp.get("body")).get("users"); - collector.checkThat("Search result size", userList.size(), - CoreMatchers.equalTo(1)); - collector.checkThat("Search result contains admin", userList.contains("admin"), - CoreMatchers.equalTo(true)); - get.releaseConnection(); - - GetMethod notUser = httpGet("/security/userlist/randomString", "admin", "password1"); - notUser.addRequestHeader("Origin", "http://localhost"); - Map notUserResp = gson.fromJson(notUser.getResponseBodyAsString(), - new TypeToken>(){}.getType()); - List emptyUserList = (List) ((Map) notUserResp.get("body")).get("users"); - collector.checkThat("Search result size", emptyUserList.size(), - CoreMatchers.equalTo(0)); - - notUser.releaseConnection(); - } -} - diff --git a/smart-zeppelin/zeppelin-server/src/test/java/org/apache/zeppelin/rest/ZeppelinRestApiTest.java b/smart-zeppelin/zeppelin-server/src/test/java/org/apache/zeppelin/rest/ZeppelinRestApiTest.java deleted file mode 100644 index 9fa6c512b54..00000000000 --- a/smart-zeppelin/zeppelin-server/src/test/java/org/apache/zeppelin/rest/ZeppelinRestApiTest.java +++ /dev/null @@ -1,734 +0,0 @@ -/* - * Licensed to the Apache Software Foundation (ASF) under one or more - * contributor license agreements. See the NOTICE file distributed with - * this work for additional information regarding copyright ownership. - * The ASF licenses this file to You under the Apache License, Version 2.0 - * (the "License"); you may not use this file except in compliance with - * the License. You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT 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.zeppelin.rest; - -import java.io.IOException; -import java.util.ArrayList; -import java.util.HashSet; -import java.util.List; -import java.util.Map; - -import com.google.common.collect.Sets; -import org.apache.commons.httpclient.methods.DeleteMethod; -import org.apache.commons.httpclient.methods.GetMethod; -import org.apache.commons.httpclient.methods.PostMethod; -import org.apache.commons.httpclient.methods.PutMethod; -import org.apache.commons.lang3.StringUtils; -import org.apache.zeppelin.notebook.Note; -import org.apache.zeppelin.notebook.Paragraph; -import org.apache.zeppelin.server.ZeppelinServer; -import org.apache.zeppelin.user.AuthenticationInfo; -import org.junit.AfterClass; -import org.junit.Before; -import org.junit.BeforeClass; -import org.junit.FixMethodOrder; -import org.junit.Test; -import org.junit.runners.MethodSorters; - -import com.google.gson.Gson; -import com.google.gson.reflect.TypeToken; - -import static org.junit.Assert.*; - -/** - * BASIC Zeppelin rest api tests - * - */ -@FixMethodOrder(MethodSorters.NAME_ASCENDING) -public class ZeppelinRestApiTest extends AbstractTestRestApi { - Gson gson = new Gson(); - AuthenticationInfo anonymous; - - @BeforeClass - public static void init() throws Exception { - AbstractTestRestApi.startUp(); - } - - @AfterClass - public static void destroy() throws Exception { - AbstractTestRestApi.shutDown(); - } - - @Before - public void setUp() { - anonymous = new AuthenticationInfo("anonymous"); - } - - /*** - * ROOT API TEST - ***/ - @Test - public void getApiRoot() throws IOException { - // when - GetMethod httpGetRoot = httpGet("/"); - // then - assertThat(httpGetRoot, isAllowed()); - httpGetRoot.releaseConnection(); - } - - @Test - public void testGetNoteInfo() throws IOException { - LOG.info("testGetNoteInfo"); - // Create note to get info - Note note = ZeppelinServer.notebook.createNote(anonymous); - assertNotNull("can't create new note", note); - note.setName("note"); - Paragraph paragraph = note.addParagraph(AuthenticationInfo.ANONYMOUS); - Map config = paragraph.getConfig(); - config.put("enabled", true); - paragraph.setConfig(config); - String paragraphText = "%md This is my new paragraph in my new note"; - paragraph.setText(paragraphText); - note.persist(anonymous); - - String sourceNoteId = note.getId(); - GetMethod get = httpGet("/notebook/" + sourceNoteId); - LOG.info("testGetNoteInfo \n" + get.getResponseBodyAsString()); - assertThat("test note get method:", get, isAllowed()); - - Map resp = gson.fromJson(get.getResponseBodyAsString(), new TypeToken>() { - }.getType()); - - assertNotNull(resp); - assertEquals("OK", resp.get("status")); - - Map body = (Map) resp.get("body"); - List> paragraphs = (List>) body.get("paragraphs"); - - assertTrue(paragraphs.size() > 0); - assertEquals(paragraphText, paragraphs.get(0).get("text")); - // - ZeppelinServer.notebook.removeNote(sourceNoteId, anonymous); - } - - @Test - public void testNoteCreateWithName() throws IOException { - String noteName = "Test note name"; - testNoteCreate(noteName); - } - - @Test - public void testNoteCreateNoName() throws IOException { - testNoteCreate(""); - } - - @Test - public void testNoteCreateWithParagraphs() throws IOException { - // Call Create Note REST API - String noteName = "test"; - String jsonRequest = "{\"name\":\"" + noteName + "\", \"paragraphs\": [" + - "{\"title\": \"title1\", \"text\": \"text1\"}," + - "{\"title\": \"title2\", \"text\": \"text2\"}" + - "]}"; - PostMethod post = httpPost("/notebook/", jsonRequest); - LOG.info("testNoteCreate \n" + post.getResponseBodyAsString()); - assertThat("test note create method:", post, isCreated()); - - Map resp = gson.fromJson(post.getResponseBodyAsString(), new TypeToken>() { - }.getType()); - - String newNoteId = (String) resp.get("body"); - LOG.info("newNoteId:=" + newNoteId); - Note newNote = ZeppelinServer.notebook.getNote(newNoteId); - assertNotNull("Can not find new note by id", newNote); - // This is partial test as newNote is in memory but is not persistent - String newNoteName = newNote.getName(); - LOG.info("new note name is: " + newNoteName); - String expectedNoteName = noteName; - if (noteName.isEmpty()) { - expectedNoteName = "Note " + newNoteId; - } - assertEquals("compare note name", expectedNoteName, newNoteName); - assertEquals("initial paragraph check failed", 3, newNote.getParagraphs().size()); - for (Paragraph p : newNote.getParagraphs()) { - if (StringUtils.isEmpty(p.getText())) { - continue; - } - assertTrue("paragraph title check failed", p.getTitle().startsWith("title")); - assertTrue("paragraph text check failed", p.getText().startsWith("text")); - } - // cleanup - ZeppelinServer.notebook.removeNote(newNoteId, anonymous); - post.releaseConnection(); - } - - private void testNoteCreate(String noteName) throws IOException { - // Call Create Note REST API - String jsonRequest = "{\"name\":\"" + noteName + "\"}"; - PostMethod post = httpPost("/notebook/", jsonRequest); - LOG.info("testNoteCreate \n" + post.getResponseBodyAsString()); - assertThat("test note create method:", post, isCreated()); - - Map resp = gson.fromJson(post.getResponseBodyAsString(), new TypeToken>() { - }.getType()); - - String newNoteId = (String) resp.get("body"); - LOG.info("newNoteId:=" + newNoteId); - Note newNote = ZeppelinServer.notebook.getNote(newNoteId); - assertNotNull("Can not find new note by id", newNote); - // This is partial test as newNote is in memory but is not persistent - String newNoteName = newNote.getName(); - LOG.info("new note name is: " + newNoteName); - String expectedNoteName = noteName; - if (noteName.isEmpty()) { - expectedNoteName = "Note " + newNoteId; - } - assertEquals("compare note name", expectedNoteName, newNoteName); - // cleanup - ZeppelinServer.notebook.removeNote(newNoteId, anonymous); - post.releaseConnection(); - - } - - @Test - public void testDeleteNote() throws IOException { - LOG.info("testDeleteNote"); - //Create note and get ID - Note note = ZeppelinServer.notebook.createNote(anonymous); - String noteId = note.getId(); - testDeleteNote(noteId); - } - - @Test - public void testDeleteNoteBadId() throws IOException { - LOG.info("testDeleteNoteBadId"); - testDeleteNote("2AZFXEX97"); - testDeleteNote("bad_ID"); - } - - - @Test - public void testexportNote() throws IOException { - LOG.info("testexportNote"); - Note note = ZeppelinServer.notebook.createNote(anonymous); - assertNotNull("can't create new note", note); - note.setName("source note for export"); - Paragraph paragraph = note.addParagraph(AuthenticationInfo.ANONYMOUS); - Map config = paragraph.getConfig(); - config.put("enabled", true); - paragraph.setConfig(config); - paragraph.setText("%md This is my new paragraph in my new note"); - note.persist(anonymous); - String sourceNoteId = note.getId(); - // Call export Note REST API - GetMethod get = httpGet("/notebook/export/" + sourceNoteId); - LOG.info("testNoteExport \n" + get.getResponseBodyAsString()); - assertThat("test note export method:", get, isAllowed()); - - Map resp = - gson.fromJson(get.getResponseBodyAsString(), - new TypeToken>() {}.getType()); - - String exportJSON = (String) resp.get("body"); - assertNotNull("Can not find new notejson", exportJSON); - LOG.info("export JSON:=" + exportJSON); - ZeppelinServer.notebook.removeNote(sourceNoteId, anonymous); - get.releaseConnection(); - - } - - @Test - public void testImportNotebook() throws IOException { - Map resp; - String noteName = "source note for import"; - LOG.info("testImortNote"); - // create test note - Note note = ZeppelinServer.notebook.createNote(anonymous); - assertNotNull("can't create new note", note); - note.setName(noteName); - Paragraph paragraph = note.addParagraph(AuthenticationInfo.ANONYMOUS); - Map config = paragraph.getConfig(); - config.put("enabled", true); - paragraph.setConfig(config); - paragraph.setText("%md This is my new paragraph in my new note"); - note.persist(anonymous); - String sourceNoteId = note.getId(); - // get note content as JSON - String oldJson = getNoteContent(sourceNoteId); - // call note post - PostMethod importPost = httpPost("/notebook/import/", oldJson); - assertThat(importPost, isCreated()); - resp = - gson.fromJson(importPost.getResponseBodyAsString(), - new TypeToken>() {}.getType()); - String importId = (String) resp.get("body"); - - assertNotNull("Did not get back a note id in body", importId); - Note newNote = ZeppelinServer.notebook.getNote(importId); - assertEquals("Compare note names", noteName, newNote.getName()); - assertEquals("Compare paragraphs count", note.getParagraphs().size(), newNote.getParagraphs() - .size()); - // cleanup - ZeppelinServer.notebook.removeNote(note.getId(), anonymous); - ZeppelinServer.notebook.removeNote(newNote.getId(), anonymous); - importPost.releaseConnection(); - } - - private String getNoteContent(String id) throws IOException { - GetMethod get = httpGet("/notebook/export/" + id); - assertThat(get, isAllowed()); - get.addRequestHeader("Origin", "http://localhost"); - Map resp = - gson.fromJson(get.getResponseBodyAsString(), - new TypeToken>() {}.getType()); - assertEquals(200, get.getStatusCode()); - String body = resp.get("body").toString(); - // System.out.println("Body is " + body); - get.releaseConnection(); - return body; - } - - private void testDeleteNote(String noteId) throws IOException { - - DeleteMethod delete = httpDelete(("/notebook/" + noteId)); - LOG.info("testDeleteNote delete response\n" + delete.getResponseBodyAsString()); - assertThat("Test delete method:", delete, isAllowed()); - delete.releaseConnection(); - // make sure note is deleted - if (!noteId.isEmpty()) { - Note deletedNote = ZeppelinServer.notebook.getNote(noteId); - assertNull("Deleted note should be null", deletedNote); - } - } - - @Test - public void testCloneNote() throws IOException, CloneNotSupportedException, IllegalArgumentException { - LOG.info("testCloneNote"); - // Create note to clone - Note note = ZeppelinServer.notebook.createNote(anonymous); - assertNotNull("can't create new note", note); - note.setName("source note for clone"); - Paragraph paragraph = note.addParagraph(AuthenticationInfo.ANONYMOUS); - Map config = paragraph.getConfig(); - config.put("enabled", true); - paragraph.setConfig(config); - paragraph.setText("%md This is my new paragraph in my new note"); - note.persist(anonymous); - String sourceNoteId = note.getId(); - - String noteName = "clone Note Name"; - // Call Clone Note REST API - String jsonRequest = "{\"name\":\"" + noteName + "\"}"; - PostMethod post = httpPost("/notebook/" + sourceNoteId, jsonRequest); - LOG.info("testNoteClone \n" + post.getResponseBodyAsString()); - assertThat("test note clone method:", post, isCreated()); - - Map resp = gson.fromJson(post.getResponseBodyAsString(), new TypeToken>() { - }.getType()); - - String newNoteId = (String) resp.get("body"); - LOG.info("newNoteId:=" + newNoteId); - Note newNote = ZeppelinServer.notebook.getNote(newNoteId); - assertNotNull("Can not find new note by id", newNote); - assertEquals("Compare note names", noteName, newNote.getName()); - assertEquals("Compare paragraphs count", note.getParagraphs().size(), newNote.getParagraphs().size()); - //cleanup - ZeppelinServer.notebook.removeNote(note.getId(), anonymous); - ZeppelinServer.notebook.removeNote(newNote.getId(), anonymous); - post.releaseConnection(); - } - - @Test - public void testListNotes() throws IOException { - LOG.info("testListNotes"); - GetMethod get = httpGet("/notebook/ "); - assertThat("List notes method", get, isAllowed()); - Map resp = gson.fromJson(get.getResponseBodyAsString(), new TypeToken>() { - }.getType()); - List> body = (List>) resp.get("body"); - //TODO(khalid): anonymous or specific user notes? - HashSet anonymous = Sets.newHashSet("anonymous"); - assertEquals("List notes are equal", ZeppelinServer.notebook.getAllNotes(anonymous).size(), body.size()); - get.releaseConnection(); - } - - @Test - public void testNoteJobs() throws IOException, InterruptedException { - LOG.info("testNoteJobs"); - // Create note to run test. - Note note = ZeppelinServer.notebook.createNote(anonymous); - assertNotNull("can't create new note", note); - note.setName("note for run test"); - Paragraph paragraph = note.addParagraph(AuthenticationInfo.ANONYMOUS); - - Map config = paragraph.getConfig(); - config.put("enabled", true); - paragraph.setConfig(config); - - paragraph.setText("%md This is test paragraph."); - note.persist(anonymous); - String noteId = note.getId(); - - note.runAll(); - // wait until job is finished or timeout. - int timeout = 1; - while (!paragraph.isTerminated()) { - Thread.sleep(1000); - if (timeout++ > 10) { - LOG.info("testNoteJobs timeout job."); - break; - } - } - - // Call Run note jobs REST API - PostMethod postNoteJobs = httpPost("/notebook/job/" + noteId, ""); - assertThat("test note jobs run:", postNoteJobs, isAllowed()); - postNoteJobs.releaseConnection(); - - // Call Stop note jobs REST API - DeleteMethod deleteNoteJobs = httpDelete("/notebook/job/" + noteId); - assertThat("test note stop:", deleteNoteJobs, isAllowed()); - deleteNoteJobs.releaseConnection(); - Thread.sleep(1000); - - // Call Run paragraph REST API - PostMethod postParagraph = httpPost("/notebook/job/" + noteId + "/" + paragraph.getId(), ""); - assertThat("test paragraph run:", postParagraph, isAllowed()); - postParagraph.releaseConnection(); - Thread.sleep(1000); - - // Call Stop paragraph REST API - DeleteMethod deleteParagraph = httpDelete("/notebook/job/" + noteId + "/" + paragraph.getId()); - assertThat("test paragraph stop:", deleteParagraph, isAllowed()); - deleteParagraph.releaseConnection(); - Thread.sleep(1000); - - //cleanup - ZeppelinServer.notebook.removeNote(note.getId(), anonymous); - } - - @Test - public void testGetNoteJob() throws IOException, InterruptedException { - LOG.info("testGetNoteJob"); - // Create note to run test. - Note note = ZeppelinServer.notebook.createNote(anonymous); - assertNotNull("can't create new note", note); - note.setName("note for run test"); - Paragraph paragraph = note.addParagraph(AuthenticationInfo.ANONYMOUS); - - Map config = paragraph.getConfig(); - config.put("enabled", true); - paragraph.setConfig(config); - - paragraph.setText("%sh sleep 1"); - paragraph.setAuthenticationInfo(anonymous); - note.persist(anonymous); - String noteId = note.getId(); - - note.runAll(); - - // wait until paragraph gets started - while (!paragraph.getStatus().isRunning()) { - Thread.sleep(100); - } - - // assume that status of the paragraph is running - GetMethod get = httpGet("/notebook/job/" + noteId); - assertThat("test get note job: ", get, isAllowed()); - String responseBody = get.getResponseBodyAsString(); - get.releaseConnection(); - - LOG.info("test get note job: \n" + responseBody); - Map resp = gson.fromJson(responseBody, new TypeToken>() { - }.getType()); - - List> paragraphs = (List>) resp.get("body"); - assertEquals(1, paragraphs.size()); - assertTrue(paragraphs.get(0).containsKey("progress")); - int progress = Integer.parseInt((String) paragraphs.get(0).get("progress")); - assertTrue(progress >= 0 && progress <= 100); - - // wait until job is finished or timeout. - int timeout = 1; - while (!paragraph.isTerminated()) { - Thread.sleep(100); - if (timeout++ > 10) { - LOG.info("testGetNoteJob timeout job."); - break; - } - } - - ZeppelinServer.notebook.removeNote(note.getId(), anonymous); - } - - @Test - public void testRunParagraphWithParams() throws IOException, InterruptedException { - LOG.info("testRunParagraphWithParams"); - // Create note to run test. - Note note = ZeppelinServer.notebook.createNote(anonymous); - assertNotNull("can't create new note", note); - note.setName("note for run test"); - Paragraph paragraph = note.addParagraph(AuthenticationInfo.ANONYMOUS); - - Map config = paragraph.getConfig(); - config.put("enabled", true); - paragraph.setConfig(config); - - paragraph.setText("%spark\nval param = z.input(\"param\").toString\nprintln(param)"); - note.persist(anonymous); - String noteId = note.getId(); - - note.runAll(); - // wait until job is finished or timeout. - int timeout = 1; - while (!paragraph.isTerminated()) { - Thread.sleep(1000); - if (timeout++ > 120) { - LOG.info("testRunParagraphWithParams timeout job."); - break; - } - } - - // Call Run paragraph REST API - PostMethod postParagraph = httpPost("/notebook/job/" + noteId + "/" + paragraph.getId(), - "{\"params\": {\"param\": \"hello\", \"param2\": \"world\"}}"); - assertThat("test paragraph run:", postParagraph, isAllowed()); - postParagraph.releaseConnection(); - Thread.sleep(1000); - - Note retrNote = ZeppelinServer.notebook.getNote(noteId); - Paragraph retrParagraph = retrNote.getParagraph(paragraph.getId()); - Map params = retrParagraph.settings.getParams(); - assertEquals("hello", params.get("param")); - assertEquals("world", params.get("param2")); - - //cleanup - ZeppelinServer.notebook.removeNote(note.getId(), anonymous); - } - - @Test - public void testJobs() throws InterruptedException, IOException{ - // create a note and a paragraph - Note note = ZeppelinServer.notebook.createNote(anonymous); - - note.setName("note for run test"); - Paragraph paragraph = note.addParagraph(AuthenticationInfo.ANONYMOUS); - paragraph.setText("%md This is test paragraph."); - - Map config = paragraph.getConfig(); - config.put("enabled", true); - paragraph.setConfig(config); - - note.runAll(); - // wait until job is finished or timeout. - int timeout = 1; - while (!paragraph.isTerminated()) { - Thread.sleep(1000); - if (timeout++ > 10) { - LOG.info("testNoteJobs timeout job."); - break; - } - } - - String jsonRequest = "{\"cron\":\"* * * * * ?\" }"; - // right cron expression but not exist note. - PostMethod postCron = httpPost("/notebook/cron/notexistnote", jsonRequest); - assertThat("", postCron, isNotFound()); - postCron.releaseConnection(); - - // right cron expression. - postCron = httpPost("/notebook/cron/" + note.getId(), jsonRequest); - assertThat("", postCron, isAllowed()); - postCron.releaseConnection(); - Thread.sleep(1000); - - // wrong cron expression. - jsonRequest = "{\"cron\":\"a * * * * ?\" }"; - postCron = httpPost("/notebook/cron/" + note.getId(), jsonRequest); - assertThat("", postCron, isBadRequest()); - postCron.releaseConnection(); - Thread.sleep(1000); - - // remove cron job. - DeleteMethod deleteCron = httpDelete("/notebook/cron/" + note.getId()); - assertThat("", deleteCron, isAllowed()); - deleteCron.releaseConnection(); - ZeppelinServer.notebook.removeNote(note.getId(), anonymous); - } - - @Test - public void testRegressionZEPPELIN_527() throws IOException { - Note note = ZeppelinServer.notebook.createNote(anonymous); - - note.setName("note for run test"); - Paragraph paragraph = note.addParagraph(AuthenticationInfo.ANONYMOUS); - paragraph.setText("%spark\nval param = z.input(\"param\").toString\nprintln(param)"); - - note.persist(anonymous); - - GetMethod getNoteJobs = httpGet("/notebook/job/" + note.getId()); - assertThat("test note jobs run:", getNoteJobs, isAllowed()); - Map resp = gson.fromJson(getNoteJobs.getResponseBodyAsString(), new TypeToken>() { - }.getType()); - List> body = (List>) resp.get("body"); - assertFalse(body.get(0).containsKey("started")); - assertFalse(body.get(0).containsKey("finished")); - getNoteJobs.releaseConnection(); - - ZeppelinServer.notebook.removeNote(note.getId(), anonymous); - } - - @Test - public void testInsertParagraph() throws IOException { - Note note = ZeppelinServer.notebook.createNote(anonymous); - - String jsonRequest = "{\"title\": \"title1\", \"text\": \"text1\"}"; - PostMethod post = httpPost("/notebook/" + note.getId() + "/paragraph", jsonRequest); - LOG.info("testInsertParagraph response\n" + post.getResponseBodyAsString()); - assertThat("Test insert method:", post, isCreated()); - post.releaseConnection(); - - Map resp = gson.fromJson(post.getResponseBodyAsString(), new TypeToken>() { - }.getType()); - - String newParagraphId = (String) resp.get("body"); - LOG.info("newParagraphId:=" + newParagraphId); - - Note retrNote = ZeppelinServer.notebook.getNote(note.getId()); - Paragraph newParagraph = retrNote.getParagraph(newParagraphId); - assertNotNull("Can not find new paragraph by id", newParagraph); - - assertEquals("title1", newParagraph.getTitle()); - assertEquals("text1", newParagraph.getText()); - - Paragraph lastParagraph = note.getLastParagraph(); - assertEquals(newParagraph.getId(), lastParagraph.getId()); - - // insert to index 0 - String jsonRequest2 = "{\"index\": 0, \"title\": \"title2\", \"text\": \"text2\"}"; - PostMethod post2 = httpPost("/notebook/" + note.getId() + "/paragraph", jsonRequest2); - LOG.info("testInsertParagraph response2\n" + post2.getResponseBodyAsString()); - assertThat("Test insert method:", post2, isCreated()); - post2.releaseConnection(); - - Paragraph paragraphAtIdx0 = note.getParagraphs().get(0); - assertEquals("title2", paragraphAtIdx0.getTitle()); - assertEquals("text2", paragraphAtIdx0.getText()); - - ZeppelinServer.notebook.removeNote(note.getId(), anonymous); - } - - @Test - public void testGetParagraph() throws IOException { - Note note = ZeppelinServer.notebook.createNote(anonymous); - - Paragraph p = note.addParagraph(AuthenticationInfo.ANONYMOUS); - p.setTitle("hello"); - p.setText("world"); - note.persist(anonymous); - - GetMethod get = httpGet("/notebook/" + note.getId() + "/paragraph/" + p.getId()); - LOG.info("testGetParagraph response\n" + get.getResponseBodyAsString()); - assertThat("Test get method: ", get, isAllowed()); - get.releaseConnection(); - - Map resp = gson.fromJson(get.getResponseBodyAsString(), new TypeToken>() { - }.getType()); - - assertNotNull(resp); - assertEquals("OK", resp.get("status")); - - Map body = (Map) resp.get("body"); - - assertEquals(p.getId(), body.get("id")); - assertEquals("hello", body.get("title")); - assertEquals("world", body.get("text")); - - ZeppelinServer.notebook.removeNote(note.getId(), anonymous); - } - - @Test - public void testMoveParagraph() throws IOException { - Note note = ZeppelinServer.notebook.createNote(anonymous); - - Paragraph p = note.addParagraph(AuthenticationInfo.ANONYMOUS); - p.setTitle("title1"); - p.setText("text1"); - - Paragraph p2 = note.addParagraph(AuthenticationInfo.ANONYMOUS); - p2.setTitle("title2"); - p2.setText("text2"); - - note.persist(anonymous); - - PostMethod post = httpPost("/notebook/" + note.getId() + "/paragraph/" + p2.getId() + "/move/" + 0, ""); - assertThat("Test post method: ", post, isAllowed()); - post.releaseConnection(); - - Note retrNote = ZeppelinServer.notebook.getNote(note.getId()); - Paragraph paragraphAtIdx0 = retrNote.getParagraphs().get(0); - - assertEquals(p2.getId(), paragraphAtIdx0.getId()); - assertEquals(p2.getTitle(), paragraphAtIdx0.getTitle()); - assertEquals(p2.getText(), paragraphAtIdx0.getText()); - - PostMethod post2 = httpPost("/notebook/" + note.getId() + "/paragraph/" + p2.getId() + "/move/" + 10, ""); - assertThat("Test post method: ", post2, isBadRequest()); - post.releaseConnection(); - - ZeppelinServer.notebook.removeNote(note.getId(), anonymous); - } - - @Test - public void testDeleteParagraph() throws IOException { - Note note = ZeppelinServer.notebook.createNote(anonymous); - - Paragraph p = note.addParagraph(AuthenticationInfo.ANONYMOUS); - p.setTitle("title1"); - p.setText("text1"); - - note.persist(anonymous); - - DeleteMethod delete = httpDelete("/notebook/" + note.getId() + "/paragraph/" + p.getId()); - assertThat("Test delete method: ", delete, isAllowed()); - delete.releaseConnection(); - - Note retrNote = ZeppelinServer.notebook.getNote(note.getId()); - Paragraph retrParagrah = retrNote.getParagraph(p.getId()); - assertNull("paragraph should be deleted", retrParagrah); - - ZeppelinServer.notebook.removeNote(note.getId(), anonymous); - } - - @Test - public void testTitleSearch() throws IOException { - Note note = ZeppelinServer.notebook.createNote(anonymous); - String jsonRequest = "{\"title\": \"testTitleSearchOfParagraph\", \"text\": \"ThisIsToTestSearchMethodWithTitle \"}"; - PostMethod postNoteText = httpPost("/notebook/" + note.getId() + "/paragraph", jsonRequest); - postNoteText.releaseConnection(); - - GetMethod searchNote = httpGet("/notebook/search?q='testTitleSearchOfParagraph'"); - searchNote.addRequestHeader("Origin", "http://localhost"); - Map respSearchResult = gson.fromJson(searchNote.getResponseBodyAsString(), - new TypeToken>() { - }.getType()); - ArrayList searchBody = (ArrayList) respSearchResult.get("body"); - - int numberOfTitleHits = 0; - for (int i = 0; i < searchBody.size(); i++) { - Map searchResult = (Map) searchBody.get(i); - if (searchResult.get("header").contains("testTitleSearchOfParagraph")) { - numberOfTitleHits++; - } - } - assertEquals("Paragraph title hits must be at-least one", true, numberOfTitleHits >= 1); - searchNote.releaseConnection(); - ZeppelinServer.notebook.removeNote(note.getId(), anonymous); - } - -} diff --git a/smart-zeppelin/zeppelin-server/src/test/java/org/apache/zeppelin/rest/ZeppelinSparkClusterTest.java b/smart-zeppelin/zeppelin-server/src/test/java/org/apache/zeppelin/rest/ZeppelinSparkClusterTest.java deleted file mode 100644 index 7affdd8d20e..00000000000 --- a/smart-zeppelin/zeppelin-server/src/test/java/org/apache/zeppelin/rest/ZeppelinSparkClusterTest.java +++ /dev/null @@ -1,485 +0,0 @@ -/* - * Licensed to the Apache Software Foundation (ASF) under one or more - * contributor license agreements. See the NOTICE file distributed with - * this work for additional information regarding copyright ownership. - * The ASF licenses this file to You under the Apache License, Version 2.0 - * (the "License"); you may not use this file except in compliance with - * the License. You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT 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.zeppelin.rest; - -import static org.junit.Assert.assertEquals; -import static org.junit.Assert.assertNotEquals; -import static org.junit.Assert.assertTrue; - -import java.io.File; -import java.io.IOException; -import java.util.Iterator; -import java.util.List; -import java.util.Map; - -import org.apache.commons.io.FileUtils; -import org.apache.zeppelin.interpreter.InterpreterResult; -import org.apache.zeppelin.interpreter.InterpreterSetting; -import org.apache.zeppelin.notebook.Note; -import org.apache.zeppelin.notebook.Paragraph; -import org.apache.zeppelin.scheduler.Job.Status; -import org.apache.zeppelin.server.ZeppelinServer; -import org.apache.zeppelin.user.AuthenticationInfo; -import org.junit.AfterClass; -import org.junit.Before; -import org.junit.BeforeClass; -import org.junit.Test; - -import com.google.gson.Gson; - -/** - * Test against spark cluster. - * Spark cluster is started by CI server using testing/startSparkCluster.sh - */ -public class ZeppelinSparkClusterTest extends AbstractTestRestApi { - Gson gson = new Gson(); - AuthenticationInfo anonymous; - - @BeforeClass - public static void init() throws Exception { - AbstractTestRestApi.startUp(); - } - - @AfterClass - public static void destroy() throws Exception { - AbstractTestRestApi.shutDown(); - } - - @Before - public void setUp() { - anonymous = new AuthenticationInfo("anonymous"); - } - - private void waitForFinish(Paragraph p) { - while (p.getStatus() != Status.FINISHED - && p.getStatus() != Status.ERROR - && p.getStatus() != Status.ABORT) { - try { - Thread.sleep(100); - } catch (InterruptedException e) { - LOG.error("Exception in WebDriverManager while getWebDriver ", e); - } - } - } - - @Test - public void basicRDDTransformationAndActionTest() throws IOException { - // create new note - Note note = ZeppelinServer.notebook.createNote(anonymous); - - // run markdown paragraph, again - Paragraph p = note.addParagraph(AuthenticationInfo.ANONYMOUS); - Map config = p.getConfig(); - config.put("enabled", true); - p.setConfig(config); - p.setText("%spark print(sc.parallelize(1 to 10).reduce(_ + _))"); - p.setAuthenticationInfo(anonymous); - note.run(p.getId()); - waitForFinish(p); - assertEquals(Status.FINISHED, p.getStatus()); - assertEquals("55", p.getResult().message().get(0).getData()); - ZeppelinServer.notebook.removeNote(note.getId(), anonymous); - } - - @Test - public void sparkSQLTest() throws IOException { - // create new note - Note note = ZeppelinServer.notebook.createNote(anonymous); - int sparkVersion = getSparkVersionNumber(note); - // DataFrame API is available from spark 1.3 - if (sparkVersion >= 13) { - // test basic dataframe api - Paragraph p = note.addParagraph(AuthenticationInfo.ANONYMOUS); - Map config = p.getConfig(); - config.put("enabled", true); - p.setConfig(config); - p.setText("%spark val df=sqlContext.createDataFrame(Seq((\"hello\",20)))\n" + - "df.collect()"); - p.setAuthenticationInfo(anonymous); - note.run(p.getId()); - waitForFinish(p); - assertEquals(Status.FINISHED, p.getStatus()); - assertTrue(p.getResult().message().get(0).getData().contains( - "Array[org.apache.spark.sql.Row] = Array([hello,20])")); - - // test display DataFrame - p = note.addParagraph(AuthenticationInfo.ANONYMOUS); - config = p.getConfig(); - config.put("enabled", true); - p.setConfig(config); - p.setText("%spark val df=sqlContext.createDataFrame(Seq((\"hello\",20)))\n" + - "z.show(df)"); - p.setAuthenticationInfo(anonymous); - note.run(p.getId()); - waitForFinish(p); - assertEquals(Status.FINISHED, p.getStatus()); - assertEquals(InterpreterResult.Type.TABLE, p.getResult().message().get(1).getType()); - assertEquals("_1\t_2\nhello\t20\n", p.getResult().message().get(1).getData()); - - // test display DataSet - if (sparkVersion >= 20) { - p = note.addParagraph(AuthenticationInfo.ANONYMOUS); - config = p.getConfig(); - config.put("enabled", true); - p.setConfig(config); - p.setText("%spark val ds=spark.createDataset(Seq((\"hello\",20)))\n" + - "z.show(ds)"); - p.setAuthenticationInfo(anonymous); - note.run(p.getId()); - waitForFinish(p); - assertEquals(Status.FINISHED, p.getStatus()); - assertEquals(InterpreterResult.Type.TABLE, p.getResult().message().get(1).getType()); - assertEquals("_1\t_2\nhello\t20\n", p.getResult().message().get(1).getData()); - } - ZeppelinServer.notebook.removeNote(note.getId(), anonymous); - } - } - - @Test - public void sparkRTest() throws IOException { - // create new note - Note note = ZeppelinServer.notebook.createNote(anonymous); - int sparkVersion = getSparkVersionNumber(note); - - if (isSparkR() && sparkVersion >= 14) { // sparkr supported from 1.4.0 - // restart spark interpreter - List settings = - ZeppelinServer.notebook.getBindedInterpreterSettings(note.getId()); - - for (InterpreterSetting setting : settings) { - if (setting.getName().equals("spark")) { - ZeppelinServer.notebook.getInterpreterSettingManager().restart(setting.getId()); - break; - } - } - - String sqlContextName = "sqlContext"; - if (sparkVersion >= 20) { - sqlContextName = "spark"; - } - Paragraph p = note.addParagraph(AuthenticationInfo.ANONYMOUS); - Map config = p.getConfig(); - config.put("enabled", true); - p.setConfig(config); - p.setText("%r localDF <- data.frame(name=c(\"a\", \"b\", \"c\"), age=c(19, 23, 18))\n" + - "df <- createDataFrame(" + sqlContextName + ", localDF)\n" + - "count(df)" - ); - p.setAuthenticationInfo(anonymous); - note.run(p.getId()); - waitForFinish(p); - System.err.println("sparkRTest=" + p.getResult().message().get(0).getData()); - assertEquals(Status.FINISHED, p.getStatus()); - assertEquals("[1] 3", p.getResult().message().get(0).getData().trim()); - } - ZeppelinServer.notebook.removeNote(note.getId(), anonymous); - } - - @Test - public void pySparkTest() throws IOException { - // create new note - Note note = ZeppelinServer.notebook.createNote(anonymous); - note.setName("note"); - int sparkVersion = getSparkVersionNumber(note); - - if (isPyspark() && sparkVersion >= 12) { // pyspark supported from 1.2.1 - // run markdown paragraph, again - Paragraph p = note.addParagraph(AuthenticationInfo.ANONYMOUS); - Map config = p.getConfig(); - config.put("enabled", true); - p.setConfig(config); - p.setText("%pyspark print(sc.parallelize(range(1, 11)).reduce(lambda a, b: a + b))"); - p.setAuthenticationInfo(anonymous); - note.run(p.getId()); - waitForFinish(p); - assertEquals(Status.FINISHED, p.getStatus()); - assertEquals("55\n", p.getResult().message().get(0).getData()); - if (sparkVersion >= 13) { - // run sqlContext test - p = note.addParagraph(AuthenticationInfo.ANONYMOUS); - config = p.getConfig(); - config.put("enabled", true); - p.setConfig(config); - p.setText("%pyspark from pyspark.sql import Row\n" + - "df=sqlContext.createDataFrame([Row(id=1, age=20)])\n" + - "df.collect()"); - p.setAuthenticationInfo(anonymous); - note.run(p.getId()); - waitForFinish(p); - assertEquals(Status.FINISHED, p.getStatus()); - assertEquals("[Row(age=20, id=1)]\n", p.getResult().message().get(0).getData()); - - // test display Dataframe - p = note.addParagraph(AuthenticationInfo.ANONYMOUS); - config = p.getConfig(); - config.put("enabled", true); - p.setConfig(config); - p.setText("%pyspark from pyspark.sql import Row\n" + - "df=sqlContext.createDataFrame([Row(id=1, age=20)])\n" + - "z.show(df)"); - p.setAuthenticationInfo(anonymous); - note.run(p.getId()); - waitForFinish(p); - assertEquals(Status.FINISHED, p.getStatus()); - assertEquals(InterpreterResult.Type.TABLE, p.getResult().message().get(0).getType()); - // TODO (zjffdu), one more \n is appended, need to investigate why. - assertEquals("age\tid\n20\t1\n", p.getResult().message().get(0).getData()); - - // test udf - p = note.addParagraph(AuthenticationInfo.ANONYMOUS); - config = p.getConfig(); - config.put("enabled", true); - p.setConfig(config); - p.setText("%pyspark sqlContext.udf.register(\"f1\", lambda x: len(x))\n" + - "sqlContext.sql(\"select f1(\\\"abc\\\") as len\").collect()"); - p.setAuthenticationInfo(anonymous); - note.run(p.getId()); - waitForFinish(p); - assertEquals(Status.FINISHED, p.getStatus()); - assertEquals("[Row(len=u'3')]\n", p.getResult().message().get(0).getData()); - } - if (sparkVersion >= 20) { - // run SparkSession test - p = note.addParagraph(AuthenticationInfo.ANONYMOUS); - config = p.getConfig(); - config.put("enabled", true); - p.setConfig(config); - p.setText("%pyspark from pyspark.sql import Row\n" + - "df=sqlContext.createDataFrame([Row(id=1, age=20)])\n" + - "df.collect()"); - p.setAuthenticationInfo(anonymous); - note.run(p.getId()); - waitForFinish(p); - assertEquals(Status.FINISHED, p.getStatus()); - assertEquals("[Row(age=20, id=1)]\n", p.getResult().message().get(0).getData()); - - // test udf - p = note.addParagraph(AuthenticationInfo.ANONYMOUS); - config = p.getConfig(); - config.put("enabled", true); - p.setConfig(config); - // use SQLContext to register UDF but use this UDF through SparkSession - p.setText("%pyspark sqlContext.udf.register(\"f1\", lambda x: len(x))\n" + - "spark.sql(\"select f1(\\\"abc\\\") as len\").collect()"); - p.setAuthenticationInfo(anonymous); - note.run(p.getId()); - waitForFinish(p); - assertEquals(Status.FINISHED, p.getStatus()); - assertEquals("[Row(len=u'3')]\n", p.getResult().message().get(0).getData()); - } - } - ZeppelinServer.notebook.removeNote(note.getId(), anonymous); - } - - @Test - public void pySparkAutoConvertOptionTest() throws IOException { - // create new note - Note note = ZeppelinServer.notebook.createNote(anonymous); - note.setName("note"); - - int sparkVersionNumber = getSparkVersionNumber(note); - - if (isPyspark() && sparkVersionNumber >= 14) { // auto_convert enabled from spark 1.4 - // run markdown paragraph, again - Paragraph p = note.addParagraph(AuthenticationInfo.ANONYMOUS); - Map config = p.getConfig(); - config.put("enabled", true); - p.setConfig(config); - - String sqlContextName = "sqlContext"; - if (sparkVersionNumber >= 20) { - sqlContextName = "spark"; - } - - p.setText("%pyspark\nfrom pyspark.sql.functions import *\n" - + "print(" + sqlContextName + ".range(0, 10).withColumn('uniform', rand(seed=10) * 3.14).count())"); - p.setAuthenticationInfo(anonymous); - note.run(p.getId()); - waitForFinish(p); - assertEquals(Status.FINISHED, p.getStatus()); - assertEquals("10\n", p.getResult().message().get(0).getData()); - } - ZeppelinServer.notebook.removeNote(note.getId(), anonymous); - } - - @Test - public void zRunTest() throws IOException { - // create new note - Note note = ZeppelinServer.notebook.createNote(anonymous); - Paragraph p0 = note.addParagraph(AuthenticationInfo.ANONYMOUS); - Map config0 = p0.getConfig(); - config0.put("enabled", true); - p0.setConfig(config0); - p0.setText("%spark z.run(1)"); - p0.setAuthenticationInfo(anonymous); - Paragraph p1 = note.addParagraph(AuthenticationInfo.ANONYMOUS); - Map config1 = p1.getConfig(); - config1.put("enabled", true); - p1.setConfig(config1); - p1.setText("%spark val a=10"); - p1.setAuthenticationInfo(anonymous); - Paragraph p2 = note.addParagraph(AuthenticationInfo.ANONYMOUS); - Map config2 = p2.getConfig(); - config2.put("enabled", true); - p2.setConfig(config2); - p2.setText("%spark print(a)"); - p2.setAuthenticationInfo(anonymous); - - note.run(p0.getId()); - waitForFinish(p0); - assertEquals(Status.FINISHED, p0.getStatus()); - - // z.run is not blocking call. So p1 may not be finished when p0 is done. - waitForFinish(p1); - note.run(p2.getId()); - waitForFinish(p2); - assertEquals(Status.FINISHED, p2.getStatus()); - assertEquals("10", p2.getResult().message().get(0).getData()); - - Paragraph p3 = note.addParagraph(AuthenticationInfo.ANONYMOUS); - Map config3 = p3.getConfig(); - config3.put("enabled", true); - p3.setConfig(config3); - p3.setText("%spark println(new java.util.Date())"); - p3.setAuthenticationInfo(anonymous); - - p0.setText(String.format("%%spark z.runNote(\"%s\")", note.getId())); - note.run(p0.getId()); - waitForFinish(p0); - waitForFinish(p1); - waitForFinish(p2); - waitForFinish(p3); - - assertEquals(Status.FINISHED, p3.getStatus()); - String p3result = p3.getResult().message().get(0).getData(); - assertNotEquals(null, p3result); - assertNotEquals("", p3result); - - p0.setText(String.format("%%spark z.run(\"%s\", \"%s\")", note.getId(), p3.getId())); - p3.setText("%%spark println(\"END\")"); - - note.run(p0.getId()); - waitForFinish(p0); - waitForFinish(p3); - - assertNotEquals(p3result, p3.getResult().message()); - - ZeppelinServer.notebook.removeNote(note.getId(), anonymous); - } - - @Test - public void pySparkDepLoaderTest() throws IOException { - // create new note - Note note = ZeppelinServer.notebook.createNote(anonymous); - int sparkVersionNumber = getSparkVersionNumber(note); - - if (isPyspark() && sparkVersionNumber >= 14) { - // restart spark interpreter - List settings = - ZeppelinServer.notebook.getBindedInterpreterSettings(note.getId()); - - for (InterpreterSetting setting : settings) { - if (setting.getName().equals("spark")) { - ZeppelinServer.notebook.getInterpreterSettingManager().restart(setting.getId()); - break; - } - } - - // load dep - Paragraph p0 = note.addParagraph(AuthenticationInfo.ANONYMOUS); - Map config = p0.getConfig(); - config.put("enabled", true); - p0.setConfig(config); - p0.setText("%dep z.load(\"com.databricks:spark-csv_2.11:1.2.0\")"); - p0.setAuthenticationInfo(anonymous); - note.run(p0.getId()); - waitForFinish(p0); - assertEquals(Status.FINISHED, p0.getStatus()); - - // write test csv file - File tmpFile = File.createTempFile("test", "csv"); - FileUtils.write(tmpFile, "a,b\n1,2"); - - // load data using libraries from dep loader - Paragraph p1 = note.addParagraph(AuthenticationInfo.ANONYMOUS); - p1.setConfig(config); - - String sqlContextName = "sqlContext"; - if (sparkVersionNumber >= 20) { - sqlContextName = "spark"; - } - p1.setText("%pyspark\n" + - "from pyspark.sql import SQLContext\n" + - "print(" + sqlContextName + ".read.format('com.databricks.spark.csv')" + - ".load('"+ tmpFile.getAbsolutePath() +"').count())"); - p1.setAuthenticationInfo(anonymous); - note.run(p1.getId()); - - waitForFinish(p1); - assertEquals(Status.FINISHED, p1.getStatus()); - assertEquals("2\n", p1.getResult().message().get(0).getData()); - } - ZeppelinServer.notebook.removeNote(note.getId(), anonymous); - } - - /** - * Get spark version number as a numerical value. - * eg. 1.1.x => 11, 1.2.x => 12, 1.3.x => 13 ... - */ - private int getSparkVersionNumber(Note note) { - Paragraph p = note.addParagraph(AuthenticationInfo.ANONYMOUS); - note.setName("note"); - Map config = p.getConfig(); - config.put("enabled", true); - p.setConfig(config); - p.setText("%spark print(sc.version)"); - p.setAuthenticationInfo(anonymous); - note.run(p.getId()); - waitForFinish(p); - assertEquals(Status.FINISHED, p.getStatus()); - String sparkVersion = p.getResult().message().get(0).getData(); - System.out.println("Spark version detected " + sparkVersion); - String[] split = sparkVersion.split("\\."); - int version = Integer.parseInt(split[0]) * 10 + Integer.parseInt(split[1]); - return version; - } - - @Test - public void testZeppelinContextDynamicForms() throws IOException { - Note note = ZeppelinServer.notebook.createNote(anonymous); - Paragraph p = note.addParagraph(AuthenticationInfo.ANONYMOUS); - note.setName("note"); - Map config = p.getConfig(); - config.put("enabled", true); - p.setConfig(config); - String code = "%spark.spark z.input(\"my_input\", \"default_name\")\n" + - "z.select(\"my_select\", \"select_2\"," + - "Seq((\"1\", \"select_1\"), (\"2\", \"select_2\")))\n" + - "z.checkbox(\"my_checkbox\", Seq(\"check_1\"), " + - "Seq((\"1\", \"check_1\"), (\"2\", \"check_2\")))"; - p.setText(code); - p.setAuthenticationInfo(anonymous); - note.run(p.getId()); - waitForFinish(p); - - assertEquals(Status.FINISHED, p.getStatus()); - Iterator formIter = p.settings.getForms().keySet().iterator(); - assert(formIter.next().equals("my_input")); - assert(formIter.next().equals("my_select")); - assert(formIter.next().equals("my_checkbox")); - } -} diff --git a/smart-zeppelin/zeppelin-server/src/test/java/org/apache/zeppelin/security/SecurityUtilsTest.java b/smart-zeppelin/zeppelin-server/src/test/java/org/apache/zeppelin/security/SecurityUtilsTest.java deleted file mode 100644 index 9d902c8099a..00000000000 --- a/smart-zeppelin/zeppelin-server/src/test/java/org/apache/zeppelin/security/SecurityUtilsTest.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.zeppelin.security; - -import static org.junit.Assert.*; -import org.apache.commons.configuration.ConfigurationException; -import org.apache.zeppelin.conf.ZeppelinConfiguration; -import org.apache.zeppelin.utils.SecurityUtils; -import org.junit.Test; - -import java.net.URISyntaxException; -import java.net.UnknownHostException; -import java.net.InetAddress; - - -public class SecurityUtilsTest { - - @Test - public void isInvalid() throws URISyntaxException, UnknownHostException { - assertFalse(SecurityUtils.isValidOrigin("http://127.0.1.1", ZeppelinConfiguration.create())); - } - - @Test - public void isInvalidFromConfig() throws URISyntaxException, UnknownHostException, ConfigurationException { - assertFalse(SecurityUtils.isValidOrigin("http://otherinvalidhost.com", - new ZeppelinConfiguration(this.getClass().getResource("/zeppelin-site.xml")))); - } - - @Test - public void isLocalhost() throws URISyntaxException, UnknownHostException { - assertTrue(SecurityUtils.isValidOrigin("http://localhost", ZeppelinConfiguration.create())); - } - - @Test - public void isLocalMachine() throws URISyntaxException, UnknownHostException { - String origin = "http://" + InetAddress.getLocalHost().getHostName(); - assertTrue("Origin " + origin + " is not allowed. Please check your hostname.", - SecurityUtils.isValidOrigin(origin, ZeppelinConfiguration.create())); - } - - @Test - public void isValidFromConfig() throws URISyntaxException, UnknownHostException, ConfigurationException { - assertTrue(SecurityUtils.isValidOrigin("http://otherhost.com", - new ZeppelinConfiguration(this.getClass().getResource("/zeppelin-site.xml")))); - } - - @Test - public void isValidFromStar() throws URISyntaxException, UnknownHostException, ConfigurationException { - assertTrue(SecurityUtils.isValidOrigin("http://anyhost.com", - new ZeppelinConfiguration(this.getClass().getResource("/zeppelin-site-star.xml")))); - } - - @Test - public void nullOrigin() throws URISyntaxException, UnknownHostException, ConfigurationException { - assertFalse(SecurityUtils.isValidOrigin(null, - new ZeppelinConfiguration(this.getClass().getResource("/zeppelin-site.xml")))); - } - - @Test - public void nullOriginWithStar() throws URISyntaxException, UnknownHostException, ConfigurationException { - assertTrue(SecurityUtils.isValidOrigin(null, - new ZeppelinConfiguration(this.getClass().getResource("/zeppelin-site-star.xml")))); - } - - @Test - public void emptyOrigin() throws URISyntaxException, UnknownHostException, ConfigurationException { - assertFalse(SecurityUtils.isValidOrigin("", - new ZeppelinConfiguration(this.getClass().getResource("/zeppelin-site.xml")))); - } - - @Test - public void notAURIOrigin() throws URISyntaxException, UnknownHostException, ConfigurationException { - assertFalse(SecurityUtils.isValidOrigin("test123", - new ZeppelinConfiguration(this.getClass().getResource("/zeppelin-site.xml")))); - } -} diff --git a/smart-zeppelin/zeppelin-server/src/test/java/org/apache/zeppelin/server/CorsFilterTest.java b/smart-zeppelin/zeppelin-server/src/test/java/org/apache/zeppelin/server/CorsFilterTest.java deleted file mode 100644 index df2a6e92e0d..00000000000 --- a/smart-zeppelin/zeppelin-server/src/test/java/org/apache/zeppelin/server/CorsFilterTest.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.zeppelin.server; - -import org.junit.Assert; -import org.junit.Test; -import org.mockito.invocation.InvocationOnMock; -import org.mockito.stubbing.Answer; - -import javax.servlet.FilterChain; -import javax.servlet.ServletException; -import javax.servlet.http.HttpServletRequest; -import javax.servlet.http.HttpServletResponse; - -import java.io.IOException; - -import static org.mockito.Matchers.anyString; -import static org.mockito.Mockito.*; - -/** - * Basic CORS REST API tests - */ -public class CorsFilterTest { - - public static String[] headers = new String[8]; - public static Integer count = 0; - - @Test - @SuppressWarnings("rawtypes") - public void ValidCorsFilterTest() throws IOException, ServletException { - CorsFilter filter = new CorsFilter(); - HttpServletResponse mockResponse = mock(HttpServletResponse.class); - FilterChain mockedFilterChain = mock(FilterChain.class); - HttpServletRequest mockRequest = mock(HttpServletRequest.class); - when(mockRequest.getHeader("Origin")).thenReturn("http://localhost:8080"); - when(mockRequest.getMethod()).thenReturn("Empty"); - when(mockRequest.getServerName()).thenReturn("localhost"); - count = 0; - - doAnswer(new Answer() { - @Override - public Object answer(InvocationOnMock invocationOnMock) throws Throwable { - headers[count] = invocationOnMock.getArguments()[1].toString(); - count++; - return null; - } - }).when(mockResponse).addHeader(anyString(), anyString()); - - filter.doFilter(mockRequest, mockResponse, mockedFilterChain); - Assert.assertTrue(headers[0].equals("http://localhost:8080")); - } - - @Test - @SuppressWarnings("rawtypes") - public void InvalidCorsFilterTest() throws IOException, ServletException { - CorsFilter filter = new CorsFilter(); - HttpServletResponse mockResponse = mock(HttpServletResponse.class); - FilterChain mockedFilterChain = mock(FilterChain.class); - HttpServletRequest mockRequest = mock(HttpServletRequest.class); - when(mockRequest.getHeader("Origin")).thenReturn("http://evillocalhost:8080"); - when(mockRequest.getMethod()).thenReturn("Empty"); - when(mockRequest.getServerName()).thenReturn("evillocalhost"); - - doAnswer(new Answer() { - @Override - public Object answer(InvocationOnMock invocationOnMock) throws Throwable { - headers[count] = invocationOnMock.getArguments()[1].toString(); - count++; - return null; - } - }).when(mockResponse).addHeader(anyString(), anyString()); - - filter.doFilter(mockRequest, mockResponse, mockedFilterChain); - Assert.assertTrue(headers[0].equals("")); - } -} diff --git a/smart-zeppelin/zeppelin-server/src/test/java/org/apache/zeppelin/socket/NotebookServerTest.java b/smart-zeppelin/zeppelin-server/src/test/java/org/apache/zeppelin/socket/NotebookServerTest.java deleted file mode 100644 index c339140419e..00000000000 --- a/smart-zeppelin/zeppelin-server/src/test/java/org/apache/zeppelin/socket/NotebookServerTest.java +++ /dev/null @@ -1,412 +0,0 @@ -/* - * Licensed to the Apache Software Foundation (ASF) under one or more - * contributor license agreements. See the NOTICE file distributed with - * this work for additional information regarding copyright ownership. - * The ASF licenses this file to You under the Apache License, Version 2.0 - * (the "License"); you may not use this file except in compliance with - * the License. You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT 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.zeppelin.socket; - -import com.google.gson.Gson; - -import org.apache.zeppelin.display.AngularObject; -import org.apache.zeppelin.display.AngularObjectBuilder; -import org.apache.zeppelin.display.AngularObjectRegistry; -import org.apache.zeppelin.interpreter.InterpreterGroup; -import org.apache.zeppelin.interpreter.InterpreterSetting; -import org.apache.zeppelin.interpreter.remote.RemoteAngularObjectRegistry; -import org.apache.zeppelin.notebook.Note; -import org.apache.zeppelin.notebook.Notebook; -import org.apache.zeppelin.notebook.Paragraph; -import org.apache.zeppelin.notebook.socket.Message; -import org.apache.zeppelin.notebook.socket.Message.OP; -import org.apache.zeppelin.rest.AbstractTestRestApi; -import org.apache.zeppelin.server.ZeppelinServer; -import org.apache.zeppelin.user.AuthenticationInfo; -import org.junit.AfterClass; -import org.junit.Before; -import org.junit.BeforeClass; -import org.junit.Test; - -import javax.servlet.http.HttpServletRequest; - -import java.io.IOException; -import java.net.InetAddress; -import java.net.UnknownHostException; -import java.util.HashSet; -import java.util.List; - -import static java.util.Arrays.asList; -import static org.junit.Assert.*; -import static org.mockito.Mockito.*; - - -/** - * Basic REST API tests for notebookServer - */ -public class NotebookServerTest extends AbstractTestRestApi { - private static Notebook notebook; - private static NotebookServer notebookServer; - private static Gson gson; - private HttpServletRequest mockRequest; - private AuthenticationInfo anonymous; - - @BeforeClass - public static void init() throws Exception { - AbstractTestRestApi.startUp(); - gson = new Gson(); - notebook = ZeppelinServer.notebook; - notebookServer = ZeppelinServer.notebookWsServer; - } - - @AfterClass - public static void destroy() throws Exception { - AbstractTestRestApi.shutDown(); - } - - @Before - public void setUp() { - mockRequest = mock(HttpServletRequest.class); - anonymous = new AuthenticationInfo("anonymous"); - } - - @Test - public void checkOrigin() throws UnknownHostException { - NotebookServer server = new NotebookServer(); - String origin = "http://" + InetAddress.getLocalHost().getHostName() + ":8080"; - - assertTrue("Origin " + origin + " is not allowed. Please check your hostname.", - server.checkOrigin(mockRequest, origin)); - } - - @Test - public void checkInvalidOrigin(){ - NotebookServer server = new NotebookServer(); - assertFalse(server.checkOrigin(mockRequest, "http://evillocalhost:8080")); - } - - @Test - public void testMakeSureNoAngularObjectBroadcastToWebsocketWhoFireTheEvent() throws IOException { - // create a notebook - Note note1 = notebook.createNote(anonymous); - - // get reference to interpreterGroup - InterpreterGroup interpreterGroup = null; - List settings = notebook.getInterpreterSettingManager().getInterpreterSettings(note1.getId()); - for (InterpreterSetting setting : settings) { - if (setting.getName().equals("md")) { - interpreterGroup = setting.getInterpreterGroup("anonymous", "sharedProcess"); - break; - } - } - - // start interpreter process - Paragraph p1 = note1.addParagraph(AuthenticationInfo.ANONYMOUS); - p1.setText("%md start remote interpreter process"); - p1.setAuthenticationInfo(anonymous); - note1.run(p1.getId()); - - // add angularObject - interpreterGroup.getAngularObjectRegistry().add("object1", "value1", note1.getId(), null); - - // create two sockets and open it - NotebookSocket sock1 = createWebSocket(); - NotebookSocket sock2 = createWebSocket(); - - assertEquals(sock1, sock1); - assertNotEquals(sock1, sock2); - - notebookServer.onOpen(sock1); - notebookServer.onOpen(sock2); - verify(sock1, times(0)).send(anyString()); // getNote, getAngularObject - // open the same notebook from sockets - notebookServer.onMessage(sock1, gson.toJson(new Message(OP.GET_NOTE).put("id", note1.getId()))); - notebookServer.onMessage(sock2, gson.toJson(new Message(OP.GET_NOTE).put("id", note1.getId()))); - - reset(sock1); - reset(sock2); - - // update object from sock1 - notebookServer.onMessage(sock1, gson.toJson( - new Message(OP.ANGULAR_OBJECT_UPDATED) - .put("noteId", note1.getId()) - .put("name", "object1") - .put("value", "value1") - .put("interpreterGroupId", interpreterGroup.getId()))); - - - // expect object is broadcasted except for where the update is created - verify(sock1, times(0)).send(anyString()); - verify(sock2, times(1)).send(anyString()); - - notebook.removeNote(note1.getId(), anonymous); - } - - @Test - public void testImportNotebook() throws IOException { - String msg = "{\"op\":\"IMPORT_NOTE\",\"data\":" + - "{\"note\":{\"paragraphs\": [{\"text\": \"Test " + - "paragraphs import\",\"config\":{},\"settings\":{}}]," + - "\"name\": \"Test Zeppelin notebook import\",\"config\": " + - "{}}}}"; - Message messageReceived = notebookServer.deserializeMessage(msg); - Note note = null; - try { - note = notebookServer.importNote(null, null, notebook, messageReceived); - } catch (NullPointerException e) { - //broadcastNoteList(); failed nothing to worry. - LOG.error("Exception in NotebookServerTest while testImportNotebook, failed nothing to " + - "worry ", e); - } - - assertNotEquals(null, notebook.getNote(note.getId())); - assertEquals("Test Zeppelin notebook import", notebook.getNote(note.getId()).getName()); - assertEquals("Test paragraphs import", notebook.getNote(note.getId()).getParagraphs().get(0).getText()); - notebook.removeNote(note.getId(), anonymous); - } - - @Test - public void bindAngularObjectToRemoteForParagraphs() throws Exception { - //Given - final String varName = "name"; - final String value = "DuyHai DOAN"; - final Message messageReceived = new Message(OP.ANGULAR_OBJECT_CLIENT_BIND) - .put("noteId", "noteId") - .put("name", varName) - .put("value", value) - .put("paragraphId", "paragraphId"); - - final NotebookServer server = new NotebookServer(); - final Notebook notebook = mock(Notebook.class); - final Note note = mock(Note.class, RETURNS_DEEP_STUBS); - - when(notebook.getNote("noteId")).thenReturn(note); - final Paragraph paragraph = mock(Paragraph.class, RETURNS_DEEP_STUBS); - when(note.getParagraph("paragraphId")).thenReturn(paragraph); - - - final RemoteAngularObjectRegistry mdRegistry = mock(RemoteAngularObjectRegistry.class); - final InterpreterGroup mdGroup = new InterpreterGroup("mdGroup"); - mdGroup.setAngularObjectRegistry(mdRegistry); - - when(paragraph.getCurrentRepl().getInterpreterGroup()).thenReturn(mdGroup); - - final AngularObject ao1 = AngularObjectBuilder.build(varName, value, "noteId", "paragraphId"); - - when(mdRegistry.addAndNotifyRemoteProcess(varName, value, "noteId", "paragraphId")).thenReturn(ao1); - - NotebookSocket conn = mock(NotebookSocket.class); - NotebookSocket otherConn = mock(NotebookSocket.class); - - final String mdMsg1 = server.serializeMessage(new Message(OP.ANGULAR_OBJECT_UPDATE) - .put("angularObject", ao1) - .put("interpreterGroupId", "mdGroup") - .put("noteId", "noteId") - .put("paragraphId", "paragraphId")); - - server.noteSocketMap.put("noteId", asList(conn, otherConn)); - - // When - server.angularObjectClientBind(conn, new HashSet(), notebook, messageReceived); - - // Then - verify(mdRegistry, never()).addAndNotifyRemoteProcess(varName, value, "noteId", null); - - verify(otherConn).send(mdMsg1); - } - - @Test - public void bindAngularObjectToLocalForParagraphs() throws Exception { - //Given - final String varName = "name"; - final String value = "DuyHai DOAN"; - final Message messageReceived = new Message(OP.ANGULAR_OBJECT_CLIENT_BIND) - .put("noteId", "noteId") - .put("name", varName) - .put("value", value) - .put("paragraphId", "paragraphId"); - - final NotebookServer server = new NotebookServer(); - final Notebook notebook = mock(Notebook.class); - final Note note = mock(Note.class, RETURNS_DEEP_STUBS); - when(notebook.getNote("noteId")).thenReturn(note); - final Paragraph paragraph = mock(Paragraph.class, RETURNS_DEEP_STUBS); - when(note.getParagraph("paragraphId")).thenReturn(paragraph); - - final AngularObjectRegistry mdRegistry = mock(AngularObjectRegistry.class); - final InterpreterGroup mdGroup = new InterpreterGroup("mdGroup"); - mdGroup.setAngularObjectRegistry(mdRegistry); - - when(paragraph.getCurrentRepl().getInterpreterGroup()).thenReturn(mdGroup); - - - final AngularObject ao1 = AngularObjectBuilder.build(varName, value, "noteId", "paragraphId"); - - when(mdRegistry.add(varName, value, "noteId", "paragraphId")).thenReturn(ao1); - - NotebookSocket conn = mock(NotebookSocket.class); - NotebookSocket otherConn = mock(NotebookSocket.class); - - final String mdMsg1 = server.serializeMessage(new Message(OP.ANGULAR_OBJECT_UPDATE) - .put("angularObject", ao1) - .put("interpreterGroupId", "mdGroup") - .put("noteId", "noteId") - .put("paragraphId", "paragraphId")); - - server.noteSocketMap.put("noteId", asList(conn, otherConn)); - - // When - server.angularObjectClientBind(conn, new HashSet(), notebook, messageReceived); - - // Then - verify(otherConn).send(mdMsg1); - } - - @Test - public void unbindAngularObjectFromRemoteForParagraphs() throws Exception { - //Given - final String varName = "name"; - final String value = "val"; - final Message messageReceived = new Message(OP.ANGULAR_OBJECT_CLIENT_UNBIND) - .put("noteId", "noteId") - .put("name", varName) - .put("paragraphId", "paragraphId"); - - final NotebookServer server = new NotebookServer(); - final Notebook notebook = mock(Notebook.class); - final Note note = mock(Note.class, RETURNS_DEEP_STUBS); - when(notebook.getNote("noteId")).thenReturn(note); - final Paragraph paragraph = mock(Paragraph.class, RETURNS_DEEP_STUBS); - when(note.getParagraph("paragraphId")).thenReturn(paragraph); - - final RemoteAngularObjectRegistry mdRegistry = mock(RemoteAngularObjectRegistry.class); - final InterpreterGroup mdGroup = new InterpreterGroup("mdGroup"); - mdGroup.setAngularObjectRegistry(mdRegistry); - - when(paragraph.getCurrentRepl().getInterpreterGroup()).thenReturn(mdGroup); - - final AngularObject ao1 = AngularObjectBuilder.build(varName, value, "noteId", "paragraphId"); - when(mdRegistry.removeAndNotifyRemoteProcess(varName, "noteId", "paragraphId")).thenReturn(ao1); - NotebookSocket conn = mock(NotebookSocket.class); - NotebookSocket otherConn = mock(NotebookSocket.class); - - final String mdMsg1 = server.serializeMessage(new Message(OP.ANGULAR_OBJECT_REMOVE) - .put("angularObject", ao1) - .put("interpreterGroupId", "mdGroup") - .put("noteId", "noteId") - .put("paragraphId", "paragraphId")); - - server.noteSocketMap.put("noteId", asList(conn, otherConn)); - - // When - server.angularObjectClientUnbind(conn, new HashSet(), notebook, messageReceived); - - // Then - verify(mdRegistry, never()).removeAndNotifyRemoteProcess(varName, "noteId", null); - - verify(otherConn).send(mdMsg1); - } - - @Test - public void unbindAngularObjectFromLocalForParagraphs() throws Exception { - //Given - final String varName = "name"; - final String value = "val"; - final Message messageReceived = new Message(OP.ANGULAR_OBJECT_CLIENT_UNBIND) - .put("noteId", "noteId") - .put("name", varName) - .put("paragraphId", "paragraphId"); - - final NotebookServer server = new NotebookServer(); - final Notebook notebook = mock(Notebook.class); - final Note note = mock(Note.class, RETURNS_DEEP_STUBS); - when(notebook.getNote("noteId")).thenReturn(note); - final Paragraph paragraph = mock(Paragraph.class, RETURNS_DEEP_STUBS); - when(note.getParagraph("paragraphId")).thenReturn(paragraph); - - final AngularObjectRegistry mdRegistry = mock(AngularObjectRegistry.class); - final InterpreterGroup mdGroup = new InterpreterGroup("mdGroup"); - mdGroup.setAngularObjectRegistry(mdRegistry); - - when(paragraph.getCurrentRepl().getInterpreterGroup()).thenReturn(mdGroup); - - final AngularObject ao1 = AngularObjectBuilder.build(varName, value, "noteId", "paragraphId"); - - when(mdRegistry.remove(varName, "noteId", "paragraphId")).thenReturn(ao1); - - NotebookSocket conn = mock(NotebookSocket.class); - NotebookSocket otherConn = mock(NotebookSocket.class); - - final String mdMsg1 = server.serializeMessage(new Message(OP.ANGULAR_OBJECT_REMOVE) - .put("angularObject", ao1) - .put("interpreterGroupId", "mdGroup") - .put("noteId", "noteId") - .put("paragraphId", "paragraphId")); - server.noteSocketMap.put("noteId", asList(conn, otherConn)); - - // When - server.angularObjectClientUnbind(conn, new HashSet(), notebook, messageReceived); - - // Then - verify(otherConn).send(mdMsg1); - } - - @Test - public void testCreateNoteWithDefaultInterpreterId() throws IOException { - // create two sockets and open it - NotebookSocket sock1 = createWebSocket(); - NotebookSocket sock2 = createWebSocket(); - - assertEquals(sock1, sock1); - assertNotEquals(sock1, sock2); - - notebookServer.onOpen(sock1); - notebookServer.onOpen(sock2); - - String noteName = "Note with millis " + System.currentTimeMillis(); - String defaultInterpreterId = ""; - List settings = notebook.getInterpreterSettingManager().get(); - if (settings.size() > 1) { - defaultInterpreterId = settings.get(1).getId(); - } - // create note from sock1 - notebookServer.onMessage(sock1, gson.toJson( - new Message(OP.NEW_NOTE) - .put("name", noteName) - .put("defaultInterpreterId", defaultInterpreterId))); - - // expect the events are broadcasted properly - verify(sock1, times(2)).send(anyString()); - - Note createdNote = null; - for (Note note : notebook.getAllNotes()) { - if (note.getName().equals(noteName)) { - createdNote = note; - break; - } - } - - if (settings.size() > 1) { - assertEquals(notebook.getInterpreterSettingManager().getDefaultInterpreterSetting( - createdNote.getId()).getId(), defaultInterpreterId); - } - notebook.removeNote(createdNote.getId(), anonymous); - } - - private NotebookSocket createWebSocket() { - NotebookSocket sock = mock(NotebookSocket.class); - when(sock.getRequest()).thenReturn(mockRequest); - return sock; - } - -} - diff --git a/smart-zeppelin/zeppelin-server/src/test/java/org/apache/zeppelin/ticket/TicketContainerTest.java b/smart-zeppelin/zeppelin-server/src/test/java/org/apache/zeppelin/ticket/TicketContainerTest.java deleted file mode 100644 index 91d2cb3af20..00000000000 --- a/smart-zeppelin/zeppelin-server/src/test/java/org/apache/zeppelin/ticket/TicketContainerTest.java +++ /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. - */ - -package org.apache.zeppelin.ticket; - -import org.junit.Before; -import org.junit.Test; - -import java.net.UnknownHostException; - -import static org.junit.Assert.assertFalse; -import static org.junit.Assert.assertTrue; - -public class TicketContainerTest { - private TicketContainer container; - - @Before - public void setUp() throws Exception { - container = TicketContainer.instance; - } - - @Test - public void isValidAnonymous() throws UnknownHostException { - boolean ok = container.isValid("anonymous", "anonymous"); - assertTrue(ok); - } - - @Test - public void isValidExistingPrincipal() throws UnknownHostException { - String ticket = container.getTicket("someuser1"); - boolean ok = container.isValid("someuser1", ticket); - assertTrue(ok); - } - - @Test - public void isValidNonExistingPrincipal() throws UnknownHostException { - boolean ok = container.isValid("unknownuser", "someticket"); - assertFalse(ok); - } - - @Test - public void isValidunkownTicket() throws UnknownHostException { - String ticket = container.getTicket("someuser2"); - boolean ok = container.isValid("someuser2", ticket+"makeitinvalid"); - assertFalse(ok); - } -} - diff --git a/smart-zeppelin/zeppelin-server/src/test/resources/log4j.properties b/smart-zeppelin/zeppelin-server/src/test/resources/log4j.properties deleted file mode 100644 index 041daf02dbd..00000000000 --- a/smart-zeppelin/zeppelin-server/src/test/resources/log4j.properties +++ /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. -# - -# Direct log messages to stdout -log4j.appender.stdout=org.apache.log4j.ConsoleAppender -log4j.appender.stdout.Target=System.out -log4j.appender.stdout.layout=org.apache.log4j.PatternLayout -log4j.appender.stdout.layout.ConversionPattern=%d{ABSOLUTE} %5p %c:%L - %m%n -#log4j.appender.stdout.layout.ConversionPattern= -#%5p [%t] (%F:%L) - %m%n -#%-4r [%t] %-5p %c %x - %m%n -# - -# Root logger option -log4j.rootLogger=INFO, stdout - -#mute some noisy guys -log4j.logger.org.apache.hadoop.mapred=WARN -log4j.logger.org.apache.hadoop.hive.ql=WARN -log4j.logger.org.apache.hadoop.hive.metastore=WARN -log4j.logger.org.apache.haadoop.hive.service.HiveServer=WARN -log4j.logger.org.apache.zeppelin.scheduler=WARN - -log4j.logger.org.quartz=WARN -log4j.logger.DataNucleus=WARN -log4j.logger.DataNucleus.MetaData=ERROR -log4j.logger.DataNucleus.Datastore=ERROR - -# Log all JDBC parameters -log4j.logger.org.hibernate.type=ALL - -log4j.logger.org.apache.zeppelin.interpreter=DEBUG \ No newline at end of file diff --git a/smart-zeppelin/zeppelin-server/src/test/resources/zeppelin-site-star.xml b/smart-zeppelin/zeppelin-server/src/test/resources/zeppelin-site-star.xml deleted file mode 100644 index 93dc0ed327b..00000000000 --- a/smart-zeppelin/zeppelin-server/src/test/resources/zeppelin-site-star.xml +++ /dev/null @@ -1,157 +0,0 @@ - - - - - - - - zeppelin.server.addr - 0.0.0.0 - Server address - - - - zeppelin.server.port - 8080 - Server port. - - - - zeppelin.notebook.dir - notebook - path or URI for notebook persist - - - - zeppelin.notebook.homescreen - - id of notebook to be displayed in homescreen. ex) 2A94M5J1Z Empty value displays default home screen - - - - zeppelin.notebook.homescreen.hide - false - hide homescreen notebook from list when this value set to true - - - - - - - - zeppelin.notebook.storage - org.apache.zeppelin.notebook.repo.VFSNotebookRepo - notebook persistence layer implementation - - - - zeppelin.interpreter.dir - interpreter - Interpreter implementation base directory - - - - zeppelin.interpreter.connect.timeout - 30000 - Interpreter process connect timeout in msec. - - - - - zeppelin.ssl - false - Should SSL be used by the servers? - - - - zeppelin.ssl.client.auth - false - Should client authentication be used for SSL connections? - - - - zeppelin.ssl.keystore.path - keystore - Path to keystore relative to Zeppelin configuration directory - - - - zeppelin.ssl.keystore.type - JKS - The format of the given keystore (e.g. JKS or PKCS12) - - - - zeppelin.ssl.keystore.password - change me - Keystore password. Can be obfuscated by the Jetty Password tool - - - - - - zeppelin.ssl.truststore.path - truststore - Path to truststore relative to Zeppelin configuration directory. Defaults to the keystore path - - - - zeppelin.ssl.truststore.type - JKS - The format of the given truststore (e.g. JKS or PKCS12). Defaults to the same type as the keystore type - - - - zeppelin.server.allowed.origins - * - Allowed sources for REST and WebSocket requests. - - - - - diff --git a/smart-zeppelin/zeppelin-server/src/test/resources/zeppelin-site.xml b/smart-zeppelin/zeppelin-server/src/test/resources/zeppelin-site.xml deleted file mode 100644 index 3215c5b3b17..00000000000 --- a/smart-zeppelin/zeppelin-server/src/test/resources/zeppelin-site.xml +++ /dev/null @@ -1,157 +0,0 @@ - - - - - - - - zeppelin.server.addr - 0.0.0.0 - Server address - - - - zeppelin.server.port - 8080 - Server port. - - - - zeppelin.notebook.dir - notebook - path or URI for notebook persist - - - - zeppelin.notebook.homescreen - - id of notebook to be displayed in homescreen. ex) 2A94M5J1Z Empty value displays default home screen - - - - zeppelin.notebook.homescreen.hide - false - hide homescreen notebook from list when this value set to true - - - - - - - - zeppelin.notebook.storage - org.apache.zeppelin.notebook.repo.VFSNotebookRepo - notebook persistence layer implementation - - - - zeppelin.interpreter.dir - interpreter - Interpreter implementation base directory - - - - zeppelin.interpreter.connect.timeout - 30000 - Interpreter process connect timeout in msec. - - - - - zeppelin.ssl - false - Should SSL be used by the servers? - - - - zeppelin.ssl.client.auth - false - Should client authentication be used for SSL connections? - - - - zeppelin.ssl.keystore.path - keystore - Path to keystore relative to Zeppelin configuration directory - - - - zeppelin.ssl.keystore.type - JKS - The format of the given keystore (e.g. JKS or PKCS12) - - - - zeppelin.ssl.keystore.password - change me - Keystore password. Can be obfuscated by the Jetty Password tool - - - - - - zeppelin.ssl.truststore.path - truststore - Path to truststore relative to Zeppelin configuration directory. Defaults to the keystore path - - - - zeppelin.ssl.truststore.type - JKS - The format of the given truststore (e.g. JKS or PKCS12). Defaults to the same type as the keystore type - - - - zeppelin.server.allowed.origins - http://onehost:8080,http://otherhost.com, - Allowed sources for REST and WebSocket requests. - - - - - diff --git a/smart-zeppelin/zeppelin-server/src/test/scala/org/apache/zeppelin/AbstractFunctionalSuite.scala b/smart-zeppelin/zeppelin-server/src/test/scala/org/apache/zeppelin/AbstractFunctionalSuite.scala deleted file mode 100644 index 2f773c6fddc..00000000000 --- a/smart-zeppelin/zeppelin-server/src/test/scala/org/apache/zeppelin/AbstractFunctionalSuite.scala +++ /dev/null @@ -1,84 +0,0 @@ -/* - * Licensed to the Apache Software Foundation (ASF) under one or more - * contributor license agreements. See the NOTICE file distributed with - * this work for additional information regarding copyright ownership. - * The ASF licenses this file to You under the Apache License, Version 2.0 - * (the "License"); you may not use this file except in compliance with - * the License. You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT 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.zeppelin - -import org.apache.zeppelin.AbstractFunctionalSuite.SERVER_ADDRESS -import org.openqa.selenium.WebDriver -import org.openqa.selenium.chrome.ChromeDriver -import org.openqa.selenium.firefox.{FirefoxBinary, FirefoxDriver, FirefoxProfile} -import org.openqa.selenium.safari.SafariDriver -import org.scalatest.concurrent.Eventually._ -import org.scalatest.time._ -import org.scalatest.selenium.WebBrowser -import org.scalatest.{BeforeAndAfterAll, FunSuite, Suite} - -import scala.sys.process._ -import scala.util.Try - -object AbstractFunctionalSuite { - val SERVER_ADDRESS = "http://localhost:8080" -} - -class AbstractFunctionalSuite extends FunSuite with WebBrowser with BeforeAndAfterAll { - - implicit val webDriver = getDriver() - - override def beforeAll() = { - "../bin/zeppelin-daemon.sh start" ! - - eventually (timeout(Span(180, Seconds))) { - go to SERVER_ADDRESS - assert(find("welcome").isDefined) - } - } - - override def nestedSuites = - List[Suite](new WelcomePageSuite).toIndexedSeq - - override def afterAll() = { - "../bin/zeppelin-daemon.sh stop" ! - - webDriver.close() - } - - def getDriver(): WebDriver = { - val possibleDrivers = List[() => WebDriver](safari, chrome, firefox) - val createdDriver = possibleDrivers.map(driverFactory => Try(driverFactory.apply())).find(_.isSuccess) - createdDriver match { - case Some(driver) => driver.get - case None => throw new RuntimeException("Could not initialize any driver") - } - } - - def safari(): WebDriver = { - new SafariDriver() - } - - def chrome(): WebDriver = { - new ChromeDriver() - } - - def firefox(): WebDriver = { - val ffox: FirefoxBinary = new FirefoxBinary - if ("true" == System.getenv("TRAVIS")) { - ffox.setEnvironmentProperty("DISPLAY", ":99") - } - val profile: FirefoxProfile = new FirefoxProfile - new FirefoxDriver(ffox, profile) - } -} diff --git a/smart-zeppelin/zeppelin-web/src/app/dashboard/views/actions/actions.js b/smart-zeppelin/zeppelin-web/src/app/dashboard/views/actions/actions.js index 859e0070926..e3bcaf831ba 100644 --- a/smart-zeppelin/zeppelin-web/src/app/dashboard/views/actions/actions.js +++ b/smart-zeppelin/zeppelin-web/src/app/dashboard/views/actions/actions.js @@ -108,11 +108,11 @@ angular.module('zeppelinWebApp') actions0.$subscribe($scope, function (actions) { updateTable(actions); }); - +/* $(function () { $("[data-toggle='tooltip']").tooltip({ container: body }); - }); + });*/ } diff --git a/smart-zeppelin/zeppelin-web/src/app/notebook/notebook-actionBar.html b/smart-zeppelin/zeppelin-web/src/app/notebook/notebook-actionBar.html index 71ad299e475..cd935b2c263 100644 --- a/smart-zeppelin/zeppelin-web/src/app/notebook/notebook-actionBar.html +++ b/smart-zeppelin/zeppelin-web/src/app/notebook/notebook-actionBar.html @@ -22,14 +22,14 @@

- + --> - + -->
@@ -249,12 +247,12 @@

tooltip-placement="bottom" uib-tooltip="List of shortcut"> - - + -->

-
-
-

Settings

-
-
-
-
Interpreter binding
-

- Bind interpreter for this note. - Click to Bind/Unbind interpreter. - Drag and drop to reorder interpreters.
- The first interpreter on the list becomes default. To create/remove interpreters, go to Interpreter menu. -

-
-
-
- - -   -
- {{item.name}} - - - , - %{{item.name}}.{{intp.name}} - (default) - - -
-
-
-
-
-
-
- - -
-
diff --git a/smart-zeppelin/zeppelin-web/src/components/navbar/navbar.html b/smart-zeppelin/zeppelin-web/src/components/navbar/navbar.html index 5107780821a..4c3cd5c4c45 100644 --- a/smart-zeppelin/zeppelin-web/src/components/navbar/navbar.html +++ b/smart-zeppelin/zeppelin-web/src/components/navbar/navbar.html @@ -18,35 +18,16 @@ - + - Smart + Smart Manager