123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596 |
- #-*- coding: utf-8 -*-
-
- ##@brief Lodel2 loader script
- #
- #@note If you want to avoid settings loading you can set the environment
- #variable LODEL2_NO_SETTINGS_LOAD (see @ref install.lodel_admin.update_plugin_discover_cache()
- #
- # @note In tests case, you can pass the path to write results file, context_tests.log
- # It has to be at first, otherwise it will not be taken
- # and the default one, current directory, will be used.
-
- import sys, os, os.path
- #
- # Bootstraping
- #
- LODEL2_LIB_ABS_PATH = None
- if LODEL2_LIB_ABS_PATH is not None:
- if not os.path.isdir(LODEL2_LIB_ABS_PATH):
- print("FATAL ERROR : the LODEL2_LIB_ABS_PATH variable in loader.py is \
- not correct : '%s'" % LODEL2_LIB_ABS_PATH, file=sys.stderr)
- sys.path.append(LODEL2_LIB_ABS_PATH)
-
- try:
- import lodel
- except ImportError as e:
- print("Unable to load lodel module. exiting...")
- print(e)
- exit(1)
-
- #Set context to MONOSITE
- from lodel.context import LodelContext
- LodelContext.init()
-
- if 'LODEL2_NO_SETTINGS_LOAD' not in os.environ:
- #
- # Loading settings
- #
- LodelContext.expose_modules(globals(), {
- 'lodel.settings.settings': [('Settings', 'settings')]})
- if not settings.started():
- settings('conf.d')
- LodelContext.expose_modules(globals(), {
- 'lodel.settings': ['Settings']})
-
- #Starts hooks
- LodelContext.expose_modules(globals(), {
- 'lodel.plugin': ['LodelHook'],
- 'lodel.plugin.core_hooks': 'core_hooks',
- 'lodel.plugin.core_scripts': 'core_scripts'})
-
- def start():
- #Load plugins
- LodelContext.expose_modules(globals(), {
- 'lodel.logger': 'logger',
- 'lodel.plugin': ['Plugin']})
- logger.debug("Loader.start() called")
- Plugin.load_all()
- LodelHook.call_hook('lodel2_bootstraped', '__main__', None)
-
-
- if __name__ == '__main__':
-
- start()
- if Settings.runtest:
- import unittest
- import tests
- loader = unittest.TestLoader()
- test_dir = os.path.join(LODEL2_LIB_ABS_PATH, 'tests')
- suite = loader.discover(test_dir, pattern='test*.py')
- if ((len(sys.argv) > 1) and (sys.argv[1].startswith('-')) is False):
- dpath = sys.argv[1]
- else:
- dpath = '.'
- with open(sys.argv[1]+'/context_tests.log', 'w') as logfile:
- tests_res = unittest.TextTestRunner(
- logfile,
- failfast = '-f' in sys.argv,
- verbosity = 2 if '-v' in sys.argv else 1).run(suite)
- if tests_res.wasSuccessful():
- exit(0)
- else:
- exit(1)
-
- lodel = LodelContext.get()
- import leapi_dyncode as dyncode
- lodel.dyncode = dyncode
- LodelHook.call_hook('lodel2_dyncode_bootstraped', '__main__', None)
- LodelHook.call_hook('lodel2_loader_main', '__main__', None)
-
- #Run interative python
- import code
- print("""
- Running interactive python in Lodel2 %s instance environment
-
- """%Settings.sitename)
- code.interact(local=locals())
|