@akylas/nativescript-cli 8.8.2 → 8.8.4
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/lib/android-tools-info.js +9 -20
- package/lib/base-package-manager.js +47 -64
- package/lib/bun-package-manager.js +65 -88
- package/lib/color.js +2 -2
- package/lib/commands/add-platform.js +14 -30
- package/lib/commands/apple-login.js +18 -29
- package/lib/commands/appstore-list.js +34 -45
- package/lib/commands/appstore-upload.js +55 -68
- package/lib/commands/build.js +57 -86
- package/lib/commands/clean.js +161 -176
- package/lib/commands/command-base.js +14 -27
- package/lib/commands/config.js +51 -70
- package/lib/commands/create-project.js +210 -229
- package/lib/commands/debug.js +66 -88
- package/lib/commands/deploy.js +28 -44
- package/lib/commands/embedding/embed.js +33 -52
- package/lib/commands/extensibility/install-extension.js +5 -16
- package/lib/commands/extensibility/list-extensions.js +13 -24
- package/lib/commands/extensibility/uninstall-extension.js +4 -15
- package/lib/commands/fonts.js +30 -41
- package/lib/commands/generate-assets.js +13 -28
- package/lib/commands/generate-help.js +2 -13
- package/lib/commands/generate.js +17 -26
- package/lib/commands/info.js +2 -13
- package/lib/commands/install.js +34 -49
- package/lib/commands/list-platforms.js +14 -25
- package/lib/commands/migrate.js +15 -26
- package/lib/commands/native-add.js +23 -46
- package/lib/commands/platform-clean.js +19 -32
- package/lib/commands/plugin/add-plugin.js +12 -25
- package/lib/commands/plugin/build-plugin.js +34 -39
- package/lib/commands/plugin/create-plugin.js +110 -133
- package/lib/commands/plugin/list-plugins.js +22 -33
- package/lib/commands/plugin/remove-plugin.js +20 -33
- package/lib/commands/plugin/update-plugin.js +20 -33
- package/lib/commands/post-install.js +20 -33
- package/lib/commands/prepare.js +19 -35
- package/lib/commands/preview.js +49 -62
- package/lib/commands/remove-platform.js +7 -18
- package/lib/commands/resources/resources-update.js +13 -26
- package/lib/commands/run.js +55 -76
- package/lib/commands/start.js +6 -19
- package/lib/commands/test-init.js +123 -134
- package/lib/commands/test.js +66 -89
- package/lib/commands/typings.js +126 -142
- package/lib/commands/update-platform.js +22 -35
- package/lib/commands/update.js +30 -43
- package/lib/common/child-process.js +53 -72
- package/lib/common/codeGeneration/code-entity.js +1 -1
- package/lib/common/codeGeneration/code-printer.js +1 -1
- package/lib/common/command-params.js +7 -18
- package/lib/common/commands/analytics.js +27 -40
- package/lib/common/commands/autocompletion.js +39 -56
- package/lib/common/commands/device/device-log-stream.js +12 -23
- package/lib/common/commands/device/get-file.js +22 -33
- package/lib/common/commands/device/list-applications.js +12 -23
- package/lib/common/commands/device/list-devices.js +72 -87
- package/lib/common/commands/device/list-files.js +23 -34
- package/lib/common/commands/device/put-file.js +22 -33
- package/lib/common/commands/device/run-application.js +12 -25
- package/lib/common/commands/device/stop-application.js +11 -22
- package/lib/common/commands/device/uninstall-application.js +6 -17
- package/lib/common/commands/generate-messages.js +17 -28
- package/lib/common/commands/help.js +20 -33
- package/lib/common/commands/package-manager-get.js +6 -17
- package/lib/common/commands/package-manager-set.js +9 -20
- package/lib/common/commands/post-install.js +2 -13
- package/lib/common/commands/preuninstall.js +23 -38
- package/lib/common/commands/proxy/proxy-base.js +8 -19
- package/lib/common/commands/proxy/proxy-clear.js +4 -15
- package/lib/common/commands/proxy/proxy-get.js +3 -14
- package/lib/common/commands/proxy/proxy-set.js +87 -100
- package/lib/common/constants.js +11 -11
- package/lib/common/decorators.js +10 -22
- package/lib/common/dispatchers.js +79 -96
- package/lib/common/errors.js +89 -104
- package/lib/common/file-system.js +106 -127
- package/lib/common/header.js +1 -2
- package/lib/common/helpers.js +149 -178
- package/lib/common/host-info.js +37 -50
- package/lib/common/http-client.js +93 -108
- package/lib/common/logger/appenders/cli-appender.js +1 -2
- package/lib/common/logger/appenders/emit-appender.js +1 -2
- package/lib/common/logger/layouts/cli-layout.js +1 -2
- package/lib/common/logger/logger.js +1 -1
- package/lib/common/mobile/android/android-application-manager.js +121 -142
- package/lib/common/mobile/android/android-debug-bridge-result-handler.js +1 -1
- package/lib/common/mobile/android/android-debug-bridge.js +87 -112
- package/lib/common/mobile/android/android-device-file-system.js +98 -131
- package/lib/common/mobile/android/android-device-hash-service.js +50 -75
- package/lib/common/mobile/android/android-device.js +74 -91
- package/lib/common/mobile/android/android-emulator-services.js +105 -130
- package/lib/common/mobile/android/android-log-filter.js +1 -1
- package/lib/common/mobile/android/android-virtual-device-service.js +76 -97
- package/lib/common/mobile/android/device-android-debug-bridge.js +13 -29
- package/lib/common/mobile/android/genymotion/genymotion-service.js +91 -118
- package/lib/common/mobile/android/genymotion/virtualbox-service.js +64 -81
- package/lib/common/mobile/android/logcat-helper.js +108 -127
- package/lib/common/mobile/application-manager-base.js +84 -107
- package/lib/common/mobile/device-log-provider-base.js +7 -18
- package/lib/common/mobile/ios/device/ios-application-manager.js +79 -108
- package/lib/common/mobile/ios/device/ios-device-file-system.js +78 -105
- package/lib/common/mobile/ios/device/ios-device-operations.js +105 -142
- package/lib/common/mobile/ios/device/ios-device.js +20 -36
- package/lib/common/mobile/ios/ios-device-base.js +58 -81
- package/lib/common/mobile/ios/simulator/ios-emulator-services.js +63 -92
- package/lib/common/mobile/ios/simulator/ios-sim-resolver.js +1 -1
- package/lib/common/mobile/ios/simulator/ios-simulator-application-manager.js +60 -89
- package/lib/common/mobile/ios/simulator/ios-simulator-device.js +27 -43
- package/lib/common/mobile/ios/simulator/ios-simulator-file-system.js +37 -62
- package/lib/common/mobile/ios/simulator/ios-simulator-log-provider.js +24 -35
- package/lib/common/mobile/mobile-core/android-device-discovery.js +43 -62
- package/lib/common/mobile/mobile-core/android-emulator-discovery.js +21 -32
- package/lib/common/mobile/mobile-core/android-process-service.js +143 -182
- package/lib/common/mobile/mobile-core/device-discovery.js +2 -13
- package/lib/common/mobile/mobile-core/devices-service.js +385 -436
- package/lib/common/mobile/mobile-core/ios-device-discovery.js +24 -35
- package/lib/common/mobile/mobile-core/ios-simulator-discovery.js +47 -62
- package/lib/common/mobile/mobile-helper.js +15 -26
- package/lib/common/mobile/wp8/wp8-emulator-services.js +25 -52
- package/lib/common/opener.js +2 -2
- package/lib/common/plist-parser.js +3 -3
- package/lib/common/prompter.js +90 -105
- package/lib/common/queue.js +9 -20
- package/lib/common/services/auto-completion-service.js +39 -52
- package/lib/common/services/cancellation.js +17 -28
- package/lib/common/services/commands-service.js +146 -169
- package/lib/common/services/help-service.js +132 -157
- package/lib/common/services/hooks-service.js +93 -108
- package/lib/common/services/ios-notification-service.js +21 -34
- package/lib/common/services/json-file-settings-service.js +52 -71
- package/lib/common/services/lock-service.js +35 -52
- package/lib/common/services/message-contract-generator.js +35 -46
- package/lib/common/services/micro-templating-service.js +4 -15
- package/lib/common/services/net-service.js +90 -107
- package/lib/common/services/project-files-manager.js +10 -23
- package/lib/common/services/proxy-service.js +13 -24
- package/lib/common/services/qr.js +13 -24
- package/lib/common/services/settings-service.js +1 -1
- package/lib/common/services/xcode-select-service.js +20 -35
- package/lib/common/utils.js +2 -2
- package/lib/common/validators/project-name-validator.js +1 -1
- package/lib/common/validators/validation-result.js +1 -1
- package/lib/common/verify-node-version.js +2 -3
- package/lib/common/yok.js +23 -36
- package/lib/config.js +7 -58
- package/lib/constants.js +24 -24
- package/lib/controllers/build-controller.js +82 -99
- package/lib/controllers/debug-controller.js +107 -128
- package/lib/controllers/deploy-controller.js +17 -22
- package/lib/controllers/migrate-controller.js +722 -795
- package/lib/controllers/platform-controller.js +72 -87
- package/lib/controllers/prepare-controller.js +266 -299
- package/lib/controllers/run-controller.js +392 -406
- package/lib/controllers/update-controller-base.js +16 -29
- package/lib/controllers/update-controller.js +94 -119
- package/lib/data/prepare-data.js +4 -1
- package/lib/definitions/ios-debugger-port-service.d.ts +1 -1
- package/lib/definitions/livesync.d.ts +1 -1
- package/lib/detached-processes/cleanup-js-subprocess.js +3 -12
- package/lib/detached-processes/cleanup-process.js +16 -25
- package/lib/device-path-provider.js +23 -34
- package/lib/device-sockets/ios/app-debug-socket-proxy-factory.js +149 -164
- package/lib/device-sockets/ios/notification.js +1 -1
- package/lib/device-sockets/ios/socket-request-executor.js +24 -39
- package/lib/helpers/android-bundle-validator-helper.js +1 -1
- package/lib/helpers/deploy-command-helper.js +45 -49
- package/lib/helpers/key-command-helper.js +4 -13
- package/lib/helpers/livesync-command-helper.js +137 -152
- package/lib/helpers/network-connectivity-validator.js +6 -17
- package/lib/helpers/options-track-helper.js +6 -17
- package/lib/helpers/platform-command-helper.js +99 -120
- package/lib/key-commands/index.js +161 -211
- package/lib/nativescript-cli.js +5 -14
- package/lib/node-package-manager.js +81 -104
- package/lib/options.js +3 -12
- package/lib/package-installation-manager.js +130 -165
- package/lib/package-manager.js +63 -86
- package/lib/platform-command-param.js +4 -15
- package/lib/pnpm-package-manager.js +59 -78
- package/lib/project-data.js +1 -1
- package/lib/providers/project-files-provider.js +1 -1
- package/lib/services/analytics/analytics-broker-process.js +13 -22
- package/lib/services/analytics/analytics-broker.js +17 -30
- package/lib/services/analytics/analytics-service.js +161 -198
- package/lib/services/analytics/google-analytics-provider.js +41 -56
- package/lib/services/analytics-settings-service.js +15 -32
- package/lib/services/android/android-bundle-tool-service.js +43 -60
- package/lib/services/android/gradle-build-args-service.js +9 -20
- package/lib/services/android/gradle-build-service.js +34 -47
- package/lib/services/android/gradle-command-service.js +22 -35
- package/lib/services/android-device-debug-service.js +90 -117
- package/lib/services/android-plugin-build-service.js +230 -256
- package/lib/services/android-project-service.js +163 -199
- package/lib/services/android-resources-migration-service.js +51 -64
- package/lib/services/apple-portal/apple-portal-application-service.js +46 -63
- package/lib/services/apple-portal/apple-portal-session-service.js +171 -188
- package/lib/services/assets-generation/assets-generation-service.js +98 -115
- package/lib/services/build-artifacts-service.js +9 -20
- package/lib/services/build-info-file-service.js +20 -35
- package/lib/services/cleanup-service.js +47 -76
- package/lib/services/cocoapods-service.js +115 -136
- package/lib/services/device/device-install-app-service.js +73 -90
- package/lib/services/doctor-service.js +99 -118
- package/lib/services/extensibility-service.js +81 -100
- package/lib/services/files-hash-service.js +26 -43
- package/lib/services/hmr-status-service.js +1 -1
- package/lib/services/initialize-service.js +37 -50
- package/lib/services/ios/export-options-plist-service.js +38 -51
- package/lib/services/ios/ios-signing-service.js +161 -180
- package/lib/services/ios/spm-service.js +40 -53
- package/lib/services/ios/xcodebuild-args-service.js +77 -94
- package/lib/services/ios/xcodebuild-command-service.js +14 -25
- package/lib/services/ios/xcodebuild-service.js +50 -69
- package/lib/services/ios-debugger-port-service.js +23 -36
- package/lib/services/ios-device-debug-service.js +75 -102
- package/lib/services/ios-entitlements-service.js +31 -42
- package/lib/services/ios-extensions-service.js +18 -29
- package/lib/services/ios-project-service.js +405 -460
- package/lib/services/ios-provision-service.js +108 -129
- package/lib/services/ios-watch-app-service.js +21 -32
- package/lib/services/ip-service.js +38 -53
- package/lib/services/itmstransporter-service.js +129 -152
- package/lib/services/livesync/android-device-livesync-service-base.js +31 -48
- package/lib/services/livesync/android-device-livesync-service.js +120 -149
- package/lib/services/livesync/android-device-livesync-sockets-service.js +121 -152
- package/lib/services/livesync/android-livesync-service.js +14 -35
- package/lib/services/livesync/android-livesync-tool.js +89 -112
- package/lib/services/livesync/device-livesync-service-base.js +15 -28
- package/lib/services/livesync/ios-device-livesync-service.js +114 -143
- package/lib/services/livesync/ios-livesync-service.js +42 -58
- package/lib/services/livesync/platform-livesync-service-base.js +94 -119
- package/lib/services/log-parser-service.js +1 -1
- package/lib/services/log-source-map-service.js +30 -41
- package/lib/services/marking-mode-service.js +15 -28
- package/lib/services/npm-config-service.js +1 -1
- package/lib/services/pacote-service.js +49 -64
- package/lib/services/performance-service.js +1 -1
- package/lib/services/platform/add-platform-service.js +50 -71
- package/lib/services/platform/platform-validation-service.js +22 -33
- package/lib/services/platform/prepare-native-platform-service.js +49 -62
- package/lib/services/platform-environment-requirements.js +26 -37
- package/lib/services/plugins-service.js +122 -147
- package/lib/services/project-backup-service.js +1 -1
- package/lib/services/project-changes-service.js +124 -141
- package/lib/services/project-cleanup-service.js +64 -77
- package/lib/services/project-config-service.js +71 -80
- package/lib/services/project-data-service.js +101 -118
- package/lib/services/project-name-service.js +28 -43
- package/lib/services/project-service.js +84 -103
- package/lib/services/project-templates-service.js +52 -67
- package/lib/services/start-service.js +41 -59
- package/lib/services/temp-service.js +8 -21
- package/lib/services/terminal-spinner-service.js +13 -24
- package/lib/services/test-execution-service.js +59 -72
- package/lib/services/test-initialization-service.js +2 -2
- package/lib/services/timeline-profiler-service.js +1 -1
- package/lib/services/versions-service.js +119 -138
- package/lib/services/webpack/webpack-compiler-service.js +211 -231
- package/lib/services/xcconfig-service.js +8 -19
- package/lib/sys-info.js +45 -62
- package/lib/tools/node-modules/node-modules-builder.js +16 -27
- package/lib/yarn-package-manager.js +59 -78
- package/lib/yarn2-package-manager.js +60 -79
- package/package.json +56 -54
- package/vendor/aab-tool/bundletool.jar +0 -0
- package/lib/common/resources/platform-tools/android/darwin/NOTICE.txt +0 -3407
- package/lib/common/resources/platform-tools/android/darwin/adb +0 -0
- package/lib/common/resources/platform-tools/android/linux/NOTICE.txt +0 -4451
- package/lib/common/resources/platform-tools/android/linux/adb +0 -0
- package/lib/common/resources/platform-tools/android/win32/AdbWinApi.dll +0 -0
- package/lib/common/resources/platform-tools/android/win32/AdbWinUsbApi.dll +0 -0
- package/lib/common/resources/platform-tools/android/win32/NOTICE.txt +0 -4451
- package/lib/common/resources/platform-tools/android/win32/adb.exe +0 -0
- package/lib/common/resources/platform-tools/android/win32/fastboot.exe +0 -0
|
@@ -1,13 +1,4 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
-
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
|
-
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
|
-
return new (P || (P = Promise))(function (resolve, reject) {
|
|
5
|
-
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
6
|
-
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
7
|
-
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
8
|
-
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
|
-
});
|
|
10
|
-
};
|
|
11
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
3
|
const path = require("path");
|
|
13
4
|
const _ = require("lodash");
|
|
@@ -33,135 +24,133 @@ class TestInitCommand {
|
|
|
33
24
|
};
|
|
34
25
|
this.$projectData.initializeProjectData();
|
|
35
26
|
}
|
|
36
|
-
execute(args) {
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
path: this.$options.path,
|
|
68
|
-
});
|
|
69
|
-
const modulePath = path.join(projectDir, "node_modules", mod.name);
|
|
70
|
-
const modulePackageJsonPath = path.join(modulePath, "package.json");
|
|
71
|
-
const modulePackageJsonContent = this.$fs.readJson(modulePackageJsonPath);
|
|
72
|
-
const modulePeerDependencies = modulePackageJsonContent.peerDependencies || {};
|
|
73
|
-
for (const peerDependency in modulePeerDependencies) {
|
|
74
|
-
const isPeerDependencyExcluded = _.includes(mod.excludedPeerDependencies, peerDependency);
|
|
75
|
-
if (isPeerDependencyExcluded) {
|
|
76
|
-
continue;
|
|
77
|
-
}
|
|
78
|
-
const dependencyVersion = modulePeerDependencies[peerDependency] || "*";
|
|
79
|
-
try {
|
|
80
|
-
yield this.$packageManager.install(`${peerDependency}@${dependencyVersion}`, projectDir, {
|
|
81
|
-
"save-dev": true,
|
|
82
|
-
"save-exact": true,
|
|
83
|
-
disableNpmInstall: false,
|
|
84
|
-
frameworkPath: this.$options.frameworkPath,
|
|
85
|
-
ignoreScripts: this.$options.ignoreScripts,
|
|
86
|
-
path: this.$options.path,
|
|
87
|
-
});
|
|
88
|
-
}
|
|
89
|
-
catch (e) {
|
|
90
|
-
this.$logger.error(e.message);
|
|
91
|
-
}
|
|
92
|
-
}
|
|
93
|
-
}
|
|
94
|
-
yield this.$pluginsService.add("@nativescript/unit-test-runner", this.$projectData);
|
|
95
|
-
this.$logger.clearScreen();
|
|
96
|
-
const bufferedLogs = [];
|
|
97
|
-
const testsDir = path.join(this.$projectData.appDirectoryPath, "tests");
|
|
98
|
-
const projectTestsDir = path.relative(this.$projectData.projectDir, testsDir);
|
|
99
|
-
const relativeTestsDir = path.relative(this.$projectData.appDirectoryPath, testsDir);
|
|
100
|
-
let shouldCreateSampleTests = true;
|
|
101
|
-
if (this.$fs.exists(testsDir)) {
|
|
102
|
-
const specFilenamePattern = `<filename>.spec${projectFilesExtension}`;
|
|
103
|
-
bufferedLogs.push(color_1.color.yellow([
|
|
104
|
-
`Note: The "${projectTestsDir}" directory already exists, will not create example tests in the project.`,
|
|
105
|
-
`You may create "${specFilenamePattern}" files anywhere you'd like.`,
|
|
106
|
-
"",
|
|
107
|
-
].join("\n")));
|
|
108
|
-
shouldCreateSampleTests = false;
|
|
109
|
-
}
|
|
110
|
-
this.$fs.ensureDirectoryExists(testsDir);
|
|
111
|
-
const frameworks = [frameworkToInstall]
|
|
112
|
-
.concat(this.karmaConfigAdditionalFrameworks[frameworkToInstall] || [])
|
|
113
|
-
.map((fw) => `'${fw}'`)
|
|
114
|
-
.join(", ");
|
|
115
|
-
const testFiles = `'${(0, helpers_1.fromWindowsRelativePathToUnix)(relativeTestsDir)}/**/*${projectFilesExtension}'`;
|
|
116
|
-
const karmaConfTemplate = this.$resources.readText("test/karma.conf.js");
|
|
117
|
-
const karmaConf = _.template(karmaConfTemplate)({
|
|
118
|
-
frameworks,
|
|
119
|
-
testFiles,
|
|
120
|
-
basePath: this.$projectData.getAppDirectoryRelativePath(),
|
|
27
|
+
async execute(args) {
|
|
28
|
+
const projectDir = this.$projectData.projectDir;
|
|
29
|
+
const frameworkToInstall = this.$options.framework ||
|
|
30
|
+
(await this.$prompter.promptForChoice("Select testing framework:", constants_1.TESTING_FRAMEWORKS));
|
|
31
|
+
if (constants_1.TESTING_FRAMEWORKS.indexOf(frameworkToInstall) === -1) {
|
|
32
|
+
this.$errors.failWithHelp(`Unknown or unsupported unit testing framework: ${frameworkToInstall}.`);
|
|
33
|
+
}
|
|
34
|
+
const projectFilesExtension = this.$projectData.projectType === constants_1.ProjectTypes.TsFlavorName ||
|
|
35
|
+
this.$projectData.projectType === constants_1.ProjectTypes.NgFlavorName
|
|
36
|
+
? ".ts"
|
|
37
|
+
: ".js";
|
|
38
|
+
let modulesToInstall = [];
|
|
39
|
+
try {
|
|
40
|
+
modulesToInstall = this.$testInitializationService.getDependencies(frameworkToInstall);
|
|
41
|
+
}
|
|
42
|
+
catch (err) {
|
|
43
|
+
this.$errors.fail(`Unable to install the unit testing dependencies. Error: '${err.message}'`);
|
|
44
|
+
}
|
|
45
|
+
modulesToInstall = modulesToInstall.filter((moduleToInstall) => !moduleToInstall.projectType ||
|
|
46
|
+
moduleToInstall.projectType === projectFilesExtension);
|
|
47
|
+
for (const mod of modulesToInstall) {
|
|
48
|
+
let moduleToInstall = mod.name;
|
|
49
|
+
moduleToInstall += `@${mod.version}`;
|
|
50
|
+
await this.$packageManager.install(moduleToInstall, projectDir, {
|
|
51
|
+
"save-dev": true,
|
|
52
|
+
"save-exact": true,
|
|
53
|
+
optional: false,
|
|
54
|
+
disableNpmInstall: this.$options.disableNpmInstall,
|
|
55
|
+
frameworkPath: this.$options.frameworkPath,
|
|
56
|
+
ignoreScripts: this.$options.ignoreScripts,
|
|
57
|
+
path: this.$options.path,
|
|
121
58
|
});
|
|
122
|
-
|
|
123
|
-
const
|
|
124
|
-
const
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
const
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
59
|
+
const modulePath = path.join(projectDir, "node_modules", mod.name);
|
|
60
|
+
const modulePackageJsonPath = path.join(modulePath, "package.json");
|
|
61
|
+
const modulePackageJsonContent = this.$fs.readJson(modulePackageJsonPath);
|
|
62
|
+
const modulePeerDependencies = modulePackageJsonContent.peerDependencies || {};
|
|
63
|
+
for (const peerDependency in modulePeerDependencies) {
|
|
64
|
+
const isPeerDependencyExcluded = _.includes(mod.excludedPeerDependencies, peerDependency);
|
|
65
|
+
if (isPeerDependencyExcluded) {
|
|
66
|
+
continue;
|
|
67
|
+
}
|
|
68
|
+
const dependencyVersion = modulePeerDependencies[peerDependency] || "*";
|
|
69
|
+
try {
|
|
70
|
+
await this.$packageManager.install(`${peerDependency}@${dependencyVersion}`, projectDir, {
|
|
71
|
+
"save-dev": true,
|
|
72
|
+
"save-exact": true,
|
|
73
|
+
disableNpmInstall: false,
|
|
74
|
+
frameworkPath: this.$options.frameworkPath,
|
|
75
|
+
ignoreScripts: this.$options.ignoreScripts,
|
|
76
|
+
path: this.$options.path,
|
|
77
|
+
});
|
|
78
|
+
}
|
|
79
|
+
catch (e) {
|
|
80
|
+
this.$logger.error(e.message);
|
|
81
|
+
}
|
|
136
82
|
}
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
"",
|
|
151
|
-
...bufferedLogs,
|
|
152
|
-
"",
|
|
153
|
-
color_1.color.yellow(`Note: @nativescript/unit-test-runner was included in "dependencies" as a convenience to automatically adjust your app's Info.plist on iOS and AndroidManifest.xml on Android to ensure the socket connects properly.`),
|
|
154
|
-
"",
|
|
155
|
-
color_1.color.yellow(`For production you may want to move to "devDependencies" and manage the settings yourself.`),
|
|
83
|
+
}
|
|
84
|
+
await this.$pluginsService.add("@nativescript/unit-test-runner", this.$projectData);
|
|
85
|
+
this.$logger.clearScreen();
|
|
86
|
+
const bufferedLogs = [];
|
|
87
|
+
const testsDir = path.join(this.$projectData.appDirectoryPath, "tests");
|
|
88
|
+
const projectTestsDir = path.relative(this.$projectData.projectDir, testsDir);
|
|
89
|
+
const relativeTestsDir = path.relative(this.$projectData.appDirectoryPath, testsDir);
|
|
90
|
+
let shouldCreateSampleTests = true;
|
|
91
|
+
if (this.$fs.exists(testsDir)) {
|
|
92
|
+
const specFilenamePattern = `<filename>.spec${projectFilesExtension}`;
|
|
93
|
+
bufferedLogs.push(color_1.color.yellow([
|
|
94
|
+
`Note: The "${projectTestsDir}" directory already exists, will not create example tests in the project.`,
|
|
95
|
+
`You may create "${specFilenamePattern}" files anywhere you'd like.`,
|
|
156
96
|
"",
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
97
|
+
].join("\n")));
|
|
98
|
+
shouldCreateSampleTests = false;
|
|
99
|
+
}
|
|
100
|
+
this.$fs.ensureDirectoryExists(testsDir);
|
|
101
|
+
const frameworks = [frameworkToInstall]
|
|
102
|
+
.concat(this.karmaConfigAdditionalFrameworks[frameworkToInstall] || [])
|
|
103
|
+
.map((fw) => `'${fw}'`)
|
|
104
|
+
.join(", ");
|
|
105
|
+
const testFiles = `'${(0, helpers_1.fromWindowsRelativePathToUnix)(relativeTestsDir)}/**/*${projectFilesExtension}'`;
|
|
106
|
+
const karmaConfTemplate = this.$resources.readText("test/karma.conf.js");
|
|
107
|
+
const karmaConf = _.template(karmaConfTemplate)({
|
|
108
|
+
frameworks,
|
|
109
|
+
testFiles,
|
|
110
|
+
basePath: this.$projectData.getAppDirectoryRelativePath(),
|
|
111
|
+
});
|
|
112
|
+
this.$fs.writeFile(path.join(projectDir, "karma.conf.js"), karmaConf);
|
|
113
|
+
const exampleFilePath = this.$resources.resolvePath(`test/example.${frameworkToInstall}${projectFilesExtension}`);
|
|
114
|
+
const targetExampleTestPath = path.join(testsDir, `example.spec${projectFilesExtension}`);
|
|
115
|
+
if (shouldCreateSampleTests && this.$fs.exists(exampleFilePath)) {
|
|
116
|
+
this.$fs.copyFile(exampleFilePath, targetExampleTestPath);
|
|
117
|
+
const targetExampleTestRelativePath = path.relative(projectDir, targetExampleTestPath);
|
|
118
|
+
bufferedLogs.push(`Added example test: ${color_1.color.yellow(targetExampleTestRelativePath)}`);
|
|
119
|
+
}
|
|
120
|
+
const testMainResourcesPath = this.$resources.resolvePath(`test/test-main${projectFilesExtension}`);
|
|
121
|
+
const testMainPath = path.join(this.$projectData.appDirectoryPath, `test${projectFilesExtension}`);
|
|
122
|
+
if (!this.$fs.exists(testMainPath)) {
|
|
123
|
+
this.$fs.copyFile(testMainResourcesPath, testMainPath);
|
|
124
|
+
const testMainRelativePath = path.relative(projectDir, testMainPath);
|
|
125
|
+
bufferedLogs.push(`Main test entrypoint created: ${color_1.color.yellow(testMainRelativePath)}`);
|
|
126
|
+
}
|
|
127
|
+
const testTsConfigTemplate = this.$resources.readText("test/tsconfig.spec.json");
|
|
128
|
+
const testTsConfig = _.template(testTsConfigTemplate)({
|
|
129
|
+
basePath: this.$projectData.getAppDirectoryRelativePath(),
|
|
164
130
|
});
|
|
131
|
+
this.$fs.writeFile(path.join(projectDir, "tsconfig.spec.json"), testTsConfig);
|
|
132
|
+
bufferedLogs.push(`Added/replaced ${color_1.color.yellow("tsconfig.spec.json")}`);
|
|
133
|
+
const greyDollarSign = color_1.color.grey("$");
|
|
134
|
+
this.$logger.info([
|
|
135
|
+
[
|
|
136
|
+
color_1.color.green(`Tests using`),
|
|
137
|
+
color_1.color.cyan(frameworkToInstall),
|
|
138
|
+
color_1.color.green(`were successfully initialized.`),
|
|
139
|
+
].join(" "),
|
|
140
|
+
"",
|
|
141
|
+
...bufferedLogs,
|
|
142
|
+
"",
|
|
143
|
+
color_1.color.yellow(`Note: @nativescript/unit-test-runner was included in "dependencies" as a convenience to automatically adjust your app's Info.plist on iOS and AndroidManifest.xml on Android to ensure the socket connects properly.`),
|
|
144
|
+
"",
|
|
145
|
+
color_1.color.yellow(`For production you may want to move to "devDependencies" and manage the settings yourself.`),
|
|
146
|
+
"",
|
|
147
|
+
"",
|
|
148
|
+
`You can now run your tests:`,
|
|
149
|
+
"",
|
|
150
|
+
` ${greyDollarSign} ${color_1.color.green("ns test ios")}`,
|
|
151
|
+
` ${greyDollarSign} ${color_1.color.green("ns test android")}`,
|
|
152
|
+
"",
|
|
153
|
+
].join("\n"));
|
|
165
154
|
}
|
|
166
155
|
}
|
|
167
156
|
yok_1.injector.registerCommand("test|init", TestInitCommand);
|
package/lib/commands/test.js
CHANGED
|
@@ -1,13 +1,4 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
-
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
|
-
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
|
-
return new (P || (P = Promise))(function (resolve, reject) {
|
|
5
|
-
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
6
|
-
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
7
|
-
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
8
|
-
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
|
-
});
|
|
10
|
-
};
|
|
11
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
3
|
const helpers_1 = require("../common/helpers");
|
|
13
4
|
const constants_1 = require("../constants");
|
|
@@ -19,67 +10,63 @@ class TestCommandBase {
|
|
|
19
10
|
hmr: { type: "boolean", default: false, hasSensitiveValue: false },
|
|
20
11
|
};
|
|
21
12
|
}
|
|
22
|
-
execute(args) {
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
process.exit(0);
|
|
53
|
-
});
|
|
13
|
+
async execute(args) {
|
|
14
|
+
let devices = [];
|
|
15
|
+
if (this.$options.debugBrk) {
|
|
16
|
+
await this.$devicesService.initialize({
|
|
17
|
+
platform: this.platform,
|
|
18
|
+
deviceId: this.$options.device,
|
|
19
|
+
emulator: this.$options.emulator,
|
|
20
|
+
skipInferPlatform: !this.platform,
|
|
21
|
+
sdk: this.$options.sdk,
|
|
22
|
+
});
|
|
23
|
+
const selectedDeviceForDebug = await this.$devicesService.pickSingleDevice({
|
|
24
|
+
onlyEmulators: this.$options.emulator,
|
|
25
|
+
onlyDevices: this.$options.forDevice,
|
|
26
|
+
deviceId: this.$options.device,
|
|
27
|
+
});
|
|
28
|
+
devices = [selectedDeviceForDebug];
|
|
29
|
+
}
|
|
30
|
+
else {
|
|
31
|
+
devices = await this.$liveSyncCommandHelper.getDeviceInstances(this.platform);
|
|
32
|
+
}
|
|
33
|
+
if (!this.$options.env) {
|
|
34
|
+
this.$options.env = {};
|
|
35
|
+
}
|
|
36
|
+
this.$options.env.unitTesting = true;
|
|
37
|
+
const liveSyncInfo = this.$liveSyncCommandHelper.getLiveSyncData(this.$projectData.projectDir);
|
|
38
|
+
const deviceDebugMap = {};
|
|
39
|
+
devices.forEach((device) => (deviceDebugMap[device.deviceInfo.identifier] = this.$options.debugBrk));
|
|
40
|
+
const deviceDescriptors = await this.$liveSyncCommandHelper.createDeviceDescriptors(devices, this.platform, { deviceDebugMap });
|
|
41
|
+
await this.$testExecutionService.startKarmaServer(this.platform, liveSyncInfo, deviceDescriptors);
|
|
42
|
+
process.exit(0);
|
|
54
43
|
}
|
|
55
|
-
canExecute(args) {
|
|
56
|
-
|
|
57
|
-
if (
|
|
58
|
-
|
|
59
|
-
this.$errors.fail("The `--hmr` option is not supported for this command.");
|
|
60
|
-
}
|
|
61
|
-
yield this.$migrateController.validate({
|
|
62
|
-
projectDir: this.$projectData.projectDir,
|
|
63
|
-
platforms: [this.platform],
|
|
64
|
-
});
|
|
44
|
+
async canExecute(args) {
|
|
45
|
+
if (!this.$options.force) {
|
|
46
|
+
if (this.$options.hmr) {
|
|
47
|
+
this.$errors.fail("The `--hmr` option is not supported for this command.");
|
|
65
48
|
}
|
|
66
|
-
this.$
|
|
67
|
-
this.$analyticsService.setShouldDispose(this.$options.justlaunch || !this.$options.watch);
|
|
68
|
-
this.$cleanupService.setShouldDispose(this.$options.justlaunch || !this.$options.watch);
|
|
69
|
-
const output = yield this.$platformEnvironmentRequirements.checkEnvironmentRequirements({
|
|
70
|
-
platform: this.platform,
|
|
49
|
+
await this.$migrateController.validate({
|
|
71
50
|
projectDir: this.$projectData.projectDir,
|
|
72
|
-
|
|
51
|
+
platforms: [this.platform],
|
|
73
52
|
});
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
53
|
+
}
|
|
54
|
+
this.$projectData.initializeProjectData();
|
|
55
|
+
this.$analyticsService.setShouldDispose(this.$options.justlaunch || !this.$options.watch);
|
|
56
|
+
this.$cleanupService.setShouldDispose(this.$options.justlaunch || !this.$options.watch);
|
|
57
|
+
const output = await this.$platformEnvironmentRequirements.checkEnvironmentRequirements({
|
|
58
|
+
platform: this.platform,
|
|
59
|
+
projectDir: this.$projectData.projectDir,
|
|
60
|
+
options: this.$options,
|
|
82
61
|
});
|
|
62
|
+
const canStartKarmaServer = await this.$testExecutionService.canStartKarmaServer(this.$projectData);
|
|
63
|
+
if (!canStartKarmaServer) {
|
|
64
|
+
this.$errors.fail({
|
|
65
|
+
formatStr: "Error: In order to run unit tests, your project must already be configured by running $ ns test init.",
|
|
66
|
+
errorCode: 133,
|
|
67
|
+
});
|
|
68
|
+
}
|
|
69
|
+
return output.canExecute && canStartKarmaServer;
|
|
83
70
|
}
|
|
84
71
|
}
|
|
85
72
|
class TestAndroidCommand extends TestCommandBase {
|
|
@@ -97,33 +84,23 @@ class TestAndroidCommand extends TestCommandBase {
|
|
|
97
84
|
this.$migrateController = $migrateController;
|
|
98
85
|
this.platform = "android";
|
|
99
86
|
}
|
|
100
|
-
execute(args) {
|
|
101
|
-
|
|
102
|
-
execute: { get: () => super.execute }
|
|
103
|
-
});
|
|
104
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
105
|
-
yield _super.execute.call(this, args);
|
|
106
|
-
});
|
|
87
|
+
async execute(args) {
|
|
88
|
+
await super.execute(args);
|
|
107
89
|
}
|
|
108
|
-
canExecute(args) {
|
|
109
|
-
const
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
this.$errors.failWithHelp(constants_1.ANDROID_RELEASE_BUILD_ERROR_MESSAGE);
|
|
119
|
-
}
|
|
120
|
-
else {
|
|
121
|
-
this.$errors.failWithHelp(constants_1.ANDROID_APP_BUNDLE_SIGNING_ERROR_MESSAGE);
|
|
122
|
-
}
|
|
90
|
+
async canExecute(args) {
|
|
91
|
+
const canExecuteBase = await super.canExecute(args);
|
|
92
|
+
if (canExecuteBase) {
|
|
93
|
+
if ((this.$options.release || this.$options.aab) &&
|
|
94
|
+
!(0, helpers_1.hasValidAndroidSigning)(this.$options)) {
|
|
95
|
+
if (this.$options.release) {
|
|
96
|
+
this.$errors.failWithHelp(constants_1.ANDROID_RELEASE_BUILD_ERROR_MESSAGE);
|
|
97
|
+
}
|
|
98
|
+
else {
|
|
99
|
+
this.$errors.failWithHelp(constants_1.ANDROID_APP_BUNDLE_SIGNING_ERROR_MESSAGE);
|
|
123
100
|
}
|
|
124
101
|
}
|
|
125
|
-
|
|
126
|
-
|
|
102
|
+
}
|
|
103
|
+
return canExecuteBase;
|
|
127
104
|
}
|
|
128
105
|
}
|
|
129
106
|
class TestIosCommand extends TestCommandBase {
|