Skip to content

Commit

Permalink
fix(frontend): tsconfig paths resolution
Browse files Browse the repository at this point in the history
  • Loading branch information
FrozenPandaz authored and vsavkin committed May 14, 2019
1 parent fba08a5 commit c2a9271
Show file tree
Hide file tree
Showing 10 changed files with 76 additions and 29 deletions.
5 changes: 2 additions & 3 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -104,6 +104,8 @@
"strip-json-comments": "2.0.1",
"tmp": "0.0.33",
"ts-loader": "^5.3.1",
"ts-node": "^8.0.2",
"tsconfig-paths-webpack-plugin": "^3.2.0",
"tsickle": "^0.33.0",
"tslib": "^1.9.3",
"tslint": "5.11.0",
Expand Down Expand Up @@ -133,8 +135,5 @@
"commitizen": {
"path": "./node_modules/cz-conventional-changelog"
}
},
"dependencies": {
"ts-node": "^8.0.2"
}
}
1 change: 1 addition & 0 deletions packages/builders/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -35,6 +35,7 @@
"rxjs": "6.3.3",
"source-map-support": "0.5.11",
"ts-loader": "5.3.1",
"tsconfig-paths-webpack-plugin": "3.2.0",
"webpack": "4.29.0",
"webpack-dev-server": "3.1.14",
"webpack-node-externals": "1.7.2",
Expand Down
3 changes: 3 additions & 0 deletions packages/builders/src/node/build/node-build.builder.spec.ts
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,8 @@ import { join, normalize } from '@angular-devkit/core';
import { TestLogger } from '@angular-devkit/architect/testing';
import BuildNodeBuilder from './node-build.builder';
import { BuildNodeBuilderOptions } from './node-build.builder';
jest.mock('tsconfig-paths-webpack-plugin');
import TsConfigPathsPlugin from 'tsconfig-paths-webpack-plugin';
import { of } from 'rxjs';
import * as fs from 'fs';

Expand Down Expand Up @@ -42,6 +44,7 @@ describe('NodeBuildBuilder', () => {
assets: [],
statsJson: false
};
(<any>TsConfigPathsPlugin).mockImplementation(class MockPathsPlugin {});
});

