Unverified Commit a72ce8bc authored by D. Koutsogiorgas's avatar D. Koutsogiorgas Committed by GitHub

Merge pull request #7661 from dnkoutso/resource_bundle_targets_by_spec_name

Split test resource bundles installed by each test spec
parents 6d77b2c7 0bb1bd41
...@@ -285,7 +285,7 @@ module Pod ...@@ -285,7 +285,7 @@ module Pod
pod_target_installation_result.test_specs_by_native_target.each do |test_native_target, test_specs| pod_target_installation_result.test_specs_by_native_target.each do |test_native_target, test_specs|
test_dependent_targets.each do |test_dependent_target| test_dependent_targets.each do |test_dependent_target|
dependency_installation_result = pod_target_installation_results_hash[test_dependent_target.name] dependency_installation_result = pod_target_installation_results_hash[test_dependent_target.name]
dependency_installation_result.test_resource_bundle_targets.each do |test_resource_bundle_target| dependency_installation_result.test_resource_bundle_targets.values.flatten.each do |test_resource_bundle_target|
test_native_target.add_dependency(test_resource_bundle_target) test_native_target.add_dependency(test_resource_bundle_target)
end end
test_native_target.add_dependency(dependency_installation_result.native_target) test_native_target.add_dependency(dependency_installation_result.native_target)
......
...@@ -35,14 +35,14 @@ module Pod ...@@ -35,14 +35,14 @@ module Pod
# For targets that should not be built (e.g. pre-built vendored frameworks etc), we add a placeholder # For targets that should not be built (e.g. pre-built vendored frameworks etc), we add a placeholder
# PBXAggregateTarget that will be used to wire up dependencies later. # PBXAggregateTarget that will be used to wire up dependencies later.
native_target = add_placeholder_target native_target = add_placeholder_target
resource_bundle_targets = add_resources_bundle_targets(file_accessors) resource_bundle_targets = add_resources_bundle_targets(file_accessors).values.flatten
return TargetInstallationResult.new(target, native_target, resource_bundle_targets) return TargetInstallationResult.new(target, native_target, resource_bundle_targets)
end end
create_support_files_dir create_support_files_dir
native_target = add_target native_target = add_target
resource_bundle_targets = add_resources_bundle_targets(file_accessors) resource_bundle_targets = add_resources_bundle_targets(file_accessors).values.flatten
test_native_targets = add_test_targets test_native_targets = add_test_targets
test_app_host_targets = add_test_app_host_targets(test_native_targets) test_app_host_targets = add_test_app_host_targets(test_native_targets)
...@@ -51,7 +51,7 @@ module Pod ...@@ -51,7 +51,7 @@ module Pod
add_files_to_build_phases(native_target, test_native_targets) add_files_to_build_phases(native_target, test_native_targets)
create_xcconfig_file(native_target, resource_bundle_targets) create_xcconfig_file(native_target, resource_bundle_targets)
create_test_xcconfig_files(test_native_targets, test_resource_bundle_targets) create_test_xcconfig_files(test_native_targets, test_resource_bundle_targets.values.flatten)
if target.defines_module? if target.defines_module?
create_module_map(native_target) do |generator| create_module_map(native_target) do |generator|
...@@ -340,8 +340,8 @@ module Pod ...@@ -340,8 +340,8 @@ module Pod
# @return [Array<PBXNativeTarget] the resource bundle native targets created. # @return [Array<PBXNativeTarget] the resource bundle native targets created.
# #
def add_resources_bundle_targets(file_accessors) def add_resources_bundle_targets(file_accessors)
file_accessors.flat_map do |file_accessor| file_accessors.each_with_object({}) do |file_accessor, hash|
file_accessor.resource_bundles.map do |bundle_name, paths| hash[file_accessor.spec.name] = file_accessor.resource_bundles.map do |bundle_name, paths|
label = target.resources_bundle_target_label(bundle_name) label = target.resources_bundle_target_label(bundle_name)
resource_bundle_target = project.new_resources_bundle(label, file_accessor.spec_consumer.platform_name) resource_bundle_target = project.new_resources_bundle(label, file_accessor.spec_consumer.platform_name)
resource_bundle_target.product_reference.tap do |bundle_product| resource_bundle_target.product_reference.tap do |bundle_product|
......
...@@ -27,9 +27,9 @@ module Pod ...@@ -27,9 +27,9 @@ module Pod
# #
attr_reader :test_native_targets attr_reader :test_native_targets
# @return [Array<PBXNativeTarget>] test_resource_bundle_targets # @return [Hash{String=>Array<PBXNativeTarget>}] test_resource_bundle_targets
# The test resource bundle targets that were produced for this target. Can be empty if the target had # The test resource bundle targets that were produced for this target keyed by test spec name.
# no resource bundles for any tests. # Can be empty if the target had no resource bundles for any tests.
# #
attr_reader :test_resource_bundle_targets attr_reader :test_resource_bundle_targets
...@@ -44,11 +44,11 @@ module Pod ...@@ -44,11 +44,11 @@ module Pod
# @param [PBXNativeTarget] native_target @see #native_target # @param [PBXNativeTarget] native_target @see #native_target
# @param [Array<PBXNativeTarget>] resource_bundle_targets @see #resource_bundle_targets # @param [Array<PBXNativeTarget>] resource_bundle_targets @see #resource_bundle_targets
# @param [Array<PBXNativeTarget>] test_native_targets @see #test_native_targets # @param [Array<PBXNativeTarget>] test_native_targets @see #test_native_targets
# @param [Array<PBXNativeTarget>] test_resource_bundle_targets @see #test_resource_bundle_targets # @param [Hash{String=>Array<PBXNativeTarget>}] test_resource_bundle_targets @see #test_resource_bundle_targets
# @param [Array<PBXNativeTarget>] test_app_host_targets @see #test_app_host_targets # @param [Array<PBXNativeTarget>] test_app_host_targets @see #test_app_host_targets
# #
def initialize(target, native_target, resource_bundle_targets = [], test_native_targets = [], def initialize(target, native_target, resource_bundle_targets = [], test_native_targets = [],
test_resource_bundle_targets = [], test_app_host_targets = []) test_resource_bundle_targets = {}, test_app_host_targets = [])
@target = target @target = target
@native_target = native_target @native_target = native_target
@resource_bundle_targets = resource_bundle_targets @resource_bundle_targets = resource_bundle_targets
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment