fixes for testing

This commit is contained in:
anhefti 2019-04-08 21:42:37 +02:00
parent 7afa633a3c
commit cee8e27fe2

View file

@ -37,6 +37,7 @@ import ch.ethz.seb.sebserver.gbl.util.Utils;
import ch.ethz.seb.sebserver.gui.service.remote.webservice.api.FormBinding; import ch.ethz.seb.sebserver.gui.service.remote.webservice.api.FormBinding;
import ch.ethz.seb.sebserver.gui.widget.ImageUpload; import ch.ethz.seb.sebserver.gui.widget.ImageUpload;
import ch.ethz.seb.sebserver.gui.widget.Selection; import ch.ethz.seb.sebserver.gui.widget.Selection;
import ch.ethz.seb.sebserver.gui.widget.Selection.Type;
import ch.ethz.seb.sebserver.gui.widget.ThresholdList; import ch.ethz.seb.sebserver.gui.widget.ThresholdList;
public final class Form implements FormBinding { public final class Form implements FormBinding {
@ -70,11 +71,26 @@ public final class Form implements FormBinding {
appendFormUrlEncodedValue(buffer, entry.getKey(), entry.getValue()); appendFormUrlEncodedValue(buffer, entry.getKey(), entry.getValue());
} }
for (final Map.Entry<String, List<FormFieldAccessor>> entry : this.formFields.entrySet()) { this.formFields.entrySet()
entry.getValue() .stream()
.stream() .forEach(entry -> {
.forEach(ffa -> appendFormUrlEncodedValue(buffer, entry.getKey(), ffa.getStringValue())); entry.getValue()
} .stream()
.forEach(ffa -> {
if (ffa.listValue) {
appendFormUrlEncodedValue(
buffer,
entry.getKey(),
ffa.getStringValue());
} else {
appendFormUrlEncodedSingleValue(
buffer,
entry.getKey(),
ffa.getStringValue(),
false);
}
});
});
return buffer.toString(); return buffer.toString();
} }
@ -212,7 +228,11 @@ public final class Form implements FormBinding {
final Selection selection, final Selection selection,
final BiConsumer<Tuple<String>, ObjectNode> jsonValueAdapter) { final BiConsumer<Tuple<String>, ObjectNode> jsonValueAdapter) {
return new FormFieldAccessor(label, selection.adaptToControl(), jsonValueAdapter) { return new FormFieldAccessor(
label,
selection.adaptToControl(),
jsonValueAdapter,
selection.type() != Type.SINGLE) {
@Override public String getStringValue() { return selection.getSelectionValue(); } @Override public String getStringValue() { return selection.getSelectionValue(); }
}; };
} }
@ -246,39 +266,53 @@ public final class Form implements FormBinding {
* Checks first if the value String is a comma separated list. If true, splits values * Checks first if the value String is a comma separated list. If true, splits values
* and adds every value within the same name mapping to the string buffer * and adds every value within the same name mapping to the string buffer
*/ */
private static void appendFormUrlEncodedValue(final StringBuffer buffer, final String name, final String value) { private static void appendFormUrlEncodedValue(
final StringBuffer buffer,
final String name,
final String value) {
if (StringUtils.isBlank(value)) { if (StringUtils.isBlank(value)) {
return; return;
} }
final String[] split = StringUtils.split(value, Constants.LIST_SEPARATOR_CHAR); final String[] split = StringUtils.split(value, Constants.LIST_SEPARATOR_CHAR);
for (int i = 0; i < split.length; i++) { for (int i = 0; i < split.length; i++) {
if (StringUtils.isBlank(split[i])) { appendFormUrlEncodedSingleValue(buffer, name, split[i], true);
continue; }
} }
if (buffer.length() > 0) { private static void appendFormUrlEncodedSingleValue(
buffer.append(Constants.FORM_URL_ENCODED_SEPARATOR); final StringBuffer buffer,
} final String name,
final String value,
final boolean checkMultiValue) {
// check of the string value is a name-value pair. If true, use the specified name an value if (StringUtils.isBlank(value)) {
// otherwise use the general name given within this method call and return;
if (split[i].contains(Constants.FORM_URL_ENCODED_NAME_VALUE_SEPARATOR)) { }
final String[] nameValue = StringUtils.split(split[i], Constants.FORM_URL_ENCODED_NAME_VALUE_SEPARATOR);
buffer.append(nameValue[0]) if (buffer.length() > 0) {
.append(Constants.FORM_URL_ENCODED_NAME_VALUE_SEPARATOR) buffer.append(Constants.FORM_URL_ENCODED_SEPARATOR);
.append(Utils.encodeFormURL_UTF_8(nameValue[1])); }
} else {
buffer.append(name) // check of the string value is a name-value pair. If true, use the specified name an value
.append(Constants.FORM_URL_ENCODED_NAME_VALUE_SEPARATOR) // otherwise use the general name given within this method call and
.append(Utils.encodeFormURL_UTF_8(split[i])); if (checkMultiValue && value.contains(Constants.FORM_URL_ENCODED_NAME_VALUE_SEPARATOR)) {
} final String[] nameValue = StringUtils.split(value, Constants.FORM_URL_ENCODED_NAME_VALUE_SEPARATOR);
buffer.append(nameValue[0])
.append(Constants.FORM_URL_ENCODED_NAME_VALUE_SEPARATOR)
.append(Utils.encodeFormURL_UTF_8(nameValue[1]));
} else {
buffer.append(name)
.append(Constants.FORM_URL_ENCODED_NAME_VALUE_SEPARATOR)
.append(Utils.encodeFormURL_UTF_8(value));
} }
} }
private static final void adaptCommaSeparatedStringToJsonArray( private static final void adaptCommaSeparatedStringToJsonArray(
final Tuple<String> tuple, final Tuple<String> tuple,
final ObjectNode jsonNode) { final ObjectNode jsonNode) {
if (StringUtils.isNoneBlank(tuple._2)) { if (StringUtils.isNoneBlank(tuple._2)) {
final ArrayNode arrayNode = jsonNode.putArray(tuple._1); final ArrayNode arrayNode = jsonNode.putArray(tuple._1);
final String[] split = StringUtils.split(tuple._2, Constants.LIST_SEPARATOR); final String[] split = StringUtils.split(tuple._2, Constants.LIST_SEPARATOR);
@ -294,15 +328,17 @@ public final class Form implements FormBinding {
public final Control control; public final Control control;
private final BiConsumer<Tuple<String>, ObjectNode> jsonValueAdapter; private final BiConsumer<Tuple<String>, ObjectNode> jsonValueAdapter;
private boolean hasError; private boolean hasError;
private final boolean listValue;
FormFieldAccessor(final Label label, final Control control) { FormFieldAccessor(final Label label, final Control control) {
this(label, control, null); this(label, control, null, false);
} }
FormFieldAccessor( FormFieldAccessor(
final Label label, final Label label,
final Control control, final Control control,
final BiConsumer<Tuple<String>, ObjectNode> jsonValueAdapter) { final BiConsumer<Tuple<String>, ObjectNode> jsonValueAdapter,
final boolean listValue) {
this.label = label; this.label = label;
this.control = control; this.control = control;
@ -315,6 +351,7 @@ public final class Form implements FormBinding {
} }
}; };
} }
this.listValue = listValue;
} }
public abstract String getStringValue(); public abstract String getStringValue();