-
Notifications
You must be signed in to change notification settings - Fork 2.7k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Use an alias system instead of camelCase function (#3101)
* - move aliases to unsupported aliases - tests properly camelised comand - tests properly command with hyphen - move generation of documentation in src/cli/commands/index.js - move every command related stuff in src/cli/commands/index.js - tests some corner cases - delete every camelCase use in src/cli/commands/index.js and src/cli/commands/help.js * fix typo and initialize commands in a clearer way
- Loading branch information
Showing
9 changed files
with
244 additions
and
148 deletions.
There are no files selected for viewing
This file was deleted.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,32 @@ | ||
/* @flow */ | ||
|
||
import unsupportedAliases from '../../src/cli/unsupported-aliases.js'; | ||
|
||
test('shorthands and affordances', () => { | ||
expect(unsupportedAliases['run-script']).toBe('run'); | ||
expect(unsupportedAliases['c']).toBe('config'); | ||
expect(unsupportedAliases['i']).toBe('install'); | ||
expect(unsupportedAliases['ls']).toBe('list'); | ||
expect(unsupportedAliases['rb']).toBe('rebuild'); | ||
expect(unsupportedAliases['runScript']).toBe('run'); | ||
expect(unsupportedAliases['t']).toBe('test'); | ||
expect(unsupportedAliases['tst']).toBe('test'); | ||
expect(unsupportedAliases['un']).toBe('remove'); | ||
expect(unsupportedAliases['up']).toBe('upgrade'); | ||
expect(unsupportedAliases['v']).toBe('version'); | ||
expect(unsupportedAliases['add-user']).toBe('login'); | ||
expect(unsupportedAliases['dist-tag']).toBe('tag'); | ||
expect(unsupportedAliases['dist-tags']).toBe('tag'); | ||
expect(unsupportedAliases['adduser']).toBe('login'); | ||
expect(unsupportedAliases['author']).toBe('owner'); | ||
expect(unsupportedAliases['isntall']).toBe('install'); | ||
expect(unsupportedAliases['la']).toBe('list'); | ||
expect(unsupportedAliases['ll']).toBe('list'); | ||
expect(unsupportedAliases['r']).toBe('remove'); | ||
expect(unsupportedAliases['rm']).toBe('remove'); | ||
expect(unsupportedAliases['show']).toBe('info'); | ||
expect(unsupportedAliases['uninstall']).toBe('remove'); | ||
expect(unsupportedAliases['update']).toBe('upgrade'); | ||
expect(unsupportedAliases['verison']).toBe('version'); | ||
expect(unsupportedAliases['view']).toBe('info'); | ||
}); |
5 changes: 5 additions & 0 deletions
5
__tests__/fixtures/index/run-generate-lock-entry/package.json
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,5 @@ | ||
{ | ||
"name": "test_generate_lock_entry", | ||
"version": "1.0.0", | ||
"license": "UNLICENSED" | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,39 +1,6 @@ | ||
/* @flow */ | ||
|
||
const shorthands: { [key: string]: string } = { | ||
c: 'config', | ||
i: 'install', | ||
la: 'list', | ||
ll: 'list', | ||
ln: 'link', | ||
ls: 'list', | ||
r: 'remove', | ||
rb: 'rebuild', | ||
rm: 'remove', | ||
t: 'test', | ||
tst: 'test', | ||
un: 'remove', | ||
up: 'upgrade', | ||
v: 'version', | ||
}; | ||
|
||
const affordances: { [key: string]: string } = { | ||
'add-user': 'login', | ||
adduser: 'login', | ||
author: 'owner', | ||
'dist-tag': 'tag', | ||
'dist-tags': 'tag', | ||
isntall: 'install', | ||
'run-script': 'run', | ||
runScript: 'run', | ||
show: 'info', | ||
uninstall: 'remove', | ||
update: 'upgrade', | ||
verison: 'version', | ||
view: 'info', | ||
}; | ||
|
||
export default ({ | ||
...shorthands, | ||
...affordances, | ||
export default({ | ||
'upgrade-interactive': 'upgradeInteractive', | ||
'generate-lock-entry': 'generateLockEntry', | ||
}: { [key: string]: string }); |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,49 +1,117 @@ | ||
/* @flow */ | ||
import {ConsoleReporter, JSONReporter} from '../../reporters/index.js'; | ||
import * as constants from '../../constants.js'; | ||
import {MessageError} from '../../errors.js'; | ||
import Config from '../../config.js'; | ||
|
||
import * as access from './access.js'; export {access}; | ||
import * as add from './add.js'; export {add}; | ||
import * as bin from './bin.js'; export {bin}; | ||
import * as cache from './cache.js'; export {cache}; | ||
import * as check from './check.js'; export {check}; | ||
import * as clean from './clean.js'; export {clean}; | ||
import * as config from './config.js'; export {config}; | ||
import * as generateLockEntry from './generate-lock-entry.js'; export {generateLockEntry}; | ||
import * as global from './global.js'; export {global}; | ||
import * as help from './help.js'; export {help}; | ||
import * as import_ from './import.js'; export {import_ as import}; | ||
import * as info from './info.js'; export {info}; | ||
import * as init from './init.js'; export {init}; | ||
import * as install from './install.js'; export {install}; | ||
import * as licenses from './licenses.js'; export {licenses}; | ||
import * as link from './link.js'; export {link}; | ||
import * as login from './login.js'; export {login}; | ||
import * as logout from './logout.js'; export {logout}; | ||
import * as list from './list.js'; export {list}; | ||
import * as outdated from './outdated.js'; export {outdated}; | ||
import * as owner from './owner.js'; export {owner}; | ||
import * as pack from './pack.js'; export {pack}; | ||
import * as publish from './publish.js'; export {publish}; | ||
import * as remove from './remove.js'; export {remove}; | ||
import * as run from './run.js'; export {run}; | ||
import * as tag from './tag.js'; export {tag}; | ||
import * as team from './team.js'; export {team}; | ||
import * as unlink from './unlink.js'; export {unlink}; | ||
import * as upgrade from './upgrade.js'; export {upgrade}; | ||
import * as version from './version.js'; export {version}; | ||
import * as versions from './versions.js'; export {versions}; | ||
import * as why from './why.js'; export {why}; | ||
import * as upgradeInteractive from './upgrade-interactive.js'; export {upgradeInteractive}; | ||
const chalk = require('chalk'); | ||
|
||
const getDocsLink = (name) => `${constants.YARN_DOCS}${name || ''}`; | ||
const getDocsInfo = (name) => 'Visit ' + chalk.bold(getDocsLink(name)) + ' for documentation about this command.'; | ||
|
||
import * as access from './access.js'; | ||
import * as add from './add.js'; | ||
import * as bin from './bin.js'; | ||
import * as cache from './cache.js'; | ||
import * as check from './check.js'; | ||
import * as clean from './clean.js'; | ||
import * as config from './config.js'; | ||
import * as generateLockEntry from './generate-lock-entry.js'; | ||
import * as global from './global.js'; | ||
import * as help from './help.js'; | ||
import * as import_ from './import.js'; | ||
import * as info from './info.js'; | ||
import * as init from './init.js'; | ||
import * as install from './install.js'; | ||
import * as licenses from './licenses.js'; | ||
import * as link from './link.js'; | ||
import * as login from './login.js'; | ||
import * as logout from './logout.js'; | ||
import * as list from './list.js'; | ||
import * as outdated from './outdated.js'; | ||
import * as owner from './owner.js'; | ||
import * as pack from './pack.js'; | ||
import * as publish from './publish.js'; | ||
import * as remove from './remove.js'; | ||
import * as run from './run.js'; | ||
import * as tag from './tag.js'; | ||
import * as team from './team.js'; | ||
import * as unlink from './unlink.js'; | ||
import * as upgrade from './upgrade.js'; | ||
import * as version from './version.js'; | ||
import * as versions from './versions.js'; | ||
import * as why from './why.js'; | ||
import * as upgradeInteractive from './upgrade-interactive.js'; | ||
|
||
import buildUseless from './_useless.js'; | ||
|
||
export const lockfile = buildUseless( | ||
"The lockfile command isn't necessary. `yarn install` will produce a lockfile.", | ||
); | ||
const commands = { | ||
access, | ||
add, | ||
bin, | ||
cache, | ||
check, | ||
clean, | ||
config, | ||
dedupe: buildUseless( | ||
"The dedupe command isn't necessary. `yarn install` will already dedupe.", | ||
), | ||
generateLockEntry, | ||
global, | ||
help, | ||
import: import_, | ||
info, | ||
init, | ||
install, | ||
licenses, | ||
link, | ||
lockfile: buildUseless( | ||
"The lockfile command isn't necessary. `yarn install` will produce a lockfile.", | ||
), | ||
login, | ||
logout, | ||
list, | ||
outdated, | ||
owner, | ||
pack, | ||
prune: buildUseless( | ||
"The prune command isn't necessary. `yarn install` will prune extraneous packages.", | ||
), | ||
publish, | ||
remove, | ||
run, | ||
tag, | ||
team, | ||
unlink, | ||
upgrade, | ||
version, | ||
versions, | ||
why, | ||
upgradeInteractive, | ||
}; | ||
|
||
for (const key in commands) { | ||
commands[key].getDocsInfo = getDocsInfo(key); | ||
} | ||
|
||
import aliases from '../aliases.js'; | ||
|
||
for (const key in aliases) { | ||
commands[key] = commands[aliases[key]]; | ||
commands[key].getDocsInfo = getDocsInfo(key); | ||
} | ||
|
||
import unsupportedAliases from '../unsupported-aliases.js'; | ||
|
||
export const dedupe = buildUseless( | ||
"The dedupe command isn't necessary. `yarn install` will already dedupe.", | ||
); | ||
for (const key in unsupportedAliases) { | ||
commands[key] = { | ||
run(config: Config, reporter: ConsoleReporter | JSONReporter): Promise<void> { | ||
throw new MessageError(`Did you mean \`yarn ${unsupportedAliases[key]}\`?`); | ||
}, | ||
setFlags: () => {}, | ||
hasWrapper: () => true, | ||
getDocsInfo: getDocsInfo(unsupportedAliases[key]), | ||
}; | ||
} | ||
|
||
export const prune = buildUseless( | ||
"The prune command isn't necessary. `yarn install` will prune extraneous packages.", | ||
); | ||
export default (commands); |
Oops, something went wrong.