Changes to tox in the past year have rendered the PBR-specific
tweaks in get_sdist_name invalid, since calling tox from within tox
now creates testenv directories relative to the parent tox's working
directory rather than the child's. While we're here, turn on more
verbose logging in the tox invocation, and fix the subprocess
routine to not discard the command's output.
Change-Id: I35fb5dde9ec400397ed21035d57c3efb872d8e58
The validate_pypi_permissions test checks that if the package exists on
PyPI, we have permissions to upload it. In order to validate that, it
first checks that the package exists by retrieving JSON information from
PyPI, and assuming that anything returned means the package exists.
However currently PyPI returns {'message': 'Not Found'} when queried for
JSON information about a non-existant package. This makes the test
assume that the package exists but we don't have permissions to upload
it, therefore failing the test.
This fix makes sure an empty dict is returned when an inexistant package
is queried, which makes the test succeed with the following message:
'no %s project data on pypi, assuming it will be created by release'
Change-Id: I27eb82109ab93fe33c339f82ec519feeb7228a1f
With the recent switch to using the build utility, this should no
longer be necessary. Even more recent changes in the Python
packaging toolchain seem to have made it stop working anyway, so
remove it and treat PBR's builds like any other project.
Change-Id: I6f9a4546fb6a7b2a4836d6aeea0713f7a7da3002
A missing comma was causing the strings to be concatenated,
resulting in a wrong command that caused the validate job
to fail.
Change-Id: I7c5dab48db725608c7b1cfa4e8e8034d8225b165
The new way of packaging a python project is via build package. This
patch replaces the old setup.py style sdist and wheel build.
Change-Id: Ia351d099aa3b2491e3a4d255d87bb7c6bd691cac
When validating PyPI settings, we retrieve package roles. If that
retrieval is not successful on the first try, we immediately retry
with a canonicalized version of the package. This sometimes hits
PyPI ratelimits. This patch introduces a one second sleep to avoid
that error.
Change-Id: Ifd20200159a2f136827a1987606b650a6db5588f
In order to tell pbr not to build release notes and create CHANGELOG and
AUTHORS files, we need to pass flags in as environment variables. We
can't just pass these flags though, as that will exclude the rest of the
normal environment set in. So copy the current environment, append our
updates, and pass that in explicitly to the subprocess call.
Change-Id: Ia47e73b51b3216572d51399338e95bd4269a8d1d
Signed-off-by: Sean McGinnis <sean.mcginnis@gmail.com>
We have a couple validations that need to build an sdist now. But once
it has been built in our temporary pristine clone, we don't need to
build it again. Because we create a clean clone, we also don't need to
worry about any stale dist builds. This adds a check to the sdist build
logic to recognize if an sdist has already been built and skip it.
There are also a few extra steps in the build process that are not
needed for our purposes. The biggest is the new(ish) pbr behavior of
building all release notes in the git tree if reno is present. This adds
an environment variable flag to tell pbr not to do that. While we're at
it, we don't need AUTHORS or CHANGELOG created either, so set the flags
telling pbr to skip those as well.
Change-Id: I15be9a12ff6684729980c40afae9625a8b8e550a
Signed-off-by: Sean McGinnis <sean.mcginnis@gmail.com>
Per best practices, explicitly use the python3 executable rather than
assuming the platform with have a "python" executable that maps to
python3.
https://www.python.org/dev/peps/pep-0394/
Change-Id: I39b8a1013a891f4570f374d8faa3cfa2ecaf3347
Signed-off-by: Sean McGinnis <sean.mcginnis@gmail.com>
The use of ``python setup.py check -r -s`` is actually deprecated and
the recommended method for validating a README for PyPi upload is to
build the sdist and wheel and run ``twine check $DIST_PATH``. This
switches our validation check to use the supported method.
Change-Id: I321b8cf6f1e2116d2fe23059d5f13aa6f2ae8b4c
Signed-off-by: Sean McGinnis <sean.mcginnis@gmail.com>
The JSON API path is wrong.
See https://warehouse.pypa.io/api-reference/json/
Change-Id: I1574e568e6c3eeddc3619591b6335c314bf92c39
Signed-off-by: Doug Hellmann <doug@doughellmann.com>
Try to build the sdist and wheel for python packages.
Change-Id: I6cf0ff8e7771367bce17061c9b21b7740516d31d
Signed-off-by: Doug Hellmann <doug@doughellmann.com>
PyPI is now more strict about requiring README.rst files to be
parseable. Failures to parse the readme block uploading new versions
of packages. To detect these errors in advance, we should validate the
README formatting as part of validating a release.
Change-Id: I416befcf3e47818680018394fa63de8983351587
Signed-off-by: Doug Hellmann <doug@doughellmann.com>
A seemingly-trivial change updated the URL for the
XMLRPC Pypi service from https://pypi.python.org/pypi
to https://pypi.org/project, while the XMLRPC service
lives at https://pypi.org/pypi. This resulted in
systematic validation failures.
Change-Id: I97218093a9346a7d84f58136764cce53930ddacb
Instead of passing None to the service as the sdist name, report that
situation as an error.
Change-Id: Ib6380d997db780ae324a4df61fdfa7f17e4507c3
Signed-off-by: Doug Hellmann <doug@doughellmann.com>
Rather than applying the rules ourselves, use the packaging project
utility function to prepare the canonical name.
Change-Id: I6310585ff14c376e954b0edc9def67cd65a5d550
Signed-off-by: Doug Hellmann <doug@doughellmann.com>
Projects that are going to try to upload releases to PyPI need to have
given openstackci permission to do that.
Change-Id: I8e5e60ea6bf2842e834d2352134a11b1f9fe02b9
Signed-off-by: Doug Hellmann <doug@doughellmann.com>
Skip the PyPI checks for things that are not python modules.
Change-Id: I15b0e42c961f7fae600f88ffe23edc22d1f98922
Signed-off-by: Doug Hellmann <doug@doughellmann.com>
Provide some wrappers around subprocess functions to capture stderr
and stdout and divert it to the logs so that the test output is less
cluttered with the output of various git commands.
Change-Id: If36ef013aca498e3a0a9cc3a2b78d666775439ab
Signed-off-by: Doug Hellmann <doug@doughellmann.com>
Extend the missing-releases command to look at PyPI for uploads there.
Change-Id: I5693686bbe46a4ec90944bbf2fa81e1c5c91749e
Signed-off-by: Doug Hellmann <doug@doughellmann.com>
Update the check_output() calls used by the validate command so the
results are decoded before being treated as strings.
Change-Id: I099ff997f69743d2958fc5581292aacebd7f5d37
Signed-off-by: Doug Hellmann <doug@doughellmann.com>
Only look at the last line of output, in case the project relies on an
old pbr that spews extra information to stdout instead of stderr.
Comment out the 0.6.0 release because getting its name triggers an error
related to testrepository.
Change-Id: I9eb2bd7ad17130115fb189ef5296cff18af6edb4
Signed-off-by: Doug Hellmann <doug@doughellmann.com>
It seems pbr needs to be installed in order to get its name, so use tox
instead of the system python.
Change-Id: I8809978b23430daacfc6a48d1f4bc84cce24c003
Signed-off-by: Doug Hellmann <doug@doughellmann.com>
We don't want to take the time to check out all of the source code for
all projects during the documentation build, so add a validation step to
check that the deliverable being modified has the tarball-base value set
properly, if it needs to be overridden from the default.
Change-Id: Id39bdd1e0a9fe771b78a053ba73803c3c095f135
Signed-off-by: Doug Hellmann <doug@doughellmann.com>