summaryrefslogtreecommitdiffstats
path: root/src/lib/Bcfg2/Client/Tools/POSIX/Hardlink.py
diff options
context:
space:
mode:
authorChris St. Pierre <chris.a.st.pierre@gmail.com>2012-09-24 13:07:15 -0400
committerChris St. Pierre <chris.a.st.pierre@gmail.com>2012-09-25 11:58:47 -0400
commit6d4d8df68717780239fad273dd722359db10e64b (patch)
treec50c94430a417cab3c97084022d85332065b022b /src/lib/Bcfg2/Client/Tools/POSIX/Hardlink.py
parentdd28e90f183972cc2a395094ce3e3f72e861953f (diff)
downloadbcfg2-6d4d8df68717780239fad273dd722359db10e64b.tar.gz
bcfg2-6d4d8df68717780239fad273dd722359db10e64b.tar.bz2
bcfg2-6d4d8df68717780239fad273dd722359db10e64b.zip
expanded pylint tests
Diffstat (limited to 'src/lib/Bcfg2/Client/Tools/POSIX/Hardlink.py')
-rw-r--r--src/lib/Bcfg2/Client/Tools/POSIX/Hardlink.py48
1 files changed, 10 insertions, 38 deletions
diff --git a/src/lib/Bcfg2/Client/Tools/POSIX/Hardlink.py b/src/lib/Bcfg2/Client/Tools/POSIX/Hardlink.py
index ca7a23717..64a0b1e15 100644
--- a/src/lib/Bcfg2/Client/Tools/POSIX/Hardlink.py
+++ b/src/lib/Bcfg2/Client/Tools/POSIX/Hardlink.py
@@ -1,43 +1,15 @@
-import os
-import sys
-try:
- from base import POSIXTool
-except ImportError:
- # py3k, incompatible syntax with py2.4
- exec("from .base import POSIXTool")
+""" Handle <Path type="hardlink" ...> entries """
-class POSIXHardlink(POSIXTool):
- __req__ = ['name', 'to']
+import os
+from Bcfg2.Client.Tools.POSIX.base import POSIXLinkTool
- def verify(self, entry, modlist):
- rv = True
- try:
- if not os.path.samefile(entry.get('name'), entry.get('to')):
- msg = "Hardlink %s is incorrect" % entry.get('name')
- self.logger.debug("POSIX: " + msg)
- entry.set('qtext', "\n".join([entry.get('qtext', ''), msg]))
- rv = False
- except OSError:
- self.logger.debug("POSIX: %s %s does not exist" %
- (entry.tag, entry.get("name")))
- entry.set('current_exists', 'false')
- return False
+class POSIXHardlink(POSIXLinkTool):
+ """ Handle <Path type="hardlink" ...> entries """
+ __linktype__ = "hardlink"
- return POSIXTool.verify(self, entry, modlist) and rv
-
- def install(self, entry):
- ondisk = self._exists(entry, remove=True)
- if ondisk:
- self.logger.info("POSIX: Hardlink %s cleanup failed" %
- entry.get('name'))
- try:
- os.link(entry.get('to'), entry.get('name'))
- rv = True
- except OSError:
- err = sys.exc_info()[1]
- self.logger.error("POSIX: Failed to create hardlink %s to %s: %s" %
- (entry.get('name'), entry.get('to'), err))
- rv = False
- return POSIXTool.install(self, entry) and rv
+ def _verify(self, entry):
+ return os.path.samefile(entry.get('name'), entry.get('to'))
+ def _link(self, entry):
+ return os.link(entry.get('to'), entry.get('name'))