Fix JPS tests after JPS module moved to Kotlin repo

Fix testdata of new compiler tests for JPS, as it is build-log-sensitive:
ClassHierarchyAffected.testWithIntermediateBodiesChanged
PureKotlin.testSerializedSubClassAndChangedInterfaces
WithJava.JavaUsedInKotlin.testRawErrorTypeDuringSerialization

Mute JavaUsedInKotlin.SamConversions tests, as it was fixed in 212 idea

Add missed part of commit 5f4be072 [JPS] Fix JS incremental compilation
Part of commit, located in JPS module, was missed during JPS relocation

Fix test MixedInheritance for non-JPS builds
Depends on commit [CHERRY PICKED FROM IJ] [testdata] Replace test IncrementalJvmJpsTest...
This commit is contained in:
Aleksei.Cherepanov
2022-01-19 15:05:26 +03:00
committed by Space
parent 411a0ecc38
commit 44d796e850
7 changed files with 198 additions and 6 deletions
@@ -432,6 +432,8 @@ class KotlinBuilder : ModuleLevelBuilder(BuilderCategory.SOURCE_PROCESSOR) {
kotlinDirtyFilesHolder.allRemovedFilesFiles
)
cleanJsOutputs(context, kotlinChunk, incrementalCaches, kotlinDirtyFilesHolder)
if (LOG.isDebugEnabled) {
LOG.debug("Compiling files: ${kotlinDirtyFilesHolder.allDirtyFiles}")
}
@@ -532,6 +534,43 @@ class KotlinBuilder : ModuleLevelBuilder(BuilderCategory.SOURCE_PROCESSOR) {
return OK
}
private fun cleanJsOutputs(
context: CompileContext,
kotlinChunk: KotlinChunk,
incrementalCaches: Map<KotlinModuleBuildTarget<*>, JpsIncrementalCache>,
kotlinDirtyFilesHolder: KotlinDirtySourceFilesHolder
) {
for (target in kotlinChunk.targets) {
val cache = incrementalCaches[target] ?: continue
if (cache is IncrementalJsCache) {
val filesToDelete = mutableListOf<File>()
val dirtyFiles = kotlinDirtyFilesHolder.getDirtyFiles(target.jpsModuleBuildTarget).keys
val removedFiles = kotlinDirtyFilesHolder.getRemovedFiles(target.jpsModuleBuildTarget)
for (file: File in dirtyFiles + removedFiles) {
filesToDelete.addAll(cache.getOutputsBySource(file).filter { it !in filesToDelete })
}
if (filesToDelete.isNotEmpty()) {
val deletedForThisSource = mutableSetOf<String>()
val parentDirs = mutableSetOf<File>()
for (kjsmFile in filesToDelete) {
BuildOperations.deleteRecursively(kjsmFile.path, deletedForThisSource, parentDirs)
}
FSOperations.pruneEmptyDirs(context, parentDirs)
val logger = context.loggingManager.projectBuilderLogger
if (logger.isEnabled && deletedForThisSource.isNotEmpty()) {
logger.logDeletedFiles(deletedForThisSource)
}
}
}
}
}
// todo(1.2.80): got rid of ModuleChunk (replace with KotlinChunk)
// todo(1.2.80): introduce KotlinRoundCompileContext, move dirtyFilesHolder, fsOperations, environment to it
private fun doCompileModuleChunk(
@@ -7,6 +7,7 @@ package org.jetbrains.kotlin.jps.targets
import org.jetbrains.jps.builders.storage.BuildDataPaths
import org.jetbrains.jps.incremental.ModuleBuildTarget
import org.jetbrains.jps.incremental.ModuleLevelBuilder
import org.jetbrains.jps.model.library.JpsOrderRootType
import org.jetbrains.jps.model.module.JpsModule
import org.jetbrains.jps.util.JpsPathUtil
@@ -227,7 +228,19 @@ class KotlinJsModuleBuildTarget(kotlinContext: KotlinCompileContext, jpsModuleBu
val jsCache = jpsIncrementalCache as IncrementalJsCache
jsCache.header = incrementalResults.headerMetadata
jsCache.updateSourceToOutputMap(files)
jsCache.compareAndUpdate(incrementalResults, changesCollector)
jsCache.clearCacheForRemovedClasses(changesCollector)
}
override fun registerOutputItems(outputConsumer: ModuleLevelBuilder.OutputConsumer, outputItems: List<GeneratedFile>) {
if (isIncrementalCompilationEnabled) {
for (output in outputItems) {
for (source in output.sourceFiles) {
outputConsumer.registerOutputFile(jpsModuleBuildTarget, File("${source.path.hashCode()}"), listOf(source.path))
}
}
} else {
super.registerOutputItems(outputConsumer, outputItems)
}
}
}
@@ -1,18 +1,25 @@
================ Step #1 =================
Cleaning output files:
out/production/module/META-INF/module.kotlin_module
out/production/module/foo/DirectBase.class
out/production/module/foo/DirectChild.class
End of files
Compiling files:
src/direct.kt
End of files
Exit code: OK
------------------------------------------
================ Step #2 =================
Cleaning output files:
out/production/module/META-INF/module.kotlin_module
out/production/module/foo/ReverseBase.class
out/production/module/foo/ReverseChild.class
End of files
Compiling files:
src/reverse.kt
End of files
Exit code: OK
------------------------------------------
------------------------------------------
@@ -2,8 +2,9 @@
Cleaning output files:
out/production/module/META-INF/module.kotlin_module
out/production/module/test/BKt.class
out/production/module/test/UsageKt.class
out/production/module/test/B.class
out/production/module/test/I1.class
out/production/module/test/I2.class
End of files
Compiling files:
src/b.kt
@@ -0,0 +1,127 @@
================ Step #1 =================
Cleaning output files:
out/production/module/BaseClass.class
End of files
Exit code: NOTHING_DONE
------------------------------------------
Compiling files:
src/BaseClass.java
End of files
Cleaning output files:
out/production/module/DerivedClass1.class
out/production/module/META-INF/module.kotlin_module
End of files
Compiling files:
src/DerivedClass1.kt
End of files
Exit code: ABORT
------------------------------------------
COMPILATION FAILED
Class 'DerivedClass1' is not abstract and does not implement abstract base class member public/*package*/ abstract fun myAbs(): Unit defined in BaseClass
================ Step #2 =================
Cleaning output files:
out/production/module/BaseClass.class
End of files
Compiling files:
src/DerivedClass1.kt
End of files
Exit code: OK
------------------------------------------
Compiling files:
src/BaseClass.java
End of files
================ Step #3 =================
Cleaning output files:
out/production/module/BaseClass.class
out/production/module/DerivedClass1.class
End of files
Exit code: NOTHING_DONE
------------------------------------------
Compiling files:
src/BaseClass.java
src/DerivedClass1.kt
End of files
================ Step #4 =================
Cleaning output files:
out/production/module/BaseClass.class
End of files
Exit code: NOTHING_DONE
------------------------------------------
Compiling files:
src/BaseClass.java
End of files
Cleaning output files:
out/production/module/DerivedClass1.class
out/production/module/META-INF/module.kotlin_module
End of files
Compiling files:
src/DerivedClass1.kt
End of files
Exit code: ABORT
------------------------------------------
COMPILATION FAILED
'doSmth' hides member of supertype 'BaseClass' and needs 'override' modifier
================ Step #5 =================
Cleaning output files:
out/production/module/BaseClass.class
End of files
Compiling files:
src/DerivedClass1.kt
End of files
Exit code: OK
------------------------------------------
Compiling files:
src/BaseClass.java
End of files
Cleaning output files:
out/production/module/DerivedClass1.class
out/production/module/META-INF/module.kotlin_module
End of files
Compiling files:
src/DerivedClass1.kt
End of files
Exit code: OK
------------------------------------------
================ Step #6 =================
Cleaning output files:
out/production/module/DerivedClass1.class
out/production/module/META-INF/module.kotlin_module
End of files
Compiling files:
src/DerivedClass1.kt
End of files
Exit code: OK
------------------------------------------
================ Step #7 =================
Cleaning output files:
out/production/module/BaseClass.class
End of files
Exit code: NOTHING_DONE
------------------------------------------
Compiling files:
src/BaseClass.java
End of files
Cleaning output files:
out/production/module/DerivedClass1.class
out/production/module/META-INF/module.kotlin_module
End of files
Compiling files:
src/DerivedClass1.kt
End of files
Exit code: ABORT
------------------------------------------
COMPILATION FAILED
Return type of 'doSmthAnother' is not a subtype of the return type of the overridden member 'public/*package*/ open fun doSmthAnother(): String! defined in BaseClass'
@@ -1,6 +1,10 @@
================ Step #1 =================
Compiling files:
Cleaning output files:
out/production/module/Foo.class
End of files
Exit code: OK
Exit code: NOTHING_DONE
------------------------------------------
Compiling files:
src/Foo.java
End of files
+1
View File
@@ -83,3 +83,4 @@ org.jetbrains.kotlin.checkers.FirKotlinHighlightingPassTestGenerated.Checker.tes
org.jetbrains.kotlin.idea.caches.resolve.MultiModuleHighlightingTest.testLanguageVersionsViaFacets,,, FLAKY
org.jetbrains.kotlin.jps.build.IncrementalJvmJpsTestGenerated.WithJava.JavaUsedInKotlin.SamConversions.testMethodAdded, KT-44844 fixed in IDEA 212,,
org.jetbrains.kotlin.jps.build.IncrementalJvmJpsTestGenerated.WithJava.JavaUsedInKotlin.SamConversions.testMethodAddedSamAdapter, KT-44844 fixed in IDEA 212,,
org.jetbrains.kotlin.jps.build.IncrementalJvmJpsTestGenerated.WithJava.JavaUsedInKotlin.SamConversions.testMethodAddDefault, KT-44844 fixed in IDEA 212,,
1 Test key Issue State (optional: MUTE or FAIL) Status (optional: FLAKY)
83 org.jetbrains.kotlin.idea.caches.resolve.MultiModuleHighlightingTest.testLanguageVersionsViaFacets FLAKY
84 org.jetbrains.kotlin.jps.build.IncrementalJvmJpsTestGenerated.WithJava.JavaUsedInKotlin.SamConversions.testMethodAdded KT-44844 fixed in IDEA 212
85 org.jetbrains.kotlin.jps.build.IncrementalJvmJpsTestGenerated.WithJava.JavaUsedInKotlin.SamConversions.testMethodAddedSamAdapter KT-44844 fixed in IDEA 212
86 org.jetbrains.kotlin.jps.build.IncrementalJvmJpsTestGenerated.WithJava.JavaUsedInKotlin.SamConversions.testMethodAddDefault KT-44844 fixed in IDEA 212