summaryrefslogtreecommitdiffstats
path: root/third_party/rust/idna/benches
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-19 00:47:55 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-19 00:47:55 +0000
commit26a029d407be480d791972afb5975cf62c9360a6 (patch)
treef435a8308119effd964b339f76abb83a57c29483 /third_party/rust/idna/benches
parentInitial commit. (diff)
downloadfirefox-26a029d407be480d791972afb5975cf62c9360a6.tar.xz
firefox-26a029d407be480d791972afb5975cf62c9360a6.zip
Adding upstream version 124.0.1.upstream/124.0.1
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'third_party/rust/idna/benches')
-rw-r--r--third_party/rust/idna/benches/all.rs53
1 files changed, 53 insertions, 0 deletions
diff --git a/third_party/rust/idna/benches/all.rs b/third_party/rust/idna/benches/all.rs
new file mode 100644
index 0000000000..157e4af251
--- /dev/null
+++ b/third_party/rust/idna/benches/all.rs
@@ -0,0 +1,53 @@
+#[macro_use]
+extern crate bencher;
+extern crate idna;
+
+use bencher::{black_box, Bencher};
+use idna::Config;
+
+fn to_unicode_puny_label(bench: &mut Bencher) {
+ let encoded = "abc.xn--mgbcm";
+ let config = Config::default();
+ bench.iter(|| config.to_unicode(black_box(encoded)));
+}
+
+fn to_unicode_ascii(bench: &mut Bencher) {
+ let encoded = "example.com";
+ let config = Config::default();
+ bench.iter(|| config.to_unicode(black_box(encoded)));
+}
+
+fn to_unicode_merged_label(bench: &mut Bencher) {
+ let encoded = "Beispiel.xn--vermgensberater-ctb";
+ let config = Config::default();
+ bench.iter(|| config.to_unicode(black_box(encoded)));
+}
+
+fn to_ascii_puny_label(bench: &mut Bencher) {
+ let encoded = "abc.ابج";
+ let config = Config::default();
+ bench.iter(|| config.to_ascii(black_box(encoded)));
+}
+
+fn to_ascii_simple(bench: &mut Bencher) {
+ let encoded = "example.com";
+ let config = Config::default();
+ bench.iter(|| config.to_ascii(black_box(encoded)));
+}
+
+fn to_ascii_merged(bench: &mut Bencher) {
+ let encoded = "beispiel.vermögensberater";
+ let config = Config::default();
+ bench.iter(|| config.to_ascii(black_box(encoded)));
+}
+
+benchmark_group!(
+ benches,
+ to_unicode_puny_label,
+ to_unicode_ascii,
+ to_unicode_merged_label,
+ to_ascii_puny_label,
+ to_ascii_simple,
+ to_ascii_merged,
+);
+benchmark_main!(benches);