• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    公众号

Python config.parse_config_file函数代码示例

原作者: [db:作者] 来自: [db:来源] 收藏 邀请

本文整理汇总了Python中mozharness.base.config.parse_config_file函数的典型用法代码示例。如果您正苦于以下问题:Python parse_config_file函数的具体用法?Python parse_config_file怎么用?Python parse_config_file使用的例子?那么恭喜您, 这里精选的函数代码示例或许可以为您提供帮助。



在下文中一共展示了parse_config_file函数的20个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于我们的系统推荐出更棒的Python代码示例。

示例1: _read_tree_config

    def _read_tree_config(self):
        """Reads an in-tree config file"""
        dirs = self.query_abs_dirs()
        test_install_dir = dirs.get('abs_test_install_dir',
                                    os.path.join(dirs['abs_work_dir'], 'tests'))

        if 'in_tree_config' in self.config:
            rel_tree_config_path = self.config['in_tree_config']
            tree_config_path = os.path.join(test_install_dir, rel_tree_config_path)

            if not os.path.isfile(tree_config_path):
                self.fatal("The in-tree configuration file '%s' does not exist!"
                           "It must be added to '%s'. See bug 1035551 for more details." %
                           (tree_config_path, os.path.join('gecko', 'testing', rel_tree_config_path)))

            try:
                self.tree_config.update(parse_config_file(tree_config_path))
            except:
                msg = "There was a problem parsing the in-tree configuration file '%s'!" % \
                      os.path.join('gecko', 'testing', rel_tree_config_path)
                self.exception(message=msg, level=FATAL)

            self.dump_config(file_path=os.path.join(dirs['abs_log_dir'], 'treeconfig.json'),
                             config=self.tree_config)

        if (self.buildbot_config and 'properties' in self.buildbot_config and
            self.buildbot_config['properties'].get('branch') == 'try'):
            try_config_path = os.path.join(test_install_dir, 'config', 'mozharness',
                                           'try_arguments.py')
            known_try_arguments = parse_config_file(try_config_path)
            self.set_extra_try_arguments(known_try_arguments)

        self.tree_config.lock()
开发者ID:paulmadore,项目名称:luckyde,代码行数:33,代码来源:testbase.py


示例2: parse_locales_file

    def parse_locales_file(self, locales_file):
        locales = []
        c = self.config
        platform = c.get("locales_platform", None)
        ignore_locales = c.get("ignore_locales", None)

        if locales_file.endswith('json'):
            locales_json = parse_config_file(locales_file)
            self.locale_dict = {}
            for locale in locales_json.keys():
                if platform and platform not in locales_json[locale]['platforms']:
                    continue
                locales.append(locale)
                self.locale_dict[locale] = locales_json[locale]['revision']
        else:
            fh = open(locales_file)
            locales = fh.read().split()
            fh.close()
        if ignore_locales:
            for locale in ignore_locales:
                if locale in locales:
                    self.debug("Ignoring locale %s." % locale)
                    locales.remove(locale)
        if locales:
            self.locales = locales
            return self.locales
开发者ID:armenzg,项目名称:mozharness,代码行数:26,代码来源:locales.py


示例3: test_dump_config_hierarchy_matches_self_config

 def test_dump_config_hierarchy_matches_self_config(self):
     try:
         ######
         # we need temp_cfg because self.s will be gcollected (NoneType) by
         # the time we get to SystemExit exception
         # temp_cfg will differ from self.s.config because of
         # 'dump_config_hierarchy'. we have to make a deepcopy because
         # config is a locked dict
         temp_s = script.BaseScript(
             initial_config_file='test/test.json',
             option_args=['--cfg', 'test/test_override.py,test/test_override2.py'],
         )
         from copy import deepcopy
         temp_cfg = deepcopy(temp_s.config)
         temp_cfg.update({'dump_config_hierarchy': True})
         ######
         self.s = script.BaseScript(
             initial_config_file='test/test.json',
             option_args=['--cfg', 'test/test_override.py,test/test_override2.py'],
             config={'dump_config_hierarchy': True}
         )
     except SystemExit:
         local_cfg_files = parse_config_file('test_logs/localconfigfiles.json')
         # finally let's just make sure that all the items added up, equals
         # what we started with: self.config
         target_cfg = {}
         for cfg_file in local_cfg_files:
             target_cfg.update(local_cfg_files[cfg_file])
         self.assertEqual(
             target_cfg, temp_cfg,
             msg="all of the items (combined) in each cfg file dumped via "
                 "--dump-config-hierarchy does not equal self.config "
         )
