Merge "Prebuilt replacing source should not change partition" am: 7ef8d46640 am: 34d8436fb5
				
					
				
			Original change: https://android-review.googlesource.com/c/platform/build/soong/+/2574171 Change-Id: I690054c5edabb126a70ccb1cc5f6404290e799c5 Signed-off-by: Automerger Merge Worker <android-build-automerger-merge-worker@system.gserviceaccount.com>
This commit is contained in:
		| @@ -46,8 +46,8 @@ type OverrideModule interface { | |||||||
|  |  | ||||||
| 	// Internal funcs to handle interoperability between override modules and prebuilts. | 	// Internal funcs to handle interoperability between override modules and prebuilts. | ||||||
| 	// i.e. cases where an overriding module, too, is overridden by a prebuilt module. | 	// i.e. cases where an overriding module, too, is overridden by a prebuilt module. | ||||||
| 	setOverriddenByPrebuilt(overridden bool) | 	setOverriddenByPrebuilt(prebuilt Module) | ||||||
| 	getOverriddenByPrebuilt() bool | 	getOverriddenByPrebuilt() Module | ||||||
|  |  | ||||||
| 	// Directory containing the Blueprint definition of the overriding module | 	// Directory containing the Blueprint definition of the overriding module | ||||||
| 	setModuleDir(string) | 	setModuleDir(string) | ||||||
| @@ -60,7 +60,7 @@ type OverrideModuleBase struct { | |||||||
|  |  | ||||||
| 	overridingProperties []interface{} | 	overridingProperties []interface{} | ||||||
|  |  | ||||||
| 	overriddenByPrebuilt bool | 	overriddenByPrebuilt Module | ||||||
|  |  | ||||||
| 	moduleDir string | 	moduleDir string | ||||||
| } | } | ||||||
| @@ -96,11 +96,11 @@ func (o *OverrideModuleBase) GetOverriddenModuleName() string { | |||||||
| 	return proptools.String(o.moduleProperties.Base) | 	return proptools.String(o.moduleProperties.Base) | ||||||
| } | } | ||||||
|  |  | ||||||
| func (o *OverrideModuleBase) setOverriddenByPrebuilt(overridden bool) { | func (o *OverrideModuleBase) setOverriddenByPrebuilt(prebuilt Module) { | ||||||
| 	o.overriddenByPrebuilt = overridden | 	o.overriddenByPrebuilt = prebuilt | ||||||
| } | } | ||||||
|  |  | ||||||
| func (o *OverrideModuleBase) getOverriddenByPrebuilt() bool { | func (o *OverrideModuleBase) getOverriddenByPrebuilt() Module { | ||||||
| 	return o.overriddenByPrebuilt | 	return o.overriddenByPrebuilt | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -281,7 +281,7 @@ func overrideModuleDepsMutator(ctx BottomUpMutatorContext) { | |||||||
| 				panic("PrebuiltDepTag leads to a non-prebuilt module " + dep.Name()) | 				panic("PrebuiltDepTag leads to a non-prebuilt module " + dep.Name()) | ||||||
| 			} | 			} | ||||||
| 			if prebuilt.UsePrebuilt() { | 			if prebuilt.UsePrebuilt() { | ||||||
| 				module.setOverriddenByPrebuilt(true) | 				module.setOverriddenByPrebuilt(dep) | ||||||
| 				return | 				return | ||||||
| 			} | 			} | ||||||
| 		}) | 		}) | ||||||
| @@ -314,8 +314,10 @@ func performOverrideMutator(ctx BottomUpMutatorContext) { | |||||||
| 		ctx.AliasVariation(variants[0]) | 		ctx.AliasVariation(variants[0]) | ||||||
| 		for i, o := range overrides { | 		for i, o := range overrides { | ||||||
| 			mods[i+1].(OverridableModule).override(ctx, mods[i+1], o) | 			mods[i+1].(OverridableModule).override(ctx, mods[i+1], o) | ||||||
| 			if o.getOverriddenByPrebuilt() { | 			if prebuilt := o.getOverriddenByPrebuilt(); prebuilt != nil { | ||||||
| 				// The overriding module itself, too, is overridden by a prebuilt. | 				// The overriding module itself, too, is overridden by a prebuilt. | ||||||
|  | 				// Perform the same check for replacement | ||||||
|  | 				checkInvariantsForSourceAndPrebuilt(ctx, mods[i+1], prebuilt) | ||||||
| 				// Copy the flag and hide it in make | 				// Copy the flag and hide it in make | ||||||
| 				mods[i+1].ReplacedByPrebuilt() | 				mods[i+1].ReplacedByPrebuilt() | ||||||
| 			} | 			} | ||||||
|   | |||||||
| @@ -419,6 +419,20 @@ func PrebuiltSourceDepsMutator(ctx BottomUpMutatorContext) { | |||||||
| 	} | 	} | ||||||
| } | } | ||||||
|  |  | ||||||
|  | // checkInvariantsForSourceAndPrebuilt checks if invariants are kept when replacing | ||||||
|  | // source with prebuilt. Note that the current module for the context is the source module. | ||||||
|  | func checkInvariantsForSourceAndPrebuilt(ctx BaseModuleContext, s, p Module) { | ||||||
|  | 	if _, ok := s.(OverrideModule); ok { | ||||||
|  | 		// skip the check when the source module is `override_X` because it's only a placeholder | ||||||
|  | 		// for the actual source module. The check will be invoked for the actual module. | ||||||
|  | 		return | ||||||
|  | 	} | ||||||
|  | 	if sourcePartition, prebuiltPartition := s.PartitionTag(ctx.DeviceConfig()), p.PartitionTag(ctx.DeviceConfig()); sourcePartition != prebuiltPartition { | ||||||
|  | 		ctx.OtherModuleErrorf(p, "partition is different: %s(%s) != %s(%s)", | ||||||
|  | 			sourcePartition, ctx.ModuleName(), prebuiltPartition, ctx.OtherModuleName(p)) | ||||||
|  | 	} | ||||||
|  | } | ||||||
|  |  | ||||||
| // PrebuiltSelectModuleMutator marks prebuilts that are used, either overriding source modules or | // PrebuiltSelectModuleMutator marks prebuilts that are used, either overriding source modules or | ||||||
| // because the source module doesn't exist.  It also disables installing overridden source modules. | // because the source module doesn't exist.  It also disables installing overridden source modules. | ||||||
| func PrebuiltSelectModuleMutator(ctx TopDownMutatorContext) { | func PrebuiltSelectModuleMutator(ctx TopDownMutatorContext) { | ||||||
| @@ -434,6 +448,8 @@ func PrebuiltSelectModuleMutator(ctx TopDownMutatorContext) { | |||||||
| 		ctx.VisitDirectDepsWithTag(PrebuiltDepTag, func(prebuiltModule Module) { | 		ctx.VisitDirectDepsWithTag(PrebuiltDepTag, func(prebuiltModule Module) { | ||||||
| 			p := GetEmbeddedPrebuilt(prebuiltModule) | 			p := GetEmbeddedPrebuilt(prebuiltModule) | ||||||
| 			if p.usePrebuilt(ctx, s, prebuiltModule) { | 			if p.usePrebuilt(ctx, s, prebuiltModule) { | ||||||
|  | 				checkInvariantsForSourceAndPrebuilt(ctx, s, prebuiltModule) | ||||||
|  |  | ||||||
| 				p.properties.UsePrebuilt = true | 				p.properties.UsePrebuilt = true | ||||||
| 				s.ReplacedByPrebuilt() | 				s.ReplacedByPrebuilt() | ||||||
| 			} | 			} | ||||||
|   | |||||||
| @@ -497,6 +497,52 @@ func TestPrebuilts(t *testing.T) { | |||||||
| 	} | 	} | ||||||
| } | } | ||||||
|  |  | ||||||
|  | func testPrebuiltError(t *testing.T, expectedError, bp string) { | ||||||
|  | 	t.Helper() | ||||||
|  | 	fs := MockFS{ | ||||||
|  | 		"prebuilt_file": nil, | ||||||
|  | 	} | ||||||
|  | 	GroupFixturePreparers( | ||||||
|  | 		PrepareForTestWithArchMutator, | ||||||
|  | 		PrepareForTestWithPrebuilts, | ||||||
|  | 		PrepareForTestWithOverrides, | ||||||
|  | 		fs.AddToFixture(), | ||||||
|  | 		FixtureRegisterWithContext(registerTestPrebuiltModules), | ||||||
|  | 	). | ||||||
|  | 		ExtendWithErrorHandler(FixtureExpectsAtLeastOneErrorMatchingPattern(expectedError)). | ||||||
|  | 		RunTestWithBp(t, bp) | ||||||
|  | } | ||||||
|  |  | ||||||
|  | func TestPrebuiltShouldNotChangePartition(t *testing.T) { | ||||||
|  | 	testPrebuiltError(t, `partition is different`, ` | ||||||
|  | 		source { | ||||||
|  | 			name: "foo", | ||||||
|  | 			vendor: true, | ||||||
|  | 		} | ||||||
|  | 		prebuilt { | ||||||
|  | 			name: "foo", | ||||||
|  | 			prefer: true, | ||||||
|  | 			srcs: ["prebuilt_file"], | ||||||
|  | 		}`) | ||||||
|  | } | ||||||
|  |  | ||||||
|  | func TestPrebuiltShouldNotChangePartition_WithOverride(t *testing.T) { | ||||||
|  | 	testPrebuiltError(t, `partition is different`, ` | ||||||
|  | 		source { | ||||||
|  | 			name: "foo", | ||||||
|  | 			vendor: true, | ||||||
|  | 		} | ||||||
|  | 		override_source { | ||||||
|  | 			name: "bar", | ||||||
|  | 			base: "foo", | ||||||
|  | 		} | ||||||
|  | 		prebuilt { | ||||||
|  | 			name: "bar", | ||||||
|  | 			prefer: true, | ||||||
|  | 			srcs: ["prebuilt_file"], | ||||||
|  | 		}`) | ||||||
|  | } | ||||||
|  |  | ||||||
| func registerTestPrebuiltBuildComponents(ctx RegistrationContext) { | func registerTestPrebuiltBuildComponents(ctx RegistrationContext) { | ||||||
| 	registerTestPrebuiltModules(ctx) | 	registerTestPrebuiltModules(ctx) | ||||||
|  |  | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user