@reduxjs/toolkit
Version:
The official, opinionated, batteries-included toolset for efficient Redux development
112 lines (95 loc) • 2.77 kB
text/typescript
import { createApi, fetchBaseQuery } from '@reduxjs/toolkit/query/react'
import { configureStore, createSelector } from '@reduxjs/toolkit'
describe('type tests', () => {
test('buildSelector type test', () => {
interface Todo {
userId: number
id: number
title: string
completed: boolean
}
type Todos = Array<Todo>
const exampleApi = createApi({
reducerPath: 'api',
baseQuery: fetchBaseQuery({
baseUrl: 'https://jsonplaceholder.typicode.com',
}),
endpoints: (build) => ({
getTodos: build.query<Todos, string>({
query: () => '/todos',
}),
}),
})
const exampleQuerySelector = exampleApi.endpoints.getTodos.select('/')
const todosSelector = createSelector(
[exampleQuerySelector],
(queryState) => {
return queryState?.data?.[0] ?? ({} as Todo)
},
)
const firstTodoTitleSelector = createSelector(
[todosSelector],
(todo) => todo?.title,
)
const store = configureStore({
reducer: {
[exampleApi.reducerPath]: exampleApi.reducer,
other: () => 1,
},
})
const todoTitle = firstTodoTitleSelector(store.getState())
// This only compiles if we carried the types through
const upperTitle = todoTitle.toUpperCase()
expectTypeOf(upperTitle).toBeString()
})
test('selectCachedArgsForQuery type test', () => {
interface Todo {
userId: number
id: number
title: string
completed: boolean
}
type Todos = Array<Todo>
const exampleApi = createApi({
reducerPath: 'api',
baseQuery: fetchBaseQuery({
baseUrl: 'https://jsonplaceholder.typicode.com',
}),
endpoints: (build) => ({
getTodos: build.query<Todos, string>({
query: () => '/todos',
}),
getInfiniteTodos: build.infiniteQuery<Todos, string, number>({
infiniteQueryOptions: {
initialPageParam: 0,
maxPages: 3,
getNextPageParam: (
lastPage,
allPages,
lastPageParam,
allPageParams,
) => lastPageParam + 1,
},
query({ pageParam }) {
return `/todos?page=${pageParam}`
},
}),
}),
})
const store = configureStore({
reducer: {
[exampleApi.reducerPath]: exampleApi.reducer,
other: () => 1,
},
})
expectTypeOf(
exampleApi.util.selectCachedArgsForQuery(store.getState(), 'getTodos'),
).toEqualTypeOf<string[]>()
expectTypeOf(
exampleApi.util.selectCachedArgsForQuery(
store.getState(),
'getInfiniteTodos',
),
).toEqualTypeOf<string[]>()
})
})