Accepting request 183655 from Cloud:Tools

Automatic submission by obs-autosubmit

OBS-URL: https://build.opensuse.org/request/show/183655
OBS-URL: https://build.opensuse.org/package/show/openSUSE:Factory/cloud-init?expand=0&rev=5
This commit is contained in:
Stephan Kulow 2013-07-19 14:51:15 +00:00 committed by Git OBS Bridge
parent 977266dbf5
commit 3e26e9102c
5 changed files with 220 additions and 56 deletions

View File

@ -1,5 +1,46 @@
------------------------------------------------------------------- -------------------------------------------------------------------
Tue Jun 18 21:28:58 UTC 2013 - rschweikert@suse.com Thu Jul 11 08:00:50 UTC 2013 - speilicke@suse.com
- Install service files into /lib/systemd/system on 12.2, the UsrMove
happened afterwards
-------------------------------------------------------------------
Wed Jul 10 07:15:50 UTC 2013 - speilicke@suse.com
- Re-imported from IBS and some cleanup
- Package LICENSE
- Install service files to /usr/lib/systemd/system, not /etc/...
- Drop %py_requires, there are several autorequires for SLES and openSUSE
- Drop $all facility Required-Start in sysvinit/cloud-final
-------------------------------------------------------------------
Wed Jun 26 15:41:24 UTC 2013 - bwiedemann@suse.com
- require python-boto >= 2.7 because it fails with 2.5.2
-------------------------------------------------------------------
Wed Jun 26 13:07:41 UTC 2013 - rschweikert@suse.com
- fix stray character in patch introduced by previous changes
-------------------------------------------------------------------
Wed Jun 26 12:37:10 UTC 2013 - rschweikert@suse.com
- fix zypper command in slesHandler, use non-interactive mode
-------------------------------------------------------------------
Wed Jun 19 17:32:11 UTC 2013 - rschweikert@suse.com
- fix duplicate entry in the config w.r.t. ssh key generation
- fix distro indicator setting, sles vs. opensuse
-------------------------------------------------------------------
Tue Jun 18 21:48:21 UTC 2013 - rschweikert@suse.com
- Integrate the sysV init script changes from Jens
-------------------------------------------------------------------
Tue Jun 18 21:23:46 UTC 2013 - rschweikert@suse.com
- integrate changes from HP - integrate changes from HP
+ update the sles handler, do not modify the util code integrate + update the sles handler, do not modify the util code integrate

View File

