Сбой сборки Heroku после настройки скрипта postinstall

Что ж, я работаю над запросом на извлечение проекта Heroku. У меня возникла следующая проблема:

-----> Удаление 1 файлов, соответствующих шаблонам.slugignore. -----> Обнаружено приложение Node.js -----> Создание среды выполнения

   NPM_CONFIG_LOGLEVEL=error
   NPM_CONFIG_PRODUCTION=false
   NODE_VERBOSE=false
   NODE_ENV=production
   NODE_MODULES_CACHE=true

-----> Установка двоичных файлов engine.node (package.json): 9.3.0 engine.npm (package.json): 5.5.1

   Resolving node version 9.3.0...
   Downloading and installing node 9.3.0...
   npm 5.5.1 already installed with node

-----> Восстановление кеша Загрузка 2 из cacheDirectories (по умолчанию): - node_modules - bower_components (не кешируется - пропуск) -----> Построение зависимостей Установка узловых модулей (package.json) uglifyjs-webpack-plugin@0.4.6 постустановочных / TMP /build_0205c32fc162b04a5bd36ce6d3e2a31a/GithubUsername-PROJNAME-45f1019/node_modules/ WebPack узел Библиотека /node_modules/uglifyjs-WebPack-плагин /post_install.js projName@0.3.0 постустановочных / TMP /build_0205c32fc162b04a5bd36ce6d3e2a31a/GithubUserName-PROJNAME-45f1019 WebPack -p - -config./webpack.config.js --progress

  90% chunk assets pro       Version: webpack 3.10.0
   Time: 25301ms
   Asset       Size  Chunks                    Chunk Names
  ///All chunk files emitted details
   projname.js    1.27 MB       0  [emitted]  [big]  main
   favicon.ico      17 kB          [emitted]
   index.html    37.4 kB          [emitted]
   [14] ./src/script.js 3.92 kB {0} [built]
   //built details
   + 208 hidden modules

   ERROR in ./src/assetLoader.js
   Module not found: Error: Can't resolve './manifest' in '/tmp/build_0205c32fc162b04a5bd36ce6d3e2a31a/GithubUsername-projName-45f1019/src'
   @ ./src/assetLoader.js 1:0-34
   @ ./src/game.js
   @ ./src/script.js

   ERROR in proj.js from UglifyJs
   Unexpected token: name (Creature) [GithubUsername-projName.js:1,99245]
   Child html-webpack-plugin for "index.html":
   Asset     Size  Chunks                    Chunk Names

   [2] ./node_modules/html-webpack-plugin/lib/loader.js!./src/index.html 

[встроенный] [4] (веб-пакет)/buildin/global.js 509 байт {0} [встроенный] [5] (веб-пакет)/buildin/module.js 517 байт {0} [встроенный] [6] ./assets/interface/AB.gif 82 байта {0} [встроенный] [7] ./assets/interface/ProjPage.png 82 байта {0} [встроенный] npm ERR! код ELIFECYCLE npm ERR! errno 2 npm ERR! projName@0.3.0 postinstall: webpack -p --config ./webpack.config.js --progress нпм ERR! Статус выхода 2 npm ERR! нпм ERR! Не удалось выполнить сценарий postinstall projName@0.3.0. нпм ERR! Это, вероятно, не проблема с npm. Вероятно, есть дополнительные выходные данные регистрации.

   npm ERR! A complete log of this run can be found in:
   npm ERR!     /app/.npm/_logs/2018-01-03T13_35_09_304Z-debug.log

-----> Сборка не удалась

   We're sorry this build is failing! You can troubleshoot common issues here:
   https://devcenter.heroku.com/articles/troubleshooting-node-deploys

   If you're stuck, please submit a ticket so we can help:
   https://help.heroku.com/

   Love,
   Heroku
     !     Push rejected, failed to compile Node.js app.  !     Push failed

вот код для:

фрагмент package.json

