Параметризованный вызов сборки 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/"
},
Вы можете настроить сценарий по своему усмотрению.