V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
推荐关注
Meteor
JSLint - a JavaScript code quality tool
jsFiddle
D3.js
WebStorm
推荐书目
JavaScript 权威指南第 5 版
Closure: The Definitive Guide
yazoox
V2EX  ›  JavaScript

调试的时候,怎么 debug 进入到第三方的 library 里面去?

  •  
  •   yazoox · 2021-06-02 15:18:48 +08:00 · 2775 次点击
    这是一个创建于 1306 天前的主题,其中的信息可能已经有所发展或是发生改变。

    我有一个项目,A,最后编译成 一个 package, 可以 publish 出去的。

    现在,我需要写一个集成测试,就是新建立一个项目 B,里面都是测试,用 jest 跑,主要就是调用包 A 里面的函数,测试它。

    现在,我 B 运行时,调用 A 的函数返回值不是预期的,我想 debug 进入到 A 里面。但是 Debug jest,B 里面断点都是有效的,能正常工作。但是我通过"node_modules"里面打开 A 的.js 文件(编译后的文件,安装 A 以后,有 a.js 还有 a.js.map, a.d.ts ),在里面打断点,运行起来后,无效。断点不会打断。

    这个是怎么回事?有相关办法么?

    谢谢!

    4 条回复    2021-06-07 17:24:33 +08:00
    lengxubo
        1
    lengxubo  
       2021-06-02 15:21:57 +08:00
    实际跑起来过后的项目用的依赖都是 node_modules 里编译后生成的现成文件,你打断点那个是源码,肯定不行呀。

    可以试试在浏览器的 source 里找到对应文件,在浏览器里打断点调试
    murmur
        2
    murmur  
       2021-06-02 15:43:25 +08:00
    npm 下来的模块有的是带了 dist,有的是源码引用,很多默认是引用的 dist 版,源码只是给你看的
    Al0rid4l
        3
    Al0rid4l  
       2021-06-02 17:37:26 +08:00
    先确认断点的文件是被执行的, 再确认是不是在同一个进程执行的, 不是的话需要 attach 到对应的进程调试才会进入断点
    muzuiget
        4
    muzuiget  
       2021-06-07 17:24:33 +08:00
    说明你打断点的源码和实际执行不是同一个文件。

    最简单就是在你调用 A 的语句前加个“debugger;”暂停后 step into 进去 A 。
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   2710 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 23ms · UTC 08:14 · PVG 16:14 · LAX 00:14 · JFK 03:14
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.