//! `SetOf` tests. #![cfg(feature = "alloc")] use der::{asn1::SetOfVec, DerOrd}; use proptest::{prelude::*, string::*}; use std::collections::BTreeSet; proptest! { #[test] fn sort_equiv(bytes in bytes_regex(".{0,64}").unwrap()) { let mut uniq = BTreeSet::new(); // Ensure there are no duplicates if bytes.iter().copied().all(move |x| uniq.insert(x)) { let mut expected = bytes.clone(); expected.sort_by(|a, b| a.der_cmp(b).unwrap()); let set = SetOfVec::try_from(bytes).unwrap(); prop_assert_eq!(expected.as_slice(), set.as_slice()); } } } /// Set ordering tests. #[cfg(all(feature = "derive", feature = "oid"))] mod ordering { use der::{ asn1::{AnyRef, ObjectIdentifier, SetOf, SetOfVec}, Decode, Sequence, ValueOrd, }; use hex_literal::hex; /// X.501 `AttributeTypeAndValue` #[derive(Copy, Clone, Debug, Eq, PartialEq, Sequence, ValueOrd)] pub struct AttributeTypeAndValue<'a> { pub oid: ObjectIdentifier, pub value: AnyRef<'a>, } const OUT_OF_ORDER_RDN_EXAMPLE: &[u8] = &hex!("311F301106035504030C0A4A4F484E20534D495448300A060355040A0C03313233"); /// For compatibility reasons, we allow non-canonical DER with out-of-order /// sets in order to match the behavior of other implementations. #[test] fn allow_out_of_order_setof() { assert!(SetOf::, 2>::from_der(OUT_OF_ORDER_RDN_EXAMPLE).is_ok()); } /// Same as above, with `SetOfVec` instead of `SetOf`. #[test] fn allow_out_of_order_setofvec() { assert!(SetOfVec::>::from_der(OUT_OF_ORDER_RDN_EXAMPLE).is_ok()); } /// Test to ensure ordering is handled correctly. #[test] fn ordering_regression() { let der_bytes = hex!("3139301906035504030C12546573742055736572393031353734333830301C060A0992268993F22C640101130E3437303031303030303134373333"); let set = SetOf::, 3>::from_der(&der_bytes).unwrap(); let attr1 = set.get(0).unwrap(); assert_eq!(ObjectIdentifier::new("2.5.4.3").unwrap(), attr1.oid); } }