1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
use crate::{
parser::types::FragmentSpread,
validation::visitor::{Visitor, VisitorContext},
Positioned,
};
#[derive(Default)]
pub struct KnownFragmentNames;
impl<'a> Visitor<'a> for KnownFragmentNames {
fn enter_fragment_spread(
&mut self,
ctx: &mut VisitorContext<'a>,
fragment_spread: &'a Positioned<FragmentSpread>,
) {
if !ctx.is_known_fragment(&fragment_spread.node.fragment_name.node) {
ctx.report_error(
vec![fragment_spread.pos],
format!(
r#"Unknown fragment: "{}""#,
fragment_spread.node.fragment_name.node
),
);
}
}
}
#[cfg(test)]
mod tests {
use super::*;
pub fn factory() -> KnownFragmentNames {
KnownFragmentNames::default()
}
#[test]
fn known() {
expect_passes_rule!(
factory,
r#"
{
human(id: 4) {
...HumanFields1
... on Human {
...HumanFields2
}
... {
name
}
}
}
fragment HumanFields1 on Human {
name
...HumanFields3
}
fragment HumanFields2 on Human {
name
}
fragment HumanFields3 on Human {
name
}
"#,
);
}
#[test]
fn unknown() {
expect_fails_rule!(
factory,
r#"
{
human(id: 4) {
...UnknownFragment1
... on Human {
...UnknownFragment2
}
}
}
fragment HumanFields on Human {
name
...UnknownFragment3
}
"#,
);
}
}