-
-
Notifications
You must be signed in to change notification settings - Fork 0
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
feat: add upgrade command #8
base: main
Are you sure you want to change the base?
Conversation
d83aa6a
to
b29fcef
Compare
b29fcef
to
240999d
Compare
31a6d97
to
b988b75
Compare
@kjugi What do you think of the messages I added to the upgrade command? It no longer uses the jscodeshift output, although I think it's a bit confusing, the statistics output adds up the files in each loop. |
console.info('> Cancelled process. Program will stop now without any actions. \n') | ||
process.exit(1) | ||
} | ||
import { onCancel, promptSource } from '../utils/share' |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
this share
filename needs adjustment. It does not tell what can be found inside. From what I can see you collect there utility methods for commands
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Yeah, I gave it that name without thinking too much, I just wanted to separate it
const expressVersion = coerce(dependencies.express)?.version ?? '4.0.0' | ||
|
||
const codemodsSuggested = TRANSFORM_OPTIONS.filter((a) => { | ||
return compare(a.version, expressVersion) > 0 |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
shouldn't we apply our codemods only if the project is on v4?
according to docs:
compare(v1, v2): Return 0 if v1 == v2, or 1 if v1 is greater, or -1 if v2 is greater.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
It is more thought out so that in the future more codemods can be added as Express evolves, and not limit us to version 4
commands/upgrade.ts
Outdated
{ | ||
type: 'multiselect', | ||
name: 'codemodsSelected', | ||
message: `The following 'codemods' are recommended for your upgrade. Select the ones to apply.`, |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
we recommend them only by checking version in the package.json
file. It doesn't necessarily bring value. Let's just check if express is there and ask user to select codemods.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
But what if there are codemods for version 6 and we're on version 5? We wouldn't want to recommend codemods from version 4, right?
commands/upgrade.ts
Outdated
console.log(`> ${results.ok} codemods were applied successfully`) | ||
console.log(`> ${results.skipped} codemods were skipped`) | ||
console.log(`> ${results.failed} codemods failed`) | ||
console.log(`> ${results.unmodified} codemods were skipped because they didn't change anything`) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
yep
I'm going to keep doing this next year, @kjugi if you want to keep going with it, it's okay by me. |
I'm going to leave this to finish in the future, I'm focused on other aspects of the project right now. |
This adds the command to update Express in a single step, displaying the available options based on the version specified in the package.json.
Things still to do:
Make the jscodeshift input more user-friendly