调试

Debugging(调试)

在本指南中,我们将探索调试 AdonisJS 应用程序的多种方法,包括使用 VSCode 调试器、使用 Dump and Die 以及查看框架的调试日志。

使用 VSCode 调试器进行调试

使用 VSCode 调试器调试 AdonisJS 应用程序非常简单。你只需要创建一个 .vscode/launch.json 文件,并使用 Node.js 调试器。

在下面的示例中,我们定义了一个配置来启动 AdonisJS 开发服务器,并将其置于调试模式,然后将 VSCode 调试器附加到它上面。

另请参阅:VSCode 官方调试文档

.vscode/launch.json
{
"version": "0.2.0",
"configurations": [
{
"type": "node",
"request": "launch",
"name": "Dev server",
"program": "${workspaceFolder}/ace.js",
"args": ["serve", "--hmr"],
"skipFiles": ["<node_internals>/**"]
}
]
}

开始调试:

  • 使用 (CMD + Shift + P) 打开命令面板。(Windows 系统的快捷键为 Ctrl + Shift + P
  • 搜索 Debug: Select and Start Debugging。你将从 .vscode/launch.json 文件中看到一系列启动选项。
  • 选择 Dev server 选项,以使用 VSCode 调试器运行 HTTP 服务器。

调试测试

你可以定义另一个启动选项,用于在调试模式下运行测试。

.vscode/launch.json
{
"version": "0.2.0",
"configurations": [
{
"type": "node",
"request": "launch",
"name": "Dev server",
"program": "${workspaceFolder}/ace.js",
"args": ["serve", "--hmr"],
"skipFiles": ["<node_internals>/**"]
},
{
"type": "node",
"request": "launch",
"name": "Tests",
"program": "${workspaceFolder}/ace.js",
"args": ["test", "--watch"],
"skipFiles": ["<node_internals>/**"]
}
]
}

调试其他所有 Ace 命令

为每个 Ace 命令定义单独的启动选项并不实际。因此,你可以在 .vscode/launch.json 文件中定义一个 attach 配置。

attach 模式下,VSCode 将其调试器附加到 已经运行的 Node.js 进程上,前提是该进程是在 VSCode 集成终端内使用 --inspect 标志启动的。

让我们从修改 .vscode/launch.json 文件开始,并向其中添加以下配置。

.vscode/launch.json
{
"version": "0.2.0",
"configurations": [
{
"type": "node",
"request": "attach",
"name": "Attach Program",
"port": 9229,
"autoAttachChildProcesses": true,
"skipFiles": ["<node_internals>/**"]
},
{
"type": "node",
"request": "launch",
"name": "Dev server",
"program": "${workspaceFolder}/ace.js",
"args": ["serve", "--hmr"],
"skipFiles": ["<node_internals>/**"]
},
{
"type": "node",
"request": "launch",
"name": "Tests",
"program": "${workspaceFolder}/ace.js",
"args": ["test", "--watch"],
"skipFiles": ["<node_internals>/**"]
}
]
}

在附加模式下开始调试:

  • 使用 (CMD + Shift + P) 打开命令面板。
  • 搜索 Debug: Select and Start Debugging。你将从 .vscode/launch.json 文件中看到一系列启动选项。
  • 选择 Attach Program 选项。
  • 使用 --inspect 标志运行 Ace 命令。例如:
    node --inspect ace migration:run

调试 Edge 模板

你可以调试 Edge 模板,就像调试用 TypeScript 编写的应用程序代码一样。然而,在 Edge 中,你无法使用 VSCode 提供的断点。相反,你必须使用 @debugger 标签来定义代码内断点。

调试器将显示 Edge 模板的编译输出。

@debugger

Dump and Die(输出并终止)

Dump and Die(简称 dd)类似于最受欢迎的调试技术 console.log。然而,dd 辅助函数会通过抛出异常来中止执行,并在浏览器或终端中显示输出。

当你在 HTTP 请求期间使用 dd 辅助函数时,输出会被渲染为 HTML 文档。否则,输出将在终端中显示。

start/routes.ts
import User from '#models/user'
import router from '@adonisjs/core/services/router'
import { dd } from '@adonisjs/core/services/dumper'
router.get('/users', async () => {
const users = await User.all()
/**
* 访问 "/users" 端点以查看倾倒的值
*/
dd(users)
return users
})

dd 的输出与使用 console.log 时看到的输出略有不同。

  • 你可以看到输出值所在的源代码位置。
  • 你可以查看类的静态属性和对象的原型属性。
  • 默认情况下,显示嵌套深度达 10 层的值。
  • 支持多种 HTML 输出主题。你可以选择 nightOwlcatppuccinminLight

Edge 辅助函数用于调试

你可以在 Edge 模板中通过 @dd 标签使用 dd 辅助函数。此外,你还可以使用 @dump 辅助函数,它不会抛出异常,而是继续渲染模板的其余部分。

{{-- 倾倒模板状态并终止 --}}
@dd(state)
{{-- 倾倒模板状态并继续渲染 --}}
@dump(state)

Dumper 设置

你可以在 config/app.ts 文件中配置 dumper 设置。该文件应导出一个 dumper 配置对象,如下所示。

config/app.ts
/**
* “dd” 辅助函数使用的全局配置。你可以
* 分别为 “console” 和 “html” 渲染器输出
* 配置设置。
*/
export const dumper = dumperConfig({
/**
* 控制台渲染器输出的设置
*/
console: {
depth: 10,
/**
* 不应进一步展开的对象。数组接受
* 对象构造函数名称的数组。
*/
collapse: ['DateTime', 'Date'],
inspectStaticMembers: true,
},
/**
* HTML 渲染器输出的设置
*/
html: {
depth: 10,
inspectStaticMembers: true,
},
})
showHidden

当设置为 true 时,将处理对象的不可枚举属性。默认值:false

depth

停止解析嵌套值的深度。所有树状数据结构(例如对象、数组、映射和集合)共享此深度。默认值:5

inspectObjectPrototype

检查对象的原型属性。默认情况下包含原型的不可枚举属性。默认值:'unless-plain-object'

  • 当设置为 true 时,将处理所有对象的原型属性。
  • 当设置为 false 时,从不处理原型属性。
  • 当设置为 'unless-plain-object' 时,将处理类实例的原型属性。
inspectArrayPrototype

检查数组的原型属性。默认值:false

inspectStaticMembers

检查类的静态成员。尽管函数和类在技术上相同,但此配置仅适用于使用 [class] 关键字定义的函数。默认值:false

maxArrayLength

要处理的 数组映射集合 的最大成员数。默认值:100

maxStringLength

要显示的字符串的最大字符数。默认值:1000

collapse

一个包含不应进一步审查的对象构造函数名称的数组。

框架调试日志

你可以使用 NODE_DEBUG 环境变量查看框架的调试日志。Node.js 运行时支持 NODE_DEBUG 标志,你可以使用它查看一个或多个模块的日志,只需指定模块名称即可。

例如,你可以使用 NODE_DEBUG="adonisjs:*" 值查看所有 AdonisJS 包的日志。

NODE_DEBUG="adonisjs:*" node ace serve --hmr

同样,你可以使用 NODE_DEBUG 环境变量查看来自 Node.js 原生模块的日志,如 fsnetmodule 等。

NODE_DEBUG="adonisjs:*,net,fs" node ace serve --hmr