From 2f8b139642fa84b0b0644d9bb40804ad1521350d Mon Sep 17 00:00:00 2001 From: Ryan Doherty Date: Mon, 16 Oct 2023 21:30:58 -0400 Subject: [PATCH 1/5] Factor build tracking into a general WDK feature and add to reporters --- Model/lib/rng/wdkModel.rng | 17 ++++++--- .../org/gusdb/wdk/model/BuildTracking.java | 38 +++++++++++++++++++ .../gusdb/wdk/model/question/Question.java | 29 +++----------- .../gusdb/wdk/model/report/ReporterRef.java | 33 +++++++++++++++- .../formatter/RecordClassFormatter.java | 4 +- 5 files changed, 90 insertions(+), 31 deletions(-) create mode 100644 Model/src/main/java/org/gusdb/wdk/model/BuildTracking.java diff --git a/Model/lib/rng/wdkModel.rng b/Model/lib/rng/wdkModel.rng index 4b226cd9e4..aba16e5280 100644 --- a/Model/lib/rng/wdkModel.rng +++ b/Model/lib/rng/wdkModel.rng @@ -1383,6 +1383,7 @@ + @@ -1400,6 +1401,15 @@ + + + + + + + + + @@ -1430,12 +1440,7 @@ - - - - - - + diff --git a/Model/src/main/java/org/gusdb/wdk/model/BuildTracking.java b/Model/src/main/java/org/gusdb/wdk/model/BuildTracking.java new file mode 100644 index 0000000000..4e7178aeaa --- /dev/null +++ b/Model/src/main/java/org/gusdb/wdk/model/BuildTracking.java @@ -0,0 +1,38 @@ +package org.gusdb.wdk.model; + +public interface BuildTracking { + + WdkModel getWdkModel(); + + String getNewBuild(); + + void setNewBuild(String newBuild); + + String getReviseBuild(); + + void setReviseBuild(String reviseBuild); + + /** + * @return if the object is newly introduced in the current build + */ + default boolean isNew() { + return buildMatches(getNewBuild()); + } + + /** + * @return if the object is revised in the current build + */ + default boolean isRevised() { + return buildMatches(getReviseBuild()); + } + + default boolean buildMatches(String trackedBuild) { + String currentBuild = getWdkModel().getBuildNumber(); + if (currentBuild == null) + return false; // current release is not set + else + return currentBuild.equals(trackedBuild); + + } + +} diff --git a/Model/src/main/java/org/gusdb/wdk/model/question/Question.java b/Model/src/main/java/org/gusdb/wdk/model/question/Question.java index 335c9b4389..59d9d3a39b 100644 --- a/Model/src/main/java/org/gusdb/wdk/model/question/Question.java +++ b/Model/src/main/java/org/gusdb/wdk/model/question/Question.java @@ -20,6 +20,7 @@ import org.gusdb.fgputil.Named; import org.gusdb.fgputil.Named.NamedObject; import org.gusdb.fgputil.functional.Functions; +import org.gusdb.wdk.model.BuildTracking; import org.gusdb.wdk.model.Utilities; import org.gusdb.wdk.model.WdkModel; import org.gusdb.wdk.model.WdkModelBase; @@ -65,7 +66,7 @@ * @version $Revision$ $Date: 2007-01-10 14:54:53 -0500 (Wed, 10 Jan * 2007) $ $Author$ */ -public class Question extends WdkModelBase implements AttributeFieldContainer, StepAnalysisContainer, NamedObject { +public class Question extends WdkModelBase implements AttributeFieldContainer, StepAnalysisContainer, NamedObject, BuildTracking { public static final String DYNAMIC_QUERY_SUFFIX = "_dynamic"; @@ -214,44 +215,26 @@ protected static String getInternalQuestionName(String prefix, RecordClass recor return prefix + recordClass.getFullName().replace('.', '_'); } + @Override public String getNewBuild() { return _newBuild; } + @Override public void setNewBuild(String newBuild) { _newBuild = newBuild; } + @Override public String getReviseBuild() { return _reviseBuild; } + @Override public void setReviseBuild(String reviseBuild) { _reviseBuild = reviseBuild; } - /** - * @return if the question a newly introduced in the current build. - */ - public boolean isNew() { - String currentBuild = _wdkModel.getBuildNumber(); - if (currentBuild == null) - return false; // current release is not set - else - return (currentBuild.equals(_newBuild)); - } - - /** - * @return if the question is revised in the current build. - */ - public boolean isRevised() { - String currentBuild = _wdkModel.getBuildNumber(); - if (currentBuild == null) - return false; // current release is not set - else - return (currentBuild.equals(_reviseBuild)); - } - public void addSuggestion(QuestionSuggestion suggestion) { _suggestions.add(suggestion); } diff --git a/Model/src/main/java/org/gusdb/wdk/model/report/ReporterRef.java b/Model/src/main/java/org/gusdb/wdk/model/report/ReporterRef.java index 6252f1e344..df7b278bf6 100644 --- a/Model/src/main/java/org/gusdb/wdk/model/report/ReporterRef.java +++ b/Model/src/main/java/org/gusdb/wdk/model/report/ReporterRef.java @@ -8,6 +8,7 @@ import java.util.Map; import org.apache.log4j.Logger; +import org.gusdb.wdk.model.BuildTracking; import org.gusdb.wdk.model.RngAnnotations.RngOptional; import org.gusdb.wdk.model.RngAnnotations.RngUndefined; import org.gusdb.wdk.model.WdkModel; @@ -24,7 +25,7 @@ * @author xingao * */ -public class ReporterRef extends WdkModelBase implements ScopedField, PropertiesProvider { +public class ReporterRef extends WdkModelBase implements ScopedField, PropertiesProvider, BuildTracking { private static final Logger LOG = Logger.getLogger(ReporterRef.class); @@ -37,6 +38,16 @@ public class ReporterRef extends WdkModelBase implements ScopedField, Properties private List _propertyList = new ArrayList<>(); private Map _properties = new LinkedHashMap<>(); + /** + * new build flag on what build this question is introduced. + */ + private String _newBuild; + + /** + * revise build flag on what build this question is revised. + */ + private String _reviseBuild; + @Override public WdkModel getWdkModel() { return _wdkModel; @@ -150,6 +161,26 @@ public String getDescription() { return (_description == null ? _displayName : _description); } + @Override + public String getNewBuild() { + return _newBuild; + } + + @Override + public void setNewBuild(String newBuild) { + _newBuild = newBuild; + } + + @Override + public String getReviseBuild() { + return _reviseBuild; + } + + @Override + public void setReviseBuild(String reviseBuild) { + _reviseBuild = reviseBuild; + } + public void addProperty(WdkModelText property) { _propertyList.add(property); } diff --git a/Service/src/main/java/org/gusdb/wdk/service/formatter/RecordClassFormatter.java b/Service/src/main/java/org/gusdb/wdk/service/formatter/RecordClassFormatter.java index f4cdab4701..6ffdb41b02 100644 --- a/Service/src/main/java/org/gusdb/wdk/service/formatter/RecordClassFormatter.java +++ b/Service/src/main/java/org/gusdb/wdk/service/formatter/RecordClassFormatter.java @@ -96,7 +96,9 @@ public static JSONArray getAnswerFormatsJson(Collection r .put(JsonKeys.DISPLAY_NAME, reporter.getDisplayName()) .put(JsonKeys.DESCRIPTION, reporter.getDescription()) .put(JsonKeys.IS_IN_REPORT, FieldScope.REPORT_MAKER.isFieldInScope(reporter)) - .put(JsonKeys.SCOPES, reporter.getScopesList()); + .put(JsonKeys.SCOPES, reporter.getScopesList()) + .put(JsonKeys.NEW_BUILD, reporter.getNewBuild()) + .put(JsonKeys.REVISE_BUILD, reporter.getReviseBuild()); array.put(obj); } } From 0dcc99038eb4281255d2aae49a05bbec72a2d87c Mon Sep 17 00:00:00 2001 From: Ryan Doherty Date: Mon, 16 Oct 2023 22:33:14 -0400 Subject: [PATCH 2/5] Add RNG annotations --- Model/src/main/java/org/gusdb/wdk/model/BuildTracking.java | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/Model/src/main/java/org/gusdb/wdk/model/BuildTracking.java b/Model/src/main/java/org/gusdb/wdk/model/BuildTracking.java index 4e7178aeaa..e601f94a54 100644 --- a/Model/src/main/java/org/gusdb/wdk/model/BuildTracking.java +++ b/Model/src/main/java/org/gusdb/wdk/model/BuildTracking.java @@ -1,15 +1,19 @@ package org.gusdb.wdk.model; +import org.gusdb.wdk.model.RngAnnotations.RngOptional; + public interface BuildTracking { WdkModel getWdkModel(); String getNewBuild(); + @RngOptional void setNewBuild(String newBuild); String getReviseBuild(); + @RngOptional void setReviseBuild(String reviseBuild); /** From 2dcdcecbd97a4a1a1e79f97c8e6a1c6db82abca0 Mon Sep 17 00:00:00 2001 From: Ryan Doherty Date: Mon, 16 Oct 2023 22:57:40 -0400 Subject: [PATCH 3/5] Try RNG annotations again --- Model/src/main/java/org/gusdb/wdk/model/BuildTracking.java | 4 ---- .../src/main/java/org/gusdb/wdk/model/report/ReporterRef.java | 2 ++ 2 files changed, 2 insertions(+), 4 deletions(-) diff --git a/Model/src/main/java/org/gusdb/wdk/model/BuildTracking.java b/Model/src/main/java/org/gusdb/wdk/model/BuildTracking.java index e601f94a54..4e7178aeaa 100644 --- a/Model/src/main/java/org/gusdb/wdk/model/BuildTracking.java +++ b/Model/src/main/java/org/gusdb/wdk/model/BuildTracking.java @@ -1,19 +1,15 @@ package org.gusdb.wdk.model; -import org.gusdb.wdk.model.RngAnnotations.RngOptional; - public interface BuildTracking { WdkModel getWdkModel(); String getNewBuild(); - @RngOptional void setNewBuild(String newBuild); String getReviseBuild(); - @RngOptional void setReviseBuild(String reviseBuild); /** diff --git a/Model/src/main/java/org/gusdb/wdk/model/report/ReporterRef.java b/Model/src/main/java/org/gusdb/wdk/model/report/ReporterRef.java index df7b278bf6..15968d4fe3 100644 --- a/Model/src/main/java/org/gusdb/wdk/model/report/ReporterRef.java +++ b/Model/src/main/java/org/gusdb/wdk/model/report/ReporterRef.java @@ -167,6 +167,7 @@ public String getNewBuild() { } @Override + @RngOptional public void setNewBuild(String newBuild) { _newBuild = newBuild; } @@ -177,6 +178,7 @@ public String getReviseBuild() { } @Override + @RngOptional public void setReviseBuild(String reviseBuild) { _reviseBuild = reviseBuild; } From c1275d367513898f59513406e80e6a800ac3b475 Mon Sep 17 00:00:00 2001 From: Ryan Doherty Date: Mon, 16 Oct 2023 23:59:04 -0400 Subject: [PATCH 4/5] Fix JSON schema for new attrs --- Service/doc/schema/wdk/includes/record-reporter.json | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/Service/doc/schema/wdk/includes/record-reporter.json b/Service/doc/schema/wdk/includes/record-reporter.json index 725c2c04e8..2fc0b471b2 100644 --- a/Service/doc/schema/wdk/includes/record-reporter.json +++ b/Service/doc/schema/wdk/includes/record-reporter.json @@ -26,6 +26,12 @@ }, "type": { "type": "string" + }, + "newBuild": { + "type": "string" + }, + "reviseBuild": { + "type": "string" } }, "required": [ From 299202b0823a2be7f084da2cd51c851b82e6f4a8 Mon Sep 17 00:00:00 2001 From: Ryan Doherty Date: Tue, 17 Oct 2023 11:46:04 -0400 Subject: [PATCH 5/5] Don't replace empty description with display name; allows client to hide '?' icon --- .../model/report/DynamicAttributeReporterReference.java | 8 ++++---- .../main/java/org/gusdb/wdk/model/report/ReporterRef.java | 2 +- 2 files changed, 5 insertions(+), 5 deletions(-) diff --git a/Model/src/main/java/org/gusdb/wdk/model/report/DynamicAttributeReporterReference.java b/Model/src/main/java/org/gusdb/wdk/model/report/DynamicAttributeReporterReference.java index b6e501687a..3d03e0dbcc 100644 --- a/Model/src/main/java/org/gusdb/wdk/model/report/DynamicAttributeReporterReference.java +++ b/Model/src/main/java/org/gusdb/wdk/model/report/DynamicAttributeReporterReference.java @@ -98,9 +98,9 @@ public void setPluginProperties(String pluginProperties) throws WdkModelExceptio public boolean hasAllDynamicFields() { return ( getName() != null && - getDisplayName() != null && - getDescription() != null && - getImplementation() != null + getDisplayName() != null && + //getDescription() != null && // description is allowed to be null + getImplementation() != null ); } @@ -109,7 +109,7 @@ public String getDynamicFieldsAsString() { String propsPrint = properties == null ? null : prettyPrint(properties, FormatUtil.Style.MULTI_LINE); return new StringBuilder("{").append(NL) .append("name: ").append(getName()).append(NL) - .append("displayName: ").append(getDisplayName()).append(NL) + .append("displayName: ").append(getDisplayName()).append(NL) .append("description: ").append(getDescription()).append(NL) .append("implementation: ").append(getImplementation()).append(NL) .append("properties: ").append(propsPrint).append(NL) diff --git a/Model/src/main/java/org/gusdb/wdk/model/report/ReporterRef.java b/Model/src/main/java/org/gusdb/wdk/model/report/ReporterRef.java index 15968d4fe3..40da13bc14 100644 --- a/Model/src/main/java/org/gusdb/wdk/model/report/ReporterRef.java +++ b/Model/src/main/java/org/gusdb/wdk/model/report/ReporterRef.java @@ -158,7 +158,7 @@ public void setDescription(WdkModelText description) { } public String getDescription() { - return (_description == null ? _displayName : _description); + return _description; } @Override