{
    "dependencies": {
        "compression": "^1.6.2",
        "express": "^4.13.4",
        "html-webpack-plugin": "^2.30.1",
        "jquery": "1.12.4",
        "jquery-mousewheel": "3.1.13",
        "jquery-ui": "^1.12.1",
        "jquery.kinetic": "2.2.4",
        "jquery.transit": "0.9.12",
        "phaser-ce": "2.7.10",
        "socket.io": "^1.3.5",
        "socket.io-client": "1.3.5"
    },
    "devDependencies": {
        "css-loader": "^0.28.7",
        "eslint": "^4.12.1",
        "expose-loader": "^0.7.4",
        "extract-text-webpack-plugin": "^3.0.2",
        "file-loader": "^1.1.5",
        "less": "^2.7.3",
        "less-loader": "^4.0.5",
        "prettier": "^1.8.2",
        "style-loader": "^0.19.0",
        "uglifyjs-webpack-plugin": "^1.1.2",
        "webpack": "^3.8.1",
        "webpack-merge": "^4.1.1"
    },

    "scripts": {
        "start": "node server.js",
        "postinstall": "webpack -p --config ./webpack.config.js --progress",
        "build": "yarn run generateManifest && webpack --env.production",
        "build:dev": "yarn run generateManifest && webpack",
        "dev": "webpack --watch",
        "lint": "eslint src/**/*.js",
        "generateManifest": "node manifestGenerator.js"
    }
}

Server.js

// Setup basic express server
var compression = require('compression');
var express = require('express');
var app = express();
var server = require('http').createServer(app);
var io = require('socket.io')(server);
var port = process.env.PORT || 8080;
var ip = process.env.IP || '127.0.0.1';
var gameManager = require('./server/gamemanager.js');
var qManager = require('./server/queuemanager.js');

// Setup the game queue and connection details
io.on('connection', function(session) {
    console.log('a user connected');

    // Store the username in the socket session for this client
    var username = makeid();
    session.username = username;

    // Add user to the queue
    qManager.addToQueue(session);

    session.on('disconnect', function() {
        console.log('user disconnected');
        qManager.removeFromQueue(session);
    });

    // Send user the username
    session.emit('login', session.username);

});


// Listen for server, and use static routing for deploy directory
server.listen(port, function() {
    console.log('Server listening at port %d', port);
});

app.use(express.static('./deploy', {
    maxAge: 86400000
}));

код webpack.config.js

 const path = require('path');
const webpack = require('webpack');
const merge = require('webpack-merge');
const HtmlWebpackPlugin = require('html-webpack-plugin');
const UglifyJSPlugin = require('uglifyjs-webpack-plugin');

// Are we in production
const production = process.env.production;

const baseSettings = {
    entry: path.resolve(__dirname, 'src', 'script.js'),
    output: {
        path: path.resolve(__dirname, 'deploy/'),
        filename: 'projname.js'
    },
    module: {
        rules: [
            {
                test: /\.less$/,
                use: [
                    'style-loader',
                    'css-loader',
                    'less-loader',
                ]
            },
            {
                test: /\.css$/,
                use: [
                    'style-loader',
                    'css-loader',
                ]
            },
            {
                test: /\.(png|jpg|gif|svg|ogg|ico|cur|woff|woff2)$/,
                use: [
                    'file-loader'
                ]
            }
        ]
    },
    resolve: {
        alias: {
            assets: path.resolve(__dirname, 'assets/'),
            modules: path.join(__dirname, "node_modules")
        }
    },
    plugins: [
        new HtmlWebpackPlugin({
            template: path.resolve(__dirname, 'src', 'index.html'),
            favicon: path.resolve(__dirname, 'assets', 'favicon.ico')
        }),
    ]
}

const prodSettings = {
    plugins: [
        new UglifyJSPlugin(),
        new webpack.DefinePlugin({
            'process.env.NODE_ENV': JSON.stringify('production')
        })
    ]
}

const devSettings = {
    devtool: 'cheap-module-eval-source-map'
}

// Create either a production or development build depending on the `production` env setting
module.exports = merge(baseSettings, production ? devSettings : prodSettings);

Я не могу понять, в чем проблема с веб-пакетом, что-то не так с моим сценарием postinstall? Я пропускаю какие-либо правила при настройке скрипта?

Я пытался применить некоторые решения из документации SO и Heroku, но ничего не получалось... Пожалуйста, помогите!!! Заранее спасибо!!! Не стесняйтесь комментировать любую другую информацию.!!!

0 ответов

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