embulk-output-kintone 0.4.1 → 1.1.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/README.md +63 -5
- data/build.gradle +1 -0
- data/classpath/commons-csv-1.9.0.jar +0 -0
- data/classpath/embulk-output-kintone-1.1.0.jar +0 -0
- data/classpath/externalsortinginjava-0.6.2.jar +0 -0
- data/classpath/{shadow-kintone-java-client-0.4.1-all.jar → shadow-kintone-java-client-1.1.0-all.jar} +0 -0
- data/src/main/java/org/embulk/output/kintone/KintoneColumnOption.java +6 -2
- data/src/main/java/org/embulk/output/kintone/KintoneColumnType.java +572 -0
- data/src/main/java/org/embulk/output/kintone/KintoneColumnVisitor.java +214 -135
- data/src/main/java/org/embulk/output/kintone/KintoneMode.java +0 -1
- data/src/main/java/org/embulk/output/kintone/KintoneOutputPlugin.java +12 -5
- data/src/main/java/org/embulk/output/kintone/KintonePageOutput.java +180 -160
- data/src/main/java/org/embulk/output/kintone/KintoneSortColumn.java +33 -0
- data/src/main/java/org/embulk/output/kintone/PluginTask.java +35 -0
- data/src/main/java/org/embulk/output/kintone/deserializer/DeserializeApplier.java +19 -0
- data/src/main/java/org/embulk/output/kintone/deserializer/DeserializeException.java +7 -0
- data/src/main/java/org/embulk/output/kintone/deserializer/Deserializer.java +279 -0
- data/src/main/java/org/embulk/output/kintone/reducer/CSVInputColumnVisitor.java +78 -0
- data/src/main/java/org/embulk/output/kintone/reducer/CSVOutputColumnVisitor.java +79 -0
- data/src/main/java/org/embulk/output/kintone/reducer/ReduceException.java +11 -0
- data/src/main/java/org/embulk/output/kintone/reducer/ReduceType.java +190 -0
- data/src/main/java/org/embulk/output/kintone/reducer/ReducedPageOutput.java +100 -0
- data/src/main/java/org/embulk/output/kintone/reducer/Reducer.java +355 -0
- data/src/test/java/org/embulk/output/kintone/KintoneColumnOptionBuilder.java +9 -3
- data/src/test/java/org/embulk/output/kintone/KintoneColumnTypeTest.java +194 -0
- data/src/test/java/org/embulk/output/kintone/KintoneColumnVisitorTest.java +703 -61
- data/src/test/java/org/embulk/output/kintone/KintoneColumnVisitorVerifier.java +45 -14
- data/src/test/java/org/embulk/output/kintone/KintonePageOutputVerifier.java +43 -5
- data/src/test/java/org/embulk/output/kintone/TestKintoneOutputPlugin.java +106 -16
- data/src/test/java/org/embulk/output/kintone/TestTaskMode.java +12 -0
- data/src/test/java/org/embulk/output/kintone/TestTaskReduce.java +46 -0
- data/src/test/java/org/embulk/output/kintone/TestTaskReduceException.java +50 -0
- data/src/test/java/org/embulk/output/kintone/TestTaskReduceSubtable.java +46 -0
- data/src/test/java/org/embulk/output/kintone/deserializer/DeserializerTest.java +165 -0
- data/src/test/java/org/embulk/output/kintone/reducer/ReduceTypeTest.java +154 -0
- data/src/test/resources/org/embulk/output/kintone/task/config.yml +1 -1
- data/src/test/resources/org/embulk/output/kintone/task/mode/config.yml +110 -0
- data/src/test/resources/org/embulk/output/kintone/task/mode/input.csv +7 -7
- data/src/test/resources/org/embulk/output/kintone/task/mode/insert_add_ignore_nulls_records.jsonl +6 -0
- data/src/test/resources/org/embulk/output/kintone/task/mode/insert_add_prefer_nulls_records.jsonl +6 -0
- data/src/test/resources/org/embulk/output/kintone/task/mode/insert_add_records.jsonl +6 -6
- data/src/test/resources/org/embulk/output/kintone/task/mode/update_update_ignore_nulls_records.jsonl +3 -0
- data/src/test/resources/org/embulk/output/kintone/task/mode/update_update_prefer_nulls_records.jsonl +3 -0
- data/src/test/resources/org/embulk/output/kintone/task/mode/update_update_records.jsonl +6 -3
- data/src/test/resources/org/embulk/output/kintone/task/mode/upsert_add_ignore_nulls_records.jsonl +3 -0
- data/src/test/resources/org/embulk/output/kintone/task/mode/upsert_add_prefer_nulls_records.jsonl +3 -0
- data/src/test/resources/org/embulk/output/kintone/task/mode/upsert_add_records.jsonl +2 -2
- data/src/test/resources/org/embulk/output/kintone/task/mode/upsert_update_ignore_nulls_records.jsonl +3 -0
- data/src/test/resources/org/embulk/output/kintone/task/mode/upsert_update_prefer_nulls_records.jsonl +3 -0
- data/src/test/resources/org/embulk/output/kintone/task/mode/upsert_update_records.jsonl +4 -4
- data/src/test/resources/org/embulk/output/kintone/task/mode/values_ignore_nulls.json +1 -0
- data/src/test/resources/org/embulk/output/kintone/task/mode/values_prefer_nulls.json +1 -0
- data/src/test/resources/org/embulk/output/kintone/task/reduce/config.yml +171 -0
- data/src/test/resources/org/embulk/output/kintone/task/reduce/input.csv +7 -0
- data/src/test/resources/org/embulk/output/kintone/task/reduce/insert_add_ignore_nulls_records.jsonl +6 -0
- data/src/test/resources/org/embulk/output/kintone/task/reduce/insert_add_prefer_nulls_records.jsonl +6 -0
- data/src/test/resources/org/embulk/output/kintone/task/reduce/insert_add_records.jsonl +6 -0
- data/src/test/resources/org/embulk/output/kintone/task/reduce/update_update_ignore_nulls_records.jsonl +3 -0
- data/src/test/resources/org/embulk/output/kintone/task/reduce/update_update_prefer_nulls_records.jsonl +3 -0
- data/src/test/resources/org/embulk/output/kintone/task/reduce/update_update_records.jsonl +6 -0
- data/src/test/resources/org/embulk/output/kintone/task/reduce/upsert_add_ignore_nulls_records.jsonl +3 -0
- data/src/test/resources/org/embulk/output/kintone/task/reduce/upsert_add_prefer_nulls_records.jsonl +3 -0
- data/src/test/resources/org/embulk/output/kintone/task/reduce/upsert_add_records.jsonl +2 -0
- data/src/test/resources/org/embulk/output/kintone/task/reduce/upsert_update_ignore_nulls_records.jsonl +3 -0
- data/src/test/resources/org/embulk/output/kintone/task/reduce/upsert_update_prefer_nulls_records.jsonl +3 -0
- data/src/test/resources/org/embulk/output/kintone/task/reduce/upsert_update_records.jsonl +4 -0
- data/src/test/resources/org/embulk/output/kintone/task/reduce/values.json +1 -0
- data/src/test/resources/org/embulk/output/kintone/task/reduce/values_ignore_nulls.json +1 -0
- data/src/test/resources/org/embulk/output/kintone/task/reduce/values_prefer_nulls.json +1 -0
- data/src/test/resources/org/embulk/output/kintone/task/reduce_exception/config.yml +36 -0
- data/src/test/resources/org/embulk/output/kintone/task/reduce_exception/derived_columns.json +1 -0
- data/src/test/resources/org/embulk/output/kintone/task/reduce_exception/input.csv +13 -0
- data/src/test/resources/org/embulk/output/kintone/task/reduce_exception/insert_add_records.jsonl +2 -0
- data/src/test/resources/org/embulk/output/kintone/task/reduce_exception/update_update_records.jsonl +2 -0
- data/src/test/resources/org/embulk/output/kintone/task/reduce_subtable/config.yml +343 -0
- data/src/test/resources/org/embulk/output/kintone/task/reduce_subtable/derived_columns.json +1 -0
- data/src/test/resources/org/embulk/output/kintone/task/reduce_subtable/input.csv +13 -0
- data/src/test/resources/org/embulk/output/kintone/task/reduce_subtable/insert_add_ignore_nulls_records.jsonl +6 -0
- data/src/test/resources/org/embulk/output/kintone/task/reduce_subtable/insert_add_prefer_nulls_records.jsonl +6 -0
- data/src/test/resources/org/embulk/output/kintone/task/reduce_subtable/insert_add_records.jsonl +6 -0
- data/src/test/resources/org/embulk/output/kintone/task/reduce_subtable/update_update_ignore_nulls_records.jsonl +3 -0
- data/src/test/resources/org/embulk/output/kintone/task/reduce_subtable/update_update_prefer_nulls_records.jsonl +3 -0
- data/src/test/resources/org/embulk/output/kintone/task/reduce_subtable/update_update_records.jsonl +6 -0
- data/src/test/resources/org/embulk/output/kintone/task/reduce_subtable/upsert_add_ignore_nulls_records.jsonl +3 -0
- data/src/test/resources/org/embulk/output/kintone/task/reduce_subtable/upsert_add_prefer_nulls_records.jsonl +3 -0
- data/src/test/resources/org/embulk/output/kintone/task/reduce_subtable/upsert_add_records.jsonl +0 -0
- data/src/test/resources/org/embulk/output/kintone/task/reduce_subtable/upsert_update_ignore_nulls_records.jsonl +3 -0
- data/src/test/resources/org/embulk/output/kintone/task/reduce_subtable/upsert_update_prefer_nulls_records.jsonl +3 -0
- data/src/test/resources/org/embulk/output/kintone/task/reduce_subtable/upsert_update_records.jsonl +6 -0
- data/src/test/resources/org/embulk/output/kintone/task/reduce_subtable/values.json +1 -0
- data/src/test/resources/org/embulk/output/kintone/task/reduce_subtable/values_ignore_nulls.json +1 -0
- data/src/test/resources/org/embulk/output/kintone/task/reduce_subtable/values_prefer_nulls.json +1 -0
- metadata +73 -4
- data/classpath/embulk-output-kintone-0.4.1.jar +0 -0
@@ -0,0 +1,165 @@
|
|
1
|
+
package org.embulk.output.kintone.deserializer;
|
2
|
+
|
3
|
+
import static org.hamcrest.MatcherAssert.assertThat;
|
4
|
+
import static org.hamcrest.Matchers.is;
|
5
|
+
|
6
|
+
import com.kintone.client.model.FileBody;
|
7
|
+
import com.kintone.client.model.Group;
|
8
|
+
import com.kintone.client.model.Organization;
|
9
|
+
import com.kintone.client.model.User;
|
10
|
+
import com.kintone.client.model.record.CheckBoxFieldValue;
|
11
|
+
import com.kintone.client.model.record.DateFieldValue;
|
12
|
+
import com.kintone.client.model.record.DateTimeFieldValue;
|
13
|
+
import com.kintone.client.model.record.DropDownFieldValue;
|
14
|
+
import com.kintone.client.model.record.FieldValue;
|
15
|
+
import com.kintone.client.model.record.FileFieldValue;
|
16
|
+
import com.kintone.client.model.record.GroupSelectFieldValue;
|
17
|
+
import com.kintone.client.model.record.LinkFieldValue;
|
18
|
+
import com.kintone.client.model.record.MultiLineTextFieldValue;
|
19
|
+
import com.kintone.client.model.record.MultiSelectFieldValue;
|
20
|
+
import com.kintone.client.model.record.NumberFieldValue;
|
21
|
+
import com.kintone.client.model.record.OrganizationSelectFieldValue;
|
22
|
+
import com.kintone.client.model.record.RadioButtonFieldValue;
|
23
|
+
import com.kintone.client.model.record.RichTextFieldValue;
|
24
|
+
import com.kintone.client.model.record.SingleLineTextFieldValue;
|
25
|
+
import com.kintone.client.model.record.SubtableFieldValue;
|
26
|
+
import com.kintone.client.model.record.TableRow;
|
27
|
+
import com.kintone.client.model.record.TimeFieldValue;
|
28
|
+
import com.kintone.client.model.record.UserSelectFieldValue;
|
29
|
+
import java.math.BigDecimal;
|
30
|
+
import java.time.LocalDate;
|
31
|
+
import java.time.LocalTime;
|
32
|
+
import java.time.ZonedDateTime;
|
33
|
+
import java.util.List;
|
34
|
+
import java.util.function.Function;
|
35
|
+
import java.util.stream.IntStream;
|
36
|
+
import org.junit.Test;
|
37
|
+
|
38
|
+
public class DeserializerTest {
|
39
|
+
// spotless:off
|
40
|
+
public static final Function<Long, String> TABLE_ROW = (id) -> String.format("{\"id\":%d,\"value\":{\"リッチエディター\":{\"type\":\"RICH_TEXT\",\"value\":\"\\u003ca href\\u003d\\\"https://www.cybozu.com\\\"\\u003eサイボウズ\\u003c/a\\u003e\"},\"グループ選択\":{\"type\":\"GROUP_SELECT\",\"value\":[{\"name\":\"プロジェクトマネージャー\",\"code\":\"project_manager\"},{\"name\":\"チームリーダー\",\"code\":\"team_leader\"}]},\"文字列(1行)\":{\"type\":\"SINGLE_LINE_TEXT\",\"value\":\"テストです。\"},\"ラジオボタン\":{\"type\":\"RADIO_BUTTON\",\"value\":\"選択肢3\"},\"ドロップダウン\":{\"type\":\"DROP_DOWN\",\"value\":\"選択肢6\"},\"組織選択\":{\"type\":\"ORGANIZATION_SELECT\",\"value\":[{\"name\":\"開発部\",\"code\":\"kaihatsu\"},{\"name\":\"人事部\",\"code\":\"jinji\"}]},\"ユーザー選択\":{\"type\":\"USER_SELECT\",\"value\":[{\"name\":\"Noboru Sato\",\"code\":\"guest/sato@cybozu.com\"},{\"name\":\"Misaki Kato\",\"code\":\"kato\"}]},\"日時\":{\"type\":\"DATETIME\",\"value\":\"2012-01-11T11:30:00Z\"},\"文字列(複数行)\":{\"type\":\"MULTI_LINE_TEXT\",\"value\":\"テスト\\nです。\"},\"時刻\":{\"type\":\"TIME\",\"value\":\"11:30\"},\"チェックボックス\":{\"type\":\"CHECK_BOX\",\"value\":[\"選択肢1\",\"選択肢2\"]},\"複数選択\":{\"type\":\"MULTI_SELECT\",\"value\":[\"選択肢4\",\"選択肢5\"]},\"数値\":{\"type\":\"NUMBER\",\"value\":\"123\"},\"添付ファイル\":{\"type\":\"FILE\",\"value\":[{\"contentType\":\"text/plain\",\"fileKey\":\"201202061155587E339F9067544F1A92C743460E3D12B3297\",\"name\":\"17to20_VerupLog (1).txt\",\"size\":\"23175\"},{\"contentType\":\"application/json\",\"fileKey\":\"201202061155583C763E30196F419E83E91D2E4A03746C273\",\"name\":\"17to20_VerupLog.txt\",\"size\":\"23176\"}]},\"リンク\":{\"type\":\"LINK\",\"value\":\"https://cybozu.co.jp/\"},\"計算\":{\"type\":\"CALC\",\"value\":\"456\"},\"日付\":{\"type\":\"DATE\",\"value\":\"2012-01-11\"}}}", id);
|
41
|
+
private static final String NULL_TABLE_ROW = "{\"value\":{\"添付ファイル(null要素)\":{\"type\":\"FILE\",\"value\":[null,null]},\"添付ファイル(null項目)\":{\"type\":\"FILE\",\"value\":[{},{}]},\"複数選択(空)\":{\"type\":\"MULTI_SELECT\",\"value\":[]},\"リッチエディター\":{\"type\":\"RICH_TEXT\"},\"文字列(1行)\":{\"type\":\"SINGLE_LINE_TEXT\"},\"ユーザー選択(null項目)\":{\"type\":\"USER_SELECT\",\"value\":[{},{}]},\"文字列(複数行)\":{\"type\":\"MULTI_LINE_TEXT\"},\"ユーザー選択(空)\":{\"type\":\"USER_SELECT\",\"value\":[]},\"チェックボックス(null要素)\":{\"type\":\"CHECK_BOX\",\"value\":[null,null]},\"組織選択(null項目)\":{\"type\":\"ORGANIZATION_SELECT\",\"value\":[{},{}]},\"計算\":{\"type\":\"CALC\"},\"日付\":{\"type\":\"DATE\"},\"組織選択(空)\":{\"type\":\"ORGANIZATION_SELECT\",\"value\":[]},\"添付ファイル(空)\":{\"type\":\"FILE\",\"value\":[]},\"ラジオボタン\":{\"type\":\"RADIO_BUTTON\"},\"グループ選択(null項目)\":{\"type\":\"GROUP_SELECT\",\"value\":[{},{}]},\"複数選択(null要素)\":{\"type\":\"MULTI_SELECT\",\"value\":[null,null]},\"ドロップダウン\":{\"type\":\"DROP_DOWN\"},\"日時\":{\"type\":\"DATETIME\"},\"組織選択(null要素)\":{\"type\":\"ORGANIZATION_SELECT\",\"value\":[null,null]},\"時刻\":{\"type\":\"TIME\"},\"グループ選択(空)\":{\"type\":\"GROUP_SELECT\",\"value\":[]},\"数値\":{\"type\":\"NUMBER\"},\"ユーザー選択(null要素)\":{\"type\":\"USER_SELECT\",\"value\":[null,null]},\"グループ選択(null要素)\":{\"type\":\"GROUP_SELECT\",\"value\":[null,null]},\"リンク\":{\"type\":\"LINK\"},\"チェックボックス(空)\":{\"type\":\"CHECK_BOX\",\"value\":[]}}}";
|
42
|
+
// spotless:on
|
43
|
+
@Test
|
44
|
+
public void deserialize() {
|
45
|
+
// spotless:off
|
46
|
+
SubtableFieldValue actual = new Deserializer().deserialize(String.format("[%s,%s]", TABLE_ROW.apply(48290L), TABLE_ROW.apply(48291L)), SubtableFieldValue.class);
|
47
|
+
// spotless:on
|
48
|
+
SubtableFieldValue expected = new SubtableFieldValue(tableRow(48290L), tableRow(48291L));
|
49
|
+
assertTableRows(actual.getRows(), expected.getRows());
|
50
|
+
}
|
51
|
+
|
52
|
+
@Test
|
53
|
+
public void deserializeNull() {
|
54
|
+
// spotless:off
|
55
|
+
SubtableFieldValue actual = new Deserializer().deserialize(String.format("[%s,%s]", NULL_TABLE_ROW, NULL_TABLE_ROW), SubtableFieldValue.class);
|
56
|
+
// spotless:on
|
57
|
+
SubtableFieldValue expected = new SubtableFieldValue(nullTableRow(), nullTableRow());
|
58
|
+
assertTableRows(actual.getRows(), expected.getRows());
|
59
|
+
}
|
60
|
+
|
61
|
+
public static void assertTableRows(List<TableRow> actual, List<TableRow> expected) {
|
62
|
+
assertTableRows("", actual, expected);
|
63
|
+
}
|
64
|
+
|
65
|
+
public static void assertTableRows(
|
66
|
+
String domain, List<TableRow> actual, List<TableRow> expected) {
|
67
|
+
assertThat(domain, actual.size(), is(expected.size()));
|
68
|
+
// spotless:off
|
69
|
+
IntStream.range(0, actual.size()).forEach(index -> assertTableRow(domain, index, actual.get(index), expected.get(index)));
|
70
|
+
// spotless:on
|
71
|
+
}
|
72
|
+
|
73
|
+
private static void assertTableRow(String domain, int index, TableRow actual, TableRow expected) {
|
74
|
+
String reason = String.format("%s:%d", domain, index);
|
75
|
+
assertThat(reason, actual.getId(), is(expected.getId()));
|
76
|
+
assertThat(reason, actual.getFieldCodes(), is(expected.getFieldCodes()));
|
77
|
+
// spotless:off
|
78
|
+
actual.getFieldCodes().forEach(fieldCode -> assertFieldValue(domain, index, fieldCode, actual.getFieldValue(fieldCode), expected.getFieldValue(fieldCode)));
|
79
|
+
// spotless:on
|
80
|
+
}
|
81
|
+
|
82
|
+
private static void assertFieldValue(
|
83
|
+
String domain, int index, String fieldCode, FieldValue actual, FieldValue expected) {
|
84
|
+
String reason = String.format("%s:%d:%s", domain, index, fieldCode);
|
85
|
+
assertThat(reason, actual.getType(), is(expected.getType()));
|
86
|
+
assertThat(reason, actual, is(expected));
|
87
|
+
}
|
88
|
+
|
89
|
+
public static TableRow tableRow(Long id) {
|
90
|
+
TableRow tableRow = new TableRow(id);
|
91
|
+
// spotless:off
|
92
|
+
tableRow.putField("文字列(1行)", new SingleLineTextFieldValue("テストです。"));
|
93
|
+
tableRow.putField("文字列(複数行)", new MultiLineTextFieldValue("テスト\nです。"));
|
94
|
+
tableRow.putField("リッチエディター", new RichTextFieldValue("<a href=\"https://www.cybozu.com\">サイボウズ</a>"));
|
95
|
+
tableRow.putField("数値", new NumberFieldValue(new BigDecimal("123")));
|
96
|
+
tableRow.putField("チェックボックス", new CheckBoxFieldValue("選択肢1", "選択肢2"));
|
97
|
+
tableRow.putField("ラジオボタン", new RadioButtonFieldValue("選択肢3"));
|
98
|
+
tableRow.putField("複数選択", new MultiSelectFieldValue("選択肢4", "選択肢5"));
|
99
|
+
tableRow.putField("ドロップダウン", new DropDownFieldValue("選択肢6"));
|
100
|
+
tableRow.putField("ユーザー選択", new UserSelectFieldValue(user("guest/sato@cybozu.com", "Noboru Sato"), user("kato", "Misaki Kato")));
|
101
|
+
tableRow.putField("組織選択", new OrganizationSelectFieldValue(organization("kaihatsu", "開発部"), organization("jinji", "人事部")));
|
102
|
+
tableRow.putField("グループ選択", new GroupSelectFieldValue(group("project_manager", "プロジェクトマネージャー"), group("team_leader", "チームリーダー")));
|
103
|
+
tableRow.putField("日付", new DateFieldValue(LocalDate.parse("2012-01-11")));
|
104
|
+
tableRow.putField("時刻", new TimeFieldValue(LocalTime.parse("11:30")));
|
105
|
+
tableRow.putField("日時", new DateTimeFieldValue(ZonedDateTime.parse("2012-01-11T11:30:00Z")));
|
106
|
+
tableRow.putField("リンク", new LinkFieldValue("https://cybozu.co.jp/"));
|
107
|
+
tableRow.putField("添付ファイル", new FileFieldValue(fileBody("text/plain", "201202061155587E339F9067544F1A92C743460E3D12B3297", "17to20_VerupLog (1).txt", "23175"), fileBody("application/json", "201202061155583C763E30196F419E83E91D2E4A03746C273", "17to20_VerupLog.txt", "23176")));
|
108
|
+
// spotless:on
|
109
|
+
return tableRow;
|
110
|
+
}
|
111
|
+
|
112
|
+
private static TableRow nullTableRow() {
|
113
|
+
TableRow tableRow = new TableRow();
|
114
|
+
// spotless:off
|
115
|
+
tableRow.putField("文字列(1行)", new SingleLineTextFieldValue(null));
|
116
|
+
tableRow.putField("文字列(複数行)", new MultiLineTextFieldValue(null));
|
117
|
+
tableRow.putField("リッチエディター", new RichTextFieldValue(null));
|
118
|
+
tableRow.putField("数値", new NumberFieldValue(null));
|
119
|
+
tableRow.putField("チェックボックス(空)", new CheckBoxFieldValue());
|
120
|
+
tableRow.putField("チェックボックス(null要素)", new CheckBoxFieldValue(null, null));
|
121
|
+
tableRow.putField("ラジオボタン", new RadioButtonFieldValue(null));
|
122
|
+
tableRow.putField("複数選択(空)", new MultiSelectFieldValue());
|
123
|
+
tableRow.putField("複数選択(null要素)", new MultiSelectFieldValue(null, null));
|
124
|
+
tableRow.putField("ドロップダウン", new DropDownFieldValue(null));
|
125
|
+
tableRow.putField("ユーザー選択(空)", new UserSelectFieldValue());
|
126
|
+
tableRow.putField("ユーザー選択(null要素)", new UserSelectFieldValue(null, null));
|
127
|
+
tableRow.putField("ユーザー選択(null項目)", new UserSelectFieldValue(user(null, null), user(null, null)));
|
128
|
+
tableRow.putField("組織選択(空)", new OrganizationSelectFieldValue());
|
129
|
+
tableRow.putField("組織選択(null要素)", new OrganizationSelectFieldValue(null, null));
|
130
|
+
tableRow.putField("組織選択(null項目)", new OrganizationSelectFieldValue(organization(null, null), organization(null, null)));
|
131
|
+
tableRow.putField("グループ選択(空)", new GroupSelectFieldValue());
|
132
|
+
tableRow.putField("グループ選択(null要素)", new GroupSelectFieldValue(null, null));
|
133
|
+
tableRow.putField("グループ選択(null項目)", new GroupSelectFieldValue(group(null, null), group(null, null)));
|
134
|
+
tableRow.putField("日付", new DateFieldValue(null));
|
135
|
+
tableRow.putField("時刻", new TimeFieldValue(null));
|
136
|
+
tableRow.putField("日時", new DateTimeFieldValue(null));
|
137
|
+
tableRow.putField("リンク", new LinkFieldValue(null));
|
138
|
+
tableRow.putField("添付ファイル(空)", new FileFieldValue());
|
139
|
+
tableRow.putField("添付ファイル(null要素)", new FileFieldValue(null, null));
|
140
|
+
tableRow.putField("添付ファイル(null項目)", new FileFieldValue(fileBody(null, null, null, null), fileBody(null, null, null, null)));
|
141
|
+
// spotless:on
|
142
|
+
return tableRow;
|
143
|
+
}
|
144
|
+
|
145
|
+
private static User user(String code, String name) {
|
146
|
+
return new User(name, code);
|
147
|
+
}
|
148
|
+
|
149
|
+
private static Organization organization(String code, String name) {
|
150
|
+
return new Organization(name, code);
|
151
|
+
}
|
152
|
+
|
153
|
+
private static Group group(String code, String name) {
|
154
|
+
return new Group(name, code);
|
155
|
+
}
|
156
|
+
|
157
|
+
private static FileBody fileBody(String contentType, String fileKey, String name, String size) {
|
158
|
+
FileBody fileBody = new FileBody();
|
159
|
+
fileBody.setContentType(contentType);
|
160
|
+
fileBody.setFileKey(fileKey);
|
161
|
+
fileBody.setName(name);
|
162
|
+
fileBody.setSize(size == null ? null : Integer.valueOf(size));
|
163
|
+
return fileBody;
|
164
|
+
}
|
165
|
+
}
|
@@ -0,0 +1,154 @@
|
|
1
|
+
package org.embulk.output.kintone.reducer;
|
2
|
+
|
3
|
+
import static org.embulk.output.kintone.KintoneColumnType.CHECK_BOX;
|
4
|
+
import static org.embulk.output.kintone.KintoneColumnType.DATE;
|
5
|
+
import static org.embulk.output.kintone.KintoneColumnType.DATETIME;
|
6
|
+
import static org.embulk.output.kintone.KintoneColumnType.DROP_DOWN;
|
7
|
+
import static org.embulk.output.kintone.KintoneColumnType.LINK;
|
8
|
+
import static org.embulk.output.kintone.KintoneColumnType.MULTI_LINE_TEXT;
|
9
|
+
import static org.embulk.output.kintone.KintoneColumnType.MULTI_SELECT;
|
10
|
+
import static org.embulk.output.kintone.KintoneColumnType.NUMBER;
|
11
|
+
import static org.embulk.output.kintone.KintoneColumnType.RADIO_BUTTON;
|
12
|
+
import static org.embulk.output.kintone.KintoneColumnType.RICH_TEXT;
|
13
|
+
import static org.embulk.output.kintone.KintoneColumnType.SINGLE_LINE_TEXT;
|
14
|
+
import static org.embulk.output.kintone.KintoneColumnType.TIME;
|
15
|
+
import static org.embulk.spi.type.Types.BOOLEAN;
|
16
|
+
import static org.embulk.spi.type.Types.DOUBLE;
|
17
|
+
import static org.embulk.spi.type.Types.JSON;
|
18
|
+
import static org.embulk.spi.type.Types.LONG;
|
19
|
+
import static org.embulk.spi.type.Types.STRING;
|
20
|
+
import static org.embulk.spi.type.Types.TIMESTAMP;
|
21
|
+
import static org.hamcrest.MatcherAssert.assertThat;
|
22
|
+
import static org.hamcrest.Matchers.is;
|
23
|
+
|
24
|
+
import java.util.Collections;
|
25
|
+
import org.embulk.output.kintone.KintoneColumnOptionBuilder;
|
26
|
+
import org.embulk.output.kintone.KintoneColumnType;
|
27
|
+
import org.embulk.spi.Column;
|
28
|
+
import org.embulk.spi.type.Type;
|
29
|
+
import org.junit.Test;
|
30
|
+
|
31
|
+
public class ReduceTypeTest {
|
32
|
+
@Test
|
33
|
+
public void value() {
|
34
|
+
// spotless:off
|
35
|
+
assertJson(BOOLEAN, SINGLE_LINE_TEXT, "true", "{\"type\":\"SINGLE_LINE_TEXT\",\"value\":\"true\"}");
|
36
|
+
assertJson(BOOLEAN, NUMBER, "true", "{\"type\":\"NUMBER\",\"value\":\"1\"}");
|
37
|
+
assertJson(LONG, SINGLE_LINE_TEXT, "123", "{\"type\":\"SINGLE_LINE_TEXT\",\"value\":\"123\"}");
|
38
|
+
assertJson(LONG, NUMBER, "123", "{\"type\":\"NUMBER\",\"value\":\"123\"}");
|
39
|
+
assertJson(LONG, DATE, "946684799", "{\"type\":\"DATE\",\"value\":\"1999-12-31\"}");
|
40
|
+
assertJson(LONG, DATE, "Asia/Tokyo", "946684799", "{\"type\":\"DATE\",\"value\":\"2000-01-01\"}");
|
41
|
+
assertJson(LONG, DATE, "US/Pacific", "946684799", "{\"type\":\"DATE\",\"value\":\"1999-12-31\"}");
|
42
|
+
assertJson(LONG, TIME, "946684799", "{\"type\":\"TIME\",\"value\":\"23:59:59\"}");
|
43
|
+
assertJson(LONG, TIME, "Asia/Tokyo", "946684799", "{\"type\":\"TIME\",\"value\":\"08:59:59\"}");
|
44
|
+
assertJson(LONG, TIME, "US/Pacific", "946684799", "{\"type\":\"TIME\",\"value\":\"15:59:59\"}");
|
45
|
+
assertJson(LONG, DATETIME, "946684799", "{\"type\":\"DATETIME\",\"value\":\"1999-12-31T23:59:59Z\"}");
|
46
|
+
assertJson(DOUBLE, SINGLE_LINE_TEXT, "123", "{\"type\":\"SINGLE_LINE_TEXT\",\"value\":\"123.0\"}");
|
47
|
+
assertJson(DOUBLE, NUMBER, "123", "{\"type\":\"NUMBER\",\"value\":\"123.0\"}");
|
48
|
+
assertJson(DOUBLE, DATE, "946684799", "{\"type\":\"DATE\",\"value\":\"1999-12-31\"}");
|
49
|
+
assertJson(DOUBLE, DATE, "Asia/Tokyo", "946684799", "{\"type\":\"DATE\",\"value\":\"2000-01-01\"}");
|
50
|
+
assertJson(DOUBLE, DATE, "US/Pacific", "946684799", "{\"type\":\"DATE\",\"value\":\"1999-12-31\"}");
|
51
|
+
assertJson(DOUBLE, TIME, "946684799", "{\"type\":\"TIME\",\"value\":\"23:59:59\"}");
|
52
|
+
assertJson(DOUBLE, TIME, "Asia/Tokyo", "946684799", "{\"type\":\"TIME\",\"value\":\"08:59:59\"}");
|
53
|
+
assertJson(DOUBLE, TIME, "US/Pacific", "946684799", "{\"type\":\"TIME\",\"value\":\"15:59:59\"}");
|
54
|
+
assertJson(DOUBLE, DATETIME, "946684799", "{\"type\":\"DATETIME\",\"value\":\"1999-12-31T23:59:59Z\"}");
|
55
|
+
assertJson(STRING, SINGLE_LINE_TEXT, "abc", "{\"type\":\"SINGLE_LINE_TEXT\",\"value\":\"abc\"}");
|
56
|
+
assertJson(STRING, MULTI_LINE_TEXT, "abc", "{\"type\":\"MULTI_LINE_TEXT\",\"value\":\"abc\"}");
|
57
|
+
assertJson(STRING, RICH_TEXT, "abc", "{\"type\":\"RICH_TEXT\",\"value\":\"abc\"}");
|
58
|
+
assertJson(STRING, NUMBER, "123", "{\"type\":\"NUMBER\",\"value\":\"123\"}");
|
59
|
+
assertJson(STRING, CHECK_BOX, "123,abc", "{\"type\":\"CHECK_BOX\",\"value\":[\"123\",\"abc\"]}");
|
60
|
+
assertJson(STRING, RADIO_BUTTON, "abc", "{\"type\":\"RADIO_BUTTON\",\"value\":\"abc\"}");
|
61
|
+
assertJson(STRING, MULTI_SELECT, "123,abc", "{\"type\":\"MULTI_SELECT\",\"value\":[\"123\",\"abc\"]}");
|
62
|
+
assertJson(STRING, DROP_DOWN, "abc", "{\"type\":\"DROP_DOWN\",\"value\":\"abc\"}");
|
63
|
+
assertJson(STRING, DATE, "1999-12-31", "{\"type\":\"DATE\",\"value\":\"1999-12-31\"}");
|
64
|
+
assertJson(STRING, DATE, "Asia/Tokyo", "1999-12-31", "{\"type\":\"DATE\",\"value\":\"1999-12-31\"}");
|
65
|
+
assertJson(STRING, DATE, "US/Pacific", "1999-12-31", "{\"type\":\"DATE\",\"value\":\"1999-12-30\"}");
|
66
|
+
assertJson(STRING, TIME, "23:59:59", "{\"type\":\"TIME\",\"value\":\"23:59:59\"}");
|
67
|
+
assertJson(STRING, TIME, "Asia/Tokyo", "23:59:59", "{\"type\":\"TIME\",\"value\":\"08:59:59\"}");
|
68
|
+
assertJson(STRING, TIME, "US/Pacific", "23:59:59", "{\"type\":\"TIME\",\"value\":\"15:59:59\"}");
|
69
|
+
assertJson(STRING, DATETIME, "1999-12-31T23:59:59Z", "{\"type\":\"DATETIME\",\"value\":\"1999-12-31T23:59:59Z\"}");
|
70
|
+
assertJson(STRING, LINK, "abc", "{\"type\":\"LINK\",\"value\":\"abc\"}");
|
71
|
+
assertJson(TIMESTAMP, SINGLE_LINE_TEXT, "1999-12-31T23:59:59Z", "{\"type\":\"SINGLE_LINE_TEXT\",\"value\":\"1999-12-31T23:59:59Z\"}");
|
72
|
+
assertJson(TIMESTAMP, NUMBER, "1999-12-31T23:59:59Z", "{\"type\":\"NUMBER\",\"value\":\"946684799\"}");
|
73
|
+
assertJson(TIMESTAMP, DATE, "1999-12-31T23:59:59Z", "{\"type\":\"DATE\",\"value\":\"1999-12-31\"}");
|
74
|
+
assertJson(TIMESTAMP, DATE, "Asia/Tokyo", "1999-12-31T23:59:59Z", "{\"type\":\"DATE\",\"value\":\"2000-01-01\"}");
|
75
|
+
assertJson(TIMESTAMP, DATE, "US/Pacific", "1999-12-31T23:59:59Z", "{\"type\":\"DATE\",\"value\":\"1999-12-31\"}");
|
76
|
+
assertJson(TIMESTAMP, TIME, "1999-12-31T23:59:59Z", "{\"type\":\"TIME\",\"value\":\"23:59:59\"}");
|
77
|
+
assertJson(TIMESTAMP, TIME, "Asia/Tokyo", "1999-12-31T23:59:59Z", "{\"type\":\"TIME\",\"value\":\"08:59:59\"}");
|
78
|
+
assertJson(TIMESTAMP, TIME, "US/Pacific", "1999-12-31T23:59:59Z", "{\"type\":\"TIME\",\"value\":\"15:59:59\"}");
|
79
|
+
assertJson(TIMESTAMP, DATETIME, "1999-12-31T23:59:59Z", "{\"type\":\"DATETIME\",\"value\":\"1999-12-31T23:59:59Z\"}");
|
80
|
+
assertJson(JSON, SINGLE_LINE_TEXT, "\"abc\"", "{\"type\":\"SINGLE_LINE_TEXT\",\"value\":\"\\\"abc\\\"\"}");
|
81
|
+
assertJson(JSON, MULTI_LINE_TEXT, "\"abc\"", "{\"type\":\"MULTI_LINE_TEXT\",\"value\":\"\\\"abc\\\"\"}");
|
82
|
+
// spotless:on
|
83
|
+
}
|
84
|
+
|
85
|
+
@Test
|
86
|
+
public void valueNull() {
|
87
|
+
assertJson(BOOLEAN, SINGLE_LINE_TEXT, null, "{\"type\":\"SINGLE_LINE_TEXT\",\"value\":null}");
|
88
|
+
assertJson(BOOLEAN, NUMBER, null, "{\"type\":\"NUMBER\",\"value\":null}");
|
89
|
+
assertJson(LONG, SINGLE_LINE_TEXT, null, "{\"type\":\"SINGLE_LINE_TEXT\",\"value\":null}");
|
90
|
+
assertJson(LONG, NUMBER, null, "{\"type\":\"NUMBER\",\"value\":null}");
|
91
|
+
assertJson(LONG, DATE, null, "{\"type\":\"DATE\",\"value\":null}");
|
92
|
+
assertJson(LONG, DATE, "Asia/Tokyo", null, "{\"type\":\"DATE\",\"value\":null}");
|
93
|
+
assertJson(LONG, DATE, "US/Pacific", null, "{\"type\":\"DATE\",\"value\":null}");
|
94
|
+
assertJson(LONG, TIME, null, "{\"type\":\"TIME\",\"value\":null}");
|
95
|
+
assertJson(LONG, TIME, "Asia/Tokyo", null, "{\"type\":\"TIME\",\"value\":null}");
|
96
|
+
assertJson(LONG, TIME, "US/Pacific", null, "{\"type\":\"TIME\",\"value\":null}");
|
97
|
+
assertJson(LONG, DATETIME, null, "{\"type\":\"DATETIME\",\"value\":null}");
|
98
|
+
assertJson(DOUBLE, SINGLE_LINE_TEXT, null, "{\"type\":\"SINGLE_LINE_TEXT\",\"value\":null}");
|
99
|
+
assertJson(DOUBLE, NUMBER, null, "{\"type\":\"NUMBER\",\"value\":null}");
|
100
|
+
assertJson(DOUBLE, DATE, null, "{\"type\":\"DATE\",\"value\":null}");
|
101
|
+
assertJson(DOUBLE, DATE, "Asia/Tokyo", null, "{\"type\":\"DATE\",\"value\":null}");
|
102
|
+
assertJson(DOUBLE, DATE, "US/Pacific", null, "{\"type\":\"DATE\",\"value\":null}");
|
103
|
+
assertJson(DOUBLE, TIME, null, "{\"type\":\"TIME\",\"value\":null}");
|
104
|
+
assertJson(DOUBLE, TIME, "Asia/Tokyo", null, "{\"type\":\"TIME\",\"value\":null}");
|
105
|
+
assertJson(DOUBLE, TIME, "US/Pacific", null, "{\"type\":\"TIME\",\"value\":null}");
|
106
|
+
assertJson(DOUBLE, DATETIME, null, "{\"type\":\"DATETIME\",\"value\":null}");
|
107
|
+
assertJson(STRING, SINGLE_LINE_TEXT, null, "{\"type\":\"SINGLE_LINE_TEXT\",\"value\":null}");
|
108
|
+
assertJson(STRING, MULTI_LINE_TEXT, null, "{\"type\":\"MULTI_LINE_TEXT\",\"value\":null}");
|
109
|
+
assertJson(STRING, RICH_TEXT, null, "{\"type\":\"RICH_TEXT\",\"value\":null}");
|
110
|
+
assertJson(STRING, NUMBER, null, "{\"type\":\"NUMBER\",\"value\":null}");
|
111
|
+
assertJson(STRING, CHECK_BOX, null, "{\"type\":\"CHECK_BOX\",\"value\":null}");
|
112
|
+
assertJson(STRING, RADIO_BUTTON, null, "{\"type\":\"RADIO_BUTTON\",\"value\":null}");
|
113
|
+
assertJson(STRING, MULTI_SELECT, null, "{\"type\":\"MULTI_SELECT\",\"value\":null}");
|
114
|
+
assertJson(STRING, DROP_DOWN, null, "{\"type\":\"DROP_DOWN\",\"value\":null}");
|
115
|
+
assertJson(STRING, DATE, null, "{\"type\":\"DATE\",\"value\":null}");
|
116
|
+
assertJson(STRING, DATE, "Asia/Tokyo", null, "{\"type\":\"DATE\",\"value\":null}");
|
117
|
+
assertJson(STRING, DATE, "US/Pacific", null, "{\"type\":\"DATE\",\"value\":null}");
|
118
|
+
assertJson(STRING, TIME, null, "{\"type\":\"TIME\",\"value\":null}");
|
119
|
+
assertJson(STRING, TIME, "Asia/Tokyo", null, "{\"type\":\"TIME\",\"value\":null}");
|
120
|
+
assertJson(STRING, TIME, "US/Pacific", null, "{\"type\":\"TIME\",\"value\":null}");
|
121
|
+
assertJson(STRING, DATETIME, null, "{\"type\":\"DATETIME\",\"value\":null}");
|
122
|
+
assertJson(STRING, LINK, null, "{\"type\":\"LINK\",\"value\":null}");
|
123
|
+
assertJson(TIMESTAMP, SINGLE_LINE_TEXT, null, "{\"type\":\"SINGLE_LINE_TEXT\",\"value\":null}");
|
124
|
+
assertJson(TIMESTAMP, NUMBER, null, "{\"type\":\"NUMBER\",\"value\":null}");
|
125
|
+
assertJson(TIMESTAMP, DATE, null, "{\"type\":\"DATE\",\"value\":null}");
|
126
|
+
assertJson(TIMESTAMP, DATE, "Asia/Tokyo", null, "{\"type\":\"DATE\",\"value\":null}");
|
127
|
+
assertJson(TIMESTAMP, DATE, "US/Pacific", null, "{\"type\":\"DATE\",\"value\":null}");
|
128
|
+
assertJson(TIMESTAMP, TIME, null, "{\"type\":\"TIME\",\"value\":null}");
|
129
|
+
assertJson(TIMESTAMP, TIME, "Asia/Tokyo", null, "{\"type\":\"TIME\",\"value\":null}");
|
130
|
+
assertJson(TIMESTAMP, TIME, "US/Pacific", null, "{\"type\":\"TIME\",\"value\":null}");
|
131
|
+
assertJson(TIMESTAMP, DATETIME, null, "{\"type\":\"DATETIME\",\"value\":null}");
|
132
|
+
assertJson(JSON, SINGLE_LINE_TEXT, null, "{\"type\":\"SINGLE_LINE_TEXT\",\"value\":null}");
|
133
|
+
assertJson(JSON, MULTI_LINE_TEXT, null, "{\"type\":\"MULTI_LINE_TEXT\",\"value\":null}");
|
134
|
+
}
|
135
|
+
|
136
|
+
private static void assertJson(Type from, KintoneColumnType to, String value, String expected) {
|
137
|
+
assertJson(from, to, "UTC", value, expected);
|
138
|
+
}
|
139
|
+
|
140
|
+
private static void assertJson(
|
141
|
+
Type from, KintoneColumnType to, String timezone, String value, String expected) {
|
142
|
+
assertThat(
|
143
|
+
ReduceType.value(
|
144
|
+
new Column(0, "", from),
|
145
|
+
Collections.singletonList(value),
|
146
|
+
new KintoneColumnOptionBuilder()
|
147
|
+
.setType(to.name())
|
148
|
+
.setTimezone(timezone)
|
149
|
+
.setValueSeparator(",")
|
150
|
+
.build())
|
151
|
+
.toJson(),
|
152
|
+
is(expected));
|
153
|
+
}
|
154
|
+
}
|
@@ -1 +1 @@
|
|
1
|
-
|
1
|
+
max_sort_memory: 67108864
|
@@ -2,36 +2,132 @@ column_options:
|
|
2
2
|
boolean_single_line_text:
|
3
3
|
field_code: boolean_single_line_text
|
4
4
|
type: SINGLE_LINE_TEXT
|
5
|
+
boolean:
|
6
|
+
field_code: boolean
|
7
|
+
type: NUMBER
|
5
8
|
long_single_line_text:
|
6
9
|
field_code: long_single_line_text
|
7
10
|
type: SINGLE_LINE_TEXT
|
8
11
|
long:
|
9
12
|
field_code: long
|
10
13
|
type: NUMBER
|
14
|
+
long_date:
|
15
|
+
field_code: long_date
|
16
|
+
type: DATE
|
17
|
+
long_date_jst:
|
18
|
+
field_code: long_date_jst
|
19
|
+
type: DATE
|
20
|
+
timezone: Asia/Tokyo
|
21
|
+
long_date_pst:
|
22
|
+
field_code: long_date_pst
|
23
|
+
type: DATE
|
24
|
+
timezone: US/Pacific
|
25
|
+
long_time:
|
26
|
+
field_code: long_time
|
27
|
+
type: TIME
|
28
|
+
long_time_jst:
|
29
|
+
field_code: long_time_jst
|
30
|
+
type: TIME
|
31
|
+
timezone: Asia/Tokyo
|
32
|
+
long_time_pst:
|
33
|
+
field_code: long_time_pst
|
34
|
+
type: TIME
|
35
|
+
timezone: US/Pacific
|
36
|
+
long_datetime:
|
37
|
+
field_code: long_datetime
|
38
|
+
type: DATETIME
|
11
39
|
double_single_line_text:
|
12
40
|
field_code: double_single_line_text
|
13
41
|
type: SINGLE_LINE_TEXT
|
14
42
|
double:
|
15
43
|
field_code: double
|
16
44
|
type: NUMBER
|
45
|
+
double_date:
|
46
|
+
field_code: double_date
|
47
|
+
type: DATE
|
48
|
+
double_date_jst:
|
49
|
+
field_code: double_date_jst
|
50
|
+
type: DATE
|
51
|
+
timezone: Asia/Tokyo
|
52
|
+
double_date_pst:
|
53
|
+
field_code: double_date_pst
|
54
|
+
type: DATE
|
55
|
+
timezone: US/Pacific
|
56
|
+
double_time:
|
57
|
+
field_code: double_time
|
58
|
+
type: TIME
|
59
|
+
double_time_jst:
|
60
|
+
field_code: double_time_jst
|
61
|
+
type: TIME
|
62
|
+
timezone: Asia/Tokyo
|
63
|
+
double_time_pst:
|
64
|
+
field_code: double_time_pst
|
65
|
+
type: TIME
|
66
|
+
timezone: US/Pacific
|
67
|
+
double_datetime:
|
68
|
+
field_code: double_datetime
|
69
|
+
type: DATETIME
|
17
70
|
string_single_line_text:
|
18
71
|
field_code: string_single_line_text
|
19
72
|
type: SINGLE_LINE_TEXT
|
20
73
|
string:
|
21
74
|
field_code: string
|
22
75
|
type: MULTI_LINE_TEXT
|
76
|
+
string_rich_text:
|
77
|
+
field_code: string_rich_text
|
78
|
+
type: RICH_TEXT
|
23
79
|
string_number:
|
24
80
|
field_code: string_number
|
25
81
|
type: NUMBER
|
26
82
|
string_check_box:
|
27
83
|
field_code: string_check_box
|
28
84
|
type: CHECK_BOX
|
85
|
+
string_radio_button:
|
86
|
+
field_code: string_radio_button
|
87
|
+
type: RADIO_BUTTON
|
88
|
+
string_multi_select:
|
89
|
+
field_code: string_multi_select
|
90
|
+
type: MULTI_SELECT
|
29
91
|
string_drop_down:
|
30
92
|
field_code: string_drop_down
|
31
93
|
type: DROP_DOWN
|
94
|
+
string_date:
|
95
|
+
field_code: string_date
|
96
|
+
type: DATE
|
97
|
+
string_date_jst:
|
98
|
+
field_code: string_date_jst
|
99
|
+
type: DATE
|
100
|
+
timezone: Asia/Tokyo
|
101
|
+
string_date_pst:
|
102
|
+
field_code: string_date_pst
|
103
|
+
type: DATE
|
104
|
+
timezone: US/Pacific
|
105
|
+
string_time:
|
106
|
+
field_code: string_time
|
107
|
+
type: TIME
|
108
|
+
string_time_jst:
|
109
|
+
field_code: string_time_jst
|
110
|
+
type: TIME
|
111
|
+
timezone: Asia/Tokyo
|
112
|
+
string_time_pst:
|
113
|
+
field_code: string_time_pst
|
114
|
+
type: TIME
|
115
|
+
timezone: US/Pacific
|
116
|
+
string_datetime:
|
117
|
+
field_code: string_datetime
|
118
|
+
type: DATETIME
|
32
119
|
string_link:
|
33
120
|
field_code: string_link
|
34
121
|
type: LINK
|
122
|
+
string_subtable:
|
123
|
+
field_code: string_subtable
|
124
|
+
type: SUBTABLE
|
125
|
+
timestamp_single_line_text:
|
126
|
+
field_code: timestamp_single_line_text
|
127
|
+
type: SINGLE_LINE_TEXT
|
128
|
+
timestamp_number:
|
129
|
+
field_code: timestamp_number
|
130
|
+
type: NUMBER
|
35
131
|
timestamp_date:
|
36
132
|
field_code: timestamp_date
|
37
133
|
type: DATE
|
@@ -43,6 +139,17 @@ column_options:
|
|
43
139
|
field_code: timestamp_date_pst
|
44
140
|
type: DATE
|
45
141
|
timezone: US/Pacific
|
142
|
+
timestamp_time:
|
143
|
+
field_code: timestamp_time
|
144
|
+
type: TIME
|
145
|
+
timestamp_time_jst:
|
146
|
+
field_code: timestamp_time_jst
|
147
|
+
type: TIME
|
148
|
+
timezone: Asia/Tokyo
|
149
|
+
timestamp_time_pst:
|
150
|
+
field_code: timestamp_time_pst
|
151
|
+
type: TIME
|
152
|
+
timezone: US/Pacific
|
46
153
|
timestamp:
|
47
154
|
field_code: timestamp
|
48
155
|
type: DATETIME
|
@@ -52,3 +159,6 @@ column_options:
|
|
52
159
|
json:
|
53
160
|
field_code: json
|
54
161
|
type: MULTI_LINE_TEXT
|
162
|
+
json_subtable:
|
163
|
+
field_code: json_subtable
|
164
|
+
type: SUBTABLE
|
@@ -1,7 +1,7 @@
|
|
1
|
-
boolean_single_line_text:boolean,long_single_line_text:long,long:long,double_single_line_text:double,double:double,string_single_line_text:string,string:string,string_number:string,string_check_box:string,string_drop_down:string,string_link:string,timestamp_date:timestamp,timestamp_date_jst:timestamp,timestamp_date_pst:timestamp,timestamp:timestamp,json_single_line_text:json,json:json
|
2
|
-
|
3
|
-
|
4
|
-
true,123,123,123,123,abc,abc,123,"123,abc",abc,abc,1999-12-31 23:59:59.000 +0000,1999-12-31 23:59:59.000 +0000,1999-12-31 23:59:59.000 +0000,1999-12-31 23:59:59.000 +0000,"""abc""","""abc"""
|
5
|
-
|
6
|
-
|
7
|
-
false,456,456,456,456,def,def,456,"456,def",def,def,2000-01-01 00:00:00.000 +0000,2000-01-01 00:00:00.000 +0000,2000-01-01 00:00:00.000 +0000,2000-01-01 00:00:00.000 +0000,"""def""","""def"""
|
1
|
+
boolean_single_line_text:boolean,boolean:boolean,long_single_line_text:long,long:long,long_date:long,long_date_jst:long,long_date_pst:long,long_time:long,long_time_jst:long,long_time_pst:long,long_datetime:long,double_single_line_text:double,double:double,double_date:double,double_date_jst:double,double_date_pst:double,double_time:double,double_time_jst:double,double_time_pst:double,double_datetime:double,string_single_line_text:string,string:string,string_rich_text:string,string_number:string,string_check_box:string,string_radio_button:string,string_multi_select:string,string_drop_down:string,string_date:string,string_date_jst:string,string_date_pst:string,string_time:string,string_time_jst:string,string_time_pst:string,string_datetime:string,string_link:string,string_subtable:string,timestamp_single_line_text:timestamp,timestamp_number:timestamp,timestamp_date:timestamp,timestamp_date_jst:timestamp,timestamp_date_pst:timestamp,timestamp_time:timestamp,timestamp_time_jst:timestamp,timestamp_time_pst:timestamp,timestamp:timestamp,json_single_line_text:json,json:json,json_subtable:json
|
2
|
+
,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,
|
3
|
+
,,,,,,,,,,,1,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,
|
4
|
+
true,true,123,123,946684799,946684799,946684799,946684799,946684799,946684799,946684799,123,123,946684799,946684799,946684799,946684799,946684799,946684799,946684799,abc,abc,abc,123,"123,abc",abc,"123,abc",abc,1999-12-31,1999-12-31,1999-12-31,23:59:59,23:59:59,23:59:59,1999-12-31T23:59:59Z,abc,[],1999-12-31 23:59:59.000 +0000,1999-12-31 23:59:59.000 +0000,1999-12-31 23:59:59.000 +0000,1999-12-31 23:59:59.000 +0000,1999-12-31 23:59:59.000 +0000,1999-12-31 23:59:59.000 +0000,1999-12-31 23:59:59.000 +0000,1999-12-31 23:59:59.000 +0000,1999-12-31 23:59:59.000 +0000,"""abc""","""abc""",[]
|
5
|
+
,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,
|
6
|
+
,,,,,,,,,,,,,,,,,,,,,,,1,,,,,,,,,,,,,,,,,,,,,,,,,
|
7
|
+
false,false,456,456,946684800,946684800,946684800,946684800,946684800,946684800,946684800,456,456,946684800,946684800,946684800,946684800,946684800,946684800,946684800,def,def,def,456,"456,def",def,"456,def",def,2000-01-01,2000-01-01,2000-01-01,00:00:00,00:00:00,00:00:00,2000-01-01T00:00:00Z,def,[],2000-01-01 00:00:00.000 +0000,2000-01-01 00:00:00.000 +0000,2000-01-01 00:00:00.000 +0000,2000-01-01 00:00:00.000 +0000,2000-01-01 00:00:00.000 +0000,2000-01-01 00:00:00.000 +0000,2000-01-01 00:00:00.000 +0000,2000-01-01 00:00:00.000 +0000,2000-01-01 00:00:00.000 +0000,"""def""","""def""",[]
|
data/src/test/resources/org/embulk/output/kintone/task/mode/insert_add_ignore_nulls_records.jsonl
ADDED
@@ -0,0 +1,6 @@
|
|
1
|
+
{}
|
2
|
+
{"double_single_line_text":{"type":"SINGLE_LINE_TEXT","value":"1.0"}}
|
3
|
+
{"boolean_single_line_text":{"type":"SINGLE_LINE_TEXT","value":"true"},"boolean":{"type":"NUMBER","value":"1"},"long_single_line_text":{"type":"SINGLE_LINE_TEXT","value":"123"},"long":{"type":"NUMBER","value":"123"},"long_date":{"type":"DATE","value":"1999-12-31"},"long_date_jst":{"type":"DATE","value":"2000-01-01"},"long_date_pst":{"type":"DATE","value":"1999-12-31"},"long_time":{"type":"TIME","value":"23:59:59"},"long_time_jst":{"type":"TIME","value":"08:59:59"},"long_time_pst":{"type":"TIME","value":"15:59:59"},"long_datetime":{"type":"DATETIME","value":"1999-12-31T23:59:59Z"},"double_single_line_text":{"type":"SINGLE_LINE_TEXT","value":"123.0"},"double":{"type":"NUMBER","value":"123.0"},"double_date":{"type":"DATE","value":"1999-12-31"},"double_date_jst":{"type":"DATE","value":"2000-01-01"},"double_date_pst":{"type":"DATE","value":"1999-12-31"},"double_time":{"type":"TIME","value":"23:59:59"},"double_time_jst":{"type":"TIME","value":"08:59:59"},"double_time_pst":{"type":"TIME","value":"15:59:59"},"double_datetime":{"type":"DATETIME","value":"1999-12-31T23:59:59Z"},"string_single_line_text":{"type":"SINGLE_LINE_TEXT","value":"abc"},"string":{"type":"MULTI_LINE_TEXT","value":"abc"},"string_rich_text":{"type":"RICH_TEXT","value":"abc"},"string_number":{"type":"NUMBER","value":"123"},"string_check_box":{"type":"CHECK_BOX","value":["123","abc"]},"string_radio_button":{"type":"RADIO_BUTTON","value":"abc"},"string_multi_select":{"type":"MULTI_SELECT","value":["123","abc"]},"string_drop_down":{"type":"DROP_DOWN","value":"abc"},"string_date":{"type":"DATE","value":"1999-12-31"},"string_date_jst":{"type":"DATE","value":"1999-12-31"},"string_date_pst":{"type":"DATE","value":"1999-12-30"},"string_time":{"type":"TIME","value":"23:59:59"},"string_time_jst":{"type":"TIME","value":"08:59:59"},"string_time_pst":{"type":"TIME","value":"15:59:59"},"string_datetime":{"type":"DATETIME","value":"1999-12-31T23:59:59Z"},"string_link":{"type":"LINK","value":"abc"},"string_subtable":{"type":"SUBTABLE","value":[]},"timestamp_single_line_text":{"type":"SINGLE_LINE_TEXT","value":"1999-12-31T23:59:59Z"},"timestamp_number":{"type":"NUMBER","value":"946684799"},"timestamp_date":{"type":"DATE","value":"1999-12-31"},"timestamp_date_jst":{"type":"DATE","value":"2000-01-01"},"timestamp_date_pst":{"type":"DATE","value":"1999-12-31"},"timestamp_time":{"type":"TIME","value":"23:59:59"},"timestamp_time_jst":{"type":"TIME","value":"08:59:59"},"timestamp_time_pst":{"type":"TIME","value":"15:59:59"},"timestamp":{"type":"DATETIME","value":"1999-12-31T23:59:59Z"},"json_single_line_text":{"type":"SINGLE_LINE_TEXT","value":"\"abc\""},"json":{"type":"MULTI_LINE_TEXT","value":"\"abc\""},"json_subtable":{"type":"SUBTABLE","value":[]}}
|
4
|
+
{}
|
5
|
+
{"string_number":{"type":"NUMBER","value":"1"}}
|
6
|
+
{"boolean_single_line_text":{"type":"SINGLE_LINE_TEXT","value":"false"},"boolean":{"type":"NUMBER","value":"0"},"long_single_line_text":{"type":"SINGLE_LINE_TEXT","value":"456"},"long":{"type":"NUMBER","value":"456"},"long_date":{"type":"DATE","value":"2000-01-01"},"long_date_jst":{"type":"DATE","value":"2000-01-01"},"long_date_pst":{"type":"DATE","value":"1999-12-31"},"long_time":{"type":"TIME","value":"00:00:00"},"long_time_jst":{"type":"TIME","value":"09:00:00"},"long_time_pst":{"type":"TIME","value":"16:00:00"},"long_datetime":{"type":"DATETIME","value":"2000-01-01T00:00:00Z"},"double_single_line_text":{"type":"SINGLE_LINE_TEXT","value":"456.0"},"double":{"type":"NUMBER","value":"456.0"},"double_date":{"type":"DATE","value":"2000-01-01"},"double_date_jst":{"type":"DATE","value":"2000-01-01"},"double_date_pst":{"type":"DATE","value":"1999-12-31"},"double_time":{"type":"TIME","value":"00:00:00"},"double_time_jst":{"type":"TIME","value":"09:00:00"},"double_time_pst":{"type":"TIME","value":"16:00:00"},"double_datetime":{"type":"DATETIME","value":"2000-01-01T00:00:00Z"},"string_single_line_text":{"type":"SINGLE_LINE_TEXT","value":"def"},"string":{"type":"MULTI_LINE_TEXT","value":"def"},"string_rich_text":{"type":"RICH_TEXT","value":"def"},"string_number":{"type":"NUMBER","value":"456"},"string_check_box":{"type":"CHECK_BOX","value":["456","def"]},"string_radio_button":{"type":"RADIO_BUTTON","value":"def"},"string_multi_select":{"type":"MULTI_SELECT","value":["456","def"]},"string_drop_down":{"type":"DROP_DOWN","value":"def"},"string_date":{"type":"DATE","value":"2000-01-01"},"string_date_jst":{"type":"DATE","value":"2000-01-01"},"string_date_pst":{"type":"DATE","value":"1999-12-31"},"string_time":{"type":"TIME","value":"00:00:00"},"string_time_jst":{"type":"TIME","value":"09:00:00"},"string_time_pst":{"type":"TIME","value":"16:00:00"},"string_datetime":{"type":"DATETIME","value":"2000-01-01T00:00:00Z"},"string_link":{"type":"LINK","value":"def"},"string_subtable":{"type":"SUBTABLE","value":[]},"timestamp_single_line_text":{"type":"SINGLE_LINE_TEXT","value":"2000-01-01T00:00:00Z"},"timestamp_number":{"type":"NUMBER","value":"946684800"},"timestamp_date":{"type":"DATE","value":"2000-01-01"},"timestamp_date_jst":{"type":"DATE","value":"2000-01-01"},"timestamp_date_pst":{"type":"DATE","value":"1999-12-31"},"timestamp_time":{"type":"TIME","value":"00:00:00"},"timestamp_time_jst":{"type":"TIME","value":"09:00:00"},"timestamp_time_pst":{"type":"TIME","value":"16:00:00"},"timestamp":{"type":"DATETIME","value":"2000-01-01T00:00:00Z"},"json_single_line_text":{"type":"SINGLE_LINE_TEXT","value":"\"def\""},"json":{"type":"MULTI_LINE_TEXT","value":"\"def\""},"json_subtable":{"type":"SUBTABLE","value":[]}}
|
data/src/test/resources/org/embulk/output/kintone/task/mode/insert_add_prefer_nulls_records.jsonl
ADDED
@@ -0,0 +1,6 @@
|
|
1
|
+
{"boolean_single_line_text":{"type":"SINGLE_LINE_TEXT","value":null},"boolean":{"type":"NUMBER","value":null},"long_single_line_text":{"type":"SINGLE_LINE_TEXT","value":null},"long":{"type":"NUMBER","value":null},"long_date":{"type":"DATE","value":null},"long_date_jst":{"type":"DATE","value":null},"long_date_pst":{"type":"DATE","value":null},"long_time":{"type":"TIME","value":null},"long_time_jst":{"type":"TIME","value":null},"long_time_pst":{"type":"TIME","value":null},"long_datetime":{"type":"DATETIME","value":null},"double_single_line_text":{"type":"SINGLE_LINE_TEXT","value":null},"double":{"type":"NUMBER","value":null},"double_date":{"type":"DATE","value":null},"double_date_jst":{"type":"DATE","value":null},"double_date_pst":{"type":"DATE","value":null},"double_time":{"type":"TIME","value":null},"double_time_jst":{"type":"TIME","value":null},"double_time_pst":{"type":"TIME","value":null},"double_datetime":{"type":"DATETIME","value":null},"string_single_line_text":{"type":"SINGLE_LINE_TEXT","value":null},"string":{"type":"MULTI_LINE_TEXT","value":null},"string_rich_text":{"type":"RICH_TEXT","value":null},"string_number":{"type":"NUMBER","value":null},"string_check_box":{"type":"CHECK_BOX","value":[]},"string_radio_button":{"type":"RADIO_BUTTON","value":null},"string_multi_select":{"type":"MULTI_SELECT","value":[]},"string_drop_down":{"type":"DROP_DOWN","value":null},"string_date":{"type":"DATE","value":null},"string_date_jst":{"type":"DATE","value":null},"string_date_pst":{"type":"DATE","value":null},"string_time":{"type":"TIME","value":null},"string_time_jst":{"type":"TIME","value":null},"string_time_pst":{"type":"TIME","value":null},"string_datetime":{"type":"DATETIME","value":null},"string_link":{"type":"LINK","value":null},"string_subtable":{"type":"SUBTABLE","value":[]},"timestamp_single_line_text":{"type":"SINGLE_LINE_TEXT","value":null},"timestamp_number":{"type":"NUMBER","value":null},"timestamp_date":{"type":"DATE","value":null},"timestamp_date_jst":{"type":"DATE","value":null},"timestamp_date_pst":{"type":"DATE","value":null},"timestamp_time":{"type":"TIME","value":null},"timestamp_time_jst":{"type":"TIME","value":null},"timestamp_time_pst":{"type":"TIME","value":null},"timestamp":{"type":"DATETIME","value":null},"json_single_line_text":{"type":"SINGLE_LINE_TEXT","value":null},"json":{"type":"MULTI_LINE_TEXT","value":null},"json_subtable":{"type":"SUBTABLE","value":[]}}
|
2
|
+
{"boolean_single_line_text":{"type":"SINGLE_LINE_TEXT","value":null},"boolean":{"type":"NUMBER","value":null},"long_single_line_text":{"type":"SINGLE_LINE_TEXT","value":null},"long":{"type":"NUMBER","value":null},"long_date":{"type":"DATE","value":null},"long_date_jst":{"type":"DATE","value":null},"long_date_pst":{"type":"DATE","value":null},"long_time":{"type":"TIME","value":null},"long_time_jst":{"type":"TIME","value":null},"long_time_pst":{"type":"TIME","value":null},"long_datetime":{"type":"DATETIME","value":null},"double_single_line_text":{"type":"SINGLE_LINE_TEXT","value":"1.0"},"double":{"type":"NUMBER","value":null},"double_date":{"type":"DATE","value":null},"double_date_jst":{"type":"DATE","value":null},"double_date_pst":{"type":"DATE","value":null},"double_time":{"type":"TIME","value":null},"double_time_jst":{"type":"TIME","value":null},"double_time_pst":{"type":"TIME","value":null},"double_datetime":{"type":"DATETIME","value":null},"string_single_line_text":{"type":"SINGLE_LINE_TEXT","value":null},"string":{"type":"MULTI_LINE_TEXT","value":null},"string_rich_text":{"type":"RICH_TEXT","value":null},"string_number":{"type":"NUMBER","value":null},"string_check_box":{"type":"CHECK_BOX","value":[]},"string_radio_button":{"type":"RADIO_BUTTON","value":null},"string_multi_select":{"type":"MULTI_SELECT","value":[]},"string_drop_down":{"type":"DROP_DOWN","value":null},"string_date":{"type":"DATE","value":null},"string_date_jst":{"type":"DATE","value":null},"string_date_pst":{"type":"DATE","value":null},"string_time":{"type":"TIME","value":null},"string_time_jst":{"type":"TIME","value":null},"string_time_pst":{"type":"TIME","value":null},"string_datetime":{"type":"DATETIME","value":null},"string_link":{"type":"LINK","value":null},"string_subtable":{"type":"SUBTABLE","value":[]},"timestamp_single_line_text":{"type":"SINGLE_LINE_TEXT","value":null},"timestamp_number":{"type":"NUMBER","value":null},"timestamp_date":{"type":"DATE","value":null},"timestamp_date_jst":{"type":"DATE","value":null},"timestamp_date_pst":{"type":"DATE","value":null},"timestamp_time":{"type":"TIME","value":null},"timestamp_time_jst":{"type":"TIME","value":null},"timestamp_time_pst":{"type":"TIME","value":null},"timestamp":{"type":"DATETIME","value":null},"json_single_line_text":{"type":"SINGLE_LINE_TEXT","value":null},"json":{"type":"MULTI_LINE_TEXT","value":null},"json_subtable":{"type":"SUBTABLE","value":[]}}
|
3
|
+
{"boolean_single_line_text":{"type":"SINGLE_LINE_TEXT","value":"true"},"boolean":{"type":"NUMBER","value":"1"},"long_single_line_text":{"type":"SINGLE_LINE_TEXT","value":"123"},"long":{"type":"NUMBER","value":"123"},"long_date":{"type":"DATE","value":"1999-12-31"},"long_date_jst":{"type":"DATE","value":"2000-01-01"},"long_date_pst":{"type":"DATE","value":"1999-12-31"},"long_time":{"type":"TIME","value":"23:59:59"},"long_time_jst":{"type":"TIME","value":"08:59:59"},"long_time_pst":{"type":"TIME","value":"15:59:59"},"long_datetime":{"type":"DATETIME","value":"1999-12-31T23:59:59Z"},"double_single_line_text":{"type":"SINGLE_LINE_TEXT","value":"123.0"},"double":{"type":"NUMBER","value":"123.0"},"double_date":{"type":"DATE","value":"1999-12-31"},"double_date_jst":{"type":"DATE","value":"2000-01-01"},"double_date_pst":{"type":"DATE","value":"1999-12-31"},"double_time":{"type":"TIME","value":"23:59:59"},"double_time_jst":{"type":"TIME","value":"08:59:59"},"double_time_pst":{"type":"TIME","value":"15:59:59"},"double_datetime":{"type":"DATETIME","value":"1999-12-31T23:59:59Z"},"string_single_line_text":{"type":"SINGLE_LINE_TEXT","value":"abc"},"string":{"type":"MULTI_LINE_TEXT","value":"abc"},"string_rich_text":{"type":"RICH_TEXT","value":"abc"},"string_number":{"type":"NUMBER","value":"123"},"string_check_box":{"type":"CHECK_BOX","value":["123","abc"]},"string_radio_button":{"type":"RADIO_BUTTON","value":"abc"},"string_multi_select":{"type":"MULTI_SELECT","value":["123","abc"]},"string_drop_down":{"type":"DROP_DOWN","value":"abc"},"string_date":{"type":"DATE","value":"1999-12-31"},"string_date_jst":{"type":"DATE","value":"1999-12-31"},"string_date_pst":{"type":"DATE","value":"1999-12-30"},"string_time":{"type":"TIME","value":"23:59:59"},"string_time_jst":{"type":"TIME","value":"08:59:59"},"string_time_pst":{"type":"TIME","value":"15:59:59"},"string_datetime":{"type":"DATETIME","value":"1999-12-31T23:59:59Z"},"string_link":{"type":"LINK","value":"abc"},"string_subtable":{"type":"SUBTABLE","value":[]},"timestamp_single_line_text":{"type":"SINGLE_LINE_TEXT","value":"1999-12-31T23:59:59Z"},"timestamp_number":{"type":"NUMBER","value":"946684799"},"timestamp_date":{"type":"DATE","value":"1999-12-31"},"timestamp_date_jst":{"type":"DATE","value":"2000-01-01"},"timestamp_date_pst":{"type":"DATE","value":"1999-12-31"},"timestamp_time":{"type":"TIME","value":"23:59:59"},"timestamp_time_jst":{"type":"TIME","value":"08:59:59"},"timestamp_time_pst":{"type":"TIME","value":"15:59:59"},"timestamp":{"type":"DATETIME","value":"1999-12-31T23:59:59Z"},"json_single_line_text":{"type":"SINGLE_LINE_TEXT","value":"\"abc\""},"json":{"type":"MULTI_LINE_TEXT","value":"\"abc\""},"json_subtable":{"type":"SUBTABLE","value":[]}}
|
4
|
+
{"boolean_single_line_text":{"type":"SINGLE_LINE_TEXT","value":null},"boolean":{"type":"NUMBER","value":null},"long_single_line_text":{"type":"SINGLE_LINE_TEXT","value":null},"long":{"type":"NUMBER","value":null},"long_date":{"type":"DATE","value":null},"long_date_jst":{"type":"DATE","value":null},"long_date_pst":{"type":"DATE","value":null},"long_time":{"type":"TIME","value":null},"long_time_jst":{"type":"TIME","value":null},"long_time_pst":{"type":"TIME","value":null},"long_datetime":{"type":"DATETIME","value":null},"double_single_line_text":{"type":"SINGLE_LINE_TEXT","value":null},"double":{"type":"NUMBER","value":null},"double_date":{"type":"DATE","value":null},"double_date_jst":{"type":"DATE","value":null},"double_date_pst":{"type":"DATE","value":null},"double_time":{"type":"TIME","value":null},"double_time_jst":{"type":"TIME","value":null},"double_time_pst":{"type":"TIME","value":null},"double_datetime":{"type":"DATETIME","value":null},"string_single_line_text":{"type":"SINGLE_LINE_TEXT","value":null},"string":{"type":"MULTI_LINE_TEXT","value":null},"string_rich_text":{"type":"RICH_TEXT","value":null},"string_number":{"type":"NUMBER","value":null},"string_check_box":{"type":"CHECK_BOX","value":[]},"string_radio_button":{"type":"RADIO_BUTTON","value":null},"string_multi_select":{"type":"MULTI_SELECT","value":[]},"string_drop_down":{"type":"DROP_DOWN","value":null},"string_date":{"type":"DATE","value":null},"string_date_jst":{"type":"DATE","value":null},"string_date_pst":{"type":"DATE","value":null},"string_time":{"type":"TIME","value":null},"string_time_jst":{"type":"TIME","value":null},"string_time_pst":{"type":"TIME","value":null},"string_datetime":{"type":"DATETIME","value":null},"string_link":{"type":"LINK","value":null},"string_subtable":{"type":"SUBTABLE","value":[]},"timestamp_single_line_text":{"type":"SINGLE_LINE_TEXT","value":null},"timestamp_number":{"type":"NUMBER","value":null},"timestamp_date":{"type":"DATE","value":null},"timestamp_date_jst":{"type":"DATE","value":null},"timestamp_date_pst":{"type":"DATE","value":null},"timestamp_time":{"type":"TIME","value":null},"timestamp_time_jst":{"type":"TIME","value":null},"timestamp_time_pst":{"type":"TIME","value":null},"timestamp":{"type":"DATETIME","value":null},"json_single_line_text":{"type":"SINGLE_LINE_TEXT","value":null},"json":{"type":"MULTI_LINE_TEXT","value":null},"json_subtable":{"type":"SUBTABLE","value":[]}}
|
5
|
+
{"boolean_single_line_text":{"type":"SINGLE_LINE_TEXT","value":null},"boolean":{"type":"NUMBER","value":null},"long_single_line_text":{"type":"SINGLE_LINE_TEXT","value":null},"long":{"type":"NUMBER","value":null},"long_date":{"type":"DATE","value":null},"long_date_jst":{"type":"DATE","value":null},"long_date_pst":{"type":"DATE","value":null},"long_time":{"type":"TIME","value":null},"long_time_jst":{"type":"TIME","value":null},"long_time_pst":{"type":"TIME","value":null},"long_datetime":{"type":"DATETIME","value":null},"double_single_line_text":{"type":"SINGLE_LINE_TEXT","value":null},"double":{"type":"NUMBER","value":null},"double_date":{"type":"DATE","value":null},"double_date_jst":{"type":"DATE","value":null},"double_date_pst":{"type":"DATE","value":null},"double_time":{"type":"TIME","value":null},"double_time_jst":{"type":"TIME","value":null},"double_time_pst":{"type":"TIME","value":null},"double_datetime":{"type":"DATETIME","value":null},"string_single_line_text":{"type":"SINGLE_LINE_TEXT","value":null},"string":{"type":"MULTI_LINE_TEXT","value":null},"string_rich_text":{"type":"RICH_TEXT","value":null},"string_number":{"type":"NUMBER","value":"1"},"string_check_box":{"type":"CHECK_BOX","value":[]},"string_radio_button":{"type":"RADIO_BUTTON","value":null},"string_multi_select":{"type":"MULTI_SELECT","value":[]},"string_drop_down":{"type":"DROP_DOWN","value":null},"string_date":{"type":"DATE","value":null},"string_date_jst":{"type":"DATE","value":null},"string_date_pst":{"type":"DATE","value":null},"string_time":{"type":"TIME","value":null},"string_time_jst":{"type":"TIME","value":null},"string_time_pst":{"type":"TIME","value":null},"string_datetime":{"type":"DATETIME","value":null},"string_link":{"type":"LINK","value":null},"string_subtable":{"type":"SUBTABLE","value":[]},"timestamp_single_line_text":{"type":"SINGLE_LINE_TEXT","value":null},"timestamp_number":{"type":"NUMBER","value":null},"timestamp_date":{"type":"DATE","value":null},"timestamp_date_jst":{"type":"DATE","value":null},"timestamp_date_pst":{"type":"DATE","value":null},"timestamp_time":{"type":"TIME","value":null},"timestamp_time_jst":{"type":"TIME","value":null},"timestamp_time_pst":{"type":"TIME","value":null},"timestamp":{"type":"DATETIME","value":null},"json_single_line_text":{"type":"SINGLE_LINE_TEXT","value":null},"json":{"type":"MULTI_LINE_TEXT","value":null},"json_subtable":{"type":"SUBTABLE","value":[]}}
|
6
|
+
{"boolean_single_line_text":{"type":"SINGLE_LINE_TEXT","value":"false"},"boolean":{"type":"NUMBER","value":"0"},"long_single_line_text":{"type":"SINGLE_LINE_TEXT","value":"456"},"long":{"type":"NUMBER","value":"456"},"long_date":{"type":"DATE","value":"2000-01-01"},"long_date_jst":{"type":"DATE","value":"2000-01-01"},"long_date_pst":{"type":"DATE","value":"1999-12-31"},"long_time":{"type":"TIME","value":"00:00:00"},"long_time_jst":{"type":"TIME","value":"09:00:00"},"long_time_pst":{"type":"TIME","value":"16:00:00"},"long_datetime":{"type":"DATETIME","value":"2000-01-01T00:00:00Z"},"double_single_line_text":{"type":"SINGLE_LINE_TEXT","value":"456.0"},"double":{"type":"NUMBER","value":"456.0"},"double_date":{"type":"DATE","value":"2000-01-01"},"double_date_jst":{"type":"DATE","value":"2000-01-01"},"double_date_pst":{"type":"DATE","value":"1999-12-31"},"double_time":{"type":"TIME","value":"00:00:00"},"double_time_jst":{"type":"TIME","value":"09:00:00"},"double_time_pst":{"type":"TIME","value":"16:00:00"},"double_datetime":{"type":"DATETIME","value":"2000-01-01T00:00:00Z"},"string_single_line_text":{"type":"SINGLE_LINE_TEXT","value":"def"},"string":{"type":"MULTI_LINE_TEXT","value":"def"},"string_rich_text":{"type":"RICH_TEXT","value":"def"},"string_number":{"type":"NUMBER","value":"456"},"string_check_box":{"type":"CHECK_BOX","value":["456","def"]},"string_radio_button":{"type":"RADIO_BUTTON","value":"def"},"string_multi_select":{"type":"MULTI_SELECT","value":["456","def"]},"string_drop_down":{"type":"DROP_DOWN","value":"def"},"string_date":{"type":"DATE","value":"2000-01-01"},"string_date_jst":{"type":"DATE","value":"2000-01-01"},"string_date_pst":{"type":"DATE","value":"1999-12-31"},"string_time":{"type":"TIME","value":"00:00:00"},"string_time_jst":{"type":"TIME","value":"09:00:00"},"string_time_pst":{"type":"TIME","value":"16:00:00"},"string_datetime":{"type":"DATETIME","value":"2000-01-01T00:00:00Z"},"string_link":{"type":"LINK","value":"def"},"string_subtable":{"type":"SUBTABLE","value":[]},"timestamp_single_line_text":{"type":"SINGLE_LINE_TEXT","value":"2000-01-01T00:00:00Z"},"timestamp_number":{"type":"NUMBER","value":"946684800"},"timestamp_date":{"type":"DATE","value":"2000-01-01"},"timestamp_date_jst":{"type":"DATE","value":"2000-01-01"},"timestamp_date_pst":{"type":"DATE","value":"1999-12-31"},"timestamp_time":{"type":"TIME","value":"00:00:00"},"timestamp_time_jst":{"type":"TIME","value":"09:00:00"},"timestamp_time_pst":{"type":"TIME","value":"16:00:00"},"timestamp":{"type":"DATETIME","value":"2000-01-01T00:00:00Z"},"json_single_line_text":{"type":"SINGLE_LINE_TEXT","value":"\"def\""},"json":{"type":"MULTI_LINE_TEXT","value":"\"def\""},"json_subtable":{"type":"SUBTABLE","value":[]}}
|