405643a089
That gives us a way to test e.g. pull requests by specifying ph_scripts_refspec="pull/123/head" Also keep "ph_" prefix to remove confusion we had between "scripts_branch" and "ph_scripts_branch" before. Update docs and moved "testing" sections up.
56 lines
2 KiB
Python
Executable file
56 lines
2 KiB
Python
Executable file
#!/usr/bin/env python3
|
|
# Copyright 2020 Google LLC
|
|
#
|
|
# Licensed under the the Apache License v2.0 with LLVM Exceptions (the "License");
|
|
# you may not use this file except in compliance with the License.
|
|
# You may obtain a copy of the License at
|
|
#
|
|
# https://llvm.org/LICENSE.txt
|
|
#
|
|
# 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.
|
|
|
|
import os
|
|
import yaml
|
|
|
|
if __name__ == '__main__':
|
|
queue_prefix = os.getenv("ph_queue_prefix", "")
|
|
diff_id = os.getenv("ph_buildable_diff")
|
|
log_level = os.getenv('ph_log_level', 'INFO')
|
|
base_commit = os.getenv('ph_base_commit', 'auto')
|
|
run_build = os.getenv('ph_skip_build') is None
|
|
steps = []
|
|
create_branch_step = {
|
|
'label': 'create branch',
|
|
'key': 'create-branch',
|
|
'commands': ['scripts/buildkite/apply_patch.sh'],
|
|
'agents': {'queue': f'{queue_prefix}linux'},
|
|
'timeout_in_minutes': 20,
|
|
'env': {
|
|
'LOG_LEVEL': log_level,
|
|
'BASE_COMMIT': base_commit,
|
|
}
|
|
}
|
|
build_linux_step = {
|
|
'trigger': 'premerge-checks',
|
|
'label': ':rocket: build and test',
|
|
'async': False,
|
|
'depends_on': 'create-branch',
|
|
'build': {
|
|
'branch': f'phab-diff-{diff_id}',
|
|
'env': {},
|
|
},
|
|
}
|
|
for e in os.environ:
|
|
if e.startswith('ph_'):
|
|
build_linux_step['build']['env'][e] = os.getenv(e)
|
|
# Set scripts source from the current build if it's not yet defined.
|
|
if 'ph_scripts_refspec' not in build_linux_step['build']['env']:
|
|
build_linux_step['build']['env']['ph_scripts_refspec'] = '${BUILDKITE_BRANCH}'
|
|
steps.append(create_branch_step)
|
|
if run_build:
|
|
steps.append(build_linux_step)
|
|
print(yaml.dump({'steps': steps}))
|