-
-
Notifications
You must be signed in to change notification settings - Fork 4.8k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Build merges on master to lastest branch (#2722)
* Build merges on master to lastest branch * Only on master
- Loading branch information
1 parent
109bc9a
commit ba0e529
Showing
5 changed files
with
172 additions
and
11 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,33 @@ | ||
#!/bin/sh -e | ||
|
||
# This script maintains a git branch which mirrors master but in a form that | ||
# what will eventually be deployed to npm, allowing npm dependencies to use: | ||
# | ||
# "parse-server": "parseplatform/parse-server#latest" | ||
# | ||
|
||
# From: https://github.com/graphql/graphql-js/blob/master/resources/npm-git.sh | ||
|
||
BUILD_DIR=latest | ||
|
||
npm run build | ||
|
||
mkdir -p $BUILD_DIR | ||
|
||
cp package.json $BUILD_DIR/ | ||
cp README.md $BUILD_DIR/ | ||
cp LICENSE $BUILD_DIR/ | ||
cp PATENTS $BUILD_DIR/ | ||
cp CHANGELOG.md $BUILD_DIR/ | ||
cp -R lib $BUILD_DIR | ||
cp -R bin $BUILD_DIR | ||
cp -R public_html $BUILD_DIR | ||
cp -R views $BUILD_DIR | ||
|
||
cd $BUILD_DIR | ||
git init | ||
git config user.name "Travis CI" | ||
git config user.email "[email protected]" | ||
git add . | ||
git commit -m "Deploy master to LATEST branch" | ||
git push --force --quiet "https://${GH_TOKEN}@github.com/parseplatform/parse-server.git" master:latest |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,102 @@ | ||
""" | ||
https://github.com/dmakhno/travis_after_all/blob/master/travis_after_all.py | ||
https://github.com/graphql/graphql-js/blob/master/resources/travis_after_all.py | ||
""" | ||
|
||
import os | ||
import json | ||
import time | ||
import logging | ||
|
||
try: | ||
import urllib.request as urllib2 | ||
except ImportError: | ||
import urllib2 | ||
|
||
log = logging.getLogger("travis.leader") | ||
log.addHandler(logging.StreamHandler()) | ||
log.setLevel(logging.INFO) | ||
|
||
TRAVIS_JOB_NUMBER = 'TRAVIS_JOB_NUMBER' | ||
TRAVIS_BUILD_ID = 'TRAVIS_BUILD_ID' | ||
POLLING_INTERVAL = 'LEADER_POLLING_INTERVAL' | ||
|
||
build_id = os.getenv(TRAVIS_BUILD_ID) | ||
polling_interval = int(os.getenv(POLLING_INTERVAL, '5')) | ||
|
||
#assume, first job is the leader | ||
is_leader = lambda job_number: job_number.endswith('.1') | ||
|
||
if not os.getenv(TRAVIS_JOB_NUMBER): | ||
# seems even for builds with only one job, this won't get here | ||
log.fatal("Don't use defining leader for build without matrix") | ||
exit(1) | ||
elif is_leader(os.getenv(TRAVIS_JOB_NUMBER)): | ||
log.info("This is a leader") | ||
else: | ||
#since python is subprocess, env variables are exported back via file | ||
with open(".to_export_back", "w") as export_var: | ||
export_var.write("BUILD_MINION=YES") | ||
log.info("This is a minion") | ||
exit(0) | ||
|
||
|
||
class MatrixElement(object): | ||
def __init__(self, json_raw): | ||
self.is_finished = json_raw['finished_at'] is not None | ||
self.is_succeeded = json_raw['result'] == 0 | ||
self.number = json_raw['number'] | ||
self.is_leader = is_leader(self.number) | ||
|
||
|
||
def matrix_snapshot(): | ||
""" | ||
:return: Matrix List | ||
""" | ||
response = urllib2.build_opener().open("https://api.travis-ci.org/builds/{0}".format(build_id)).read() | ||
raw_json = json.loads(response) | ||
matrix_without_leader = [MatrixElement(element) for element in raw_json["matrix"]] | ||
return matrix_without_leader | ||
|
||
|
||
def wait_others_to_finish(): | ||
def others_finished(): | ||
""" | ||
Dumps others to finish | ||
Leader cannot finish, it is working now | ||
:return: tuple(True or False, List of not finished jobs) | ||
""" | ||
snapshot = matrix_snapshot() | ||
finished = [el.is_finished for el in snapshot if not el.is_leader] | ||
return reduce(lambda a, b: a and b, finished), [el.number for el in snapshot if | ||
not el.is_leader and not el.is_finished] | ||
|
||
while True: | ||
finished, waiting_list = others_finished() | ||
if finished: break | ||
log.info("Leader waits for minions {0}...".format(waiting_list)) # just in case do not get "silence timeout" | ||
time.sleep(polling_interval) | ||
|
||
|
||
try: | ||
wait_others_to_finish() | ||
|
||
final_snapshot = matrix_snapshot() | ||
log.info("Final Results: {0}".format([(e.number, e.is_succeeded) for e in final_snapshot])) | ||
|
||
BUILD_AGGREGATE_STATUS = 'BUILD_AGGREGATE_STATUS' | ||
others_snapshot = [el for el in final_snapshot if not el.is_leader] | ||
if reduce(lambda a, b: a and b, [e.is_succeeded for e in others_snapshot]): | ||
os.environ[BUILD_AGGREGATE_STATUS] = "others_succeeded" | ||
elif reduce(lambda a, b: a and b, [not e.is_succeeded for e in others_snapshot]): | ||
log.error("Others Failed") | ||
os.environ[BUILD_AGGREGATE_STATUS] = "others_failed" | ||
else: | ||
log.warn("Others Unknown") | ||
os.environ[BUILD_AGGREGATE_STATUS] = "unknown" | ||
#since python is subprocess, env variables are exported back via file | ||
with open(".to_export_back", "w") as export_var: | ||
export_var.write("BUILD_LEADER=YES {0}={1}".format(BUILD_AGGREGATE_STATUS, os.environ[BUILD_AGGREGATE_STATUS])) | ||
|
||
except Exception as e: | ||
log.fatal(e) |