use of bio.terra.model.IntPartitionOptionsModel in project jade-data-repo by DataBiosphere.
the class DatasetRequestValidator method validateTable.
private void validateTable(TableModel table, Errors errors, SchemaValidationContext context) {
String tableName = table.getName();
List<ColumnModel> columns = table.getColumns();
List<String> primaryKeyList = table.getPrimaryKey();
if (tableName != null && columns != null) {
List<String> columnNames = columns.stream().map(ColumnModel::getName).collect(toList());
if (ValidationUtils.hasDuplicates(columnNames)) {
errors.rejectValue("schema", "DuplicateColumnNames");
}
if (primaryKeyList != null) {
if (!columnNames.containsAll(primaryKeyList)) {
errors.rejectValue("schema", "MissingPrimaryKeyColumn");
}
for (ColumnModel column : columns) {
if (primaryKeyList.contains(column.getName()) && column.isArrayOf()) {
errors.rejectValue("schema", "PrimaryKeyArrayColumn");
}
}
}
context.addTable(tableName, columns);
}
TableModel.PartitionModeEnum mode = table.getPartitionMode();
DatePartitionOptionsModel dateOptions = table.getDatePartitionOptions();
IntPartitionOptionsModel intOptions = table.getIntPartitionOptions();
if (mode == TableModel.PartitionModeEnum.DATE) {
if (dateOptions == null) {
errors.rejectValue("schema", "MissingDatePartitionOptions", "datePartitionOptions must be specified when using 'date' partitionMode");
} else {
validateDatePartitionOptions(dateOptions, columns, errors);
}
} else if (dateOptions != null) {
errors.rejectValue("schema", "InvalidDatePartitionOptions", "datePartitionOptions can only be specified when using 'date' partitionMode");
}
if (mode == TableModel.PartitionModeEnum.INT) {
if (intOptions == null) {
errors.rejectValue("schema", "MissingIntPartitionOptions", "intPartitionOptions must be specified when using 'int' partitionMode");
} else {
validateIntPartitionOptions(intOptions, columns, errors);
}
} else if (intOptions != null) {
errors.rejectValue("schema", "InvalidIntPartitionOptions", "intPartitionOptions can only be specified when using 'int' partitionMode");
}
}
use of bio.terra.model.IntPartitionOptionsModel in project jade-data-repo by DataBiosphere.
the class DatasetValidationsTest method testPartitionOptionsWithoutMode.
@Test
public void testPartitionOptionsWithoutMode() throws Exception {
TableModel table = new TableModel().name("table").columns(Collections.emptyList()).datePartitionOptions(new DatePartitionOptionsModel().column("foo")).intPartitionOptions(new IntPartitionOptionsModel().column("bar").min(1L).max(2L).interval(1L));
DatasetRequestModel req = buildDatasetRequest();
req.getSchema().tables(Collections.singletonList(table)).relationships(Collections.emptyList()).assets(Collections.emptyList());
ErrorModel errorModel = expectBadDatasetCreateRequest(req);
checkValidationErrorModel(errorModel, new String[] { "InvalidDatePartitionOptions", "InvalidIntPartitionOptions" });
}
use of bio.terra.model.IntPartitionOptionsModel in project jade-data-repo by DataBiosphere.
the class DatasetValidationsTest method testIntPartitionWithMissingColumn.
@Test
public void testIntPartitionWithMissingColumn() throws Exception {
TableModel table = new TableModel().name("table").columns(Collections.emptyList()).partitionMode(TableModel.PartitionModeEnum.INT).intPartitionOptions(new IntPartitionOptionsModel().column("not_a_column").min(1L).max(2L).interval(1L));
DatasetRequestModel req = buildDatasetRequest();
req.getSchema().tables(Collections.singletonList(table)).relationships(Collections.emptyList()).assets(Collections.emptyList());
ErrorModel errorModel = expectBadDatasetCreateRequest(req);
checkValidationErrorModel(errorModel, new String[] { "InvalidIntPartitionColumnName" });
}
use of bio.terra.model.IntPartitionOptionsModel in project jade-data-repo by DataBiosphere.
the class DatasetValidationsTest method testDatePartitionWithBadOptions.
@Test
public void testDatePartitionWithBadOptions() throws Exception {
TableModel table = new TableModel().name("table").columns(Collections.emptyList()).partitionMode(TableModel.PartitionModeEnum.DATE).intPartitionOptions(new IntPartitionOptionsModel().column("foo").min(1L).max(2L).interval(1L));
DatasetRequestModel req = buildDatasetRequest();
req.getSchema().tables(Collections.singletonList(table)).relationships(Collections.emptyList()).assets(Collections.emptyList());
ErrorModel errorModel = expectBadDatasetCreateRequest(req);
checkValidationErrorModel(errorModel, new String[] { "MissingDatePartitionOptions", "InvalidIntPartitionOptions" });
}
use of bio.terra.model.IntPartitionOptionsModel in project jade-data-repo by DataBiosphere.
the class DatasetValidationsTest method testIntPartitionWithBadRange.
@Test
public void testIntPartitionWithBadRange() throws Exception {
ColumnModel column = new ColumnModel().name("column").datatype("int64");
TableModel table = new TableModel().name("table").columns(Collections.singletonList(column)).partitionMode(TableModel.PartitionModeEnum.INT).intPartitionOptions(new IntPartitionOptionsModel().column(column.getName()).min(5L).max(2L).interval(-1L));
DatasetRequestModel req = buildDatasetRequest();
req.getSchema().tables(Collections.singletonList(table)).relationships(Collections.emptyList()).assets(Collections.emptyList());
ErrorModel errorModel = expectBadDatasetCreateRequest(req);
checkValidationErrorModel(errorModel, new String[] { "InvalidIntPartitionRange", "InvalidIntPartitionInterval" });
}
Aggregations