From 8471070ba4a55fce7ad212bbe149611783dcffc3 Mon Sep 17 00:00:00 2001 From: Haoqun Jiang Date: Tue, 29 Oct 2019 16:21:19 +0800 Subject: [PATCH 1/3] feat: support binary mirrors for taobao registry fixes issues like #4718 --- .../cli/lib/util/ProjectPackageManager.js | 50 ++++++++++++++++--- 1 file changed, 43 insertions(+), 7 deletions(-) diff --git a/packages/@vue/cli/lib/util/ProjectPackageManager.js b/packages/@vue/cli/lib/util/ProjectPackageManager.js index 62df7b8206..c6ccb2653f 100644 --- a/packages/@vue/cli/lib/util/ProjectPackageManager.js +++ b/packages/@vue/cli/lib/util/ProjectPackageManager.js @@ -31,7 +31,6 @@ const metadataCache = new LRU({ const isTestOrDebug = process.env.VUE_CLI_TEST || process.env.VUE_CLI_DEBUG -const TAOBAO_DIST_URL = 'https://npm.taobao.org/dist' const SUPPORTED_PACKAGE_MANAGERS = ['yarn', 'pnpm', 'npm'] const PACKAGE_MANAGER_PNPM4_CONFIG = { install: ['install', '--reporter', 'silent', '--shamefully-hoist'], @@ -114,8 +113,12 @@ class PackageManager { } else if (await shouldUseTaobao(this.bin)) { this._registry = registries.taobao } else { - const { stdout } = await execa(this.bin, ['config', 'get', 'registry']) - this._registry = stdout + try { + this._registry = (await execa(this.bin, ['config', 'get', 'registry'])).stdout + } catch (e) { + // Yarn 2 uses `npmRegistryServer` instead of `registry` + this._registry = (await execa(this.bin, ['config', 'get', 'npmRegistryServer'])).stdout + } } return this._registry @@ -125,12 +128,42 @@ class PackageManager { const registry = await this.getRegistry() args.push(`--registry=${registry}`) - if (registry === registries.taobao) { - // for node-gyp - process.env.NODEJS_ORG_MIRROR = TAOBAO_DIST_URL + return args + } + + // set mirror urls for users in china + async setBinaryMirrors () { + const registry = await this.getRegistry() + + if (registry !== registries.taobao) { + return } - return args + try { + // node-sass, chromedriver, etc. + const binaryMirrorConfig = await this.getMetadata('binary-mirror-config') + const mirrors = binaryMirrorConfig.mirrors.china + for (const key in mirrors.ENVS) { + process.env[key] = mirrors.ENVS[key] + } + + // Cypress + const cypressMirror = mirrors.cypress + const defaultPlatforms = { + darwin: 'osx64', + linux: 'linux64', + win32: 'win64' + } + const platforms = cypressMirror.newPlatforms || defaultPlatforms + const targetPlatform = platforms[require('os').platform()] + if (targetPlatform) { + const latestCypressVersion = await this.getRemoteVersion('cypress') + process.env.CYPRESS_INSTALL_BINARY = + `${cypressMirror.host}/${latestCypressVersion}/${targetPlatform}/cypress.zip` + } + } catch (e) { + // get binary mirror config failed + } } async getMetadata (packageName, { field = '' } = {}) { @@ -178,11 +211,13 @@ class PackageManager { } async install () { + await this.setBinaryMirrors() const args = await this.addRegistryToArgs(PACKAGE_MANAGER_CONFIG[this.bin].install) return executeCommand(this.bin, args, this.context) } async add (packageName, isDev = true) { + await this.setBinaryMirrors() const args = await this.addRegistryToArgs([ ...PACKAGE_MANAGER_CONFIG[this.bin].add, packageName, @@ -205,6 +240,7 @@ class PackageManager { return } + await this.setBinaryMirrors() const args = await this.addRegistryToArgs([ ...PACKAGE_MANAGER_CONFIG[this.bin].add, packageName From 3acf202b18500bd4debf5e8f5186536c561a35f1 Mon Sep 17 00:00:00 2001 From: Haoqun Jiang Date: Tue, 29 Oct 2019 16:24:40 +0800 Subject: [PATCH 2/3] fix: only install cypress 3, for now --- packages/@vue/cli/lib/util/ProjectPackageManager.js | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/packages/@vue/cli/lib/util/ProjectPackageManager.js b/packages/@vue/cli/lib/util/ProjectPackageManager.js index c6ccb2653f..289607a7c8 100644 --- a/packages/@vue/cli/lib/util/ProjectPackageManager.js +++ b/packages/@vue/cli/lib/util/ProjectPackageManager.js @@ -157,7 +157,8 @@ class PackageManager { const platforms = cypressMirror.newPlatforms || defaultPlatforms const targetPlatform = platforms[require('os').platform()] if (targetPlatform) { - const latestCypressVersion = await this.getRemoteVersion('cypress') + // We only support cypress 3 for the current major version + const latestCypressVersion = await this.getRemoteVersion('cypress', '^3') process.env.CYPRESS_INSTALL_BINARY = `${cypressMirror.host}/${latestCypressVersion}/${targetPlatform}/cypress.zip` } From dfc42ca3648d5fadf86ea0ad43da3da8d5b5e763 Mon Sep 17 00:00:00 2001 From: Haoqun Jiang Date: Tue, 29 Oct 2019 16:29:05 +0800 Subject: [PATCH 3/3] fix: do not override user defined `CYPRESS_INSTALL_BINARY` env --- packages/@vue/cli/lib/util/ProjectPackageManager.js | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/packages/@vue/cli/lib/util/ProjectPackageManager.js b/packages/@vue/cli/lib/util/ProjectPackageManager.js index 289607a7c8..0a7856779a 100644 --- a/packages/@vue/cli/lib/util/ProjectPackageManager.js +++ b/packages/@vue/cli/lib/util/ProjectPackageManager.js @@ -156,7 +156,9 @@ class PackageManager { } const platforms = cypressMirror.newPlatforms || defaultPlatforms const targetPlatform = platforms[require('os').platform()] - if (targetPlatform) { + // Do not override user-defined env variable + // Because we may construct a wrong download url and an escape hatch is necessary + if (targetPlatform && !process.env.CYPRESS_INSTALL_BINARY) { // We only support cypress 3 for the current major version const latestCypressVersion = await this.getRemoteVersion('cypress', '^3') process.env.CYPRESS_INSTALL_BINARY =