1fe7707cf0
Due to various reasons, this script may encounter the 500 status code from some repo (x/fuel-plugin-onos in current case[1]) If that happen then it return failure status code to the propose-updates job and fail that job - https://zuul.openstack.org/builds?job_name=propose-updates&project=openstack%2Fdevstack&skip=0 It is better not to raise the 500 error in this script and just ignore those repo to process further to detect the plugin. [1] https://zuul.openstack.org/build/dba0aa41d145472397916dfcd13948de/log/job-output.txt#2442 Change-Id: Ibca0a2aac404161340e8fc00170018eecf5c8326
87 lines
2.8 KiB
Python
87 lines
2.8 KiB
Python
#! /usr/bin/env python3
|
|
|
|
# Copyright 2016 Hewlett Packard Enterprise Development Company, L.P.
|
|
#
|
|
# Licensed under the Apache License, Version 2.0 (the "License"); you may
|
|
# not use this file except in compliance with the License. You may obtain
|
|
# a copy of the License at
|
|
#
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
|
#
|
|
# Unless required by applicable law or agreed to in writing, software
|
|
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
|
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
|
# License for the specific language governing permissions and limitations
|
|
# under the License.
|
|
|
|
# This script is intended to be run as part of a periodic proposal bot
|
|
# job in OpenStack infrastructure.
|
|
#
|
|
# In order to function correctly, the environment in which the
|
|
# script runs must have
|
|
# * network access to the review.opendev.org Gerrit API
|
|
# working directory
|
|
# * network access to https://opendev.org/
|
|
|
|
import functools
|
|
import logging
|
|
import json
|
|
import requests
|
|
|
|
from requests.adapters import HTTPAdapter
|
|
from requests.packages.urllib3.util.retry import Retry
|
|
|
|
logging.basicConfig(level=logging.DEBUG)
|
|
|
|
url = 'https://review.opendev.org/projects/'
|
|
|
|
# This is what a project looks like
|
|
'''
|
|
"openstack-attic/akanda": {
|
|
"id": "openstack-attic%2Fakanda",
|
|
"state": "READ_ONLY"
|
|
},
|
|
'''
|
|
|
|
def is_in_wanted_namespace(proj):
|
|
# only interested in openstack or x namespace (e.g. not retired
|
|
# stackforge, etc).
|
|
#
|
|
# openstack/openstack "super-repo" of openstack projects as
|
|
# submodules, that can cause gitea to 500 timeout and thus stop
|
|
# this script. Skip it.
|
|
if proj.startswith('stackforge/') or \
|
|
proj.startswith('stackforge-attic/') or \
|
|
proj == "openstack/openstack":
|
|
return False
|
|
else:
|
|
return True
|
|
|
|
# Check if this project has a plugin file
|
|
def has_devstack_plugin(session, proj):
|
|
# Don't link in the deb packaging repos
|
|
if "openstack/deb-" in proj:
|
|
return False
|
|
r = session.get("https://opendev.org/%s/raw/branch/master/devstack/plugin.sh" % proj)
|
|
return r.status_code == 200
|
|
|
|
logging.debug("Getting project list from %s" % url)
|
|
r = requests.get(url)
|
|
projects = sorted(filter(is_in_wanted_namespace, json.loads(r.text[4:])))
|
|
logging.debug("Found %d projects" % len(projects))
|
|
|
|
s = requests.Session()
|
|
# sometimes gitea gives us a 500 error; retry sanely
|
|
# https://stackoverflow.com/a/35636367
|
|
# We need to disable raise_on_status because if any repo endup with 500 then
|
|
# propose-updates job which run this script will fail.
|
|
retries = Retry(total=3, backoff_factor=1,
|
|
status_forcelist=[ 500 ],
|
|
raise_on_status=False)
|
|
s.mount('https://', HTTPAdapter(max_retries=retries))
|
|
|
|
found_plugins = filter(functools.partial(has_devstack_plugin, s), projects)
|
|
|
|
for project in found_plugins:
|
|
print(project)
|