Browse Source

Improve limitations related to `git.latest` in `salt.formulas` (#239)

* Ensure options for formulas `git.latest` are also based on defaults

* Prevent erroneous remote tracking branch modification by `salt.formulas` #238

* Allow multiple envs to use the same gitdir for `salt.formulas`

* Ensure `gitdir` original branch is checked out after formulas `git.latest`

* Fix erroneous comment re: merging in `salt` pillar
tags/v0.57.0
myii 6 years ago
parent
commit
91b666c75f
5 changed files with 61 additions and 8 deletions
  1. +3
    -0
      pillar.example
  2. +3
    -0
      salt/defaults.yaml
  3. +10
    -1
      salt/formulas.jinja
  4. +37
    -6
      salt/formulas.sls
  5. +8
    -1
      salt/map.jinja

+ 3
- 0
pillar.example View File

@@ -351,6 +351,9 @@ salt_formulas:
user: root
group: root
mode: 755
# Explicitly checkout the original branch for repos after the
# git.latest states have been processed (False by default)
checkout_orig_branch: False
# List of formulas to enable in each environment
list:
base:

+ 3
- 0
salt/defaults.yaml View File

@@ -53,3 +53,6 @@ salt:
providers: salt://salt/files/cloud.providers.d
profiles: salt://salt/files/cloud.profiles.d
maps: salt://salt/files/cloud.maps.d

salt_formulas:
checkout_orig_branch: False

+ 10
- 1
salt/formulas.jinja View File

@@ -2,7 +2,9 @@
'baseurl': 'https://github.com/saltstack-formulas',
'basedir': '/srv/formulas',
'update': False,
'options': {},
'options': {
'branch': 'master',
},
}
%}
{% set formulas = salt['pillar.get']('salt_formulas:list', {}) %}
@@ -14,6 +16,13 @@
{{ value|yaml }}
{%- endmacro -%}

{%- macro formulas_opts_for_git_latest(env) -%}
{%- set options = defaults['options'] or {} -%}
{%- do options.update(salt['pillar.get']('salt_formulas:git_opts:default:options') or {}) -%}
{%- do options.update(salt['pillar.get']('salt_formulas:git_opts:{0}:options'.format(env)) or {}) -%}
{{ options|yaml }}
{%- endmacro -%}

{%- macro formulas_roots(env) -%}
{%- set value = [] -%}
{%- for dir in formulas.get(env, []) -%}

+ 37
- 6
salt/formulas.sls View File

@@ -1,7 +1,10 @@
{% set processed_gitdirs = [] %}
{% set processed_gitdirs = {} %}
{% set processed_gitdir_envs = [] %}
{% set processed_basedirs = [] %}

{% from "salt/map.jinja" import formulas_settings with context %}
{% from "salt/formulas.jinja" import formulas_git_opt with context %}
{% from "salt/formulas.jinja" import formulas_opts_for_git_latest with context %}

# Loop over all formulas listed in pillar data
{% for env, entries in salt['pillar.get']('salt_formulas:list', {}).items() %}
@@ -11,6 +14,15 @@
{% set gitdir = '{0}/{1}'.format(basedir, entry) %}
{% set update = formulas_git_opt(env, 'update')|load_yaml %}

{% if formulas_settings.checkout_orig_branch %}
{% if not salt['file.directory_exists']('{0}/{1}'.format(gitdir, '.git')) %}
{% set gitdir_branch = '' %}
{% else %}
{% set gitdir_branch = salt['git.current_branch'](gitdir) %}
{% endif %}
{% do processed_gitdirs.update({gitdir:gitdir_branch}) %}
{% endif %}

# Setup the directory hosting the Git repository
{% if basedir not in processed_basedirs %}
{% do processed_basedirs.append(basedir) %}
@@ -23,11 +35,13 @@
{% endif %}

# Setup the formula Git repository
{% if gitdir not in processed_gitdirs %}
{% do processed_gitdirs.append(gitdir) %}
{% set options = formulas_git_opt(env, 'options')|load_yaml %}
{% set gitdir_env = '{0}_{1}'.format(gitdir, env) %}
{% if gitdir_env not in processed_gitdir_envs %}
{% do processed_gitdir_envs.append(gitdir_env) %}
{% set options = formulas_opts_for_git_latest(env)|load_yaml %}
{% set baseurl = formulas_git_opt(env, 'baseurl')|load_yaml %}
{{ gitdir }}:

{{ gitdir_env }}:
git.latest:
- name: {{ baseurl }}/{{ entry }}.git
- target: {{ gitdir }}
@@ -40,6 +54,23 @@
- unless: test -e {{ gitdir }}
{%- endif %}
{% endif %}

{% endfor %}
{% endfor %}

{% if formulas_settings.checkout_orig_branch %}
# For each directory processed, explicitly checkout the original branch before
# the `git.latest` state ran
{% for gitdir, original_branch in processed_gitdirs.items() %}
{% if original_branch %}
{% set gitdir_user = salt['file.get_user'](gitdir) %}
checkout_original_branch_for_{{ gitdir }}:
module.run:
- name: git.checkout
- order: last
- cwd: {{ gitdir }}
- rev: {{ original_branch }}
- user: {{ gitdir_user }}
- unless: test "$(cd {{ gitdir }}; git rev-parse --abbrev-ref HEAD)" = "{{ original_branch }}"
{% endif %}
{% endfor %}
{% endif %}

+ 8
- 1
salt/map.jinja View File

@@ -218,9 +218,16 @@ that differ from whats in defaults.yaml
{## Merge the flavor_map to the default settings ##}
{% do deep_merge(default_settings.salt,os_family_map) %}

{## Merge in salt:lookup pillar ##}
{## Merge in salt pillar ##}
{% set salt_settings = salt['pillar.get'](
'salt',
default=default_settings.salt,
merge=True)
%}

{## Merge in salt_formulas pillar ##}
{% set formulas_settings = salt['pillar.get'](
'salt_formulas',
default=default_settings.salt_formulas,
merge=True)
%}

Loading…
Cancel
Save