开发者ID:djmitche,项目名称:build-mozharness,代码行数:33,代码来源:test_base_script.py


示例4: test_dump_config_equals_self_config

 def test_dump_config_equals_self_config(self):
     try:
         ######
         # we need temp_cfg because self.s will be gcollected (NoneType) by
         # the time we get to SystemExit exception
         # temp_cfg will differ from self.s.config because of
         # 'dump_config_hierarchy'. we have to make a deepcopy because
         # config is a locked dict
         temp_s = script.BaseScript(
             initial_config_file='test/test.json',
             option_args=['--cfg', 'test/test_override.py,test/test_override2.py'],
         )
         from copy import deepcopy
         temp_cfg = deepcopy(temp_s.config)
         temp_cfg.update({'dump_config': True})
         ######
         self.s = script.BaseScript(
             initial_config_file='test/test.json',
             option_args=['--cfg', 'test/test_override.py,test/test_override2.py'],
             config={'dump_config': True}
         )
     except SystemExit:
         target_cfg = parse_config_file('test_logs/localconfig.json')
         self.assertEqual(
             target_cfg, temp_cfg,
             msg="all of the items (combined) in each cfg file dumped via "
                 "--dump-config does not equal self.config "
         )
开发者ID:djmitche,项目名称:build-mozharness,代码行数:28,代码来源:test_base_script.py


示例5: _read_tree_config

    def _read_tree_config(self):
        """Reads an in-tree config file"""
        dirs = self.query_abs_dirs()
        test_install_dir = dirs.get('abs_test_install_dir',
                                    os.path.join(dirs['abs_work_dir'], 'tests'))

        if 'in_tree_config' in self.config:
            rel_tree_config_path = self.config['in_tree_config']
            tree_config_path = os.path.join(test_install_dir, rel_tree_config_path)

            if not os.path.isfile(tree_config_path):
                self.fatal("The in-tree configuration file '%s' does not exist!"
                           "It must be added to '%s'. See bug 981030 for more details." %
                           (tree_config_path, os.path.join('gecko', 'testing', rel_tree_config_path)))

            try:
                self.tree_config.update(parse_config_file(tree_config_path))
            except:
                msg = "There was a problem parsing the in-tree configuration file '%s'!" % \
                      os.path.join('gecko', 'testing', rel_tree_config_path)
                self.exception(message=msg, level=FATAL)

            self.dump_config(file_path=os.path.join(dirs['abs_log_dir'], 'treeconfig.json'),
                             config=self.tree_config)
        self.tree_config.lock()
开发者ID:hwine,项目名称:build-mozharness,代码行数:25,代码来源:testbase.py


示例6: query_release_config

 def query_release_config(self):
     if self.release_config:
         return self.release_config
     c = self.config
     dirs = self.query_abs_dirs()
     if c.get("release_config_file"):
         self.info("Getting release config from %s..." % c["release_config_file"])
         rc = None
         try:
             rc = parse_config_file(
                 os.path.join(dirs['abs_work_dir'],
                              c["release_config_file"]),
                 config_dict_name="releaseConfig"
             )
         except IOError:
             self.fatal("Release config file %s not found!" % c["release_config_file"])
         except RuntimeError:
             self.fatal("Invalid release config file %s!" % c["release_config_file"])
         self.release_config['version'] = rc['version']
         self.release_config['buildnum'] = rc['buildNumber']
         self.release_config['ftp_server'] = rc['stagingServer']
         self.release_config['ftp_user'] = c.get('ftp_user', rc['hgUsername'])
         self.release_config['ftp_ssh_key'] = c.get('ftp_ssh_key', rc['hgSshKey'])
         self.release_config['release_channel'] = rc['releaseChannel']
     else:
         self.info("No release config file; using default config.")
         for key in ('version', 'buildnum',
                     'ftp_server', 'ftp_user', 'ftp_ssh_key'):
             self.release_config[key] = c[key]
     self.info("Release config:\n%s" % self.release_config)
     return self.release_config
开发者ID:kleopatra999,项目名称:system-addons,代码行数:31,代码来源:release.py


