Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

IsNumber throws error when first argument is not correctly set (null instead of {}) #2571

Open
BUONJG opened this issue Jan 10, 2025 · 1 comment

Comments

@BUONJG
Copy link

BUONJG commented Jan 10, 2025

Hello,

This week, one of my team member lost time debugging because he had an error due to wrong usage of IsNumber

On an array of numbers property he put the validator:

  • @IsNumber(null, { each: true })

When the first argument is supposed to be an object:

  • @IsNumber({}, { each: true })

Is there a way to make sure the validator does not throw an error in that case?

The issue is on the line 31: if (options.maxDecimalPlaces !== undefined)

Thank you

@AbbasSrour
Copy link

AbbasSrour commented Jan 18, 2025

Yeah this is due to js considering null a valid value and instead of providing {} it is providing null, we can do something like this, happy to open a PR with it

export function IsNumber(options: IsNumberOptions = {}, validationOptions?: ValidationOptions): PropertyDecorator {
  return ValidateBy(
    {
      name: IS_NUMBER,
      constraints: [getValidationOptions(options)],
      validator: {
        validate: (value, args): boolean => isNumber(value, args?.constraints[0]),
        defaultMessage: buildMessage(
          eachPrefix => eachPrefix + '$property must be a number conforming to the specified constraints',
          validationOptions
        ),
      },
    },
    validationOptions
  );
}
const getDecoratorOptions = <T>(decoratorOptions: T) => {
  if (!decoratorOptions) {
    return {} as T;
  }

  return decoratorOptions;
}
import { IsNumber, Validator } from '../../src';

const validator = new Validator();

describe('typechecker validation', () => {
  it('should not throw on error when null is provided', () => {
    class MyClass {
      @IsNumber(null, { each: true })
      someNumber: number;

      constructor(someNumber: number) {
        this.someNumber = someNumber;
      }
    }

    const model = new MyClass(9);

    return validator.validate(model).then(errors => {
      expect(errors.length).toEqual(0);
    });
  });
});
```

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Development

No branches or pull requests

2 participants