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

ee.jakarta.tck.ws.rs.common.webclient.Goldenfile Maven / Gradle / Ivy

/*
 * Copyright (c) 2007, 2021 Oracle and/or its affiliates. All rights reserved.
 *
 * This program and the accompanying materials are made available under the
 * terms of the Eclipse Public License v. 2.0, which is available at
 * http://www.eclipse.org/legal/epl-2.0.
 *
 * This Source Code may also be made available under the following Secondary
 * Licenses when the conditions for such availability set forth in the
 * Eclipse Public License v. 2.0 are satisfied: GNU General Public License,
 * version 2 with the GNU Classpath Exception, which is available at
 * https://www.gnu.org/software/classpath/license.html.
 *
 * SPDX-License-Identifier: EPL-2.0 OR GPL-2.0 WITH Classpath-exception-2.0
 */

/*
 * $Id$
 */

package ee.jakarta.tck.ws.rs.common.webclient;

import java.io.ByteArrayInputStream;
import java.io.File;
import java.io.FileInputStream;
import java.io.IOException;
import java.io.InputStream;

import ee.jakarta.tck.ws.rs.lib.util.TestUtil;

/**
 * A representation of a Goldenfile that may be used by a particular test case.
 */

public class Goldenfile {

  /*
   * Message to be returned if the goldenfile cannot be located.
   */
  private static final byte[] NOTFOUND = "NO GOLDENFILE FOUND".getBytes();

  /*
   * Message to be returned if the goldenfile doesn't have read permissions.
   */
  private static final byte[] NOPERM = "INSUFFICIENT PERMISSIONS".getBytes();

  /*
   * Goldenfile represented by this object.
   */
  private File _file = null;

  /*
   * Error message to return by public methods if the file is not found or the
   * user has insufficient permissions.
   */
  private byte[] _errMessage = null;

  /*
   * Goldenfile length
   */
  private long _length = 0L;

  /*
   * Encoding
   */
  private String _encoding = null;

  /**
   * Creates a new GoldenFile based on the fully qualified filename provided.
   *
   * @param path
   *          Fully qualified file name
   * @param encoding
   *          to use when reading the goldenfile
   */
  public Goldenfile(String path, String encoding) {
    _file = new File(path);
    if (!_file.exists()) {
      TestUtil.logTrace("[GoldenFile] Goldenfile: " + path + ", not found!");
      _errMessage = NOTFOUND;
      _file = null;
    } else if (!_file.canRead()) {
      _errMessage = NOPERM;
      _file = null;
    } else {
      _length = _file.length();
      _encoding = encoding;
    }
  }

  /*
   * public methods
   * ========================================================================
   */

  /**
   * Returns the length of the Goldenfile.
   *
   * @return long length
   */
  public long getLength() {
    return _length;
  }

  /**
   * Returns the byte content of the specified goldenfile using the charset
   * encoding specified in the response from the server.
   *
   * @return the goldenfile as a byte array
   * @throws IOException
   *           if an error occurs processing the file.
   */
  public byte[] getGoldenFileAsBytes() throws IOException {
    if (_file != null) {
      return getGoldenFileAsString().getBytes();
    } else {
      return _errMessage;
    }
  }

  /**
   * Retuns a string representation of the specified goldenfile using the
   * charset encoding specified in the response from the server.
   *
   * @return the goldenfile as a String.
   * @throws IOException
   *           if an error occurs processing the file.
   */
  public String getGoldenFileAsString() throws IOException {
    String gf = null;
    if (_file != null) {
      TestUtil.logTrace(
          "[Goldenfile] Loading goldenfile using " + "encoding: " + _encoding);
      FileInputStream in = new FileInputStream(_file);
      gf = Util.getEncodedStringFromStream(in, _encoding);
      in.close();
    } else {
      gf = new String(_errMessage);
    }
    return gf;
  }

  /**
   * Returns the goldenfile as an InputStream using the charset encoding
   * specified in the response from the server.
   *
   * @return goldenfile as an InputStream
   * @throws IOException
   *           If an error occurs processing the file.
   */
  public InputStream getGoldenFileAsStream() throws IOException {
    if (_file != null) {
      return new ByteArrayInputStream(getGoldenFileAsBytes());
    } else {
      return new ByteArrayInputStream(_errMessage);
    }
  }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy