/usr/share/grafana/public/app/features/variables/state
import { reduxTester } from '../../../../test/core/redux/reduxTester'; import { variableAdapters } from '../adapters'; import { ALL_VARIABLE_TEXT, ALL_VARIABLE_VALUE } from '../constants'; import { createCustomVariableAdapter } from '../custom/adapter'; import { customBuilder } from '../shared/testing/builders'; import { toKeyedVariableIdentifier, toVariablePayload } from '../utils'; import { setOptionFromUrl } from './actions'; import { getTemplatingRootReducer, TemplatingReducerType } from './helpers'; import { toKeyedAction } from './keyedVariablesReducer'; import { addVariable, setCurrentVariableValue } from './sharedReducer'; variableAdapters.setInit(() => [createCustomVariableAdapter()]); describe('when setOptionFromUrl is dispatched with a custom variable (no refresh property)', () => { it.each` urlValue | isMulti | expected ${'B'} | ${false} | ${'B'} ${['B']} | ${false} | ${'B'} ${'X'} | ${false} | ${'X'} ${''} | ${false} | ${''} ${null} | ${false} | ${''} ${undefined} | ${false} | ${''} ${'B'} | ${true} | ${['B']} ${['B']} | ${true} | ${['B']} ${'X'} | ${true} | ${['X']} ${''} | ${true} | ${['']} ${['A', 'B']} | ${true} | ${['A', 'B']} ${null} | ${true} | ${['']} ${undefined} | ${true} | ${['']} `('and urlValue is $urlValue then correct actions are dispatched', async ({ urlValue, expected, isMulti }) => { const key = 'key'; const custom = customBuilder() .withId('0') .withRootStateKey(key) .withMulti(isMulti) .withOptions('A', 'B', 'C') .withCurrent('A') .build(); const tester = await reduxTester<TemplatingReducerType>() .givenRootReducer(getTemplatingRootReducer()) .whenActionIsDispatched( toKeyedAction(key, addVariable(toVariablePayload(custom, { global: false, index: 0, model: custom }))) ) .whenAsyncActionIsDispatched(setOptionFromUrl(toKeyedVariableIdentifier(custom), urlValue), true); await tester.thenDispatchedActionsShouldEqual( toKeyedAction( key, setCurrentVariableValue( toVariablePayload( { type: 'custom', id: '0' }, { option: { text: expected, value: expected, selected: false } } ) ) ) ); }); }); describe('when setOptionFromUrl is dispatched for a variable with a custom all value', () => { it('and urlValue contains same all value then correct actions are dispatched', async () => { const allValue = '.*'; const urlValue = allValue; const key = 'key'; const custom = customBuilder() .withId('0') .withRootStateKey(key) .withMulti(false) .withIncludeAll() .withAllValue(allValue) .withOptions('A', 'B', 'C') .withCurrent('A') .build(); const tester = await reduxTester<TemplatingReducerType>() .givenRootReducer(getTemplatingRootReducer()) .whenActionIsDispatched( toKeyedAction(key, addVariable(toVariablePayload(custom, { global: false, index: 0, model: custom }))) ) .whenAsyncActionIsDispatched(setOptionFromUrl(toKeyedVariableIdentifier(custom), urlValue), true); await tester.thenDispatchedActionsShouldEqual( toKeyedAction( key, setCurrentVariableValue( toVariablePayload( { type: 'custom', id: '0' }, { option: { text: ALL_VARIABLE_TEXT, value: ALL_VARIABLE_VALUE, selected: false } } ) ) ) ); }); it('and urlValue differs from all value then correct actions are dispatched', async () => { const allValue = '.*'; const urlValue = 'X'; const key = 'key'; const custom = customBuilder() .withId('0') .withRootStateKey(key) .withMulti(false) .withIncludeAll() .withAllValue(allValue) .withOptions('A', 'B', 'C') .withCurrent('A') .build(); const tester = await reduxTester<TemplatingReducerType>() .givenRootReducer(getTemplatingRootReducer()) .whenActionIsDispatched( toKeyedAction(key, addVariable(toVariablePayload(custom, { global: false, index: 0, model: custom }))) ) .whenAsyncActionIsDispatched(setOptionFromUrl(toKeyedVariableIdentifier(custom), urlValue), true); await tester.thenDispatchedActionsShouldEqual( toKeyedAction( key, setCurrentVariableValue( toVariablePayload({ type: 'custom', id: '0' }, { option: { text: 'X', value: 'X', selected: false } }) ) ) ); }); it('and urlValue differs but matches an option then correct actions are dispatched', async () => { const allValue = '.*'; const urlValue = 'B'; const key = 'key'; const custom = customBuilder() .withId('0') .withRootStateKey(key) .withMulti(false) .withIncludeAll() .withAllValue(allValue) .withOptions('A', 'B', 'C') .withCurrent('A') .build(); const tester = await reduxTester<TemplatingReducerType>() .givenRootReducer(getTemplatingRootReducer()) .whenActionIsDispatched( toKeyedAction(key, addVariable(toVariablePayload(custom, { global: false, index: 0, model: custom }))) ) .whenAsyncActionIsDispatched(setOptionFromUrl(toKeyedVariableIdentifier(custom), urlValue), true); await tester.thenDispatchedActionsShouldEqual( toKeyedAction( key, setCurrentVariableValue( toVariablePayload({ type: 'custom', id: '0' }, { option: { text: 'B', value: 'B', selected: false } }) ) ) ); }); it('and custom all value matches an option', async () => { const allValue = '.*'; const urlValue = allValue; const key = 'key'; const custom = customBuilder() .withId('0') .withRootStateKey(key) .withMulti(false) .withIncludeAll() .withAllValue(allValue) .withOptions('A', 'B', '.*') .withCurrent('A') .build(); custom.options[2].value = 'special value for .*'; const tester = await reduxTester<TemplatingReducerType>() .givenRootReducer(getTemplatingRootReducer()) .whenActionIsDispatched( toKeyedAction(key, addVariable(toVariablePayload(custom, { global: false, index: 0, model: custom }))) ) .whenAsyncActionIsDispatched(setOptionFromUrl(toKeyedVariableIdentifier(custom), urlValue), true); await tester.thenDispatchedActionsShouldEqual( toKeyedAction( key, setCurrentVariableValue( toVariablePayload( { type: 'custom', id: '0' }, { option: { text: '.*', value: 'special value for .*', selected: false } } ) ) ) ); }); });
.
Edit
..
Edit
__tests__
Edit
actions.test.ts
Edit
actions.ts
Edit
helpers.ts
Edit
initVariableTransaction.test.ts
Edit
keyedVariablesReducer.test.ts
Edit
keyedVariablesReducer.ts
Edit
migrateVariablesDatasourceNameToRef.test.ts
Edit
onTimeRangeUpdated.test.ts
Edit
processVariable.test.ts
Edit
reducers.test.ts
Edit
reducers.ts
Edit
selectors.ts
Edit
setOptionFromUrl.test.ts
Edit
sharedReducer.test.ts
Edit
sharedReducer.ts
Edit
templateVarsChangedInUrl.test.ts
Edit
transactionReducer.test.ts
Edit
transactionReducer.ts
Edit
types.ts
Edit
upgradeLegacyQueries.test.ts
Edit
variablesReducer.ts
Edit