build: Initial linting setup (#1560)

* sets up linting config and runs `yarn lint --fix` once, so that all changes will show up correctly in future PRs.

* Note that there are still a lot of linter errors.
This commit is contained in:
Nathan Nichols
2021-08-26 21:22:40 -05:00
committed by Mayukha Vadari
parent 12cfed5c17
commit 8b95ee5fab
286 changed files with 15508 additions and 12691 deletions

View File

@@ -1,58 +1,66 @@
'use strict';
const path = require('path');
const webpack = require('webpack');
const assert = require('assert');
const {BundleAnalyzerPlugin} = require('webpack-bundle-analyzer');
'use strict'
const path = require('path')
const webpack = require('webpack')
const assert = require('assert')
const {BundleAnalyzerPlugin} = require('webpack-bundle-analyzer')
function getDefaultConfiguration() {
return {
cache: true,
performance: { hints: false },
stats: 'errors-only',
entry: './dist/npm/index.js',
output: {
library: 'ripple',
path: path.join(__dirname, 'build/'),
filename: `ripple-lib.default.js`,
},
plugins: [
new webpack.NormalModuleReplacementPlugin(/^ws$/, './wsWrapper'),
new webpack.NormalModuleReplacementPlugin(/^\.\/wallet$/, './wallet-web'),
new webpack.NormalModuleReplacementPlugin(/^.*setup-api$/, './setup-api-web'),
new webpack.ProvidePlugin({ process: 'process/browser' }),
new webpack.ProvidePlugin({ Buffer: ['buffer', 'Buffer'] })
],
module: {
rules: []
},
resolve: {
extensions: ['.js', '.json'],
fallback: {
"buffer": require.resolve("buffer/"),
"assert": require.resolve("assert/"),
"url": require.resolve("url/"),
"stream": require.resolve("stream-browserify"),
"crypto": require.resolve("crypto-browserify"),
"https": require.resolve("https-browserify"),
"http": require.resolve('stream-http')
cache: true,
performance: {hints: false},
stats: 'errors-only',
entry: './dist/npm/index.js',
output: {
library: 'ripple',
path: path.join(__dirname, 'build/'),
filename: `ripple-lib.default.js`
},
plugins: [
new webpack.NormalModuleReplacementPlugin(/^ws$/, './wsWrapper'),
new webpack.NormalModuleReplacementPlugin(/^\.\/wallet$/, './wallet-web'),
new webpack.NormalModuleReplacementPlugin(
/^.*setup-api$/,
'./setup-api-web'
),
new webpack.ProvidePlugin({process: 'process/browser'}),
new webpack.ProvidePlugin({Buffer: ['buffer', 'Buffer']})
],
module: {
rules: []
},
resolve: {
alias: {
'ws': './dist/npm/client/wsWrapper.js',
'https-proxy-agent': false
},
extensions: ['.js', '.json'],
fallback: {
buffer: require.resolve('buffer/'),
assert: require.resolve('assert/'),
url: require.resolve('url/'),
stream: require.resolve('stream-browserify'),
crypto: require.resolve('crypto-browserify'),
https: require.resolve('https-browserify'),
http: require.resolve('stream-http')
}
}
},
};
}
}
function webpackForTest(testFileName) {
const match = testFileName.match(/\/?([^\/]*).ts$/);
const match = testFileName.match(/\/?([^\/]*).ts$/)
if (!match) {
assert(false, 'wrong filename:' + testFileName);
assert(false, 'wrong filename:' + testFileName)
}
const test = {
cache: true,
externals: [{
'lodash': '_',
'xrpl-local': 'ripple',
'net': 'null'
}],
externals: [
{
'xrpl-local': 'ripple',
'net': 'null'
}
],
entry: testFileName,
output: {
library: match[1].replace(/-/g, '_'),
@@ -60,64 +68,72 @@ function webpackForTest(testFileName) {
filename: match[1] + '.js'
},
plugins: [
new webpack.ProvidePlugin({ process: 'process/browser' }),
new webpack.ProvidePlugin({ Buffer: ['buffer', 'Buffer'] })
new webpack.ProvidePlugin({process: 'process/browser'}),
new webpack.ProvidePlugin({Buffer: ['buffer', 'Buffer']})
],
module: {
rules: [{
test: /jayson/,
use: 'null',
}, {
test: /\.ts$/,
use: [{
loader: 'ts-loader',
options: {
compilerOptions: {
composite: false,
declaration: false,
declarationMap: false
rules: [
{
test: /jayson/,
use: 'null'
},
{
test: /\.ts$/,
use: [
{
loader: 'ts-loader',
options: {
compilerOptions: {
composite: false,
declaration: false,
declarationMap: false
}
}
}
},
}],
}]
]
}
]
},
node: {
global: true,
__filename: false,
__dirname: true,
__dirname: true
},
resolve: {
extensions: [ '.ts', '.js', '.json' ],
fallback: {
"buffer": require.resolve("buffer/"),
"assert": require.resolve("assert/"),
"url": require.resolve("url/"),
"stream": require.resolve("stream-browserify"),
"crypto": require.resolve("crypto-browserify"),
"path": require.resolve("path-browserify"),
"http": require.resolve("stream-http"),
"fs": false
alias: {
'ws': './dist/npm/client/wsWrapper.js',
'https-proxy-agent': false
},
extensions: ['.ts', '.js', '.json'],
fallback: {
buffer: require.resolve('buffer/'),
assert: require.resolve('assert/'),
url: require.resolve('url/'),
stream: require.resolve('stream-browserify'),
crypto: require.resolve('crypto-browserify'),
path: require.resolve('path-browserify'),
http: require.resolve('stream-http')
}
}
};
return Object.assign({}, getDefaultConfiguration(), test);
}
return Object.assign({}, getDefaultConfiguration(), test)
}
module.exports = [
(env, argv) => {
const config = getDefaultConfiguration();
config.mode = 'development';
config.output.filename = `ripple-latest.js`;
return config;
const config = getDefaultConfiguration()
config.mode = 'development'
config.output.filename = `ripple-latest.js`
return config
},
(env, argv) => {
const config = getDefaultConfiguration();
config.mode = 'production';
config.output.filename = `ripple-latest-min.js`;
const config = getDefaultConfiguration()
config.mode = 'production'
config.output.filename = `ripple-latest-min.js`
if (process.argv.includes('--analyze')) {
config.plugins.push(new BundleAnalyzerPlugin());
config.plugins.push(new BundleAnalyzerPlugin())
}
return config;
return config
},
(env, argv) => webpackForTest('./test/integration/integration.ts'),
];
(env, argv) => webpackForTest('./test/integration/integration.ts')
]