FileAssertion.java

46 lines | 1.256 kB Blame History Raw Download
package azkaban.fixture;

import static org.assertj.core.api.Assertions.assertThat;

import java.io.IOException;
import java.nio.charset.StandardCharsets;
import java.nio.file.Files;
import java.nio.file.Paths;


/**
 * The type File assertion.
 */
public class FileAssertion {

  /**
   * Assert the given string equals the given file's content.
   *
   * The white space differences are ignored.
   *
   * @param expectedFilePath the expected file path
   * @param actual the actual string
   * @throws IOException the io exception
   */
  public static void assertStringEqualFileContent(final String expectedFilePath,
      final String actual)
      throws IOException {
    final String expected = new String(Files.readAllBytes(Paths.get(expectedFilePath)),
        StandardCharsets.UTF_8);
    assertThat(actual).isEqualToIgnoringWhitespace(expected);
  }

  /**
   * Return the html based content surrounded with the HTML tag.
   *
   * This is useful to compare a fragment of HTML content with a proper expected HTML file so that
   * the expected file can be viewed more easily with a browser.
   *
   * @param content the content
   * @return string
   */
  public static String surroundWithHtmlTag(final String content) {
    return "<html>\n" + content + "</html>\n";
  }
}