SEARCH
NEW RPMS
DIRECTORIES
ABOUT
FAQ
VARIOUS
BLOG

 
 

salt-lint rpm build for : openSUSE Tumbleweed. For other distributions click salt-lint.

Name : salt-lint
Version : 0.9.2 Vendor : obs://build_opensuse_org/home:aschnell
Release : 2.18 Date : 2023-06-14 14:47:46
Group : Development/Languages/Python Source RPM : salt-lint-0.9.2-2.18.src.rpm
Size : 0.21 MB
Packager : (none)
Summary : A command-line utility that checks for best practices in SaltStack
Description :
.. image:: https://img.shields.io/pypi/v/salt-lint.svg?style=for-the-badge
:target: https://pypi.org/project/salt-lint
:alt: PyPI

.. image:: https://img.shields.io/travis/roaldnefs/salt-lint.svg?style=for-the-badge
:target: https://travis-ci.org/roaldnefs/salt-lint
:alt: Travis (.org)

.. image:: https://img.shields.io/coveralls/github/roaldnefs/salt-lint.svg?style=for-the-badge
:target: https://coveralls.io/github/roaldnefs/salt-lint
:alt: Coveralls

Salt-lint
=========

``salt-lint`` checks Salt state files (SLS) for practices and behavior that could potentially be improved.

The project is heavily based on `ansible-lint`_, which was created by `Will Thames`_ and is now maintained as part of the `Ansible`_ by `Red Hat`_ project.

Installing
==========

Using Pip
---------

.. code-block:: bash

pip install salt-lint

From Source
-----------

.. code-block:: bash

pip install git+https://github.com/roaldnefs/salt-lint.git

Usage
=====

Command Line Options
--------------------

The following is the output from ``salt-lint --help``, providing an overview of the basic command line options:

.. code-block:: bash

Usage: salt-lint [options] init.sls [state ...]

