calamares/src/modules/testmodule.py

147 lines
4.6 KiB
Python
Raw Normal View History

#!/usr/bin/env python3
2015-02-18 15:06:10 +01:00
# -*- coding: utf-8 -*-
#
# === This file is part of Calamares - <http://github.com/calamares> ===
#
# Copyright 2014, Teo Mrnjavac <teo@kde.org>
# Copyright 2017, Adriaan de Groot <groot@kde.org>
#
# Calamares is free software: you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
#
# Calamares is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with Calamares. If not, see <http://www.gnu.org/licenses/>.
"""
Testing tool to run a single Python module; optionally a
global configuration and module configuration can be read
from YAML files. Give a full path to the module-directory,
and also full paths to the configuration files. An empty
configuration file name, or "-" (a single dash) is used
to indicate that no file should be read -- useful to load
a module configuratioon file without a global configuration.
"""
2014-07-24 10:15:16 +02:00
import argparse
import os
import sys
2014-07-24 10:15:16 +02:00
import yaml
2014-07-24 10:15:16 +02:00
try:
import libcalamares
except ImportError:
2014-07-29 13:52:55 +02:00
print("Failed to import libcalamares. Make sure then PYTHONPATH "
"environment variable includes the dir where libcalamares.so is "
"installed.")
2014-07-24 10:15:16 +02:00
print()
raise
class Job:
2015-02-20 20:54:25 +01:00
"""
:param working_path:
:param doc:
:param cfg_doc:
"""
def __init__(self, working_path, doc, cfg_doc):
2014-07-29 13:52:55 +02:00
self.module_name = doc["name"]
self.pretty_name = "Testing job " + doc["name"]
self.working_path = working_path
self.configuration = cfg_doc
2014-07-29 13:52:55 +02:00
def setprogress(self, progress):
2015-02-20 20:54:25 +01:00
"""
:param progress:
"""
2014-07-29 13:52:55 +02:00
print("Job set progress to {}%.".format(progress * 100))
2014-07-23 13:01:30 +02:00
def test_module(moduledir, globalconfigfilename, moduleconfigfilename, lang):
print("Testing module in: " + moduledir)
2014-07-24 10:15:16 +02:00
confpath = os.path.join(moduledir, "module.desc")
2014-07-29 13:52:55 +02:00
with open(confpath) as f:
doc = yaml.load(f)
2014-07-29 13:52:55 +02:00
if doc["type"] != "job" or doc["interface"] != "python":
print("Only Python jobs can be tested.")
return 1
# Parameter None creates a new, empty GlobalStorage
libcalamares.globalstorage = libcalamares.GlobalStorage(None)
libcalamares.globalstorage.insert("testing", True)
if lang:
libcalamares.globalstorage.insert("locale", lang)
libcalamares.globalstorage.insert("localeConf", {"LANG": lang})
# if a file for simulating globalStorage contents is provided, load it
if globalconfigfilename:
with open(globalconfigfilename) as f:
gs_doc = yaml.load(f)
2014-08-06 12:57:12 +02:00
for key, value in gs_doc.items():
2014-07-30 12:41:34 +02:00
libcalamares.globalstorage.insert(key, value)
print("Global configuration '" + globalconfigfilename + "' loaded.")
else:
print("No global configuration loaded.")
cfg_doc = dict()
if moduleconfigfilename:
with open(moduleconfigfilename) as f:
cfg_doc = yaml.load(f)
print("Local configuration '" + moduleconfigfilename + "' loaded.")
else:
print("No module configuration loaded.")
libcalamares.job = Job(moduledir, doc, cfg_doc)
scriptpath = os.path.abspath(moduledir)
2014-07-29 13:52:55 +02:00
sys.path.append(scriptpath)
import main # Assumed to import main from module itself
2014-07-29 13:52:55 +02:00
print("Output from module:")
print(main.run())
return 0
def munge_filename(filename):
"""
Maps files "" (empty) and "-" (just a dash) to None,
to simplify processing elsewhere.
"""
if not filename or filename == "-":
return None
return filename
def main():
parser = argparse.ArgumentParser(description=globals()["__doc__"])
parser.add_argument("moduledir",
help="Dir containing the Python module.")
parser.add_argument("globalstorage_yaml", nargs="?",
help="A yaml file to initialize GlobalStorage.")
parser.add_argument("configuration_yaml", nargs="?",
help="A yaml file to initialize the Job.")
parser.add_argument("--lang", "-l", nargs="?", default=None,
help="Set translation language.")
args = parser.parse_args()
return test_module(args.moduledir,
munge_filename(args.globalstorage_yaml),
munge_filename(args.configuration_yaml),
args.lang)
if __name__ == "__main__":
2014-07-29 13:52:55 +02:00
sys.exit(main())