mirror of
https://github.com/Comfy-Org/ComfyUI_frontend.git
synced 2026-01-30 21:09:53 +00:00
<img width="596" height="213" alt="image" src="https://github.com/user-attachments/assets/174c5461-f638-42de-b3ad-0e108dee3983" />  ┆Issue is synchronized with this [Notion page](https://www.notion.so/PR-6354-Add-pricing-badge-when-a-subgraph-contains-partner-nodes-29b6d73d365081c685bec3e9446970eb) by [Unito](https://www.unito.io)
65 lines
2.0 KiB
TypeScript
65 lines
2.0 KiB
TypeScript
import { describe, expect, vi } from 'vitest'
|
|
|
|
import { LGraphNode } from '@/lib/litegraph/src/litegraph'
|
|
import type { LGraphBadge } from '@/lib/litegraph/src/LGraphBadge'
|
|
import type { LGraphIcon } from '@/lib/litegraph/src/LGraphIcon'
|
|
|
|
import { subgraphTest } from '../../litegraph/subgraph/fixtures/subgraphFixtures'
|
|
|
|
import { usePriceBadge } from '@/composables/node/usePriceBadge'
|
|
|
|
vi.mock('@/stores/workspace/colorPaletteStore', () => ({
|
|
useColorPaletteStore: () => ({
|
|
completedActivePalette: {
|
|
light_theme: false,
|
|
colors: { litegraph_base: {} }
|
|
}
|
|
})
|
|
}))
|
|
|
|
const { updateSubgraphCredits } = usePriceBadge()
|
|
|
|
const mockNode = new LGraphNode('mock node')
|
|
const mockIcon: Partial<LGraphIcon> = { unicode: '\ue96b' }
|
|
const badge: Partial<LGraphBadge> = {
|
|
icon: mockIcon as LGraphIcon,
|
|
text: '$0.05/Run'
|
|
}
|
|
mockNode.badges = [badge as LGraphBadge]
|
|
|
|
function getBadgeText(node: LGraphNode): string {
|
|
const badge = node.badges[0]
|
|
return (typeof badge === 'function' ? badge() : badge).text
|
|
}
|
|
|
|
describe('subgraph pricing', () => {
|
|
subgraphTest(
|
|
'should not display badge for subgraphs without API nodes',
|
|
({ subgraphWithNode }) => {
|
|
const { subgraphNode } = subgraphWithNode
|
|
updateSubgraphCredits(subgraphNode)
|
|
expect(subgraphNode.badges.length).toBe(0)
|
|
}
|
|
)
|
|
subgraphTest(
|
|
'should return the price of a single contained API node',
|
|
({ subgraphWithNode }) => {
|
|
const { subgraphNode, subgraph } = subgraphWithNode
|
|
subgraph.add(mockNode)
|
|
updateSubgraphCredits(subgraphNode)
|
|
expect(subgraphNode.badges.length).toBe(1)
|
|
expect(getBadgeText(subgraphNode)).toBe('$0.05/Run')
|
|
}
|
|
)
|
|
subgraphTest(
|
|
'should return the number of api nodes if more than one exists',
|
|
({ subgraphWithNode }) => {
|
|
const { subgraphNode, subgraph } = subgraphWithNode
|
|
for (let i = 0; i < 5; i++) subgraph.add(mockNode)
|
|
updateSubgraphCredits(subgraphNode)
|
|
expect(subgraphNode.badges.length).toBe(1)
|
|
expect(getBadgeText(subgraphNode)).toBe('Partner Nodes x 5')
|
|
}
|
|
)
|
|
})
|