-
Notifications
You must be signed in to change notification settings - Fork 828
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
Precache manifest missing entries when recompiled via webpack --watch #1790
Comments
Just adding to this, for completeness, the navigate fallback file is also ejected on re-build. |
Sorry for letting this drop until now. workboox-webpack-plugin background
webpack --watch mode behaviorAfter running some local experiments with I believe some other plugins (like Problems with cumulative state
The concern that I have, though, is that there is no way for a webpack plugin to detect that a given asset has been removed following a recompilation—the absence of an asset from any particular compilation can't be used as a signal that it was removed, since that scenario is identical to what would happen if it was still present but unchanged. Unfortunately, it's pretty easy to trigger that scenario even without bringing any third-party plugins into the mix; if you're following the official guide for dynamic imports with // Assume this is in your main chunk:
async function load() {
const b = await import(/* webpackChunkName: "b" */ './b.js');
const c = await import(/* webpackChunkName: "c" */ './c.js');
} If you remove the dynamic import for Possible solutionsGiven that, it sounds like there's a tradeoff when in Neither solution is ideal, but I think from a service worker functionality perspective, the current behavior might be preferable—if you include a URL in the precache manifest list that doesn't exist, the installation process of the updated service worker will end up failing entirely. That sounds worse than the current behavior, in which the updated service worker installs but precaches less than expected. I'd love to hear folks' thoughts, though. Additional warningsWhat I plan on doing regardless is to detect when |
Ugh Rock and a Hard place, Jeff. Sorry webpack leaves you so few good options. Would plugging this specific bug make sense? Ie, on watch, manually, forcibly check for the navigateFallback, and just add that? Not perfect, but it would solve one of the worse manifestations of this bug. |
So what I'd like to do for the v5 timeframe is add in the I'm going to explore a bit more to see if there's anything in the I don't want to block the v5 release on that work, as it's likely going to take some time. I feel like adding in the warning about inconsistently gives us some leeway to make this sort of change post-v5, since developers will have a heads-up about not relying on |
Is there a recommendation how to use this in dev mode (with watch or dev server)? |
There are a few approaches:
I'd personally go with one of the first two options, as I think testing your service worker is best done via a "staging" rather than live-reload "development" build. |
I don't know if it's just because our case is unusual, but this would be very painful for my team. We recently added a Workbox service worker to a legacy application, and getting it right was largely a process of trial and error. Our non-live-reload Webpack build times take minutes to complete, whereas live-reload lets us fail fast and move on. Basically, sometimes what you're developing is the service worker itself, or requires the service worker to be present to function (e.g. Notifications on Android Chrome). We also value having the service worker in live-reload situations because of the concept of dev/prod parity. If developers are always working without the service worker running, they will probably miss issues that can and do arise once a service worker is in play. FWIW, we went with option 3 above, but it doesn't save us from getting spammed with redundant warning messages over and over: P.S. I have some experience writing Webpack plugins, so I do sympathise with how challenging it could be to find a "real" fix for this. I just wanted to plead my case 🙏 |
@jeffposnick any new solutions since then? |
There aren't any new solutions at this time. The warning message that gets logged in v5 will hopefully let folks know about the issue while doing local development. |
My temporary solution. So I can make development lighter:
|
A similar approach as per @devarthurribeiro, but through the disable option:
|
I don't think there's anything more we can do here, other than log the warning on recompilation that we've implemented. |
I don't get it... Is there a solution that doesn't require using next.js? Or does next-pwa not require using next.js? |
…e colors and theme, and initial app header design idea (#8) * merge squashed feat/Next.js branch * disabled service worked in dev environment due to GoogleChrome/workbox#1790 * added more components and edited theme * Fix for native dependencies * Faster docker builds I'm GitHub actions (#7) Closes #7 * Support window.location.origin if BASE_URL is not set (#6) When this is launched, the base URL may be different depending on if the user accesses over Tor, citadel.local, or locally using the IP. By not depending on the base URL from process.env, this is fixed. * first pass at top of page design, added h5s and h6s to CSS reset, edited theme and typography/design page layout, added @bitcoin-design/bitcoin-icons-react Co-authored-by: Aaron Dewes <[email protected]>
whatever your pipeline, simply don't use workbox when |
Prevents GenerateSW from being called multiple times in dev. Ref: GoogleChrome/workbox#1790
My team has a case where we want to generate and register the service worker in development. This is because we have caching set up in our service-worker for some very large assets that are not a part of our webpack build, and we also want to be able to test and receive push notifications in local development. If that's also your case, I figured out this hacky workaround: const nextConfig = {
webpack(config, options) {
if (!options.isServer) {
const workboxPlugin = new InjectManifest({
swSrc: "./src/service-worker/index.ts",
swDest: "../public/service-worker.js",
// In dev, exclude everything.
// This avoids irrelevant warnings about chunks being too large for caching.
// In non-dev, use the default `exclude` option, don't override.
...(options.dev ? { exclude: [/./] } : undefined),
})
if (options.dev) {
// Suppress the "InjectManifest has been called multiple times" warning by reaching into
// the private properties of the plugin and making sure it never ends up in the state
// where it makes that warning.
// https://github.com/GoogleChrome/workbox/blob/v6/packages/workbox-webpack-plugin/src/inject-manifest.ts#L260-L282
Object.defineProperty(workboxPlugin, "alreadyCalled", {
get() {
return false
},
set() {
// do nothing; the internals try to set it to true, which then results in a warning
// on the next run of webpack.
},
})
}
config.plugins.push(workboxPlugin)
}
return config
}
} You may also need to set |
based on this workaround, i just added this to my webpack config file, and the warning gone <3
|
아래의 문구를 없애기 위해 개발시 비활성화 ⚠ GenerateSW has been called multiple times, perhaps due to running webpack in --watch mode. The precache manifest generated after the first call may be inaccurate! Please see GoogleChrome/workbox#1790 for more information
….now im getting: InjectManifest has been called multiple times, perhaps due to running webpack in --watch mode. The precache manifest generated after the first call may be inaccurate! Please see GoogleChrome/workbox#1790 for more information.
Library Affected:
workbox-webpack-plugin
Browser & Platform:
Webpack 2.3.3, workbox-webpack-plugin 3.6.3
Issue Description:
In the
webpack --watch
mode,precache-manifest.hash.js
file at first generates a perfect list of files, but on subsequent updates it misses some files.For example, files generated with
CopyWebpackPlugin
are missing (but includingcopyUnmodified: true
in options helps).Another kind of files that are missing, is
fontawesome-webfont.eot?hash
files (importes via this process https://medium.com/@chanonroy/webpack-2-and-font-awesome-icon-importing-59df3364f35c), this I don't yet know how to fix.Here is a similar issue for another manifest plugin: shellscape/webpack-manifest-plugin#144.
The text was updated successfully, but these errors were encountered: