containerized-data-importer/containerized-data-importer.spec
Dirk Mueller 2da922fc4b Accepting request 889151 from home:vulyanov
- Set default reg_path='registry.opensuse.org/kubevirt'
- Add _constraints file with disk requirements
- Drop CDI_VERSION env var since its not used during the build

OBS-URL: https://build.opensuse.org/request/show/889151
OBS-URL: https://build.opensuse.org/package/show/Virtualization/containerized-data-importer?expand=0&rev=15
2021-04-29 07:11:21 +00:00

227 lines
6.6 KiB
RPMSpec

#
# spec file for package containerized-data-importer
#
# Copyright (c) 2021 SUSE LLC
#
# All modifications and additions to the file contributed by third parties
# remain the property of their copyright owners, unless otherwise agreed
# upon. The license for this file, and modifications and additions to the
# file, is the same license as for the pristine package itself (unless the
# license for the pristine package is not an Open Source License, in which
# case the license is the MIT License). An "Open Source License" is a
# license that conforms to the Open Source Definition (Version 1.9)
# published by the Open Source Initiative.
# Please submit bugfixes or comments via https://bugs.opensuse.org/
#
Name: containerized-data-importer
Version: 1.30.0
Release: 0
Summary: Container native virtualization
License: Apache-2.0
Group: System/Packages
URL: https://github.com/kubevirt/containerized-data-importer
Source0: %{name}-%{version}.tar.gz
BuildRequires: golang-packaging
BuildRequires: libnbd-devel
BuildRequires: pkgconfig
BuildRequires: rsync
BuildRequires: sed
BuildRequires: golang(API) = 1.14
ExclusiveArch: x86_64
%description
Containerized-Data-Importer (CDI) is a persistent storage management add-on for Kubernetes
%package api
Summary: CDI API server
Group: System/Packages
%description api
The containerized-data-importer-api package provides the kubernetes API extension for CDI
%package cloner
Summary: Cloner for host assisted cloning
Group: System/Packages
%description cloner
Source and Target cloner image for host assisted cloning
%package controller
Summary: Controller for the data fetching service
Group: System/Packages
%description controller
Controller for the data fetching service for VM container images
%package importer
Summary: Data fetching service
Group: System/Packages
%description importer
Data fetching service for VM container imagess
%package operator
Summary: Operator for the data fetching service
Group: System/Packages
%description operator
Operator for the data fetching service for VM container images
%package uploadproxy
Summary: Upload proxy for the data fetching service
Group: System/Packages
%description uploadproxy
Upload proxy for the data fetching service for VM container images
%package uploadserver
Summary: Upload server for the data fetching service
Group: System/Packages
%description uploadserver
Upload server for the data fetching service for VM container images
%package manifests
Summary: YAML manifests used to install CDI
Group: System/Packages
%description manifests
This contains the built YAML manifests used to install CDI into a
kubernetes installation with kubectl apply.
%prep
# Unpack the sources respecting the GOPATH directory structure expected by the
# go imports resolver. I.e. if DIR is in GOPATH then DIR/src/foo/bar can be
# imported as "foo/bar". The same 'visibility' rules apply to the local copies
# of external dependencies placed in 'vendor' directory when imported from the
# 'parent' package.
#
# Note: having bar symlink'ed to DIR/src/foo/bar does not seem to work. Looks
# like symlinks in go path are not resolved correctly. Hence the sources need
# to be 'physically' placed into the proper location.
%setup -n go/src/kubevirt.io/%{name} -c -T
tar --strip-components=1 -xf %{S:0}
%build
# Hackery to determine which registry path to use in cdi-operator.yaml
# when building the manifests
#
# The 'registry_path' macro can be used to define an explicit path in the
# project config, e.g.
#
# Macros:
# %registry_path registry.opensuse.org/Virtualization/container
# :Macros
#
# 'registry_path' can also be defined when building locally, e.g.
#
# osc build --define='registry_path registry.opensuse.org/foo/bar/baz' ...
#
# If 'registry_path' is not specified, the standard publish location for SLE and
# openSUSE-based containers is used.
#
# TODO:
# 1. Determine "standard publish location" for SLE and openSUSE variants
# 2. Support Leap when 1 is done
#
%if "%{?registry_path}" == ""
distro='%{?sle_version}:%{is_opensuse}'
case "${distro}" in
150200:0)
reg_path='registry.suse.de/suse/containers/sle-server/15/containers/suse/sles/15.2' ;;
150300:0)
reg_path='registry.suse.de/suse/containers/sle-server/15/containers/suse/sles/15.3' ;;
*)
reg_path='registry.opensuse.org/kubevirt' ;;
esac
%else
reg_path='%{registry_path}'
%endif
export GOPATH=%{_builddir}/go
export GOFLAGS="-buildmode=pie -mod=vendor"
env \
CDI_SOURCE_DATE_EPOCH="$(date -r LICENSE +%s)" \
CDI_GIT_COMMIT='v%{version}' \
CDI_GIT_VERSION='v%{version}' \
CDI_GIT_TREE_STATE="clean" \
./hack/build/build-go.sh build \
cmd/cdi-apiserver \
cmd/cdi-cloner \
cmd/cdi-controller \
cmd/cdi-importer \
cmd/cdi-uploadproxy \
cmd/cdi-uploadserver \
cmd/cdi-operator \
%{nil}
env DOCKER_PREFIX=$reg_path DOCKER_TAG=%{version} ./hack/build/build-manifests.sh
%install
mkdir -p %{buildroot}%{_bindir}
install -p -m 0755 _out/cmd/cdi-apiserver/cdi-apiserver %{buildroot}%{_bindir}/virt-cdi-apiserver
install -p -m 0755 cmd/cdi-cloner/cloner_startup.sh %{buildroot}%{_bindir}/
install -p -m 0755 _out/cmd/cdi-cloner/cdi-cloner %{buildroot}%{_bindir}/
install -p -m 0755 _out/cmd/cdi-controller/cdi-controller %{buildroot}%{_bindir}/virt-cdi-controller
install -p -m 0755 _out/cmd/cdi-importer/cdi-importer %{buildroot}%{_bindir}/virt-cdi-importer
install -p -m 0755 _out/cmd/cdi-operator/cdi-operator %{buildroot}%{_bindir}/virt-cdi-operator
install -p -m 0755 _out/cmd/cdi-uploadproxy/cdi-uploadproxy %{buildroot}%{_bindir}/virt-cdi-uploadproxy
install -p -m 0755 _out/cmd/cdi-uploadserver/cdi-uploadserver %{buildroot}%{_bindir}/virt-cdi-uploadserver
mkdir -p %{buildroot}%{_datadir}/cdi
cp -r _out/manifests %{buildroot}%{_datadir}/cdi/
%files api
%license LICENSE
%doc README.md
%{_bindir}/virt-cdi-apiserver
%files cloner
%license LICENSE
%doc README.md
%{_bindir}/cloner_startup.sh
%{_bindir}/cdi-cloner
%files controller
%license LICENSE
%doc README.md
%{_bindir}/virt-cdi-controller
%files importer
%license LICENSE
%doc README.md
%{_bindir}/virt-cdi-importer
%files operator
%license LICENSE
%doc README.md
%{_bindir}/virt-cdi-operator
%files uploadproxy
%license LICENSE
%doc README.md
%{_bindir}/virt-cdi-uploadproxy
%files uploadserver
%license LICENSE
%doc README.md
%{_bindir}/virt-cdi-uploadserver
%files manifests
%license LICENSE
%doc README.md
%dir %{_datadir}/cdi
%{_datadir}/cdi/manifests
%changelog