escape=lambda x: x):
values = dict(values)
assert succeeded
+ for key in ['category', 'name', 'principal']:
+ values[key] = escape(values[key])
msg = '%(principal)s just created a new repository, %(category)s/%(name)s.git' % values
return msg
+def prebuild_msg(succeeded, values, verbose=True, success=lambda x: x, failure=lambda x: x,
+ escape=lambda x: x):
+ for key in ['build_id', 'pocket', 'package', 'commit', 'principal', 'version', 'inserted_at']:
+ values[key] = escape(values[key])
+ msg = """Build started: %(package)s %(version)s in %(pocket)s.
+Base commit %(commit)s .
+Job submitted by %(principal)s at %(inserted_at)s.""" % values
+ return msg
+
# Names of hooks
POST_BUILD = 'post-build'
FAILED_BUILD = 'failed-build'
POST_SUBMIT = 'post-submit'
FAILED_SUBMIT = 'failed-submit'
POST_ADD_REPO = 'post-add-repo'
+PRE_BUILD = 'pre-build'
# Types of communication
FAILED_BUILD : build_completion_msg,
POST_SUBMIT : submit_completion_msg,
FAILED_SUBMIT : submit_completion_msg,
- POST_ADD_REPO : repo_creation_msg },
+ POST_ADD_REPO : repo_creation_msg,
+ PRE_BUILD : prebuild_msg },
MAIL : { POST_BUILD : build_completion_msg,
FAILED_BUILD : build_completion_msg,
POST_SUBMIT : submit_completion_msg,
FAILED_SUBMIT : submit_completion_msg,
- POST_ADD_REPO : repo_creation_msg }
+ POST_ADD_REPO : repo_creation_msg,
+ PRE_BUILD : prebuild_msg }
}
def zephyr_escape(m):
hook_config = config.build.hooks.failed_submit
elif prog == POST_ADD_REPO:
hook_config = config.build.hooks.post_add_repo
+ elif prog == PRE_BUILD:
+ hook_config = config.build.hooks.pre_build
else:
parser.error('hook script invoked with unrecognized name %s' % prog)
return 2
print >>sys.stderr, 'No hook configuration found for %s.' % prog
return 1
- if prog in [POST_BUILD, FAILED_BUILD]:
+ if prog in [POST_BUILD, FAILED_BUILD, PRE_BUILD]:
if len(args) != 1:
parser.set_usage('Usage: %prog [options] build_id')
parser.print_help()
'version' : build.version,
'default_instance' : 'b%(build_id)s',
'default_subject' : 'Build %(build_id)d %(result)s: %(package)s %(version)s in %(pocket)s'}
- if build.succeeded:
+ if prog == PRE_BUILD:
+ succeeded = True
+ elif build.succeeded:
assert prog == POST_BUILD
values['result'] = 'succeeded'
succeeded = True
src = b.validateBuild(pocket, package, commit)
version = b.getVersion(package, commit)
db.version = str(version)
- b.runHook('pre-build', [str(db.build_id), db.pocket, db.package,
- db.commit, db.principal, db.version, str(db.inserted_at)])
+ b.runHook('pre-build', [str(db.build_id)])
env = dict(os.environ)
env['GIT_COMMITTER_NAME'] = config.build.tagger.name