UNPKG

@hookform/resolvers

Version:

React Hook Form validation resolvers: Yup, Joi, Superstruct, Zod, Vest, Class Validator, io-ts, Nope, computed-types, TypeBox, arktype, Typanion, Effect-TS and VineJS

152 lines (125 loc) 4.21 kB
import { Resolver, SubmitHandler, useForm } from 'react-hook-form'; import { z } from 'zod'; import { standardSchemaResolver } from '..'; import { customSchema, fields, invalidData, schema, validData, } from './__fixtures__/data'; const shouldUseNativeValidation = false; describe('standardSchemaResolver', () => { it('should return values from standardSchemaResolver when validation pass', async () => { const result = await standardSchemaResolver(schema)(validData, undefined, { fields, shouldUseNativeValidation, }); expect(result).toMatchSnapshot(); }); it('should return a single error from standardSchemaResolver when validation fails', async () => { const result = await standardSchemaResolver(schema)( invalidData, undefined, { fields, shouldUseNativeValidation, }, ); expect(result).toMatchSnapshot(); }); it('should return all the errors from standardSchemaResolver when validation fails with `validateAllFieldCriteria` set to true', async () => { const result = await standardSchemaResolver(schema)( invalidData, undefined, { fields, criteriaMode: 'all', shouldUseNativeValidation, }, ); expect(result).toMatchSnapshot(); }); it('should return values from standardSchemaResolver when validation pass & raw=true', async () => { const validateSpy = vi.spyOn(schema['~standard'], 'validate'); const result = await standardSchemaResolver(schema, undefined, { raw: true, })(validData, undefined, { fields, shouldUseNativeValidation, }); expect(validateSpy).toHaveBeenCalledTimes(1); expect(result).toMatchSnapshot(); }); it('should correctly handle path segments that are objects', async () => { const result = await standardSchemaResolver(customSchema)( validData, undefined, { fields, shouldUseNativeValidation, }, ); expect(result).toMatchSnapshot(); }); /** * Type inference tests */ it('should correctly infer the output type from a standardSchema schema', () => { const resolver = standardSchemaResolver(z.object({ id: z.number() })); expectTypeOf(resolver).toEqualTypeOf< Resolver<{ id: number }, unknown, { id: number }> >(); }); it('should correctly infer the output type from a standardSchema schema using a transform', () => { const resolver = standardSchemaResolver( z.object({ id: z.number().transform((val) => String(val)) }), ); expectTypeOf(resolver).toEqualTypeOf< Resolver<{ id: number }, unknown, { id: string }> >(); }); it('should correctly infer the output type from a standardSchema schema when a different input type is specified', () => { const schema = z.object({ id: z.number() }).transform(({ id }) => { return { id: String(id) }; }); const resolver = standardSchemaResolver< { id: number }, any, z.output<typeof schema> >(schema); expectTypeOf(resolver).toEqualTypeOf< Resolver<{ id: number }, any, { id: string }> >(); }); it('should correctly infer the output type from a standardSchema schema for the handleSubmit function in useForm', () => { const schema = z.object({ id: z.number() }); const form = useForm({ resolver: standardSchemaResolver(schema), defaultValues: { id: 3, }, }); expectTypeOf(form.watch('id')).toEqualTypeOf<number>(); expectTypeOf(form.handleSubmit).parameter(0).toEqualTypeOf< SubmitHandler<{ id: number; }> >(); }); it('should correctly infer the output type from a standardSchema schema with a transform for the handleSubmit function in useForm', () => { const schema = z.object({ id: z.number().transform((val) => String(val)) }); const form = useForm({ resolver: standardSchemaResolver(schema), defaultValues: { id: 3, }, }); expectTypeOf(form.watch('id')).toEqualTypeOf<number>(); expectTypeOf(form.handleSubmit).parameter(0).toEqualTypeOf< SubmitHandler<{ id: string; }> >(); }); });