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
		
			
				
	
	
		
			47 lines
		
	
	
	
		
			1.6 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			47 lines
		
	
	
	
		
			1.6 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
 | |
| 
 | |
| from taskgraph.optimize import All, OptimizationStrategy, register_strategy
 | |
| from taskgraph.util.backstop import BACKSTOP_PUSH_INTERVAL
 | |
| 
 | |
| 
 | |
| @register_strategy("skip-unless-backstop")
 | |
| class SkipUnlessBackstop(OptimizationStrategy):
 | |
|     """Always removes tasks except on backstop pushes."""
 | |
| 
 | |
|     def should_remove_task(self, task, params, _):
 | |
|         return not params["backstop"]
 | |
| 
 | |
| 
 | |
| class SkipUnlessPushInterval(OptimizationStrategy):
 | |
|     """Always removes tasks except every N pushes.
 | |
| 
 | |
|     Args:
 | |
|         push_interval (int): Number of pushes
 | |
|     """
 | |
| 
 | |
|     def __init__(self, push_interval, remove_on_projects=None):
 | |
|         self.push_interval = push_interval
 | |
| 
 | |
|     @property
 | |
|     def description(self):
 | |
|         return "skip-unless-push-interval-{}".format(self.push_interval)
 | |
| 
 | |
|     def should_remove_task(self, task, params, _):
 | |
|         # On every Nth push, want to run all tasks.
 | |
|         return int(params["pushlog_id"]) % self.push_interval != 0
 | |
| 
 | |
| 
 | |
| # Strategy to run tasks on "expanded" pushes, currently defined as pushes that
 | |
| # are half the backstop interval. The 'All' composite strategy means that the
 | |
| # "backstop" strategy will prevent "expanded" from applying on backstop pushes.
 | |
| register_strategy(
 | |
|     "skip-unless-expanded",
 | |
|     args=(
 | |
|         "skip-unless-backstop",
 | |
|         SkipUnlessPushInterval(BACKSTOP_PUSH_INTERVAL / 2),
 | |
|     ),
 | |
| )(All)
 |