Add separate clone parameter (#5307)
* Add separate clone parameter This brings the hg module in line with the git module for controlling individual update and checkout functionality based on whether the directory exists or not. It also allows specifying `no` for both to pull the remote revision without performing a checkout * Reflect the right added ver for the hg clone arg
This commit is contained in:
parent
422ec08649
commit
97bf5b84e3
1 changed files with 36 additions and 5 deletions
|
@ -41,6 +41,7 @@ options:
|
||||||
dest:
|
dest:
|
||||||
description:
|
description:
|
||||||
- Absolute path of where the repository should be cloned to.
|
- Absolute path of where the repository should be cloned to.
|
||||||
|
This parameter is required, unless clone and update are set to no
|
||||||
required: true
|
required: true
|
||||||
default: null
|
default: null
|
||||||
revision:
|
revision:
|
||||||
|
@ -70,6 +71,13 @@ options:
|
||||||
version_added: "2.0"
|
version_added: "2.0"
|
||||||
description:
|
description:
|
||||||
- If C(no), do not retrieve new revisions from the origin repository
|
- If C(no), do not retrieve new revisions from the origin repository
|
||||||
|
clone:
|
||||||
|
required: false
|
||||||
|
default: "yes"
|
||||||
|
choices: [ "yes", "no" ]
|
||||||
|
version_added: "2.3"
|
||||||
|
description:
|
||||||
|
- If C(no), do not clone the repository if it does not exist locally.
|
||||||
executable:
|
executable:
|
||||||
required: false
|
required: false
|
||||||
default: null
|
default: null
|
||||||
|
@ -88,6 +96,10 @@ requirements: [ ]
|
||||||
EXAMPLES = '''
|
EXAMPLES = '''
|
||||||
# Ensure the current working copy is inside the stable branch and deletes untracked files if any.
|
# Ensure the current working copy is inside the stable branch and deletes untracked files if any.
|
||||||
- hg: repo=https://bitbucket.org/user/repo1 dest=/home/user/repo1 revision=stable purge=yes
|
- hg: repo=https://bitbucket.org/user/repo1 dest=/home/user/repo1 revision=stable purge=yes
|
||||||
|
|
||||||
|
# Example just get information about the repository whether or not it has
|
||||||
|
# already been cloned locally.
|
||||||
|
- hg: repo=git://bitbucket.org/user/repo dest=/srv/checkout clone=no update=no
|
||||||
'''
|
'''
|
||||||
|
|
||||||
import os
|
import os
|
||||||
|
@ -129,6 +141,13 @@ class Hg(object):
|
||||||
else:
|
else:
|
||||||
return to_native(out).strip('\n')
|
return to_native(out).strip('\n')
|
||||||
|
|
||||||
|
def get_remote_revision(self):
|
||||||
|
(rc, out, err) = self._command(['id', self.repo])
|
||||||
|
if rc != 0:
|
||||||
|
self.module_fail_json(msg=err)
|
||||||
|
else:
|
||||||
|
return to_native(out).strip('\n')
|
||||||
|
|
||||||
def has_local_mods(self):
|
def has_local_mods(self):
|
||||||
now = self.get_revision()
|
now = self.get_revision()
|
||||||
if '+' in now:
|
if '+' in now:
|
||||||
|
@ -215,11 +234,12 @@ def main():
|
||||||
module = AnsibleModule(
|
module = AnsibleModule(
|
||||||
argument_spec = dict(
|
argument_spec = dict(
|
||||||
repo = dict(required=True, aliases=['name']),
|
repo = dict(required=True, aliases=['name']),
|
||||||
dest = dict(required=True, type='path'),
|
dest = dict(type='path'),
|
||||||
revision = dict(default=None, aliases=['version']),
|
revision = dict(default=None, aliases=['version']),
|
||||||
force = dict(default='no', type='bool'),
|
force = dict(default='no', type='bool'),
|
||||||
purge = dict(default='no', type='bool'),
|
purge = dict(default='no', type='bool'),
|
||||||
update = dict(default='yes', type='bool'),
|
update = dict(default='yes', type='bool'),
|
||||||
|
clone = dict(default='yes', type='bool'),
|
||||||
executable = dict(default=None),
|
executable = dict(default=None),
|
||||||
),
|
),
|
||||||
)
|
)
|
||||||
|
@ -229,22 +249,33 @@ def main():
|
||||||
force = module.params['force']
|
force = module.params['force']
|
||||||
purge = module.params['purge']
|
purge = module.params['purge']
|
||||||
update = module.params['update']
|
update = module.params['update']
|
||||||
|
clone = module.params['clone']
|
||||||
hg_path = module.params['executable'] or module.get_bin_path('hg', True)
|
hg_path = module.params['executable'] or module.get_bin_path('hg', True)
|
||||||
hgrc = os.path.join(dest, '.hg/hgrc')
|
if dest is not None:
|
||||||
|
hgrc = os.path.join(dest, '.hg/hgrc')
|
||||||
|
|
||||||
# initial states
|
# initial states
|
||||||
before = ''
|
before = ''
|
||||||
changed = False
|
changed = False
|
||||||
cleaned = False
|
cleaned = False
|
||||||
|
|
||||||
|
if not dest and (clone or update):
|
||||||
|
module.fail_json(msg="the destination directory must be specified unless clone=no and update=no")
|
||||||
|
|
||||||
hg = Hg(module, dest, repo, revision, hg_path)
|
hg = Hg(module, dest, repo, revision, hg_path)
|
||||||
|
|
||||||
# If there is no hgrc file, then assume repo is absent
|
# If there is no hgrc file, then assume repo is absent
|
||||||
# and perform clone. Otherwise, perform pull and update.
|
# and perform clone. Otherwise, perform pull and update.
|
||||||
|
if not clone and not update:
|
||||||
|
out = hg.get_remote_revision()
|
||||||
|
module.exit_json(after=out, changed=False)
|
||||||
if not os.path.exists(hgrc):
|
if not os.path.exists(hgrc):
|
||||||
(rc, out, err) = hg.clone()
|
if clone:
|
||||||
if rc != 0:
|
(rc, out, err) = hg.clone()
|
||||||
module.fail_json(msg=err)
|
if rc != 0:
|
||||||
|
module.fail_json(msg=err)
|
||||||
|
else:
|
||||||
|
module.exit_json(changed=False)
|
||||||
elif not update:
|
elif not update:
|
||||||
# Just return having found a repo already in the dest path
|
# Just return having found a repo already in the dest path
|
||||||
before = hg.get_revision()
|
before = hg.get_revision()
|
||||||
|
|
Loading…
Reference in a new issue