Skip to content

Commit

Permalink
Use Immer in components reducer (#70)
Browse files Browse the repository at this point in the history
* Use immer

* Add tests on component reducers
  • Loading branch information
baptadn authored Feb 20, 2020
1 parent c48bee7 commit 258e073
Show file tree
Hide file tree
Showing 2 changed files with 264 additions and 140 deletions.
181 changes: 181 additions & 0 deletions src/core/models/components.test.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,181 @@
import components, { ComponentsState, INITIAL_COMPONENTS } from './components'
import { onboarding } from '../../templates/onboarding'
import produce from 'immer'

const STATE: ComponentsState = {
components: {
'button-testid': {
children: [],
id: 'button-testid',
parent: 'root',
props: { children: 'Button text' },
rootParentType: 'Button',
type: 'Button',
},
root: {
children: ['button-testid'],
id: 'root',
parent: 'root',
props: {},
type: 'Box',
},
},
selectedId: 'button-testid',
}

describe('Components model', () => {
it('should reset the state', async () => {
const state: ComponentsState = {
components: INITIAL_COMPONENTS,
selectedId: 'root',
}

const nextState = components.reducers.reset(state)
expect(nextState).toEqual(state)
})

it('should load a demo', async () => {
const state: ComponentsState = {
components: INITIAL_COMPONENTS,
selectedId: 'root',
}

const nextState = components.reducers.loadDemo(state, 'onboarding')
expect(nextState).toEqual({
components: onboarding,
selectedId: 'comp-root',
})
})

it('should reset props', async () => {
return produce(STATE, (draftState: ComponentsState) => {
draftState.components['button-testid'].props = {
children: 'Button text',
variant: 'ghost',
}

const nextState = components.reducers.resetProps(
draftState,
'button-testid',
)

expect(nextState.components['button-testid'].props).toEqual({
children: 'Button text',
})
})
})

it('should update props', async () => {
const nextState = components.reducers.updateProps(STATE, {
id: 'button-testid',
name: 'variantColor',
value: 'teal.300',
})

expect(nextState.components['button-testid'].props).toEqual({
children: 'Button text',
variantColor: 'teal.300',
})
})

it('should add a new component', async () => {
const state: ComponentsState = {
components: INITIAL_COMPONENTS,
selectedId: 'root',
}

const nextState = components.reducers.addComponent(state, {
parentName: 'root',
type: 'Button',
testId: 'button-testid',
})

expect(nextState).toEqual(STATE)
})

it('should delete a simple component', async () => {
const nextState = components.reducers.deleteComponent(
STATE,
'button-testid',
)

expect(nextState).toEqual({
components: INITIAL_COMPONENTS,
selectedId: 'root',
})
})

it('should move a component', async () => {
return produce(STATE, (draftState: ComponentsState) => {
draftState.components['box-testid'] = {
children: [],
id: 'box-testid',
parent: 'root',
props: {},
rootParentType: 'Box',
type: 'Box',
}

expect(draftState.components['root'].children).toContain('button-testid')

const nextState = components.reducers.moveComponent(draftState, {
parentId: 'box-testid',
componentId: 'button-testid',
})

expect(nextState.components['box-testid'].children).toContain(
'button-testid',
)

expect(nextState.components['root'].children).not.toContain(
'button-testid',
)
})
})

it('should move a selected component', async () => {
return produce(STATE, (draftState: ComponentsState) => {
draftState.components['box-testid'] = {
children: [],
id: 'box-testid',
parent: 'root',
props: {},
rootParentType: 'Box',
type: 'Box',
}

draftState.selectedId = 'root'
draftState.components['root'].children.push('box-testid')

expect(draftState.components['root'].children).toEqual([
'button-testid',
'box-testid',
])

const nextState = components.reducers.moveSelectedComponentChildren(
draftState,
{
fromIndex: 0,
toIndex: 1,
},
)

expect(nextState.components['root'].children).toEqual([
'box-testid',
'button-testid',
])
})
})

it('should select a component', async () => {
expect(STATE.selectedId).toEqual('button-testid')
const nextState = components.reducers.select(STATE, 'root')
expect(nextState.selectedId).toEqual('root')
})

it('should unselect a component', async () => {
expect(STATE.selectedId).toEqual('button-testid')
const nextState = components.reducers.unselect(STATE)
expect(nextState.selectedId).toEqual('root')
})
})
Loading

0 comments on commit 258e073

Please sign in to comment.