!1 add zincati source package and spec file

From: @duyiwei7w 
Reviewed-by: @duguhaotian, @yangzhao_kl 
Signed-off-by: @yangzhao_kl
This commit is contained in:
openeuler-ci-bot 2022-02-17 02:37:58 +00:00 committed by Gitee
commit f3178cffb0
No known key found for this signature in database
GPG Key ID: 173E9B9CA92EEF8F
4 changed files with 149 additions and 0 deletions

124
rust-zincati.spec Normal file
View File

@ -0,0 +1,124 @@
%bcond_without check
%global __cargo_skip_build 0
%define debug_package %{nil}
%global crate zincati
Name: rust-%{crate}
Version: 0.0.18
Release: 1
Summary: Update agent for NestOS
License: ASL 2.0
URL: https://crates.io/crates/%{crate}
Source0: %{crate}-%{version}.crate
Source1: https://github.com/coreos/%{crate}/releases/download/v%{version}/%{crate}-%{version}-vendor.tar.gz
Patch0: zincati-fix-metadata.diff
BuildRequires: rust-packaging
BuildRequires: systemd openssl-devel
Requires: polkit
%global _description %{expand:
Update agent for NestOS.}
%description %{_description}
%package -n %{crate}
Summary: %{summary}
License: ASL 2.0 and BSD and MIT and MPLv2.0 and zlib
%description -n %{crate} %{_description}
%files -n %{crate}
%{_libexecdir}/zincati
%doc README.md
%license COPYRIGHT LICENSE
%dir %{_prefix}/lib/%{crate}
%dir %{_prefix}/lib/%{crate}/config.d
%{_prefix}/lib/%{crate}/config.d/*.toml
%attr(0775, zincati, zincati) %dir /run/%{crate}
%attr(0775, zincati, zincati) %dir /run/%{crate}/config.d
%attr(0770, zincati, zincati) %dir /run/%{crate}/private
%attr(0775, zincati, zincati) %dir /run/%{crate}/public
%verify(not size mtime md5) /run/%{crate}/public/metrics.promsock
%verify(not size mtime md5) /run/%{crate}/private/metrics.promsock
%dir %{_sysconfdir}/%{crate}
%dir %{_sysconfdir}/%{crate}/config.d
%{_unitdir}/zincati.service
%{_sysusersdir}/50-zincati.conf
%{_tmpfilesdir}/zincati.conf
%{_datadir}/polkit-1/rules.d/zincati.rules
%{_datadir}/polkit-1/actions/org.coreos.zincati.*
%post -n %{crate}
%systemd_post zincati.service
%preun -n %{crate}
%systemd_preun zincati.service
%postun -n %{crate}
%systemd_postun_with_restart zincati.service
%prep
%autosetup -n %{crate}-%{version} -p1
%patch0 -R -p1
%cargo_prep
tar xvf %{SOURCE1}
mv $RPM_BUILD_DIR/zincati-0.0.18/target/vendor $RPM_BUILD_DIR/zincati-0.0.18
mkdir -p .cargo
cat >.cargo/config << EOF
[build]
rustc = "%{__rustc}"
rustdoc = "%{__rustdoc}"
rustflags = %{__global_rustflags_toml}
[install]
root = "%{buildroot}%{_prefix}"
[term]
verbose = true
[source.crates-io]
replace-with = "vendored-sources"
[source.vendored-sources]
directory = "vendor"
EOF
%build
%cargo_build
%install
%cargo_install
# `zincati` should not be executed directly by users, so we move the binary
# out of `/usr/bin`. See: https://github.com/coreos/fedora-coreos-tracker/issues/244
mkdir -p %{buildroot}%{_libexecdir}
mv %{buildroot}%{_bindir}/zincati %{buildroot}%{_libexecdir}/zincati
install -Dpm0644 -t %{buildroot}%{_prefix}/lib/%{crate}/config.d \
dist/config.d/*.toml
mkdir -p %{buildroot}/run/%{crate}/config.d
mkdir -p %{buildroot}/run/%{crate}/private
mkdir -p %{buildroot}/run/%{crate}/public
touch %{buildroot}/run/%{crate}/public/metrics.promsock
mkdir -p %{buildroot}%{_sysconfdir}/%{crate}/config.d
install -Dpm0644 -t %{buildroot}%{_unitdir} \
dist/systemd/system/*.service
install -Dpm0644 -t %{buildroot}%{_sysusersdir} \
dist/sysusers.d/*.conf
install -Dpm0644 -t %{buildroot}%{_tmpfilesdir} \
dist/tmpfiles.d/*.conf
install -Dpm0644 -t %{buildroot}%{_datadir}/polkit-1/rules.d \
dist/polkit-1/rules.d/*.rules
install -Dpm0644 -t %{buildroot}%{_datadir}/polkit-1/actions \
dist/polkit-1/actions/org.coreos.zincati.*
ln -snf /run/%{crate}/public/metrics.promsock %{buildroot}/run/%{crate}/private/metrics.promsock
%if %{with check}
%check
%cargo_test
%endif
%changelog
* Mon Dec 27 2021 duyiwei <duyiwei@kylinos.cn> - 0.0.18-1
- Package init

Binary file not shown.

BIN
zincati-0.0.18.crate Normal file

Binary file not shown.

25
zincati-fix-metadata.diff Normal file
View File

@ -0,0 +1,25 @@
--- zincati-0.0.18/Cargo.toml
+++ zincati-0.0.18/Cargo.toml
@@ -89,7 +89,7 @@ version = "2.1"
features = ["serde"]
[dependencies.prometheus]
-version = "0.11"
+version = "0.10"
default-features = false
[dependencies.rand]
@@ -128,10 +128,10 @@ features = ["serde"]
version = "0.2"
[dev-dependencies.mockito]
-version = "0.29"
+version = "0.28"
[dev-dependencies.proptest]
-version = "1.0"
+version = "0.10"
[features]
failpoints = ["fail/failpoints"]