-
Notifications
You must be signed in to change notification settings - Fork 46
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
commit 31fbc83 Author: Andrey Tarbeev <dinis.taranov@mail.ru> Date: Fri Jul 8 10:50:52 2022 +0300 Minimize exceptions in signature (#418) * Minimize exceptions in test methods signatures commit 63eb9b0 Author: Yury Kamenev <yurkam447@gmail.com> Date: Thu Jul 7 15:13:45 2022 +0300 Removed always used coverage-based minimization strategy (#450) commit fe0f7f8 Author: Yury Kamenev <yurkam447@gmail.com> Date: Thu Jul 7 14:19:53 2022 +0300 Disabled NPE checks for non-public library fields by default (#353) commit d1b51fe Author: Yury Kamenev <yurkam447@gmail.com> Date: Thu Jul 7 13:44:46 2022 +0300 Fixed NPE for processing static field as first statement in MUT (#433) commit acc2fff Author: Nikita Vlaev <nikitavlaev00@gmail.com> Date: Wed Jul 6 15:37:28 2022 +0300 Added ForceStaticMockListener to run "configure mockito-inline" action. Refactored url listener in notifications. commit 80c2328 Author: Nikita Stroganov <54814796+IdeaSeeker@users.noreply.github.com> Date: Thu Jul 7 11:21:13 2022 +0300 Support -P parameters in the utbot-gradle (#377) commit a92e289 Author: Sergey Pospelov <sergeypospelov59@gmail.com> Date: Tue Jul 5 10:29:45 2022 +0300 Fix searching of modifiers field for JDK 8-17 commit 9a3acb6 Author: Amandel Pie <105506115+amandelpie@users.noreply.github.com> Date: Wed Jul 6 14:16:09 2022 +0300 Disabled clustering of tests generated by Fuzzer (#431) * Disabled clustering of tests generated by Fuzzer * Refactored the multiple calls commit c09568f Author: Vassiliy Kudryashov <vassiliy.kudryashov@gmail.com> Date: Wed Jul 6 10:21:52 2022 +0300 Existing test file without test class obstruct generation #160 (#425) commit 2ec8fb3 Author: Denis Fokin <Denis.Fokin@gmail.com> Date: Tue Jul 5 16:52:42 2022 +0300 Better naming commit 68c66ef Author: Vassiliy Kudryashov <vassiliy.kudryashov@gmail.com> Date: Tue Jul 5 19:51:55 2022 +0300 SVG logo contains 'inaccurate' holes #330 (#411) commit 1d48789 Author: Dmitrii Timofeev <dtim@comitative.com> Date: Tue Jul 5 17:08:38 2022 +0300 Workaround: run concrete execution for invokedynamic commit 65d95c1 Author: Vassiliy Kudryashov <vassiliy.kudryashov@gmail.com> Date: Tue Jul 5 19:42:55 2022 +0300 Plugin fails with an exception if no SDK is configured for the test module #399 (#424) commit 6f9f2d8 Author: Maksim Pelevin <maks.pelevin@gmail.com> Date: Tue Jul 5 17:49:58 2022 +0300 Fix CNFE: kotlin.collections.ArrayDeque in ContestEstimator (#419) commit 67cc7d9 Author: Denis Fokin <Denis.Fokin@gmail.com> Date: Tue Jul 5 11:58:40 2022 +0300 Put concrete executor jar in resources for contest estimator commit 63e2252 Author: Alena Lisevych <37301492+alisevych@users.noreply.github.com> Date: Tue Jul 5 15:48:29 2022 +0300 Tooltips correction for #343 (#410) Co-authored-by: Alena Lisevych <> commit 8b3defa Author: Vassiliy Kudryashov <vassiliy.kudryashov@gmail.com> Date: Tue Jul 5 13:22:31 2022 +0300 Write access exception on test generating in Idea project with JDK 11 #350 (#409) commit c02883c Author: Amandel Pie <105506115+amandelpie@users.noreply.github.com> Date: Tue Jul 5 11:21:21 2022 +0300 Enables 40 tests for utbot-summary module (#389) * Repair testPow * Repaired ReturnExampleTest tests * Restored SummaryCycleTest.kt * Restored all the tests commit 65c07f8 Author: Victoria <32179813+victoriafomina@users.noreply.github.com> Date: Tue Jul 5 09:51:44 2022 +0300 Update Dockerfile_java_cli (#396) commit 3b21112 Author: Alexey Menshutin <alex.menshutin99@gmail.com> Date: Mon Jul 4 21:16:53 2022 +0300 ToString support for abstract collection using makeSymbolic #391 commit c2673df Author: Vassiliy Kudryashov <vassiliy.kudryashov@gmail.com> Date: Mon Jul 4 21:56:43 2022 +0300 IDE fatal error during tests generation #68 (#379) commit 43693fb Author: Nikita Vlaev <vlaev.nikita@huawei.com> Date: Mon Jul 4 18:59:57 2022 +0300 Bring back test class generation (#403) commit 1c01193 Author: Yury Kamenev <yurkam447@gmail.com> Date: Mon Jul 4 20:24:03 2022 +0300 Added the wrapper for static methods of java.util.List (#400) commit a805f31 Author: Nikita Vlaev <vlaev.nikita@huawei.com> Date: Fri Jul 1 20:16:28 2022 +0300 Add title pane with unsupported jdk notification (#373) commit 16c13fb Author: Dmitrii Timofeev <dtim@comitative.com> Date: Mon Jul 4 18:35:36 2022 +0300 Initiate concrete execution if a wrapper method is missing (#392) If a JVM class is overridden but a method is missing from the wrapper, the engine will discard the path and fall back to concrete execution instead of analysing the real JVM code graph. This approach fixes the problem with methods that have been introduced in newer JDKs. Now wrappers are mostly limited to Java 1.8 interfaces and fail to analyze methods like `String::isBlank` or `String::lines` when the code runs under JDK 11. Building graphs from the real JDK code fails because the wrapper does not have private fields that the original code uses. TODO: to allow symbolic analysis of the code, missing methods should be actually implemented in corresponding wrappers.
- Loading branch information
Showing
70 changed files
with
3,360 additions
and
1,580 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
49 changes: 49 additions & 0 deletions
49
utbot-framework-api/src/main/kotlin/org/utbot/framework/TrustedLibraries.kt
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,49 @@ | ||
package org.utbot.framework | ||
|
||
import mu.KotlinLogging | ||
import org.utbot.common.PathUtil.toPath | ||
import java.io.IOException | ||
|
||
private val logger = KotlinLogging.logger {} | ||
|
||
private val defaultUserTrustedLibrariesPath: String = "${utbotHomePath}/trustedLibraries.txt" | ||
private const val userTrustedLibrariesKey: String = "utbot.settings.trusted.libraries.path" | ||
|
||
object TrustedLibraries { | ||
/** | ||
* Always "trust" JDK. | ||
*/ | ||
private val defaultTrustedLibraries: List<String> = listOf( | ||
"java", | ||
"sun", | ||
"javax", | ||
"com.sun", | ||
"org.omg", | ||
"org.xml", | ||
"org.w3c.dom", | ||
) | ||
|
||
private val userTrustedLibraries: List<String> | ||
get() { | ||
val userTrustedLibrariesPath = System.getProperty(userTrustedLibrariesKey) ?: defaultUserTrustedLibrariesPath | ||
val userTrustedLibrariesFile = userTrustedLibrariesPath.toPath().toFile() | ||
|
||
if (!userTrustedLibrariesFile.exists()) { | ||
return emptyList() | ||
} | ||
|
||
return try { | ||
userTrustedLibrariesFile.readLines() | ||
} catch (e: IOException) { | ||
logger.info { e.message } | ||
|
||
emptyList() | ||
} | ||
} | ||
|
||
/** | ||
* Represents prefixes of packages for trusted libraries - | ||
* as the union of [defaultTrustedLibraries] and [userTrustedLibraries]. | ||
*/ | ||
val trustedLibraries: Set<String> by lazy { (defaultTrustedLibraries + userTrustedLibraries).toSet() } | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
10 changes: 10 additions & 0 deletions
10
utbot-framework-api/src/main/kotlin/org/utbot/framework/plugin/api/util/ThrowableUtils.kt
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,10 @@ | ||
package org.utbot.framework.plugin.api.util | ||
|
||
val Throwable.description | ||
get() = message?.replace('\n', '\t') ?: "<Throwable with empty message>" | ||
|
||
val Throwable.isCheckedException | ||
get() = !(this is RuntimeException || this is Error) | ||
|
||
val Class<*>.isCheckedException | ||
get() = !(RuntimeException::class.java.isAssignableFrom(this) || Error::class.java.isAssignableFrom(this)) |
13 changes: 13 additions & 0 deletions
13
utbot-framework/src/main/java/org/utbot/engine/overrides/collections/AbstractCollection.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,13 @@ | ||
package org.utbot.engine.overrides.collections; | ||
|
||
import org.utbot.api.annotation.UtClassMock; | ||
|
||
import static org.utbot.api.mock.UtMock.makeSymbolic; | ||
|
||
@UtClassMock(target = java.util.AbstractCollection.class, internalUsage = true) | ||
public abstract class AbstractCollection<E> implements java.util.Collection<E> { | ||
@Override | ||
public String toString() { | ||
return makeSymbolic(); | ||
} | ||
} |
72 changes: 72 additions & 0 deletions
72
utbot-framework/src/main/java/org/utbot/engine/overrides/collections/List.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,72 @@ | ||
package org.utbot.engine.overrides.collections; | ||
|
||
import org.utbot.api.annotation.UtClassMock; | ||
|
||
import java.util.Collection; | ||
|
||
@UtClassMock(target = java.util.List.class, internalUsage = true) | ||
public interface List<E> extends java.util.List<E> { | ||
static <E> java.util.List<E> of() { | ||
return new UtArrayList<>(); | ||
} | ||
|
||
@SuppressWarnings("unchecked") | ||
static <E> java.util.List<E> of(E e1) { | ||
return new UtArrayList<>((E[]) new Object[]{e1}); | ||
} | ||
|
||
@SuppressWarnings("unchecked") | ||
static <E> java.util.List<E> of(E e1, E e2) { | ||
return new UtArrayList<>((E[]) new Object[]{e1, e2}); | ||
} | ||
|
||
@SuppressWarnings("unchecked") | ||
static <E> java.util.List<E> of(E e1, E e2, E e3) { | ||
return new UtArrayList<>((E[]) new Object[]{e1, e2, e3}); | ||
} | ||
|
||
@SuppressWarnings("unchecked") | ||
static <E> java.util.List<E> of(E e1, E e2, E e3, E e4) { | ||
return new UtArrayList<>((E[]) new Object[]{e1, e2, e3, e4}); | ||
} | ||
|
||
@SuppressWarnings("unchecked") | ||
static <E> java.util.List<E> of(E e1, E e2, E e3, E e4, E e5) { | ||
return new UtArrayList<>((E[]) new Object[]{e1, e2, e3, e4, e5}); | ||
} | ||
|
||
@SuppressWarnings("unchecked") | ||
static <E> java.util.List<E> of(E e1, E e2, E e3, E e4, E e5, E e6) { | ||
return new UtArrayList<>((E[]) new Object[]{e1, e2, e3, e4, e5, e6}); | ||
} | ||
|
||
@SuppressWarnings("unchecked") | ||
static <E> java.util.List<E> of(E e1, E e2, E e3, E e4, E e5, E e6, E e7) { | ||
return new UtArrayList<>((E[]) new Object[]{e1, e2, e3, e4, e5, e6, e7}); | ||
} | ||
|
||
@SuppressWarnings("unchecked") | ||
static <E> java.util.List<E> of(E e1, E e2, E e3, E e4, E e5, E e6, E e7, E e8) { | ||
return new UtArrayList<>((E[]) new Object[]{e1, e2, e3, e4, e5, e6, e7, e8}); | ||
} | ||
|
||
@SuppressWarnings("unchecked") | ||
static <E> java.util.List<E> of(E e1, E e2, E e3, E e4, E e5, E e6, E e7, E e8, E e9) { | ||
return new UtArrayList<>((E[]) new Object[]{e1, e2, e3, e4, e5, e6, e7, e8, e9}); | ||
} | ||
|
||
@SuppressWarnings("unchecked") | ||
static <E> java.util.List<E> of(E e1, E e2, E e3, E e4, E e5, E e6, E e7, E e8, E e9, E e10) { | ||
return new UtArrayList<>((E[]) new Object[]{e1, e2, e3, e4, e5, e6, e7, e8, e9, e10}); | ||
} | ||
|
||
@SafeVarargs | ||
@SuppressWarnings("varargs") | ||
static <E> java.util.List<E> of(E... elements) { | ||
return new UtArrayList<>(elements); | ||
} | ||
|
||
static <E> java.util.List<E> copyOf(Collection<? extends E> collection) { | ||
return new UtArrayList<>(collection); | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.