@alloy-js/core 0.23.0-dev.0 → 0.23.0-dev.8

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (269) hide show
  1. package/CHANGELOG.md +0 -22
  2. package/dist/devtools/index.html +68 -0
  3. package/dist/src/binder.d.ts +2 -0
  4. package/dist/src/binder.d.ts.map +1 -1
  5. package/dist/src/binder.js +55 -12
  6. package/dist/src/binder.js.map +1 -1
  7. package/dist/src/components/AppendFile.d.ts.map +1 -1
  8. package/dist/src/components/AppendFile.js +14 -3
  9. package/dist/src/components/AppendFile.js.map +1 -1
  10. package/dist/src/components/Block.js +1 -1
  11. package/dist/src/components/Block.js.map +1 -1
  12. package/dist/src/components/Declaration.d.ts.map +1 -1
  13. package/dist/src/components/Declaration.js +2 -1
  14. package/dist/src/components/Declaration.js.map +1 -1
  15. package/dist/src/components/Scope.d.ts.map +1 -1
  16. package/dist/src/components/Scope.js +4 -1
  17. package/dist/src/components/Scope.js.map +1 -1
  18. package/dist/src/components/TemplateFile.d.ts.map +1 -1
  19. package/dist/src/components/TemplateFile.js +18 -3
  20. package/dist/src/components/TemplateFile.js.map +1 -1
  21. package/dist/src/content-slot.d.ts.map +1 -1
  22. package/dist/src/content-slot.js +6 -5
  23. package/dist/src/content-slot.js.map +1 -1
  24. package/dist/src/context.d.ts.map +1 -1
  25. package/dist/src/context.js +8 -1
  26. package/dist/src/context.js.map +1 -1
  27. package/dist/src/debug/cli.d.ts +6 -0
  28. package/dist/src/debug/cli.d.ts.map +1 -0
  29. package/dist/src/{debug.js → debug/cli.js} +78 -84
  30. package/dist/src/debug/cli.js.map +1 -0
  31. package/dist/src/debug/diagnostics.test.d.ts +2 -0
  32. package/dist/src/debug/diagnostics.test.d.ts.map +1 -0
  33. package/dist/src/debug/diagnostics.test.js +45 -0
  34. package/dist/src/debug/diagnostics.test.js.map +1 -0
  35. package/dist/src/debug/effects.d.ts +69 -0
  36. package/dist/src/debug/effects.d.ts.map +1 -0
  37. package/dist/src/debug/effects.js +228 -0
  38. package/dist/src/debug/effects.js.map +1 -0
  39. package/dist/src/debug/effects.test.d.ts +2 -0
  40. package/dist/src/debug/effects.test.d.ts.map +1 -0
  41. package/dist/src/debug/effects.test.js +86 -0
  42. package/dist/src/debug/effects.test.js.map +1 -0
  43. package/dist/src/debug/files.d.ts +14 -0
  44. package/dist/src/debug/files.d.ts.map +1 -0
  45. package/dist/src/debug/files.js +40 -0
  46. package/dist/src/debug/files.js.map +1 -0
  47. package/dist/src/debug/files.test.d.ts +2 -0
  48. package/dist/src/debug/files.test.d.ts.map +1 -0
  49. package/dist/src/debug/files.test.js +89 -0
  50. package/dist/src/debug/files.test.js.map +1 -0
  51. package/dist/src/debug/index.d.ts +60 -0
  52. package/dist/src/debug/index.d.ts.map +1 -0
  53. package/dist/src/debug/index.js +68 -0
  54. package/dist/src/debug/index.js.map +1 -0
  55. package/dist/src/debug/render.d.ts +57 -0
  56. package/dist/src/debug/render.d.ts.map +1 -0
  57. package/dist/src/debug/render.js +519 -0
  58. package/dist/src/debug/render.js.map +1 -0
  59. package/dist/src/debug/render.test.d.ts +2 -0
  60. package/dist/src/debug/render.test.d.ts.map +1 -0
  61. package/dist/src/debug/render.test.js +328 -0
  62. package/dist/src/debug/render.test.js.map +1 -0
  63. package/dist/src/debug/serialize.d.ts +9 -0
  64. package/dist/src/debug/serialize.d.ts.map +1 -0
  65. package/dist/src/debug/serialize.js +70 -0
  66. package/dist/src/debug/serialize.js.map +1 -0
  67. package/dist/src/debug/symbols.d.ts +9 -0
  68. package/dist/src/debug/symbols.d.ts.map +1 -0
  69. package/dist/src/debug/symbols.js +164 -0
  70. package/dist/src/debug/symbols.js.map +1 -0
  71. package/dist/src/debug/symbols.test.d.ts +2 -0
  72. package/dist/src/debug/symbols.test.d.ts.map +1 -0
  73. package/dist/src/debug/symbols.test.js +104 -0
  74. package/dist/src/debug/symbols.test.js.map +1 -0
  75. package/dist/src/debug/trace.d.ts +342 -0
  76. package/dist/src/debug/trace.d.ts.map +1 -0
  77. package/dist/src/debug/trace.js +443 -0
  78. package/dist/src/debug/trace.js.map +1 -0
  79. package/dist/src/devtools/devtools-protocol.d.ts +232 -0
  80. package/dist/src/devtools/devtools-protocol.d.ts.map +1 -0
  81. package/dist/src/devtools/devtools-protocol.js +2 -0
  82. package/dist/src/devtools/devtools-protocol.js.map +1 -0
  83. package/dist/src/devtools/devtools-server.browser.d.ts +28 -0
  84. package/dist/src/devtools/devtools-server.browser.d.ts.map +1 -0
  85. package/dist/src/devtools/devtools-server.browser.js +36 -0
  86. package/dist/src/devtools/devtools-server.browser.js.map +1 -0
  87. package/dist/src/devtools/devtools-server.d.ts +72 -0
  88. package/dist/src/devtools/devtools-server.d.ts.map +1 -0
  89. package/dist/src/devtools/devtools-server.js +256 -0
  90. package/dist/src/devtools/devtools-server.js.map +1 -0
  91. package/dist/src/devtools/devtools-transport.d.ts +23 -0
  92. package/dist/src/devtools/devtools-transport.d.ts.map +1 -0
  93. package/dist/src/devtools/devtools-transport.js +114 -0
  94. package/dist/src/devtools/devtools-transport.js.map +1 -0
  95. package/dist/src/devtools-entry.browser.d.ts +4 -0
  96. package/dist/src/devtools-entry.browser.d.ts.map +1 -0
  97. package/dist/src/devtools-entry.browser.js +2 -0
  98. package/dist/src/devtools-entry.browser.js.map +1 -0
  99. package/dist/src/devtools-entry.d.ts +4 -0
  100. package/dist/src/devtools-entry.d.ts.map +1 -0
  101. package/dist/src/devtools-entry.js +2 -0
  102. package/dist/src/devtools-entry.js.map +1 -0
  103. package/dist/src/diagnostics.d.ts +34 -0
  104. package/dist/src/diagnostics.d.ts.map +1 -0
  105. package/dist/src/diagnostics.js +89 -0
  106. package/dist/src/diagnostics.js.map +1 -0
  107. package/dist/src/index.d.ts +3 -2
  108. package/dist/src/index.d.ts.map +1 -1
  109. package/dist/src/index.js +3 -2
  110. package/dist/src/index.js.map +1 -1
  111. package/dist/src/print-hook.d.ts +14 -0
  112. package/dist/src/print-hook.d.ts.map +1 -0
  113. package/dist/src/print-hook.js +10 -0
  114. package/dist/src/print-hook.js.map +1 -0
  115. package/dist/src/reactive-union-set.d.ts.map +1 -1
  116. package/dist/src/reactive-union-set.js +15 -0
  117. package/dist/src/reactive-union-set.js.map +1 -1
  118. package/dist/src/reactivity.d.ts +17 -3
  119. package/dist/src/reactivity.d.ts.map +1 -1
  120. package/dist/src/reactivity.js +162 -14
  121. package/dist/src/reactivity.js.map +1 -1
  122. package/dist/src/render-stack.d.ts +29 -0
  123. package/dist/src/render-stack.d.ts.map +1 -0
  124. package/dist/src/render-stack.js +247 -0
  125. package/dist/src/render-stack.js.map +1 -0
  126. package/dist/src/render.d.ts +9 -19
  127. package/dist/src/render.d.ts.map +1 -1
  128. package/dist/src/render.js +363 -153
  129. package/dist/src/render.js.map +1 -1
  130. package/dist/src/resource.d.ts.map +1 -1
  131. package/dist/src/resource.js +5 -0
  132. package/dist/src/resource.js.map +1 -1
  133. package/dist/src/runtime/component.d.ts +7 -1
  134. package/dist/src/runtime/component.d.ts.map +1 -1
  135. package/dist/src/runtime/component.js +4 -1
  136. package/dist/src/runtime/component.js.map +1 -1
  137. package/dist/src/scheduler.d.ts +3 -0
  138. package/dist/src/scheduler.d.ts.map +1 -1
  139. package/dist/src/scheduler.js +45 -2
  140. package/dist/src/scheduler.js.map +1 -1
  141. package/dist/src/symbols/basic-symbol.d.ts.map +1 -1
  142. package/dist/src/symbols/basic-symbol.js +6 -1
  143. package/dist/src/symbols/basic-symbol.js.map +1 -1
  144. package/dist/src/symbols/decl.d.ts.map +1 -1
  145. package/dist/src/symbols/decl.js +5 -1
  146. package/dist/src/symbols/decl.js.map +1 -1
  147. package/dist/src/symbols/output-scope.d.ts +2 -1
  148. package/dist/src/symbols/output-scope.d.ts.map +1 -1
  149. package/dist/src/symbols/output-scope.js +13 -8
  150. package/dist/src/symbols/output-scope.js.map +1 -1
  151. package/dist/src/symbols/output-symbol.d.ts +1 -0
  152. package/dist/src/symbols/output-symbol.d.ts.map +1 -1
  153. package/dist/src/symbols/output-symbol.js +23 -6
  154. package/dist/src/symbols/output-symbol.js.map +1 -1
  155. package/dist/src/symbols/symbol-flow.d.ts.map +1 -1
  156. package/dist/src/symbols/symbol-flow.js +22 -6
  157. package/dist/src/symbols/symbol-flow.js.map +1 -1
  158. package/dist/src/symbols/symbol-slot.d.ts.map +1 -1
  159. package/dist/src/symbols/symbol-slot.js +15 -0
  160. package/dist/src/symbols/symbol-slot.js.map +1 -1
  161. package/dist/src/symbols/symbol-slot.test.d.ts +2 -0
  162. package/dist/src/symbols/symbol-slot.test.d.ts.map +1 -0
  163. package/dist/src/symbols/symbol-slot.test.js +35 -0
  164. package/dist/src/symbols/symbol-slot.test.js.map +1 -0
  165. package/dist/src/symbols/symbol-table.d.ts.map +1 -1
  166. package/dist/src/symbols/symbol-table.js +6 -5
  167. package/dist/src/symbols/symbol-table.js.map +1 -1
  168. package/dist/src/trace.d.ts +2 -0
  169. package/dist/src/trace.d.ts.map +1 -0
  170. package/dist/src/trace.js +2 -0
  171. package/dist/src/trace.js.map +1 -0
  172. package/dist/src/tracer.d.ts +2 -228
  173. package/dist/src/tracer.d.ts.map +1 -1
  174. package/dist/src/tracer.js +5 -298
  175. package/dist/src/tracer.js.map +1 -1
  176. package/dist/src/utils.d.ts.map +1 -1
  177. package/dist/src/utils.js +5 -0
  178. package/dist/src/utils.js.map +1 -1
  179. package/dist/test/components/append-file.test.d.ts.map +1 -1
  180. package/dist/test/components/append-file.test.js +18 -10
  181. package/dist/test/components/append-file.test.js.map +1 -1
  182. package/dist/test/components/template-file.test.d.ts.map +1 -1
  183. package/dist/test/components/template-file.test.js +6 -4
  184. package/dist/test/components/template-file.test.js.map +1 -1
  185. package/dist/test/rendering/basic.test.js +3 -0
  186. package/dist/test/rendering/basic.test.js.map +1 -1
  187. package/dist/test/rendering/print-render-stack.test.d.ts +2 -0
  188. package/dist/test/rendering/print-render-stack.test.d.ts.map +1 -0
  189. package/dist/test/rendering/print-render-stack.test.js +207 -0
  190. package/dist/test/rendering/print-render-stack.test.js.map +1 -0
  191. package/dist/testing/create-test-wrapper.d.ts +1 -1
  192. package/dist/testing/create-test-wrapper.d.ts.map +1 -1
  193. package/dist/testing/create-test-wrapper.js +1 -1
  194. package/dist/testing/create-test-wrapper.js.map +1 -1
  195. package/dist/testing/devtools-utils.d.ts +26 -0
  196. package/dist/testing/devtools-utils.d.ts.map +1 -0
  197. package/dist/testing/devtools-utils.js +140 -0
  198. package/dist/testing/devtools-utils.js.map +1 -0
  199. package/dist/testing/extend-expect.d.ts.map +1 -1
  200. package/dist/testing/extend-expect.js +63 -1
  201. package/dist/testing/extend-expect.js.map +1 -1
  202. package/dist/testing/render.d.ts +2 -2
  203. package/dist/testing/render.d.ts.map +1 -1
  204. package/dist/testing/render.js +2 -2
  205. package/dist/testing/render.js.map +1 -1
  206. package/dist/tsconfig.tsbuildinfo +1 -1
  207. package/package.json +21 -7
  208. package/scripts/copy-devtools-ui.mjs +26 -0
  209. package/src/binder.ts +71 -16
  210. package/src/components/AppendFile.tsx +14 -9
  211. package/src/components/Block.tsx +1 -1
  212. package/src/components/Declaration.tsx +2 -1
  213. package/src/components/Scope.tsx +4 -1
  214. package/src/components/TemplateFile.tsx +18 -9
  215. package/src/content-slot.tsx +6 -6
  216. package/src/context.ts +15 -4
  217. package/src/{debug.ts → debug/cli.ts} +112 -127
  218. package/src/debug/diagnostics.test.tsx +55 -0
  219. package/src/debug/effects.test.tsx +96 -0
  220. package/src/debug/effects.ts +313 -0
  221. package/src/debug/files.test.tsx +96 -0
  222. package/src/debug/files.ts +40 -0
  223. package/src/debug/index.ts +126 -0
  224. package/src/debug/render.test.tsx +379 -0
  225. package/src/debug/render.ts +639 -0
  226. package/src/debug/serialize.ts +85 -0
  227. package/src/debug/symbols.test.tsx +106 -0
  228. package/src/debug/symbols.ts +230 -0
  229. package/src/debug/trace.ts +312 -0
  230. package/src/devtools/devtools-protocol.ts +312 -0
  231. package/src/devtools/devtools-server.browser.ts +71 -0
  232. package/src/devtools/devtools-server.ts +290 -0
  233. package/src/devtools/devtools-transport.ts +154 -0
  234. package/src/devtools-entry.browser.ts +52 -0
  235. package/src/devtools-entry.ts +54 -0
  236. package/src/diagnostics.ts +141 -0
  237. package/src/index.ts +2 -6
  238. package/src/print-hook.ts +22 -0
  239. package/src/reactive-union-set.ts +71 -41
  240. package/src/reactivity.ts +206 -23
  241. package/src/render-stack.ts +289 -0
  242. package/src/render.ts +464 -212
  243. package/src/resource.ts +28 -19
  244. package/src/runtime/component.ts +11 -0
  245. package/src/scheduler.ts +55 -3
  246. package/src/symbols/basic-symbol.ts +6 -1
  247. package/src/symbols/decl.ts +5 -1
  248. package/src/symbols/output-scope.ts +21 -12
  249. package/src/symbols/output-symbol.ts +33 -12
  250. package/src/symbols/symbol-flow.ts +68 -37
  251. package/src/symbols/symbol-slot.test.tsx +41 -0
  252. package/src/symbols/symbol-slot.tsx +47 -20
  253. package/src/symbols/symbol-table.ts +6 -10
  254. package/src/trace.ts +1 -0
  255. package/src/tracer.ts +13 -242
  256. package/src/utils.tsx +22 -13
  257. package/temp/api.json +1811 -277
  258. package/test/components/append-file.test.tsx +36 -29
  259. package/test/components/template-file.test.tsx +11 -11
  260. package/test/rendering/basic.test.tsx +4 -0
  261. package/test/rendering/print-render-stack.test.tsx +244 -0
  262. package/testing/create-test-wrapper.tsx +1 -1
  263. package/testing/devtools-utils.ts +203 -0
  264. package/testing/extend-expect.ts +89 -0
  265. package/testing/render.ts +2 -2
  266. package/testing/vitest.d.ts +9 -0
  267. package/dist/src/debug.d.ts +0 -15
  268. package/dist/src/debug.d.ts.map +0 -1
  269. package/dist/src/debug.js.map +0 -1
