From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: from lists.gentoo.org (pigeon.gentoo.org [208.92.234.80]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange X25519 server-signature RSA-PSS (2048 bits)) (No client certificate requested) by finch.gentoo.org (Postfix) with ESMTPS id 96F8A158009 for ; Sun, 18 Jun 2023 14:57:54 +0000 (UTC) Received: from pigeon.gentoo.org (localhost [127.0.0.1]) by pigeon.gentoo.org (Postfix) with SMTP id C5317E0936; Sun, 18 Jun 2023 14:57:53 +0000 (UTC) Received: from smtp.gentoo.org (woodpecker.gentoo.org [140.211.166.183]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange X25519 server-signature RSA-PSS (4096 bits)) (No client certificate requested) by pigeon.gentoo.org (Postfix) with ESMTPS id A0C34E0935 for ; Sun, 18 Jun 2023 14:57:53 +0000 (UTC) Received: from oystercatcher.gentoo.org (oystercatcher.gentoo.org [148.251.78.52]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange X25519 server-signature RSA-PSS (4096 bits)) (No client certificate requested) by smtp.gentoo.org (Postfix) with ESMTPS id AE2A1340FC1 for ; Sun, 18 Jun 2023 14:57:52 +0000 (UTC) Received: from localhost.localdomain (localhost [IPv6:::1]) by oystercatcher.gentoo.org (Postfix) with ESMTP id 4913AA66 for ; Sun, 18 Jun 2023 14:57:51 +0000 (UTC) From: "Michał Górny" To: gentoo-commits@lists.gentoo.org Content-Transfer-Encoding: 8bit Content-type: text/plain; charset=UTF-8 Reply-To: gentoo-dev@lists.gentoo.org, "Michał Górny" Message-ID: <1687100263.a9d3b1f7d35f9b226a8d8bf35d9e83b1244aa016.mgorny@gentoo> Subject: [gentoo-commits] repo/gentoo:master commit in: eclass/tests/ X-VCS-Repository: repo/gentoo X-VCS-Files: eclass/tests/cargo-bench.sh X-VCS-Directories: eclass/tests/ X-VCS-Committer: mgorny X-VCS-Committer-Name: Michał Górny X-VCS-Revision: a9d3b1f7d35f9b226a8d8bf35d9e83b1244aa016 X-VCS-Branch: master Date: Sun, 18 Jun 2023 14:57:51 +0000 (UTC) Precedence: bulk List-Post: List-Help: List-Unsubscribe: List-Subscribe: List-Id: Gentoo Linux mail X-BeenThere: gentoo-commits@lists.gentoo.org X-Auto-Response-Suppress: DR, RN, NRN, OOF, AutoReply X-Archives-Salt: 6da805f5-8948-41e8-bdbd-11a29f8db4b0 X-Archives-Hash: 34ee91a02373fea3acbe47362bf83d09 commit: a9d3b1f7d35f9b226a8d8bf35d9e83b1244aa016 Author: Michał Górny gentoo org> AuthorDate: Thu Jun 15 04:32:10 2023 +0000 Commit: Michał Górny gentoo org> CommitDate: Sun Jun 18 14:57:43 2023 +0000 URL: https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=a9d3b1f7 eclass/tests: Add a minimal benchmark for cargo.eclass The initial results on my machine are: ``` real 252 it/s user 289 it/s ``` Signed-off-by: Michał Górny gentoo.org> eclass/tests/cargo-bench.sh | 107 ++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 107 insertions(+) diff --git a/eclass/tests/cargo-bench.sh b/eclass/tests/cargo-bench.sh new file mode 100755 index 000000000000..cdc5e4431c14 --- /dev/null +++ b/eclass/tests/cargo-bench.sh @@ -0,0 +1,107 @@ +#!/bin/bash +# Copyright 2023 Gentoo Authors +# Distributed under the terms of the GNU General Public License v2 + +EAPI=8 +source tests-common.sh || exit + +export LC_ALL=C + +ITERATIONS=1000 +RUNS=3 + +doit() { + for (( i = 0; i < ITERATIONS; i++ )); do + SRC_URI=" + $(cargo_crate_uris) + " + done +} + +timeit() { + local real=() + local user=() + local x vr avg + + for (( x = 0; x < RUNS; x++ )); do + while read tt tv; do + case ${tt} in + real) real+=( ${tv} );; + user) user+=( ${tv} );; + esac + done < <( ( time -p doit ) 2>&1 ) + done + + [[ ${#real[@]} == ${RUNS} ]] || die "Did not get ${RUNS} real times" + [[ ${#user[@]} == ${RUNS} ]] || die "Did not get ${RUNS} user times" + + local xr avg + for x in real user; do + xr="${x}[*]" + avg=$(dc -S 3 -e "${ITERATIONS} ${RUNS} * ${!xr} + + / p") + + printf '%s %4.0f it/s\n' "${x}" "${avg}" + done +} + +# taken from cryptograpy-41.0.1 +CRATES=" + Inflector-0.11.4 + aliasable-0.1.3 + asn1-0.15.2 + asn1_derive-0.15.2 + autocfg-1.1.0 + base64-0.13.1 + bitflags-1.3.2 + cc-1.0.79 + cfg-if-1.0.0 + foreign-types-0.3.2 + foreign-types-shared-0.1.1 + indoc-1.0.9 + libc-0.2.144 + lock_api-0.4.9 + memoffset-0.8.0 + once_cell-1.17.2 + openssl-0.10.54 + openssl-macros-0.1.1 + openssl-sys-0.9.88 + ouroboros-0.15.6 + ouroboros_macro-0.15.6 + parking_lot-0.12.1 + parking_lot_core-0.9.7 + pem-1.1.1 + pkg-config-0.3.27 + proc-macro-error-1.0.4 + proc-macro-error-attr-1.0.4 + proc-macro2-1.0.59 + pyo3-0.18.3 + pyo3-build-config-0.18.3 + pyo3-ffi-0.18.3 + pyo3-macros-0.18.3 + pyo3-macros-backend-0.18.3 + quote-1.0.28 + redox_syscall-0.2.16 + scopeguard-1.1.0 + smallvec-1.10.0 + syn-1.0.109 + syn-2.0.18 + target-lexicon-0.12.7 + unicode-ident-1.0.9 + unindent-0.1.11 + vcpkg-0.2.15 + version_check-0.9.4 + windows-sys-0.45.0 + windows-targets-0.42.2 + windows_aarch64_gnullvm-0.42.2 + windows_aarch64_msvc-0.42.2 + windows_i686_gnu-0.42.2 + windows_i686_msvc-0.42.2 + windows_x86_64_gnu-0.42.2 + windows_x86_64_gnullvm-0.42.2 + windows_x86_64_msvc-0.42.2 +" + +inherit cargo +timeit + +texit