Support nulls when optional
This commit is contained in:
parent
6e7c78362e
commit
1d041a3dd5
|
@ -4,6 +4,9 @@ interface SchemaColumn {
|
||||||
readonly name: string
|
readonly name: string
|
||||||
readonly type: FieldTypes
|
readonly type: FieldTypes
|
||||||
readonly autocolumn?: boolean
|
readonly autocolumn?: boolean
|
||||||
|
readonly constraints?: {
|
||||||
|
presence: boolean
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
interface Schema {
|
interface Schema {
|
||||||
|
@ -76,6 +79,11 @@ export function validate(rows: Rows, schema: Schema): ValidationResults {
|
||||||
// If the columnType is not a string, then it's not present in the schema, and should be added to the invalid columns array
|
// If the columnType is not a string, then it's not present in the schema, and should be added to the invalid columns array
|
||||||
if (typeof columnType !== "string") {
|
if (typeof columnType !== "string") {
|
||||||
results.invalidColumns.push(columnName)
|
results.invalidColumns.push(columnName)
|
||||||
|
} else if (
|
||||||
|
columnData == null &&
|
||||||
|
!schema[columnName].constraints?.presence
|
||||||
|
) {
|
||||||
|
results.schemaValidation[columnName] = true
|
||||||
} else if (
|
} else if (
|
||||||
// If there's no data for this field don't bother with further checks
|
// If there's no data for this field don't bother with further checks
|
||||||
// If the field is already marked as invalid there's no need for further checks
|
// If the field is already marked as invalid there's no need for further checks
|
||||||
|
|
Loading…
Reference in New Issue