Debug Gradle plugins con IntelliJ

Problema

Quiero usar el depurador interactivo con IntelliJ. Desafortunadamente, no puedo convencer a IntelliJ para que cargue y compile el complemento. Sin embargo, puedo hacergradle clean build y el complemento construye y ejecuta sus pruebas como se espera.

Específicamente, estoy tratando de depurar cambios locales paragradle-js-plugin e IntelliJ dice que no puede encontrarcom.google.javascript.jscomp.CompilerOptions tanto comospock.lang.Specification. (Estoy pensando que tal vez sea algo sobre la forma en que están cargados, pero eso es una suposición).


Cosas que he probado

NOTA: No revertí ningún proceso entre pasos.

0. Mi primera conjetura

Me di cuentaun howto endocs.codehaus.org. IntelliJ no pudo encontrarorg.gradle.launcher.GradleMain, así que lo he adaptado para usarGradleLauncher con lo siguiente:

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"
        )
    }
}

PorDocumentación de GradleLauncher.

Salir: IntelliJ no compilará el proyecto.

1. PorLa respuesta de Peter Niederwieser. Corrige el proyecto de idea y depura a través de pluginPasos~# cd /path/to/gradle-js-plugin && gradle cleanIdea ideaAbrió el proyecto recién creado e intentó depurar usando el ScriptRunner desde el paso 0.

Salir: Proyecto compila (¡Hurra!), pero solo puedo llegar a puntos de interrupción enGradleScriptRunner.groovy.

2. PorLa respuesta de Peter Niederwieser. ejecutar gradle CLI w / opciones especiales

1 y 2. fusionados para mayor claridad:

~# 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
Configure IntelliJ para conectarse a este puerto e inicie la depuración (ver imagen):

Para este paso probé las siguientes configuraciones de archivos .gradle:

1. Utilice solo 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()
}

Salir:

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. Utilice tanto build.gradle como 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()
}

Salir:

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

Mi configuraciónGradle
~# 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
Java
~# 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)
IntelliJ
IntelliJ IDEA Ultimate 117.499 w/ Bundled Gradle plugin

Con la esperanza de

Cualquier consejo que me permita entrar en modo de depuración dentro del complemento.

Respuestas a la pregunta(3)

Su respuesta a la pregunta