Есть ли способ установить зависимости maven до того, как maven попытается их разрешить? - PullRequest
18 голосов
/ 10 мая 2011

Мне нужно распаковать некоторые зависимости из удаленного местоположения и установить их локально.

Я успешно получил их (с помощью плагина antrun) и установил их (с помощью плагина установки)

Однако, если я определю их как зависимости (<dependency>..</dependency>), maven сначала попытается разрешить их, и только затем, если это удастся, перейдет к antrun и установит.

Я также попробовал плагин build-helper-plugin и его атрибут attach-, но он ничего не делает (он даже не добавляет артефакты в окончательный файл войны)

Итак, как запустить мои исполнения до того, как maven попытается разрешить зависимости?

Ответы [ 4 ]

7 голосов
/ 10 мая 2011

Интересный вопрос!Одна из попыток (может быть) добиться этого - использовать установку Multi Module Project.

Выбрать и установить ваши зависимости в родительском проекте и использовать их в дочернем модуле.Я проверил свое предположение следующим образом:

Parent pom.xml

<project
    xmlns="http://maven.apache.org/POM/4.0.0"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <groupId>foo.bar</groupId>
    <artifactId>foo.bar.parent</artifactId>
    <version>1.0.0</version>
    <packaging>pom</packaging>

    <modules>
        <module>foo.bar.child</module>
    </modules>

    <build>
        <plugins>
            <plugin>
                <artifactId>maven-antrun-plugin</artifactId>
                <version>1.6</version>
                <executions>
                    <execution>
                        <phase>validate</phase>
                        <configuration>
                            <target>
                                <echo
                                    message="Hello world!" />
                            </target>
                        </configuration>
                        <goals>
                            <goal>run</goal>
                        </goals>
                    </execution>
                </executions>
            </plugin>
        </plugins>
    </build>

</project>

Модуль pom.xml

<project
    xmlns="http://maven.apache.org/POM/4.0.0"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <groupId>foo.bar</groupId>
    <artifactId>foo.bar.child</artifactId>
    <version>1.0.0</version>

    <parent>
        <groupId>foo.bar</groupId>
        <artifactId>foo.bar.parent</artifactId>
        <version>1.0.0</version>
    </parent>

    <dependencies>
        <dependency>
            <artifactId>can.not</artifactId>
            <groupId>find.me</groupId>
            <version>0.0.0</version>
        </dependency>
    </dependencies>

</project>

Я получаю вывод " Hello World " из родительской сборки pom до того, как сборка дочернего модуля завершится неудачей (из-за отсутствия зависимости).Если вы добились предоставления зависимости в сборке parent.pom, проект дочернего модуля должен быть компилируемым.

1 голос
/ 11 мая 2011

Я закончил делать это в два этапа:

  • настроить antrun и установить выполнение для запуска на clean
  • , когда выбран package, сборка не удаласьесли он не был очищен хотя бы один раз

Однако решение представляет собой небольшую сложность.

1 голос
/ 10 мая 2011

вы должны посмотреть на запуск Artifact Repository Manager, такого как Archiva, затем вы можете просто загрузить их туда, и в вашем файле ~/.m2/settings.xml добавить сервер Archiva, и вам не нужно беспокоиться о локальной установке вручную, то есть при условии, что артефакты еще не находятся в удаленном хранилище. Если ваше «удаленное местоположение» является репозиторием Maven, Archiva также может прозрачно использовать прокси.

0 голосов
/ 23 сентября 2013

Вы можете попробовать область действия system в зависимости и добавить systemPath:

<dependency>
    <groupId>junit</groupId>
    <artifactId>junit</artifactId>
    <version>4.0</version>
    <scope>system</scope>
    <systemPath>${project.basedir}/lib/myhackedjunit-4.0.jar</systemPath>
</dependency>

Область действия system аналогична provided, за исключением того, что вы должны предоставить JAR, который содержит ее явно. Артефакт всегда доступен и не просматривается в хранилище.

systemPath используется только в том случае, если область зависимостей является системной. Путь должен быть абсолютным. Поскольку предполагается, что зависимости системной области установлены ранее, Maven не будет проверять репозитории для проекта, а вместо этого проверяет, существует ли файл.

...