From a3fc59240da30cc65d415134fc13665c7a82fd0f Mon Sep 17 00:00:00 2001 From: Alan Malta Rodrigues Date: Wed, 28 Aug 2024 10:40:20 -0400 Subject: [PATCH] Standlone script to test gfal rmdir --- .../MicroService_t/MSUnmerged_t/test_gfal.py | 42 +++++++++++++++++++ 1 file changed, 42 insertions(+) create mode 100644 test/python/WMCore_t/MicroService_t/MSUnmerged_t/test_gfal.py diff --git a/test/python/WMCore_t/MicroService_t/MSUnmerged_t/test_gfal.py b/test/python/WMCore_t/MicroService_t/MSUnmerged_t/test_gfal.py new file mode 100644 index 00000000000..545c2f77639 --- /dev/null +++ b/test/python/WMCore_t/MicroService_t/MSUnmerged_t/test_gfal.py @@ -0,0 +1,42 @@ +#!/usr/bin/env python +import logging + +try: + import gfal2 +except ImportError: + # in case we do not have gfal2 installed + print("FAILED to import gfal2. Use it only in emulateGfal2=True mode!!!") + gfal2 = None + +def createGfal2Context(logLevel="normal", emulate=False): + """ + Create a gfal2 context object + :param logLevel: string with the gfal2 log level + :param emulate: boolean to be used by unit tests + :return: the gfal2 context object + """ + if emulate: + return None + ctx = gfal2.creat_context() + gfal2.set_verbose(gfal2.verbose_level.names[logLevel]) + return ctx + +def testGFAL(ctx): + logger = logging.getLogger() + rseDirs = ["/store/unmerged/Run3Summer22EENanoAODv11/Wto2Q-3Jets_HT-200to400_TuneCP5_13p6TeV_madgraphMLM-pythia8/NANOAODSIM/126X_mcRun3_2022_realistic_postEE_v1-v3", + "/store/unmerged/RunIISummer20UL18NanoAODv9/GluGluHoffshell_HToWWToENuTauNu_TuneCP5_13TeV_MCFM701-pythia8/NANOAODSIM/106X_upgrade2018_realistic_v16_L1v1-v2"] + + for dirPfn in rseDirs: + try: + # NOTE: For gfal2 rmdir() exit status of 0 is success + rmdirSuccess = ctx.rmdir(dirPfn) == 0 + except gfal2.GError as gfalExc: + logger.warning("MISSING directory: %s, gfal code=%s", dirPfn, gfalExc.code) + +def main(): + ctx = createGfal2Context() + testGFAL(ctx) + print("succeeded") + +if __name__ == '__main__': + main() \ No newline at end of file