Debuguj wtyczki Gradle za pomocą IntelliJ
Chcę używać interaktywnego debuggera z IntelliJ. Niestety, nie mogę przekonać IntelliJ do załadowania i skompilowania wtyczki. Jednak, mogę zrobićgradle clean build
wtyczka buduje i uruchamia testy zgodnie z oczekiwaniami.
W szczególności próbuję debugować zmiany lokalne naplugin gradle-js i IntelliJ mówi, że nie może znaleźćcom.google.javascript.jscomp.CompilerOptions
jak równieżspock.lang.Specification
. (Myślę, że może chodzi o sposób, w jaki są ładowane, ale zgaduję.)
UWAGA: Nie przywróciłem żadnych procesów między krokami.
0. Moje pierwsze domysłyZauważyłemhowto nadocs.codehaus.org. IntelliJ nie mógł znaleźćorg.gradle.launcher.GradleMain
, więc przystosowałem go do użyciaGradleLauncher
z następującymi:
import org.gradle.GradleLauncher
class GradleScriptRunner {
public static void main(String[] args) {
GradleLauncher.newInstance(
"-p",
"/path/to/gradle-js-plugin/src/test/resources/build.gradle",
"clean assemble"
)
}
}
ZaDokumentacja GradleLauncher.
Wynik: IntelliJ nie skompiluje projektu.
1. PerOdpowiedź Petera Niederwiesera Napraw projekt pomysłu i debuguj przez wtyczkęKroki~# cd /path/to/gradle-js-plugin && gradle cleanIdea idea
Otworzył nowo utworzony projekt i próbował debugować za pomocą ScriptRunner od kroku 0.Wynik: Kompiluje projekt (tak!), ale mogę tylko uderzyć w punkty przerwaniaGradleScriptRunner.groovy
.
1 i 2. Scalono dla jasności:
~# export GRADLE_OPTS="-Xdebug -Xrunjdwp:transport=dt_socket,server=y,suspend=y,address=5005"
~# gradle clean assemble
Listening for transport dt_socket at address: 5005
Skonfiguruj IntelliJ, aby połączyć się z tym portem i rozpocząć debugowanie (patrz obraz):W tym kroku próbowałem następujących konfiguracji plików .gradle:
1. Użyj tylko build.gradle
--build.gradle--
apply plugin: 'groovy'
apply plugin: 'java'
apply plugin: 'idea'
apply plugin: 'maven'
apply plugin: 'js'
buildscript {
repositories {
mavenLocal()
mavenCentral()
}
dependencies {
compile findProject "/path/to/gradle-js-plugin"
}
}
repositories {
mavenLocal()
mavenCentral()
}
Wynik:
FAILURE: Build failed with an exception.
* Where:
Build file '/path/to/gradle-js-plugin/src/test/resources/build.gradle' line: 13
* What went wrong:
A problem occurred evaluating root project 'resources'.
> No such property: findProject for class: org.gradle.api.internal.artifacts.dsl.dependencies.DefaultDependencyHandler
* Try:
Run with --stacktrace option to get the stack trace. Run with --info or --debug option to get more log output.
BUILD FAILED
Total time: 8 mins 50.498 secs
2. Użyj zarówno build.gradle, jak i settings.gradle
--settings.gradle--
include "/path/to/gradle-js-plugin"
--build.gradle--
apply plugin: 'groovy'
apply plugin: 'java'
apply plugin: 'idea'
apply plugin: 'maven'
apply plugin: 'js'
buildscript {
repositories {
mavenLocal()
mavenCentral()
}
}
repositories {
mavenLocal()
mavenCentral()
}
Wynik:
FAILURE: Build failed with an exception.
* Where:
Build file '/path/to/gradle-js-plugin/src/test/resources/build.gradle' line: 5
* What went wrong:
A problem occurred evaluating root project 'resources'.
> Plugin with id 'js' not found.
* Try:
Run with --stacktrace option to get the stack trace. Run with --info or --debug option to get more log output.
BUILD FAILED
Total time: 13.553 secs
Moja konfiguracjaGradle~# gradle -v
------------------------------------------------------------
Gradle 1.0
------------------------------------------------------------
Gradle build time: Tuesday, June 12, 2012 12:56:21 AM UTC
Groovy: 1.8.6
Ant: Apache Ant(TM) version 1.8.2 compiled on December 20 2010
Ivy: 2.2.0
JVM: 1.7.0_04 (Oracle Corporation 23.0-b21)
OS: Linux 3.2.0-2-amd64 amd64
Jawa~# java -version
java version "1.7.0_04"
Java(TM) SE Runtime Environment (build 1.7.0_04-b20)
Java HotSpot(TM) 64-Bit Server VM (build 23.0-b21, mixed mode)
IntelliJIntelliJ IDEA Ultimate 117.499 w/ Bundled Gradle plugin
Mieć nadzieję żeWszelkie wskazówki, które doprowadzą mnie do trybu debugowania w wtyczce.