1
0
Fork 0
mirror of https://github.com/ansible-collections/community.general.git synced 2024-09-14 20:13:21 +02:00

Merge pull request #4931 from mscherer/urpmi_fix

Various fix for the urpmi module
This commit is contained in:
Michael DeHaan 2013-11-17 08:37:53 -08:00
commit b7971a426c

View file

@ -76,11 +76,18 @@ import json
import shlex
import os
import sys
try:
import rpm
USE_PYTHON = True
except ImportError:
USE_PYTHON = False
URPMI_PATH = '/usr/sbin/urpmi'
URPME_PATH = '/usr/sbin/urpme'
def query_package(module, name):
if USE_PYTHON:
return rpm.TransactionSet().dbMatch(rpm.RPMTAG_NAME, name).count() != 0
# rpm -q returns 0 if the package is installed,
# 1 if it is not installed
@ -90,6 +97,15 @@ def query_package(module, name):
else:
return False
def query_package_provides(module, name):
if USE_PYTHON:
return rpm.TransactionSet().dbMatch(rpm.RPMTAG_PROVIDES, name).count() != 0
# rpm -q returns 0 if the package is installed,
# 1 if it is not installed
rc = os.system("rpm -q --provides %s >/dev/null" % (name))
return rc == 0
def update_package_db(module):
rc = os.system("urpmi.update -a -q")
@ -125,7 +141,8 @@ def install_packages(module, pkgspec, force=True, no_suggests=True):
packages = ""
for package in pkgspec:
packages += "'%s' " % package
if not query_package_provides(module, package):
packages += "'%s' " % package
if len(packages) != 0:
if no_suggests: