50 lines
1.5 KiB
Python
50 lines
1.5 KiB
Python
|
import argparse
|
||
|
import logging
|
||
|
import json
|
||
|
|
||
|
from app import app
|
||
|
from data import model
|
||
|
from data.database import RepositoryBuildTrigger, configure
|
||
|
|
||
|
configure(app.config)
|
||
|
|
||
|
logger = logging.getLogger(__name__)
|
||
|
|
||
|
def run_branchregex_migration():
|
||
|
encountered = set()
|
||
|
while True:
|
||
|
found = list(RepositoryBuildTrigger.select().where(RepositoryBuildTrigger.config ** "%branch_regex%",
|
||
|
~(RepositoryBuildTrigger.config ** "%branchtag_regex%")))
|
||
|
found = [f for f in found if not f.uuid in encountered]
|
||
|
|
||
|
if not found:
|
||
|
logger.debug('No additional records found')
|
||
|
return
|
||
|
|
||
|
logger.debug('Found %s records to be changed', len(found))
|
||
|
for trigger in found:
|
||
|
encountered.add(trigger.uuid)
|
||
|
|
||
|
try:
|
||
|
config = json.loads(trigger.config)
|
||
|
except:
|
||
|
logging.error("Cannot parse config for trigger %s", trigger.uuid)
|
||
|
continue
|
||
|
|
||
|
logger.debug("Checking trigger %s", trigger.uuid)
|
||
|
existing_regex = config['branch_regex']
|
||
|
logger.debug("Found branch regex '%s'", existing_regex)
|
||
|
|
||
|
sub_regex = existing_regex.split('|')
|
||
|
new_regex = '|'.join(['heads/' + sub for sub in sub_regex])
|
||
|
config['branchtag_regex'] = new_regex
|
||
|
|
||
|
logger.debug("Updating to branchtag regex '%s'", new_regex)
|
||
|
trigger.config = json.dumps(config)
|
||
|
trigger.save()
|
||
|
|
||
|
if __name__ == "__main__":
|
||
|
logging.basicConfig(level=logging.DEBUG)
|
||
|
logging.getLogger('boto').setLevel(logging.CRITICAL)
|
||
|
|
||
|
run_branchregex_migration()
|