Удаленная отладка JavaScript с VS2015. Часть 3 (F12 Chooser)

    Предлагаю перевод статьи «VS2015 Remote Debugging JavaScript – Part 3».

    F12 Chooser – потрясающий новый инструмент для WinForms приложения с Web Browser Control


    Ранее мы обсудили удаленную отладку JS из IE и других процессов.

    VS2015 – прекрасный инструмент для удаленной отладки приложений (или процессов). Он предоставляет широкие возможности. Можно отлаживать приложения, размещенный в средах QA, тестирования, интеграции и прочих, где нет возможности установить Visual Studio. Но что, если возникла задача отладить утечку памяти на одной из этих удаленных машин? F12 (инструменты разработчика в браузере) помогли бы, но что, если приложением с утечкой является WinForms с Web Browser Control? Что ж, вариантов не много. DebugDiag мог бы помочь идентифицировать утечку, однако без доступа к приватным символам нам может и не повезти. Будет затруднительно искать утечку памяти в JS. Если вы были в подобной ситуации, то точно оцените новый инструмент F12Chooser, который поставляется вместе с Windows 10.

    За более детальной информацией по инструментам разработчика F12 можно обратиться к следующим ресурсам:

    Ссылки на исходный код и демонстрационное приложение


    В этом простом демо я использую MDI WinForms приложение. Мы откроем две формы и отладим их. Вы можете скачать само приложение и исходный код. Вы можете скачать тестовое приложение и сам код. Это приложение представляет собой слегка измененную версию предыдущего демо, в основном, это конвертация в MDI приложение.
    1. TestApp2.exe
    2. TestApp2.zip
    3. TestLeak.html
    4. TestLeak2.html
    5. TestApp.zip (предыдущее демо)

    Отладка WinForms приложения, выступающего хостом для Web Browser Control


    1. Запускаем TestApp2.exe
    2. Нажимаем File -> New Form для открытия новой формы
    3. Открываем файл TestLeak.html внутри нее. Можете просто перетащить файл на браузерный элемент управления и компонент перейдет на этот файл
    4. Нажимаем File -> New Form для открытия еще одной новой формы
    5. Открываем файл TestLeak2.html внутри нее. Можете просто перетащить файл на браузерный элемент управления и компонент перейдет на этот файл
    6. Нажимаем Window -> Tile Horizontally для одновременного отображения обоих окон

    7. (Барабанная дробь! ) Теперь открываем приложение  C:\Windows\SysWOW64\F12\F12Chooser.exe или C:\Windows\System32\F12\F12Chooser.exe. Выбор зависит от того, запущено ли приложение как 32-х или 64-х разрядный процесс.

    8. Кликаем на тайл с надписью «TestLeak.html». Вы увидите знакомое окно F12, а с ним мы уже прекрасно знаем, как работать.

    9. Поставим точку останова в методе onclick на TestLeak.html. В приложении кликаем на кнопку «Throw an error» и видим срабатывание точки останова в отладчике F12Chooser (F12)

    10. Перейдя на вкладку консоли в F12, можем увидеть нашу ошибку

    11. Прекрасная новость состоит в возможности независимой отладки каждой формы. Другими словами, можно присоединить более одного отладчика F12Chooser к одному процессу.
    12. Вы можете делать все привычные вам в F12 вещи, например, изменять режим документа (document mode) или строку агента пользователя

    Отладка утечек памяти у WinForms приложения, выступающего хостом для Web Browser Control


    Пункты с 1 по 7 те же, что и выше, а дальше:
    1. На этот раз открываем  LeakTest2.html. Переходим на вкладку памяти в F12. Вы будете удивлены, увидев, что не можете проанализировать утечки памяти для приложения.

    2. Важное замечание: даже несмотря на то, что у вас установлен IE11, страничка все равно рендерится в режиме IE7. Это поведение по умолчанию для компонента Web Browser Control. В основном, это сделано для обратной совместимости для многих корпоративных интранет сайтов, который могут сломаться в случае отображения в Edge Mode
    3. Так что давайте изменим режим документа на Edge и вернемся на вкладку памяти
    4. Нажимаем кнопку «Start Profiling»
    5. Делаем снимок памяти
    6. В приложении нажимаем кнопку «Start Memory Leak», затем после 4-5 секунд — «Stop Memory Leak»
    7. Делаем еще один снимок памяти
    8. Сравниваем два снимка путем нажатия правой кнопкой мыши на одном из них и выбирая второй, как показано на скриншоте
    9. Если вы выберете одну из строк, которые текут, то увидите, что корнем для них выступает глобальный массив
    10. Аналогично и для div элементов
    11. Я не собираюсь углубляться в детали отладки утечек памяти в этой статье, их можно найти здесь: Diagnosing memory problems in your webpages
    12. Также для удобства F12Chooser может показывать идентификатор процесса для удобства поиска нужного при подключении

    Итоги


    • F12Chooser поставляется вместе с Windows 10 и позволяет воспользоваться мощью F12 для любого процесса
    • Вы можете отлаживать IE, Edge, приложения с Web Browser Control и пр.
    • Похоже, что Edge неплохо управляется с памятью за счет использования нового движка парсинга для DOM
    Метки:
    Поделиться публикацией
    Похожие публикации
    Комментарии 0

    Только полноправные пользователи могут оставлять комментарии. Войдите, пожалуйста.