ClonerConfig + tests

Signed-off-by: Václav Valíček <valicek1994@gmail.com>
This commit is contained in:
Václav Valíček 2022-06-26 05:22:19 +02:00
parent 9feca35311
commit cb5e934c4a
Signed by: valicek
GPG Key ID: FF05BDCA0C73BB31
5 changed files with 154 additions and 4 deletions

View File

@ -0,0 +1,42 @@
from repo_cloner.lib.default_cloner_config import DefaultClonerConfig
class ClonerConfig(DefaultClonerConfig):
def __init__(self):
super().__init__()
self.__properties = list(filter(self.has_property, dir(self)))
self.__values = {}
def __try_default(self, key: str, default_value):
if not self.has_property(key):
raise KeyError(f"{key} is not recognized config option")
if key in self.__values:
return self.__values[key]
return default_value
@property
def cloner_project_name(self) -> str:
return self.__try_default("cloner_project_name", super(ClonerConfig, self).cloner_project_name)
@property
def cloner_repo_url(self) -> str:
return self.__try_default("cloner_repo_url", super(ClonerConfig, self).cloner_repo_url)
@property
def cloner_interval(self) -> int:
return self.__try_default("cloner_interval", super(ClonerConfig, self).cloner_interval)
@property
def cloner_submodules(self) -> bool:
return self.__try_default("cloner_submodules", super(ClonerConfig, self).cloner_submodules)
@property
def cloner_submodule_depth(self) -> int:
return self.__try_default("cloner_submodule_depth", super(ClonerConfig, self).cloner_submodule_depth)
def _set_property(self, key: str, value):
if not self.has_property(key):
raise KeyError(f"{key} is not recognized config option")
if not isinstance(value, type(self.__getattribute__(key))):
raise ValueError(f"Invalid value for key {key}: type is {type(value)}")
self.__values[key] = value

View File

@ -1,6 +1,6 @@
class DefaultClonerConfig: class DefaultClonerConfig:
def __init__(self): def __init__(self):
properties = list(filter(lambda prop: not str(prop).startswith("__"), dir(self))) properties = list(filter(lambda prop: not str(prop).startswith("_"), dir(self)))
self.__properties: list = properties self.__properties: list = properties
@property @property

View File

@ -1,8 +1,25 @@
#!/usr/bin/env python3 #!/usr/bin/env python3
import argparse import argparse
import os
from repo_cloner.lib.repo_dir_structure import RepoDirStructure from repo_cloner.lib.repo_dir_structure import RepoDirStructure
from git.config import GitConfigParser
import logging as l
l.basicConfig(level = 0)
def config_try_override(config_writer: GitConfigParser, section: str, option: str, value: str):
if not section in config_writer.sections():
l.debug(f"CFG Creating section: {section}")
config_writer.add_section(section)
if not config_writer.has_option(section, option):
l.debug(f"CFG Creating option: {option}")
config_writer.add_value(section, option, "")
l.debug(f"Setting {section}.{option} = {value}")
config_writer.set(section, option, value)
def main(): def main():
@ -13,9 +30,27 @@ def main():
args = parser.parse_args() args = parser.parse_args()
dirs = RepoDirStructure(args.base_dir) dirs = RepoDirStructure(args.base_dir)
print(dirs)
dirs.exists os.environ['XDG_CONFIG_HOME'] = dirs.conf_dir
from git import Repo
r = Repo("/home/vasek/dev/repo-cloner")
path: str = r._get_config_path("user")
print(path)
path = os.path.dirname(path)
print(path)
if not os.path.isdir(path):
os.mkdir(path)
cred_store: str = os.path.join(path, "git-credentials")
ssh_identity: str = os.path.join(dirs.conf_dir, "ssh", "identity")
with r.config_writer("user") as cfgw:
config_try_override(cfgw, "credential", "helper", f"store --file={cred_store}")
config_try_override(cfgw, "core", "sshcommand",
f"ssh -i {ssh_identity} -o StrictHostKeyChecking=no -o UserKnownHostsFile=/dev/null -o BatchMode=yes -q")
if __name__ == "__main__": if __name__ == "__main__":
main() main()

View File

@ -0,0 +1,74 @@
from repo_cloner.lib.cloner_config import ClonerConfig
import pytest
def test_init():
x = ClonerConfig()
assert x._ClonerConfig__properties == ['cloner_interval', 'cloner_project_name', 'cloner_repo_url',
'cloner_submodule_depth', 'cloner_submodules']
assert isinstance(x._ClonerConfig__values, dict)
assert len(dict(x._ClonerConfig__values)) == 0
def test_try_default():
x = ClonerConfig()
assert 888 == x._ClonerConfig__try_default("cloner_interval", 888)
with pytest.raises(KeyError) as exc:
x._ClonerConfig__try_default("nonexistent_key", 888)
assert exc.exconly() == "KeyError: 'nonexistent_key is not recognized config option'"
x._ClonerConfig__values['cloner_interval'] = 666
assert 666 == x._ClonerConfig__try_default("cloner_interval", 888)
def test_cloner_project_name():
x = ClonerConfig()
assert x.cloner_project_name == ""
x._ClonerConfig__values['cloner_project_name'] = "asdfgh"
assert x.cloner_project_name == "asdfgh"
def test_cloner_repo_url():
x = ClonerConfig()
assert x.cloner_repo_url == ""
x._ClonerConfig__values['cloner_repo_url'] = "asdfgh"
assert x.cloner_repo_url == "asdfgh"
def test_cloner_interval():
x = ClonerConfig()
assert x.cloner_interval == 5
x._ClonerConfig__values['cloner_interval'] = 0
assert x.cloner_interval == 0
def test_cloner_submodules():
x = ClonerConfig()
assert x.cloner_submodules == True
x._ClonerConfig__values['cloner_submodules'] = False
assert not x.cloner_submodules
def test_cloner_submodule_depth():
x = ClonerConfig()
assert x.cloner_submodule_depth == 50000
x._ClonerConfig__values['cloner_submodule_depth'] = -1
assert x.cloner_submodule_depth == -1
def test_set_property():
x = ClonerConfig()
assert x.cloner_interval == 5
x._set_property("cloner_interval", 0)
assert x.cloner_interval == 0
# invalid type
with pytest.raises(ValueError) as exc:
x._set_property("cloner_interval", "č")
assert exc.exconly() == "ValueError: Invalid value for key cloner_interval: type is <class 'str'>"
# undefined property
with pytest.raises(KeyError) as exc:
x._set_property("nonexistent_key", 888)
assert exc.exconly() == "KeyError: 'nonexistent_key is not recognized config option'"

View File

@ -33,4 +33,3 @@ def test_has_property():
assert x.has_property("cloner_interval") assert x.has_property("cloner_interval")
assert x.has_property("cloner_submodules") assert x.has_property("cloner_submodules")
assert x.has_property("cloner_submodule_depth") assert x.has_property("cloner_submodule_depth")