@electron-forge/maker-base 6.0.0-beta.7 → 6.0.0-beta.70

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/Maker.d.ts CHANGED
@@ -1,4 +1,5 @@
1
- import { ForgeArch, ForgeConfig, ForgePlatform } from '@electron-forge/shared-types';
1
+ import { ForgeArch, ForgePlatform, IForgeMaker, ResolvedForgeConfig } from '@electron-forge/shared-types';
2
+ export declare type EmptyConfig = Record<string, never>;
2
3
  export interface MakerOptions {
3
4
  /**
4
5
  * The directory containing the packaged Electron application
@@ -24,20 +25,28 @@ export interface MakerOptions {
24
25
  /**
25
26
  * Fully resolved forge configuration, you shouldn't really need this
26
27
  */
27
- forgeConfig: ForgeConfig;
28
+ forgeConfig: ResolvedForgeConfig;
28
29
  /**
29
- * The applications package.json file
30
+ * The application's package.json file
30
31
  */
31
32
  packageJSON: any;
32
33
  }
33
- export default abstract class Maker<C> {
34
+ export default abstract class Maker<C> implements IForgeMaker {
35
+ private configOrConfigFetcher;
36
+ protected platformsToMakeOn?: string[] | undefined;
34
37
  config: C;
35
- protected providedPlatforms: ForgePlatform[] | undefined;
36
38
  abstract name: string;
37
39
  abstract defaultPlatforms: ForgePlatform[];
40
+ requiredExternalBinaries: string[];
41
+ /** @internal */
38
42
  __isElectronForgeMaker: true;
39
- constructor(config?: C, providedPlatforms?: ForgePlatform[] | undefined);
40
- readonly platforms: ForgePlatform[];
43
+ /**
44
+ * @param configOrConfigFetcher - Either a configuration object for this maker or a simple method that returns such a configuration for a given target architecture
45
+ * @param platformsToMakeOn - If you want this maker to run on platforms different from `defaultPlatforms` you can provide those platforms here
46
+ */
47
+ constructor(configOrConfigFetcher?: C | ((arch: ForgeArch) => C), platformsToMakeOn?: string[] | undefined);
48
+ get platforms(): ForgePlatform[];
49
+ prepareConfig(targetArch: ForgeArch): void;
41
50
  /**
42
51
  * Makers must implement this method and return true or false indicating whether
43
52
  * this maker can be run on the current platform. Normally this is just a process.platform
@@ -69,9 +78,24 @@ export default abstract class Maker<C> {
69
78
  * I.e. If the file already exists it is deleted and the path created
70
79
  */
71
80
  ensureFile(file: string): Promise<void>;
81
+ /**
82
+ * Checks if the specified binaries exist, which are required for the maker to be used.
83
+ */
84
+ externalBinariesExist(): boolean;
85
+ /**
86
+ * Throws an error if any of the binaries don't exist.
87
+ */
88
+ ensureExternalBinariesExist(): void;
72
89
  /**
73
90
  * Checks if the given module is installed, used for testing if optional dependencies
74
91
  * are installed or not
75
92
  */
76
93
  isInstalled(module: string): boolean;
94
+ /**
95
+ * Normalize the given semver-formatted version to a 4-part dot delimited version number without
96
+ * prerelease information for use in Windows apps.
97
+ */
98
+ normalizeWindowsVersion(version: string): string;
77
99
  }
100
+ export { Maker as MakerBase };
101
+ //# sourceMappingURL=Maker.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Maker.d.ts","sourceRoot":"","sources":["../src/Maker.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,SAAS,EAAE,aAAa,EAAE,WAAW,EAAE,mBAAmB,EAAE,MAAM,8BAA8B,CAAC;AAI1G,oBAAY,WAAW,GAAG,MAAM,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC;AAEhD,MAAM,WAAW,YAAY;IAC3B;;OAEG;IACH,GAAG,EAAE,MAAM,CAAC;IACZ;;;OAGG;IACH,OAAO,EAAE,MAAM,CAAC;IAChB;;OAEG;IACH,OAAO,EAAE,MAAM,CAAC;IAChB;;OAEG;IACH,cAAc,EAAE,aAAa,CAAC;IAC9B;;OAEG;IACH,UAAU,EAAE,SAAS,CAAC;IACtB;;OAEG;IACH,WAAW,EAAE,mBAAmB,CAAC;IACjC;;OAEG;IACH,WAAW,EAAE,GAAG,CAAC;CAClB;AAED,MAAM,CAAC,OAAO,CAAC,QAAQ,OAAO,KAAK,CAAC,CAAC,CAAE,YAAW,WAAW;IAgB/C,OAAO,CAAC,qBAAqB;IAA0C,SAAS,CAAC,iBAAiB,CAAC;IAfxG,MAAM,EAAG,CAAC,CAAC;IAElB,SAAgB,IAAI,EAAE,MAAM,CAAC;IAE7B,SAAgB,gBAAgB,EAAE,aAAa,EAAE,CAAC;IAE3C,wBAAwB,EAAE,MAAM,EAAE,CAAM;IAE/C,gBAAgB;IAChB,sBAAsB,EAAG,IAAI,CAAC;IAE9B;;;OAGG;gBACiB,qBAAqB,GAAE,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,SAAS,KAAK,CAAC,CAAW,EAAY,iBAAiB,CAAC,sBAAiB;IAQhI,IAAI,SAAS,IAAI,aAAa,EAAE,CAG/B;IAID,aAAa,CAAC,UAAU,EAAE,SAAS,GAAG,IAAI;IAQ1C;;;;;;;;OAQG;IACH,4BAA4B,IAAI,OAAO;IAOvC;;;OAGG;IAEG,IAAI,CAAC,IAAI,EAAE,YAAY,GAAG,OAAO,CAAC,MAAM,EAAE,CAAC;IAOjD;;OAEG;IAEH;;;;;OAKG;IACG,eAAe,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAOjD;;;;OAIG;IACG,UAAU,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAO7C;;OAEG;IACH,qBAAqB,IAAI,OAAO;IAIhC;;OAEG;IACH,2BAA2B,IAAI,IAAI;IAMnC;;;OAGG;IACH,WAAW,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO;IAUpC;;;OAGG;IACH,uBAAuB,CAAC,OAAO,EAAE,MAAM,GAAG,MAAM;CAIjD;AAED,OAAO,EAAE,KAAK,IAAI,SAAS,EAAE,CAAC"}
package/dist/Maker.js CHANGED
@@ -1,57 +1,44 @@
1
1
  "use strict";
2
-
3
2
  Object.defineProperty(exports, "__esModule", {
4
- value: true
3
+ value: true
5
4
  });
6
- exports.default = void 0;
7
-
8
- require("source-map-support/register");
9
-
10
- var _fsExtra = _interopRequireDefault(require("fs-extra"));
11
-
5
+ exports.MakerBase = exports.default = void 0;
12
6
  var _path = _interopRequireDefault(require("path"));
13
-
14
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
15
-
16
- function _asyncToGenerator(fn) { return function () { var self = this, args = arguments; return new Promise(function (resolve, reject) { var gen = fn.apply(self, args); function step(key, arg) { try { var info = gen[key](arg); var value = info.value; } catch (error) { reject(error); return; } if (info.done) { resolve(value); } else { Promise.resolve(value).then(_next, _throw); } } function _next(value) { step("next", value); } function _throw(err) { step("throw", err); } _next(); }); }; }
17
-
7
+ var _fsExtra = _interopRequireDefault(require("fs-extra"));
8
+ var _which = _interopRequireDefault(require("which"));
9
+ function _interopRequireDefault(obj) {
10
+ return obj && obj.__esModule ? obj : {
11
+ default: obj
12
+ };
13
+ }
18
14
  class Maker {
19
- /* tslint:disable variable-name */
20
-
21
- /* tslint:enable variable-name */
22
- constructor(config = {}, providedPlatforms) {
23
- this.config = config;
24
- this.providedPlatforms = providedPlatforms;
25
- Object.defineProperty(this, "name", {
26
- configurable: true,
27
- enumerable: true,
28
- writable: true,
29
- value: void 0
30
- });
31
- Object.defineProperty(this, "defaultPlatforms", {
32
- configurable: true,
33
- enumerable: true,
34
- writable: true,
35
- value: void 0
36
- });
37
- Object.defineProperty(this, "__isElectronForgeMaker", {
38
- configurable: true,
39
- enumerable: true,
40
- writable: true,
41
- value: void 0
42
- });
43
- Object.defineProperty(this, '__isElectronForgeMaker', {
44
- value: true,
45
- enumerable: false,
46
- configurable: false
47
- });
48
- }
49
-
50
- get platforms() {
51
- if (this.providedPlatforms) return this.providedPlatforms;
52
- return this.defaultPlatforms;
53
- }
54
- /**
15
+ /**
16
+ * @param configOrConfigFetcher - Either a configuration object for this maker or a simple method that returns such a configuration for a given target architecture
17
+ * @param platformsToMakeOn - If you want this maker to run on platforms different from `defaultPlatforms` you can provide those platforms here
18
+ */ constructor(configOrConfigFetcher = {}, platformsToMakeOn){
19
+ this.configOrConfigFetcher = configOrConfigFetcher;
20
+ this.platformsToMakeOn = platformsToMakeOn;
21
+ this.requiredExternalBinaries = [];
22
+ Object.defineProperty(this, '__isElectronForgeMaker', {
23
+ value: true,
24
+ enumerable: false,
25
+ configurable: false
26
+ });
27
+ }
28
+ get platforms() {
29
+ if (this.platformsToMakeOn) return this.platformsToMakeOn;
30
+ return this.defaultPlatforms;
31
+ }
32
+ // TODO: Remove this, it is an eye-sore and is a nasty hack to provide forge
33
+ // v5 style functionality in the new API
34
+ prepareConfig(targetArch) {
35
+ if (typeof this.configOrConfigFetcher === 'function') {
36
+ this.config = this.configOrConfigFetcher(targetArch);
37
+ } else {
38
+ this.config = this.configOrConfigFetcher;
39
+ }
40
+ }
41
+ /**
55
42
  * Makers must implement this method and return true or false indicating whether
56
43
  * this maker can be run on the current platform. Normally this is just a process.platform
57
44
  * check but it can be a deeper check for dependencies like fake-root or other
@@ -59,80 +46,81 @@ class Maker {
59
46
  *
60
47
  * If the issue is a missing dependency you should log out a HELPFUL error message
61
48
  * telling the developer exactly what is missing and if possible how to get it.
62
- */
63
-
64
-
65
- isSupportedOnCurrentPlatform() {
66
- throw new Error(`Maker ${this.name} did not implement the isSupportedOnCurrentPlatform method`);
67
- }
68
- /**
49
+ */ isSupportedOnCurrentPlatform() {
50
+ if (this.isSupportedOnCurrentPlatform === Maker.prototype.isSupportedOnCurrentPlatform) {
51
+ throw new Error(`Maker ${this.name} did not implement the isSupportedOnCurrentPlatform method`);
52
+ }
53
+ return true;
54
+ }
55
+ /**
69
56
  * Makers must implement this method and return an array of absolute paths
70
57
  * to the artifacts generated by your maker
71
- */
72
-
73
-
74
- make(opts) {
75
- var _this = this;
76
-
77
- return _asyncToGenerator(function* () {
78
- throw new Error(`Maker ${_this.name} did not implement the make method`);
79
- })();
80
- }
81
- /**
58
+ */ // eslint-disable-next-line @typescript-eslint/no-unused-vars
59
+ async make(opts) {
60
+ if (this.make === Maker.prototype.make) {
61
+ throw new Error(`Maker ${this.name} did not implement the make method`);
62
+ }
63
+ return [];
64
+ }
65
+ /**
82
66
  * Helpers
83
- */
84
-
85
- /**
67
+ */ /**
86
68
  * Ensures the directory exists and is forced to be empty.
87
69
  *
88
70
  * I.e. If the directory already exists it is deleted and recreated, this
89
71
  * is a destructive operation
90
- */
91
-
92
-
93
- ensureDirectory(dir) {
94
- return _asyncToGenerator(function* () {
95
- if (yield _fsExtra.default.pathExists(dir)) {
96
- yield _fsExtra.default.remove(dir);
97
- }
98
-
99
- return _fsExtra.default.mkdirs(dir);
100
- })();
101
- }
102
- /**
72
+ */ async ensureDirectory(dir) {
73
+ if (await _fsExtra.default.pathExists(dir)) {
74
+ await _fsExtra.default.remove(dir);
75
+ }
76
+ return _fsExtra.default.mkdirs(dir);
77
+ }
78
+ /**
103
79
  * Ensures the path to the file exists and the file does not exist
104
80
  *
105
81
  * I.e. If the file already exists it is deleted and the path created
106
- */
107
-
108
-
109
- ensureFile(file) {
110
- return _asyncToGenerator(function* () {
111
- if (yield _fsExtra.default.pathExists(file)) {
112
- yield _fsExtra.default.remove(file);
113
- }
114
-
115
- yield _fsExtra.default.mkdirs(_path.default.dirname(file));
116
- })();
117
- }
118
- /**
82
+ */ async ensureFile(file) {
83
+ if (await _fsExtra.default.pathExists(file)) {
84
+ await _fsExtra.default.remove(file);
85
+ }
86
+ await _fsExtra.default.mkdirs(_path.default.dirname(file));
87
+ }
88
+ /**
89
+ * Checks if the specified binaries exist, which are required for the maker to be used.
90
+ */ externalBinariesExist() {
91
+ return this.requiredExternalBinaries.every((binary)=>_which.default.sync(binary, {
92
+ nothrow: true
93
+ }) !== null
94
+ );
95
+ }
96
+ /**
97
+ * Throws an error if any of the binaries don't exist.
98
+ */ ensureExternalBinariesExist() {
99
+ if (!this.externalBinariesExist()) {
100
+ throw new Error(`Cannot make for ${this.name}, the following external binaries need to be installed: ${this.requiredExternalBinaries.join(', ')}`);
101
+ }
102
+ }
103
+ /**
119
104
  * Checks if the given module is installed, used for testing if optional dependencies
120
105
  * are installed or not
121
- */
122
-
123
-
124
- isInstalled(module) {
125
- try {
126
- require(module);
127
-
128
- return true;
129
- } catch (e) {
130
- // Package doesn't exist -- must not be installable on this platform
131
- return false;
106
+ */ isInstalled(module) {
107
+ try {
108
+ require(module);
109
+ return true;
110
+ } catch (e) {
111
+ // Package doesn't exist -- must not be installable on this platform
112
+ return false;
113
+ }
114
+ }
115
+ /**
116
+ * Normalize the given semver-formatted version to a 4-part dot delimited version number without
117
+ * prerelease information for use in Windows apps.
118
+ */ normalizeWindowsVersion(version) {
119
+ const noPrerelease = version.replace(/-.*/, '');
120
+ return `${noPrerelease}.0`;
132
121
  }
133
- }
134
-
135
122
  }
136
-
137
123
  exports.default = Maker;
138
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9NYWtlci50cyJdLCJuYW1lcyI6WyJNYWtlciIsImNvbnN0cnVjdG9yIiwiY29uZmlnIiwicHJvdmlkZWRQbGF0Zm9ybXMiLCJPYmplY3QiLCJkZWZpbmVQcm9wZXJ0eSIsInZhbHVlIiwiZW51bWVyYWJsZSIsImNvbmZpZ3VyYWJsZSIsInBsYXRmb3JtcyIsImRlZmF1bHRQbGF0Zm9ybXMiLCJpc1N1cHBvcnRlZE9uQ3VycmVudFBsYXRmb3JtIiwiRXJyb3IiLCJuYW1lIiwibWFrZSIsIm9wdHMiLCJlbnN1cmVEaXJlY3RvcnkiLCJkaXIiLCJmcyIsInBhdGhFeGlzdHMiLCJyZW1vdmUiLCJta2RpcnMiLCJlbnN1cmVGaWxlIiwiZmlsZSIsInBhdGgiLCJkaXJuYW1lIiwiaXNJbnN0YWxsZWQiLCJtb2R1bGUiLCJyZXF1aXJlIiwiZSJdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7O0FBR0E7O0FBQ0E7Ozs7OztBQWtDZSxNQUFlQSxLQUFmLENBQXdCO0FBR3JDOztBQUVBO0FBRUFDLGNBQW1CQyxTQUFZLEVBQS9CLEVBQWtEQyxpQkFBbEQsRUFBdUY7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQ3JGQyxXQUFPQyxjQUFQLENBQXNCLElBQXRCLEVBQTRCLHdCQUE1QixFQUFzRDtBQUNwREMsYUFBTyxJQUQ2QztBQUVwREMsa0JBQVksS0FGd0M7QUFHcERDLG9CQUFjO0FBSHNDLEtBQXREO0FBS0Q7O0FBRUQsTUFBSUMsU0FBSixHQUFnQjtBQUNkLFFBQUksS0FBS04saUJBQVQsRUFBNEIsT0FBTyxLQUFLQSxpQkFBWjtBQUM1QixXQUFPLEtBQUtPLGdCQUFaO0FBQ0Q7QUFFRDs7Ozs7Ozs7Ozs7QUFTQUMsaUNBQXdDO0FBQ3RDLFVBQU0sSUFBSUMsS0FBSixDQUFXLFNBQVEsS0FBS0MsSUFBSyw0REFBN0IsQ0FBTjtBQUNEO0FBRUQ7Ozs7OztBQUlNQyxNQUFOLENBQVdDLElBQVgsRUFBa0Q7QUFBQTs7QUFBQTtBQUNoRCxZQUFNLElBQUlILEtBQUosQ0FBVyxTQUFRLE1BQUtDLElBQUssb0NBQTdCLENBQU47QUFEZ0Q7QUFFakQ7QUFHRDs7OztBQUlBOzs7Ozs7OztBQU1NRyxpQkFBTixDQUFzQkMsR0FBdEIsRUFBa0Q7QUFBQTtBQUNoRCxnQkFBVUMsaUJBQUdDLFVBQUgsQ0FBY0YsR0FBZCxDQUFWLEVBQThCO0FBQzVCLGNBQU1DLGlCQUFHRSxNQUFILENBQVVILEdBQVYsQ0FBTjtBQUNEOztBQUNELGFBQU9DLGlCQUFHRyxNQUFILENBQVVKLEdBQVYsQ0FBUDtBQUpnRDtBQUtqRDtBQUVEOzs7Ozs7O0FBS01LLFlBQU4sQ0FBaUJDLElBQWpCLEVBQThDO0FBQUE7QUFDNUMsZ0JBQVVMLGlCQUFHQyxVQUFILENBQWNJLElBQWQsQ0FBVixFQUErQjtBQUM3QixjQUFNTCxpQkFBR0UsTUFBSCxDQUFVRyxJQUFWLENBQU47QUFDRDs7QUFDRCxZQUFNTCxpQkFBR0csTUFBSCxDQUFVRyxjQUFLQyxPQUFMLENBQWFGLElBQWIsQ0FBVixDQUFOO0FBSjRDO0FBSzdDO0FBRUQ7Ozs7OztBQUlBRyxjQUFZQyxNQUFaLEVBQXFDO0FBQ25DLFFBQUk7QUFDRkMsY0FBUUQsTUFBUjs7QUFDQSxhQUFPLElBQVA7QUFDRCxLQUhELENBR0UsT0FBT0UsQ0FBUCxFQUFVO0FBQ1Y7QUFDQSxhQUFPLEtBQVA7QUFDRDtBQUNGOztBQW5Gb0MiLCJzb3VyY2VzQ29udGVudCI6WyIvKiBlc2xpbnQtZGlzYWJsZSBuby11bnVzZWQtdmFycyAqL1xuXG5pbXBvcnQgeyBGb3JnZUFyY2gsIEZvcmdlQ29uZmlnLCBGb3JnZVBsYXRmb3JtLCBJRm9yZ2VNYWtlciB9IGZyb20gJ0BlbGVjdHJvbi1mb3JnZS9zaGFyZWQtdHlwZXMnO1xuaW1wb3J0IGZzIGZyb20gJ2ZzLWV4dHJhJztcbmltcG9ydCBwYXRoIGZyb20gJ3BhdGgnO1xuXG5leHBvcnQgaW50ZXJmYWNlIE1ha2VyT3B0aW9ucyB7XG4gIC8qKlxuICAgKiBUaGUgZGlyZWN0b3J5IGNvbnRhaW5pbmcgdGhlIHBhY2thZ2VkIEVsZWN0cm9uIGFwcGxpY2F0aW9uXG4gICAqL1xuICBkaXI6IHN0cmluZztcbiAgLyoqXG4gICAqIFRoZSBkaXJlY3RvcnkgeW91IHNob3VsZCBwdXQgYWxsIHlvdXIgYXJ0aWZhY3RzIGluIChwb3RlbnRpYWxseSBpbiBzdWIgZm9sZGVycylcbiAgICogTk9URTogdGhpcyBkaXJlY3RvcnkgaXMgbm90IGd1YXJ1bnRlZWQgdG8gYWxyZWFkeSBleGlzdFxuICAgKi9cbiAgbWFrZURpcjogc3RyaW5nO1xuICAvKipcbiAgICogVGhlIHJlc29sdmVkIGh1bWFuIGZyaWVuZGx5IG5hbWUgb2YgdGhlIHByb2plY3RcbiAgICovXG4gIGFwcE5hbWU6IHN0cmluZztcbiAgLyoqXG4gICAqIFRoZSB0YXJnZXQgcGxhdGZvcm0geW91IHNob3VsZCBtYWtlIGZvclxuICAgKi9cbiAgdGFyZ2V0UGxhdGZvcm06IEZvcmdlUGxhdGZvcm07XG4gIC8qKlxuICAgKiBUaGUgdGFyZ2V0IGFyY2hpdGVjdHVyZSB5b3Ugc2hvdWxkIG1ha2UgZm9yXG4gICAqL1xuICB0YXJnZXRBcmNoOiBGb3JnZUFyY2g7XG4gIC8qKlxuICAgKiBGdWxseSByZXNvbHZlZCBmb3JnZSBjb25maWd1cmF0aW9uLCB5b3Ugc2hvdWxkbid0IHJlYWxseSBuZWVkIHRoaXNcbiAgICovXG4gIGZvcmdlQ29uZmlnOiBGb3JnZUNvbmZpZztcbiAgLyoqXG4gICAqIFRoZSBhcHBsaWNhdGlvbnMgcGFja2FnZS5qc29uIGZpbGVcbiAgICovXG4gIHBhY2thZ2VKU09OOiBhbnk7XG59XG5cbmV4cG9ydCBkZWZhdWx0IGFic3RyYWN0IGNsYXNzIE1ha2VyPEM+IHtcbiAgcHVibGljIGFic3RyYWN0IG5hbWU6IHN0cmluZztcbiAgcHVibGljIGFic3RyYWN0IGRlZmF1bHRQbGF0Zm9ybXM6IEZvcmdlUGxhdGZvcm1bXTtcbiAgLyogdHNsaW50OmRpc2FibGUgdmFyaWFibGUtbmFtZSAqL1xuICBfX2lzRWxlY3Ryb25Gb3JnZU1ha2VyITogdHJ1ZTtcbiAgLyogdHNsaW50OmVuYWJsZSB2YXJpYWJsZS1uYW1lICovXG5cbiAgY29uc3RydWN0b3IocHVibGljIGNvbmZpZzogQyA9IHt9IGFzIEMsIHByb3RlY3RlZCBwcm92aWRlZFBsYXRmb3Jtcz86IEZvcmdlUGxhdGZvcm1bXSkge1xuICAgIE9iamVjdC5kZWZpbmVQcm9wZXJ0eSh0aGlzLCAnX19pc0VsZWN0cm9uRm9yZ2VNYWtlcicsIHtcbiAgICAgIHZhbHVlOiB0cnVlLFxuICAgICAgZW51bWVyYWJsZTogZmFsc2UsXG4gICAgICBjb25maWd1cmFibGU6IGZhbHNlLFxuICAgIH0pO1xuICB9XG5cbiAgZ2V0IHBsYXRmb3JtcygpIHtcbiAgICBpZiAodGhpcy5wcm92aWRlZFBsYXRmb3JtcykgcmV0dXJuIHRoaXMucHJvdmlkZWRQbGF0Zm9ybXM7XG4gICAgcmV0dXJuIHRoaXMuZGVmYXVsdFBsYXRmb3JtcztcbiAgfVxuXG4gIC8qKlxuICAgKiBNYWtlcnMgbXVzdCBpbXBsZW1lbnQgdGhpcyBtZXRob2QgYW5kIHJldHVybiB0cnVlIG9yIGZhbHNlIGluZGljYXRpbmcgd2hldGhlclxuICAgKiB0aGlzIG1ha2VyIGNhbiBiZSBydW4gb24gdGhlIGN1cnJlbnQgcGxhdGZvcm0uICBOb3JtYWxseSB0aGlzIGlzIGp1c3QgYSBwcm9jZXNzLnBsYXRmb3JtXG4gICAqIGNoZWNrIGJ1dCBpdCBjYW4gYmUgYSBkZWVwZXIgY2hlY2sgZm9yIGRlcGVuZGVuY2llcyBsaWtlIGZha2Utcm9vdCBvciBvdGhlclxuICAgKiByZXF1aXJlZCBleHRlcm5hbCBidWlsZCB0b29scy5cbiAgICpcbiAgICogSWYgdGhlIGlzc3VlIGlzIGEgbWlzc2luZyBkZXBlbmRlbmN5IHlvdSBzaG91bGQgbG9nIG91dCBhIEhFTFBGVUwgZXJyb3IgbWVzc2FnZVxuICAgKiB0ZWxsaW5nIHRoZSBkZXZlbG9wZXIgZXhhY3RseSB3aGF0IGlzIG1pc3NpbmcgYW5kIGlmIHBvc3NpYmxlIGhvdyB0byBnZXQgaXQuXG4gICAqL1xuICBpc1N1cHBvcnRlZE9uQ3VycmVudFBsYXRmb3JtKCk6IGJvb2xlYW4ge1xuICAgIHRocm93IG5ldyBFcnJvcihgTWFrZXIgJHt0aGlzLm5hbWV9IGRpZCBub3QgaW1wbGVtZW50IHRoZSBpc1N1cHBvcnRlZE9uQ3VycmVudFBsYXRmb3JtIG1ldGhvZGApO1xuICB9XG5cbiAgLyoqXG4gICAqIE1ha2VycyBtdXN0IGltcGxlbWVudCB0aGlzIG1ldGhvZCBhbmQgcmV0dXJuIGFuIGFycmF5IG9mIGFic29sdXRlIHBhdGhzXG4gICAqIHRvIHRoZSBhcnRpZmFjdHMgZ2VuZXJhdGVkIGJ5IHlvdXIgbWFrZXJcbiAgICovXG4gIGFzeW5jIG1ha2Uob3B0czogTWFrZXJPcHRpb25zKTogUHJvbWlzZTxzdHJpbmdbXT4ge1xuICAgIHRocm93IG5ldyBFcnJvcihgTWFrZXIgJHt0aGlzLm5hbWV9IGRpZCBub3QgaW1wbGVtZW50IHRoZSBtYWtlIG1ldGhvZGApO1xuICB9XG5cblxuICAvKipcbiAgICogSGVscGVyc1xuICAgKi9cblxuICAvKipcbiAgICogRW5zdXJlcyB0aGUgZGlyZWN0b3J5IGV4aXN0cyBhbmQgaXMgZm9yY2VkIHRvIGJlIGVtcHR5LlxuICAgKlxuICAgKiBJLmUuIElmIHRoZSBkaXJlY3RvcnkgYWxyZWFkeSBleGlzdHMgaXQgaXMgZGVsZXRlZCBhbmQgcmVjcmVhdGVkLCB0aGlzXG4gICAqIGlzIGEgZGVzdHJ1Y3RpdmUgb3BlcmF0aW9uXG4gICAqL1xuICBhc3luYyBlbnN1cmVEaXJlY3RvcnkoZGlyOiBzdHJpbmcpOiBQcm9taXNlPHZvaWQ+IHtcbiAgICBpZiAoYXdhaXQgZnMucGF0aEV4aXN0cyhkaXIpKSB7XG4gICAgICBhd2FpdCBmcy5yZW1vdmUoZGlyKTtcbiAgICB9XG4gICAgcmV0dXJuIGZzLm1rZGlycyhkaXIpO1xuICB9XG5cbiAgLyoqXG4gICAqIEVuc3VyZXMgdGhlIHBhdGggdG8gdGhlIGZpbGUgZXhpc3RzIGFuZCB0aGUgZmlsZSBkb2VzIG5vdCBleGlzdFxuICAgKlxuICAgKiBJLmUuIElmIHRoZSBmaWxlIGFscmVhZHkgZXhpc3RzIGl0IGlzIGRlbGV0ZWQgYW5kIHRoZSBwYXRoIGNyZWF0ZWRcbiAgICovXG4gIGFzeW5jIGVuc3VyZUZpbGUoZmlsZTogc3RyaW5nKTogUHJvbWlzZTx2b2lkPiB7XG4gICAgaWYgKGF3YWl0IGZzLnBhdGhFeGlzdHMoZmlsZSkpIHtcbiAgICAgIGF3YWl0IGZzLnJlbW92ZShmaWxlKTtcbiAgICB9XG4gICAgYXdhaXQgZnMubWtkaXJzKHBhdGguZGlybmFtZShmaWxlKSk7XG4gIH1cblxuICAvKipcbiAgICogQ2hlY2tzIGlmIHRoZSBnaXZlbiBtb2R1bGUgaXMgaW5zdGFsbGVkLCB1c2VkIGZvciB0ZXN0aW5nIGlmIG9wdGlvbmFsIGRlcGVuZGVuY2llc1xuICAgKiBhcmUgaW5zdGFsbGVkIG9yIG5vdFxuICAgKi9cbiAgaXNJbnN0YWxsZWQobW9kdWxlOiBzdHJpbmcpOiBib29sZWFuIHtcbiAgICB0cnkge1xuICAgICAgcmVxdWlyZShtb2R1bGUpO1xuICAgICAgcmV0dXJuIHRydWU7XG4gICAgfSBjYXRjaCAoZSkge1xuICAgICAgLy8gUGFja2FnZSBkb2Vzbid0IGV4aXN0IC0tIG11c3Qgbm90IGJlIGluc3RhbGxhYmxlIG9uIHRoaXMgcGxhdGZvcm1cbiAgICAgIHJldHVybiBmYWxzZTtcbiAgICB9XG4gIH1cbn1cbiJdfQ==
124
+ exports.MakerBase = Maker;
125
+
126
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/Maker.ts"],"sourcesContent":["import path from 'path';\n\nimport { ForgeArch, ForgePlatform, IForgeMaker, ResolvedForgeConfig } from '@electron-forge/shared-types';\nimport fs from 'fs-extra';\nimport which from 'which';\n\nexport type EmptyConfig = Record<string, never>;\n\nexport interface MakerOptions {\n  /**\n   * The directory containing the packaged Electron application\n   */\n  dir: string;\n  /**\n   * The directory you should put all your artifacts in (potentially in sub folders)\n   * NOTE: this directory is not guarunteed to already exist\n   */\n  makeDir: string;\n  /**\n   * The resolved human friendly name of the project\n   */\n  appName: string;\n  /**\n   * The target platform you should make for\n   */\n  targetPlatform: ForgePlatform;\n  /**\n   * The target architecture you should make for\n   */\n  targetArch: ForgeArch;\n  /**\n   * Fully resolved forge configuration, you shouldn't really need this\n   */\n  forgeConfig: ResolvedForgeConfig;\n  /**\n   * The application's package.json file\n   */\n  packageJSON: any; // eslint-disable-line @typescript-eslint/no-explicit-any\n}\n\nexport default abstract class Maker<C> implements IForgeMaker {\n  public config!: C;\n\n  public abstract name: string;\n\n  public abstract defaultPlatforms: ForgePlatform[];\n\n  public requiredExternalBinaries: string[] = [];\n\n  /** @internal */\n  __isElectronForgeMaker!: true;\n\n  /**\n   * @param configOrConfigFetcher - Either a configuration object for this maker or a simple method that returns such a configuration for a given target architecture\n   * @param platformsToMakeOn - If you want this maker to run on platforms different from `defaultPlatforms` you can provide those platforms here\n   */\n  constructor(private configOrConfigFetcher: C | ((arch: ForgeArch) => C) = {} as C, protected platformsToMakeOn?: ForgePlatform[]) {\n    Object.defineProperty(this, '__isElectronForgeMaker', {\n      value: true,\n      enumerable: false,\n      configurable: false,\n    });\n  }\n\n  get platforms(): ForgePlatform[] {\n    if (this.platformsToMakeOn) return this.platformsToMakeOn;\n    return this.defaultPlatforms;\n  }\n\n  // TODO: Remove this, it is an eye-sore and is a nasty hack to provide forge\n  //       v5 style functionality in the new API\n  prepareConfig(targetArch: ForgeArch): void {\n    if (typeof this.configOrConfigFetcher === 'function') {\n      this.config = (this.configOrConfigFetcher as unknown as (arch: ForgeArch) => C)(targetArch);\n    } else {\n      this.config = this.configOrConfigFetcher as C;\n    }\n  }\n\n  /**\n   * Makers must implement this method and return true or false indicating whether\n   * this maker can be run on the current platform.  Normally this is just a process.platform\n   * check but it can be a deeper check for dependencies like fake-root or other\n   * required external build tools.\n   *\n   * If the issue is a missing dependency you should log out a HELPFUL error message\n   * telling the developer exactly what is missing and if possible how to get it.\n   */\n  isSupportedOnCurrentPlatform(): boolean {\n    if (this.isSupportedOnCurrentPlatform === Maker.prototype.isSupportedOnCurrentPlatform) {\n      throw new Error(`Maker ${this.name} did not implement the isSupportedOnCurrentPlatform method`);\n    }\n    return true;\n  }\n\n  /**\n   * Makers must implement this method and return an array of absolute paths\n   * to the artifacts generated by your maker\n   */\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  async make(opts: MakerOptions): Promise<string[]> {\n    if (this.make === Maker.prototype.make) {\n      throw new Error(`Maker ${this.name} did not implement the make method`);\n    }\n    return [];\n  }\n\n  /**\n   * Helpers\n   */\n\n  /**\n   * Ensures the directory exists and is forced to be empty.\n   *\n   * I.e. If the directory already exists it is deleted and recreated, this\n   * is a destructive operation\n   */\n  async ensureDirectory(dir: string): Promise<void> {\n    if (await fs.pathExists(dir)) {\n      await fs.remove(dir);\n    }\n    return fs.mkdirs(dir);\n  }\n\n  /**\n   * Ensures the path to the file exists and the file does not exist\n   *\n   * I.e. If the file already exists it is deleted and the path created\n   */\n  async ensureFile(file: string): Promise<void> {\n    if (await fs.pathExists(file)) {\n      await fs.remove(file);\n    }\n    await fs.mkdirs(path.dirname(file));\n  }\n\n  /**\n   * Checks if the specified binaries exist, which are required for the maker to be used.\n   */\n  externalBinariesExist(): boolean {\n    return this.requiredExternalBinaries.every((binary) => which.sync(binary, { nothrow: true }) !== null);\n  }\n\n  /**\n   * Throws an error if any of the binaries don't exist.\n   */\n  ensureExternalBinariesExist(): void {\n    if (!this.externalBinariesExist()) {\n      throw new Error(`Cannot make for ${this.name}, the following external binaries need to be installed: ${this.requiredExternalBinaries.join(', ')}`);\n    }\n  }\n\n  /**\n   * Checks if the given module is installed, used for testing if optional dependencies\n   * are installed or not\n   */\n  isInstalled(module: string): boolean {\n    try {\n      require(module);\n      return true;\n    } catch (e) {\n      // Package doesn't exist -- must not be installable on this platform\n      return false;\n    }\n  }\n\n  /**\n   * Normalize the given semver-formatted version to a 4-part dot delimited version number without\n   * prerelease information for use in Windows apps.\n   */\n  normalizeWindowsVersion(version: string): string {\n    const noPrerelease = version.replace(/-.*/, '');\n    return `${noPrerelease}.0`;\n  }\n}\n\nexport { Maker as MakerBase };\n"],"names":["Maker","configOrConfigFetcher","platformsToMakeOn","requiredExternalBinaries","Object","defineProperty","value","enumerable","configurable","platforms","defaultPlatforms","prepareConfig","targetArch","config","isSupportedOnCurrentPlatform","prototype","Error","name","make","opts","ensureDirectory","dir","fs","pathExists","remove","mkdirs","ensureFile","file","path","dirname","externalBinariesExist","every","binary","which","sync","nothrow","ensureExternalBinariesExist","join","isInstalled","module","require","e","normalizeWindowsVersion","version","noPrerelease","replace","MakerBase"],"mappings":"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"}
package/index.ts ADDED
@@ -0,0 +1,5 @@
1
+ // ⚠️ AUTOGENERATED ⚠️ AUTOGENERATED ⚠️ AUTOGENERATED ⚠️
2
+ // This file was automatically generated by `tools/gen-ts-glue.ts`. Do not modify directly if you want to keep your changes.
3
+ export * from "./src/Maker";
4
+ import defaultExport from "./src/Maker";
5
+ export default defaultExport;
package/package.json CHANGED
@@ -1,24 +1,23 @@
1
1
  {
2
2
  "name": "@electron-forge/maker-base",
3
- "version": "6.0.0-beta.7",
3
+ "version": "6.0.0-beta.70",
4
4
  "description": "Base maker for Electron Forge",
5
- "repository": "https://github.com/electron-userland/electron-forge",
5
+ "repository": "https://github.com/electron/forge",
6
6
  "author": "Samuel Attard",
7
7
  "license": "MIT",
8
8
  "main": "dist/Maker.js",
9
9
  "typings": "dist/Maker.d.ts",
10
- "scripts": {
11
- "test": "mocha --require ts-node/register test/**/*_spec.ts test/**/**/*_spec.ts --opts ../../../mocha.opts"
12
- },
13
10
  "devDependencies": {
14
- "chai": "^4.0.0",
15
- "mocha": "^5.0.0"
11
+ "chai": "^4.3.3",
12
+ "mocha": "^9.0.1",
13
+ "sinon": "^13.0.1"
16
14
  },
17
15
  "engines": {
18
- "node": ">= 6.0"
16
+ "node": ">= 14.17.5"
19
17
  },
20
18
  "dependencies": {
21
- "@electron-forge/shared-types": "6.0.0-beta.7",
22
- "fs-extra": "^5.0.0"
19
+ "@electron-forge/shared-types": "6.0.0-beta.70",
20
+ "fs-extra": "^10.0.0",
21
+ "which": "^2.0.2"
23
22
  }
24
23
  }
package/src/Maker.ts CHANGED
@@ -1,8 +1,10 @@
1
- /* eslint-disable no-unused-vars */
1
+ import path from 'path';
2
2
 
3
- import { ForgeArch, ForgeConfig, ForgePlatform, IForgeMaker } from '@electron-forge/shared-types';
3
+ import { ForgeArch, ForgePlatform, IForgeMaker, ResolvedForgeConfig } from '@electron-forge/shared-types';
4
4
  import fs from 'fs-extra';
5
- import path from 'path';
5
+ import which from 'which';
6
+
7
+ export type EmptyConfig = Record<string, never>;
6
8
 
7
9
  export interface MakerOptions {
8
10
  /**
@@ -29,21 +31,30 @@ export interface MakerOptions {
29
31
  /**
30
32
  * Fully resolved forge configuration, you shouldn't really need this
31
33
  */
32
- forgeConfig: ForgeConfig;
34
+ forgeConfig: ResolvedForgeConfig;
33
35
  /**
34
- * The applications package.json file
36
+ * The application's package.json file
35
37
  */
36
- packageJSON: any;
38
+ packageJSON: any; // eslint-disable-line @typescript-eslint/no-explicit-any
37
39
  }
38
40
 
39
- export default abstract class Maker<C> {
41
+ export default abstract class Maker<C> implements IForgeMaker {
42
+ public config!: C;
43
+
40
44
  public abstract name: string;
45
+
41
46
  public abstract defaultPlatforms: ForgePlatform[];
42
- /* tslint:disable variable-name */
47
+
48
+ public requiredExternalBinaries: string[] = [];
49
+
50
+ /** @internal */
43
51
  __isElectronForgeMaker!: true;
44
- /* tslint:enable variable-name */
45
52
 
46
- constructor(public config: C = {} as C, protected providedPlatforms?: ForgePlatform[]) {
53
+ /**
54
+ * @param configOrConfigFetcher - Either a configuration object for this maker or a simple method that returns such a configuration for a given target architecture
55
+ * @param platformsToMakeOn - If you want this maker to run on platforms different from `defaultPlatforms` you can provide those platforms here
56
+ */
57
+ constructor(private configOrConfigFetcher: C | ((arch: ForgeArch) => C) = {} as C, protected platformsToMakeOn?: ForgePlatform[]) {
47
58
  Object.defineProperty(this, '__isElectronForgeMaker', {
48
59
  value: true,
49
60
  enumerable: false,
@@ -51,11 +62,21 @@ export default abstract class Maker<C> {
51
62
  });
52
63
  }
53
64
 
54
- get platforms() {
55
- if (this.providedPlatforms) return this.providedPlatforms;
65
+ get platforms(): ForgePlatform[] {
66
+ if (this.platformsToMakeOn) return this.platformsToMakeOn;
56
67
  return this.defaultPlatforms;
57
68
  }
58
69
 
70
+ // TODO: Remove this, it is an eye-sore and is a nasty hack to provide forge
71
+ // v5 style functionality in the new API
72
+ prepareConfig(targetArch: ForgeArch): void {
73
+ if (typeof this.configOrConfigFetcher === 'function') {
74
+ this.config = (this.configOrConfigFetcher as unknown as (arch: ForgeArch) => C)(targetArch);
75
+ } else {
76
+ this.config = this.configOrConfigFetcher as C;
77
+ }
78
+ }
79
+
59
80
  /**
60
81
  * Makers must implement this method and return true or false indicating whether
61
82
  * this maker can be run on the current platform. Normally this is just a process.platform
@@ -66,18 +87,24 @@ export default abstract class Maker<C> {
66
87
  * telling the developer exactly what is missing and if possible how to get it.
67
88
  */
68
89
  isSupportedOnCurrentPlatform(): boolean {
69
- throw new Error(`Maker ${this.name} did not implement the isSupportedOnCurrentPlatform method`);
90
+ if (this.isSupportedOnCurrentPlatform === Maker.prototype.isSupportedOnCurrentPlatform) {
91
+ throw new Error(`Maker ${this.name} did not implement the isSupportedOnCurrentPlatform method`);
92
+ }
93
+ return true;
70
94
  }
71
95
 
72
96
  /**
73
97
  * Makers must implement this method and return an array of absolute paths
74
98
  * to the artifacts generated by your maker
75
99
  */
100
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars
76
101
  async make(opts: MakerOptions): Promise<string[]> {
77
- throw new Error(`Maker ${this.name} did not implement the make method`);
102
+ if (this.make === Maker.prototype.make) {
103
+ throw new Error(`Maker ${this.name} did not implement the make method`);
104
+ }
105
+ return [];
78
106
  }
79
107
 
80
-
81
108
  /**
82
109
  * Helpers
83
110
  */
@@ -107,6 +134,22 @@ export default abstract class Maker<C> {
107
134
  await fs.mkdirs(path.dirname(file));
108
135
  }
109
136
 
137
+ /**
138
+ * Checks if the specified binaries exist, which are required for the maker to be used.
139
+ */
140
+ externalBinariesExist(): boolean {
141
+ return this.requiredExternalBinaries.every((binary) => which.sync(binary, { nothrow: true }) !== null);
142
+ }
143
+
144
+ /**
145
+ * Throws an error if any of the binaries don't exist.
146
+ */
147
+ ensureExternalBinariesExist(): void {
148
+ if (!this.externalBinariesExist()) {
149
+ throw new Error(`Cannot make for ${this.name}, the following external binaries need to be installed: ${this.requiredExternalBinaries.join(', ')}`);
150
+ }
151
+ }
152
+
110
153
  /**
111
154
  * Checks if the given module is installed, used for testing if optional dependencies
112
155
  * are installed or not
@@ -120,4 +163,15 @@ export default abstract class Maker<C> {
120
163
  return false;
121
164
  }
122
165
  }
166
+
167
+ /**
168
+ * Normalize the given semver-formatted version to a 4-part dot delimited version number without
169
+ * prerelease information for use in Windows apps.
170
+ */
171
+ normalizeWindowsVersion(version: string): string {
172
+ const noPrerelease = version.replace(/-.*/, '');
173
+ return `${noPrerelease}.0`;
174
+ }
123
175
  }
176
+
177
+ export { Maker as MakerBase };
@@ -0,0 +1,42 @@
1
+ import { expect } from 'chai';
2
+ import { stub } from 'sinon';
3
+
4
+ import { MakerBase } from '../src/Maker';
5
+
6
+ class MakerImpl extends MakerBase<{ a: number }> {
7
+ name = 'test';
8
+
9
+ defaultPlatforms = [];
10
+ }
11
+
12
+ describe('prepareConfig', () => {
13
+ it('should call the provided configure function', () => {
14
+ const fetcher = stub();
15
+ fetcher.returns({
16
+ a: 123,
17
+ });
18
+ const maker = new MakerImpl(fetcher, []);
19
+ expect(maker.config).to.be.undefined;
20
+ expect(fetcher.callCount).to.equal(0);
21
+ maker.prepareConfig('x64');
22
+ expect(maker.config).to.deep.equal({
23
+ a: 123,
24
+ });
25
+ expect(fetcher.callCount).to.equal(1);
26
+ expect(fetcher.firstCall.args).to.deep.equal(['x64']);
27
+ });
28
+
29
+ it('should hand through the provided object', () => {
30
+ const maker = new MakerImpl(
31
+ {
32
+ a: 234,
33
+ },
34
+ []
35
+ );
36
+ expect(maker.config).to.be.undefined;
37
+ maker.prepareConfig('x64');
38
+ expect(maker.config).to.deep.equal({
39
+ a: 234,
40
+ });
41
+ });
42
+ });
@@ -1,12 +1,14 @@
1
- import { expect } from 'chai';
2
- import fs from 'fs-extra';
3
1
  import os from 'os';
4
2
  import path from 'path';
5
3
 
6
- import MakerBase from '../src/Maker';
4
+ import { expect } from 'chai';
5
+ import fs from 'fs-extra';
6
+
7
+ import { EmptyConfig, MakerBase } from '../src/Maker';
7
8
 
8
- class MakerImpl extends MakerBase<{}> {
9
+ class MakerImpl extends MakerBase<EmptyConfig> {
9
10
  name = 'test';
11
+
10
12
  defaultPlatforms = [];
11
13
  }
12
14
 
@@ -0,0 +1,19 @@
1
+ import { expect } from 'chai';
2
+
3
+ import { EmptyConfig, MakerBase } from '../src/Maker';
4
+
5
+ class MakerImpl extends MakerBase<EmptyConfig> {
6
+ name = 'test';
7
+
8
+ defaultPlatforms = [];
9
+
10
+ requiredExternalBinaries = ['bash', 'nonexistent'];
11
+ }
12
+
13
+ describe('ensureExternalBinariesExist', () => {
14
+ const maker = new MakerImpl({}, []);
15
+
16
+ it('throws an error when one of the binaries does not exist', () => {
17
+ expect(() => maker.ensureExternalBinariesExist()).to.throw(/the following external binaries need to be installed: bash, nonexistent/);
18
+ });
19
+ });
@@ -0,0 +1,22 @@
1
+ import { expect } from 'chai';
2
+
3
+ import { EmptyConfig, MakerBase } from '../src/Maker';
4
+
5
+ class MakerImpl extends MakerBase<EmptyConfig> {
6
+ name = 'test';
7
+
8
+ defaultPlatforms = [];
9
+ }
10
+
11
+ describe('normalizeWindowsVersion', () => {
12
+ const maker = new MakerImpl({}, []);
13
+
14
+ it('removes everything after the dash', () => {
15
+ for (const version of ['1.0.0-alpha', '1.0.0-alpha.1', '1.0.0-0.3.7', '1.0.0-x.7.z.92']) {
16
+ expect(maker.normalizeWindowsVersion(version)).to.equal('1.0.0.0');
17
+ }
18
+ });
19
+ it('does not truncate the version when there is no dash', () => {
20
+ expect(maker.normalizeWindowsVersion('2.0.0')).to.equal('2.0.0.0');
21
+ });
22
+ });