Bitbucket Angular npm运行构建失败

时间:2020-07-10 15:09:22

标签: angular bitbucket-pipelines ng-build npm-build

我正在尝试在Bitbucket上建立构建管道。我正在使用一个干净的新Angular项目。 到目前为止看起来像这样

- step:
    name: build frontend
    caches:
      - node
    condition:
      changesets:
        includePaths:
          - "frontend/src/deguvino-portal/**"
    image: node:14.5.0
    script:
      - npm install
      - npm install -g @angular/cli          
      - npm install -g npm@latest
      - npm install -g @angular-devkit/build-angular
      - npm run build --prod --prefix ./frontend/src/deguvino-portal/

并且在npm run build命令上不断失败并显示错误

An unhandled exception occurred: Cannot find module '@angular-devkit/build-angular/package.json'
Require stack:
- /usr/local/lib/node_modules/@angular/cli/node_modules/@angular-devkit/architect/node/node-modules-architect-host.js
- /usr/local/lib/node_modules/@angular/cli/node_modules/@angular-devkit/architect/node/index.js
- /usr/local/lib/node_modules/@angular/cli/models/architect-command.js
- /usr/local/lib/node_modules/@angular/cli/commands/build-impl.js
- /usr/local/lib/node_modules/@angular/cli/node_modules/@angular-devkit/schematics/tools/export-ref.js
- /usr/local/lib/node_modules/@angular/cli/node_modules/@angular-devkit/schematics/tools/index.js
- /usr/local/lib/node_modules/@angular/cli/utilities/json-schema.js
- /usr/local/lib/node_modules/@angular/cli/models/command-runner.js
- /usr/local/lib/node_modules/@angular/cli/lib/cli/index.js
- /usr/local/lib/node_modules/@angular/cli/lib/init.js
- /usr/local/lib/node_modules/@angular/cli/bin/ng
See "/tmp/ng-nTDaRU/angular-errors.log" for further details.
npm ERR! code ELIFECYCLE
npm ERR! syscall spawn
npm ERR! file sh
npm ERR! errno ENOENT
npm ERR! deguvino-portal@0.0.0 build: `ng build`
npm ERR! spawn ENOENT
npm ERR! 
npm ERR! Failed at the deguvino-portal@0.0.0 build script.
npm ERR! This is probably not a problem with npm. There is likely additional logging output above.
npm WARN Local package.json exists, but node_modules missing, did you mean to install?
npm ERR! A complete log of this run can be found in:
npm ERR!     /root/.npm/_logs/2020-07-10T14_51_37_386Z-debug.log

有关如何解决它的任何建议? 附言我使用的是npm run build而不是ng build,因为我的源代码不在根文件夹中,而是在frontend/src/deguvino-portal/目录下,并且确实找到了一种为{{1}指定目录的方法}。

1 个答案:

答案 0 :(得分:0)

我所要做的就是使用 - cd ./frontend/src/deguvino-portal 导航到根文件夹,进行安装和构建,然后返回。完整脚本:

 - step:
    name: build frontend
    caches:
      - node
    image: node:14.5.0
    script:        
      - cd ./frontend/src/deguvino-portal
      - npm install
      - npm run build-prod
      - apt-get update
      - apt-get install zip -y
      - cd ./dist/deguvino-portal
      - zip -r PublishOutputUI.zip .
      - pipe: microsoft/azure-web-apps-deploy:1.0.3
        variables:
         AZURE_APP_ID: $AZURE_APP_ID
         AZURE_PASSWORD: $AZURE_PASSWORD
         AZURE_TENANT_ID: $AZURE_TENANT_ID
         AZURE_RESOURCE_GROUP: '****'
         AZURE_APP_NAME: '*****'
         ZIP_FILE: 'PublishOutputUI.zip'
    artifacts: 
      - PublishOutputUI.zip