/* Copyright (c) 2000-2006 hamcrest.org
*/
package org.hamcrest.core;
import org.hamcrest.Factory;
import org.hamcrest.Matcher;
/**
* Tests if the argument is a string that contains a substring.
*/
public class StringEndsWith extends SubstringMatcher {
public StringEndsWith(boolean ignoringCase, String substring) { super("ending with", ignoringCase, substring); }
@Override
protected boolean evalSubstringOf(String s) {
return converted(s).endsWith(converted(substring));
}
/**
* Creates a matcher that matches if the examined {@link String} ends with the specified
* {@link String}.
* <p/>
* For example:
* <pre>assertThat("myStringOfNote", endsWith("Note"))</pre>
*
* @param suffix
* the substring that the returned matcher will expect at the end of any examined string
*/
@Factory
public static Matcher<String> endsWith(String suffix) {
return new StringEndsWith(false, suffix);
}
/**
* Creates a matcher that matches if the examined {@link String} ends with the specified
* {@link String}, ignoring case.
* <p/>
* For example:
* <pre>assertThat("myStringOfNote", endsWith("Note"))</pre>
*
* @param suffix
* the substring that the returned matcher will expect at the end of any examined string
*/
@Factory
public static Matcher<String> endsWithIgnoringCase(String suffix) {
return new StringEndsWith(true, suffix);
}
}