180 likes | 197 Views
Implementing continuous integration for sPHENIX software to automate GitHub pull request checks and regular testing, ensuring stable builds. Get reports automatically to track project progress.
E N D
Continuous Integration for sPHENIX Jin Huang (BNL)
sPHENIX Software Repo. Hardware Design Decisions Physics obs. Projection Detector Design → G4 Simulation → Digitization Reconstruction Real Data Open source @ https://github.com/sPHENIX-Collaboration/ Core software: 200k line of code Analysis: 59k line of code Jin Huang <jhuang@bnl.gov>
Questions and solutions Jin Huang <jhuang@bnl.gov> You might had these questions: When did jet energy scale changed? Did the code run slower/faster recently? Would my pull request break the sPHENIX build? I build this new module, may I have some suggestion? Our new solution: Implementing continuous integration for sPHENIX software Automatically run compile, QA, and code analysis for new GitHub pull request. Regularly test/archive default setups
Pull request checks https://github.com/sPHENIX-Collaboration/coresoftware/pulls On-going checks Passed checks Report available Jin Huang <jhuang@bnl.gov>
Would my pull request break the sPHENIX build? https://github.com/sPHENIX-Collaboration/coresoftware/pull/509#issuecomment-452144033 Reports automatically post to pull request Also sent to email list: https://lists.bnl.gov/mailman/listinfo/sphenix-github-l ← Passed tests Failed tests → Jin Huang <jhuang@bnl.gov>
Behind the scene https://github.com/sPHENIX-Collaboration/coresoftware/pull/509#issuecomment-452144033 • Run pipelines of tests • On a dedicated 32-core server • Reproduce RCF env with sPHENIX Singularity container https://github.com/sPHENIX-Collaboration/singularity Jin Huang <jhuang@bnl.gov>
Did the code run slower recently? https://github.com/sPHENIX-Collaboration/coresoftware/pull/509#issuecomment-452144033 https://web.racf.bnl.gov/jenkins-sphenix/job/sPHENIX/job/test-calo-single-qa/ Jin Huang <jhuang@bnl.gov>
When did jet energy scale changed? https://github.com/sPHENIX-Collaboration/coresoftware/pull/509#issuecomment-452144033 • https://github.com/sPHENIX-Collaboration/coresoftware/pull/104 • https://github.com/sPHENIX-Collaboration/coresoftware/pull/105 • https://github.com/sPHENIX-Collaboration/coresoftware/pull/107 Jin Huang <jhuang@bnl.gov>
When did jet energy scale changed? https://web.racf.bnl.gov/jenkins-sphenix/job/sPHENIX/job/test-calo-single-qa/13//QA_20Report/ Jin Huang <jhuang@bnl.gov>
When did jet energy scale changed? https://web.racf.bnl.gov/jenkins-sphenix/job/sPHENIX/job/test-calo-single-qa/13//QA_20Report/ Jin Huang <jhuang@bnl.gov>
May I have some suggestion on my code? https://github.com/sPHENIX-Collaboration/coresoftware/pull/538#issuecomment-452992916 Jin Huang <jhuang@bnl.gov>
More checks … https://github.com/sPHENIX-Collaboration/coresoftware/pull/538#issuecomment-452992916 Jin Huang <jhuang@bnl.gov>
Jenkins dashboard https://web.racf.bnl.gov/jenkins-sphenix/view/sPHENIX%20Pipelines/ Jin Huang <jhuang@bnl.gov>
Need your help Jin Huang <jhuang@bnl.gov> • Tracking QA modules → plots • Jet samples to run/archive jet QA • Summarize QA results, e.g. KS-tests • Add more checks • Pull request check (~100 CPU-hr) • Weekly checks (~1000 CPU-hr) • Suggestions welcomed • At Tue sim./software meeting: https://indico.bnl.gov/category/88/ • At email list: sphenix-software-l@lists.bnl.gov.
Extra information Jin Huang <jhuang@bnl.gov>
Portability and containers https://singularity.lbl.gov/ Jin Huang <jhuang@bnl.gov> • sPHENIX software is built and distributed on RCF only. But there are needs to use it offsite • Use computing resource at grid or user institutes • Development code offline from RCF • RCF has a container for sPHENIX already • A light layer of software environment wrapping for sPHENIX computing environment • Based on singularity container (non-SU version of Docker). • Promising to solving software compatibility reproducibility issue. • Called for volunteer testing in last collaboration meeting
Update from the last meeting Ross Corliss (MIT) Ron Soltz (LLNL) sPHENIX in container @ BNL TPC lab sPHENIX in container @ LLNL Fe-55 → GEM →SAMPA → FELIX Jin Huang <jhuang@bnl.gov> RCF authorized us to allow distribution to sPHENIX collaborators Simple macros setup for download and sync with nightly builds: https://github.com/sPHENIX-Collaboration/Singularity Thanks to our 1st users for trying it out: Ross Corliss (MIT) and Ron Soltz (LLNL) Possible sim production @ LLNL super computer Expect coming version of container updated to use CVMFS, reduce downloads
Wish list (a few as example) EMCal tower occupancy A test Jenkins CI server DELPHES 3 [arXiv:1307.6346 ] Zero suppression Jin Huang <jhuang@bnl.gov> Simulation and evaluation of SiPM noise and zero-suppression20 GeV energy in EMCal just from SiPM noise and zero suppression Fast simulation: General packages e.g. DELPHES? Continuous Integration for sPHENIX softwareTesting a Jenkins for automatic software verification Containers, virtual machines: Distribute sPHENIX software to your laptop