Merge "Revert "Revert "Build System: Validate AndroidTest.xml Configs"""
am: d3ef2822cc
Change-Id: Id57e37bd69958c9e6cfc178414ef9a5a84842d25
			
			
This commit is contained in:
		| @@ -558,7 +558,8 @@ multi_arch := | |||||||
| # The module itself. | # The module itself. | ||||||
| $(foreach suite, $(LOCAL_COMPATIBILITY_SUITE), \ | $(foreach suite, $(LOCAL_COMPATIBILITY_SUITE), \ | ||||||
|   $(eval my_compat_dist_$(suite) := $(foreach dir, $(call compatibility_suite_dirs,$(suite),$(arch_dir)), \ |   $(eval my_compat_dist_$(suite) := $(foreach dir, $(call compatibility_suite_dirs,$(suite),$(arch_dir)), \ | ||||||
|     $(LOCAL_BUILT_MODULE):$(dir)/$(my_installed_module_stem)))) |     $(LOCAL_BUILT_MODULE):$(dir)/$(my_installed_module_stem))) \ | ||||||
|  |   $(eval my_compat_dist_config_$(suite) := )) | ||||||
|  |  | ||||||
| # Make sure we only add the files once for multilib modules. | # Make sure we only add the files once for multilib modules. | ||||||
| ifndef $(my_prefix)$(LOCAL_MODULE_CLASS)_$(LOCAL_MODULE)_compat_files | ifndef $(my_prefix)$(LOCAL_MODULE_CLASS)_$(LOCAL_MODULE)_compat_files | ||||||
| @@ -605,7 +606,7 @@ is_instrumentation_test := | |||||||
|  |  | ||||||
| ifneq (,$(test_config)) | ifneq (,$(test_config)) | ||||||
| $(foreach suite, $(LOCAL_COMPATIBILITY_SUITE), \ | $(foreach suite, $(LOCAL_COMPATIBILITY_SUITE), \ | ||||||
|   $(eval my_compat_dist_$(suite) += $(foreach dir, $(call compatibility_suite_dirs,$(suite)), \ |   $(eval my_compat_dist_config_$(suite) += $(foreach dir, $(call compatibility_suite_dirs,$(suite)), \ | ||||||
|     $(test_config):$(dir)/$(LOCAL_MODULE).config))) |     $(test_config):$(dir)/$(LOCAL_MODULE).config))) | ||||||
| endif | endif | ||||||
|  |  | ||||||
| @@ -613,14 +614,14 @@ test_config := | |||||||
|  |  | ||||||
| ifneq (,$(wildcard $(LOCAL_PATH)/DynamicConfig.xml)) | ifneq (,$(wildcard $(LOCAL_PATH)/DynamicConfig.xml)) | ||||||
| $(foreach suite, $(LOCAL_COMPATIBILITY_SUITE), \ | $(foreach suite, $(LOCAL_COMPATIBILITY_SUITE), \ | ||||||
|   $(eval my_compat_dist_$(suite) += $(foreach dir, $(call compatibility_suite_dirs,$(suite)), \ |   $(eval my_compat_dist_config_$(suite) += $(foreach dir, $(call compatibility_suite_dirs,$(suite)), \ | ||||||
|     $(LOCAL_PATH)/DynamicConfig.xml:$(dir)/$(LOCAL_MODULE).dynamic))) |     $(LOCAL_PATH)/DynamicConfig.xml:$(dir)/$(LOCAL_MODULE).dynamic))) | ||||||
| endif | endif | ||||||
|  |  | ||||||
| ifneq (,$(wildcard $(LOCAL_PATH)/$(LOCAL_MODULE)_*.config)) | ifneq (,$(wildcard $(LOCAL_PATH)/$(LOCAL_MODULE)_*.config)) | ||||||
| $(foreach extra_config, $(wildcard $(LOCAL_PATH)/$(LOCAL_MODULE)_*.config), \ | $(foreach extra_config, $(wildcard $(LOCAL_PATH)/$(LOCAL_MODULE)_*.config), \ | ||||||
|   $(foreach suite, $(LOCAL_COMPATIBILITY_SUITE), \ |   $(foreach suite, $(LOCAL_COMPATIBILITY_SUITE), \ | ||||||
|     $(eval my_compat_dist_$(suite) += $(foreach dir, $(call compatibility_suite_dirs,$(suite)), \ |     $(eval my_compat_dist_config_$(suite) += $(foreach dir, $(call compatibility_suite_dirs,$(suite)), \ | ||||||
|       $(extra_config):$(dir)/$(notdir $(extra_config)))))) |       $(extra_config):$(dir)/$(notdir $(extra_config)))))) | ||||||
| endif | endif | ||||||
| endif # $(my_prefix)$(LOCAL_MODULE_CLASS)_$(LOCAL_MODULE)_compat_files | endif # $(my_prefix)$(LOCAL_MODULE_CLASS)_$(LOCAL_MODULE)_compat_files | ||||||
| @@ -639,6 +640,8 @@ arch_dir := | |||||||
| is_native := | is_native := | ||||||
|  |  | ||||||
| $(call create-suite-dependencies) | $(call create-suite-dependencies) | ||||||
|  | $(foreach suite, $(LOCAL_COMPATIBILITY_SUITE), \ | ||||||
|  |   $(eval my_compat_dist_config_$(suite) := )) | ||||||
|  |  | ||||||
| endif  # LOCAL_COMPATIBILITY_SUITE | endif  # LOCAL_COMPATIBILITY_SUITE | ||||||
|  |  | ||||||
|   | |||||||
| @@ -2695,6 +2695,18 @@ $(2): $(1) $(XMLLINT) | |||||||
| 	$$(copy-file-to-target) | 	$$(copy-file-to-target) | ||||||
| endef | endef | ||||||
|  |  | ||||||
|  | # Copies many xml files and check they are well-formed. | ||||||
|  | # $(1): The xml files to copy.  Each entry is a ':' separated src:dst pair. | ||||||
|  | # Evaluates to the list of the dst files. (ie suitable for a dependency list.) | ||||||
|  | define copy-many-xml-files-checked | ||||||
|  | $(foreach f, $(1), $(strip \ | ||||||
|  |     $(eval _cmf_tuple := $(subst :, ,$(f))) \ | ||||||
|  |     $(eval _cmf_src := $(word 1,$(_cmf_tuple))) \ | ||||||
|  |     $(eval _cmf_dest := $(word 2,$(_cmf_tuple))) \ | ||||||
|  |     $(eval $(call copy-xml-file-checked,$(_cmf_src),$(_cmf_dest))) \ | ||||||
|  |     $(_cmf_dest))) | ||||||
|  | endef | ||||||
|  |  | ||||||
| # Copy the file only if it is a well-formed manifest file. For use viea $(eval) | # Copy the file only if it is a well-formed manifest file. For use viea $(eval) | ||||||
| # $(1): source file | # $(1): source file | ||||||
| # $(2): destination file | # $(2): destination file | ||||||
| @@ -3138,15 +3150,20 @@ endef | |||||||
|  |  | ||||||
| # For each suite: | # For each suite: | ||||||
| # 1. Copy the files to the many suite output directories. | # 1. Copy the files to the many suite output directories. | ||||||
|  | #    And for test config files, we'll check the .xml is well-formed before copy. | ||||||
| # 2. Add all the files to each suite's dependent files list. | # 2. Add all the files to each suite's dependent files list. | ||||||
| # 3. Do the dependency addition to my_all_targets | # 3. Do the dependency addition to my_all_targets | ||||||
| # Requires for each suite: my_compat_dist_$(suite) to be defined. | # Requires for each suite: use my_compat_dist_config_$(suite) to define the test config. | ||||||
|  | #    and use my_compat_dist_$(suite) to define the others. | ||||||
| define create-suite-dependencies | define create-suite-dependencies | ||||||
| $(foreach suite, $(LOCAL_COMPATIBILITY_SUITE), \ | $(foreach suite, $(LOCAL_COMPATIBILITY_SUITE), \ | ||||||
|   $(eval COMPATIBILITY.$(suite).FILES := \ |   $(eval COMPATIBILITY.$(suite).FILES := \ | ||||||
|     $$(COMPATIBILITY.$(suite).FILES) $$(foreach f,$$(my_compat_dist_$(suite)),$$(call word-colon,2,$$(f))))) \ |     $$(COMPATIBILITY.$(suite).FILES) $$(foreach f,$$(my_compat_dist_$(suite)),$$(call word-colon,2,$$(f))) \ | ||||||
|  |       $$(foreach f,$$(my_compat_dist_config_$(suite)),$$(call word-colon,2,$$(f))))) \ | ||||||
| $(eval $(my_all_targets) : $(call copy-many-files, \ | $(eval $(my_all_targets) : $(call copy-many-files, \ | ||||||
|   $(sort $(foreach suite,$(LOCAL_COMPATIBILITY_SUITE),$(my_compat_dist_$(suite)))))) |   $(sort $(foreach suite,$(LOCAL_COMPATIBILITY_SUITE),$(my_compat_dist_$(suite))))) \ | ||||||
|  |   $(call copy-many-xml-files-checked, \ | ||||||
|  |     $(sort $(foreach suite,$(LOCAL_COMPATIBILITY_SUITE),$(my_compat_dist_config_$(suite)))))) | ||||||
| endef | endef | ||||||
|  |  | ||||||
| ########################################################### | ########################################################### | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user