@@ -1,127 +1,16 @@
1
- import { isReactive } from "@vue/reactivity";
2
1
  import Table from "cli-table3";
3
2
  import pc from "picocolors";
4
- import { contextsByKey } from "./context.js";
5
- import { Context, getContext } from "./reactivity.js";
3
+ import { contextsByKey } from "../context.js";
4
+ import { getContext, untrack } from "../reactivity.js";
5
+ import { isReactiveTarget } from "./effects.js";
6
6
 
7
- interface DebugInterface {
8
- component: {
9
- stack(): void;
10
- tree(): void;
11
- watch(): void;
12
- render(): void;
13
- context(): void;
14
- };
15
- }
16
-
17
- const debug: DebugInterface = {
18
- component: {
19
- stack: debugStack,
20
- tree() {
21
- //eslint-disable-next-line no-console
22
- console.log("tree");
23
- },
24
- watch() {
25
- //eslint-disable-next-line no-console
26
- console.log("watch");
27
- },
28
- render() {
29
- //eslint-disable-next-line no-console
30
- console.log("render");
31
- },
32
- context: debugContext,
33
- },
34
- };
35
-
36
- function debugStack() {
37
- let currentContext = getContext();
38
- let foundContexts: Context[] = [];
39
- while (currentContext !== null) {
40
- if (
41
- currentContext.context &&
42
- Object.getOwnPropertySymbols(currentContext.context)[0]
43
- ) {
44
- foundContexts.push(currentContext);
45
- }
46
-
47
- if (
48
- currentContext.componentOwner &&
49
- currentContext.componentOwner.component.name !== "Provider"
50
- ) {
51
- process.stdout.write(
52
- style.component.name(currentContext.componentOwner.component.name) +
53
- "\n",
54
- );
55
- const table = kvTable();
56
- const props = currentContext.componentOwner.props;
57
-
58
- table.push([
59
- { hAlign: "right", content: "props" },
60
- props && Object.keys(props).length > 0 ?
61
- dumpValue(props)
62
- : pc.gray("(none)"),
63
- ]);
64
-
65
- table.push([
66
- { hAlign: "right", content: "contexts" },
67
- foundContexts.length > 0 ?
68
- foundContexts.map((c) => printContext(c, true)).join("\n")
69
- : pc.gray("(none)"),
70
- ]);
71
-
72
- process.stdout.write(table.toString() + "\n\n");
73
- foundContexts = [];
74
- }
75
-
76
- currentContext = currentContext.owner;
77
- }
78
- }
79
-
80
- function debugContext() {
81
- let currentContext = getContext();
82
- while (currentContext !== null) {
83
- //eslint-disable-next-line no-console
84
- console.log(printContext(currentContext));
85
- currentContext = currentContext.owner;
86
- }
87
- }
88
- function printContext(context: Context, omitOwner: boolean = false) {
89
- if (!context.context) return "";
90
- const key = Object.getOwnPropertySymbols(context.context)[0];
91
- if (!key) return "";
92
- const contextDefinition = contextsByKey.get(key);
93
- const contextName = contextDefinition?.name ?? "unknown context";
94
- const value = context.context[key];
95
-
96
- let output = style.context.name(contextName);
97
- if (!omitOwner) {
98
- const owner = findContextOwner(context);
99
- output += " provided by " + style.component.name(owner);
100
- }
101
-
102
- output += "\n" + dumpValue(value) + "\n";
103
-
104
- return output;
105
- }
106
-
107
- function findContextOwner(context: Context) {
108
- let currentContext: Context | null = context;
109
- while (
110
- currentContext &&
111
- (currentContext.componentOwner === undefined ||
112
- currentContext.componentOwner.component.name === "Provider")
113
- ) {
114
- currentContext = currentContext.owner;
7
+ function reactiveTag(value: unknown) {
8
+ if (isReactiveTarget(value)) {
9
+ return " " + pc.greenBright(`reactive`) + " ";
115
10
  }
116
-
117
- return currentContext?.componentOwner?.component.name ?? "unknown";
118
- }
119
- declare global {
120
- var debug: DebugInterface;
11
+ return "";
121
12
  }
122
13
 
123
- globalThis.debug = debug;
124
-
125
14
  const style = {
126
15
  value: {
127
16
  primitive(value: string | number | boolean | null | undefined) {
@@ -151,13 +40,6 @@ const style = {
151
40
  },
152
41
  };
153
42
 
154
- function reactiveTag(value: unknown) {
155
- if (isReactive(value)) {
156
- return " " + pc.greenBright(`reactive`) + " ";
157
- }
158
- return "";
159
- }
160
-
161
43
  function dumpValue(value: unknown, level = 0) {
162
44
  switch (typeof value) {
163
45
  case "boolean":
@@ -210,6 +92,109 @@ function kvTable(sep = " ") {
210
92
  });
211
93
  }
212
94
 
213
- export function shouldDebug() {
214
- return typeof process !== "undefined" && !!process.env?.ALLOY_DEBUG;
95
+ function printContext(
96
+ context: ReturnType<typeof getContext>,
97
+ omitOwner = false,
98
+ ) {
99
+ if (!context?.context) return "";
100
+ const key = Object.getOwnPropertySymbols(context.context)[0];
101
+ if (!key) return "";
102
+ const contextDefinition = contextsByKey.get(key);
103
+ const contextName = contextDefinition?.name ?? "unknown context";
104
+ const value = context.context[key];
105
+
106
+ let output = style.context.name(contextName);
107
+ if (!omitOwner) {
108
+ const owner = findContextOwner(context);
109
+ output += " provided by " + style.component.name(owner);
110
+ }
111
+
112
+ output += "\n" + dumpValue(value) + "\n";
113
+
114
+ return output;
115
+ }
116
+
117
+ function findContextOwner(context: ReturnType<typeof getContext>) {
118
+ let currentContext = context;
119
+ while (
120
+ currentContext &&
121
+ (currentContext.componentOwner === undefined ||
122
+ currentContext.componentOwner.component.name === "Provider")
123
+ ) {
124
+ currentContext = currentContext.owner;
125
+ }
126
+
127
+ return currentContext?.componentOwner?.component.name ?? "unknown";
128
+ }
129
+
130
+ export function debugStack() {
131
+ untrack(() => {
132
+ let currentContext = getContext();
133
+ let foundContexts: (typeof currentContext)[] = [];
134
+ while (currentContext !== null) {
135
+ if (
136
+ currentContext.context &&
137
+ Object.getOwnPropertySymbols(currentContext.context)[0]
138
+ ) {
139
+ foundContexts.push(currentContext);
140
+ }
141
+
142
+ if (
143
+ currentContext.componentOwner &&
144
+ currentContext.componentOwner.component.name !== "Provider"
145
+ ) {
146
+ process.stdout.write(
147
+ style.component.name(currentContext.componentOwner.component.name) +
148
+ "\n",
149
+ );
150
+ const table = kvTable();
151
+ const props = currentContext.componentOwner.props;
152
+
153
+ table.push([
154
+ { hAlign: "right", content: "props" },
155
+ props && Object.keys(props).length > 0 ?
156
+ dumpValue(props)
157
+ : pc.gray("(none)"),
158
+ ]);
159
+
160
+ table.push([
161
+ { hAlign: "right", content: "contexts" },
162
+ foundContexts.length > 0 ?
163
+ foundContexts.map((c) => printContext(c, true)).join("\n")
164
+ : pc.gray("(none)"),
165
+ ]);
166
+
167
+ process.stdout.write(table.toString() + "\n\n");
168
+ foundContexts = [];
169
+ }
170
+
171
+ currentContext = currentContext.owner;
172
+ }
173
+ });
174
+ }
175
+
176
+ export function debugContext() {
177
+ untrack(() => {
178
+ let currentContext = getContext();
179
+ while (currentContext !== null) {
180
+ // eslint-disable-next-line no-console
181
+ console.log(printContext(currentContext));
182
+ currentContext = currentContext.owner;
183
+ }
184
+ });
185
+ }
186
+
187
+ export function debugTree() {
188
+ // eslint-disable-next-line no-console
189
+ console.log("tree");
190
+ }
191
+
192
+ export function debugWatch() {
193
+ // eslint-disable-next-line no-console
194
+ console.log("watch");
195
+ }
196
+
197
+ export function debugRender() {
198
+ // eslint-disable-next-line no-console
199
+ console.log("render");
215
200
  }
@@ -0,0 +1,55 @@
1
+ import { afterEach, beforeEach, expect, it } from "vitest";
2
+ import WebSocket from "ws";
3
+ import {
4
+ createMessageCollector,
5
+ type DevtoolsMessage,
6
+ } from "../../testing/devtools-utils.js";
7
+ import { Output } from "../components/Output.jsx";
8
+ import {
9
+ enableDevtools,
10
+ resetDevtoolsServerForTests,
11
+ } from "../devtools/devtools-server.js";
12
+ import { DiagnosticsCollector } from "../diagnostics.js";
13
+ import { renderAsync } from "../render.js";
14
+
15
+ let socket: WebSocket | undefined;
16
+
17
+ beforeEach(async () => {
18
+ const server = await enableDevtools({ port: 0 });
19
+ socket = new WebSocket(`ws://127.0.0.1:${server.port}`);
20
+
21
+ await new Promise<void>((resolve, reject) => {
22
+ socket?.once("open", resolve);
23
+ socket?.once("error", reject);
24
+ });
25
+ });
26
+
27
+ afterEach(async () => {
28
+ if (socket) {
29
+ socket.close();
30
+ socket = undefined;
31
+ }
32
+
33
+ await resetDevtoolsServerForTests();
34
+ });
35
+
36
+ it("emits diagnostics:report messages", async () => {
37
+ const collector = createMessageCollector(socket!);
38
+ const diagnostics = new DiagnosticsCollector();
39
+
40
+ diagnostics.emit({ message: "Test diagnostic", severity: "warning" });
41
+
42
+ await renderAsync(<Output>{"ok"}</Output>);
43
+
44
+ const messages = await collector.waitForRender();
45
+ const diagnosticsMessages = messages.filter(
46
+ (m: DevtoolsMessage) => m.type === "diagnostics:report",
47
+ );
48
+
49
+ collector.stop();
50
+
51
+ expect(diagnosticsMessages[0]).toMatchObject({
52
+ type: "diagnostics:report",
53
+ diagnostics: expect.any(Array),
54
+ });
55
+ });
@@ -0,0 +1,96 @@
1
+ import { afterEach, beforeEach, expect, it } from "vitest";
2
+ import WebSocket from "ws";
3
+ import {
4
+ createMessageCollector,
5
+ filterEffectsMessages,
6
+ } from "../../testing/devtools-utils.js";
7
+ import { Output } from "../components/Output.jsx";
8
+ import {
9
+ enableDevtools,
10
+ resetDevtoolsServerForTests,
11
+ } from "../devtools/devtools-server.js";
12
+ import { effect, ref } from "../reactivity.js";
13
+ import { renderAsync } from "../render.js";
14
+ import { debug } from "./index.js";
15
+
16
+ let socket: WebSocket | undefined;
17
+
18
+ beforeEach(async () => {
19
+ debug.effect.reset();
20
+
21
+ const server = await enableDevtools({ port: 0 });
22
+ socket = new WebSocket(`ws://127.0.0.1:${server.port}`);
23
+ await new Promise<void>((resolve, reject) => {
24
+ socket?.once("open", resolve);
25
+ socket?.once("error", reject);
26
+ });
27
+ });
28
+
29
+ afterEach(async () => {
30
+ if (socket) {
31
+ socket.close();
32
+ socket = undefined;
33
+ }
34
+
35
+ await resetDevtoolsServerForTests();
36
+ debug.effect.reset();
37
+ });
38
+
39
+ it("emits effect, ref, edge, and update messages", async () => {
40
+ const collector = createMessageCollector(socket!);
41
+ const r1 = ref(0);
42
+ const r2 = ref(1);
43
+
44
+ effect(() => {
45
+ r1.value = r2.value + 1;
46
+ });
47
+
48
+ await renderAsync(<Output>{"ok"}</Output>);
49
+
50
+ const messages = await collector.waitForRender();
51
+ const effectsMessages = filterEffectsMessages(messages);
52
+ collector.stop();
53
+
54
+ expect(effectsMessages[0]).toMatchObject({
55
+ type: "effect:refAdded",
56
+ ref: expect.objectContaining({
57
+ id: expect.any(Number),
58
+ kind: "ref",
59
+ }),
60
+ });
61
+ expect(effectsMessages[1]).toMatchObject({
62
+ type: "effect:refAdded",
63
+ ref: expect.objectContaining({
64
+ id: expect.any(Number),
65
+ kind: "ref",
66
+ }),
67
+ });
68
+ expect(effectsMessages[2]).toMatchObject({
69
+ type: "effect:effectAdded",
70
+ effect: expect.objectContaining({
71
+ id: expect.any(Number),
72
+ }),
73
+ });
74
+ expect(effectsMessages[3]).toMatchObject({
75
+ type: "effect:track",
76
+ edge: expect.objectContaining({
77
+ type: "track",
78
+ effectId: expect.any(Number),
79
+ refId: expect.any(Number),
80
+ }),
81
+ });
82
+ expect(effectsMessages[4]).toMatchObject({
83
+ type: "effect:trigger",
84
+ edge: expect.objectContaining({
85
+ type: "trigger",
86
+ effectId: expect.any(Number),
87
+ refId: expect.any(Number),
88
+ }),
89
+ });
90
+ expect(effectsMessages[5]).toMatchObject({
91
+ type: "effect:effectUpdated",
92
+ effect: expect.objectContaining({
93
+ id: expect.any(Number),
94
+ }),
95
+ });
96
+ });