Feat: add submission scripts and unified histogrammer #130
Workflow file for this run
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
name: ctag ttbar workflows | |
on: | |
push: | |
branches: [ master ] | |
paths: | |
- 'src/BTVNanoCommissioning/workflows/ctag*tt*' | |
- 'src/BTVNanoCommissioning/helpers/update_branch.py' | |
- 'src/BTVNanoCommissioning/helpers/func.py' | |
- 'src/BTVNanoCommissioning/helpers/definitions.py' | |
- 'src/BTVNanoCommissioning/utils/*' | |
- '.github/workflows/ctag_ttbar_workflow.yml' | |
pull_request_target: | |
branches: [ master ] | |
paths: | |
- 'src/BTVNanoCommissioning/workflows/ctag*tt*' | |
- 'src/BTVNanoCommissioning/helpers/update_branch.py' | |
- 'src/BTVNanoCommissioning/helpers/func.py' | |
- 'src/BTVNanoCommissioning/helpers/definitions.py' | |
- 'src/BTVNanoCommissioning/utils/*' | |
- '.github/workflows/ctag_ttbar_workflow.yml' | |
workflow_dispatch: | |
jobs: | |
build: | |
runs-on: ubuntu-latest | |
if: ${{ !contains(github.event.head_commit.message, '[skip ci]') }} | |
strategy: | |
max-parallel: 4 | |
matrix: | |
python-version: ["3.10"] | |
defaults: | |
run: | |
shell: "bash -l {0}" | |
steps: | |
- uses: actions/checkout@v4 | |
- name: Merge PR locally | |
if: github.event_name == 'pull_request_target' | |
id: merge | |
continue-on-error: true | |
run: | | |
git fetch origin pull/${{ github.event.pull_request.number }}/head:MR | |
git checkout -b ATTEMPT_MERGE | |
git merge MR | |
git branch -vv | |
git remote -v | |
git diff master | |
- uses: cvmfs-contrib/github-action-cvmfs@v4 | |
with: | |
cvmfs_repositories: 'grid.cern.ch' | |
- name: Set conda environment | |
uses: conda-incubator/setup-miniconda@v3 | |
with: | |
python-version: ${{ matrix.python-version }} | |
channels: conda-forge,defaults | |
channel-priority: true | |
activate-environment: btv_coffea | |
environment-file: test_env.yml | |
auto-activate-base: false | |
- name: Verify environment | |
run: | | |
conda info | |
conda env list | |
conda list | |
- name: Set up proxy | |
# https://awesome-workshop.github.io/gitlab-cms/03-vomsproxy/index.html | |
# continue-on-error: true | |
env: | |
# To genereate secrets use (strip all \n) | |
# base64 -i ~/.globus/usercert.pem | awk NF=NF RS= OFS= | |
# base64 -i ~/.globus/userkey.pem | awk NF=NF RS= OFS= | |
# Cross check roundtrip by adding ``| base64 -d `` and see if same as input | |
GRID_USERKEY: ${{ secrets.GRID_USERKEY }} | |
GRID_USERCERT: ${{ secrets.GRID_USERCERT }} | |
# Read automatically by voms-proxy-init | |
X509_VOMS_DIR: /cvmfs/grid.cern.ch/etc/grid-security/vomsdir/ | |
X509_VOMSES: /cvmfs/grid.cern.ch/etc/grid-security/vomses/ | |
X509_CERT_DIR: /cvmfs/grid.cern.ch/etc/grid-security/certificates/ | |
X509_DEFAULT_USER_CERT: $HOME/.globus/usercert.pem | |
X509_DEFAULT_USER_KEY: $HOME/.globus/userkey.pem | |
run: | | |
mkdir $HOME/.globus | |
printf $GRID_USERKEY | base64 -d > $HOME/.globus/userkey.pem | |
printf $GRID_USERCERT | base64 -d > $HOME/.globus/usercert.pem | |
# DEBUG: dump decoded cert, cert is public, but don't dump key! | |
# base64 -i $HOME/.globus/usercert.pem | |
chmod 400 $HOME/.globus/userkey.pem | |
openssl rand -out $HOME/.rnd -hex 256 | |
printf "${{secrets.GRID_PASSWORD}}" | voms-proxy-init --voms cms --debug --pwstdin -certdir $X509_CERT_DIR -vomses $X509_VOMSES | |
chmod 755 /usr/share/miniconda/envs/btv_coffea/etc/grid-security/certificates | |
- name: Install Repo | |
run: | | |
pip install -e . | |
- name: ctag semileptonic muon ttbar workflows | |
run: | | |
string=$(git log -1 --pretty=format:'%s') | |
if [[ $string == *"ci:skip array"* ]]; then | |
opts=$(echo "$opts" | sed 's/--isArray //g') | |
fi | |
if [[ $string == *"ci:skip syst"* ]]; then | |
opts=$(echo "$opts" | sed 's/--isSyst all//g') | |
elif [[ $string == *"ci:JERC_split"* ]]; then | |
opts=$(echo "$opts" | sed 's/--isSyst all/--isSyst JERC_split/g') | |
elif [[ $string == *"ci:weight_only"* ]]; then | |
opts=$(echo "$opts" | sed 's/--isSyst all/--isSyst weight_only/g') | |
fi | |
python runner.py --workflow ctag_ttsemilep_sf --json metadata/test_bta_run3.json --limit 1 --executor iterative --campaign Summer23 --year 2023 $opts | |
- name: ctag semileptonic electron ttbar workflows | |
run: | | |
string=$(git log -1 --pretty=format:'%s') | |
if [[ $string == *"ci:skip array"* ]]; then | |
opts=$(echo "$opts" | sed 's/--isArray //g') | |
fi | |
if [[ $string == *"ci:skip syst"* ]]; then | |
opts=$(echo "$opts" | sed 's/--isSyst all//g') | |
elif [[ $string == *"ci:JERC_split"* ]]; then | |
opts=$(echo "$opts" | sed 's/--isSyst all/--isSyst JERC_split/g') | |
elif [[ $string == *"ci:weight_only"* ]]; then | |
opts=$(echo "$opts" | sed 's/--isSyst all/--isSyst weight_only/g') | |
fi | |
python runner.py --workflow ectag_ttsemilep_sf --json metadata/test_bta_run3.json --limit 1 --executor iterative --campaign Summer23 --year 2023 $opts | |
- name: ctag dileptonic muon ttbar workflows | |
run: | | |
string=$(git log -1 --pretty=format:'%s') | |
if [[ $string == *"ci:skip array"* ]]; then | |
opts=$(echo "$opts" | sed 's/--isArray //g') | |
fi | |
if [[ $string == *"ci:skip syst"* ]]; then | |
opts=$(echo "$opts" | sed 's/--isSyst all//g') | |
elif [[ $string == *"ci:JERC_split"* ]]; then | |
opts=$(echo "$opts" | sed 's/--isSyst all/--isSyst JERC_split/g') | |
elif [[ $string == *"ci:weight_only"* ]]; then | |
opts=$(echo "$opts" | sed 's/--isSyst all/--isSyst weight_only/g') | |
fi | |
python runner.py --workflow ctag_ttdilep_sf --json metadata/test_bta_run3.json --limit 1 --executor iterative --campaign Summer23 --year 2023 $opts | |
- name: ctag dileptonic electron ttbar workflows | |
run: | | |
string=$(git log -1 --pretty=format:'%s') | |
if [[ $string == *"ci:skip array"* ]]; then | |
opts=$(echo "$opts" | sed 's/--isArray //g') | |
fi | |
if [[ $string == *"ci:skip syst"* ]]; then | |
opts=$(echo "$opts" | sed 's/--isSyst all//g') | |
elif [[ $string == *"ci:JERC_split"* ]]; then | |
opts=$(echo "$opts" | sed 's/--isSyst all/--isSyst JERC_split/g') | |
elif [[ $string == *"ci:weight_only"* ]]; then | |
opts=$(echo "$opts" | sed 's/--isSyst all/--isSyst weight_only/g') | |
fi | |
python runner.py --workflow ectag_ttdilep_sf --json metadata/test_bta_run3.json --limit 1 --executor iterative --campaign Summer23 --year 2023 $opts | |
- name: ctag dileptonic emu ttbar workflows | |
run: | | |
string=$(git log -1 --pretty=format:'%s') | |
if [[ $string == *"ci:skip array"* ]]; then | |
opts=$(echo "$opts" | sed 's/--isArray //g') | |
fi | |
if [[ $string == *"ci:skip syst"* ]]; then | |
opts=$(echo "$opts" | sed 's/--isSyst all//g') | |
elif [[ $string == *"ci:JERC_split"* ]]; then | |
opts=$(echo "$opts" | sed 's/--isSyst all/--isSyst JERC_split/g') | |
elif [[ $string == *"ci:weight_only"* ]]; then | |
opts=$(echo "$opts" | sed 's/--isSyst all/--isSyst weight_only/g') | |
fi | |
python runner.py --workflow emctag_ttdilep_sf --json metadata/test_bta_run3.json --limit 1 --executor iterative --campaign Summer23 --year 2023 $opts | |