| //! This primarily benchmarks `impl Debug for str`, |
| //! and it also explicitly tests that we minimizes calls to the underlying `Write`r. |
| //! While that is an implementation detail and there are no guarantees about it, |
| //! we should still try to minimize those calls over time rather than regress them. |
| |
| use std::fmt::{self, Write}; |
| use test::{black_box, Bencher}; |
| |
| #[derive(Default)] |
| struct CountingWriter { |
| buf: String, |
| write_calls: usize, |
| } |
| |
| impl Write for CountingWriter { |
| fn write_str(&mut self, s: &str) -> fmt::Result { |
| self.buf.push_str(s); |
| self.write_calls += 1; |
| Ok(()) |
| } |
| } |
| |
| fn assert_fmt(s: &str, expected: &str, expected_write_calls: usize) { |
| let mut w = CountingWriter::default(); |
| |
| write!(&mut w, "{s:?}").unwrap(); |
| assert_eq!(s.len(), 64); |
| assert_eq!(w.buf, expected); |
| assert_eq!(w.write_calls, expected_write_calls); |
| } |
| |
| #[bench] |
| fn ascii_only(b: &mut Bencher) { |
| let s = "just a bit of ascii text that has no escapes. 64 bytes exactly!!"; |
| assert_fmt(s, r#""just a bit of ascii text that has no escapes. 64 bytes exactly!!""#, 3); |
| b.iter(|| { |
| black_box(format!("{:?}", black_box(s))); |
| }); |
| } |
| |
| #[bench] |
| fn ascii_escapes(b: &mut Bencher) { |
| let s = "some\tmore\tascii\ttext\nthis time with some \"escapes\", also 64 byte"; |
| assert_fmt( |
| s, |
| r#""some\tmore\tascii\ttext\nthis time with some \"escapes\", also 64 byte""#, |
| 21, |
| ); |
| b.iter(|| { |
| black_box(format!("{:?}", black_box(s))); |
| }); |
| } |
| |
| #[bench] |
| fn some_unicode(b: &mut Bencher) { |
| let s = "egy kis szöveg néhány unicode betűvel. legyen ez is 64 byte."; |
| assert_fmt(s, r#""egy kis szöveg néhány unicode betűvel. legyen ez is 64 byte.""#, 3); |
| b.iter(|| { |
| black_box(format!("{:?}", black_box(s))); |
| }); |
| } |
| |
| #[bench] |
| fn mostly_unicode(b: &mut Bencher) { |
| let s = "предложение из кириллических букв."; |
| assert_fmt(s, r#""предложение из кириллических букв.""#, 3); |
| b.iter(|| { |
| black_box(format!("{:?}", black_box(s))); |
| }); |
| } |
| |
| #[bench] |
| fn mixed(b: &mut Bencher) { |
| let s = "\"❤️\"\n\"hűha ez betű\"\n\"кириллических букв\"."; |
| assert_fmt(s, r#""\"❤\u{fe0f}\"\n\"hűha ez betű\"\n\"кириллических букв\".""#, 36); |
| b.iter(|| { |
| black_box(format!("{:?}", black_box(s))); |
| }); |
| } |