feat(vela-ui): add placeholder push-to-talk control shell
This commit is contained in:
@@ -68,6 +68,7 @@ describe('voice session shell', () => {
|
||||
|
||||
expect(getByTestId('connection-state').textContent).toBe('not connected');
|
||||
expect(getByTestId('mocked-turn-button').hasAttribute('disabled')).toBe(true);
|
||||
expect(getByTestId('mic-control-button').hasAttribute('disabled')).toBe(true);
|
||||
|
||||
await fireEvent.click(getByTestId('connect-button'));
|
||||
const socket = MockWebSocket.latest();
|
||||
@@ -78,6 +79,7 @@ describe('voice session shell', () => {
|
||||
await waitFor(() => {
|
||||
expect(getByTestId('connection-state').textContent).toBe('connected');
|
||||
expect(getByTestId('mocked-turn-button').hasAttribute('disabled')).toBe(false);
|
||||
expect(getByTestId('mic-control-button').hasAttribute('disabled')).toBe(false);
|
||||
});
|
||||
|
||||
await fireEvent.click(getByTestId('disconnect-button'));
|
||||
@@ -86,10 +88,69 @@ describe('voice session shell', () => {
|
||||
await waitFor(() => {
|
||||
expect(getByTestId('connection-state').textContent).toBe('disconnected');
|
||||
expect(getByTestId('mocked-turn-button').hasAttribute('disabled')).toBe(true);
|
||||
expect(getByTestId('mic-control-button').hasAttribute('disabled')).toBe(true);
|
||||
expect(getByTestId('session-id').textContent).toBe('session-123');
|
||||
});
|
||||
});
|
||||
|
||||
it('runs a placeholder mic-control cycle and keeps mocked turn usable on the same socket', async () => {
|
||||
render(VoiceSessionShell);
|
||||
|
||||
await fireEvent.click(getByTestId('connect-button'));
|
||||
const socket = MockWebSocket.latest();
|
||||
socket.open();
|
||||
|
||||
await waitFor(() => {
|
||||
expect(getByTestId('connection-state').textContent).toBe('connected');
|
||||
});
|
||||
|
||||
expect(getByTestId('mic-control-button').hasAttribute('disabled')).toBe(true);
|
||||
|
||||
socket.message(createMessageEnvelope('session.ready', { sessionId: 'session-mic' }));
|
||||
socket.message(createMessageEnvelope('session.state', { value: 'idle' }));
|
||||
|
||||
await waitFor(() => {
|
||||
expect(getByTestId('mic-control-button').hasAttribute('disabled')).toBe(false);
|
||||
});
|
||||
|
||||
await fireEvent.mouseDown(getByTestId('mic-control-button'));
|
||||
|
||||
expect(socket.sent).toHaveLength(1);
|
||||
expect(JSON.parse(socket.sent[0])).toEqual({
|
||||
type: 'input_audio.append',
|
||||
payload: { chunk: 'placeholder-control-shell-chunk' }
|
||||
});
|
||||
expect(getByTestId('mic-control-status').textContent).toBe('holding');
|
||||
|
||||
socket.message(createMessageEnvelope('session.state', { value: 'listening' }));
|
||||
|
||||
await waitFor(() => {
|
||||
expect(getByTestId('gateway-session-state').textContent).toBe('listening');
|
||||
expect(getByTestId('mocked-turn-button').hasAttribute('disabled')).toBe(true);
|
||||
});
|
||||
|
||||
await fireEvent.mouseUp(getByTestId('mic-control-button'));
|
||||
|
||||
expect(socket.sent).toHaveLength(2);
|
||||
expect(JSON.parse(socket.sent[1])).toEqual({
|
||||
type: 'input_audio.commit',
|
||||
payload: {}
|
||||
});
|
||||
expect(getByTestId('mic-control-status').textContent).toBe('idle');
|
||||
|
||||
socket.message(createMessageEnvelope('session.state', { value: 'idle' }));
|
||||
|
||||
await waitFor(() => {
|
||||
expect(getByTestId('gateway-session-state').textContent).toBe('idle');
|
||||
expect(getByTestId('mocked-turn-button').hasAttribute('disabled')).toBe(false);
|
||||
});
|
||||
|
||||
await fireEvent.click(getByTestId('mocked-turn-button'));
|
||||
|
||||
expect(socket.sent).toHaveLength(3);
|
||||
expect(JSON.parse(socket.sent[2]).type).toBe('mocked.turn.trigger');
|
||||
});
|
||||
|
||||
it('renders mocked transcript before assistant response for a connected session', async () => {
|
||||
render(VoiceSessionShell);
|
||||
|
||||
|
||||
Reference in New Issue
Block a user