Skip to content

Commit

Permalink
fix(build): fixed webpack config and circular-dependency-plugin config.
Browse files Browse the repository at this point in the history
  • Loading branch information
dsebastien committed Jun 2, 2018
1 parent 248374d commit 7813218
Show file tree
Hide file tree
Showing 8 changed files with 71 additions and 74 deletions.
17 changes: 10 additions & 7 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -38,7 +38,7 @@ Stark's reusable build integrates support for:
* [Tree shaking](https://webpack.js.org/guides/tree-shaking/) to automatically remove unused code from your production bundle
* [Hot Module Replacement](https://webpack.github.io/docs/hot-module-replacement-with-webpack.html) with [@angularclass/hmr](https://github.com/angularclass/angular-hmr) and [@angularclass/hmr-loader](https://github.com/angularclass/angular-hmr-loader)
* Minification & uglyfication
* Cache busting with [file hashes](https://www.npmjs.com/package/webpack-sha-hash)
* Cache busting with file hashes
* [Tests](https://angular.io/docs/ts/latest/guide/testing.html): [E2E](https://angular.github.io/protractor/#/faq#what-s-the-difference-between-karma-and-protractor-when-do-i-use-which-), [Karma](https://karma-runner.github.io/), [Protractor](https://angular.github.io/protractor/), [Jasmine](https://github.com/jasmine/jasmine), with source maps support, possibility to execute subsets of the tests, ...
* Tests code coverage with [Istanbul](https://github.com/gotwarlost/istanbul)
* Environments definition (development | production)
Expand All @@ -47,17 +47,20 @@ Stark's reusable build integrates support for:
* Local testing with fake back-ends using [json-server](https://github.com/typicode/json-server)
* Router visualization with [UI-Router Visualizer](https://github.com/ui-router/visualizer)

## Stark modules
TODO list stark modules and point to docs

## Developer guide
TODO add links to developer guide sections

### Releases
Stark releases are available on npm: https://www.npmjs.com/settings/nationalbankbelgium/packages

### Contributing
Please follow our [contribution guidelines](/CONTRIBUTING.md)
Please follow our [contribution guidelines](/CONTRIBUTING.md).

To know how to release Stark, refer to [this page](/RELEASE.md).

### Releasing Stark
See [this page](/RELEASE.md)
### Snapshot builds
Each and every day, a new snapshot of Stark is built, tested and published on npm: https://www.npmjs.com/settings/nationalbankbelgium/packages
See [this page](/SNAPSHOTS.md) for more information about the process behind this.

## Authors

Expand Down
6 changes: 6 additions & 0 deletions SNAPSHOTS.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
# Stark Snapshots
Daily snapshot builds are created and published by a Travis cron job.
This was introduced via [this issue](https://github.com/NationalBankBelgium/stark/issues/27).

For details, refer to `.travis.yml` and `release-publish.sh`

33 changes: 0 additions & 33 deletions packages/stark-build/config/nightly-build.js

This file was deleted.

23 changes: 9 additions & 14 deletions packages/stark-build/config/webpack.common.js
Original file line number Diff line number Diff line change
Expand Up @@ -13,12 +13,12 @@ const SplitChunksPlugin = require("webpack/lib/optimize/SplitChunksPlugin");
const CopyWebpackPlugin = require("copy-webpack-plugin");
const HtmlWebpackPlugin = require("html-webpack-plugin");
const BaseHrefWebpackPlugin = require("base-href-webpack-plugin").BaseHrefWebpackPlugin;
const HashedModuleIdsPlugin = require("webpack/lib/HashedModuleIdsPlugin");
// const InlineManifestWebpackPlugin = require("inline-manifest-webpack-plugin");
// const ScriptExtHtmlWebpackPlugin = require("script-ext-html-webpack-plugin");
const { AngularCompilerPlugin } = require("@ngtools/webpack");
const AngularNamedLazyChunksWebpackPlugin = require("angular-named-lazy-chunks-webpack-plugin");
const ContextReplacementPlugin = require("webpack/lib/ContextReplacementPlugin");
const CircularDependencyPlugin = require("circular-dependency-plugin");
const PurifyPlugin = require("@angular-devkit/build-optimizer").PurifyPlugin;

const buildUtils = require("./build-utils");
Expand All @@ -28,7 +28,7 @@ const buildUtils = require("./build-utils");
*
* See: http://webpack.github.io/docs/configuration.html#cli
*/
module.exports = function(options) {
module.exports = (options) => {
const isProd = options.ENV === "production";
const METADATA = Object.assign({}, buildUtils.DEFAULT_METADATA, options.metadata || {});
const supportES2015 = buildUtils.supportES2015(METADATA.tsConfigPath);
Expand Down Expand Up @@ -365,6 +365,13 @@ module.exports = function(options) {

new PurifyPlugin(),

new CircularDependencyPlugin({
// exclude detection of files based on a RegExp
exclude: /node_modules/,
// log warnings to webpack
failOnError: false
}),

/**
* Plugin: CommonsChunkPlugin
* Description: Shares common code between the pages.
Expand Down Expand Up @@ -457,18 +464,6 @@ module.exports = function(options) {
{}
),

/**
* Plugin: HashedModuleIdsPlugin
* Description: This plugin will cause hashes to be based on the relative path of the module,
* generating a four character string as the module id
* See: https://webpack.js.org/plugins/hashed-module-ids-plugin/
*/
new HashedModuleIdsPlugin({
hashFunction: "sha256",
hashDigest: "hex",
hashDigestLength: 20
}),

/**
* Plugin: ContextReplacementPlugin
* Description: allows to override the inferred information in a 'require' context
Expand Down
8 changes: 0 additions & 8 deletions packages/stark-build/config/webpack.dev.js
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,6 @@ const SourceMapDevToolPlugin = require("webpack/lib/SourceMapDevToolPlugin");

const WriteFilePlugin = require("write-file-webpack-plugin");
const StylelintPlugin = require("stylelint-webpack-plugin");
const CircularDependencyPlugin = require("circular-dependency-plugin");

// Dev custom config
const webpackCustomConfig = require(helpers.root("config/webpack-custom-config.dev.json"));
Expand Down Expand Up @@ -272,13 +271,6 @@ module.exports = function(env) {
files: ["src/**/*.?(pc|sc|c|sa)ss"] // pcss|scss|css|sass
}),

new CircularDependencyPlugin({
// exclude detection of files based on a RegExp
exclude: /node_modules/,
// log warnings to webpack
failOnError: false
}),

/**
* Plugin: WebpackMonitor
* Description: This plugins give us information about the bundle size
Expand Down
55 changes: 45 additions & 10 deletions packages/stark-build/config/webpack.prod.js
Original file line number Diff line number Diff line change
Expand Up @@ -21,6 +21,7 @@ const PurifyPlugin = require("@angular-devkit/build-optimizer").PurifyPlugin;
const MiniCssExtractPlugin = require("mini-css-extract-plugin");
const OptimizeCSSAssetsPlugin = require("optimize-css-assets-webpack-plugin");
const UglifyJsPlugin = require("uglifyjs-webpack-plugin");
const HashedModuleIdsPlugin = require("webpack/lib/HashedModuleIdsPlugin");

function getUglifyOptions(supportES2015) {
const uglifyCompressOptions = {
Expand Down Expand Up @@ -71,9 +72,20 @@ module.exports = function() {

mode: "production",

// reference: https://medium.com/webpack/webpack-4-mode-and-optimization-5423a6bc597a
optimization: {
removeAvailableModules: true,
removeEmptyChunks: true,
mergeDuplicateChunks: true,
flagIncludedChunks: true,
occurrenceOrder: true,
providedExports: true,
usedExports: true,
sideEffects: true,
concatenateModules: true,
minimizer: [
runtimeChunk: true,
noEmitOnErrors: true,
minimizer: [ // minimization libraries to use
/**
* Plugin: UglifyJsPlugin
* Description: Minimize all JavaScript output of chunks.
Expand All @@ -84,20 +96,36 @@ module.exports = function() {
* NOTE: To debug prod builds uncomment //debug lines and comment //prod lines
*/
new UglifyJsPlugin({
sourceMap: true,
sourceMap: true, // useful to still be able to debug in production
uglifyOptions: getUglifyOptions(supportES2015)
}),
// other options than Uglify: BabelifyMinifyWebpackPlugin or ClosureCompilerPlugin

new OptimizeCSSAssetsPlugin({})
],
cacheGroups: {
styles: {
name: "styles",
test: /\.css$/,
chunks: "all",
enforce: true
splitChunks: { // reference: https://webpack.js.org/plugins/split-chunks-plugin/
chunks: "all", // include all types of chunks (async or not)
cacheGroups: { // assign modules to cache groups
// cache group for all modules from node_modules that are duplicated in at least 2 chunks
vendors: {
test: /[\\/]node_modules[\\/]/,
name: "vendor",
chunks: "all",
priority: -10
},
styles: {
name: "styles",
test: /\.css$/,
chunks: "all",
enforce: true
},
default: {
minChunks: 2,
priority: -20,
reuseExistingChunk: true
}
}
}
},
},

/**
Expand Down Expand Up @@ -284,9 +312,16 @@ module.exports = function() {
new PurifyPlugin() /* buildOptimizer */,

/**
* Plugin: HashedModuleIdsPlugin
* Description: This plugin will cause hashes to be based on the relative path of the module,
* generating a four character string as the module id
* See: https://webpack.js.org/plugins/hashed-module-ids-plugin/
*/
new HashedModuleIdsPlugin()
new HashedModuleIdsPlugin({
hashFunction: "sha256",
hashDigest: "hex",
hashDigestLength: 20
}),
]
});
};
1 change: 0 additions & 1 deletion packages/stark-build/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -74,7 +74,6 @@
"webpack-dll-bundles-plugin": "1.0.0-beta.5",
"webpack-merge": "4.1.2",
"webpack-monitor": "1.0.14",
"webpack-sha-hash": "2.0.0",
"write-file-webpack-plugin": "4.3.1"
},
"devDependencies": {
Expand Down
2 changes: 1 addition & 1 deletion packages/stark-core/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@
"esm5": "./esm5/stark-core.js",
"esm2015": "./esm2015/stark-core.js",
"fesm5": "./fesm5/stark-core.js",
"fesm2015": "fesm2015/stark-core.js",
"fesm2015": "./fesm2015/stark-core.js",
"main": "bundles/stark-core.umd.js",
"types": "stark-core.d.ts",
"description": "Stark - Core",
Expand Down

0 comments on commit 7813218

Please sign in to comment.