aboutsummaryrefslogtreecommitdiffstats
path: root/build/gen_ins_pkg_script.py
diff options
context:
space:
mode:
authorbaigk <baiguoku@huawei.com>2015-09-08 07:47:19 -0400
committerbaigk <baiguoku@huawei.com>2015-09-08 08:24:09 -0400
commitcf87d3067a63cb8be315a3addfd9c27d86be3b5a (patch)
tree861d46aebc75c73cc13a19fecfb5c48aa88a56a1 /build/gen_ins_pkg_script.py
parent633175ed2c5d0ab339027ba0a542bcdd4d3769c0 (diff)
Build improvement for speedup and using public repo
JIRA: COMPASS-19 Change-Id: Iba101807e1bd2f843f1253791b7e87e1acb7934b Signed-off-by: baigk <baiguoku@huawei.com>
Diffstat (limited to 'build/gen_ins_pkg_script.py')
-rw-r--r--build/gen_ins_pkg_script.py64
1 files changed, 64 insertions, 0 deletions
diff --git a/build/gen_ins_pkg_script.py b/build/gen_ins_pkg_script.py
new file mode 100644
index 00000000..0f756d07
--- /dev/null
+++ b/build/gen_ins_pkg_script.py
@@ -0,0 +1,64 @@
+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, special_packages):
+ 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 in special_packages:
+ continue
+
+ if value not in package_name_list:
+ package_name_list += value
+
+ return package_name_list
+
+def generate_download_script(root, arch, tmpl, docker_tmpl, default_packages, special_packages, special_packages_dir):
+ package_name_list = get_packages_name_list(get_file_list(root, arch), special_packages) if root else []
+
+ tmpl = Template(file=tmpl, searchList={'packages':package_name_list, 'default_packages':default_packages})
+ with open('work/repo/install_packages.sh', 'w') as f:
+ f.write(tmpl.respond())
+
+ make_script = []
+ for i in special_packages:
+ name = 'make_' + i + '.sh'
+ if os.path.exists(os.path.join('.', arch, name)):
+ make_script.append(name)
+
+ searchList = {'dir':os.path.join('.', arch), 'scripts':make_script}
+ if os.path.exists(special_packages_dir):
+ special_packages_names = [i for i in os.listdir(special_packages_dir) if os.path.isfile(i)]
+ searchList.update({'spcial_packages':special_packages_names})
+
+ Dockerfile=os.path.basename(docker_tmpl).split('.')[0]
+ tmpl = Template(file=docker_tmpl, searchList=searchList)
+ with open(os.path.join('work/repo', Dockerfile), '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], sys.argv[4],
+ sys.argv[5].split(' '), sys.argv[6].split(' '), sys.argv[7])
+