Merge branch 'subduxes-as-class-objects'
This commit is contained in:
commit
a6b6a54c72
32
src/subduxes.test.ts
Normal file
32
src/subduxes.test.ts
Normal file
@ -0,0 +1,32 @@
|
|||||||
|
import { test, expect } from 'vitest';
|
||||||
|
import { expectTypeOf } from 'expect-type';
|
||||||
|
|
||||||
|
import Updux from './Updux.js';
|
||||||
|
|
||||||
|
const subA = new Updux({
|
||||||
|
initialState: true,
|
||||||
|
actions: {
|
||||||
|
action1: (x: string) => x,
|
||||||
|
},
|
||||||
|
selectors: {
|
||||||
|
getAntiSub: (s) => !s,
|
||||||
|
},
|
||||||
|
});
|
||||||
|
|
||||||
|
const mainDux = new Updux({
|
||||||
|
subduxes: { subA },
|
||||||
|
});
|
||||||
|
|
||||||
|
test('subduxes resolves as objects', () => {
|
||||||
|
expectTypeOf(mainDux.initialState).toMatchTypeOf<{
|
||||||
|
subA: boolean;
|
||||||
|
}>();
|
||||||
|
expectTypeOf(mainDux.actions.action1('foo')).toMatchTypeOf<{
|
||||||
|
type: 'action1';
|
||||||
|
payload: string;
|
||||||
|
}>();
|
||||||
|
expectTypeOf(
|
||||||
|
mainDux.selectors.getAntiSub({ subA: true }),
|
||||||
|
).toMatchTypeOf<boolean>();
|
||||||
|
expect(mainDux.selectors.getAntiSub({ subA: true })).toEqual(false);
|
||||||
|
});
|
Loading…
Reference in New Issue
Block a user