-
Notifications
You must be signed in to change notification settings - Fork 6
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
1 parent
540c548
commit a9efcb8
Showing
1 changed file
with
127 additions
and
0 deletions.
There are no files selected for viewing
127 changes: 127 additions & 0 deletions
127
packages/ui-components/src/__tests__/FieldDefinitionButtons.test.ts
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,127 @@ | ||
import { render, fireEvent } from '@testing-library/svelte'; | ||
import { describe, it, expect, vi, beforeEach } from 'vitest'; | ||
import FieldDefinitionButtons from '../lib/components/deployment/wizard/FieldDefinitionButtons.svelte'; | ||
import { DotrainOrderGui } from '@rainlanguage/orderbook/js_api'; | ||
import deploymentStepsStore from '../lib/components/deployment/wizard/deploymentStepsStore'; | ||
|
||
// Mock the DotrainOrderGui class | ||
vi.mock('@rainlanguage/orderbook/js_api', () => ({ | ||
DotrainOrderGui: vi.fn().mockImplementation(() => ({ | ||
saveFieldValue: vi.fn(), | ||
getFieldValue: vi.fn(), | ||
isFieldPreset: vi.fn() | ||
})) | ||
})); | ||
|
||
describe('FieldDefinitionButtons', () => { | ||
let mockGui: DotrainOrderGui; | ||
const mockFieldDefinition = { | ||
binding: 'test-binding', | ||
name: 'Test Field', | ||
description: 'Test Description', | ||
presets: [ | ||
{ id: 'preset1', name: 'Preset 1', value: 'value1' }, | ||
{ id: 'preset2', name: 'Preset 2', value: 'value2' } | ||
] | ||
}; | ||
|
||
beforeEach(() => { | ||
mockGui = new DotrainOrderGui(); | ||
vi.spyOn(deploymentStepsStore, 'updateDeploymentStep'); | ||
}); | ||
|
||
it('renders field name and description', () => { | ||
const { getByText } = render(FieldDefinitionButtons, { | ||
props: { | ||
fieldDefinition: mockFieldDefinition, | ||
gui: mockGui, | ||
currentStep: 0 | ||
} | ||
}); | ||
|
||
expect(getByText('Test Field')).toBeTruthy(); | ||
expect(getByText('Test Description')).toBeTruthy(); | ||
}); | ||
|
||
it('renders preset buttons', () => { | ||
const { getByText } = render(FieldDefinitionButtons, { | ||
props: { | ||
fieldDefinition: mockFieldDefinition, | ||
gui: mockGui, | ||
currentStep: 0 | ||
} | ||
}); | ||
|
||
expect(getByText('Preset 1')).toBeTruthy(); | ||
expect(getByText('Preset 2')).toBeTruthy(); | ||
expect(getByText('Custom')).toBeTruthy(); | ||
}); | ||
|
||
it('handles preset button clicks', async () => { | ||
const { getByText } = render(FieldDefinitionButtons, { | ||
props: { | ||
fieldDefinition: mockFieldDefinition, | ||
gui: mockGui, | ||
currentStep: 0 | ||
} | ||
}); | ||
|
||
await fireEvent.click(getByText('Preset 1')); | ||
|
||
expect(mockGui.saveFieldValue).toHaveBeenCalledWith('test-binding', { | ||
isPreset: true, | ||
value: 'preset1' | ||
}); | ||
expect(deploymentStepsStore.updateDeploymentStep).toHaveBeenCalled(); | ||
}); | ||
|
||
it('shows custom input when Custom button is clicked', async () => { | ||
const { getByText, getByPlaceholderText } = render(FieldDefinitionButtons, { | ||
props: { | ||
fieldDefinition: mockFieldDefinition, | ||
gui: mockGui, | ||
currentStep: 0 | ||
} | ||
}); | ||
|
||
await fireEvent.click(getByText('Custom')); | ||
expect(getByPlaceholderText('Enter custom value')).toBeTruthy(); | ||
}); | ||
|
||
it('handles custom input changes', async () => { | ||
const { getByText, getByPlaceholderText } = render(FieldDefinitionButtons, { | ||
props: { | ||
fieldDefinition: mockFieldDefinition, | ||
gui: mockGui, | ||
currentStep: 0 | ||
} | ||
}); | ||
|
||
await fireEvent.click(getByText('Custom')); | ||
const input = getByPlaceholderText('Enter custom value'); | ||
await fireEvent.input(input, { target: { value: 'custom value' } }); | ||
|
||
expect(mockGui.saveFieldValue).toHaveBeenCalledWith('test-binding', { | ||
isPreset: false, | ||
value: 'custom value' | ||
}); | ||
expect(deploymentStepsStore.updateDeploymentStep).toHaveBeenCalled(); | ||
}); | ||
|
||
it('does not show Custom button for is-fast-exit binding', () => { | ||
const fastExitFieldDef = { | ||
...mockFieldDefinition, | ||
binding: 'is-fast-exit' | ||
}; | ||
|
||
const { queryByText } = render(FieldDefinitionButtons, { | ||
props: { | ||
fieldDefinition: fastExitFieldDef, | ||
gui: mockGui, | ||
currentStep: 0 | ||
} | ||
}); | ||
|
||
expect(queryByText('Custom')).toBeNull(); | ||
}); | ||
}); |