[gradle] gradle artifacts import fix importing module output elements

Also, do not skip non-existent modules to make errors visible

Committer: Sergey.Rostov@jetbrains.com

GitOrigin-RevId: db5c4a33b1ff0475ea0b9ee49074c2cd8c564a9a
This commit is contained in:
Nikita Skvortsov
2019-08-30 16:59:20 +03:00
committed by intellij-monorepo-bot
parent f4853a1eab
commit 39f405bc27
2 changed files with 82 additions and 36 deletions

View File

@@ -4,11 +4,10 @@ package com.intellij.openapi.externalSystem.service.project.settings
import com.intellij.execution.BeforeRunTask
import com.intellij.execution.BeforeRunTaskProvider
import com.intellij.execution.configurations.RunConfiguration
import com.intellij.openapi.diagnostic.Logger
import com.intellij.openapi.externalSystem.model.project.settings.ConfigurationData
import com.intellij.openapi.externalSystem.project.PackagingModifiableModel
import com.intellij.openapi.externalSystem.service.project.IdeModifiableModelsProvider
import com.intellij.openapi.module.Module
import com.intellij.openapi.module.ModuleManager
import com.intellij.openapi.module.ModulePointer
import com.intellij.openapi.module.ModulePointerManager
import com.intellij.openapi.project.Project
@@ -16,6 +15,7 @@ import com.intellij.openapi.roots.libraries.Library
import com.intellij.openapi.roots.libraries.LibraryTablesRegistrar
import com.intellij.packaging.artifacts.*
import com.intellij.packaging.elements.CompositePackagingElement
import com.intellij.packaging.elements.PackagingElement
import com.intellij.packaging.impl.artifacts.PlainArtifactType
import com.intellij.packaging.impl.elements.*
import com.intellij.packaging.impl.run.BuildArtifactsBeforeRunTask
@@ -23,6 +23,7 @@ import com.intellij.packaging.impl.run.BuildArtifactsBeforeRunTaskProvider
import com.intellij.util.ObjectUtils.consumeIfCast
class ArtifactsImporter: ConfigurationHandler {
private val LOG = Logger.getInstance(ArtifactsImporter::class.java)
override fun apply(project: Project, modelsProvider: IdeModifiableModelsProvider, configuration: ConfigurationData) {
val artifacts = configuration.find("ideArtifacts") as? List<*> ?: return
@@ -44,18 +45,42 @@ class ArtifactsImporter: ConfigurationHandler {
.findArtifact(name)?.let { modifiableModel.getOrCreateModifiableArtifact(it) }
?: modifiableModel.addArtifact(name, type)
val rootElement = type.createRootElement(name)
populateArtifact(project, rootElement, artifactConfig, postponedOps)
populateArtifact(project, modelsProvider, rootElement, artifactConfig, postponedOps)
artifact.rootElement = rootElement
}
postponedOps.forEach { it.invoke(modifiableModel) }
}
private fun populateArtifact(project: Project, element: CompositePackagingElement<*>,
private fun populateArtifact(project: Project,
modelsProvider: IdeModifiableModelsProvider,
element: CompositePackagingElement<*>,
config: Map<*, *>,
postponedOps: MutableList<(ModifiableArtifactModel) -> Unit>) {
consumeIfCast(config["children"], List::class.java) {
it.forEach { child ->
fun createModulePointer(moduleName: String): ModulePointer {
val module = modelsProvider.findIdeModule(moduleName)
return if (module != null) {
ModulePointerManager.getInstance(project).create(module)
} else {
LOG.warn("Artifact `${element.name}`: unable to find module `$moduleName`");
ModulePointerManager.getInstance(project).create(moduleName)
}
}
fun addModuleElement(config: Map<*, *>, provider: (ModulePointer) -> PackagingElement<*>) {
val moduleName = config["moduleName"] as? String
if (moduleName == null) {
LOG.warn("Artifact `${element.name}`: moduleName missed for $config")
return
}
val modulePointer = createModulePointer(moduleName)
val child = provider(modulePointer)
element.addOrFindChild(child)
}
consumeIfCast(config["children"], List::class.java) { children ->
children.forEach { child ->
consumeIfCast(child, Map::class.java) child@{ config ->
val type = config["type"] as? String ?: return@child
when (type) {
@@ -63,13 +88,13 @@ class ArtifactsImporter: ConfigurationHandler {
"DIR" -> {
val directory = DirectoryPackagingElement(config["name"] as? String ?: "no_name")
populateArtifact(project, directory, config,postponedOps)
populateArtifact(project, modelsProvider, directory, config, postponedOps)
element.addOrFindChild(directory)
}
"ARCHIVE" -> {
val archive = ArchivePackagingElement(config["name"] as? String ?: "no_name")
populateArtifact(project, archive, config, postponedOps)
populateArtifact(project, modelsProvider, archive, config, postponedOps)
element.addOrFindChild(archive)
}
@@ -87,32 +112,11 @@ class ArtifactsImporter: ConfigurationHandler {
}
}
"MODULE_OUTPUT" -> {
val moduleName = config["moduleName"] as? String
project.ifModuleFound(moduleName) { module ->
val pointer: ModulePointer = ModulePointerManager.getInstance(project).create(module)
val moduleOutput = ProductionModuleOutputPackagingElement(project, pointer)
element.addOrFindChild(moduleOutput)
}
}
"MODULE_OUTPUT" -> addModuleElement(config) { ProductionModuleOutputPackagingElement(project, it) }
"MODULE_TEST_OUTPUT" -> {
val moduleName = config["moduleName"] as? String
project.ifModuleFound(moduleName) { module ->
val pointer: ModulePointer = ModulePointerManager.getInstance(project).create(module)
val moduleOutput = TestModuleOutputPackagingElement(project, pointer)
element.addOrFindChild(moduleOutput)
}
}
"MODULE_TEST_OUTPUT" -> addModuleElement(config) { TestModuleOutputPackagingElement(project, it) }
"MODULE_SRC" -> {
val moduleName = config["moduleName"] as? String
project.ifModuleFound(moduleName) { module ->
val pointer: ModulePointer = ModulePointerManager.getInstance(project).create(module)
val moduleOutput = ProductionModuleSourcePackagingElement(project, pointer)
element.addOrFindChild(moduleOutput)
}
}
"MODULE_SRC" -> addModuleElement(config) { ProductionModuleSourcePackagingElement(project, it) }
"FILE" -> {
consumeIfCast(config["sourceFiles"], List::class.java) {
@@ -151,6 +155,8 @@ class ArtifactsImporter: ConfigurationHandler {
}
}
}
else -> LOG.warn("Artifact `${element.name}`: unsupported artifact type `$type` in $config")
}
}
}
@@ -161,10 +167,6 @@ class ArtifactsImporter: ConfigurationHandler {
val libraryTable = LibraryTablesRegistrar.getInstance().getLibraryTable(this@findLibraryByNameSuffix)
return libraryTable.libraries.find { it.name?.endsWith(nameSuffix) ?: false }
}
private fun Project.ifModuleFound(moduleName: String?, processor: (Module) -> Unit) {
if (moduleName != null) { ModuleManager.getInstance(this@ifModuleFound).findModuleByName(moduleName)?.let { processor(it) } }
}
}
class BuildArtifactsTaskImporter: BeforeRunTaskImporter {

View File

@@ -8,7 +8,9 @@ import com.intellij.compiler.impl.javaCompiler.javac.JavacConfiguration;
import com.intellij.packaging.artifacts.Artifact;
import com.intellij.packaging.artifacts.ArtifactManager;
import com.intellij.packaging.elements.PackagingElement;
import com.intellij.packaging.impl.elements.ArchivePackagingElement;
import com.intellij.packaging.impl.elements.ArtifactPackagingElement;
import com.intellij.packaging.impl.elements.ModuleOutputPackagingElement;
import org.jetbrains.jps.model.java.compiler.JpsJavaCompilerOptions;
import org.junit.Test;
@@ -118,4 +120,46 @@ public class GradleJavaSettingsImportingTest extends GradleSettingsImportingTest
assertInstanceOf(element, ArtifactPackagingElement.class);
assertEquals("SomeArt", ((ArtifactPackagingElement)element).getArtifactName());
}
@Test
public void testModuleReferenceImport() throws Exception {
importProject(
new GradleBuildScriptBuilderEx()
.withGradleIdeaExtPlugin(IDEA_EXT_PLUGIN_VERSION)
.addPostfix(
"idea.project.settings {",
" ideArtifacts {",
" SomeArt {",
" archive(\"main.jar\") {",
" moduleOutput(idea.module.name)",
" moduleOutput(\"unknown_module\")",
" }",
" }",
" }",
"}"
)
.generate()
);
ArtifactManager artifactsManager = ArtifactManager.getInstance(myProject);
Artifact artifact = artifactsManager.findArtifact("SomeArt");
assertNotNull(artifact);
List<PackagingElement<?>> artifactChildren = artifact.getRootElement().getChildren();
assertSize( 1, artifactChildren);
PackagingElement<?> archive = artifactChildren.get(0);
assertNotNull(archive);
assertInstanceOf(archive, ArchivePackagingElement.class);
List<PackagingElement<?>> archiveChildren = ((ArchivePackagingElement)archive).getChildren();
assertSize( 2, archiveChildren);
PackagingElement<?> moduleOutput1 = archiveChildren.get(0);
assertInstanceOf(moduleOutput1, ModuleOutputPackagingElement.class);
assertEquals("project", ((ModuleOutputPackagingElement)moduleOutput1).getModuleName());
PackagingElement<?> moduleOutput2 = archiveChildren.get(1);
assertInstanceOf(moduleOutput2, ModuleOutputPackagingElement.class);
assertEquals("unknown_module", ((ModuleOutputPackagingElement)moduleOutput2).getModuleName());
}
}