Options:
--version show program\'s version number and exit
-h, --help show this help message and exit
-L list all the rules
-r RULESDIR specify one or more rules directories using one or
more -r arguments. Any -r flags override the default
rules in /tmp/saltlint/lib/saltlint/rules, unless -R
is also used.
-R Use default rules in /tmp/saltlint/lib/saltlint/rules
in addition to any extra rules directories specified
with -r. There is no need to specify this if no -r
flags are used.
-t TAGS only check rules whose id/tags match these values
-T list all the tags
-v Increase verbosity level
-x SKIP_LIST only check rules whose id/tags do not match these
values
--nocolor disable colored output
--force-color Try force colored output (relying on salt\'s code)
--exclude=EXCLUDE_PATHS
path to directories or files to skip. This option is
repeatable.
-c C Specify configuration file to use. Defaults to
\".salt-lint\"

Linting Salt state files
------------------------

It\'s important to note that ``salt-lint`` accepts a list of Salt state files or a list of directories.

GitHub Action
-------------

Salt-lint is available on the GitHub `marketplace`_ as a GitHub Action. The `salt-lint-action`_ allows you to run ``salt-lint`` with no additional options.

To use the action simply add the following lines to your ``.github/workflows/main.yml``.

.. code-block:: yaml

on: [push]

jobs:
test:
runs-on: ubuntu-latest
name: Salt Lint Action
steps:
- uses: actions/checkoutAATTv1
- name: Run salt-lint
uses: roaldnefs/salt-lint-actionAATTmaster
env:
ACTION_STATE_NAME: init.sls

Configuring
===========

Configuration File
------------------

Salt-lint supports local configuration via a ``.salt-lint`` configuration file. Salt-lint checks the working directory for the presence of this file and applies any configuration found there. The configuration file location can also be overridden via the ``-c path/to/file`` CLI flag.

If a value is provided on both the command line and via a configuration file, the values will be merged (if a list like **exclude_paths**), or the **True** value will be preferred, in the case of something like **quiet**.

The following values are supported, and function identically to their CLI counterparts:

.. code-block:: yaml

---
exclude_paths:
- exclude_this_file
- exclude_this_directory/
- exclude/this/sub-directory/
skip_list:
- 207
- 208
tags:
- formatting
verbosity: 1

Pre-commit Setup
----------------

To use salt-lint with `pre-commit`_, just add the following to your local repo\'s ``.pre-commit-config.yaml`` file. Prior to version 0.12.0 of `pre-commit`_ the file was ``hooks.yaml`` (now ``.pre-commit-config.yaml``).

.. code-block:: yaml

---




- id: salt-lint
name: Salt-lint
description: This hook runs salt-lint.
entry: salt-lint
language: python
files: \\.(sls)$

Rules
=====

False Positives: Skipping Rules
-------------------------------

Some rules are bit of a rule of thumb. To skip a specific rule for a specific task, inside your state add ``# noqa [rule_id]`` at the end of the line. You can skip multiple rules via a space-separated list. Example:

.. code-block:: yaml

/tmp/testfile:
file.managed:
- source: salt://{{unspaced_var}}/example # noqa: 206

Authors
=======

salt-lint is heavily based on `ansible-lint`_ with the modified work by `Roald Nefs`_. `ansible-lint`_ was created by `Will Thames`_ and is now maintained as part of the `Ansible`_ by `Red Hat`_ project.

.. _pre-commit: https://pre-commit.com
.. _ansible-lint: https://github.com/ansible/ansible-lint
.. _Roald Nefs: https://github.com/roaldnefs
.. _Will Thames: https://github.com/willthames
.. _Ansible: https://ansible.com
.. _Red Hat: https://redhat.com
.. _marketplace: https://github.com/marketplace/actions/salt-lint
.. _salt-lint-action: https://github.com/roaldnefs/salt-lint-action

RPM found in directory: /packages/linux-pbone/ftp5.gwdg.de/pub/opensuse/repositories/home:/aschnell:/boost/openSUSE_Tumbleweed/noarch

Content of RPM  Changelog  Provides Requires

Download
ftp.icm.edu.pl  salt-lint-0.9.2-2.18.noarch.rpm
     

Provides :
python3.11dist(salt-lint)
python3dist(salt-lint)
salt-lint

Requires :
/usr/bin/python3.11
python(abi) = 3.11
python3 >= 3.6
python3-PyYAML
python3-pathspec >= 0.6.0
python3-salt
rpmlib(CompressedFileNames) <= 3.0.4-1
rpmlib(FileDigests) <= 4.6.0-1
rpmlib(PayloadFilesHavePrefix) <= 4.0-1
rpmlib(PayloadIsZstd) <= 5.4.18-1


Content of RPM :
/usr/bin/salt-lint
/usr/lib/python3.11/site-packages/salt_lint-0.9.2-py3.11.egg-info
/usr/lib/python3.11/site-packages/salt_lint-0.9.2-py3.11.egg-info/PKG-INFO
/usr/lib/python3.11/site-packages/salt_lint-0.9.2-py3.11.egg-info/SOURCES.txt
/usr/lib/python3.11/site-packages/salt_lint-0.9.2-py3.11.egg-info/dependency_links.txt
/usr/lib/python3.11/site-packages/salt_lint-0.9.2-py3.11.egg-info/entry_points.txt
/usr/lib/python3.11/site-packages/salt_lint-0.9.2-py3.11.egg-info/not-zip-safe
/usr/lib/python3.11/site-packages/salt_lint-0.9.2-py3.11.egg-info/requires.txt
/usr/lib/python3.11/site-packages/salt_lint-0.9.2-py3.11.egg-info/top_level.txt
/usr/lib/python3.11/site-packages/saltlint
/usr/lib/python3.11/site-packages/saltlint/__init__.py
/usr/lib/python3.11/site-packages/saltlint/__main__.py
/usr/lib/python3.11/site-packages/saltlint/__pycache__
/usr/lib/python3.11/site-packages/saltlint/__pycache__/__init__.cpython-311.opt-1.pyc
/usr/lib/python3.11/site-packages/saltlint/__pycache__/__init__.cpython-311.pyc
/usr/lib/python3.11/site-packages/saltlint/__pycache__/__main__.cpython-311.opt-1.pyc
/usr/lib/python3.11/site-packages/saltlint/__pycache__/__main__.cpython-311.pyc
/usr/lib/python3.11/site-packages/saltlint/__pycache__/cli.cpython-311.opt-1.pyc
/usr/lib/python3.11/site-packages/saltlint/__pycache__/cli.cpython-311.pyc
/usr/lib/python3.11/site-packages/saltlint/__pycache__/config.cpython-311.opt-1.pyc
/usr/lib/python3.11/site-packages/saltlint/__pycache__/config.cpython-311.pyc
/usr/lib/python3.11/site-packages/saltlint/__pycache__/utils.cpython-311.opt-1.pyc
/usr/lib/python3.11/site-packages/saltlint/__pycache__/utils.cpython-311.pyc
/usr/lib/python3.11/site-packages/saltlint/cli.py
/usr/lib/python3.11/site-packages/saltlint/config.py
/usr/lib/python3.11/site-packages/saltlint/formatters
/usr/lib/python3.11/site-packages/saltlint/formatters/__init__.py
/usr/lib/python3.11/site-packages/saltlint/formatters/__pycache__
/usr/lib/python3.11/site-packages/saltlint/formatters/__pycache__/__init__.cpython-311.opt-1.pyc
/usr/lib/python3.11/site-packages/saltlint/formatters/__pycache__/__init__.cpython-311.pyc
There is 138 files more in these RPM.

 
ICM