2011-04-21 16:14:06 +02:00
|
|
|
Index: InitScriptCheck.py
|
|
|
|
===================================================================
|
|
|
|
--- InitScriptCheck.py.orig
|
2008-04-17 04:52:37 +02:00
|
|
|
+++ InitScriptCheck.py
|
2011-04-21 16:14:06 +02:00
|
|
|
@@ -29,6 +29,10 @@ dot_in_name_regex = re.compile('.*\..*')
|
2011-04-21 12:12:02 +02:00
|
|
|
use_deflevels = Config.getOption('UseDefaultRunlevels', True)
|
2008-04-17 04:52:37 +02:00
|
|
|
lsb_tags_regex = re.compile('^# ([\w-]+):\s*(.*?)\s*$')
|
|
|
|
lsb_cont_regex = re.compile('^#(?:\t| )(.*?)\s*$')
|
|
|
|
+insserv_regex=re.compile('^\s*sbin/insserv', re.MULTILINE)
|
2011-04-21 16:14:06 +02:00
|
|
|
+stop_on_removal_regex=re.compile('^\s*%stop_on_removal\s+\S+', re.MULTILINE)
|
|
|
|
+restart_on_update_regex=re.compile('^\s*%restart_on_update\s\S+', re.MULTILINE)
|
2011-04-21 12:12:02 +02:00
|
|
|
+insserv_cleanup_regex=re.compile('^\s*%insserv_cleanup', re.MULTILINE)
|
2008-04-17 04:52:37 +02:00
|
|
|
|
2009-08-21 18:19:06 +02:00
|
|
|
LSB_KEYWORDS = ('Provides', 'Required-Start', 'Required-Stop', 'Should-Start',
|
|
|
|
'Should-Stop', 'Default-Start', 'Default-Stop',
|
2011-04-21 16:14:06 +02:00
|
|
|
@@ -47,6 +51,13 @@ class InitScriptCheck(AbstractCheck.Abst
|
2008-04-17 04:52:37 +02:00
|
|
|
return
|
|
|
|
|
|
|
|
initscript_list = []
|
|
|
|
+
|
2009-08-21 18:19:06 +02:00
|
|
|
+
|
2008-04-17 04:52:37 +02:00
|
|
|
+ # check chkconfig call in %post and %preun
|
2009-08-21 18:19:06 +02:00
|
|
|
+ postin = pkg[rpm.RPMTAG_POSTIN] or pkg[rpm.RPMTAG_POSTINPROG]
|
|
|
|
+ preun = pkg[rpm.RPMTAG_PREUN] or pkg[rpm.RPMTAG_PREUNPROG]
|
|
|
|
+ postun = pkg[rpm.RPMTAG_POSTUN] or pkg[rpm.RPMTAG_POSTUNPROG]
|
2008-04-17 04:52:37 +02:00
|
|
|
+
|
2009-08-21 18:19:06 +02:00
|
|
|
for fname, pkgfile in pkg.files().items():
|
2008-04-17 04:52:37 +02:00
|
|
|
|
2011-04-21 12:12:02 +02:00
|
|
|
if not fname.startswith('/etc/init.d/') and \
|
2011-04-21 16:14:06 +02:00
|
|
|
@@ -60,18 +71,19 @@ class InitScriptCheck(AbstractCheck.Abst
|
2011-04-21 12:12:02 +02:00
|
|
|
|
|
|
|
if dot_in_name_regex.match(basename):
|
|
|
|
printError(pkg, 'init-script-name-with-dot', fname)
|
|
|
|
- # check chkconfig call in %post and %preun
|
|
|
|
- postin = pkg[rpm.RPMTAG_POSTIN] or pkg[rpm.RPMTAG_POSTINPROG]
|
|
|
|
- if not postin:
|
|
|
|
- printError(pkg, 'init-script-without-chkconfig-postin', fname)
|
|
|
|
- elif not chkconfig_regex.search(postin):
|
|
|
|
- printError(pkg, 'postin-without-chkconfig', fname)
|
|
|
|
|
|
|
|
- preun = pkg[rpm.RPMTAG_PREUN] or pkg[rpm.RPMTAG_PREUNPROG]
|
|
|
|
if not preun:
|
|
|
|
- printError(pkg, 'init-script-without-chkconfig-preun', fname)
|
|
|
|
- elif not chkconfig_regex.search(preun):
|
|
|
|
- printError(pkg, 'preun-without-chkconfig', fname)
|
|
|
|
+ printError(pkg, 'init-script-without-%stop_on_removal-preun', fname)
|
|
|
|
+ elif not stop_on_removal_regex.search(postin):
|
2011-04-21 16:14:06 +02:00
|
|
|
+ printError(pkg, 'preun-without-%stop_on_removal-preun', fname)
|
2008-04-17 04:52:37 +02:00
|
|
|
+
|
2011-04-21 12:12:02 +02:00
|
|
|
+ if not postun:
|
|
|
|
+ printError(pkg, 'init-script-without-%restart_on_update-postun', fname)
|
|
|
|
+ else:
|
|
|
|
+ if not restart_on_update_regex.search(postun):
|
|
|
|
+ printError(pkg, 'postun-without-%restart_on_update', fname)
|
|
|
|
+ if not insserv_cleanup_regex.search(postun):
|
|
|
|
+ printError(pkg, 'postun-without-%insserv_cleanup', fname)
|
2008-04-17 04:52:37 +02:00
|
|
|
|
2011-04-21 12:12:02 +02:00
|
|
|
status_found = False
|
|
|
|
reload_found = False
|
2011-04-21 16:14:06 +02:00
|
|
|
@@ -202,10 +214,18 @@ a call to chkconfig.''',
|
2011-04-21 12:12:02 +02:00
|
|
|
'''The package contains an init script but doesn't call chkconfig in its
|
|
|
|
%post script.''',
|
2008-04-17 04:52:37 +02:00
|
|
|
|
|
|
|
-'init-script-without-chkconfig-preun',
|
|
|
|
+'init-script-without-%stop_on_removal-preun',
|
|
|
|
'''The package contains an init script but doesn't contain a %preun with
|
|
|
|
a call to chkconfig.''',
|
|
|
|
|
|
|
|
+'init-script-without-%insserv_cleanup-postun',
|
|
|
|
+'''The package contains an init script but doesn't contain a %postun
|
|
|
|
+with a call to %insserv_cleanup-postun''',
|
|
|
|
+
|
|
|
|
+'postun-without-%insserv_cleanup',
|
|
|
|
+'''The package contains an init script but doesn't contain a %postun
|
|
|
|
+with a call to %insserv_cleanup-postun''',
|
|
|
|
+
|
|
|
|
'preun-without-chkconfig',
|
2011-04-21 12:12:02 +02:00
|
|
|
'''The package contains an init script but doesn't call chkconfig in its
|
|
|
|
%preun script.''',
|
2011-04-21 16:14:06 +02:00
|
|
|
@@ -264,6 +284,24 @@ of chkconfig don't work as expected with
|
2008-04-17 04:52:37 +02:00
|
|
|
'init-script-non-executable',
|
|
|
|
'''The init script should have at least the execution bit set for root
|
|
|
|
in order for it to run at boot time.''',
|
|
|
|
+
|
|
|
|
+'init-script-without-%stop_on_removal-preun',
|
|
|
|
+'''The init script should have a %preun script that calls %stop_on_removal.''',
|
|
|
|
+
|
|
|
|
+'preun-without-%stop_on_removal-preun',
|
|
|
|
+'''The init script is not listed in %stop_on_removal in %preun.''',
|
|
|
|
+
|
|
|
|
+'init-script-without-%insserv_cleanup-postun',
|
|
|
|
+'''The package doesn't have a %insserv_cleanup call in %postun''',
|
|
|
|
+
|
|
|
|
+'postun-without-%insserv_cleanup',
|
2011-04-21 12:12:02 +02:00
|
|
|
+'''The package has an init script that is inserted with insserv but
|
|
|
|
+doesn't have a %insserv_cleanup call in %postun''',
|
|
|
|
+
|
|
|
|
+'init-script-without-%restart_on_update-postun',
|
|
|
|
+''' The package has an init script but is missing the %restart_on_update
|
|
|
|
+call in %postun to automatically restart the daemon. This is optional,
|
|
|
|
+but in most cases it is wanted. Please check.'''
|
2008-04-17 04:52:37 +02:00
|
|
|
)
|
|
|
|
|
|
|
|
# InitScriptCheck.py ends here
|