https-dns 0.2.0

Minimal and efficient DNS-over-HTTPS (DoH) client
Documentation
use https_dns::utils::{build_request_message, build_test_listener};
use std::{collections::HashMap, net::Ipv4Addr};
use tokio::{net::UdpSocket, test};
use trust_dns_proto::{
    op::Message,
    rr::{Name, RData, RecordType},
};

#[test]
async fn a_record() {
    let udp_listener = build_test_listener().await;
    tokio::spawn(async move {
        udp_listener.listen().await;
    });

    let result_map = HashMap::from([
        (
            "dns.google",
            vec![Ipv4Addr::new(8, 8, 8, 8), Ipv4Addr::new(8, 8, 4, 4)],
        ),
        (
            "one.one.one.one",
            vec![Ipv4Addr::new(1, 1, 1, 1), Ipv4Addr::new(1, 0, 0, 1)],
        ),
    ]);

    for (host, socket_addr_list) in result_map {
        let request_name: Name = host.parse().unwrap();
        let request_message = build_request_message(request_name, RecordType::A);
        let raw_request_message = request_message.to_vec().unwrap();

        let udp_socket = UdpSocket::bind("127.0.0.1:10054").await.unwrap();
        udp_socket.connect("127.0.0.1:10053").await.unwrap();

        udp_socket.send(&raw_request_message).await.unwrap();
        let mut buffer = [0; 4096];
        udp_socket.recv(&mut buffer).await.unwrap();

        let response_message = Message::from_vec(&buffer).unwrap();
        let record_data = &response_message.answers()[0].data().unwrap();
        if let RData::A(ipv4_address) = record_data {
            assert!(socket_addr_list.contains(ipv4_address));
        } else {
            panic!("the record type is not A")
        }
    }
}