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

Drupal/Gatsby: Build time tracking #522

Open
pmelab opened this issue Dec 7, 2020 · 3 comments
Open

Drupal/Gatsby: Build time tracking #522

pmelab opened this issue Dec 7, 2020 · 3 comments
Assignees
Labels
drupal Concerns Drupal backends. feature A new feature, visible by users. gatsby Gatsby infrastructure and features.

Comments

@pmelab
Copy link
Contributor

pmelab commented Dec 7, 2020

An extension to #521: Instead of just tracking a single state, the build trigger should log build time by tracking builds in a database table and show the expected build time (no, it won't be accurate) in the toolbar as a countdown.

@pmelab pmelab changed the title Drupal Gatsby built time tracking Drupal Gatsby build time tracking Dec 7, 2020
@pmelab pmelab added gatsby Gatsby infrastructure and features. drupal Concerns Drupal backends. labels Dec 7, 2020
@pmelab pmelab changed the title Drupal Gatsby build time tracking Drupal/Gatsby: Build time tracking Dec 7, 2020
@pmelab pmelab added the feature A new feature, visible by users. label Oct 21, 2021
@chindris chindris self-assigned this Feb 6, 2022
@chindris
Copy link
Contributor

chindris commented Feb 7, 2022

Hi @pmelab and @Leksat !
I did a POC in #945 and I based the estimation on the data which is already logged in the gatsby_build_monitor_stats table.

In the toolbar I added a progress bar (not too fancy though) instead of a countdown. I was also facing another issue and want to double check with you: after a node gets saved, and a rebuild is triggered in the frontend, I would expect just two calls for the set state route, from the frontend to the backend: one to change the state to building, and one to change it to idle. However, I saw that there are 3 requests I get to set state to building. This affects that toolbar progress bar because each time when a state gets set, the progress bar would start from the beginning. So, is this thing also happening to you, or is it maybe something on my setup? I did spend a bit on debugging this, and apparently there are only two calls (one for building and one for idle) from the fast-builds/serve.ts script, so not sure where are the others from...

@Leksat
Copy link
Member

Leksat commented Feb 8, 2022

One of our projects has the following stats:

  • incremental builds take less than a minute
  • builds with cache clear take more than 10 minutes

Let's imagine that average would be 2.5 minutes. In this case the progress bar will always be wrong.

As a client, I would not be really happy with this :)

I think we can make the prediction more accurate if we teach the Gatsby plugin to identify incremental and full builds. But I'm not sure if this is really possible.

@chindris
Copy link
Contributor

chindris commented Feb 8, 2022

@Leksat if the builds with cache clear do not happen that often, it is a high chance they are ignored. I know this is just an estimate and it will not be accurate all the time, and if we could somehow create two averages, one for incremental and one for full builds, it would be great. We could at least identify the incremental ones (when using the fast build __rebuild route), that would be an improvement.
So, the average is probably to not be accurate for the builds with cache clear, because the algorithm is like this:

  • consider the last 100 builds
  • order the builds in an array (like if 10 build are taking 1 minute and 4 builds 2 minutes, those 10 builds will appear at the beginning of the array).
  • ignore the second half of the array (this is the step where probably the builds with a cache clear, if they don't appear often, will be removed).
  • compute the average.

But yes, if we could make this separation between the incremental ones and the full ones, it would be great.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
drupal Concerns Drupal backends. feature A new feature, visible by users. gatsby Gatsby infrastructure and features.
Projects
None yet
Development

No branches or pull requests

3 participants