All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.google.common.truth.ComparableSubject Maven / Gradle / Ivy

There is a newer version: 1.4.4
Show newest version
/*
 * Copyright (c) 2014 Google, Inc.
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 * http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
package com.google.common.truth;

import static com.google.common.base.Preconditions.checkNotNull;

import com.google.common.collect.Range;
import org.checkerframework.checker.nullness.qual.Nullable;

/**
 * Propositions for {@link Comparable} typed subjects.
 *
 * @author Kurt Alfred Kluever
 * @param  the type of the object being tested by this {@code ComparableSubject}
 */
// TODO(b/136040841): Consider further tightening this to the proper `extends Comparable`
public abstract class ComparableSubject> extends Subject {
  /**
   * Constructor for use by subclasses. If you want to create an instance of this class itself, call
   * {@link Subject#check(String, Object...) check(...)}{@code .that(actual)}.
   */
  private final @Nullable T actual;

  protected ComparableSubject(FailureMetadata metadata, @Nullable T actual) {
    super(metadata, actual);
    this.actual = actual;
  }

  /** Checks that the subject is in {@code range}. */
  public final void isIn(Range range) {
    if (!range.contains(checkNotNull(actual))) {
      failWithActual("expected to be in range", range);
    }
  }

  /** Checks that the subject is not in {@code range}. */
  public final void isNotIn(Range range) {
    if (range.contains(checkNotNull(actual))) {
      failWithActual("expected not to be in range", range);
    }
  }

  /**
   * Checks that the subject is equivalent to {@code other} according to {@link
   * Comparable#compareTo}, (i.e., checks that {@code a.comparesTo(b) == 0}).
   *
   * 

Note: Do not use this method for checking object equality. Instead, use {@link * #isEqualTo(Object)}. */ @SuppressWarnings("unchecked") public void isEquivalentAccordingToCompareTo(@Nullable T expected) { if (checkNotNull((Comparable) actual).compareTo(checkNotNull(expected)) != 0) { failWithActual("expected value that sorts equal to", expected); } } /** * Checks that the subject is greater than {@code other}. * *

To check that the subject is greater than or equal to {@code other}, use {@link * #isAtLeast}. */ @SuppressWarnings("unchecked") public final void isGreaterThan(@Nullable T other) { if (checkNotNull((Comparable) actual).compareTo(checkNotNull(other)) <= 0) { failWithActual("expected to be greater than", other); } } /** * Checks that the subject is less than {@code other}. * *

To check that the subject is less than or equal to {@code other}, use {@link * #isAtMost}. */ @SuppressWarnings("unchecked") public final void isLessThan(@Nullable T other) { if (checkNotNull((Comparable) actual).compareTo(checkNotNull(other)) >= 0) { failWithActual("expected to be less than", other); } } /** * Checks that the subject is less than or equal to {@code other}. * *

To check that the subject is strictly less than {@code other}, use {@link * #isLessThan}. */ @SuppressWarnings("unchecked") public final void isAtMost(@Nullable T other) { if (checkNotNull((Comparable) actual).compareTo(checkNotNull(other)) > 0) { failWithActual("expected to be at most", other); } } /** * Checks that the subject is greater than or equal to {@code other}. * *

To check that the subject is strictly greater than {@code other}, use {@link * #isGreaterThan}. */ @SuppressWarnings("unchecked") public final void isAtLeast(@Nullable T other) { if (checkNotNull((Comparable) actual).compareTo(checkNotNull(other)) < 0) { failWithActual("expected to be at least", other); } } }