示例7: read_buildbot_config

 def read_buildbot_config(self):
     c = self.config
     if not c.get("buildbot_json_path"):
         # If we need to fail out, add postflight_read_buildbot_config()
         self.info("buildbot_json_path is not set.  Skipping...")
     else:
         # TODO try/except?
         self.buildbot_config = parse_config_file(c["buildbot_json_path"])
         self.info(pprint.pformat(self.buildbot_config))
开发者ID:Callek,项目名称:mozharness,代码行数:9,代码来源:buildbot.py


示例8: query_talos_json_config

 def query_talos_json_config(self):
     """Return the talos json config."""
     if self.talos_json_config:
         return self.talos_json_config
     if not self.talos_json:
         self.talos_json = os.path.join(self.talos_path, 'talos.json')
     self.talos_json_config = parse_config_file(self.talos_json)
     self.info(pprint.pformat(self.talos_json_config))
     return self.talos_json_config
开发者ID:Wafflespeanut,项目名称:gecko-dev,代码行数:9,代码来源:talos.py


示例9: read_buildbot_config

 def read_buildbot_config(self):
     c = self.config
     if not c.get("buildbot_json_path"):
         # If we need to fail out, add postflight_read_buildbot_config()
         self.info("buildbot_json_path is not set.  Skipping...")
     else:
         # TODO try/except?
         self.buildbot_config = parse_config_file(c['buildbot_json_path'])
         self.info(json.dumps(self.buildbot_config, indent=4))
开发者ID:catlee,项目名称:build-mozharness,代码行数:9,代码来源:buildbot.py


示例10: query_talos_json_config

    def query_talos_json_config(self):
        if self.talos_json_config:
            return self.talos_json_config

        dirs = self.query_abs_dirs()
        self.talos_json = self.download_file(self.talos_json_url,
                                             parent_dir=dirs['abs_talosdata_dir'],
                                             error_level=FATAL)
        self.talos_json_config = parse_config_file(self.talos_json)
        self.info(pprint.pformat(self.talos_json_config))

        return self.talos_json_config
开发者ID:djmitche,项目名称:build-mozharness,代码行数:12,代码来源:android_panda_talos.py


示例11: _read_tree_config

    def _read_tree_config(self):
        """Reads an in-tree config file"""
        dirs = self.query_abs_dirs()
        test_install_dir = dirs.get('abs_test_install_dir',
                                    os.path.join(dirs['abs_work_dir'], 'tests'))
        tree_config_path = os.path.join(test_install_dir, 'config', 'mozharness_config.py')

        if os.path.isfile(tree_config_path):
            self.tree_config.update(parse_config_file(tree_config_path))
            self.dump_config(file_path=os.path.join(dirs['abs_log_dir'], 'treeconfig.json'),
                             config=self.tree_config)
        self.tree_config.lock()
开发者ID:KevinGrandon,项目名称:build-mozharness,代码行数:12,代码来源:testbase.py


示例12: query_talos_json_config

 def query_talos_json_config(self):
     """Return the talos json config; download and read from the
     talos_json_url if need be."""
     if self.talos_json_config:
         return self.talos_json_config
     if not self.talos_json:
         talos_json_url = self.query_talos_json_url()
         if not talos_json_url:
             self.fatal("Can't download talos_json without a talos_json_url!")
         self.download_talos_json()
     self.talos_json_config = parse_config_file(self.talos_json)
     self.info(pprint.pformat(self.talos_json_config))
     return self.talos_json_config
开发者ID:TechnoAyan,项目名称:gecko-dev,代码行数:13,代码来源:talos.py


