Fix node def handling of undefined fields (#1199)

* Fix node def handling

* nit

* Add test
This commit is contained in:
Chenlei Hu
2024-10-09 22:11:27 -04:00
committed by GitHub
parent 59a5f5f5d0
commit f71595fcc9
3 changed files with 22 additions and 8 deletions

View File

@@ -169,21 +169,21 @@ export class ComfyNodeDefImpl {
this.deprecated = obj.deprecated ?? obj.category === ''
this.experimental =
obj.experimental ?? obj.category.startsWith('_for_testing')
this.input = new ComfyInputsSpec(obj.input)
this.input = new ComfyInputsSpec(obj.input ?? {})
this.output = ComfyNodeDefImpl.transformOutputSpec(obj)
this.nodeSource = getNodeSource(obj.python_module)
}
private static transformOutputSpec(obj: any): ComfyOutputsSpec {
const { output, output_is_list, output_name, output_tooltips } = obj
const result = output.map((type: string | any[], index: number) => {
const result = (output ?? []).map((type: string | any[], index: number) => {
const typeString = Array.isArray(type) ? 'COMBO' : type
return new ComfyOutputSpec(
index,
output_name[index],
output_name?.[index],
typeString,
output_is_list[index],
output_is_list?.[index],
Array.isArray(type) ? type : undefined,
output_tooltips?.[index]
)

View File

@@ -346,10 +346,10 @@ const zComfyOutputTypesSpec = z.array(
)
const zComfyNodeDef = z.object({
input: zComfyInputsSpec,
output: zComfyOutputTypesSpec,
output_is_list: z.array(z.boolean()),
output_name: z.array(z.string()),
input: zComfyInputsSpec.optional(),
output: zComfyOutputTypesSpec.optional(),
output_is_list: z.array(z.boolean()).optional(),
output_name: z.array(z.string()).optional(),
output_tooltips: z.array(z.string()).optional(),
name: z.string(),
display_name: z.string(),

View File

@@ -356,6 +356,20 @@ describe('ComfyNodeDefImpl', () => {
expect(result.output.all).toEqual([])
})
it('should handle undefined fields', () => {
const plainObject = {
name: 'EmptyOutputNode',
display_name: 'Empty Output Node',
category: 'Test',
python_module: 'test_module',
description: 'A node with no outputs'
}
const result = new ComfyNodeDefImpl(plainObject)
expect(result.output.all).toEqual([])
expect(result.input.all).toEqual([])
})
it('should handle complex input specifications', () => {
const plainObject = {
name: 'ComplexInputNode',