Fixed descriptions and quick fix texts. Fixed highlighting of found problems and also 'Run inspection by Name' returning nothing.
This commit is contained in:
parent
78ad242b43
commit
5d91eaf276
@ -5,7 +5,7 @@ plugins {
|
|||||||
}
|
}
|
||||||
|
|
||||||
group 'de.platon42'
|
group 'de.platon42'
|
||||||
version '0.1'
|
version '0.2'
|
||||||
|
|
||||||
repositories {
|
repositories {
|
||||||
mavenCentral()
|
mavenCentral()
|
||||||
@ -40,7 +40,12 @@ intellij {
|
|||||||
|
|
||||||
patchPluginXml {
|
patchPluginXml {
|
||||||
changeNotes """
|
changeNotes """
|
||||||
<h2>V0.1 (31-Mar-19)
|
<h4>V0.2 (01-Apr-19)</h4>
|
||||||
|
<ul>
|
||||||
|
<li>Fixed descriptions and quick fix texts.
|
||||||
|
<li>Fixed highlighting of found problems and also 'Run inspection by Name' returning nothing.
|
||||||
|
</ul>
|
||||||
|
<h4>V0.1 (31-Mar-19)</h4>
|
||||||
<ul>
|
<ul>
|
||||||
<li>Initial release.
|
<li>Initial release.
|
||||||
</ul>
|
</ul>
|
||||||
|
@ -1,9 +1,7 @@
|
|||||||
package de.platon42.intellij.plugins.cajon.inspections
|
package de.platon42.intellij.plugins.cajon.inspections
|
||||||
|
|
||||||
import com.intellij.codeInspection.AbstractBaseJavaLocalInspectionTool
|
import com.intellij.codeInspection.AbstractBaseJavaLocalInspectionTool
|
||||||
import com.intellij.codeInspection.ProblemHighlightType
|
|
||||||
import com.intellij.codeInspection.ProblemsHolder
|
import com.intellij.codeInspection.ProblemsHolder
|
||||||
import com.intellij.openapi.util.TextRange
|
|
||||||
import com.intellij.psi.CommonClassNames
|
import com.intellij.psi.CommonClassNames
|
||||||
import com.intellij.psi.JavaPsiFacade
|
import com.intellij.psi.JavaPsiFacade
|
||||||
import com.intellij.psi.PsiCapturedWildcardType
|
import com.intellij.psi.PsiCapturedWildcardType
|
||||||
@ -125,8 +123,6 @@ open class AbstractAssertJInspection : AbstractBaseJavaLocalInspectionTool() {
|
|||||||
holder.registerProblem(
|
holder.registerProblem(
|
||||||
expression,
|
expression,
|
||||||
message,
|
message,
|
||||||
ProblemHighlightType.INFORMATION,
|
|
||||||
null as TextRange?,
|
|
||||||
ReplaceSimpleMethodCallQuickFix(description, replacementMethod)
|
ReplaceSimpleMethodCallQuickFix(description, replacementMethod)
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
@ -40,5 +40,4 @@ open class AbstractJUnitAssertInspection : AbstractBaseJavaLocalInspectionTool()
|
|||||||
|
|
||||||
protected fun getOriginalMethodName(expression: PsiMethodCallExpression) =
|
protected fun getOriginalMethodName(expression: PsiMethodCallExpression) =
|
||||||
expression.resolveMethod()?.name?.plus("()")
|
expression.resolveMethod()?.name?.plus("()")
|
||||||
|
|
||||||
}
|
}
|
@ -1,8 +1,6 @@
|
|||||||
package de.platon42.intellij.plugins.cajon.inspections
|
package de.platon42.intellij.plugins.cajon.inspections
|
||||||
|
|
||||||
import com.intellij.codeInspection.ProblemHighlightType
|
|
||||||
import com.intellij.codeInspection.ProblemsHolder
|
import com.intellij.codeInspection.ProblemsHolder
|
||||||
import com.intellij.openapi.util.TextRange
|
|
||||||
import com.intellij.psi.*
|
import com.intellij.psi.*
|
||||||
import com.intellij.psi.util.PsiTreeUtil
|
import com.intellij.psi.util.PsiTreeUtil
|
||||||
import de.platon42.intellij.plugins.cajon.quickfixes.ReplaceSizeMethodCallQuickFix
|
import de.platon42.intellij.plugins.cajon.quickfixes.ReplaceSizeMethodCallQuickFix
|
||||||
@ -11,7 +9,7 @@ class AssertThatSizeInspection : AbstractAssertJInspection() {
|
|||||||
|
|
||||||
companion object {
|
companion object {
|
||||||
private const val DISPLAY_NAME = "Asserting the size of an collection or array"
|
private const val DISPLAY_NAME = "Asserting the size of an collection or array"
|
||||||
private const val CONCISER_MESSAGE_TEMPLATE = "%s would be conciser than %s"
|
private const val MORE_CONCISE_MESSAGE_TEMPLATE = "%s would be more concise than %s"
|
||||||
}
|
}
|
||||||
|
|
||||||
override fun getDisplayName() = DISPLAY_NAME
|
override fun getDisplayName() = DISPLAY_NAME
|
||||||
@ -31,28 +29,28 @@ class AssertThatSizeInspection : AbstractAssertJInspection() {
|
|||||||
val constValue = calculateConstantParameterValue(expectedCallExpression, 0)
|
val constValue = calculateConstantParameterValue(expectedCallExpression, 0)
|
||||||
if (IS_EQUAL_TO_INT.test(expectedCallExpression)) {
|
if (IS_EQUAL_TO_INT.test(expectedCallExpression)) {
|
||||||
if (constValue == 0) {
|
if (constValue == 0) {
|
||||||
registerSizeMethod(holder, expression, "isEmpty()", noExpectedExpression = true)
|
registerSizeMethod(holder, expression, expectedCallExpression, "isEmpty()", noExpectedExpression = true)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
val equalToExpression = expectedCallExpression.argumentList.expressions[0]
|
val equalToExpression = expectedCallExpression.argumentList.expressions[0]
|
||||||
if (isCollectionSize(equalToExpression) || isArrayLength(equalToExpression)) {
|
if (isCollectionSize(equalToExpression) || isArrayLength(equalToExpression)) {
|
||||||
registerSizeMethod(holder, expression, "hasSameSizeAs()", expectedIsCollection = true)
|
registerSizeMethod(holder, expression, expectedCallExpression, "hasSameSizeAs()", expectedIsCollection = true)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
registerSizeMethod(holder, expression, "hasSize()")
|
registerSizeMethod(holder, expression, expectedCallExpression, "hasSize()")
|
||||||
} else {
|
} else {
|
||||||
if ((IS_LESS_THAN_OR_EQUAL_TO_INT.test(expectedCallExpression) && (constValue == 0))
|
if ((IS_LESS_THAN_OR_EQUAL_TO_INT.test(expectedCallExpression) && (constValue == 0))
|
||||||
|| (IS_LESS_THAN_INT.test(expectedCallExpression) && (constValue == 1))
|
|| (IS_LESS_THAN_INT.test(expectedCallExpression) && (constValue == 1))
|
||||||
|| IS_ZERO.test(expectedCallExpression)
|
|| IS_ZERO.test(expectedCallExpression)
|
||||||
) {
|
) {
|
||||||
registerSizeMethod(holder, expression, "isEmpty()", noExpectedExpression = true)
|
registerSizeMethod(holder, expression, expectedCallExpression, "isEmpty()", noExpectedExpression = true)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
if ((IS_GREATER_THAN_INT.test(expectedCallExpression) && (constValue == 0))
|
if ((IS_GREATER_THAN_INT.test(expectedCallExpression) && (constValue == 0))
|
||||||
|| (IS_GREATER_THAN_OR_EQUAL_TO_INT.test(expectedCallExpression) && (constValue == 1))
|
|| (IS_GREATER_THAN_OR_EQUAL_TO_INT.test(expectedCallExpression) && (constValue == 1))
|
||||||
|| IS_NOT_ZERO.test(expectedCallExpression)
|
|| IS_NOT_ZERO.test(expectedCallExpression)
|
||||||
) {
|
) {
|
||||||
registerSizeMethod(holder, expression, "isNotEmpty()", noExpectedExpression = true)
|
registerSizeMethod(holder, expression, expectedCallExpression, "isNotEmpty()", noExpectedExpression = true)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -70,18 +68,17 @@ class AssertThatSizeInspection : AbstractAssertJInspection() {
|
|||||||
private fun registerSizeMethod(
|
private fun registerSizeMethod(
|
||||||
holder: ProblemsHolder,
|
holder: ProblemsHolder,
|
||||||
expression: PsiMethodCallExpression,
|
expression: PsiMethodCallExpression,
|
||||||
|
expectedCallExpression: PsiMethodCallExpression,
|
||||||
replacementMethod: String,
|
replacementMethod: String,
|
||||||
noExpectedExpression: Boolean = false,
|
noExpectedExpression: Boolean = false,
|
||||||
expectedIsCollection: Boolean = false
|
expectedIsCollection: Boolean = false
|
||||||
) {
|
) {
|
||||||
val originalMethod = getOriginalMethodName(expression) ?: return
|
val originalMethod = getOriginalMethodName(expectedCallExpression) ?: return
|
||||||
val description = REPLACE_DESCRIPTION_TEMPLATE.format(replacementMethod, originalMethod)
|
val description = REPLACE_DESCRIPTION_TEMPLATE.format(originalMethod, replacementMethod)
|
||||||
val message = CONCISER_MESSAGE_TEMPLATE.format(originalMethod, replacementMethod)
|
val message = MORE_CONCISE_MESSAGE_TEMPLATE.format(replacementMethod, originalMethod)
|
||||||
holder.registerProblem(
|
holder.registerProblem(
|
||||||
expression,
|
expression,
|
||||||
message,
|
message,
|
||||||
ProblemHighlightType.INFORMATION,
|
|
||||||
null as TextRange?,
|
|
||||||
ReplaceSizeMethodCallQuickFix(description, replacementMethod, noExpectedExpression, expectedIsCollection)
|
ReplaceSizeMethodCallQuickFix(description, replacementMethod, noExpectedExpression, expectedIsCollection)
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user