4c972f00bd
The canMerge check is executed whenever zuul tests if a change can enter a gate pipeline. This is part of the critical path in the event handling of the scheduler and therefore must be as fast as possible. Currently this takes five requests for doing its work and also transfers large amounts of data that is unneeded: * get pull request * get branch protection settings * get commits * get status of latest commit * get check runs of latest commit Especially when Github is busy this can slow down zuul's event processing considerably. This can be optimized using graphql to only query the data we need with a single request. This reduces requests and load on Github and speeds up event processing in the scheduler. Since this is the first usage of graphql this also sets up needed testing infrastructure using graphene to mock the github api with real test data. Change-Id: I77be4f16cf7eb5c8035ce0312f792f4e8d4c3e10 |
||
---|---|---|
.. | ||
ansible | ||
cmd | ||
connection | ||
driver | ||
execution_context | ||
executor | ||
lib | ||
manager | ||
merger | ||
reporter | ||
source | ||
sphinx | ||
trigger | ||
web | ||
__init__.py | ||
_setup_hook.py | ||
change_matcher.py | ||
configloader.py | ||
exceptions.py | ||
model.py | ||
nodepool.py | ||
rpcclient.py | ||
rpclistener.py | ||
scheduler.py | ||
version.py | ||
zk.py |