Refactor OptimizedBuildTarget and add general-tests optimization

Refactor the OptimizedBuildTarget base class to more simply handle
enabling/disabling build optimizations based on flags. Now all
optimizers (aside from the no-op NullOptimizer will have their enabling
built into the base class, and also necessitate their get_build_targets
and package_outputs functions to be defined in order to not error out.
Add the GeneralTestsOptimizer class as well, unimplemented for now.

Test: atest build_test_suites_test
Bug: 358215235
Change-Id: Ide22c64fc238d754db8d8e76484947401e54e680
This commit is contained in:
Luca Farsi
2024-08-07 17:29:16 -07:00
parent 70270692d0
commit 70a53bd6cf
2 changed files with 87 additions and 48 deletions

View File

@@ -14,6 +14,9 @@
# limitations under the License.
from abc import ABC
from typing import Self
import argparse
import functools
class OptimizedBuildTarget(ABC):
@@ -24,15 +27,41 @@ class OptimizedBuildTarget(ABC):
build.
"""
def __init__(self, build_context, args):
def __init__(
self,
target: str,
build_context: dict[str, any],
args: argparse.Namespace,
):
self.target = target
self.build_context = build_context
self.args = args
def get_build_targets(self):
pass
def get_build_targets(self) -> set[str]:
features = self.build_context.get('enabledBuildFeatures', [])
if self.get_enabled_flag() in features:
return self.get_build_targets_impl()
return {self.target}
def package_outputs(self):
pass
features = self.build_context.get('enabledBuildFeatures', [])
if self.get_enabled_flag() in features:
return self.package_outputs_impl()
def package_outputs_impl(self):
raise NotImplementedError(
f'package_outputs_impl not implemented in {type(self).__name__}'
)
def get_enabled_flag(self):
raise NotImplementedError(
f'get_enabled_flag not implemented in {type(self).__name__}'
)
def get_build_targets_impl(self) -> set[str]:
raise NotImplementedError(
f'get_build_targets_impl not implemented in {type(self).__name__}'
)
class NullOptimizer(OptimizedBuildTarget):
@@ -52,18 +81,25 @@ class NullOptimizer(OptimizedBuildTarget):
pass
def get_target_optimizer(target, enabled_flag, build_context, optimizer):
if enabled_flag in build_context['enabledBuildFeatures']:
return optimizer
class GeneralTestsOptimizer(OptimizedBuildTarget):
"""general-tests optimizer
return NullOptimizer(target)
TODO(b/358215235): Implement
This optimizer reads in the list of changed files from the file located in
env[CHANGE_INFO] and uses this list alongside the normal TEST MAPPING logic to
determine what test mapping modules will run for the given changes. It then
builds those modules and packages them in the same way general-tests.zip is
normally built.
"""
def get_enabled_flag(self):
return 'general-tests-optimized'
@classmethod
def get_optimized_targets(cls) -> dict[str, OptimizedBuildTarget]:
return {'general-tests': functools.partial(cls)}
# To be written as:
# 'target': lambda target, build_context, args: get_target_optimizer(
# target,
# 'target_enabled_flag',
# build_context,
# TargetOptimizer(build_context, args),
# )
OPTIMIZED_BUILD_TARGETS = dict()
OPTIMIZED_BUILD_TARGETS = {}
OPTIMIZED_BUILD_TARGETS.update(GeneralTestsOptimizer.get_optimized_targets())