Break one test with new validation
This commit is contained in:
parent
994fa7310b
commit
4ab838509b
@ -10,7 +10,7 @@ use serde::{Deserialize, Serialize};
|
|||||||
use crate::{
|
use crate::{
|
||||||
context::Context,
|
context::Context,
|
||||||
error::{RuntimeError, ValidationError},
|
error::{RuntimeError, ValidationError},
|
||||||
identifier::Identifier,
|
identifier::{self, Identifier},
|
||||||
Value,
|
Value,
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -111,12 +111,31 @@ impl AbstractNode for ValueNode {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if let Some(Type::Enum { variants, .. }) = context.get_type(&type_name.node)? {
|
if let Some(Type::Enum { name, variants, .. }) = context.get_type(&type_name.node)? {
|
||||||
if variants
|
let mut found = false;
|
||||||
.iter()
|
|
||||||
.find(|(identifier, _)| identifier == &variant.node)
|
for (identifier, content) in &variants {
|
||||||
.is_none()
|
if identifier == &variant.node {
|
||||||
|
found = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
if let Some(content) = content {
|
||||||
|
for r#type in content {
|
||||||
|
if let Type::Generic {
|
||||||
|
concrete_type: None,
|
||||||
|
..
|
||||||
|
} = r#type
|
||||||
{
|
{
|
||||||
|
return Err(ValidationError::FullTypeNotKnown {
|
||||||
|
identifier: name,
|
||||||
|
position: variant.position,
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if !found {
|
||||||
return Err(ValidationError::EnumVariantNotFound {
|
return Err(ValidationError::EnumVariantNotFound {
|
||||||
identifier: variant.node.clone(),
|
identifier: variant.node.clone(),
|
||||||
position: variant.position,
|
position: variant.position,
|
||||||
|
Loading…
Reference in New Issue
Block a user