Параметризованный вызов сборки Angular CLI от Maven (плагин Eirslett)

Я создаю веб-приложение на Java, которое упаковывает статические ресурсы WAR. Эти статические ресурсы создаются через Angular-CLI.

Сборка Maven запускает сборку NG через Eirslett's maven-frontend-plugin, со сценариями npm и mojo npm.

Проблема в том, что я хотел бы использовать кастом base href в зависимости от параметров сборки Maven, и мне не удалось передать его в ng, ни по переменным окружения, ни по параметрам.

Может кто-нибудь сказать мне, как передать параметры для сборки нг из Maven?

Код:

pom.xml

                 <plugin>
                    <groupId>com.github.eirslett</groupId>
                    <artifactId>frontend-maven-plugin</artifactId>
                    <executions>
                        <execution>
                            <id>node install</id>
                            <phase>generate-resources</phase>
                            <goals>
                                <goal>install-node-and-npm</goal>
                            </goals>
                        </execution>
                        <execution>
                            <id>npm install</id>
                            <phase>generate-resources</phase>
                            <goals>
                                <goal>npm</goal>
                            </goals>
                            <configuration>
                                <arguments>--registry=${npm.internal.registry} --userconfig ${basedir}/.jenkins-npmrc install</arguments>
                            </configuration>
                        </execution>
                        <execution>
                            <id>npm build</id>
                            <phase>prepare-package</phase>
                            <goals>
                                <goal>npm</goal>
                            </goals>
                            <configuration>
                                <arguments>--userconfig ${basedir}/.jenkins-npmrc run-script build</arguments>
                                <environmentVariables>
                                    <test>this-does-not-work</test>
                                </environmentVariables>
                            </configuration>
                        </execution>
                        <execution>
                            <id>npm test</id>
                            <phase>test</phase>
                            <goals>
                                <goal>npm</goal>
                            </goals>
                            <configuration>
                                <arguments>run-script test</arguments>
                            </configuration>
                        </execution>
                    </executions>
                    <configuration>
                        <nodeVersion>v8.6.0</nodeVersion>
                        <npmVersion>5.3.0</npmVersion>
                        <installDirectory>.</installDirectory>
                        <nodeDownloadRoot>${node.internal.repo}</nodeDownloadRoot>
                        <npmDownloadRoot>${npm.internal.registry}/npm/-/</npmDownloadRoot>
                        <installDirectory>.</installDirectory>
                        <workingDirectory>.</workingDirectory>
                    </configuration>
                </plugin>

package.json

"scripts": {
    (...)
    "build": "ng build --prod --env=prod --bh=process.env.test --base-href=process.env.test",
    (...)
  }

2 ответа

Я решаю аналогичную проблему, имея в (предполагает регулярный Angle-Cli build вход в package.json):

pom.xml

...
<execution>
  <id>build</id>
  <goals>
    <goal>npm</goal>
  </goals>
  <configuration>
    <arguments>run build -- --base-href ${context.root}/</arguments>
  </configuration>
</execution>
...

Вы можете контролировать <context.root> свойство через профили Maven и имеющее значение по умолчанию в родительском модуле Maven <properties> раздел.

Мне нужно было передать версию проекта Maven моему сценарию NPM, и нижеприведенное сработало для меня с exec-maven-plugin:

pom.xml

<execution>
    <id>my-npm-build</id>
    <goals>
        <goal>exec</goal>
    </goals>
    <phase>compile</phase>
    <configuration>
        <executable>npm</executable>
        <arguments>
            <argument>run</argument>
            <argument>my-npm-script</argument>
        </arguments>
        <environmentVariables>
            <mvn_prj_vrsn>${project.version}</mvn_prj_vrsn>
        </environmentVariables>
    </configuration>
</execution>

И в package.json

"scripts": {
    "my-npm-script": "echo %mvn_prj_vrsn% &&[my other commands]
}

Выше было для окон, в случае использования Linux

$mvn_prj_vrsn

Это решение сработало для меня: на моем pom.xml: я вызываю свой скрипт run build:prod

    <plugin>
        <groupId>com.github.eirslett</groupId>
        <artifactId>frontend-maven-plugin</artifactId>
        <version>1.7.5</version>

        <configuration>
            <nodeVersion>v11.8.0</nodeVersion>
            <npmVersion>6.5.0</npmVersion>
            <workingDirectory>src/main/webapp</workingDirectory>
        </configuration>

        <executions>
            <execution>
                <id>install node and npm</id>
                <goals>
                    <goal>install-node-and-npm</goal>
                </goals>
            </execution>
            <execution>
                <id>npm install</id>
                <goals>
                    <goal>npm</goal>
                </goals>
            </execution>
            <execution>
                <id>npm run build</id>
                <goals>
                    <goal>npm</goal>
                </goals>
                <phase>generate-resources</phase>
                <configuration>
                        <arguments>run build:prod</arguments>
                </configuration>
            </execution>

        </executions>
    </plugin>

В моем приложении angular ( packaga.json):

"scripts": {
    "ng": "ng",
    "start": "ng serve",
    "build": "ng build",
    "test": "ng test",
    "lint": "ng lint",
    "e2e": "ng e2e",
    "build:prod": "ng build --prod --build-optimizer --base-href /myBaseUrl/"
}, 

Вы можете настроить сценарий по своему усмотрению.

Другие вопросы по тегам