diff options
author | Chigang(Justin) <chigang@huawei.com> | 2015-08-18 12:17:22 +0000 |
---|---|---|
committer | Gerrit Code Review <gerrit@172.30.200.206> | 2015-08-18 12:17:22 +0000 |
commit | 8df99c5890236b6acc7578f663f36fd0deafa453 (patch) | |
tree | 8b3e63682d7c3cbb78e4fe0d811086cfa1d93dea /ci/gen_ins_pkg_script.py | |
parent | ade17ce57eb08dbf262cb9b6f1893367e2832dc1 (diff) | |
parent | 3656b2525c9b4e8c5e1f45625adb1cd143425dc0 (diff) |
Merge "Generate ppa repositories automatically"
Diffstat (limited to 'ci/gen_ins_pkg_script.py')
-rw-r--r-- | ci/gen_ins_pkg_script.py | 45 |
1 files changed, 45 insertions, 0 deletions
diff --git a/ci/gen_ins_pkg_script.py b/ci/gen_ins_pkg_script.py new file mode 100644 index 00000000..9ce71f4a --- /dev/null +++ b/ci/gen_ins_pkg_script.py @@ -0,0 +1,45 @@ +import yaml, os, sys +from Cheetah.Template import Template + +def get_file_list(root, arch): + files = [] + + dirs = os.listdir(os.path.join(root, 'roles')) + + for dir in dirs: + var_dir = os.path.join(root, 'roles', dir, 'vars') + for name in ['main.yml', arch + r'.yml']: + if os.path.exists(os.path.join(var_dir, name)): + files.append(os.path.join(var_dir, name)) + + return files + +def get_packages_name_list(file_list): + package_name_list = [] + + for file in file_list: + datas = yaml.load(open(file)) + for key, value in datas.items(): + if not key.endswith("packages") and not key.endswith("packages_noarch"): + continue + + if not value: + continue + + if value not in package_name_list: + package_name_list += value + + return package_name_list + +def generate_download_script(root, arch, tmpl): + package_name_list = get_packages_name_list(get_file_list(root, arch)) + + tmpl = Template(file=tmpl, searchList={'packages':package_name_list}) + + with open('install_packages.sh', 'w') as f: + f.write(tmpl.respond()) + +if __name__=='__main__': + # generate_download_script('ansible', 'Debian', 'Debian.tmpl') + generate_download_script(sys.argv[1], sys.argv[2], sys.argv[3]) + |