示例13: _read_tree_config

    def _read_tree_config(self):
        """Reads an in-tree config file"""
        dirs = self.query_abs_dirs()
        test_install_dir = dirs.get('abs_test_install_dir',
                                    os.path.join(dirs['abs_work_dir'], 'tests'))

        if 'in_tree_config' in self.config:
            rel_tree_config_path = self.config['in_tree_config']
            tree_config_path = os.path.join(test_install_dir, rel_tree_config_path)

            if not os.path.isfile(tree_config_path):
                self.fatal("The in-tree configuration file '%s' does not exist!"
                           "It must be added to '%s'. See bug 1035551 for more details." %
                           (tree_config_path, os.path.join('gecko', 'testing', rel_tree_config_path)))

            try:
                self.tree_config.update(parse_config_file(tree_config_path))
            except:
                msg = "There was a problem parsing the in-tree configuration file '%s'!" % \
                      os.path.join('gecko', 'testing', rel_tree_config_path)
                self.exception(message=msg, level=FATAL)

            self.dump_config(file_path=os.path.join(dirs['abs_log_dir'], 'treeconfig.json'),
                             config=self.tree_config)

        if (self.buildbot_config and 'properties' in self.buildbot_config and
            self.buildbot_config['properties'].get('branch') == 'try'):
            try_config_path = os.path.join(test_install_dir, 'config', 'mozharness',
                                           'try_arguments.py')
            known_try_arguments = parse_config_file(try_config_path)
            comments = self.buildbot_config['sourcestamp']['changes'][-1]['comments']
            if not comments and 'try_syntax' in self.buildbot_config['properties']:
                # If we don't find try syntax in the usual place, check for it in an
                # alternate property available to tools using self-serve.
                comments = self.buildbot_config['properties']['try_syntax']
            self.parse_extra_try_arguments(comments, known_try_arguments)

        self.tree_config.lock()
开发者ID:c0mmandCS,项目名称:Waterfox,代码行数:38,代码来源:testbase.py


示例14: checkout_gaia_l10n

    def checkout_gaia_l10n(self):
        if not self.config.get('gaia_languages_file'):
            self.info('Skipping checkout_gaia_l10n because no gaia language file was specified.')
            return

        l10n_config = self.load_goanna_config().get('gaia', {}).get('l10n')
        if not l10n_config:
            self.fatal("gaia.l10n is required in the goanna config when --gaia-languages-file is specified.")

        abs_work_dir = self.query_abs_dirs()['abs_work_dir']
        languages_file = os.path.join(abs_work_dir, 'gaia', self.config['gaia_languages_file'])
        l10n_base_dir = self.query_abs_dirs()['gaia_l10n_base_dir']

        self.pull_gaia_locale_source(l10n_config, parse_config_file(languages_file).keys(), l10n_base_dir)
开发者ID:Antonius32,项目名称:Pale-Moon,代码行数:14,代码来源:b2g_build.py


示例15: checkout_gaia_l10n

    def checkout_gaia_l10n(self):
        if not self.config.get("gaia_languages_file"):
            self.info("Skipping checkout_gaia_l10n because no gaia language file was specified.")
            return

        l10n_config = self.load_gecko_config().get("gaia", {}).get("l10n")
        if not l10n_config:
            self.fatal("gaia.l10n is required in the gecko config when --gaia-languages-file is specified.")

        abs_work_dir = self.query_abs_dirs()["abs_work_dir"]
        languages_file = os.path.join(abs_work_dir, "gaia", self.config["gaia_languages_file"])
        l10n_base_dir = self.query_abs_dirs()["gaia_l10n_base_dir"]

        self.pull_gaia_locale_source(l10n_config, parse_config_file(languages_file).keys(), l10n_base_dir)
开发者ID:mozilla-git,项目名称:gecko-dev,代码行数:14,代码来源:b2g_build.py


示例16: test_dump_config_hierarchy_valid_files_len

 def test_dump_config_hierarchy_valid_files_len(self):
     try:
         self.s = script.BaseScript(
             initial_config_file='test/test.json',
             option_args=['--cfg', 'test/test_override.py,test/test_override2.py'],
             config={'dump_config_hierarchy': True}
         )
     except SystemExit:
         local_cfg_files = parse_config_file('test_logs/localconfigfiles.json')
         # first let's see if the correct number of config files were
         # realized
         self.assertEqual(
             len(local_cfg_files), 4,
             msg="--dump-config-hierarchy dumped wrong number of config files"
         )
开发者ID:djmitche,项目名称:build-mozharness,代码行数:15,代码来源:test_base_script.py


示例17: read_buildbot_config

 def read_buildbot_config(self):
     c = self.config
     if not c.get("buildbot_json_path"):
         # If we need to fail out, add postflight_read_buildbot_config()
         self.info("buildbot_json_path is not set.  Skipping...")
     else:
         # TODO try/except?
         self.buildbot_config = parse_config_file(c['buildbot_json_path'])
         buildbot_properties = copy.deepcopy(self.buildbot_config.get('properties', {}))
         if 'commit_titles' in buildbot_properties:
             # Remove the commit messages since they can cause false positives with
             # Treeherder log parsers. Eg: "Bug X - Fix TEST-UNEPXECTED-FAIL ...".
             del buildbot_properties['commit_titles']
         self.info("Using buildbot properties:")
         self.info(json.dumps(buildbot_properties, indent=4))
