Merge "Add extra_test_configs option" am: ec7a91f9fa am: 82448f2d2d
				
					
				
			Original change: https://android-review.googlesource.com/c/platform/build/soong/+/1402168 Change-Id: If619742e8271e804231d029a87f5fa1297959488
This commit is contained in:
		| @@ -167,6 +167,14 @@ func AndroidMkDataPaths(data []android.DataPath) []string { | ||||
| 	return testFiles | ||||
| } | ||||
|  | ||||
| func androidMkWriteExtraTestConfigs(extraTestConfigs android.Paths, entries *android.AndroidMkEntries) { | ||||
| 	if len(extraTestConfigs) > 0 { | ||||
| 		entries.ExtraEntries = append(entries.ExtraEntries, func(entries *android.AndroidMkEntries) { | ||||
| 			entries.AddStrings("LOCAL_EXTRA_FULL_TEST_CONFIGS", extraTestConfigs.Strings()...) | ||||
| 		}) | ||||
| 	} | ||||
| } | ||||
|  | ||||
| func androidMkWriteTestData(data []android.DataPath, ctx AndroidMkContext, entries *android.AndroidMkEntries) { | ||||
| 	testFiles := AndroidMkDataPaths(data) | ||||
| 	if len(testFiles) > 0 { | ||||
| @@ -372,6 +380,7 @@ func (test *testBinary) AndroidMkEntries(ctx AndroidMkContext, entries *android. | ||||
| 	}) | ||||
|  | ||||
| 	androidMkWriteTestData(test.data, ctx, entries) | ||||
| 	androidMkWriteExtraTestConfigs(test.extraTestConfigs, entries) | ||||
| } | ||||
|  | ||||
| func (fuzz *fuzzBinary) AndroidMkEntries(ctx AndroidMkContext, entries *android.AndroidMkEntries) { | ||||
|   | ||||
							
								
								
									
										13
									
								
								cc/test.go
									
									
									
									
									
								
							
							
						
						
									
										13
									
								
								cc/test.go
									
									
									
									
									
								
							| @@ -40,8 +40,12 @@ type TestProperties struct { | ||||
| type TestOptions struct { | ||||
| 	// The UID that you want to run the test as on a device. | ||||
| 	Run_test_as *string | ||||
|  | ||||
| 	// A list of free-formed strings without spaces that categorize the test. | ||||
| 	Test_suite_tag []string | ||||
|  | ||||
| 	// a list of extra test configuration files that should be installed with the module. | ||||
| 	Extra_test_configs []string `android:"path,arch_variant"` | ||||
| } | ||||
|  | ||||
| type TestBinaryProperties struct { | ||||
| @@ -309,9 +313,10 @@ type testBinary struct { | ||||
| 	testDecorator | ||||
| 	*binaryDecorator | ||||
| 	*baseCompiler | ||||
| 	Properties TestBinaryProperties | ||||
| 	data       []android.DataPath | ||||
| 	testConfig android.Path | ||||
| 	Properties       TestBinaryProperties | ||||
| 	data             []android.DataPath | ||||
| 	testConfig       android.Path | ||||
| 	extraTestConfigs android.Paths | ||||
| } | ||||
|  | ||||
| func (test *testBinary) linkerProps() []interface{} { | ||||
| @@ -408,6 +413,8 @@ func (test *testBinary) install(ctx ModuleContext, file android.Path) { | ||||
| 	test.testConfig = tradefed.AutoGenNativeTestConfig(ctx, test.Properties.Test_config, | ||||
| 		test.Properties.Test_config_template, test.Properties.Test_suites, configs, test.Properties.Auto_gen_config) | ||||
|  | ||||
| 	test.extraTestConfigs = android.PathsForModuleSrc(ctx, test.Properties.Test_options.Extra_test_configs) | ||||
|  | ||||
| 	test.binaryDecorator.baseInstaller.dir = "nativetest" | ||||
| 	test.binaryDecorator.baseInstaller.dir64 = "nativetest64" | ||||
|  | ||||
|   | ||||
| @@ -161,6 +161,7 @@ func (j *Test) AndroidMkEntries() []android.AndroidMkEntries { | ||||
| 		if j.testConfig != nil { | ||||
| 			entries.SetPath("LOCAL_FULL_TEST_CONFIG", j.testConfig) | ||||
| 		} | ||||
| 		androidMkWriteExtraTestConfigs(j.extraTestConfigs, entries) | ||||
| 		androidMkWriteTestData(j.data, entries) | ||||
| 		if !BoolDefault(j.testProperties.Auto_gen_config, true) { | ||||
| 			entries.SetString("LOCAL_DISABLE_AUTO_GENERATE_TEST_CONFIG", "true") | ||||
| @@ -170,6 +171,12 @@ func (j *Test) AndroidMkEntries() []android.AndroidMkEntries { | ||||
| 	return entriesList | ||||
| } | ||||
|  | ||||
| func androidMkWriteExtraTestConfigs(extraTestConfigs android.Paths, entries *android.AndroidMkEntries) { | ||||
| 	if len(extraTestConfigs) > 0 { | ||||
| 		entries.AddStrings("LOCAL_EXTRA_FULL_TEST_CONFIGS", extraTestConfigs.Strings()...) | ||||
| 	} | ||||
| } | ||||
|  | ||||
| func (j *TestHelperLibrary) AndroidMkEntries() []android.AndroidMkEntries { | ||||
| 	entriesList := j.Library.AndroidMkEntries() | ||||
| 	entries := &entriesList[0] | ||||
| @@ -431,6 +438,7 @@ func (a *AndroidTest) AndroidMkEntries() []android.AndroidMkEntries { | ||||
| 		if a.testConfig != nil { | ||||
| 			entries.SetPath("LOCAL_FULL_TEST_CONFIG", a.testConfig) | ||||
| 		} | ||||
| 		androidMkWriteExtraTestConfigs(a.extraTestConfigs, entries) | ||||
| 		androidMkWriteTestData(a.data, entries) | ||||
| 	}) | ||||
|  | ||||
|   | ||||
| @@ -1064,8 +1064,9 @@ type AndroidTest struct { | ||||
|  | ||||
| 	testProperties testProperties | ||||
|  | ||||
| 	testConfig android.Path | ||||
| 	data       android.Paths | ||||
| 	testConfig       android.Path | ||||
| 	extraTestConfigs android.Paths | ||||
| 	data             android.Paths | ||||
| } | ||||
|  | ||||
| func (a *AndroidTest) InstallInTestcases() bool { | ||||
| @@ -1093,6 +1094,7 @@ func (a *AndroidTest) GenerateAndroidBuildActions(ctx android.ModuleContext) { | ||||
| 	testConfig := tradefed.AutoGenInstrumentationTestConfig(ctx, a.testProperties.Test_config, | ||||
| 		a.testProperties.Test_config_template, a.manifestPath, a.testProperties.Test_suites, a.testProperties.Auto_gen_config, configs) | ||||
| 	a.testConfig = a.FixTestConfig(ctx, testConfig) | ||||
| 	a.extraTestConfigs = android.PathsForModuleSrc(ctx, a.testProperties.Test_options.Extra_test_configs) | ||||
| 	a.data = android.PathsForModuleSrc(ctx, a.testProperties.Data) | ||||
| } | ||||
|  | ||||
|   | ||||
							
								
								
									
										16
									
								
								java/java.go
									
									
									
									
									
								
							
							
						
						
									
										16
									
								
								java/java.go
									
									
									
									
									
								
							| @@ -2128,6 +2128,12 @@ func LibraryHostFactory() android.Module { | ||||
| // Java Tests | ||||
| // | ||||
|  | ||||
| // Test option struct. | ||||
| type TestOptions struct { | ||||
| 	// a list of extra test configuration files that should be installed with the module. | ||||
| 	Extra_test_configs []string `android:"path,arch_variant"` | ||||
| } | ||||
|  | ||||
| type testProperties struct { | ||||
| 	// list of compatibility suites (for example "cts", "vts") that the module should be | ||||
| 	// installed into. | ||||
| @@ -2153,6 +2159,9 @@ type testProperties struct { | ||||
| 	// Add parameterized mainline modules to auto generated test config. The options will be | ||||
| 	// handled by TradeFed to do downloading and installing the specified modules on the device. | ||||
| 	Test_mainline_modules []string | ||||
|  | ||||
| 	// Test options. | ||||
| 	Test_options TestOptions | ||||
| } | ||||
|  | ||||
| type hostTestProperties struct { | ||||
| @@ -2181,8 +2190,9 @@ type Test struct { | ||||
|  | ||||
| 	testProperties testProperties | ||||
|  | ||||
| 	testConfig android.Path | ||||
| 	data       android.Paths | ||||
| 	testConfig       android.Path | ||||
| 	extraTestConfigs android.Paths | ||||
| 	data             android.Paths | ||||
| } | ||||
|  | ||||
| type TestHost struct { | ||||
| @@ -2221,6 +2231,8 @@ func (j *Test) GenerateAndroidBuildActions(ctx android.ModuleContext) { | ||||
|  | ||||
| 	j.data = android.PathsForModuleSrc(ctx, j.testProperties.Data) | ||||
|  | ||||
| 	j.extraTestConfigs = android.PathsForModuleSrc(ctx, j.testProperties.Test_options.Extra_test_configs) | ||||
|  | ||||
| 	ctx.VisitDirectDepsWithTag(dataNativeBinsTag, func(dep android.Module) { | ||||
| 		j.data = append(j.data, android.OutputFileForModule(ctx, dep, "")) | ||||
| 	}) | ||||
|   | ||||
		Reference in New Issue
	
	Block a user