Search in sources :

Example 1 with IntPartitionOptionsModel

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");
    }
}
Also used : IntPartitionOptionsModel(bio.terra.model.IntPartitionOptionsModel) DatePartitionOptionsModel(bio.terra.model.DatePartitionOptionsModel) ColumnModel(bio.terra.model.ColumnModel) TableModel(bio.terra.model.TableModel) AssetTableModel(bio.terra.model.AssetTableModel)

Example 2 with IntPartitionOptionsModel

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" });
}
Also used : IntPartitionOptionsModel(bio.terra.model.IntPartitionOptionsModel) DatasetRequestModel(bio.terra.model.DatasetRequestModel) DatePartitionOptionsModel(bio.terra.model.DatePartitionOptionsModel) ErrorModel(bio.terra.model.ErrorModel) TableModel(bio.terra.model.TableModel) AssetTableModel(bio.terra.model.AssetTableModel) Test(org.junit.Test) SpringBootTest(org.springframework.boot.test.context.SpringBootTest)

Example 3 with IntPartitionOptionsModel

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" });
}
Also used : IntPartitionOptionsModel(bio.terra.model.IntPartitionOptionsModel) DatasetRequestModel(bio.terra.model.DatasetRequestModel) ErrorModel(bio.terra.model.ErrorModel) TableModel(bio.terra.model.TableModel) AssetTableModel(bio.terra.model.AssetTableModel) Test(org.junit.Test) SpringBootTest(org.springframework.boot.test.context.SpringBootTest)

Example 4 with IntPartitionOptionsModel

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" });
}
Also used : IntPartitionOptionsModel(bio.terra.model.IntPartitionOptionsModel) DatasetRequestModel(bio.terra.model.DatasetRequestModel) ErrorModel(bio.terra.model.ErrorModel) TableModel(bio.terra.model.TableModel) AssetTableModel(bio.terra.model.AssetTableModel) Test(org.junit.Test) SpringBootTest(org.springframework.boot.test.context.SpringBootTest)

Example 5 with IntPartitionOptionsModel

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" });
}
Also used : IntPartitionOptionsModel(bio.terra.model.IntPartitionOptionsModel) DatasetRequestModel(bio.terra.model.DatasetRequestModel) ErrorModel(bio.terra.model.ErrorModel) ColumnModel(bio.terra.model.ColumnModel) TableModel(bio.terra.model.TableModel) AssetTableModel(bio.terra.model.AssetTableModel) Test(org.junit.Test) SpringBootTest(org.springframework.boot.test.context.SpringBootTest)

Aggregations

AssetTableModel (bio.terra.model.AssetTableModel)7 IntPartitionOptionsModel (bio.terra.model.IntPartitionOptionsModel)7 TableModel (bio.terra.model.TableModel)7 DatasetRequestModel (bio.terra.model.DatasetRequestModel)6 ErrorModel (bio.terra.model.ErrorModel)6 Test (org.junit.Test)6 SpringBootTest (org.springframework.boot.test.context.SpringBootTest)6 ColumnModel (bio.terra.model.ColumnModel)4 DatePartitionOptionsModel (bio.terra.model.DatePartitionOptionsModel)2