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

chore(gatsby-source-filesystem): update got dependency #18857

Merged
merged 6 commits into from
Mar 20, 2020
Merged

chore(gatsby-source-filesystem): update got dependency #18857

merged 6 commits into from
Mar 20, 2020

Conversation

EnKrypt
Copy link
Contributor

@EnKrypt EnKrypt commented Oct 20, 2019

Description

Using gatsby-source-contentful with certain options triggers a particular DeprecationWarning in node v12. (For more info, follow issue link below)

Bumping got to 9.6.0 in gatsby-source-filesystem fixes this.

The only side-effect is that this requires min Node v8. I don't think that should be a problem, but feel free to correct me.

Checked with all tests passing.

I'm not sure what the protocol is following this, but I'm guessing after this is merged, it will be reflected when another PR with chore(release) bumps all depending package versions to publish.

Related Issues

Fixes #18433

@EnKrypt EnKrypt requested a review from a team as a code owner October 20, 2019 13:23
@EnKrypt EnKrypt requested a review from pieh October 20, 2019 13:25
@EnKrypt EnKrypt added the type: maintenance An issue or pull request describing a change that isn't a bug, feature or documentation change label Oct 20, 2019
@pieh
Copy link
Contributor

pieh commented Oct 20, 2019

[email protected] requires node@>=8.6 ( https://github.com/sindresorhus/got/blob/v9.6.0/package.json#L8-L10 ) and our packages declare support for node>=8.0 ( https://github.com/gatsbyjs/gatsby/blob/master/packages/gatsby-source-filesystem/package.json#L52-L54 ), so this is tricky, because we would have to drop support for >=8.0 && <8.6 node versions with this change.

Depending when this was changed in got we might be able to bump maybe to got@8 which still supports older node versions. If this was fixed in got@9 then there's pickle - either live with deprecation warnings or drop support for some node versions (which should be considered breaking change)

@EnKrypt
Copy link
Contributor Author

EnKrypt commented Oct 20, 2019

So I went through the releases while debugging this.

Unfortunately the first release of got that fixes this is [email protected] which does require node@>=8.6.

Now, the actual fix within got itself is trivial. Pre 9.0.0, it depends on timed-out@4 which is what throws the DeprecationWarning. From [email protected], it no longer depends on that package, but timed-out@5 fixes the issue as well.

I initially thought we could keep the old version of got but bump timed-out in the package lockfile, but sadly we're not adding lockfiles to version control. I tried starting a conversation about this in the Discord, but haven't had any replies yet.

What do you suggest?

@EnKrypt
Copy link
Contributor Author

EnKrypt commented Oct 20, 2019

Btw, I see from the existing lockfile that we are already depending on got@^9.6.0. How does that play out then?

We can also alternatively just remove the dependency on got outright. The package makes only one call to it (for downloading a remote file), and that can easily be replaced by something else.

@pieh
Copy link
Contributor

pieh commented Oct 20, 2019

Now, the actual fix within got itself is trivial. Pre 9.0.0, it depends on timed-out@4 which is what throws the DeprecationWarning. From [email protected], it no longer depends on that package, but timed-out@5 fixes the issue as well.

I initially thought we could keep the old version of got but bump timed-out in the package lockfile, but sadly we're not adding lockfiles to version control. I tried starting a conversation about this in the Discord, but haven't had any replies yet.

We can't really mess with dependencies with packages we don't control. Yarn has some support for this ( https://yarnpkg.com/lang/en/docs/selective-version-resolutions/ ), but npm doesn't support it.

I was checking combination of npm aliases and optional dependencies, but npm added support to package aliases in [email protected] and versions before that doesn't understand the syntax and refuse to install, so this is no go.

Btw, I see from the existing lockfile that we are already depending on got@^9.6.0. How does that play out then?

Yeah, you are right.

We already use got@9 with gatsby-source-contentful, because is-online package that this plugin uses, depends on got@9 ( https://unpkg.com/browse/[email protected]/package.json ).

Maybe doing the swap is ok, and it won't disturb the users. I looked up our telemetry stats, and seems like over last month people that run gatsby on Node@>=8.0 && < 8.6 were 0.01% of our userbase. It might be ok to go forward with this, given that we already broke >=8.0 support with contentful plugin itself, but I do need to sleep on it a bit to make decision like that.

We can also alternatively just remove the dependency on got outright. The package makes only one call to it (for downloading a remote file), and that can easily be replaced by something else.

Sure, but it also abstract few things that we don't have to handle ourselves. I would be wary of removing it and re-implementing things we need.

@EnKrypt
Copy link
Contributor Author

EnKrypt commented Oct 21, 2019

Maybe doing the swap is ok, and it won't disturb the users. I looked up our telemetry stats, and seems like over last month people that run gatsby on Node@>=8.0 && < 8.6 were 0.01% of our userbase. It might be ok to go forward with this, given that we already broke >=8.0 support with contentful plugin itself, but I do need to sleep on it a bit to make decision like that.

Sure thing. Let me know what you decide is the best way forward. I'll keep this PR open till then.

@Lemraj
Copy link

Lemraj commented Oct 21, 2019

I am having the same problem when running http-server (local).

I have a simple angular app:
1 - ng build --prod
2 - go to dist/{name-app}
3 - run http-server

when browsing the url i get the following error:

image

image

@EnKrypt
Copy link
Contributor Author

EnKrypt commented Oct 21, 2019

@Lemraj I see that you've encountered the same DeprecationWarning, but I admit I don't quite see how it might relate to this PR or Gatsby.

Am I correct in assuming that you happened to land here while searching for this issue?

In that case, this issue in http-server might be more relevant.

@Lemraj
Copy link

Lemraj commented Oct 21, 2019

@EnKrypt You are right! i was searching for this issue and landed here!
I will post my question in the http-server issues page. Thanks.

@pieh
Copy link
Contributor

pieh commented Oct 22, 2019

Ok, I think the best move (still not great, but best we can do) is to not merge that yet:
It's unfortunate that we broke node version in gatsby-source-contentful (this should be considered as bug), but this plugin is used far less than gatsby-source-filesystem (which is used pretty much with almost every gatsby site).

Given that this PR gets rid of deprecation warning (and doesn't fix something that is broken), I think it's fair not to make the change yet. So upside of the change is that users on node 12 don't get warning, downside is that users on officially supported >=8.0 <8.6 will have problems with using this package (depending on package manager this can mean either not being able to install the package, to potential build time problems)

We will be dropping Node 8 support when it will reach its "end of life" which will happen in ~2 months ( https://nodejs.org/en/about/releases/ ), so that will be great time to make this change.

Any thoughts on that? If we can agree on this I would close PR for now, and this can be reoponed on 1st of January 2020, as this would be when we would officially drop node 8 support

@EnKrypt
Copy link
Contributor Author

EnKrypt commented Oct 23, 2019

I think you've made a reasonable argument.

Alright! Feel free to close this.

Now I just have to make sure I'm not too drunk or hungover on New Year's to remember to re-open this issue. Quite the challenge, but I'm up for it.

@pieh
Copy link
Contributor

pieh commented Oct 23, 2019

Now I just have to make sure I'm not too drunk or hungover on New Year's to remember to re-open this issue. Quite the challenge, but I'm up for it.

Hahaha, I didn't mean to re-open precisely on 1st of January 2020 ;) We will also probably need few days to get rest of our stuff in order (update all engines declaration in all of our packages, docs etc)

DanielRuf
DanielRuf previously approved these changes Jan 6, 2020
@EnKrypt
Copy link
Contributor Author

EnKrypt commented Jan 6, 2020

@pieh Re-opened as discussed. If we've dropped support for node 8, I think we should be good to go.

@DanielRuf
Copy link
Contributor

packages/gatsby-source-filesystem/package.json

Can you take a look the conflict and resolve it?

@sidharthachatterjee
Copy link
Contributor

We're adding a deprecation warning in #20466 and delaying breaking support for another month or so

@sidharthachatterjee sidharthachatterjee added the status: blocked This issue/PR can't be solved at the moment and shouldn't be closed/merged label Jan 8, 2020
@EnKrypt
Copy link
Contributor Author

EnKrypt commented Feb 11, 2020

Any updates? What are the current stats on our users using Node < 10.13?

@sidharthachatterjee sidharthachatterjee removed the status: blocked This issue/PR can't be solved at the moment and shouldn't be closed/merged label Mar 20, 2020
@pieh pieh changed the title Fixed DeprecationWarning while using node v12 chore(gatsby-source-filesystem): update got dependency Mar 20, 2020
Copy link
Contributor

@sidharthachatterjee sidharthachatterjee left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Time to get this in!

@sidharthachatterjee sidharthachatterjee added the bot: merge on green Gatsbot will merge these PRs automatically when all tests passes label Mar 20, 2020
@sidharthachatterjee sidharthachatterjee changed the title chore(gatsby-source-filesystem): update got dependency chore(gatsby-source-filesystem): update got dependency Mar 20, 2020
@sidharthachatterjee sidharthachatterjee merged commit e1a7313 into gatsbyjs:master Mar 20, 2020
@AleC77
Copy link

AleC77 commented Mar 5, 2021

Hi, with gatsby 3.0 I am seeing again the same problem. Any suggestion?

(node:18172) [DEP0066] DeprecationWarning: OutgoingMessage.prototype._headers is deprecated
at module.exports (node_modules\timed-out\index.js:9:17)
at EventEmitter. (node_modules\got\index.js:244:5)
at Object.onceWrapper (events.js:313:26)
at EventEmitter.emit (events.js:223:5)
at makeRequest (node_modules\got\node_modules\cacheable-request\src\index.js:94:9)
at node_modules\got\node_modules\cacheable-request\src\index.js:104:14
at runNextTicks (internal/process/task_queues.js:59:5)
at processImmediate (internal/timers.js:412:9)

@qubis741
Copy link

Same with gatsby 3.1.2

@zackthoutt
Copy link

This happened to me as well. Fixed it by adding the latest version of got to my dependencies.

"got": "^11.8.2"

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
bot: merge on green Gatsbot will merge these PRs automatically when all tests passes type: maintenance An issue or pull request describing a change that isn't a bug, feature or documentation change
Projects
None yet
Development

Successfully merging this pull request may close these issues.

[gatsby-source-filesystem] Deprecation warning
9 participants