forked from mirrors/gecko-dev
		
	 02a7b4ebdf
			
		
	
	
		02a7b4ebdf
		
	
	
	
	
		
			
			Allow-list all Python code in tree for use with the black linter, and re-format all code in-tree accordingly. To produce this patch I did all of the following: 1. Make changes to tools/lint/black.yml to remove include: stanza and update list of source extensions. 2. Run ./mach lint --linter black --fix 3. Make some ad-hoc manual updates to python/mozbuild/mozbuild/test/configure/test_configure.py -- it has some hard-coded line numbers that the reformat breaks. 4. Make some ad-hoc manual updates to `testing/marionette/client/setup.py`, `testing/marionette/harness/setup.py`, and `testing/firefox-ui/harness/setup.py`, which have hard-coded regexes that break after the reformat. 5. Add a set of exclusions to black.yml. These will be deleted in a follow-up bug (1672023). # ignore-this-changeset Differential Revision: https://phabricator.services.mozilla.com/D94045
		
			
				
	
	
		
			61 lines
		
	
	
	
		
			2.1 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			61 lines
		
	
	
	
		
			2.1 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| # This Source Code Form is subject to the terms of the Mozilla Public
 | |
| # License, v. 2.0. If a copy of the MPL was not distributed with this
 | |
| # file, You can obtain one at http://mozilla.org/MPL/2.0/.
 | |
| 
 | |
| from __future__ import absolute_import, print_function, unicode_literals
 | |
| 
 | |
| import logging
 | |
| 
 | |
| import six
 | |
| 
 | |
| from ..util.templates import merge
 | |
| from ..util.yaml import load_yaml
 | |
| 
 | |
| logger = logging.getLogger(__name__)
 | |
| 
 | |
| 
 | |
| def loader(kind, path, config, params, loaded_tasks):
 | |
|     """
 | |
|     Get the input elements that will be transformed into tasks in a generic
 | |
|     way.  The elements themselves are free-form, and become the input to the
 | |
|     first transform.
 | |
| 
 | |
|     By default, this reads jobs from the `jobs` key, or from yaml files
 | |
|     named by `jobs-from`.  The entities are read from mappings, and the
 | |
|     keys to those mappings are added in the `name` key of each entity.
 | |
| 
 | |
|     If there is a `job-defaults` config, then every job is merged with it.
 | |
|     This provides a simple way to set default values for all jobs of a kind.
 | |
|     The `job-defaults` key can also be specified in a yaml file pointed to by
 | |
|     `jobs-from`. In this case it will only apply to tasks defined in the same
 | |
|     file.
 | |
| 
 | |
|     Other kind implementations can use a different loader function to
 | |
|     produce inputs and hand them to `transform_inputs`.
 | |
|     """
 | |
| 
 | |
|     def jobs():
 | |
|         defaults = config.get("job-defaults")
 | |
|         for name, job in six.iteritems(config.get("jobs", {})):
 | |
|             if defaults:
 | |
|                 job = merge(defaults, job)
 | |
|             job["job-from"] = "kind.yml"
 | |
|             yield name, job
 | |
| 
 | |
|         for filename in config.get("jobs-from", []):
 | |
|             tasks = load_yaml(path, filename)
 | |
| 
 | |
|             file_defaults = tasks.pop("job-defaults", None)
 | |
|             if defaults:
 | |
|                 file_defaults = merge(defaults, file_defaults or {})
 | |
| 
 | |
|             for name, job in six.iteritems(tasks):
 | |
|                 if file_defaults:
 | |
|                     job = merge(file_defaults, job)
 | |
|                 job["job-from"] = filename
 | |
|                 yield name, job
 | |
| 
 | |
|     for name, job in jobs():
 | |
|         job["name"] = name
 | |
|         logger.debug("Generating tasks for {} {}".format(kind, name))
 | |
|         yield job
 |