You are viewing a plain text version of this content. The canonical link for it is here.
Posted to commits@zeppelin.apache.org by ah...@apache.org on 2017/04/04 06:08:10 UTC

zeppelin git commit: ZEPPELIN-2189. The order of dynamic forms should be the order that you create them

Repository: zeppelin
Updated Branches:
  refs/heads/master 53a28a3a9 -> d4085468d


ZEPPELIN-2189. The order of dynamic forms should be the order that you create them

### What is this PR for?
The order of dynamic forms should be the order that you create them. So I made the following 2 changes for this:
* change the type of forms in GUI from TreeMap to LinkedHashMap
*  remove orderBy in paragraph-parameterizedQueryForm.html

Besides, I also did some code refactoring.

### What type of PR is it?
[Bug Fix | Improvement | Refactoring]

### Todos
* [ ] - Task

### What is the Jira issue?
* https://issues.apache.org/jira/browse/ZEPPELIN-2189

### How should this be tested?
Tested manually.

### Screenshots (if appropriate)
Before
![2017-02-27_1310](https://cloud.githubusercontent.com/assets/164491/24486826/9ac3c1e4-153e-11e7-8280-8cf4f6ef7560.png)

After
![2017-03-30_1109](https://cloud.githubusercontent.com/assets/164491/24486828/9b733ee4-153e-11e7-9a13-44ed71aa29d8.png)

### Questions:
* Does the licenses files need update?
* Is there breaking changes for older versions?
* Does this needs documentation?

Author: Jeff Zhang <zj...@apache.org>

Closes #2204 from zjffdu/ZEPPELIN-2189 and squashes the following commits:

a69ab5a [Jeff Zhang] add test
167d162 [Jeff Zhang] fix code style
369900e [Jeff Zhang] ZEPPELIN-2189. The order of dynamic forms should be the order that you create them


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

Branch: refs/heads/master
Commit: d4085468d09a869ff42fa92e053c3bce49829a36
Parents: 53a28a3
Author: Jeff Zhang <zj...@apache.org>
Authored: Fri Mar 31 10:36:39 2017 +0800
Committer: ahyoungryu <ah...@apache.org>
Committed: Tue Apr 4 15:08:04 2017 +0900

----------------------------------------------------------------------
 .../java/org/apache/zeppelin/display/GUI.java   | 14 ++++-------
 .../java/org/apache/zeppelin/display/Input.java | 22 ++++++-----------
 .../org/apache/zeppelin/display/InputTest.java  | 12 ++++-----
 .../zeppelin/rest/ZeppelinSparkClusterTest.java | 26 ++++++++++++++++++++
 .../paragraph-parameterizedQueryForm.html       |  2 +-
 .../java/org/apache/zeppelin/notebook/Note.java | 10 +++-----
 .../org/apache/zeppelin/notebook/Paragraph.java |  6 ++---
 7 files changed, 52 insertions(+), 40 deletions(-)
----------------------------------------------------------------------


http://git-wip-us.apache.org/repos/asf/zeppelin/blob/d4085468/zeppelin-interpreter/src/main/java/org/apache/zeppelin/display/GUI.java
----------------------------------------------------------------------
diff --git a/zeppelin-interpreter/src/main/java/org/apache/zeppelin/display/GUI.java b/zeppelin-interpreter/src/main/java/org/apache/zeppelin/display/GUI.java
index 27640de..30a8ba7 100644
--- a/zeppelin-interpreter/src/main/java/org/apache/zeppelin/display/GUI.java
+++ b/zeppelin-interpreter/src/main/java/org/apache/zeppelin/display/GUI.java
@@ -19,11 +19,7 @@ package org.apache.zeppelin.display;
 
 import java.io.Serializable;
 
-import java.util.Collection;
-import java.util.HashMap;
-import java.util.LinkedList;
-import java.util.Map;
-import java.util.TreeMap;
+import java.util.*;
 
 import org.apache.zeppelin.display.Input.ParamOption;
 
@@ -33,7 +29,7 @@ import org.apache.zeppelin.display.Input.ParamOption;
 public class GUI implements Serializable {
 
   Map<String, Object> params = new HashMap<>(); // form parameters from client
-  Map<String, Input> forms = new TreeMap<>(); // form configuration
+  LinkedHashMap<String, Input> forms = new LinkedHashMap<>(); // form configuration
 
   public GUI() {
 
@@ -47,11 +43,11 @@ public class GUI implements Serializable {
     return params;
   }
 
-  public Map<String, Input> getForms() {
+  public LinkedHashMap<String, Input> getForms() {
     return forms;
   }
 
-  public void setForms(Map<String, Input> forms) {
+  public void setForms(LinkedHashMap<String, Input> forms) {
     this.forms = forms;
   }
 
@@ -105,6 +101,6 @@ public class GUI implements Serializable {
   }
 
   public void clear() {
-    this.forms = new TreeMap<>();
+    this.forms = new LinkedHashMap<>();
   }
 }

http://git-wip-us.apache.org/repos/asf/zeppelin/blob/d4085468/zeppelin-interpreter/src/main/java/org/apache/zeppelin/display/Input.java
----------------------------------------------------------------------
diff --git a/zeppelin-interpreter/src/main/java/org/apache/zeppelin/display/Input.java b/zeppelin-interpreter/src/main/java/org/apache/zeppelin/display/Input.java
index 9736230..4924b2b 100644
--- a/zeppelin-interpreter/src/main/java/org/apache/zeppelin/display/Input.java
+++ b/zeppelin-interpreter/src/main/java/org/apache/zeppelin/display/Input.java
@@ -20,13 +20,7 @@ package org.apache.zeppelin.display;
 import org.apache.commons.lang.StringUtils;
 
 import java.io.Serializable;
-import java.util.ArrayList;
-import java.util.Arrays;
-import java.util.Collection;
-import java.util.HashMap;
-import java.util.LinkedList;
-import java.util.List;
-import java.util.Map;
+import java.util.*;
 import java.util.regex.Matcher;
 import java.util.regex.Pattern;
 
@@ -291,21 +285,21 @@ public class Input implements Serializable {
     return new Input(varName, displayName, type, arg, defaultValue, paramOptions, hidden);
   }
 
-  public static Map<String, Input> extractSimpleQueryParam(String script) {
-    Map<String, Input> params = new HashMap<>();
+  public static LinkedHashMap<String, Input> extractSimpleQueryForm(String script) {
+    LinkedHashMap<String, Input> forms = new LinkedHashMap<>();
     if (script == null) {
-      return params;
+      return forms;
     }
     String replaced = script;
 
     Matcher match = VAR_PTN.matcher(replaced);
     while (match.find()) {
-      Input param = getInputForm(match);
-      params.put(param.name, param);
+      Input form = getInputForm(match);
+      forms.put(form.name, form);
     }
 
-    params.remove("pql");
-    return params;
+    forms.remove("pql");
+    return forms;
   }
 
   private static final String DEFAULT_DELIMITER = ",";

http://git-wip-us.apache.org/repos/asf/zeppelin/blob/d4085468/zeppelin-interpreter/src/test/java/org/apache/zeppelin/display/InputTest.java
----------------------------------------------------------------------
diff --git a/zeppelin-interpreter/src/test/java/org/apache/zeppelin/display/InputTest.java b/zeppelin-interpreter/src/test/java/org/apache/zeppelin/display/InputTest.java
index 4dd16ee..b6f1e3e 100644
--- a/zeppelin-interpreter/src/test/java/org/apache/zeppelin/display/InputTest.java
+++ b/zeppelin-interpreter/src/test/java/org/apache/zeppelin/display/InputTest.java
@@ -44,7 +44,7 @@ public class InputTest {
 	public void testFormExtraction() {
 		// input form
 		String script = "${input_form=}";
-		Map<String, Input> forms = Input.extractSimpleQueryParam(script);
+		Map<String, Input> forms = Input.extractSimpleQueryForm(script);
 		assertEquals(1, forms.size());
 		Input form = forms.get("input_form");
 		assertEquals("input_form", form.name);
@@ -54,13 +54,13 @@ public class InputTest {
 
 		// input form with display name & default value
 		script = "${input_form(Input Form)=xxx}";
-		forms = Input.extractSimpleQueryParam(script);
+		forms = Input.extractSimpleQueryForm(script);
 		form = forms.get("input_form");
 		assertEquals("xxx", form.defaultValue);
 
 		// selection form
 		script = "${select_form(Selection Form)=op1,op1|op2(Option 2)|op3}";
-		form = Input.extractSimpleQueryParam(script).get("select_form");
+		form = Input.extractSimpleQueryForm(script).get("select_form");
 		assertEquals("select_form", form.name);
 		assertEquals("op1", form.defaultValue);
 		assertArrayEquals(new ParamOption[]{new ParamOption("op1", null),
@@ -68,7 +68,7 @@ public class InputTest {
 
 		// checkbox form
 		script = "${checkbox:checkbox_form=op1,op1|op2|op3}";
-		form = Input.extractSimpleQueryParam(script).get("checkbox_form");
+		form = Input.extractSimpleQueryForm(script).get("checkbox_form");
 		assertEquals("checkbox_form", form.name);
 		assertEquals("checkbox", form.type);
 		assertArrayEquals(new Object[]{"op1"}, (Object[]) form.defaultValue);
@@ -77,7 +77,7 @@ public class InputTest {
 
 		// checkbox form with multiple default checks
 		script = "${checkbox:checkbox_form(Checkbox Form)=op1|op3,op1(Option 1)|op2|op3}";
-		form = Input.extractSimpleQueryParam(script).get("checkbox_form");
+		form = Input.extractSimpleQueryForm(script).get("checkbox_form");
 		assertEquals("checkbox_form", form.name);
 		assertEquals("Checkbox Form", form.displayName);
 		assertEquals("checkbox", form.type);
@@ -87,7 +87,7 @@ public class InputTest {
 
 		// checkbox form with no default check
 		script = "${checkbox:checkbox_form(Checkbox Form)=,op1(Option 1)|op2(Option 2)|op3(Option 3)}";
-		form = Input.extractSimpleQueryParam(script).get("checkbox_form");
+		form = Input.extractSimpleQueryForm(script).get("checkbox_form");
 		assertEquals("checkbox_form", form.name);
 		assertEquals("Checkbox Form", form.displayName);
 		assertEquals("checkbox", form.type);

http://git-wip-us.apache.org/repos/asf/zeppelin/blob/d4085468/zeppelin-server/src/test/java/org/apache/zeppelin/rest/ZeppelinSparkClusterTest.java
----------------------------------------------------------------------
diff --git a/zeppelin-server/src/test/java/org/apache/zeppelin/rest/ZeppelinSparkClusterTest.java b/zeppelin-server/src/test/java/org/apache/zeppelin/rest/ZeppelinSparkClusterTest.java
index 7c790b3..9bcdbfa 100644
--- a/zeppelin-server/src/test/java/org/apache/zeppelin/rest/ZeppelinSparkClusterTest.java
+++ b/zeppelin-server/src/test/java/org/apache/zeppelin/rest/ZeppelinSparkClusterTest.java
@@ -22,6 +22,7 @@ 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;
 
@@ -480,4 +481,29 @@ public class ZeppelinSparkClusterTest extends AbstractTestRestApi {
         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<String> formIter = p.settings.getForms().keySet().iterator();
+        assert(formIter.next().equals("my_input"));
+        assert(formIter.next().equals("my_select"));
+        assert(formIter.next().equals("my_checkbox"));
+    }
 }

http://git-wip-us.apache.org/repos/asf/zeppelin/blob/d4085468/zeppelin-web/src/app/notebook/paragraph/paragraph-parameterizedQueryForm.html
----------------------------------------------------------------------
diff --git a/zeppelin-web/src/app/notebook/paragraph/paragraph-parameterizedQueryForm.html b/zeppelin-web/src/app/notebook/paragraph/paragraph-parameterizedQueryForm.html
index 5d5f477..64da3cf 100644
--- a/zeppelin-web/src/app/notebook/paragraph/paragraph-parameterizedQueryForm.html
+++ b/zeppelin-web/src/app/notebook/paragraph/paragraph-parameterizedQueryForm.html
@@ -15,7 +15,7 @@ limitations under the License.
       ng-show="!paragraph.config.tableHide"
       class=" paragraphForm form-horizontal row">
   <div class="form-group col-sm-6 col-md-6 col-lg-4"
-       ng-repeat="formulaire in paragraph.settings.forms | toArray | orderBy:'name.toString()'"
+       ng-repeat="formulaire in paragraph.settings.forms | toArray"
        ng-init="loadForm(formulaire, paragraph.settings.params)">
     <label class="control-label input-sm" ng-class="{'disable': paragraph.status == 'RUNNING' || paragraph.status == 'PENDING' }">{{formulaire.name}}</label>
     <div>

http://git-wip-us.apache.org/repos/asf/zeppelin/blob/d4085468/zeppelin-zengine/src/main/java/org/apache/zeppelin/notebook/Note.java
----------------------------------------------------------------------
diff --git a/zeppelin-zengine/src/main/java/org/apache/zeppelin/notebook/Note.java b/zeppelin-zengine/src/main/java/org/apache/zeppelin/notebook/Note.java
index 0463c6b..dd2c094 100644
--- a/zeppelin-zengine/src/main/java/org/apache/zeppelin/notebook/Note.java
+++ b/zeppelin-zengine/src/main/java/org/apache/zeppelin/notebook/Note.java
@@ -21,11 +21,7 @@ import static java.lang.String.format;
 
 import java.io.IOException;
 import java.io.Serializable;
-import java.util.HashMap;
-import java.util.Iterator;
-import java.util.LinkedList;
-import java.util.List;
-import java.util.Map;
+import java.util.*;
 import java.util.concurrent.ScheduledFuture;
 import java.util.concurrent.ScheduledThreadPoolExecutor;
 import java.util.concurrent.TimeUnit;
@@ -320,8 +316,8 @@ public class Note implements Serializable, ParagraphJobListener {
         interpreterSettingManager);
 
     Map<String, Object> config = new HashMap<>(srcParagraph.getConfig());
-    Map<String, Object> param = new HashMap<>(srcParagraph.settings.getParams());
-    Map<String, Input> form = new HashMap<>(srcParagraph.settings.getForms());
+    Map<String, Object> param = srcParagraph.settings.getParams();
+    LinkedHashMap<String, Input> form = srcParagraph.settings.getForms();
 
     newParagraph.setConfig(config);
     newParagraph.settings.setParams(param);

http://git-wip-us.apache.org/repos/asf/zeppelin/blob/d4085468/zeppelin-zengine/src/main/java/org/apache/zeppelin/notebook/Paragraph.java
----------------------------------------------------------------------
diff --git a/zeppelin-zengine/src/main/java/org/apache/zeppelin/notebook/Paragraph.java b/zeppelin-zengine/src/main/java/org/apache/zeppelin/notebook/Paragraph.java
index f5cf15d..894fd19 100644
--- a/zeppelin-zengine/src/main/java/org/apache/zeppelin/notebook/Paragraph.java
+++ b/zeppelin-zengine/src/main/java/org/apache/zeppelin/notebook/Paragraph.java
@@ -139,7 +139,7 @@ public class Paragraph extends Job implements Serializable, Cloneable {
   public Paragraph cloneParagraphForUser(String user) {
     Paragraph p = new Paragraph();
     p.settings.setParams(Maps.newHashMap(settings.getParams()));
-    p.settings.setForms(Maps.newHashMap(settings.getForms()));
+    p.settings.setForms(Maps.newLinkedHashMap(settings.getForms()));
     p.setConfig(Maps.newHashMap(config));
     p.setTitle(getTitle());
     p.setText(getText());
@@ -389,8 +389,8 @@ public class Paragraph extends Job implements Serializable, Cloneable {
       settings.clear();
     } else if (repl.getFormType() == FormType.SIMPLE) {
       String scriptBody = getScriptBody();
-      Map<String, Input> inputs = Input.extractSimpleQueryParam(scriptBody); // inputs will be built
-      // from script body
+      // inputs will be built from script body
+      LinkedHashMap<String, Input> inputs = Input.extractSimpleQueryForm(scriptBody);
 
       final AngularObjectRegistry angularRegistry =
           repl.getInterpreterGroup().getAngularObjectRegistry();