开发者ID:MichaelKohler,项目名称:gecko-dev,代码行数:15,代码来源:buildbot.py


示例18: parse_locales_file

    def parse_locales_file(self, locales_file):
        locales = []
        c = self.config
        platform = c.get("locales_platform", None)

        if locales_file.endswith('json'):
            locales_json = parse_config_file(locales_file)
            self.locale_dict = {}
            for locale in locales_json.keys():
                if platform and platform not in locales_json[locale]['platforms']:
                    continue
                locales.append(locale)
                self.locale_dict[locale] = locales_json[locale]['revision']
        else:
            locales = self.read_from_file(locales_file).split()
        return locales
开发者ID:ctalbert,项目名称:mozharness,代码行数:16,代码来源:locales.py


示例19: test_dump_config_hierarchy_keys_unique_and_valid

 def test_dump_config_hierarchy_keys_unique_and_valid(self):
     try:
         self.s = script.BaseScript(
             initial_config_file='test/test.json',
             option_args=['--cfg', 'test/test_override.py,test/test_override2.py'],
             config={'dump_config_hierarchy': True}
         )
     except SystemExit:
         local_cfg_files = parse_config_file('test_logs/localconfigfiles.json')
         # now let's see if only unique items were added from each config
         t_override = local_cfg_files.get('test/test_override.py', {})
         self.assertTrue(
             t_override.get('keep_string') == "don't change me" and len(t_override.keys()) == 1,
             msg="--dump-config-hierarchy dumped wrong keys/value for "
                 "`test/test_override.py`. There should only be one "
                 "item and it should be unique to all the other "
                 "items in test_log/localconfigfiles.json."
         )
开发者ID:djmitche,项目名称:build-mozharness,代码行数:18,代码来源:test_base_script.py


示例20: _update_build_variant

    def _update_build_variant(self, rw_config, variant='artifact'):
        """ Intended for use in _pre_config_lock """
        c = self.config
        variant_cfg_path, _ = BuildOptionParser.find_variant_cfg_path(
            '--custom-build-variant-cfg',
            variant,
            rw_config.config_parser
        )
        if not variant_cfg_path:
            self.fatal('Could not find appropriate config file for variant %s' % variant)
        # Update other parts of config to keep dump-config accurate
        # Only dump-config is affected because most config info is set during
        # initial parsing
        variant_cfg_dict = parse_config_file(variant_cfg_path)
        rw_config.all_cfg_files_and_dicts.append((variant_cfg_path, variant_cfg_dict))
        c.update({
            'build_variant': variant,
            'config_files': c['config_files'] + [variant_cfg_path]
        })

        self.info("Updating self.config with the following from {}:".format(variant_cfg_path))
        self.info(pprint.pformat(variant_cfg_dict))
        c.update(variant_cfg_dict)
        c['forced_artifact_build'] = True
        # Bug 1231320 adds MOZHARNESS_ACTIONS in TaskCluster tasks to override default_actions
        # We don't want that when forcing an artifact build.
        if rw_config.volatile_config['actions']:
            self.info("Updating volatile_config to include default_actions "
                      "from {}.".format(variant_cfg_path))
            # add default actions in correct order
            combined_actions = []
            for a in rw_config.all_actions:
                if a in c['default_actions'] or a in rw_config.volatile_config['actions']:
                    combined_actions.append(a)
            rw_config.volatile_config['actions'] = combined_actions
            self.info("Actions in volatile_config are now: {}".format(
                rw_config.volatile_config['actions'])
            )
        # replace rw_config as well to set actions as in BaseScript
        rw_config.set_config(c, overwrite=True)
        rw_config.update_actions()
        self.actions = tuple(rw_config.actions)
        self.all_actions = tuple(rw_config.all_actions)
开发者ID:luke-chang,项目名称:gecko-1,代码行数:43,代码来源:fx_desktop_build.py



注:本文中的mozharness.base.config.parse_config_file函数示例由纯净天空整理自Github/MSDocs等源码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。


鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
上一篇:
Python log.OutputParser类代码示例发布时间:2022-05-27
下一篇:
Python mozfile.NamedTemporaryFile类代码示例发布时间:2022-05-27
热门推荐
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap