recursor_test: backfill a CNAME test

there are more cname tests to add, but they would fail without code change :)
This commit is contained in:
Colin 2024-05-09 06:59:54 +00:00
parent 2aa98d0799
commit c43bef87f9

View File

@ -94,6 +94,7 @@ const ZONE_EXAMPLE_COM: &str = r#"
example.com. A 10.0.100.1
www.example.com. A 10.0.100.1
cname.sub.example.com. CNAME www.example.com.
"#;
type HardcodedNameServer = NameServer<HardcodedConnProvider>;
@ -130,7 +131,7 @@ impl DnsHandle for HardcodedDnsHandle {
let response_futures: Vec<_> = request.queries().iter().map(move |query| {
let query = query.clone();
stream::once(async move {
println!("HardcodedDnsHandle: fielding query");
println!("HardcodedDnsHandle: fielding query: {:?} {:?}", query.name(), query.query_type());
let mut response = Message::new();
response.add_query(query.clone());
response.set_message_type(MessageType::Response);
@ -371,3 +372,29 @@ fn test_recurse() {
assert_eq!(&*lookup.records().to_vec(), &[expected_record]);
}
/// If `example.com.` is a NS and `sub.example.com.` doesn't exist, then `cname.sub.example.com.`
/// triggers a different codepath than `cname.example.com.`. The recursor tries to query the
/// latter as a NS (and receives a CNAME); the former is queried directly as a CNAME.
#[test]
fn test_cname_below_nonexistent_parent() {
logger("DEBUG");
let query = Query::query(Name::from_str("cname.sub.example.com.").unwrap(), RecordType::CNAME);
let expected_record = cname_record(
Name::from_str("cname.sub.example.com.").unwrap(),
Name::from_str("www.example.com.").unwrap(),
);
let roots = NameServerPool::from_nameservers(
Default::default(),
vec![mock_nameserver(NS_ROOT)],
vec![],
);
let recursor = Recursor::new_with_pool(roots, 1024, 1048576).unwrap();
let now = Instant::now();
let lookup = block_on(recursor.resolve(query, now)).unwrap();
assert_eq!(&*lookup.records().to_vec(), &[expected_record]);
}