Skip to content
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

Update dependency gulp to v5 #20601

Merged
merged 2 commits into from
May 1, 2024
Merged

Update dependency gulp to v5 #20601

merged 2 commits into from
May 1, 2024

Conversation

renovate[bot]
Copy link
Contributor

@renovate renovate bot commented Apr 24, 2024

Mend Renovate

This PR contains the following updates:

Package Change Age Adoption Passing Confidence
gulp (source) 4.0.2 -> 5.0.0 age adoption passing confidence

Release Notes

gulpjs/gulp (gulp)

v5.0.0

Compare Source

We've tried to provide a high-level changelog for gulp v5 below, but it
doesn't contain all changes from the 60+ dependencies that we maintain.

Please see individual changelogs to drill down
into all changes that were made.

⚠ BREAKING CHANGES
  • Drop support for Node.js <10.13
  • Default stream encoding to UTF-8
  • Standardized on anymatch library for globbing paths. All globs should work the same between src and watch now!
  • Removed support for ordered globs. This aligns with the chokidar globbing implementation. If you need your globs to be ordered, you can use ordered-read-stream
  • All globs and paths are normalized to unix-like filepaths
  • Only allow JS variants for .gulp.* config files
  • Removed support for alpha releases of v4 from gulp-cli
  • Removed the --verify flag
  • Renamed the --require flag to --preload to avoid conflicting with Node.js flags
  • Removed many legacy and deprecated loaders
  • Upgrade to chokidar v3
  • Clone Vinyl objects with stream contents using teex, but no longer wait for all streams to flow before cloned streams will receive data
  • Stop using process.umask() to make directories, instead falling back to Node's default mode
  • Throw on non-function, non-string option coercers
  • Drop support of Node.js snake_case flags
  • Use a Symbol for attaching the gulplog namespace to the store
  • Use a Symbol for attaching the gulplog store to the global
  • Use sha256 to hash the v8flags cache into a filename
Features
  • Streamlined the dependency tree
  • Switch all streams implementation to Streamx
  • Rewrote glob-stream to use a custom directory walk that relies on newer Node.js features and is more performant than old implementation
  • Implement translation support for all CLI messages and all messages passing through gulplog
  • Allow users to customize or remove the timestamp from their logs
  • Upgraded gulplog to v2. Messages logged via v1 will also display a deprecated warning. Plugins should update to v2 as the community upgrades to gulp 5
  • Added support for gulpile.cjs and gulpfile.mjs
  • Add support for swc, esbuild, sucrase, and mdx loaders
  • Provide an ESM export (#​2760) (b00de68)
  • Support sourcemap handling on streaming Vinyl contents
  • Support extends syntax for .gulp.* config file
  • Allow overriding gulpfile and preloads via .gulp.* config file
Bug Fixes
  • Resolve bugs related to symlinks on various platforms
  • Resolved some reported ReDoS CVEs and improved performance in glob-parent
  • Rework errors surfaced when encountering files or symlinks when trying to create directories
  • Ensure watch allows japanese characters in globs (72668c6)
  • Ensure watch does not trigger on negated globs (72668c6)
  • Improve handling of BOM at the beginning of a stream
  • Properly handle function coercer in array of option coercers
  • Fork to-absolute-glob to:
    • Check negative patterns before trimming
    • Ensure glob-like characters are escaped in cwd & root options
    • Resolve ../ at the beginning of globs
Miscellaneous Chores
  • Remove lazystream dependency
  • Updated various stream test suites to test against Node.js core stream, readable-stream, and streamx
  • Normalize repository, dropping node <10.13 support (#​2758) (72668c6)
Individual Changelogs

We created and maintain various projects that gulp depends upon. You can find their changelogs linked below:


Configuration

📅 Schedule: Branch creation - At any time (no schedule defined), Automerge - At any time (no schedule defined).

🚦 Automerge: Disabled by config. Please merge this manually once you are satisfied.

Rebasing: Whenever PR becomes conflicted, or you tick the rebase/retry checkbox.

🔕 Ignore: Close this PR and you won't be reminded about this update again.


  • If you want to rebase/retry this PR, check this box

This PR has been generated by Mend Renovate. View repository job log here.

@renovate renovate bot added the Dependencies Pull requests that update a dependency file label Apr 24, 2024
@bdraco bdraco marked this pull request as draft April 24, 2024 09:25
@bdraco
Copy link
Member

bdraco commented Apr 24, 2024

draft since the root cause that necessitated the revert in #20598 needs to be discovered first

@steverep steverep self-assigned this Apr 24, 2024
@renovate renovate bot force-pushed the renovate/gulp-5.x branch from a918996 to 2b10732 Compare April 24, 2024 16:12
@steverep
Copy link
Member

Compatibility issue seems to be in the gulp-merge-json plugin. Still working on details.

@steverep steverep closed this Apr 24, 2024
@steverep steverep reopened this Apr 24, 2024
@renovate renovate bot force-pushed the renovate/gulp-5.x branch from 2b10732 to ee259e9 Compare April 27, 2024 09:17
@github-actions github-actions bot added the Build Related to building the code label Apr 28, 2024
@steverep steverep marked this pull request as ready for review April 28, 2024 04:21
@steverep
Copy link
Member

The root cause of the missing translations is owed to the fact that version 5 switched to using the streamx package. The pipe method for such streams does not support keeping the destination stream open with the { end: false } option like native node streams. So the main processing stream was being closed right after handling English.

The fix is simple enough just to send it through an intermediate stream first.

In a perfect world, the task should have failed. The pipe method from streamx should have thrown given the unsupported argument type, and the promises for merging all the non-English translations should never have fulfilled since they were piping to a closed stream. The latter seems just to be because gulp-merge-json uses a very old package to build its transform. I can do away with that in a follow up.

Copy link
Contributor Author

renovate bot commented Apr 28, 2024

Edited/Blocked Notification

Renovate will not automatically rebase this PR, because it does not recognize the last commit author and assumes somebody else may have edited the PR.

You can manually request rebase by checking the rebase/retry box above.

Warning: custom changes will be lost.

@silamon
Copy link
Contributor

silamon commented May 1, 2024

I've started a nightly run to compare, but locally I get the same as gulp v4 now.

@steverep
Copy link
Member

steverep commented May 1, 2024

Nightly would be no different than the CI build. The only difference is that the nightly workflow pulls the translations from Lokalise instead of from the nightly artifacts.

@silamon silamon merged commit b2797ab into dev May 1, 2024
15 checks passed
@silamon silamon deleted the renovate/gulp-5.x branch May 1, 2024 13:13
steverep added a commit that referenced this pull request May 1, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Build Related to building the code cla-signed Dependencies Pull requests that update a dependency file
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants