143 lines
3.4 KiB
Nix
143 lines
3.4 KiB
Nix
{
|
|
lib,
|
|
stdenv,
|
|
rustPlatform,
|
|
fetchFromGitHub,
|
|
protobuf,
|
|
|
|
# nativeBuildInputs
|
|
cmake,
|
|
openssl,
|
|
perl,
|
|
pkg-config,
|
|
|
|
# buildInputs
|
|
rdkafka,
|
|
|
|
# tests
|
|
cacert,
|
|
versionCheckHook,
|
|
|
|
# passthru
|
|
testers,
|
|
restate,
|
|
nix-update-script,
|
|
}:
|
|
rustPlatform.buildRustPackage (finalAttrs: {
|
|
pname = "restate";
|
|
version = "1.4.4";
|
|
|
|
src = fetchFromGitHub {
|
|
owner = "restatedev";
|
|
repo = "restate";
|
|
tag = "v${finalAttrs.version}";
|
|
hash = "sha256-OtDVYGYoUpocy3c9ZDKbE5ZqGRLewJMvABj2QQxJQ80=";
|
|
};
|
|
|
|
cargoHash = "sha256-OWSFnVqyI2qV0IEXKOAp2QMs2qmjzS0UINVo+nu296g=";
|
|
|
|
env = {
|
|
PROTOC = lib.getExe protobuf;
|
|
PROTOC_INCLUDE = "${protobuf}/include";
|
|
|
|
VERGEN_GIT_SHA = "v${finalAttrs.version}";
|
|
|
|
# rustflags as defined in the upstream's .cargo/config.toml
|
|
RUSTFLAGS =
|
|
let
|
|
target = stdenv.hostPlatform.config;
|
|
targetFlags = lib.fix (self: {
|
|
build = [
|
|
"-C force-unwind-tables"
|
|
"--cfg uuid_unstable"
|
|
"--cfg tokio_unstable"
|
|
"--cfg tokio_taskdump"
|
|
];
|
|
|
|
"aarch64-unknown-linux-gnu" = self.build ++ [
|
|
# Enable frame pointers to support Parca (https://github.com/parca-dev/parca-agent/pull/1805)
|
|
"-C force-frame-pointers=yes"
|
|
];
|
|
|
|
"x86_64-unknown-linux-musl" = self.build ++ [
|
|
"-C link-self-contained=yes"
|
|
];
|
|
|
|
"aarch64-unknown-linux-musl" = self.build ++ [
|
|
# Enable frame pointers to support Parca (https://github.com/parca-dev/parca-agent/pull/1805)
|
|
"-C force-frame-pointers=yes"
|
|
"-C link-self-contained=yes"
|
|
];
|
|
});
|
|
in
|
|
lib.concatStringsSep " " (lib.attrsets.attrByPath [ target ] targetFlags.build targetFlags);
|
|
|
|
# Have to be set to dynamically link librdkafka
|
|
CARGO_FEATURE_DYNAMIC_LINKING = 1;
|
|
};
|
|
|
|
nativeBuildInputs = [
|
|
cmake
|
|
openssl
|
|
perl
|
|
pkg-config
|
|
rustPlatform.bindgenHook
|
|
];
|
|
|
|
buildInputs = [
|
|
rdkafka
|
|
];
|
|
|
|
nativeCheckInputs = [
|
|
cacert
|
|
];
|
|
|
|
useNextest = true;
|
|
# Feature resolution seems to be failing due to this https://github.com/rust-lang/cargo/issues/7754
|
|
auditable = false;
|
|
|
|
checkFlags = [
|
|
# Error: deadline has elapsed
|
|
"--skip replicated_loglet"
|
|
|
|
# TIMEOUT [ 180.006s]
|
|
"--skip fast_forward_over_trim_gap"
|
|
|
|
# TIMEOUT (could be related to https://github.com/restatedev/restate/issues/3043)
|
|
"--skip restatectl_smoke_test"
|
|
];
|
|
|
|
__darwinAllowLocalNetworking = true;
|
|
|
|
nativeInstallCheckInputs = [
|
|
versionCheckHook
|
|
];
|
|
versionCheckProgramArg = "--version";
|
|
doInstallCheck = true;
|
|
|
|
passthru = {
|
|
tests.restateCliVersion = testers.testVersion {
|
|
package = restate;
|
|
command = "restate --version";
|
|
};
|
|
tests.restateServerVersion = testers.testVersion {
|
|
package = restate;
|
|
command = "restate-server --version";
|
|
};
|
|
tests.restateCtlVersion = testers.testVersion {
|
|
package = restate;
|
|
command = "restatectl --version";
|
|
};
|
|
updateScript = nix-update-script { };
|
|
};
|
|
|
|
meta = {
|
|
description = "Platform for developing distributed fault-tolerant applications";
|
|
homepage = "https://restate.dev";
|
|
changelog = "https://github.com/restatedev/restate/releases/tag/v${finalAttrs.version}";
|
|
mainProgram = "restate";
|
|
license = lib.licenses.bsl11;
|
|
maintainers = with lib.maintainers; [ myypo ];
|
|
};
|
|
})
|