Tox: add tox job and requirements to improve specfiles

This is a tox job to scan the RPM specfiles and do some
initial sanity checks and use the OpenDev Spec-Cleaner tool, this
is not a 'linter' per-se, but will output a diff of recommended
changes for the specfile.

Initial disable cleaning our default CentOS specfiles since we
know they need work, we can enable this later.

This uses the speclint script in starlingx/integ a proposed
by the Depends-On.

The recommended guildline for openSUSE is located here:
https://en.opensuse.org/openSUSE:Specfile_guidelines

Fix up fm-rest-api opensuse specfile

Depends-On: https://review.opendev.org/664995
Change-Id: I46da780a667569a9dccedd551d955c983e9601cd
Signed-off-by: Saul Wold <sgw@linux.intel.com>
This commit is contained in:
Saul Wold 2019-05-14 13:31:12 -07:00
parent 59aa18cf57
commit 91af45019b
5 changed files with 38 additions and 4 deletions

View File

@ -11,6 +11,8 @@
- openstack-tox-linters - openstack-tox-linters
- openstack-tox-pep8 - openstack-tox-pep8
- stx-fault-build - stx-fault-build
- flock-check-packaging:
voting: false
gate: gate:
jobs: jobs:
- build-openstack-api-ref - build-openstack-api-ref
@ -56,3 +58,12 @@
fault: https://opendev.org/starlingx/fault fault: https://opendev.org/starlingx/fault
integ: https://opendev.org/starlingx/integ integ: https://opendev.org/starlingx/integ
update: https://opendev.org/starlingx/update update: https://opendev.org/starlingx/update
- job:
name: flock-check-packaging
parent: tox
description: Sanity check RPM spec files
required-projects:
- name: starlingx/integ
vars:
tox_envlist: rpm-packaging-lint

2
bindep.txt Normal file
View File

@ -0,0 +1,2 @@
diffutils
rpm

View File

@ -6,16 +6,16 @@ License: Apache-2.0
Group: Development/Tools/Other Group: Development/Tools/Other
URL: https://opendev.org/starlingx/fault URL: https://opendev.org/starlingx/fault
Source0: %{name}-%{version}.tar.xz Source0: %{name}-%{version}.tar.xz
BuildRequires: python2-oslo.config BuildRequires: insserv-compat
BuildRequires: python-oslo.db BuildRequires: python-oslo.db
BuildRequires: python2-oslo.log
BuildRequires: python-oslo.messaging BuildRequires: python-oslo.messaging
BuildRequires: python-oslo.middleware BuildRequires: python-oslo.middleware
BuildRequires: python-setuptools BuildRequires: python-setuptools
BuildRequires: python2-oslo.config
BuildRequires: python2-oslo.log
BuildRequires: python2-pip BuildRequires: python2-pip
BuildRequires: systemd BuildRequires: systemd
BuildRequires: systemd-rpm-macros BuildRequires: systemd-rpm-macros
BuildRequires: insserv-compat
Requires: python-eventlet Requires: python-eventlet
Requires: python-paste Requires: python-paste
Requires: python-webob Requires: python-webob

View File

@ -2,3 +2,4 @@ hacking!=0.13.0,<0.14,>=0.12.0
bashate >= 0.2 bashate >= 0.2
PyYAML >= 3.1.0 PyYAML >= 3.1.0
yamllint >= 0.5.2 yamllint >= 0.5.2
spec_cleaner>=1.0.9

22
tox.ini
View File

@ -1,5 +1,5 @@
[tox] [tox]
envlist = linters,pep8 envlist = linters,pep8,rpm-packaging-lint
minversion = 2.3 minversion = 2.3
skipsdist = True skipsdist = True
@ -11,6 +11,26 @@ setenv = VIRTUAL_ENV={envdir}
OS_TEST_TIMEOUT=60 OS_TEST_TIMEOUT=60
deps = -r{toxinidir}/test-requirements.txt deps = -r{toxinidir}/test-requirements.txt
[testenv:rpm-packaging-lint]
basepython = python3
setenv =
VIRTUAL_ENV={envdir}
LC_ALL=en_US.utf-8
install_command = pip install -U \
-c{env:UPPER_CONSTRAINTS_FILE:https://opendev.org/openstack/requirements/raw/branch/stable/stein/upper-constraints.txt} \
{opts} {packages}
deps = -r{toxinidir}/test-requirements.txt
whitelist_externals = bash
commands =
bash -c 'if [ -d {toxinidir}/../integ ]; then integdir={toxinidir}/../integ; \
else integdir={toxinidir}/../stx-integ; \
fi; \
find . \
-not \( -type d -name .?\* -prune \) \
-not \( -type d -name centos -prune \) \
-type f -name \*.spec \
-print0 | xargs -0 $integdir/tools/spec-tools/speclint.sh'
[testenv:linters] [testenv:linters]
basepython = python3 basepython = python3
whitelist_externals = bash whitelist_externals = bash