Skip to content

Commit

Permalink
Exporter DSL.
Browse files Browse the repository at this point in the history
  • Loading branch information
HassanJaveed84 committed Aug 15, 2018
1 parent b74c11a commit 4b606cd
Show file tree
Hide file tree
Showing 7 changed files with 394 additions and 1 deletion.
11 changes: 10 additions & 1 deletion dataeng/jobs/AnalyticsEmailOptin.groovy
Original file line number Diff line number Diff line change
Expand Up @@ -40,6 +40,10 @@ job ('analytics-email-optin-worker') {
stringParam('PLATFORM_VENV')
}

logRotator {
daysToKeep(30)
}

throttleConcurrentBuilds {
maxPerNode(5)
maxTotal(5)
Expand Down Expand Up @@ -141,6 +145,10 @@ job ('analytics-email-optin-master') {
}
}

triggers{
cron('# Saturdays around 4 a.m. UTC\nH 4 * * 6')
}

wrappers {
timestamps()
}
Expand All @@ -154,8 +162,9 @@ job ('analytics-email-optin-master') {
}
virtualenv {
nature("shell")
name("analytics-exporter")
command(
readFileFromWorkspace("dataeng/resources/setup-exporter-properties.sh")
readFileFromWorkspace("dataeng/resources/setup-exporter-email-optin.sh")
)
}
downstreamParameterized {
Expand Down
280 changes: 280 additions & 0 deletions dataeng/jobs/AnalyticsExporter.groovy
Original file line number Diff line number Diff line change
@@ -0,0 +1,280 @@
import org.yaml.snakeyaml.Yaml
import org.yaml.snakeyaml.error.YAMLException


Map config = [:]
Binding bindings = getBinding()
config.putAll(bindings.getVariables())
PrintStream out = config['out']

Map globals = binding.variables
String commonVarsDir = globals.get('COMMON_VARS_DIR')
String commonVarsFilePath = commonVarsDir + 'common.yaml'
Map commonConfigMap = [:]

try {
out.println('Parsing secret YAML file')
String commonConfigContents = readFileFromWorkspace(commonVarsFilePath)
Yaml yaml = new Yaml()
commonConfigMap = yaml.load(commonConfigContents)
out.println('Successfully parsed secret YAML file')

} catch (YAMLException e) {
throw new IllegalArgumentException("Unable to parse ${commonVarsFilePath}: ${e.message}")
}

job ('analytics-exporter-course') {
parameters {
stringParam('COURSES', '', 'Space separated list of courses to process. E.g. --course=course-v1:BerkleeX+BMPR365_3x+1T2015')
stringParam('EXPORTER_BRANCH', 'environment/production', 'Branch from the analytics-exporter repository. For tags use tags/[tag-name].')
stringParam('PLATFORM_BRANCH', 'origin/zafft/analytics-exporter-settings-hotfix', 'Branch from the exporter repository. For tags use tags/[tag-name].')
stringParam('SECURE_BRANCH', 'release', 'Branch from the analytics-secure repository, where the configuration settings reside. For tags use tags/[tag-name]')
stringParam('CONFIG_FILENAME', 'course_exporter.yaml', 'Name of configuration file in analytics-secure/analytics-exporter.')
stringParam('OUTPUT_BUCKET', '', 'Name of the bucket for the destination of the export data. Can use a path. (eg. export-data/test).')
stringParam('NOTIFICATION_EMAILS', '', 'Space separated list of emails to notify in case of failure.')
stringParam('DATE_MODIFIER', '', 'Used to set the date of the CWSM dump. Leave blank to use today\'s date. Set to "-d 201x-0x-0x" if that is when the CWSM dump took place. (Leave off quotes.)')
stringParam('TASKS', '', 'Space separated list of tasks to process. Leave this blank to use the task list specified in the config file. Specify here only if you are running tests of a specific task.')
}

multiscm{
git {
remote {
url('[email protected]:edx/edx-platform.git')
branch('$PLATFORM_BRANCH')
credentials('1')
}
extensions {
pruneBranches()
relativeTargetDirectory('edx-platform')
}
}
git {
remote {
url('[email protected]:edx/edx-analytics-exporter.git')
branch('$EXPORTER_BRANCH')
credentials('1')
}
extensions {
pruneBranches()
relativeTargetDirectory('analytics-exporter')
}
}
git {
remote {
url(commonConfigMap.get('SECURE_REPO_URL'))
branch('$SECURE_BRANCH')
credentials('1')
}
extensions {
pruneBranches()
relativeTargetDirectory('analytics-secure')
}
}
git {
remote {
url(commonConfigMap.get('BAKED_CONFIG_SECURE_REPO_URL'))
branch('*/master')
credentials('1')
}
extensions {
relativeTargetDirectory('config/baked-config-secure')
}
}
}

wrappers {
timestamps()
}

steps {
virtualenv {
nature("shell")
command(
readFileFromWorkspace("dataeng/resources/setup-platform-venv.sh")
)
}
virtualenv {
nature("shell")
name("analytics-exporter")
command(
readFileFromWorkspace("dataeng/resources/run-course-exporter.sh")
)
}
}
}

job ('analytics-exporter-worker') {

parameters {
stringParam('NOTIFICATION_EMAILS')
stringParam('MASTER_WORKSPACE')
stringParam('ORG_CONFIG_PATH')
stringParam('GPG_KEYS_PATH')
stringParam('DATE')
stringParam('CONFIG_PATH')
stringParam('OUTPUT_BUCKET')
stringParam('EXPORTER_VENV')
stringParam('ORG')
stringParam('PLATFORM_VENV')
stringParam('EXTRA_OPTIONS')
stringParam('SECURE_BRANCH')
}

logRotator {
daysToKeep(30)
}

throttleConcurrentBuilds {
maxPerNode(4)
maxTotal(4)
}

concurrentBuild()

multiscm {
git {
remote {
url(commonConfigMap.get('BAKED_CONFIG_SECURE_REPO_URL'))
branch('*/master')
credentials('1')
}
extensions {
relativeTargetDirectory('config/baked-config-secure')
}
}
git {
remote {
url(commonConfigMap.get('SECURE_REPO_URL'))
branch('$SECURE_BRANCH')
credentials('1')
}
extensions {
pruneBranches()
relativeTargetDirectory('analytics-secure')
}
}
}

wrappers {
timestamps()
buildName('#${BUILD_NUMBER} ${ENV,var="ORG"}')
}

steps {
shell(readFileFromWorkspace("dataeng/resources/org-exporter-worker.sh"))
}

publishers {
// Mark the build as 'unstable' if the text is found in 'console log'.
textFinder("\\[WARNING\\]", '', true, false, true)
}

}

job ('analytics-exporter-master') {

parameters {
stringParam('ORGS', '*', 'Space separated list of organizations to process. Can use wildcards. e.g.: idbx HarvardX')
stringParam('EXPORTER_BRANCH', 'environment/production', 'Branch from the edx-analytics-exporter repository. For tags use tags/[tag-name].')
stringParam('PLATFORM_BRANCH', 'aed/analytics-exporter-settings-hotfix', 'Branch from the edx-platform repository. For tags use tags/[tag-name].')
stringParam('SECURE_BRANCH', 'release', 'Branch from the analytics-secure repository, where the configuration settings reside. For tags use tags/[tag-name]')
stringParam('CONFIG_FILENAME', 'default.yaml', 'Name of configuration file in analytics-secure/analytics-exporter.')
stringParam('OUTPUT_BUCKET', commonConfigMap.get('EXPORTER_OUTPUT_BUCKET'), 'Name of the bucket for the destination of the export data. Can use a path. (eg. export-data/test).')
stringParam('NOTIFICATION_EMAILS', commonConfigMap.get('EXTENDED_NOTIFY_LIST'), 'Space separated list of emails to notify in case of failure.')
stringParam('DATE_MODIFIER', '', 'Used to set the date of the CWSM dump. Leave blank to use today\'s date. Set to "-d 201x-0x-0x" if that is when the CWSM dump took place. (Leave off quotes.)')
stringParam('EXTRA_OPTIONS', '--exclude-task=OrgEmailOptInTask', 'e.g. --exclude-task=OrgEmailOptInTask')
stringParam('ORG_CONFIG', 'data-czar-keys/config.yaml', 'Path to the data-czar organization config file.')
stringParam('DATA_CZAR_KEYS_BRANCH', 'master', 'Branch to use for the data-czar-keys repository.')
}

multiscm{
git {
remote {
url('[email protected]:edx/edx-platform.git')
branch('$PLATFORM_BRANCH')
credentials('1')
}
extensions {
pruneBranches()
relativeTargetDirectory('edx-platform')
}
}
git {
remote {
url('[email protected]:edx/edx-analytics-exporter.git')
branch('$EXPORTER_BRANCH')
credentials('1')
}
extensions {
pruneBranches()
relativeTargetDirectory('analytics-exporter')
}
}
git {
remote {
url(commonConfigMap.get('SECURE_REPO_URL'))
branch('$SECURE_BRANCH')
credentials('1')
}
extensions {
pruneBranches()
relativeTargetDirectory('analytics-secure')
}
}
git {
remote {
url(commonConfigMap.get('DATA_CZAR_KEYS_REPO_URL'))
branch('$DATA_CZAR_KEYS_BRANCH')
credentials('1')
}
extensions {
relativeTargetDirectory('data-czar-keys')
}
}
}

triggers{
cron('# Sundays around 10 a.m. UTC\nH 10 * * 0')
}

wrappers {
timestamps()
}

steps {
virtualenv {
nature("shell")
command(
readFileFromWorkspace("dataeng/resources/setup-platform-venv-legacy.sh")
)
}
virtualenv {
nature("shell")
name("analytics-exporter")
command(
readFileFromWorkspace("dataeng/resources/setup-exporter.sh")
)
}

downstreamParameterized {
trigger('analytics-exporter-worker') {
block {
buildStepFailure('FAILURE')
failure('FAILURE')
unstable('UNSTABLE')
}
parameters {
predefinedProp('MASTER_WORKSPACE', '${WORKSPACE}')
predefinedProp('NOTIFICATION_EMAILS', '${NOTIFICATION_EMAILS}')
}
parameterFactories {
fileBuildParameterFactory {
filePattern('organizations/*')
encoding('UTF-8')
noFilesFoundAction('SKIP')
}
}
}
}
}
}
12 changes: 12 additions & 0 deletions dataeng/resources/org-exporter-worker.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
TODAY=$(date +%d)

env | sort

${EXPORTER_VENV}/bin/exporter \
--org=${ORG} \
--output-bucket=${OUTPUT_BUCKET} \
--external-prefix=databases/${DATE:-$TODAY} \
--django-admin=${PLATFORM_VENV}/bin/django-admin.py \
--django-pythonpath=${PLATFORM_VENV}/edx-platform \
--gpg-keys=${GPG_KEYS_PATH} \
${EXTRA_OPTIONS} ${CONFIG_PATH} ${ORG_CONFIG_PATH}
32 changes: 32 additions & 0 deletions dataeng/resources/run-course-exporter.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,32 @@
# Create destination directory
WORKING_DIRECTORY=/var/lib/jenkins/tmp/analytics-course-exporter
mkdir -p ${WORKING_DIRECTORY}/course-data

# Install requirements into this (exporter) virtual environment
pushd analytics-exporter/
pip install -r github_requirements.txt
pip install mysql-connector-python -e .
popd

# Get name of other (platform) virtual environment
source platform_venv

# Configuration paths in analytics-secure
SECURE_ROOT=${WORKSPACE}/analytics-secure/analytics-exporter
CONFIG_PATH=${SECURE_ROOT}/${CONFIG_FILENAME}

DATE=$(date +%d ${DATE_MODIFIER})
TODAY=$(date +%d)

env | sort

# Export job configuration files
course-exporter \
${COURSES} \
${TASKS} \
--work-dir=${WORKING_DIRECTORY} \
--output-bucket=${OUTPUT_BUCKET} \
--external-prefix=databases/${DATE:-$TODAY} \
--django-admin=${PLATFORM_VENV}/bin/django-admin.py \
--django-pythonpath=${PLATFORM_VENV}/edx-platform \
${CONFIG_PATH}
Loading

0 comments on commit 4b606cd

Please sign in to comment.