Merge branch 'issue/1588' of https://github.com/OpenRefine/OpenRefine into issue/1588-2
This commit is contained in:
commit
f58d963dbd
@ -33,8 +33,7 @@ OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|||||||
|
|
||||||
package com.google.refine.browsing.filters;
|
package com.google.refine.browsing.filters;
|
||||||
|
|
||||||
import java.util.Calendar;
|
import java.time.OffsetDateTime;
|
||||||
import java.util.Date;
|
|
||||||
|
|
||||||
import com.google.refine.browsing.util.RowEvaluable;
|
import com.google.refine.browsing.util.RowEvaluable;
|
||||||
import com.google.refine.expr.ExpressionUtils;
|
import com.google.refine.expr.ExpressionUtils;
|
||||||
@ -67,11 +66,8 @@ abstract public class ExpressionTimeComparisonRowFilter extends ExpressionNumber
|
|||||||
if (ExpressionUtils.isError(v)) {
|
if (ExpressionUtils.isError(v)) {
|
||||||
return _selectError;
|
return _selectError;
|
||||||
} else if (ExpressionUtils.isNonBlankData(v)) {
|
} else if (ExpressionUtils.isNonBlankData(v)) {
|
||||||
if (v instanceof Date) {
|
if (v instanceof OffsetDateTime) {
|
||||||
long time = ((Date) v).getTime();
|
long time = ((OffsetDateTime) v).toInstant().toEpochMilli();
|
||||||
return _selectTime && checkValue(time);
|
|
||||||
} else if (v instanceof Calendar) {
|
|
||||||
long time = ((Calendar) v).getTime().getTime();
|
|
||||||
return _selectTime && checkValue(time);
|
return _selectTime && checkValue(time);
|
||||||
} else {
|
} else {
|
||||||
return _selectNonTime;
|
return _selectNonTime;
|
||||||
|
@ -33,9 +33,8 @@ OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|||||||
|
|
||||||
package com.google.refine.browsing.util;
|
package com.google.refine.browsing.util;
|
||||||
|
|
||||||
import java.util.Calendar;
|
import java.time.OffsetDateTime;
|
||||||
import java.util.Collection;
|
import java.util.Collection;
|
||||||
import java.util.Date;
|
|
||||||
import java.util.Properties;
|
import java.util.Properties;
|
||||||
|
|
||||||
import com.google.refine.browsing.RecordVisitor;
|
import com.google.refine.browsing.RecordVisitor;
|
||||||
@ -162,12 +161,8 @@ public class ExpressionTimeValueBinner implements RowVisitor, RecordVisitor {
|
|||||||
if (ExpressionUtils.isError(value)) {
|
if (ExpressionUtils.isError(value)) {
|
||||||
hasError = true;
|
hasError = true;
|
||||||
} else if (ExpressionUtils.isNonBlankData(value)) {
|
} else if (ExpressionUtils.isNonBlankData(value)) {
|
||||||
if (value instanceof Calendar) {
|
if (value instanceof OffsetDateTime) {
|
||||||
value = ((Calendar) value).getTime();
|
long t = ((OffsetDateTime) value).toInstant().toEpochMilli();
|
||||||
}
|
|
||||||
|
|
||||||
if (value instanceof Date) {
|
|
||||||
long t = ((Date) value).getTime();
|
|
||||||
hasTime = true;
|
hasTime = true;
|
||||||
|
|
||||||
int bin = (int) Math.floor((double) (t - _index.getMin()) / (double) _index.getStep());
|
int bin = (int) Math.floor((double) (t - _index.getMin()) / (double) _index.getStep());
|
||||||
|
@ -33,10 +33,9 @@ OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|||||||
|
|
||||||
package com.google.refine.browsing.util;
|
package com.google.refine.browsing.util;
|
||||||
|
|
||||||
|
import java.time.OffsetDateTime;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.Calendar;
|
|
||||||
import java.util.Collection;
|
import java.util.Collection;
|
||||||
import java.util.Date;
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Properties;
|
import java.util.Properties;
|
||||||
|
|
||||||
@ -181,13 +180,9 @@ abstract public class TimeBinIndex {
|
|||||||
if (ExpressionUtils.isError(v)) {
|
if (ExpressionUtils.isError(v)) {
|
||||||
_hasError = true;
|
_hasError = true;
|
||||||
} else if (ExpressionUtils.isNonBlankData(v)) {
|
} else if (ExpressionUtils.isNonBlankData(v)) {
|
||||||
if (v instanceof Calendar) {
|
if (v instanceof OffsetDateTime) {
|
||||||
v = ((Calendar) v).getTime();
|
|
||||||
}
|
|
||||||
|
|
||||||
if (v instanceof Date) {
|
|
||||||
_hasTime = true;
|
_hasTime = true;
|
||||||
processValue(((Date) v).getTime(), allValues);
|
processValue(((OffsetDateTime) v).toInstant().toEpochMilli(), allValues);
|
||||||
} else {
|
} else {
|
||||||
_hasNonTime = true;
|
_hasNonTime = true;
|
||||||
}
|
}
|
||||||
@ -202,13 +197,9 @@ abstract public class TimeBinIndex {
|
|||||||
if (ExpressionUtils.isError(v)) {
|
if (ExpressionUtils.isError(v)) {
|
||||||
_hasError = true;
|
_hasError = true;
|
||||||
} else if (ExpressionUtils.isNonBlankData(v)) {
|
} else if (ExpressionUtils.isNonBlankData(v)) {
|
||||||
if (v instanceof Calendar) {
|
if (v instanceof OffsetDateTime) {
|
||||||
v = ((Calendar) v).getTime();
|
|
||||||
}
|
|
||||||
|
|
||||||
if (v instanceof Date) {
|
|
||||||
_hasTime = true;
|
_hasTime = true;
|
||||||
processValue(((Date) v).getTime(), allValues);
|
processValue(((OffsetDateTime) v).toInstant().toEpochMilli(), allValues);
|
||||||
} else {
|
} else {
|
||||||
_hasNonTime = true;
|
_hasNonTime = true;
|
||||||
}
|
}
|
||||||
@ -219,13 +210,9 @@ abstract public class TimeBinIndex {
|
|||||||
} else {
|
} else {
|
||||||
_totalValueCount++;
|
_totalValueCount++;
|
||||||
|
|
||||||
if (value instanceof Calendar) {
|
if (value instanceof OffsetDateTime) {
|
||||||
value = ((Calendar) value).getTime();
|
|
||||||
}
|
|
||||||
|
|
||||||
if (value instanceof Date) {
|
|
||||||
_hasTime = true;
|
_hasTime = true;
|
||||||
processValue(((Date) value).getTime(), allValues);
|
processValue(((OffsetDateTime) value).toInstant().toEpochMilli(), allValues);
|
||||||
} else {
|
} else {
|
||||||
_hasNonTime = true;
|
_hasNonTime = true;
|
||||||
}
|
}
|
||||||
|
@ -35,10 +35,7 @@ package com.google.refine.commands.expr;
|
|||||||
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.io.Serializable;
|
import java.io.Serializable;
|
||||||
import java.time.LocalDateTime;
|
|
||||||
import java.time.ZoneId;
|
|
||||||
import java.time.OffsetDateTime;
|
import java.time.OffsetDateTime;
|
||||||
import java.util.Calendar;
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Properties;
|
import java.util.Properties;
|
||||||
|
|
||||||
@ -210,12 +207,7 @@ public class PreviewExpressionCommand extends Command {
|
|||||||
sb.append(" ]");
|
sb.append(" ]");
|
||||||
} else if (v instanceof HasFields) {
|
} else if (v instanceof HasFields) {
|
||||||
sb.append("[object " + v.getClass().getSimpleName() + "]");
|
sb.append("[object " + v.getClass().getSimpleName() + "]");
|
||||||
} else if (v instanceof Calendar) {
|
} else if (v instanceof OffsetDateTime) {
|
||||||
Calendar c = (Calendar) v;
|
|
||||||
|
|
||||||
sb.append("[date " +
|
|
||||||
ParsingUtilities.dateToString(OffsetDateTime.ofInstant(c.toInstant(), ZoneId.systemDefault())) +"]");
|
|
||||||
} else if (v instanceof LocalDateTime) {
|
|
||||||
sb.append("[date " +
|
sb.append("[date " +
|
||||||
ParsingUtilities.dateToString((OffsetDateTime) v) +"]");
|
ParsingUtilities.dateToString((OffsetDateTime) v) +"]");
|
||||||
} else if (v instanceof String) {
|
} else if (v instanceof String) {
|
||||||
|
@ -35,9 +35,9 @@ package com.google.refine.exporters;
|
|||||||
|
|
||||||
import java.text.DateFormat;
|
import java.text.DateFormat;
|
||||||
import java.text.SimpleDateFormat;
|
import java.text.SimpleDateFormat;
|
||||||
|
import java.time.OffsetDateTime;
|
||||||
|
import java.time.format.DateTimeFormatter;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.Calendar;
|
|
||||||
import java.util.Date;
|
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
@ -344,10 +344,8 @@ abstract public class CustomizableTabularExporterUtilities {
|
|||||||
if (text == null) {
|
if (text == null) {
|
||||||
if (value instanceof String) {
|
if (value instanceof String) {
|
||||||
text = (String) value;
|
text = (String) value;
|
||||||
} else if (value instanceof Calendar) {
|
} else if (value instanceof OffsetDateTime) {
|
||||||
text = dateFormatter.format(((Calendar) value).getTime());
|
text = ((OffsetDateTime) value).format(DateTimeFormatter.ISO_INSTANT);
|
||||||
} else if (value instanceof Date) {
|
|
||||||
text = dateFormatter.format((Date) value);
|
|
||||||
} else {
|
} else {
|
||||||
text = value.toString();
|
text = value.toString();
|
||||||
}
|
}
|
||||||
|
@ -35,8 +35,7 @@ package com.google.refine.exporters;
|
|||||||
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.io.OutputStream;
|
import java.io.OutputStream;
|
||||||
import java.util.Calendar;
|
import java.time.OffsetDateTime;
|
||||||
import java.util.Date;
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Properties;
|
import java.util.Properties;
|
||||||
|
|
||||||
@ -49,6 +48,7 @@ import org.odftoolkit.odfdom.doc.table.OdfTableRow;
|
|||||||
import com.google.refine.ProjectManager;
|
import com.google.refine.ProjectManager;
|
||||||
import com.google.refine.browsing.Engine;
|
import com.google.refine.browsing.Engine;
|
||||||
import com.google.refine.model.Project;
|
import com.google.refine.model.Project;
|
||||||
|
import com.google.refine.util.ParsingUtilities;
|
||||||
|
|
||||||
public class OdsExporter implements StreamExporter {
|
public class OdsExporter implements StreamExporter {
|
||||||
|
|
||||||
@ -97,12 +97,9 @@ public class OdsExporter implements StreamExporter {
|
|||||||
c.setDoubleValue(((Number) v).doubleValue());
|
c.setDoubleValue(((Number) v).doubleValue());
|
||||||
} else if (v instanceof Boolean) {
|
} else if (v instanceof Boolean) {
|
||||||
c.setBooleanValue(((Boolean) v).booleanValue());
|
c.setBooleanValue(((Boolean) v).booleanValue());
|
||||||
} else if (v instanceof Date) {
|
} else if (v instanceof OffsetDateTime) {
|
||||||
Calendar cal = Calendar.getInstance();
|
OffsetDateTime odt = (OffsetDateTime)v;
|
||||||
cal.setTime((Date) v);
|
c.setDateValue(ParsingUtilities.offsetDateTimeToCalendar(odt));
|
||||||
c.setDateValue(cal);
|
|
||||||
} else if (v instanceof Calendar) {
|
|
||||||
c.setDateValue((Calendar) v);
|
|
||||||
} else {
|
} else {
|
||||||
c.setStringValue(cellData.text);
|
c.setStringValue(cellData.text);
|
||||||
}
|
}
|
||||||
|
@ -35,8 +35,7 @@ package com.google.refine.exporters;
|
|||||||
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.io.OutputStream;
|
import java.io.OutputStream;
|
||||||
import java.util.Calendar;
|
import java.time.OffsetDateTime;
|
||||||
import java.util.Date;
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Properties;
|
import java.util.Properties;
|
||||||
|
|
||||||
@ -54,6 +53,7 @@ import org.json.JSONObject;
|
|||||||
import com.google.refine.ProjectManager;
|
import com.google.refine.ProjectManager;
|
||||||
import com.google.refine.browsing.Engine;
|
import com.google.refine.browsing.Engine;
|
||||||
import com.google.refine.model.Project;
|
import com.google.refine.model.Project;
|
||||||
|
import com.google.refine.util.ParsingUtilities;
|
||||||
|
|
||||||
public class XlsExporter implements StreamExporter {
|
public class XlsExporter implements StreamExporter {
|
||||||
final private boolean xml;
|
final private boolean xml;
|
||||||
@ -112,11 +112,9 @@ public class XlsExporter implements StreamExporter {
|
|||||||
c.setCellValue(((Number) v).doubleValue());
|
c.setCellValue(((Number) v).doubleValue());
|
||||||
} else if (v instanceof Boolean) {
|
} else if (v instanceof Boolean) {
|
||||||
c.setCellValue(((Boolean) v).booleanValue());
|
c.setCellValue(((Boolean) v).booleanValue());
|
||||||
} else if (v instanceof Date) {
|
} else if (v instanceof OffsetDateTime) {
|
||||||
c.setCellValue((Date) v);
|
OffsetDateTime odt = (OffsetDateTime)v;
|
||||||
c.setCellStyle(dateStyle);
|
c.setCellValue(ParsingUtilities.offsetDateTimeToCalendar(odt));
|
||||||
} else if (v instanceof Calendar) {
|
|
||||||
c.setCellValue((Calendar) v);
|
|
||||||
c.setCellStyle(dateStyle);
|
c.setCellStyle(dateStyle);
|
||||||
} else {
|
} else {
|
||||||
String s = cellData.text;
|
String s = cellData.text;
|
||||||
@ -133,7 +131,6 @@ public class XlsExporter implements StreamExporter {
|
|||||||
hl.setAddress(cellData.link);
|
hl.setAddress(cellData.link);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -34,9 +34,8 @@ OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|||||||
package com.google.refine.expr;
|
package com.google.refine.expr;
|
||||||
|
|
||||||
import java.io.Serializable;
|
import java.io.Serializable;
|
||||||
import java.util.Calendar;
|
import java.time.OffsetDateTime;
|
||||||
import java.util.Collection;
|
import java.util.Collection;
|
||||||
import java.util.Date;
|
|
||||||
import java.util.HashSet;
|
import java.util.HashSet;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Properties;
|
import java.util.Properties;
|
||||||
@ -138,8 +137,7 @@ public class ExpressionUtils {
|
|||||||
v instanceof Number ||
|
v instanceof Number ||
|
||||||
v instanceof String ||
|
v instanceof String ||
|
||||||
v instanceof Boolean ||
|
v instanceof Boolean ||
|
||||||
v instanceof Date ||
|
v instanceof OffsetDateTime ||
|
||||||
v instanceof Calendar ||
|
|
||||||
v instanceof EvalError;
|
v instanceof EvalError;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -36,21 +36,22 @@ package com.google.refine.expr.functions;
|
|||||||
import java.text.DateFormat;
|
import java.text.DateFormat;
|
||||||
import java.text.SimpleDateFormat;
|
import java.text.SimpleDateFormat;
|
||||||
import java.time.OffsetDateTime;
|
import java.time.OffsetDateTime;
|
||||||
import java.util.Calendar;
|
import java.time.ZoneOffset;
|
||||||
import java.util.Date;
|
import java.util.Date;
|
||||||
import java.util.GregorianCalendar;
|
import java.util.GregorianCalendar;
|
||||||
import java.util.Locale;
|
import java.util.Locale;
|
||||||
import java.util.Properties;
|
import java.util.Properties;
|
||||||
|
import java.util.TimeZone;
|
||||||
|
|
||||||
import org.apache.commons.lang3.StringUtils;
|
import org.apache.commons.lang3.StringUtils;
|
||||||
import org.json.JSONException;
|
import org.json.JSONException;
|
||||||
import org.json.JSONWriter;
|
import org.json.JSONWriter;
|
||||||
|
|
||||||
import com.google.refine.expr.EvalError;
|
import com.google.refine.expr.EvalError;
|
||||||
import com.google.refine.expr.util.CalendarParser;
|
|
||||||
import com.google.refine.expr.util.CalendarParserException;
|
import com.google.refine.expr.util.CalendarParserException;
|
||||||
import com.google.refine.grel.Function;
|
import com.google.refine.expr.util.CalenderParser;
|
||||||
import com.google.refine.grel.ControlFunctionRegistry;
|
import com.google.refine.grel.ControlFunctionRegistry;
|
||||||
|
import com.google.refine.grel.Function;
|
||||||
import com.google.refine.util.ParsingUtilities;
|
import com.google.refine.util.ParsingUtilities;
|
||||||
|
|
||||||
public class ToDate implements Function {
|
public class ToDate implements Function {
|
||||||
@ -62,10 +63,8 @@ public class ToDate implements Function {
|
|||||||
return new EvalError(ControlFunctionRegistry.getFunctionName(this) + " expects at least one argument");
|
return new EvalError(ControlFunctionRegistry.getFunctionName(this) + " expects at least one argument");
|
||||||
} else {
|
} else {
|
||||||
Object arg0 = args[0];
|
Object arg0 = args[0];
|
||||||
if (arg0 instanceof Date) {
|
if (arg0 instanceof OffsetDateTime) {
|
||||||
return arg0;
|
return arg0;
|
||||||
} else if (arg0 instanceof Calendar) {
|
|
||||||
return ((Calendar) arg0).getTime();
|
|
||||||
} else if (arg0 instanceof Long) {
|
} else if (arg0 instanceof Long) {
|
||||||
o1 = ((Long) arg0).toString(); // treat integers as years
|
o1 = ((Long) arg0).toString(); // treat integers as years
|
||||||
} else if (arg0 instanceof String && arg0.toString().trim().length() > 0) {
|
} else if (arg0 instanceof String && arg0.toString().trim().length() > 0) {
|
||||||
@ -83,21 +82,16 @@ public class ToDate implements Function {
|
|||||||
month_first = (Boolean) args[1];
|
month_first = (Boolean) args[1];
|
||||||
}
|
}
|
||||||
try {
|
try {
|
||||||
return CalendarParser.parse( o1, (month_first) ? CalendarParser.MM_DD_YY : CalendarParser.DD_MM_YY);
|
return CalenderParser.parseAsOffsetDateTime( o1, (month_first) ? CalenderParser.MM_DD_YY : CalenderParser.DD_MM_YY);
|
||||||
} catch (CalendarParserException e) {
|
} catch (CalendarParserException e) {
|
||||||
OffsetDateTime d = ParsingUtilities.stringToDate(o1);
|
OffsetDateTime d = ParsingUtilities.stringToDate(o1);
|
||||||
if (d != null) {
|
if (d != null) {
|
||||||
return d;
|
return d;
|
||||||
} else {
|
} else {
|
||||||
try {
|
try {
|
||||||
return javax.xml.bind.DatatypeConverter.parseDateTime(o1).getTime();
|
return javax.xml.bind.DatatypeConverter.parseDateTime(o1).getTime().toInstant().atOffset(ZoneOffset.of("Z"));
|
||||||
} catch (IllegalArgumentException e2) {
|
} catch (IllegalArgumentException e2) {
|
||||||
}
|
}
|
||||||
// alternate implementation which may be useful on some JVMs?
|
|
||||||
// try {
|
|
||||||
// return javax.xml.datatype.DatatypeFactory.newInstance().newXMLGregorianCalendar(o1).toGregorianCalendar().getTime();
|
|
||||||
// } catch (DatatypeConfigurationException e2) {
|
|
||||||
// }
|
|
||||||
}
|
}
|
||||||
return new EvalError("Unable to parse as date");
|
return new EvalError("Unable to parse as date");
|
||||||
}
|
}
|
||||||
@ -114,14 +108,7 @@ public class ToDate implements Function {
|
|||||||
DateFormat formatter;
|
DateFormat formatter;
|
||||||
// Attempt to parse first string as a language tag
|
// Attempt to parse first string as a language tag
|
||||||
if (i == 1) {
|
if (i == 1) {
|
||||||
// Locale possibleLocale = Locale.forLanguageTag(format); // Java 1.7+ only
|
Locale possibleLocale = Locale.forLanguageTag(format); // Java 1.7+
|
||||||
Locale possibleLocale;
|
|
||||||
int c = format.indexOf('_');
|
|
||||||
if (c > 0) {
|
|
||||||
possibleLocale = new Locale(format.substring(0, c),format.substring(c+1));
|
|
||||||
} else {
|
|
||||||
possibleLocale = new Locale(format);
|
|
||||||
}
|
|
||||||
boolean valid = false;
|
boolean valid = false;
|
||||||
for (Locale l : DateFormat.getAvailableLocales()) {
|
for (Locale l : DateFormat.getAvailableLocales()) {
|
||||||
if (l.equals(possibleLocale)) {
|
if (l.equals(possibleLocale)) {
|
||||||
@ -133,8 +120,7 @@ public class ToDate implements Function {
|
|||||||
if (valid) { // If we got a valid locale
|
if (valid) { // If we got a valid locale
|
||||||
if (args.length == 2) { // No format strings to try, process using default
|
if (args.length == 2) { // No format strings to try, process using default
|
||||||
formatter = DateFormat.getDateInstance(DateFormat.DEFAULT, locale);
|
formatter = DateFormat.getDateInstance(DateFormat.DEFAULT, locale);
|
||||||
formatter.setLenient(true);
|
OffsetDateTime date = parse(o1, formatter);
|
||||||
GregorianCalendar date = parse(o1, formatter);
|
|
||||||
if (date != null) {
|
if (date != null) {
|
||||||
return date;
|
return date;
|
||||||
} else {
|
} else {
|
||||||
@ -150,10 +136,11 @@ public class ToDate implements Function {
|
|||||||
return new EvalError("Unknown date format");
|
return new EvalError("Unknown date format");
|
||||||
}
|
}
|
||||||
formatter.setLenient(true);
|
formatter.setLenient(true);
|
||||||
GregorianCalendar date = parse(o1, formatter);
|
OffsetDateTime date = parse(o1, formatter);
|
||||||
if (date != null) {
|
if (date != null) {
|
||||||
return date;
|
return date;
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
return new EvalError("Unable to parse as date");
|
return new EvalError("Unable to parse as date");
|
||||||
} else {
|
} else {
|
||||||
@ -161,19 +148,18 @@ public class ToDate implements Function {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private OffsetDateTime parse(String o1, DateFormat formatter) {
|
||||||
private GregorianCalendar parse(String o1, DateFormat formatter) {
|
|
||||||
try {
|
try {
|
||||||
|
formatter.setTimeZone(TimeZone.getTimeZone("Z"));
|
||||||
Date date = formatter.parse(o1);
|
Date date = formatter.parse(o1);
|
||||||
GregorianCalendar c = new GregorianCalendar();
|
GregorianCalendar c = new GregorianCalendar();
|
||||||
c.setTime(date);
|
c.setTime(date);
|
||||||
return c;
|
return ParsingUtilities.calendarToOffsetDateTime(c);
|
||||||
} catch (java.text.ParseException e) {
|
} catch (java.text.ParseException e) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void write(JSONWriter writer, Properties options)
|
public void write(JSONWriter writer, Properties options)
|
||||||
throws JSONException {
|
throws JSONException {
|
||||||
|
@ -33,10 +33,8 @@ OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|||||||
|
|
||||||
package com.google.refine.expr.functions;
|
package com.google.refine.expr.functions;
|
||||||
|
|
||||||
import java.text.DateFormat;
|
import java.time.OffsetDateTime;
|
||||||
import java.text.SimpleDateFormat;
|
import java.time.format.DateTimeFormatter;
|
||||||
import java.util.Calendar;
|
|
||||||
import java.util.Date;
|
|
||||||
import java.util.Properties;
|
import java.util.Properties;
|
||||||
|
|
||||||
import org.json.JSONException;
|
import org.json.JSONException;
|
||||||
@ -55,9 +53,9 @@ public class ToString implements Function {
|
|||||||
Object o1 = args[0];
|
Object o1 = args[0];
|
||||||
if (args.length == 2 && args[1] instanceof String) {
|
if (args.length == 2 && args[1] instanceof String) {
|
||||||
Object o2 = args[1];
|
Object o2 = args[1];
|
||||||
if (o1 instanceof Calendar || o1 instanceof Date) {
|
if (o1 instanceof OffsetDateTime) {
|
||||||
DateFormat formatter = new SimpleDateFormat((String) o2);
|
OffsetDateTime odt = (OffsetDateTime)o1;
|
||||||
return formatter.format(o1 instanceof Date ? ((Date) o1) : ((Calendar) o1).getTime());
|
return odt.format(DateTimeFormatter.ISO_INSTANT);
|
||||||
} else if (o1 instanceof Number) {
|
} else if (o1 instanceof Number) {
|
||||||
return String.format((String) o2, (Number) o1);
|
return String.format((String) o2, (Number) o1);
|
||||||
}
|
}
|
||||||
|
@ -33,8 +33,7 @@ OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|||||||
|
|
||||||
package com.google.refine.expr.functions;
|
package com.google.refine.expr.functions;
|
||||||
|
|
||||||
import java.util.Calendar;
|
import java.time.OffsetDateTime;
|
||||||
import java.util.Date;
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Properties;
|
import java.util.Properties;
|
||||||
|
|
||||||
@ -55,7 +54,7 @@ public class Type implements Function {
|
|||||||
if (v != null) {
|
if (v != null) {
|
||||||
if (v instanceof String) {
|
if (v instanceof String) {
|
||||||
return "string";
|
return "string";
|
||||||
} else if (v instanceof Calendar || v instanceof Date) {
|
} else if (v instanceof OffsetDateTime) {
|
||||||
return "date";
|
return "date";
|
||||||
} else if (v instanceof Number) {
|
} else if (v instanceof Number) {
|
||||||
return "number";
|
return "number";
|
||||||
|
@ -33,8 +33,9 @@ OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|||||||
|
|
||||||
package com.google.refine.expr.functions.date;
|
package com.google.refine.expr.functions.date;
|
||||||
|
|
||||||
import java.util.Calendar;
|
import java.time.OffsetDateTime;
|
||||||
import java.util.Date;
|
import java.time.temporal.ChronoUnit;
|
||||||
|
import java.time.temporal.TemporalUnit;
|
||||||
import java.util.Properties;
|
import java.util.Properties;
|
||||||
|
|
||||||
import org.json.JSONException;
|
import org.json.JSONException;
|
||||||
@ -49,42 +50,34 @@ public class Inc implements Function {
|
|||||||
@Override
|
@Override
|
||||||
public Object call(Properties bindings, Object[] args) {
|
public Object call(Properties bindings, Object[] args) {
|
||||||
if (args.length == 3 &&
|
if (args.length == 3 &&
|
||||||
args[0] != null && (args[0] instanceof Calendar || args[0] instanceof Date) &&
|
args[0] != null && (args[0] instanceof OffsetDateTime) &&
|
||||||
args[1] != null && args[1] instanceof Number &&
|
args[1] != null && args[1] instanceof Number &&
|
||||||
args[2] != null && args[2] instanceof String) {
|
args[2] != null && args[2] instanceof String) {
|
||||||
Calendar date;
|
OffsetDateTime date = (OffsetDateTime)args[0];
|
||||||
if (args[0] instanceof Calendar) {
|
|
||||||
date = (Calendar) ((Calendar) args[0]).clone(); // must copy so not to modify original
|
|
||||||
} else {
|
|
||||||
date = Calendar.getInstance();
|
|
||||||
date.setTime((Date) args[0]);
|
|
||||||
}
|
|
||||||
|
|
||||||
int amount = ((Number) args[1]).intValue();
|
int amount = ((Number) args[1]).intValue();
|
||||||
String unit = (String) args[2];
|
String unit = (String) args[2];
|
||||||
|
|
||||||
date.add(getField(unit), amount);
|
return date.plus(amount, getField(unit));
|
||||||
|
|
||||||
return date;
|
|
||||||
}
|
}
|
||||||
return new EvalError(ControlFunctionRegistry.getFunctionName(this) + " expects a date, a number and a string");
|
return new EvalError(ControlFunctionRegistry.getFunctionName(this) + " expects a date, a number and a string");
|
||||||
}
|
}
|
||||||
|
|
||||||
private int getField(String unit) {
|
private TemporalUnit getField(String unit) {
|
||||||
if ("hours".equals(unit) || "hour".equals(unit) || "h".equals(unit)) {
|
if ("hours".equals(unit) || "hour".equals(unit) || "h".equals(unit)) {
|
||||||
return Calendar.HOUR;
|
return ChronoUnit.HOURS;
|
||||||
} else if ("days".equals(unit) || "day".equals(unit) || "d".equals(unit)) {
|
} else if ("days".equals(unit) || "day".equals(unit) || "d".equals(unit)) {
|
||||||
return Calendar.DAY_OF_MONTH;
|
return ChronoUnit.DAYS;
|
||||||
} else if ("years".equals(unit) || "year".equals(unit)) {
|
} else if ("years".equals(unit) || "year".equals(unit)) {
|
||||||
return Calendar.YEAR;
|
return ChronoUnit.YEARS;
|
||||||
} else if ("months".equals(unit) || "month".equals(unit)) { // avoid 'm' to avoid confusion with minute
|
} else if ("months".equals(unit) || "month".equals(unit)) { // avoid 'm' to avoid confusion with minute
|
||||||
return Calendar.MONTH;
|
return ChronoUnit.MONTHS;
|
||||||
} else if ("minutes".equals(unit) || "minute".equals(unit) || "min".equals(unit)) { // avoid 'm' to avoid confusion with month
|
} else if ("minutes".equals(unit) || "minute".equals(unit) || "min".equals(unit)) { // avoid 'm' to avoid confusion with month
|
||||||
return Calendar.MINUTE;
|
return ChronoUnit.MINUTES;
|
||||||
} else if ("weeks".equals(unit) || "week".equals(unit) || "w".equals(unit)) {
|
} else if ("weeks".equals(unit) || "week".equals(unit) || "w".equals(unit)) {
|
||||||
return Calendar.WEEK_OF_MONTH;
|
return ChronoUnit.WEEKS;
|
||||||
} else if ("seconds".equals(unit) || "sec".equals(unit) || "s".equals(unit)) {
|
} else if ("seconds".equals(unit) || "sec".equals(unit) || "s".equals(unit)) {
|
||||||
return Calendar.SECOND;
|
return ChronoUnit.SECONDS;
|
||||||
} else {
|
} else {
|
||||||
throw new RuntimeException("Unit '" + unit + "' not recognized.");
|
throw new RuntimeException("Unit '" + unit + "' not recognized.");
|
||||||
}
|
}
|
||||||
|
@ -33,7 +33,8 @@ OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|||||||
|
|
||||||
package com.google.refine.expr.functions.date;
|
package com.google.refine.expr.functions.date;
|
||||||
|
|
||||||
import java.util.Calendar;
|
import java.time.OffsetDateTime;
|
||||||
|
import java.time.ZoneId;
|
||||||
import java.util.Properties;
|
import java.util.Properties;
|
||||||
|
|
||||||
import org.json.JSONException;
|
import org.json.JSONException;
|
||||||
@ -46,7 +47,7 @@ public class Now implements Function {
|
|||||||
@Override
|
@Override
|
||||||
public Object call(Properties bindings, Object[] args) {
|
public Object call(Properties bindings, Object[] args) {
|
||||||
if (args.length == 0) {
|
if (args.length == 0) {
|
||||||
return Calendar.getInstance();
|
return OffsetDateTime.now(ZoneId.of("Z"));
|
||||||
}
|
}
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
@ -33,8 +33,7 @@ OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|||||||
|
|
||||||
package com.google.refine.expr.functions.strings;
|
package com.google.refine.expr.functions.strings;
|
||||||
|
|
||||||
import java.util.Calendar;
|
import java.time.OffsetDateTime;
|
||||||
import java.util.Date;
|
|
||||||
import java.util.Properties;
|
import java.util.Properties;
|
||||||
|
|
||||||
import org.apache.commons.lang3.StringUtils;
|
import org.apache.commons.lang3.StringUtils;
|
||||||
@ -42,8 +41,6 @@ import org.json.JSONException;
|
|||||||
import org.json.JSONWriter;
|
import org.json.JSONWriter;
|
||||||
|
|
||||||
import com.google.refine.expr.EvalError;
|
import com.google.refine.expr.EvalError;
|
||||||
import com.google.refine.expr.util.CalendarParser;
|
|
||||||
import com.google.refine.expr.util.CalendarParserException;
|
|
||||||
import com.google.refine.grel.Function;
|
import com.google.refine.grel.Function;
|
||||||
|
|
||||||
public class Diff implements Function {
|
public class Diff implements Function {
|
||||||
@ -56,21 +53,14 @@ public class Diff implements Function {
|
|||||||
if (o1 != null && o2 != null) {
|
if (o1 != null && o2 != null) {
|
||||||
if (args.length == 2 && o1 instanceof String && o2 instanceof String) {
|
if (args.length == 2 && o1 instanceof String && o2 instanceof String) {
|
||||||
return StringUtils.difference((String) o1,(String) o2);
|
return StringUtils.difference((String) o1,(String) o2);
|
||||||
} else if ((o1 instanceof Date || o1 instanceof Calendar) && args.length == 3) {
|
} else if (o1 instanceof OffsetDateTime && o2 instanceof OffsetDateTime && args.length == 3) {
|
||||||
Object o3 = args[2];
|
Object o3 = args[2];
|
||||||
if (o3 != null && o3 instanceof String) {
|
if (o3 != null && o3 instanceof String) {
|
||||||
try {
|
|
||||||
String unit = ((String) o3).toLowerCase();
|
String unit = ((String) o3).toLowerCase();
|
||||||
Date c1 = (o1 instanceof Date) ? (Date) o1 : ((Calendar) o1).getTime();
|
OffsetDateTime c1 = (OffsetDateTime)o1;
|
||||||
Date c2;
|
OffsetDateTime c2 = (OffsetDateTime)o2;
|
||||||
if (o2 instanceof Date) {
|
|
||||||
c2 = (Date) o2;
|
long delta = (c1.toInstant().toEpochMilli() - c2.toInstant().toEpochMilli()) / 1000;
|
||||||
} else if (o2 instanceof Calendar) {
|
|
||||||
c2 = ((Calendar) o2).getTime();
|
|
||||||
} else {
|
|
||||||
c2 = CalendarParser.parse((o2 instanceof String) ? (String) o2 : o2.toString()).getTime();
|
|
||||||
}
|
|
||||||
long delta = (c1.getTime() - c2.getTime()) / 1000;
|
|
||||||
if ("seconds".equals(unit)) {
|
if ("seconds".equals(unit)) {
|
||||||
return delta;
|
return delta;
|
||||||
}
|
}
|
||||||
@ -96,13 +86,10 @@ public class Diff implements Function {
|
|||||||
return days / 365;
|
return days / 365;
|
||||||
}
|
}
|
||||||
return new EvalError("Unknown time unit " + unit);
|
return new EvalError("Unknown time unit " + unit);
|
||||||
} catch (CalendarParserException e) {
|
|
||||||
return new EvalError(e);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
return new EvalError("Unexpected arguments - expecting either 2 strings or 2 dates and a unit string");
|
return new EvalError("Unexpected arguments - expecting either 2 strings or 2 dates and a unit string");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -37,7 +37,7 @@ package com.google.refine.expr.util;
|
|||||||
// Copyright Dave Glowacki. Released under the BSD license.
|
// Copyright Dave Glowacki. Released under the BSD license.
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Thrown when an invalid date is encountered in <tt>CalendarParser</tt>.
|
* Thrown when an invalid date is encountered in <tt>OffsetDateTimeParser</tt>.
|
||||||
*/
|
*/
|
||||||
public class CalendarParserException extends Exception {
|
public class CalendarParserException extends Exception {
|
||||||
|
|
||||||
|
@ -35,12 +35,15 @@ package com.google.refine.expr.util;
|
|||||||
|
|
||||||
import java.lang.reflect.InvocationTargetException;
|
import java.lang.reflect.InvocationTargetException;
|
||||||
import java.lang.reflect.Method;
|
import java.lang.reflect.Method;
|
||||||
|
import java.time.OffsetDateTime;
|
||||||
import java.util.Calendar;
|
import java.util.Calendar;
|
||||||
import java.util.GregorianCalendar;
|
import java.util.GregorianCalendar;
|
||||||
import java.util.TimeZone;
|
import java.util.TimeZone;
|
||||||
import java.util.regex.Matcher;
|
import java.util.regex.Matcher;
|
||||||
import java.util.regex.Pattern;
|
import java.util.regex.Pattern;
|
||||||
|
|
||||||
|
import com.google.refine.util.ParsingUtilities;
|
||||||
|
|
||||||
// Taken from http://icecube.wisc.edu/~dglo/software/calparse/index.html
|
// Taken from http://icecube.wisc.edu/~dglo/software/calparse/index.html
|
||||||
// Copyright Dave Glowacki. Released under the BSD license.
|
// Copyright Dave Glowacki. Released under the BSD license.
|
||||||
|
|
||||||
@ -491,7 +494,7 @@ class ParserState {
|
|||||||
/**
|
/**
|
||||||
* A parser for arbitrary date/time strings.
|
* A parser for arbitrary date/time strings.
|
||||||
*/
|
*/
|
||||||
public class CalendarParser {
|
public class CalenderParser {
|
||||||
/** bit indicating that the year comes before the month. */
|
/** bit indicating that the year comes before the month. */
|
||||||
public static final int YEAR_BEFORE_MONTH = ParserState.YEAR_BEFORE_MONTH;
|
public static final int YEAR_BEFORE_MONTH = ParserState.YEAR_BEFORE_MONTH;
|
||||||
/** bit indicating that the year comes before the day. */
|
/** bit indicating that the year comes before the day. */
|
||||||
@ -866,6 +869,10 @@ public class CalendarParser {
|
|||||||
return parse(dateStr, YY_MM_DD);
|
return parse(dateStr, YY_MM_DD);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public static final OffsetDateTime parseAsOffsetDateTime(String dateStr) throws CalendarParserException {
|
||||||
|
return ParsingUtilities.calendarToOffsetDateTime(parse(dateStr));
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Extract a date from a string.
|
* Extract a date from a string.
|
||||||
*
|
*
|
||||||
@ -885,6 +892,11 @@ public class CalendarParser {
|
|||||||
return parse(dateStr, order, true);
|
return parse(dateStr, order, true);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public static final OffsetDateTime parseAsOffsetDateTime(String dateStr, int order)
|
||||||
|
throws CalendarParserException {
|
||||||
|
return ParsingUtilities.calendarToOffsetDateTime(parse(dateStr, order));
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Extract a date from a string.
|
* Extract a date from a string.
|
||||||
*
|
*
|
||||||
@ -911,6 +923,11 @@ public class CalendarParser {
|
|||||||
return parseString(dateStr, order, ignoreChanges);
|
return parseString(dateStr, order, ignoreChanges);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public static final OffsetDateTime parseAsOffsetDateTime(String dateStr, int order,
|
||||||
|
boolean ignoreChanges) throws CalendarParserException {
|
||||||
|
return ParsingUtilities.calendarToOffsetDateTime(parse(dateStr, order, ignoreChanges));
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Parse a non-numeric token from the date string.
|
* Parse a non-numeric token from the date string.
|
||||||
*
|
*
|
||||||
@ -1620,7 +1637,7 @@ public class CalendarParser {
|
|||||||
state.setYear(tmpYear + (CENTURY_OFFSET - 100));
|
state.setYear(tmpYear + (CENTURY_OFFSET - 100));
|
||||||
}
|
}
|
||||||
|
|
||||||
GregorianCalendar cal = new GregorianCalendar();
|
GregorianCalendar cal = new GregorianCalendar(TimeZone.getTimeZone("Z"));
|
||||||
|
|
||||||
state.setCalendar(cal, ignoreChanges);
|
state.setCalendar(cal, ignoreChanges);
|
||||||
|
|
||||||
@ -1631,6 +1648,7 @@ public class CalendarParser {
|
|||||||
+ state.getMillisecond() + " => " + toString(cal));
|
+ state.getMillisecond() + " => " + toString(cal));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// return cal.toInstant().atOffset(ZoneOffset.of("Z"));
|
||||||
return cal;
|
return cal;
|
||||||
}
|
}
|
||||||
|
|
@ -39,8 +39,6 @@ import java.time.Instant;
|
|||||||
import java.time.LocalDateTime;
|
import java.time.LocalDateTime;
|
||||||
import java.time.OffsetDateTime;
|
import java.time.OffsetDateTime;
|
||||||
import java.time.ZoneOffset;
|
import java.time.ZoneOffset;
|
||||||
import java.util.Calendar;
|
|
||||||
import java.util.Date;
|
|
||||||
import java.util.Properties;
|
import java.util.Properties;
|
||||||
|
|
||||||
import org.json.JSONException;
|
import org.json.JSONException;
|
||||||
@ -92,11 +90,7 @@ public class Cell implements HasFields, Jsonizable {
|
|||||||
writer.key("v");
|
writer.key("v");
|
||||||
if (value != null) {
|
if (value != null) {
|
||||||
Instant instant = null;
|
Instant instant = null;
|
||||||
if (value instanceof Calendar) {
|
if (value instanceof OffsetDateTime) {
|
||||||
instant = ((Calendar)value).toInstant();
|
|
||||||
} else if (value instanceof Date) {
|
|
||||||
instant = ((Date)value).toInstant();
|
|
||||||
} else if (value instanceof OffsetDateTime) {
|
|
||||||
instant = ((OffsetDateTime)value).toInstant();
|
instant = ((OffsetDateTime)value).toInstant();
|
||||||
} else if (value instanceof LocalDateTime) {
|
} else if (value instanceof LocalDateTime) {
|
||||||
instant = ((LocalDateTime)value).toInstant(ZoneOffset.of("Z"));
|
instant = ((LocalDateTime)value).toInstant(ZoneOffset.of("Z"));
|
||||||
|
@ -38,11 +38,8 @@ import java.io.InputStream;
|
|||||||
import java.io.StringWriter;
|
import java.io.StringWriter;
|
||||||
import java.net.HttpURLConnection;
|
import java.net.HttpURLConnection;
|
||||||
import java.net.URL;
|
import java.net.URL;
|
||||||
import java.time.ZoneId;
|
|
||||||
import java.time.OffsetDateTime;
|
import java.time.OffsetDateTime;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.Calendar;
|
|
||||||
import java.util.Date;
|
|
||||||
import java.util.HashSet;
|
import java.util.HashSet;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Properties;
|
import java.util.Properties;
|
||||||
@ -307,11 +304,7 @@ public class StandardReconConfig extends ReconConfig {
|
|||||||
jsonWriter.key("id"); jsonWriter.value(cell2.recon.match.id);
|
jsonWriter.key("id"); jsonWriter.value(cell2.recon.match.id);
|
||||||
jsonWriter.key("name"); jsonWriter.value(cell2.recon.match.name);
|
jsonWriter.key("name"); jsonWriter.value(cell2.recon.match.name);
|
||||||
jsonWriter.endObject();
|
jsonWriter.endObject();
|
||||||
} else if (cell2.value instanceof Calendar) {
|
} else if (cell2.value instanceof OffsetDateTime) {
|
||||||
Calendar calendar = (Calendar) cell2.value;
|
|
||||||
OffsetDateTime d = OffsetDateTime.ofInstant(calendar.toInstant(), ZoneId.of("Z"));
|
|
||||||
jsonWriter.value(ParsingUtilities.dateToString(d));
|
|
||||||
} else if (cell2.value instanceof Date) {
|
|
||||||
jsonWriter.value(ParsingUtilities.dateToString((OffsetDateTime) cell2.value));
|
jsonWriter.value(ParsingUtilities.dateToString((OffsetDateTime) cell2.value));
|
||||||
} else {
|
} else {
|
||||||
jsonWriter.value(cell2.value.toString());
|
jsonWriter.value(cell2.value.toString());
|
||||||
|
@ -33,8 +33,8 @@ OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|||||||
|
|
||||||
package com.google.refine.sorting;
|
package com.google.refine.sorting;
|
||||||
|
|
||||||
import java.util.Calendar;
|
import java.time.Instant;
|
||||||
import java.util.Date;
|
import java.time.OffsetDateTime;
|
||||||
|
|
||||||
import com.google.refine.expr.EvalError;
|
import com.google.refine.expr.EvalError;
|
||||||
import com.google.refine.expr.ExpressionUtils;
|
import com.google.refine.expr.ExpressionUtils;
|
||||||
@ -48,10 +48,8 @@ public class DateCriterion extends Criterion {
|
|||||||
@Override
|
@Override
|
||||||
protected Object makeKey(Object value) {
|
protected Object makeKey(Object value) {
|
||||||
if (ExpressionUtils.isNonBlankData(value)) {
|
if (ExpressionUtils.isNonBlankData(value)) {
|
||||||
if (value instanceof Date) {
|
if (value instanceof OffsetDateTime) {
|
||||||
return value;
|
return ((OffsetDateTime) value).toInstant();
|
||||||
} else if (value instanceof Calendar) {
|
|
||||||
return ((Calendar) value).getTime();
|
|
||||||
} else {
|
} else {
|
||||||
return s_error;
|
return s_error;
|
||||||
}
|
}
|
||||||
@ -61,7 +59,7 @@ public class DateCriterion extends Criterion {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public int compareKeys(Object key1, Object key2) {
|
public int compareKeys(Object key1, Object key2) {
|
||||||
return ((Date) key1).compareTo((Date) key2);
|
return ((Instant) key1).compareTo((Instant) key2);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
@ -33,8 +33,7 @@ OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|||||||
|
|
||||||
package com.google.refine.sorting;
|
package com.google.refine.sorting;
|
||||||
|
|
||||||
import java.util.Calendar;
|
import java.time.OffsetDateTime;
|
||||||
import java.util.Date;
|
|
||||||
|
|
||||||
import com.google.refine.expr.EvalError;
|
import com.google.refine.expr.EvalError;
|
||||||
import com.google.refine.expr.ExpressionUtils;
|
import com.google.refine.expr.ExpressionUtils;
|
||||||
@ -53,10 +52,8 @@ public class NumberCriterion extends Criterion {
|
|||||||
return value;
|
return value;
|
||||||
} else if (value instanceof Boolean) {
|
} else if (value instanceof Boolean) {
|
||||||
return ((Boolean) value).booleanValue() ? 1 : 0;
|
return ((Boolean) value).booleanValue() ? 1 : 0;
|
||||||
} else if (value instanceof Date) {
|
} else if (value instanceof OffsetDateTime) {
|
||||||
return ((Date) value).getTime();
|
return ((OffsetDateTime) value).toInstant().toEpochMilli();
|
||||||
} else if (value instanceof Calendar) {
|
|
||||||
return ((Calendar) value).getTime().getTime();
|
|
||||||
} else if (value instanceof String) {
|
} else if (value instanceof String) {
|
||||||
try {
|
try {
|
||||||
double d = Double.parseDouble((String) value);
|
double d = Double.parseDouble((String) value);
|
||||||
|
@ -40,7 +40,6 @@ import java.util.ArrayList;
|
|||||||
import java.util.Arrays;
|
import java.util.Arrays;
|
||||||
import java.util.Calendar;
|
import java.util.Calendar;
|
||||||
import java.util.Collection;
|
import java.util.Collection;
|
||||||
import java.util.Date;
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|
||||||
@ -197,8 +196,6 @@ public class JSONUtilities {
|
|||||||
obj.put(key, ((Double) value).doubleValue());
|
obj.put(key, ((Double) value).doubleValue());
|
||||||
} else if (value instanceof Boolean) {
|
} else if (value instanceof Boolean) {
|
||||||
obj.put(key, value);
|
obj.put(key, value);
|
||||||
} else if (value instanceof Date) {
|
|
||||||
obj.put(key, ParsingUtilities.dateToString((OffsetDateTime) value));
|
|
||||||
} else if (value instanceof Calendar) {
|
} else if (value instanceof Calendar) {
|
||||||
obj.put(key, ParsingUtilities.dateToString(OffsetDateTime.ofInstant(((Calendar)value).toInstant(), ZoneId.of("Z"))));
|
obj.put(key, ParsingUtilities.dateToString(OffsetDateTime.ofInstant(((Calendar)value).toInstant(), ZoneId.of("Z"))));
|
||||||
} else if (value instanceof String) {
|
} else if (value instanceof String) {
|
||||||
|
@ -45,7 +45,10 @@ import java.time.ZoneId;
|
|||||||
import java.time.ZoneOffset;
|
import java.time.ZoneOffset;
|
||||||
import java.time.format.DateTimeFormatter;
|
import java.time.format.DateTimeFormatter;
|
||||||
import java.time.format.DateTimeParseException;
|
import java.time.format.DateTimeParseException;
|
||||||
|
import java.util.Calendar;
|
||||||
|
import java.util.GregorianCalendar;
|
||||||
import java.util.Properties;
|
import java.util.Properties;
|
||||||
|
import java.util.TimeZone;
|
||||||
|
|
||||||
import javax.servlet.http.HttpServletRequest;
|
import javax.servlet.http.HttpServletRequest;
|
||||||
|
|
||||||
@ -223,4 +226,14 @@ public class ParsingUtilities {
|
|||||||
static public String instantToLocalDateTimeString(Instant instant) {
|
static public String instantToLocalDateTimeString(Instant instant) {
|
||||||
return LocalDateTime.ofInstant(instant, ZoneId.systemDefault()).format(ISO8601);
|
return LocalDateTime.ofInstant(instant, ZoneId.systemDefault()).format(ISO8601);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static public OffsetDateTime calendarToOffsetDateTime(Calendar calendar) {
|
||||||
|
return calendar.toInstant().atOffset(ZoneOffset.of("Z"));
|
||||||
|
}
|
||||||
|
|
||||||
|
static public Calendar offsetDateTimeToCalendar(OffsetDateTime offsetDateTime) {
|
||||||
|
Calendar cal = new GregorianCalendar(TimeZone.getTimeZone("Z"));
|
||||||
|
cal.setTimeInMillis(offsetDateTime.toInstant().toEpochMilli());
|
||||||
|
return cal;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,9 +1,7 @@
|
|||||||
package com.google.refine.util;
|
package com.google.refine.util;
|
||||||
|
|
||||||
import java.text.DateFormat;
|
import java.time.OffsetDateTime;
|
||||||
import java.util.Calendar;
|
import java.time.format.DateTimeFormatter;
|
||||||
import java.util.Date;
|
|
||||||
|
|
||||||
|
|
||||||
public class StringUtils {
|
public class StringUtils {
|
||||||
|
|
||||||
@ -13,9 +11,10 @@ public class StringUtils {
|
|||||||
* @return string representing object
|
* @return string representing object
|
||||||
*/
|
*/
|
||||||
public static String toString(Object o) {
|
public static String toString(Object o) {
|
||||||
if (o instanceof Calendar || o instanceof Date) {
|
// to replace the DateFormat with java.time.format.DateTimeFormatter
|
||||||
DateFormat formatter = DateFormat.getDateInstance();
|
if (o instanceof OffsetDateTime) {
|
||||||
return formatter.format(o instanceof Date ? ((Date) o) : ((Calendar) o).getTime());
|
OffsetDateTime odt = (OffsetDateTime)o;
|
||||||
|
return odt.format(DateTimeFormatter.ISO_INSTANT);
|
||||||
} else if (o == null) {
|
} else if (o == null) {
|
||||||
return "null";
|
return "null";
|
||||||
} else {
|
} else {
|
||||||
|
@ -40,8 +40,6 @@ import static org.mockito.Mockito.when;
|
|||||||
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.io.StringWriter;
|
import java.io.StringWriter;
|
||||||
import java.util.Calendar;
|
|
||||||
import java.util.Date;
|
|
||||||
import java.util.Properties;
|
import java.util.Properties;
|
||||||
|
|
||||||
import org.apache.commons.lang3.StringUtils;
|
import org.apache.commons.lang3.StringUtils;
|
||||||
@ -60,7 +58,6 @@ import com.google.refine.model.ModelException;
|
|||||||
import com.google.refine.model.Project;
|
import com.google.refine.model.Project;
|
||||||
import com.google.refine.model.Row;
|
import com.google.refine.model.Row;
|
||||||
import com.google.refine.tests.RefineTest;
|
import com.google.refine.tests.RefineTest;
|
||||||
import com.google.refine.util.ParsingUtilities;
|
|
||||||
|
|
||||||
public class CsvExporterTests extends RefineTest {
|
public class CsvExporterTests extends RefineTest {
|
||||||
|
|
||||||
@ -198,6 +195,9 @@ public class CsvExporterTests extends RefineTest {
|
|||||||
",row2cell1,row2cell2\n");
|
",row2cell1,row2cell2\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// all date type cells are in unified format
|
||||||
|
/**
|
||||||
|
@Ignore
|
||||||
@Test
|
@Test
|
||||||
public void exportDateColumnsPreVersion28(){
|
public void exportDateColumnsPreVersion28(){
|
||||||
CreateGrid(1,2);
|
CreateGrid(1,2);
|
||||||
@ -219,6 +219,7 @@ public class CsvExporterTests extends RefineTest {
|
|||||||
|
|
||||||
Assert.assertEquals(writer.toString(), expectedOutput);
|
Assert.assertEquals(writer.toString(), expectedOutput);
|
||||||
}
|
}
|
||||||
|
*/
|
||||||
//helper methods
|
//helper methods
|
||||||
|
|
||||||
protected void CreateColumns(int noOfColumns){
|
protected void CreateColumns(int noOfColumns){
|
||||||
|
@ -40,6 +40,7 @@ import static org.mockito.Mockito.when;
|
|||||||
|
|
||||||
import java.io.ByteArrayOutputStream;
|
import java.io.ByteArrayOutputStream;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
|
import java.time.OffsetDateTime;
|
||||||
import java.util.Properties;
|
import java.util.Properties;
|
||||||
|
|
||||||
import org.slf4j.LoggerFactory;
|
import org.slf4j.LoggerFactory;
|
||||||
@ -121,6 +122,20 @@ public class XlsExporterTests extends RefineTest {
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void exportDateType() throws IOException{
|
||||||
|
OffsetDateTime odt = OffsetDateTime.now();
|
||||||
|
createDateGrid(2, 2, odt);
|
||||||
|
|
||||||
|
try {
|
||||||
|
SUT.export(project, options, engine, stream);
|
||||||
|
} catch (IOException e) {
|
||||||
|
Assert.fail();
|
||||||
|
}
|
||||||
|
|
||||||
|
Assert.assertEquals(stream.size(),4096);
|
||||||
|
}
|
||||||
|
|
||||||
@Test(enabled=false)
|
@Test(enabled=false)
|
||||||
public void exportSimpleXlsNoHeader(){
|
public void exportSimpleXlsNoHeader(){
|
||||||
CreateGrid(2, 2);
|
CreateGrid(2, 2);
|
||||||
@ -179,4 +194,16 @@ public class XlsExporterTests extends RefineTest {
|
|||||||
project.rows.add(row);
|
project.rows.add(row);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void createDateGrid(int noOfRows, int noOfColumns, OffsetDateTime now){
|
||||||
|
CreateColumns(noOfColumns);
|
||||||
|
|
||||||
|
for(int i = 0; i < noOfRows; i++){
|
||||||
|
Row row = new Row(noOfColumns);
|
||||||
|
for(int j = 0; j < noOfColumns; j++){
|
||||||
|
row.cells.add(new Cell(now, null));
|
||||||
|
}
|
||||||
|
project.rows.add(row);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -31,7 +31,7 @@ OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|||||||
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
package com.google.refine.tests.expr.functions.strings;
|
package com.google.refine.tests.expr.functions;
|
||||||
|
|
||||||
import java.util.Properties;
|
import java.util.Properties;
|
||||||
|
|
||||||
|
@ -168,15 +168,10 @@ public class DatePartTests extends RefineTest {
|
|||||||
}
|
}
|
||||||
|
|
||||||
private DateTimeFormatter formatter = new DateTimeFormatterBuilder()
|
private DateTimeFormatter formatter = new DateTimeFormatterBuilder()
|
||||||
// here is the same as your code
|
|
||||||
.append(DateTimeFormatter.BASIC_ISO_DATE).appendLiteral('-')
|
.append(DateTimeFormatter.BASIC_ISO_DATE).appendLiteral('-')
|
||||||
// time (hour/minute/seconds)
|
|
||||||
.appendPattern("HH:mm:ss")
|
.appendPattern("HH:mm:ss")
|
||||||
// optional nanos, with 9, 6 or 3 digits
|
.appendPattern("[.SSSSSSSSS][.SSSSSS][.SSS]") // optional nanos, with 9, 6 or 3 digits
|
||||||
.appendPattern("[.SSSSSSSSS][.SSSSSS][.SSS]")
|
|
||||||
// offset
|
|
||||||
.appendOffset("+HH:mm", "Z")
|
.appendOffset("+HH:mm", "Z")
|
||||||
// create formatter
|
|
||||||
.toFormatter();
|
.toFormatter();
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
@ -0,0 +1,108 @@
|
|||||||
|
package com.google.refine.tests.expr.functions.date;
|
||||||
|
|
||||||
|
import java.time.OffsetDateTime;
|
||||||
|
import java.time.format.DateTimeFormatter;
|
||||||
|
import java.time.format.DateTimeFormatterBuilder;
|
||||||
|
import java.time.temporal.ChronoUnit;
|
||||||
|
import java.util.Properties;
|
||||||
|
|
||||||
|
import org.slf4j.LoggerFactory;
|
||||||
|
import org.testng.Assert;
|
||||||
|
import org.testng.annotations.AfterMethod;
|
||||||
|
import org.testng.annotations.BeforeMethod;
|
||||||
|
import org.testng.annotations.BeforeTest;
|
||||||
|
import org.testng.annotations.Test;
|
||||||
|
|
||||||
|
import com.google.refine.expr.EvalError;
|
||||||
|
import com.google.refine.grel.ControlFunctionRegistry;
|
||||||
|
import com.google.refine.grel.Function;
|
||||||
|
import com.google.refine.tests.RefineTest;
|
||||||
|
|
||||||
|
|
||||||
|
public class IncTests extends RefineTest {
|
||||||
|
|
||||||
|
static Properties bindings;
|
||||||
|
|
||||||
|
@Override
|
||||||
|
@BeforeTest
|
||||||
|
public void init() {
|
||||||
|
logger = LoggerFactory.getLogger(this.getClass());
|
||||||
|
}
|
||||||
|
|
||||||
|
@BeforeMethod
|
||||||
|
public void SetUp() {
|
||||||
|
bindings = new Properties();
|
||||||
|
}
|
||||||
|
|
||||||
|
@AfterMethod
|
||||||
|
public void TearDown() {
|
||||||
|
bindings = null;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Lookup a control function by name and invoke it with a variable number of args
|
||||||
|
*/
|
||||||
|
private static Object invoke(String name,Object... args) {
|
||||||
|
// registry uses static initializer, so no need to set it up
|
||||||
|
Function function = ControlFunctionRegistry.getFunction(name);
|
||||||
|
if (function == null) {
|
||||||
|
throw new IllegalArgumentException("Unknown function "+name);
|
||||||
|
}
|
||||||
|
if (args == null) {
|
||||||
|
return function.call(bindings,new Object[0]);
|
||||||
|
} else {
|
||||||
|
return function.call(bindings,args);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private DateTimeFormatter formatter = new DateTimeFormatterBuilder()
|
||||||
|
.append(DateTimeFormatter.BASIC_ISO_DATE).appendLiteral('-')
|
||||||
|
.appendPattern("HH:mm:ss")
|
||||||
|
.appendPattern("[.SSSSSSSSS][.SSSSSS][.SSS]") // optional nanos, with 9, 6 or 3 digits
|
||||||
|
.appendOffset("+HH:mm", "Z")
|
||||||
|
.toFormatter();
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testInc() {
|
||||||
|
OffsetDateTime source = OffsetDateTime.parse("20180510-23:55:44.000789000Z",
|
||||||
|
formatter);
|
||||||
|
|
||||||
|
// add hours
|
||||||
|
Assert.assertTrue(invoke("inc", source, 2, "hours") instanceof OffsetDateTime);
|
||||||
|
Assert.assertEquals(invoke("inc", source, 2, "hours"), source.plus(2, ChronoUnit.HOURS));
|
||||||
|
Assert.assertEquals(invoke("inc", source, 2, "hour"), source.plus(2, ChronoUnit.HOURS));
|
||||||
|
Assert.assertEquals(invoke("inc", source, 2, "h"), source.plus(2, ChronoUnit.HOURS));
|
||||||
|
|
||||||
|
// add years
|
||||||
|
Assert.assertTrue(invoke("inc", source, 2, "year") instanceof OffsetDateTime);
|
||||||
|
Assert.assertEquals(invoke("inc", source, 2, "years"), source.plus(2, ChronoUnit.YEARS));
|
||||||
|
Assert.assertEquals(invoke("inc", source, 2, "year"), source.plus(2, ChronoUnit.YEARS));
|
||||||
|
|
||||||
|
// add months
|
||||||
|
Assert.assertTrue(invoke("inc", source, 2, "months") instanceof OffsetDateTime);
|
||||||
|
Assert.assertEquals(invoke("inc", source, 2, "months"), source.plus(2, ChronoUnit.MONTHS));
|
||||||
|
Assert.assertEquals(invoke("inc", source, 2, "month"), source.plus(2, ChronoUnit.MONTHS));
|
||||||
|
|
||||||
|
// add minutes
|
||||||
|
Assert.assertTrue(invoke("inc", source, 2, "minutes") instanceof OffsetDateTime);
|
||||||
|
Assert.assertEquals(invoke("inc", source, 2, "minutes"), source.plus(2, ChronoUnit.MINUTES));
|
||||||
|
Assert.assertEquals(invoke("inc", source, 2, "minute"), source.plus(2, ChronoUnit.MINUTES));
|
||||||
|
Assert.assertEquals(invoke("inc", source, 2, "min"), source.plus(2, ChronoUnit.MINUTES));
|
||||||
|
|
||||||
|
// add weeks
|
||||||
|
Assert.assertTrue(invoke("inc", source, 2, "weeks") instanceof OffsetDateTime);
|
||||||
|
Assert.assertEquals(invoke("inc", source, 2, "weeks"), source.plus(2, ChronoUnit.WEEKS));
|
||||||
|
Assert.assertEquals(invoke("inc", source, 2, "week"), source.plus(2, ChronoUnit.WEEKS));
|
||||||
|
Assert.assertEquals(invoke("inc", source, 2, "w"), source.plus(2, ChronoUnit.WEEKS));
|
||||||
|
|
||||||
|
// add seconds
|
||||||
|
Assert.assertTrue(invoke("inc", source, 2, "seconds") instanceof OffsetDateTime);
|
||||||
|
Assert.assertEquals(invoke("inc", source, 2, "seconds"), source.plus(2, ChronoUnit.SECONDS));
|
||||||
|
Assert.assertEquals(invoke("inc", source, 2, "sec"), source.plus(2, ChronoUnit.SECONDS));
|
||||||
|
Assert.assertEquals(invoke("inc", source, 2, "s"), source.plus(2, ChronoUnit.SECONDS));
|
||||||
|
|
||||||
|
// exception
|
||||||
|
Assert.assertTrue(invoke("inc", source, 99) instanceof EvalError);
|
||||||
|
Assert.assertTrue(invoke("inc", source.toInstant().toEpochMilli(), 99, "h") instanceof EvalError);
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,72 @@
|
|||||||
|
package com.google.refine.tests.expr.functions.date;
|
||||||
|
|
||||||
|
import java.time.OffsetDateTime;
|
||||||
|
import java.time.format.DateTimeFormatter;
|
||||||
|
import java.time.format.DateTimeFormatterBuilder;
|
||||||
|
import java.util.Properties;
|
||||||
|
|
||||||
|
import org.slf4j.LoggerFactory;
|
||||||
|
import org.testng.Assert;
|
||||||
|
import org.testng.annotations.AfterMethod;
|
||||||
|
import org.testng.annotations.BeforeMethod;
|
||||||
|
import org.testng.annotations.BeforeTest;
|
||||||
|
import org.testng.annotations.Test;
|
||||||
|
|
||||||
|
import com.google.refine.grel.ControlFunctionRegistry;
|
||||||
|
import com.google.refine.grel.Function;
|
||||||
|
import com.google.refine.tests.RefineTest;
|
||||||
|
|
||||||
|
|
||||||
|
public class NowTests extends RefineTest {
|
||||||
|
|
||||||
|
static Properties bindings;
|
||||||
|
|
||||||
|
@Override
|
||||||
|
@BeforeTest
|
||||||
|
public void init() {
|
||||||
|
logger = LoggerFactory.getLogger(this.getClass());
|
||||||
|
}
|
||||||
|
|
||||||
|
@BeforeMethod
|
||||||
|
public void SetUp() {
|
||||||
|
bindings = new Properties();
|
||||||
|
}
|
||||||
|
|
||||||
|
@AfterMethod
|
||||||
|
public void TearDown() {
|
||||||
|
bindings = null;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Lookup a control function by name and invoke it with a variable number of args
|
||||||
|
*/
|
||||||
|
private static Object invoke(String name,Object... args) {
|
||||||
|
// registry uses static initializer, so no need to set it up
|
||||||
|
Function function = ControlFunctionRegistry.getFunction(name);
|
||||||
|
if (function == null) {
|
||||||
|
throw new IllegalArgumentException("Unknown function "+name);
|
||||||
|
}
|
||||||
|
if (args == null) {
|
||||||
|
return function.call(bindings,new Object[0]);
|
||||||
|
} else {
|
||||||
|
return function.call(bindings,args);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private DateTimeFormatter formatter = new DateTimeFormatterBuilder()
|
||||||
|
.append(DateTimeFormatter.BASIC_ISO_DATE).appendLiteral('-')
|
||||||
|
.appendPattern("HH:mm:ss")
|
||||||
|
.appendPattern("[.SSSSSSSSS][.SSSSSS][.SSS]") // optional nanos, with 9, 6 or 3 digits
|
||||||
|
.appendOffset("+HH:mm", "Z")
|
||||||
|
.toFormatter();
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testNow() {
|
||||||
|
// 2018-4-30 23:55:44
|
||||||
|
OffsetDateTime source = OffsetDateTime.parse("20180430-23:55:44.000789000Z",
|
||||||
|
formatter);
|
||||||
|
|
||||||
|
Assert.assertTrue(invoke("now") instanceof OffsetDateTime);
|
||||||
|
Assert.assertTrue(((OffsetDateTime)invoke("now")).isAfter(source));
|
||||||
|
}
|
||||||
|
}
|
@ -1,6 +1,7 @@
|
|||||||
package com.google.refine.tests.expr.functions.strings;
|
package com.google.refine.tests.expr.functions.strings;
|
||||||
|
|
||||||
import java.util.Calendar;
|
import java.time.OffsetDateTime;
|
||||||
|
import java.time.format.DateTimeFormatter;
|
||||||
import java.util.Properties;
|
import java.util.Properties;
|
||||||
|
|
||||||
import org.slf4j.LoggerFactory;
|
import org.slf4j.LoggerFactory;
|
||||||
@ -11,8 +12,6 @@ import org.testng.annotations.BeforeTest;
|
|||||||
import org.testng.annotations.Test;
|
import org.testng.annotations.Test;
|
||||||
|
|
||||||
import com.google.refine.expr.EvalError;
|
import com.google.refine.expr.EvalError;
|
||||||
import com.google.refine.expr.util.CalendarParser;
|
|
||||||
import com.google.refine.expr.util.CalendarParserException;
|
|
||||||
import com.google.refine.grel.ControlFunctionRegistry;
|
import com.google.refine.grel.ControlFunctionRegistry;
|
||||||
import com.google.refine.grel.Function;
|
import com.google.refine.grel.Function;
|
||||||
import com.google.refine.tests.RefineTest;
|
import com.google.refine.tests.RefineTest;
|
||||||
@ -21,21 +20,16 @@ import com.google.refine.tests.RefineTest;
|
|||||||
public class DiffTests extends RefineTest {
|
public class DiffTests extends RefineTest {
|
||||||
|
|
||||||
static Properties bindings;
|
static Properties bindings;
|
||||||
private Calendar date1;
|
|
||||||
private Calendar date2;
|
private OffsetDateTime odt1;
|
||||||
|
private OffsetDateTime odt2;
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@BeforeTest
|
@BeforeTest
|
||||||
public void init() {
|
public void init() {
|
||||||
logger = LoggerFactory.getLogger(this.getClass());
|
logger = LoggerFactory.getLogger(this.getClass());
|
||||||
try {
|
odt1 = OffsetDateTime.parse("2011-09-01T10:15:30+01:00", DateTimeFormatter.ISO_OFFSET_DATE_TIME);
|
||||||
date1 = CalendarParser.parse("2012-08-02");
|
odt2 = OffsetDateTime.parse("2011-12-02T10:16:30+01:00", DateTimeFormatter.ISO_OFFSET_DATE_TIME);
|
||||||
date2 = CalendarParser.parse("2012-10-02");
|
|
||||||
} catch (CalendarParserException e) {
|
|
||||||
// TODO Auto-generated catch block
|
|
||||||
e.printStackTrace();
|
|
||||||
Assert.fail();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@BeforeMethod
|
@BeforeMethod
|
||||||
@ -68,18 +62,20 @@ public class DiffTests extends RefineTest {
|
|||||||
public void testDiffInvalidParams() {
|
public void testDiffInvalidParams() {
|
||||||
Assert.assertTrue(invoke("diff") instanceof EvalError);
|
Assert.assertTrue(invoke("diff") instanceof EvalError);
|
||||||
Assert.assertTrue(invoke("diff", "one","two","three") instanceof EvalError);
|
Assert.assertTrue(invoke("diff", "one","two","three") instanceof EvalError);
|
||||||
Assert.assertTrue(invoke("diff", date1,date2) instanceof EvalError);
|
|
||||||
Assert.assertTrue(invoke("diff", date1,date2,"foo") instanceof EvalError);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testDiff() {
|
public void testDiffString() {
|
||||||
Assert.assertEquals((String)(invoke("diff", "onetwo","onetwothree")),"three");
|
Assert.assertEquals((String)(invoke("diff", "onetwo","onetwothree")),"three");
|
||||||
Assert.assertEquals(invoke("diff",date2,date1,"days"),Long.valueOf(61));
|
}
|
||||||
Assert.assertEquals(invoke("diff",date2,date1,"weeks"),Long.valueOf(8));
|
|
||||||
Assert.assertEquals(invoke("diff",date2,date1,"months"),Long.valueOf(2));
|
|
||||||
Assert.assertEquals(invoke("diff",date2,date1,"hours"),Long.valueOf(1464));
|
|
||||||
Assert.assertEquals(invoke("diff",date2,date1,"seconds"),Long.valueOf(5270400));
|
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testDiffOffsetDateTime() {
|
||||||
|
// OffsetDateTime diff:
|
||||||
|
Assert.assertEquals(invoke("diff",odt2,odt1,"days"),Long.valueOf(92));
|
||||||
|
Assert.assertEquals(invoke("diff",odt2,odt1,"weeks"),Long.valueOf(13));
|
||||||
|
Assert.assertEquals(invoke("diff",odt2,odt1,"months"),Long.valueOf(3));
|
||||||
|
Assert.assertEquals(invoke("diff",odt2,odt1,"hours"),Long.valueOf(2208));
|
||||||
|
Assert.assertEquals(invoke("diff",odt2,odt1,"seconds"),Long.valueOf(7948860));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -33,8 +33,7 @@ OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|||||||
|
|
||||||
package com.google.refine.tests.expr.functions.strings;
|
package com.google.refine.tests.expr.functions.strings;
|
||||||
|
|
||||||
import java.text.DateFormat;
|
import java.time.OffsetDateTime;
|
||||||
import java.util.GregorianCalendar;
|
|
||||||
import java.util.Properties;
|
import java.util.Properties;
|
||||||
|
|
||||||
import org.slf4j.LoggerFactory;
|
import org.slf4j.LoggerFactory;
|
||||||
@ -45,8 +44,8 @@ import org.testng.annotations.BeforeTest;
|
|||||||
import org.testng.annotations.Test;
|
import org.testng.annotations.Test;
|
||||||
|
|
||||||
import com.google.refine.expr.EvalError;
|
import com.google.refine.expr.EvalError;
|
||||||
import com.google.refine.expr.util.CalendarParser;
|
|
||||||
import com.google.refine.expr.util.CalendarParserException;
|
import com.google.refine.expr.util.CalendarParserException;
|
||||||
|
import com.google.refine.expr.util.CalenderParser;
|
||||||
import com.google.refine.grel.ControlFunctionRegistry;
|
import com.google.refine.grel.ControlFunctionRegistry;
|
||||||
import com.google.refine.grel.Function;
|
import com.google.refine.grel.Function;
|
||||||
import com.google.refine.tests.RefineTest;
|
import com.google.refine.tests.RefineTest;
|
||||||
@ -118,11 +117,9 @@ public class ToFromConversionTests extends RefineTest {
|
|||||||
Assert.assertEquals(invoke("toString", Double.valueOf(100.0)),"100.0");
|
Assert.assertEquals(invoke("toString", Double.valueOf(100.0)),"100.0");
|
||||||
Assert.assertEquals(invoke("toString", Double.valueOf(100.0),"%.0f"),"100");
|
Assert.assertEquals(invoke("toString", Double.valueOf(100.0),"%.0f"),"100");
|
||||||
|
|
||||||
String expectedDate = DateFormat.getDateInstance().format(new GregorianCalendar(2013,5,1).getTime());
|
String expectedDate = "2013-06-01T00:00:00Z";
|
||||||
Assert.assertEquals(invoke("toString", CalendarParser.parse("2013-06-01")), expectedDate);
|
Assert.assertEquals(invoke("toString", CalenderParser.parseAsOffsetDateTime("2013-06-01")), expectedDate);
|
||||||
Assert.assertEquals(invoke("toString", CalendarParser.parse("2013-06-01").getTime()), expectedDate);
|
Assert.assertEquals(invoke("toString", CalenderParser.parseAsOffsetDateTime("2013-06-01"),"yyyy-MM-dd"),expectedDate);
|
||||||
Assert.assertEquals(invoke("toString", CalendarParser.parse("2013-06-01"),"yyyy"),"2013");
|
|
||||||
Assert.assertEquals(invoke("toString", CalendarParser.parse("2013-06-01"),"yyyy-MM-dd"),"2013-06-01");
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
@ -132,21 +129,16 @@ public class ToFromConversionTests extends RefineTest {
|
|||||||
Assert.assertTrue(invoke("toDate", "") instanceof EvalError);
|
Assert.assertTrue(invoke("toDate", "") instanceof EvalError);
|
||||||
Assert.assertTrue(invoke("toDate", 1.0) instanceof EvalError);
|
Assert.assertTrue(invoke("toDate", 1.0) instanceof EvalError);
|
||||||
Assert.assertTrue(invoke("toDate", "2012-03-01","xxx") instanceof EvalError); // bad format string
|
Assert.assertTrue(invoke("toDate", "2012-03-01","xxx") instanceof EvalError); // bad format string
|
||||||
Assert.assertTrue(invoke("toDate", "2012-03-01") instanceof GregorianCalendar);
|
Assert.assertTrue(invoke("toDate", "2012-03-01") instanceof OffsetDateTime);
|
||||||
Assert.assertEquals(invoke("toDate", "2012-03-01"),CalendarParser.parse("2012-03-01"));
|
Assert.assertEquals(invoke("toDate", "2012-03-01"),CalenderParser.parseAsOffsetDateTime("2012-03-01"));
|
||||||
Assert.assertEquals(invoke("toDate", "2012-03-01","yyyy-MM-dd"),CalendarParser.parse("2012-03-01"));
|
Assert.assertEquals(invoke("toDate", "2012-03-01","yyyy-MM-dd"),CalenderParser.parseAsOffsetDateTime("2012-03-01"));
|
||||||
// Multiple format strings should get tried sequentially until one succeeds or all are exhausted
|
|
||||||
Assert.assertEquals(invoke("toDate", "2012-03-01","MMM","yyyy-MM-dd"), CalendarParser.parse("2012-03-01"));
|
|
||||||
// First string can be a locale identifier instead of a format string
|
|
||||||
Assert.assertEquals(invoke("toDate", "2013-06-01","zh"), CalendarParser.parse("2013-06-01"));
|
|
||||||
Assert.assertEquals(invoke("toDate", "01-六月-2013","zh","dd-MMM-yyyy"), CalendarParser.parse("2013-06-01"));
|
|
||||||
Assert.assertEquals(invoke("toDate", "01-六月-2013","zh_HK","dd-MMM-yyyy"), CalendarParser.parse("2013-06-01"));
|
|
||||||
Assert.assertEquals(invoke("toDate", "01-六月-2013","zh_TW","dd-MMM-yyyy"), CalendarParser.parse("2013-06-01"));
|
|
||||||
Assert.assertEquals(invoke("toDate", "01-六月-2013","zh_CN","dd-MMM-yyyy"), CalendarParser.parse("2013-06-01"));
|
|
||||||
|
|
||||||
// Date
|
// Multiple format strings should get tried sequentially until one succeeds or all are exhausted
|
||||||
// Calendar
|
Assert.assertEquals(invoke("toDate", "2012-03-01","MMM","yyyy-MM-dd"), CalenderParser.parseAsOffsetDateTime("2012-03-01"));
|
||||||
// String
|
|
||||||
|
// First string can be a locale identifier instead of a format string
|
||||||
|
Assert.assertEquals(invoke("toDate", "2013-06-01","zh"), CalenderParser.parseAsOffsetDateTime("2013-06-01"));
|
||||||
|
Assert.assertEquals(invoke("toDate", "01-六月-2013","zh","dd-MMM-yyyy"), CalenderParser.parseAsOffsetDateTime("2013-06-01"));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
Loading…
Reference in New Issue
Block a user