com.google.common.truth.ComparableSubject Maven / Gradle / Ivy
/*
* 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 super T>`
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