@ -15,23 +15,24 @@
# Please submit bugfixes or comments via http://bugs.opensuse.org/ # Please submit bugfixes or comments via http://bugs.opensuse.org/
# #
Name: cloud-init
%define component cloud-init
Name: %{component}
Version: 0.7.2 Version: 0.7.2
Release: 0 Release: 0
Summary: Cloud node initialization tool
License: GPL-3.0 License: GPL-3.0
Group: System/Management Summary: Cloud node initialization tool
Url: http://launchpad.net/cloud-init/ Url: http://launchpad.net/cloud-init/
Source0: %{component}-%{version}.tar.bz2 Group: System/Management
Source0: %{name}-%{version}.tar.bz2
Source1: cloud.cfg.suse Source1: cloud.cfg.suse
Patch0: fixupSysVinit.patch Patch0: fixupSysVinit.patch
Patch1: slesHandler.patch Patch1: slesHandler.patch
Patch2: openSUSEHandler.diff Patch2: openSUSEHandler.diff
BuildRequires: fdupes
BuildRequires: filesystem
BuildRequires: python-devel
BuildRequires: python-setuptools
Requires: python-argparse Requires: python-argparse
Requires: python-boto Requires: python-boto >= 2.7
Requires: python-cheetah Requires: python-cheetah
Requires: python-configobj Requires: python-configobj
Requires: python-oauth Requires: python-oauth
@ -39,67 +40,70 @@ Requires: python-prettytable
Requires: python-requests Requires: python-requests
Requires: python-xml Requires: python-xml
Requires: python-yaml Requires: python-yaml
BuildRequires: filesystem
BuildRequires: python-devel
BuildRequires: python-setuptools
#BuildRequires: python-distribute
BuildRequires: fdupes
BuildRoot: %{_tmppath}/%{name}-%{version}-build BuildRoot: %{_tmppath}/%{name}-%{version}-build
%define docdir %{_defaultdocdir}/%{name} %define docdir %{_defaultdocdir}/%{name}
%if 0%{?suse_version} && 0%{?suse_version} <= 1110 %if 0%{?suse_version} && 0%{?suse_version} <= 1110
%{!?python_sitelib: %global python_sitelib %(%{__python} -c "from distutils.sysconfig import get_python_lib; print get_python_lib()")}
%else %else
BuildArch: noarch BuildArch: noarch
%endif %endif
%if 0%{?suse_version} && 0%{?suse_version} <= 1210 %if 0%{?suse_version} && 0%{?suse_version} <= 1210
%define initsys sysvinit %define initsys sysvinit
%else %else
%define initsys systemd %define initsys systemd
BuildRequires: systemd
%{?systemd_requires}
%if 0%{?suse_version} && 0%{?suse_version} == 1220
%define systemd_prefix /lib
%else
%define systemd_prefix /usr/lib
%endif
%endif %endif
%{py_requires}
%description %description
Cloud-init is an init script that initializes a cloud node (VM) Cloud-init is an init script that initializes a cloud node (VM)
according to the fetched configuration data from the admin node. according to the fetched configuration data from the admin node.
Authors:
--------
Scott Moser <scott.moser@canonical.com>
%package doc %package doc
Summary: Cloud node initialization tool doc Summary: Cloud node initialization tool - Documentation
Group: System/Management Group: System/Management
Recommends: cloud-init = %version Recommends: cloud-init = %{version}
%description doc %description doc
Cloud-init is an init script that initializes a cloud node (VM)
according to the fetched configuration data from the admin node.
Documentation and examples for cloud-init tools Documentation and examples for cloud-init tools
%package test %package test
Summary: Cloud node initialization tool tests Summary: Cloud node initialization tool - Testsuite
Group: System/Management Group: System/Management
Requires: cloud-init = %version Requires: cloud-init = %{version}
%description test %description test
Cloud-init is an init script that initializes a cloud node (VM)
according to the fetched configuration data from the admin node.
Unit tests for the cloud-init tools Unit tests for the cloud-init tools
%prep %prep
%setup -q -n %{component}-%{version} %setup -q
%patch0 %patch0
%patch1 -p1 %patch1 -p1
%patch2 -p1 %patch2 -p1
%if 0%{?suse_version} <= 1130 %if 0%{?suse_version} <= 1130
# disable ecdsa for SLE 11 (not available) # disable ecdsa for SLE 11 (not available)
echo "ssh_genkeytypes: ['rsa', 'dsa']" >> %{S:1} echo "ssh_genkeytypes: ['rsa', 'dsa']" >> %{SOURCE1}
%endif %endif
# Install service files into correct location
sed -i "s|/etc/systemd/system|%{systemd_prefix}/systemd/system|" setup.py
# Drop $all facility Required-Start in sysvinit/cloud-final:
sed -i "s|\$all cloud-config|cloud-config|" sysvinit/cloud-final
%build %build
python setup.py build python setup.py build
%install %install
python setup.py install --skip-build --root=%{buildroot} --prefix=%{_prefix} --record-rpm=INSTALLED_FILES --install-lib=%{python_sitelib} --init-system=%{initsys} python setup.py install --root=%{buildroot} --prefix=%{_prefix} --install-lib=%{python_sitelib} --init-system=%{initsys}
find %{buildroot} \( -name .gitignore -o -name .placeholder \) -delete find %{buildroot} \( -name .gitignore -o -name .placeholder \) -delete
# from debian install script # from debian install script
for x in "%{buildroot}%{_bindir}/"*.py; do for x in "%{buildroot}%{_bindir}/"*.py; do
@ -108,16 +112,23 @@ done
mkdir -p %{buildroot}%{_localstatedir}/lib/cloud mkdir -p %{buildroot}%{_localstatedir}/lib/cloud
# move documentation # move documentation
mkdir -p %{buildroot}%{_defaultdocdir} mkdir -p %{buildroot}%{_defaultdocdir}
mv %{buildroot}/usr/share/doc/%{component} %{buildroot}%{docdir} mv %{buildroot}%{_datadir}/doc/%{name} %{buildroot}%{docdir}
cp -a %{S:1} %{buildroot}/%{_sysconfdir}/cloud/cloud.cfg cp -a %{SOURCE1} %{buildroot}/%{_sysconfdir}/cloud/cloud.cfg
# Set the distribution indicator
%if 0%{?suse_version} %if 0%{?suse_version}
%if 0%{?sles_version} != 0 %if 0%{?suse_version} < 1130
sed -i s/INSERT_SUSE_DISTRO/sles/ %{buildroot}/%{_sysconfdir}/cloud/cloud.cfg sed -i s/INSERT_SUSE_DISTRO/sles/ %{buildroot}/%{_sysconfdir}/cloud/cloud.cfg
%endif %endif
%if 0%{?sles_version} == 0 %if 0%{?suse_version} > 1140
sed -i s/INSERT_SUSE_DISTRO/opensuse/ %{buildroot}/%{_sysconfdir}/cloud/cloud.cfg sed -i s/INSERT_SUSE_DISTRO/opensuse/ %{buildroot}/%{_sysconfdir}/cloud/cloud.cfg
%endif %endif
%endif %endif
#grep Enterprise /etc/SuSE-release >& /dev/null
#if [ $? = 0 ]; then
#sed -i s/INSERT_SUSE_DISTRO/sles/ %{buildroot}/%{_sysconfdir}/cloud/cloud.cfg
#else
#sed -i s/INSERT_SUSE_DISTRO/opensuse/ %{buildroot}/%{_sysconfdir}/cloud/cloud.cfg
#fi
# remove debian/ubuntu specific profile.d file (bnc#779553) # remove debian/ubuntu specific profile.d file (bnc#779553)
rm -f %{buildroot}%{_sysconfdir}/profile.d/Z99-cloud-locale-test.sh rm -f %{buildroot}%{_sysconfdir}/profile.d/Z99-cloud-locale-test.sh
@ -139,21 +150,32 @@ popd
%fdupes %{buildroot}%{python_sitelib} %fdupes %{buildroot}%{python_sitelib}
%endif %endif
%postun
%insserv_cleanup
%files %files
%defattr(-,root,root) %defattr(-,root,root)
%{python_sitelib}/cloudinit
%{python_sitelib}/cloud_init*egg-info
%{_bindir}/cloud-init %{_bindir}/cloud-init
%{_bindir}/cloud-init-per %{_bindir}/cloud-init-per
%config(noreplace) %{_sysconfdir}/cloud/ %config(noreplace) %{_sysconfdir}/cloud/
/usr/lib/cloud-init %{python_sitelib}/cloudinit
%{python_sitelib}/cloud_init-%{version}-py%{py_ver}.egg-info
%{_prefix}/lib/cloud-init
%if 0%{?suse_version} && 0%{?suse_version} <= 1210 %if 0%{?suse_version} && 0%{?suse_version} <= 1210
%{_sbindir}/rc* %{_sbindir}/rccloud-config
%attr(0755, root, root) %{_initddir}/* %{_sbindir}/rccloud-init
%{_sbindir}/rccloud-init-local
%{_sbindir}/rccloud-final
%attr(0755, root, root) %{_initddir}/cloud-config
%attr(0755, root, root) %{_initddir}/cloud-init
%attr(0755, root, root) %{_initddir}/cloud-init-local
%attr(0755, root, root) %{_initddir}/cloud-final
%else %else
%dir /etc/systemd %{systemd_prefix}/systemd/system/cloud-config.service
%dir /etc/systemd/system %{systemd_prefix}/systemd/system/cloud-config.target
%{_sysconfdir}/systemd/system/* %{systemd_prefix}/systemd/system/cloud-init-local.service
%{systemd_prefix}/systemd/system/cloud-init.service
%{systemd_prefix}/systemd/system/cloud-final.service
%endif %endif
%dir %attr(0755, root, root) %{_localstatedir}/lib/cloud %dir %attr(0755, root, root) %{_localstatedir}/lib/cloud
@ -165,7 +187,4 @@ popd
%defattr(-,root,root) %defattr(-,root,root)
%{python_sitelib}/tests %{python_sitelib}/tests
%postun
%insserv_cleanup
%changelog %changelog

View File

@ -7,7 +7,6 @@ disable_root: false
preserve_hostname: false preserve_hostname: false
syslog_fix_perms: root:root syslog_fix_perms: root:root
mount_default_fields: [~, ~, 'auto', 'defaults,nofail', '0', '2'] mount_default_fields: [~, ~, 'auto', 'defaults,nofail', '0', '2']
ssh_genkeytypes: ['rsa', 'dsa']
# The modules that run in the 'init' stage # The modules that run in the 'init' stage
cloud_init_modules: cloud_init_modules:

View File

@ -1,52 +1,157 @@
Index: sysvinit/cloud-config
===================================================================
--- sysvinit/cloud-config.orig --- sysvinit/cloud-config.orig
+++ sysvinit/cloud-config +++ sysvinit/cloud-config
@@ -27,8 +27,8 @@ @@ -27,9 +27,9 @@
# Provides: cloud-config # Provides: cloud-config
# Required-Start: cloud-init cloud-init-local # Required-Start: cloud-init cloud-init-local
# Should-Start: $time # Should-Start: $time
-# Required-Stop: -# Required-Stop:
-# Should-Stop: -# Should-Stop:
-# Default-Start: 2 3 4 5
+# Required-Stop: $null +# Required-Stop: $null
+# Should-Stop: $null +# Should-Stop: $null
# Default-Start: 2 3 4 5 +# Default-Start: 2 3 5
# Default-Stop: 0 1 6 # Default-Stop: 0 1 6
# Short-Description: The config cloud-init job # Short-Description: The config cloud-init job
# Description: Start cloud-init and runs the config phase
@@ -62,6 +62,9 @@ conf="/etc/cloud/cloud.cfg"
[ -f /etc/sysconfig/cloud-init ] && . /etc/sysconfig/cloud-init
[ -f /etc/default/cloud-init ] && . /etc/default/cloud-init
+. /etc/rc.status
+rc_reset
+
start() {
[ -x $cloud_init ] || return 5
[ -f $conf ] || return 6
@@ -118,4 +121,6 @@ case "$1" in
;;
esac
-exit $RETVAL
+_rc_status=$RETVAL
+rc_status -v
+rc_exit
Index: sysvinit/cloud-final
===================================================================
--- sysvinit/cloud-final.orig --- sysvinit/cloud-final.orig
+++ sysvinit/cloud-final +++ sysvinit/cloud-final
@@ -27,8 +27,8 @@ @@ -27,9 +27,9 @@
# Provides: cloud-final # Provides: cloud-final
# Required-Start: $all cloud-config # Required-Start: $all cloud-config
# Should-Start: $time # Should-Start: $time
-# Required-Stop: -# Required-Stop:
-# Should-Stop: -# Should-Stop:
-# Default-Start: 2 3 4 5
+# Required-Stop: $null +# Required-Stop: $null
+# Should-Stop: $null +# Should-Stop: $null
# Default-Start: 2 3 4 5 +# Default-Start: 2 3 5
# Default-Stop: 0 1 6 # Default-Stop: 0 1 6
# Short-Description: The final cloud-init job # Short-Description: The final cloud-init job
# Description: Start cloud-init and runs the final phase
@@ -62,6 +62,9 @@ conf="/etc/cloud/cloud.cfg"
[ -f /etc/sysconfig/cloud-init ] && . /etc/sysconfig/cloud-init
[ -f /etc/default/cloud-init ] && . /etc/default/cloud-init
+. /etc/rc.status
+rc_reset
+
start() {
[ -x $cloud_init ] || return 5
[ -f $conf ] || return 6
@@ -118,4 +121,6 @@ case "$1" in
;;
esac
-exit $RETVAL
+_rc_status=$RETVAL
+rc_status -v
+rc_exit
Index: sysvinit/cloud-init
===================================================================
--- sysvinit/cloud-init.orig --- sysvinit/cloud-init.orig
+++ sysvinit/cloud-init +++ sysvinit/cloud-init
@@ -27,8 +27,8 @@ @@ -27,9 +27,9 @@
# Provides: cloud-init # Provides: cloud-init
# Required-Start: $local_fs $network $named $remote_fs cloud-init-local # Required-Start: $local_fs $network $named $remote_fs cloud-init-local
# Should-Start: $time # Should-Start: $time
-# Required-Stop: -# Required-Stop:
-# Should-Stop: -# Should-Stop:
-# Default-Start: 2 3 4 5
+# Required-Stop: $null +# Required-Stop: $null
+# Should-Stop: $null +# Should-Stop: $null
# Default-Start: 2 3 4 5 +# Default-Start: 2 3 5
# Default-Stop: 0 1 6 # Default-Stop: 0 1 6
# Short-Description: The initial cloud-init job (net and fs contingent) # Short-Description: The initial cloud-init job (net and fs contingent)
# Description: Start cloud-init and runs the initialization phase
@@ -62,6 +62,9 @@ conf="/etc/cloud/cloud.cfg"
[ -f /etc/sysconfig/cloud-init ] && . /etc/sysconfig/cloud-init
[ -f /etc/default/cloud-init ] && . /etc/default/cloud-init
+. /etc/rc.status
+rc_reset
+
start() {
[ -x $cloud_init ] || return 5
[ -f $conf ] || return 6
@@ -103,6 +106,8 @@ case "$1" in
;;
status)
echo -n $"Checking for service $prog:"
+ RETVAL=3
+ [ -e /root/.ssh/authorized_keys ] && RETVAL=0
# Return value is slightly different for the status command:
# 0 - service up and running
# 1 - service dead, but /var/run/ pid file exists
@@ -110,7 +115,6 @@ case "$1" in
# 3 - service not running (unused)
# 4 - service status unknown :-(
# 5--199 reserved (5--99 LSB, 100--149 distro, 150--199 appl.)
- RETVAL=3
;;
*)
echo "Usage: $0 {start|stop|status|try-restart|condrestart|restart|force-reload|reload}"
@@ -118,4 +122,6 @@ case "$1" in
;;
esac
-exit $RETVAL
+_rc_status=$RETVAL
+rc_status -v
+rc_exit
Index: sysvinit/cloud-init-local
===================================================================
--- sysvinit/cloud-init-local.orig --- sysvinit/cloud-init-local.orig
+++ sysvinit/cloud-init-local +++ sysvinit/cloud-init-local
@@ -27,8 +27,8 @@ @@ -27,9 +27,9 @@
# Provides: cloud-init-local # Provides: cloud-init-local
# Required-Start: $local_fs $remote_fs # Required-Start: $local_fs $remote_fs
# Should-Start: $time # Should-Start: $time
-# Required-Stop: -# Required-Stop:
-# Should-Stop: -# Should-Stop:
-# Default-Start: 2 3 4 5
+# Required-Stop: $null +# Required-Stop: $null
+# Should-Stop: $null +# Should-Stop: $null
# Default-Start: 2 3 4 5 +# Default-Start: 2 3 5
# Default-Stop: 0 1 6 # Default-Stop: 0 1 6
# Short-Description: The initial cloud-init job (local fs contingent) # Short-Description: The initial cloud-init job (local fs contingent)
# Description: Start cloud-init and runs the initialization phases
@@ -62,6 +62,9 @@ conf="/etc/cloud/cloud.cfg"
[ -f /etc/sysconfig/cloud-init ] && . /etc/sysconfig/cloud-init
[ -f /etc/default/cloud-init ] && . /etc/default/cloud-init
+. /etc/rc.status
+rc_reset
+
start() {
[ -x $cloud_init ] || return 5
[ -f $conf ] || return 6
@@ -118,4 +121,6 @@ case "$1" in
;;
esac
-exit $RETVAL
+_rc_status=$RETVAL
+rc_status -v
+rc_exit

View File

@ -341,7 +341,7 @@ Index: cloud-init-0.7.2/cloudinit/distros/sles.py
+ +
+ cmd = ['zypper'] + cmd = ['zypper']
+ # No user interaction possible, enable non-interactive mode + # No user interaction possible, enable non-interactive mode
+ cmd.append('-t') + cmd.append('--non-interactive')
+ # Do not check the keys, we assume that the initial repos configured + # Do not check the keys, we assume that the initial repos configured
+ # in the image can be trusted + # in the image can be trusted
+ cmd.append('--no-gpg-checks') + cmd.append('--no-gpg-checks')