Сбой сборки 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, но ничего не получалось... Пожалуйста, помогите!!! Заранее спасибо!!! Не стесняйтесь комментировать любую другую информацию.!!!