describe('run', () => {
Expand Down
14 changes: 9 additions & 5 deletions packages/builders/src/utils/webpack/config.spec.ts
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,8 @@ import * as ts from 'typescript';
import { LicenseWebpackPlugin } from 'license-webpack-plugin';
import CircularDependencyPlugin = require('circular-dependency-plugin');
import ForkTsCheckerWebpackPlugin = require('fork-ts-checker-webpack-plugin');
jest.mock('tsconfig-paths-webpack-plugin');
import TsConfigPathsPlugin from 'tsconfig-paths-webpack-plugin';
import { ProgressPlugin } from 'webpack';
import { BuildBuilderOptions } from '../types';

Expand All @@ -19,6 +21,7 @@ describe('getBaseWebpackPartial', () => {
root: getSystemPath(normalize('/root')),
statsJson: false
};
(<any>TsConfigPathsPlugin).mockImplementation(class MockPathsPlugin {});
});

describe('unconditional options', () => {
Expand Down Expand Up @@ -127,19 +130,20 @@ describe('getBaseWebpackPartial', () => {
expect(typeCheckerPlugin.options.tsconfig).toBe('tsconfig.json');
});

it('should set aliases for compilerOptionPaths', () => {
it('should add the TsConfigPathsPlugin for resolving', () => {
spyOn(ts, 'parseJsonConfigFileContent').and.returnValue({
options: {
paths: {
'@npmScope/libraryName': ['libs/libraryName/src/index.ts']
}
}
});

const result = getBaseWebpackPartial(input);
expect(result.resolve.alias).toEqual({
'@npmScope/libraryName': '/root/libs/libraryName/src/index.ts'
});
expect(
result.resolve.plugins.some(
plugin => plugin instanceof TsConfigPathsPlugin
)
).toEqual(true);
});

it('should include es2015 in mainFields if typescript is set es2015', () => {
Expand Down
32 changes: 15 additions & 17 deletions packages/builders/src/utils/webpack/config.ts
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@ import { resolve } from 'path';
import { LicenseWebpackPlugin } from 'license-webpack-plugin';
import CircularDependencyPlugin = require('circular-dependency-plugin');
import ForkTsCheckerWebpackPlugin = require('fork-ts-checker-webpack-plugin');
import TsConfigPathsPlugin from 'tsconfig-paths-webpack-plugin';
import * as CopyWebpackPlugin from 'copy-webpack-plugin';

import { AssetPatternObject } from '@angular-devkit/build-angular';
Expand All @@ -22,6 +23,8 @@ export function getBaseWebpackPartial(
const supportsEs2015 =
compilerOptions.target !== ts.ScriptTarget.ES3 &&
compilerOptions.target !== ts.ScriptTarget.ES5;
const mainFields = [...(supportsEs2015 ? ['es2015'] : []), 'module', 'main'];
const extensions = ['.ts', '.tsx', '.mjs', '.js', '.jsx'];
const webpackConfig: Configuration = {
entry: {
main: [options.main]
Expand All @@ -47,9 +50,16 @@ export function getBaseWebpackPartial(
]
},
resolve: {
extensions: ['.ts', '.tsx', '.mjs', '.js', '.jsx'],
alias: getAliases(options, compilerOptions),
mainFields: [...(supportsEs2015 ? ['es2015'] : []), 'module', 'main']
extensions,
alias: getAliases(options),
plugins: [
new TsConfigPathsPlugin({
configFile: options.tsConfig,
extensions,
mainFields
})
],
mainFields
},
performance: {
hints: false
Expand Down Expand Up @@ -124,20 +134,8 @@ export function getBaseWebpackPartial(
return webpackConfig;
}

function getAliases(
options: BuildBuilderOptions,
compilerOptions: ts.CompilerOptions
): { [key: string]: string } {
const replacements = [
...options.fileReplacements,
...(compilerOptions.paths
? Object.entries(compilerOptions.paths).map(([importPath, values]) => ({
replace: importPath,
with: resolve(options.root, values[0])
}))
: [])
];
return replacements.reduce(
function getAliases(options: BuildBuilderOptions): { [key: string]: string } {
return options.fileReplacements.reduce(
(aliases, replacement) => ({
...aliases,
[replacement.replace]: replacement.with
Expand Down
7 changes: 5 additions & 2 deletions packages/builders/src/utils/webpack/devserver.config.spec.ts
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,8 @@ import { WebBuildBuilderOptions } from '../../web/build/web-build.builder';
import { WebDevServerOptions } from '../../web/dev-server/web-dev-server.builder';
import { getDevServerConfig } from './devserver.config';
import { Logger } from '@angular-devkit/core/src/logger';
jest.mock('tsconfig-paths-webpack-plugin');
import TsConfigPathsPlugin from 'tsconfig-paths-webpack-plugin';
import * as ts from 'typescript';
import * as fs from 'fs';

Expand Down Expand Up @@ -48,9 +50,10 @@ describe('getDevServerConfig', () => {
watch: true
};

(<any>TsConfigPathsPlugin).mockImplementation(class MockPathsPlugin {});

mockCompilerOptions = {
target: 'es2015',
paths: { path: ['mapped/path'] }
target: 'es2015'
};

spyOn(ts, 'readConfigFile').and.callFake(() => ({
Expand Down
7 changes: 5 additions & 2 deletions packages/builders/src/utils/webpack/node.config.spec.ts
Original file line number Diff line number Diff line change
@@ -1,7 +1,9 @@
import { getNodeWebpackConfig } from './node.config';
import { getSystemPath, normalize } from '@angular-devkit/core';
import { BuildNodeBuilderOptions } from '../../node/build/node-build.builder';
import { BannerPlugin } from 'webpack';
jest.mock('tsconfig-paths-webpack-plugin');
import TsConfigPathsPlugin from 'tsconfig-paths-webpack-plugin';
import { getNodeWebpackConfig } from './node.config';
import { BuildNodeBuilderOptions } from '../../node/build/node-build.builder';

describe('getNodePartial', () => {
let input: BuildNodeBuilderOptions;
Expand All @@ -15,6 +17,7 @@ describe('getNodePartial', () => {
root: getSystemPath(normalize('/root')),
statsJson: false
};
(<any>TsConfigPathsPlugin).mockImplementation(class MockPathsPlugin {});
});

describe('unconditionally', () => {
Expand Down
3 changes: 3 additions & 0 deletions packages/builders/src/utils/webpack/web.config.spec.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,6 @@
import { getSystemPath, normalize, Path } from '@angular-devkit/core';
jest.mock('tsconfig-paths-webpack-plugin');
import TsConfigPathsPlugin from 'tsconfig-paths-webpack-plugin';
import { getWebConfig as getWebPartial } from './web.config';
import { WebBuildBuilderOptions } from '../../web/build/web-build.builder';
import { createConsoleLogger } from '@angular-devkit/core/node';
Expand Down Expand Up @@ -42,6 +44,7 @@ describe('getWebConfig', () => {
target: 'es2015',
paths: { path: ['mapped/path'] }
};
(<any>TsConfigPathsPlugin).mockImplementation(class MockPathsPlugin {});

spyOn(ts, 'readConfigFile').and.callFake(() => ({
config: {
Expand Down
3 changes: 3 additions & 0 deletions packages/builders/src/web/build/web-build.builder.spec.ts
Original file line number Diff line number Diff line change
@@ -1,5 +1,7 @@
import { normalize, join } from '@angular-devkit/core';
import { TestLogger } from '@angular-devkit/architect/testing';
jest.mock('tsconfig-paths-webpack-plugin');
import TsConfigPathsPlugin from 'tsconfig-paths-webpack-plugin';
import WebBuildBuilder from './web-build.builder';
import { WebBuildBuilderOptions } from './web-build.builder';
import { of } from 'rxjs';
Expand Down Expand Up @@ -45,6 +47,7 @@ describe('WebBuildBuilder', () => {
assets: [],
statsJson: false
};
(<any>TsConfigPathsPlugin).mockImplementation(class MockPathsPlugin {});
});

describe('run', () => {
Expand Down
30 changes: 30 additions & 0 deletions yarn.lock
Original file line number Diff line number Diff line change
Expand Up @@ -619,6 +619,11 @@
version "3.2.16"
resolved "https://registry.yarnpkg.com/@types/jquery/-/jquery-3.2.16.tgz#04419c404a3194350e7d3f339a90e72c88db3111"

"@types/json5@^0.0.29":
version "0.0.29"
resolved "https://registry.yarnpkg.com/@types/json5/-/json5-0.0.29.tgz#ee28707ae94e11d2b827bcbe5270bcea7f3e71ee"
integrity sha1-7ihweulOEdK4J7y+UnC86n8+ce4=

"@types/[email protected]":
version "4.14.87"
resolved "https://registry.yarnpkg.com/@types/lodash/-/lodash-4.14.87.tgz#55f92183b048c2c64402afe472f8333f4e319a6b"
Expand Down Expand Up @@ -3553,6 +3558,11 @@ deep-is@~0.1.3:
version "0.1.3"
resolved "https://registry.yarnpkg.com/deep-is/-/deep-is-0.1.3.tgz#b369d6fb5dbc13eecf524f91b070feedc357cf34"

deepmerge@^2.0.1:
version "2.2.1"
resolved "https://registry.yarnpkg.com/deepmerge/-/deepmerge-2.2.1.tgz#5d3ff22a01c00f645405a2fbc17d0778a1801170"
integrity sha512-R9hc1Xa/NOBi9WRVUWg19rl1UB7Tt4kuPd+thNJgFZoxXsTz7ncaPaeIm+40oSGuP33DfMb4sZt1QIGiJzC4EA==

default-gateway@^2.6.0:
version "2.7.2"
resolved "https://registry.yarnpkg.com/default-gateway/-/default-gateway-2.7.2.tgz#b7ef339e5e024b045467af403d50348db4642d0f"
Expand Down Expand Up @@ -10988,6 +10998,26 @@ ts-node@^8.0.2:
source-map-support "^0.5.6"
yn "^3.0.0"

tsconfig-paths-webpack-plugin@^3.2.0:
version "3.2.0"
resolved "https://registry.yarnpkg.com/tsconfig-paths-webpack-plugin/-/tsconfig-paths-webpack-plugin-3.2.0.tgz#6e70bd42915ad0efb64d3385163f0c1270f3e04d"
integrity sha512-S/gOOPOkV8rIL4LurZ1vUdYCVgo15iX9ZMJ6wx6w2OgcpT/G4wMyHB6WM+xheSqGMrWKuxFul+aXpCju3wmj/g==
dependencies:
chalk "^2.3.0"
enhanced-resolve "^4.0.0"
tsconfig-paths "^3.4.0"

tsconfig-paths@^3.4.0:
version "3.8.0"
resolved "https://registry.yarnpkg.com/tsconfig-paths/-/tsconfig-paths-3.8.0.tgz#4e34202d5b41958f269cf56b01ed95b853d59f72"
integrity sha512-zZEYFo4sjORK8W58ENkRn9s+HmQFkkwydDG7My5s/fnfr2YYCaiyXe/HBUcIgU8epEKOXwiahOO+KZYjiXlWyQ==
dependencies:
"@types/json5" "^0.0.29"
deepmerge "^2.0.1"
json5 "^1.0.1"
minimist "^1.2.0"
strip-bom "^3.0.0"

tsickle@^0.33.0:
version "0.33.1"
resolved "https://registry.yarnpkg.com/tsickle/-/tsickle-0.33.1.tgz#eee4ebabeda3bcd8afc32cee34c822cbe3e839ec"
Expand Down

0 comments on commit c2a9271

Please sign in to comment.