94 lines
2.6 KiB
Nix
94 lines
2.6 KiB
Nix
{
|
|
lib,
|
|
stdenv,
|
|
fetchFromGitHub,
|
|
autoreconfHook,
|
|
pkg-config,
|
|
libmysqlclient,
|
|
libaio,
|
|
luajit,
|
|
# For testing:
|
|
testers,
|
|
sysbench,
|
|
}:
|
|
|
|
stdenv.mkDerivation rec {
|
|
pname = "sysbench";
|
|
version = "1.0.20";
|
|
|
|
nativeBuildInputs = [
|
|
autoreconfHook
|
|
pkg-config
|
|
];
|
|
buildInputs = [
|
|
libmysqlclient
|
|
luajit
|
|
] ++ lib.optionals stdenv.hostPlatform.isLinux [ libaio ];
|
|
depsBuildBuild = [ pkg-config ];
|
|
|
|
src = fetchFromGitHub {
|
|
owner = "akopytov";
|
|
repo = pname;
|
|
rev = version;
|
|
sha256 = "1sanvl2a52ff4shj62nw395zzgdgywplqvwip74ky8q7s6qjf5qy";
|
|
};
|
|
|
|
enableParallelBuilding = true;
|
|
|
|
configureFlags = [
|
|
# The bundled version does not build on aarch64-darwin:
|
|
# https://github.com/akopytov/sysbench/issues/416
|
|
"--with-system-luajit"
|
|
"--with-mysql-includes=${lib.getDev libmysqlclient}/include/mysql"
|
|
"--with-mysql-libs=${libmysqlclient}/lib/mysql"
|
|
];
|
|
|
|
# We cannot use the regular nixpkgs ck here, since it has very
|
|
# different performance characteristics than the vendored one.
|
|
# On the downside the vendored libck version require more fixes for cross-compilation.
|
|
# Sysbench related on statically linked vendored libck.
|
|
postPatch = ''
|
|
substituteInPlace \
|
|
third_party/concurrency_kit/ck/configure \
|
|
--replace-fail \
|
|
'COMPILER=`./.1 2> /dev/null`' \
|
|
"COMPILER=${
|
|
if stdenv.cc.isGNU then
|
|
"gcc"
|
|
else if stdenv.cc.isClang then
|
|
"clang"
|
|
else
|
|
throw "Unsupported compiler"
|
|
}" \
|
|
--replace-fail \
|
|
'PLATFORM=`uname -m 2> /dev/null`' \
|
|
"PLATFORM=${stdenv.hostPlatform.parsed.cpu.name}"
|
|
substituteInPlace \
|
|
third_party/concurrency_kit/ck/src/Makefile.in \
|
|
--replace-fail \
|
|
"ar rcs" \
|
|
"${stdenv.cc.targetPrefix}ar rcs"
|
|
'';
|
|
|
|
passthru.tests = {
|
|
versionTest = testers.testVersion {
|
|
package = sysbench;
|
|
};
|
|
};
|
|
|
|
meta = {
|
|
description = "Modular, cross-platform and multi-threaded benchmark tool";
|
|
mainProgram = "sysbench";
|
|
longDescription = ''
|
|
sysbench is a scriptable multi-threaded benchmark tool based on LuaJIT.
|
|
It is most frequently used for database benchmarks, but can also be used
|
|
to create arbitrarily complex workloads that do not involve a database
|
|
server.
|
|
'';
|
|
homepage = "https://github.com/akopytov/sysbench";
|
|
downloadPage = "https://github.com/akopytov/sysbench/releases/tag/${version}";
|
|
changelog = "https://github.com/akopytov/sysbench/blob/${version}/ChangeLog";
|
|
license = lib.licenses.gpl2;
|
|
platforms = lib.platforms.unix;
|
|
};
|
|
}
|