/* This Source Code Form is subject to the terms of the Mozilla Public * License, v. 2.0. If a copy of the MPL was not distributed with this * file, You can obtain one at . */ /* import-globals-from ../head.js */ /** * This second test will focus on v1/removed-original.js which is an original source mapped file. * This source is mapped to replaced-bundle.js. * In the first reload (v2), this original source is removed and another original file: v2/new-original.js * will replace the content of the removed-original.js in the replaced-bundle.js generated file. * And finally, in the second reload (v3) everything is removed, both original and generated source. * * Note that great care is done to ensure that new-original replaces removed-original with the * exact same breakable lines and columns. So that the breakpoint isn't simply removed * because the location is no longer breakable. */ "use strict"; addIntegrationTask(async function testReloadingRemovedOriginalSources( testServer, testUrl, { isCompressed } ) { info(" # Test reloading a source that is replaced and then removed"); testServer.backToFirstVersion(); const dbg = await initDebuggerWithAbsoluteURL(testUrl, "removed-original.js"); info("Add initial breakpoint"); await selectSource(dbg, "removed-original.js"); await addBreakpoint(dbg, "removed-original.js", 4); // Assert the precise behavior of the breakpoint before reloading invokeInTab("removedOriginal"); await waitForPaused(dbg); const replacedSource = findSource(dbg, "removed-original.js"); assertPausedAtSourceAndLine(dbg, replacedSource.id, 4); assertTextContentOnLine(dbg, 4, 'console.log("Removed original");'); await assertBreakpoint(dbg, 4); is(dbg.selectors.getBreakpointCount(), 1, "One breakpoint exists"); is( dbg.client.getServerBreakpointsList().length, 1, "One breakpoint exists on the server" ); let breakpoint = dbg.selectors.getBreakpointsList()[0]; is(breakpoint.location.sourceUrl, replacedSource.url); is(breakpoint.location.line, 4); if (isCompressed) { is(breakpoint.generatedLocation.line, 1); is(breakpoint.generatedLocation.column, 992); } else { is(breakpoint.generatedLocation.line, 80); } await resume(dbg); info( "Reload, which should remove the original file and a add a new original file which will replace its content in the generated file" ); const syncBp = waitForDispatch(dbg.store, "SET_BREAKPOINT"); testServer.switchToNextVersion(); const onReloaded = reload(dbg, "new-original.js"); await syncBp; // Assert the new breakpoint being created after reload // For now, the current behavior of the debugger is that: // the breakpoint is still hit based on the generated source/bundle file // and the UI updates itself to mention the new original file. await waitForPaused(dbg); const newSource = findSource(dbg, "new-original.js"); assertPausedAtSourceAndLine(dbg, newSource.id, 4); assertTextContentOnLine(dbg, 4, 'console.log("New original");'); await assertBreakpoint(dbg, 4); is(dbg.selectors.getBreakpointCount(), 1, "One breakpoint exists"); is( dbg.client.getServerBreakpointsList().length, 1, "One breakpoint exists on the server" ); breakpoint = dbg.selectors.getBreakpointsList()[0]; is(breakpoint.location.sourceUrl, newSource.url); is(breakpoint.location.line, 4); if (isCompressed) { is(breakpoint.generatedLocation.line, 1); is(breakpoint.generatedLocation.column, 992); } else { is(breakpoint.generatedLocation.line, 80); } await resume(dbg); info("Wait for reload to complete after resume"); await onReloaded; info( "Reload a last time to remove both original and generated sources entirely" ); testServer.switchToNextVersion(); await reload(dbg); // Let some time for breakpoint syncing to be buggy and recreated unexpected breakpoint await wait(1000); info("Assert that sources and breakpoints are gone and we aren't paused"); ok( !sourceExists(dbg, "removed-original.js"), "removed-original is not present" ); ok(!sourceExists(dbg, "new-original.js"), "new-original is not present"); ok( !sourceExists(dbg, "replaced-bundle.js"), "replaced-bundle is not present" ); assertNotPaused(dbg); is(dbg.selectors.getBreakpointCount(), 0, "We no longer have any breakpoint"); // The breakpoint for the removed source still exists, atm this difficult to fix // as the frontend never loads the source. is( dbg.client.getServerBreakpointsList().length, 1, "One breakpoint still exists on the server" ); });