Skip to content

Latest commit

 

History

History
230 lines (172 loc) · 6.66 KB

README.md

File metadata and controls

230 lines (172 loc) · 6.66 KB

Validation

A simple and easy-to-use validation utility library.

By Tom Ansill

Motivation

I got tired of manually including null checks, empty array checks, and various kinds of checks against bad input parameters. So I decided to build a library to make things a bit easier for me.

Why not use Objects.requireNonNull(T)?

Objects.requireNonNull(T) will throw NullPointerException and I disagree with this choice of exception because NullPointerException is supposed to be thrown in event of null object being de-referenced. Like:

StringBuilder sb = null;
sb.append("something"); // <-- This will throw NullPointerException because you are trying to de-reference a null object

So, hence the name NullPointerException, you get the exception because you are attempting to de-reference a null value and it blows up on you. I don't believe this is the case here where I want to ensure that parameters that are passed in is not null. I'm not necessarily trying to dereference it. I think IllegalArgumentException is more appropriate exception to best describe the problem.

Prerequisites

  • Java 8 or better

Download

Package Repository

The library is availble for download on Sonatype public Maven repository (https://oss.sonatype.org/#nexus):

<dependency>
  <groupId>com.ansill.validation</groupId>
  <artifactId>validation</artifactId>
  <version>0.2.2</version>
</dependency>

Build

Maven (or other similar build tools) is needed to build and install JavaValidation.

$ git clone https://github.com/tomansill/javavalidation
$ cd javavalidation
$ mvn install

Then include the dependency in your project's pom.xml:

<dependency>
    <groupId>com.ansill.validation</groupId>
    <artifactId>validation</artifactId>
    <version>0.2.2</version>
</dependency>

How to use

Null Checks

Use Validation.assertNonnull(Object) to assert that object is not null:

import com.ansill.validation.Validation;

public class Application{
    public static void main(String[] args){
        String message = null;
        Application application = new Application();
        application.print(message);
    }
    public void print(String message){
        System.out.println(Validation.assertNonnull(message));
    }
}

When you run the code, it will yield this message:

Exception in thread "main" java.lang.IllegalArgumentException: Value is expected to be non-null but is found to be null
	at Application.print(Application.java:9)
	at Application.main(Application.java:7)

Natural Number Checks

Use Validation.assertNaturalNumber(long) to assert that number is a natural number (no negative number or zero):

import com.ansill.validation.Validation;

public class Application{
    public static void main(String[] args){
        Application application = new Application();
        application.setPort(0);
    }
    private int port = 80;
    public void setPort(int port){
        this.port = Validation.assertNaturalNumber(port, "port");
    }
}

When you run the code, it will yield this message:

Exception in thread "main" java.lang.IllegalArgumentException: Value in variable 'port' is expected to be a natural number (1, 2, ..., N-1, N) but it is actually not a natural number
	at Application.setPort(Application.java:9)
	at Application.main(Application.java:6)

Non-Negative Checks

Use Validation.assertNonnegative(long) to assert that number is a positive number:

import com.ansill.validation.Validation;

public class Application{
    public static void main(String[] args){
        Application application = new Application();
        application.add((short) 0, -1);
    }
    public void add(short one, long two){
        Validation.assertNonnegative(one);
        Validation.assertNonnegative(two);
        System.out.println(one + two);
    }
}

When you run the code, it will yield this message:

Exception in thread "main" java.lang.IllegalArgumentException: Value is expected to be non-negative but value is actually a negative number
	at Application.add(Application.java:10)
	at Application.main(Application.java:6)

Non-Empty String Checks

Use Validation.assertNonemptyString(String) to assert that String is non-empty:

import com.ansill.validation.Validation;

public class Application{
    public static void main(String[] args){
        Application application = new Application("");
    }
    public final String name;
    public Application(String name){
        Validation.assertNonemptyString(name, "name");
        this.name = name;
    }
}

When you run the code, it will yield this message:

Exception in thread "main" java.lang.IllegalArgumentException: Value in variable 'name' is expected to be non-empty but value is actually a empty string
	at Application.<init>(Application.java:9)
	at Application.main(Application.java:5)

Non-Empty Array/Collection

Use Validation.assertNonempty(Object[]) or Validation.assertNonempty(Collection) to assert that Array/Collection is non-empty:

import com.ansill.validation.Validation;

import java.util.*;

public class Application{
    public static void main(String[] args){
        Application application = new Application(Collections.emptyList());
    }
    public final Collection hostnames;
    public Application(Collection hostnames){
        Validation.assertNonempty(hostnames);
        this.hostnames = hostnames;
    }
}

When you run the code, it will yield this message:

Exception in thread "main" java.lang.IllegalArgumentException: Value is expected to be non-empty but value is actually empty
	at Application.<init>(Application.java:11)
	at Application.main(Application.java:7)

Array/Collection Member Null Check

Use Validation.assertNonnullElements(Object[]) or Validation.assertNonnullElements(Collection) to assert that Array/Collection does not have null elements:

import com.ansill.validation.Validation;

import java.util.*;

public class Application{
    public static void main(String[] args){
        Application application = new Application(Arrays.asList("google.com", null, "github.com", null, null, "reddit.com"));
    }
    public final Collection hostnames;
    public Application(Collection hostnames){
        Validation.assertNonnullElements(hostnames, false);
        this.hostnames = hostnames;
    }
}

When you run the code, it will yield this message:

Exception in thread "main" java.lang.IllegalArgumentException: Value is expected to have all of its list members to be non-null but the list contains null members. Invalid members are located at indices [1, 3, 4]
	at Application.<init>(Application.java:11)
	at Application.main(Application.java:7)