JsonlReaderTest.java
/*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package tech.tablesaw.io.jsonl;
import static org.junit.jupiter.api.Assertions.assertEquals;
import org.junit.jupiter.api.Test;
import tech.tablesaw.api.ColumnType;
import tech.tablesaw.api.IntColumn;
import tech.tablesaw.api.Table;
public class JsonlReaderTest {
@Test
public void arrayOfNestedObjects() {
String json =
"{\"a\":1453438800000,\"b\":{\"c\":-2.1448117025014}}\n" //
+ "{\"a\":1454043600000,\"b\":{\"c\":-2.9763153817574}}\n" //
+ "{\"a\":1454648400000,\"b\":{\"c\":-2.9545283436391}}";
Table table = Table.read().string(json, "jsonl");
assertEquals(2, table.columnCount());
assertEquals(3, table.rowCount());
assertEquals("a", table.column(0).name());
assertEquals("b.c", table.column(1).name());
assertEquals(ColumnType.LONG, table.typeArray()[0]);
}
@Test
public void arrayOfRowsWithIncompleteIndexes() {
String json =
"{\"A\" : \"123\", \"B\" : \"456\"}\n" //
+ "{\"B\" : \"789\", \"C\" : \"123\"}";
Table expected =
Table.create(
IntColumn.create("A", new int[] {123, Integer.MIN_VALUE}),
IntColumn.create("B", new int[] {456, 789}),
IntColumn.create("C", new int[] {Integer.MIN_VALUE, 123}));
Table actual = Table.read().string(json, "jsonl");
assertEquals(ColumnType.INTEGER, actual.typeArray()[0]);
assertEquals(expected.column("A").asList(), actual.column("A").asList());
assertEquals(expected.column("B").asList(), actual.column("B").asList());
assertEquals(expected.column("C").asList(), actual.column("C").asList());
}
}