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

com.seleniumtests.driver.screenshots.ScreenShot Maven / Gradle / Ivy

/**
 * Orignal work: Copyright 2015 www.seleniumtests.com
 * Modified work: Copyright 2016 www.infotel.com
 * 				Copyright 2017-2019 B.Hecquet
 *
 * 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.seleniumtests.driver.screenshots;

import java.awt.image.BufferedImage;
import java.io.File;
import java.io.FileNotFoundException;
import java.io.IOException;
import java.nio.charset.StandardCharsets;
import java.nio.file.Files;
import java.nio.file.Path;
import java.nio.file.Paths;
import java.nio.file.StandardCopyOption;

import com.seleniumtests.customexception.ScenarioException;
import com.seleniumtests.reporter.logger.FileContent;
import com.seleniumtests.util.FileUtility;
import com.seleniumtests.util.HashCodeGenerator;
import org.apache.commons.io.FileExistsException;
import org.apache.commons.io.FileUtils;
import org.apache.logging.log4j.Logger;
import org.json.JSONObject;

import com.seleniumtests.core.SeleniumTestsContextManager;
import com.seleniumtests.util.logging.SeleniumRobotLogger;

/**
 * Represents a screenshot (image + HTML source code when applicable)
 * Files are stored in the output directory of the test
 */
public class ScreenShot {
	
	private static final Logger logger = SeleniumRobotLogger.getLogger(ScreenShot.class);

    private String location;
    private FileContent image;
    private FileContent html;
    private String title;
    private long duration;
    private String outputDirectory;
    
    /**
     * File will be copied in /screenshots/
     * @param imageBuffer
     */
    public ScreenShot(BufferedImage imageBuffer, String pageSource) {
    
        initializeOutputDirectory();
        
        String filename = HashCodeGenerator.getRandomHashCode("web");
        if (imageBuffer != null) {
            Path filePath = Paths.get(outputDirectory, ScreenshotUtil.SCREENSHOT_DIR, filename + ".png");
            FileUtility.writeImage(filePath.toString(), imageBuffer);
            this.image = new FileContent(filePath.toFile());
        }

        if (pageSource != null) {
            try {
                File htmlFile = Paths.get(outputDirectory, ScreenshotUtil.HTML_DIR, filename + ".html").toFile();
                FileUtils.writeStringToFile(htmlFile, pageSource, StandardCharsets.UTF_8);
                html = new FileContent(htmlFile);
            } catch (IOException e) {
                logger.warn("Ex", e);
            }
        }
    }
    
    /**
     * File will be copied in /screenshots/
     * @param imageFile
     */
    public ScreenShot(File imageFile) {
        this(imageFile, null, ScreenshotUtil.SCREENSHOT_DIR);
    }
    public ScreenShot(File imageFile, File htmlFile) {
        this(imageFile, htmlFile, ScreenshotUtil.SCREENSHOT_DIR);
    }
    
    /**
     * File will be copied in //
     * @param imageFile
     */
    public ScreenShot(File imageFile, File htmlFile, String relativePath) {
        
        
    
        initializeOutputDirectory();
    
        // copy the input image file to /screenshots/
        if (imageFile != null && imageFile.exists()) {
            Path filePath = Paths.get(outputDirectory, relativePath, imageFile.getName());
            filePath.getParent().toFile().mkdirs();
            try {
                Files.move(imageFile.toPath(), filePath, StandardCopyOption.REPLACE_EXISTING);
                this.image = new FileContent(filePath.toFile());
            } catch (Exception e) {
                throw new ScenarioException(String.format("Failed to move image file %s to %s: %s", imageFile.getAbsolutePath(), filePath.toFile().getAbsolutePath(), e.getMessage()));
            }
        }
    
        // copy the input HTML file to /htmls/
        if (htmlFile != null && htmlFile.exists()) {
            Path htmlFilePath = Paths.get(outputDirectory, ScreenshotUtil.HTML_DIR, htmlFile.getName());
            htmlFilePath.getParent().toFile().mkdirs();
            try {
                Files.move(htmlFile.toPath(), htmlFilePath, StandardCopyOption.REPLACE_EXISTING);
                this.html = new FileContent(htmlFilePath.toFile());
            } catch (Exception e) {
                throw new ScenarioException(String.format("Failed to move html file %s to %s: %s", htmlFile.getAbsolutePath(), htmlFilePath.toFile().getAbsolutePath(), e.getMessage()));
            }
        }
    
        this.duration = 0;
    }
    
    private void initializeOutputDirectory() {
        if (SeleniumTestsContextManager.getGlobalContext().getTestNGContext() != null) {
            outputDirectory = SeleniumTestsContextManager.getThreadContext().getOutputDirectory();
        } else {
            throw new ScenarioException("Cannot create a screenshot outside of a test");
        }
    }

    public String getOutputDirectory() {
        return outputDirectory;
    }
    
    /**
     * For test
     * @param outputDirectory
     */
    public void setOutputDirectory(String outputDirectory) {
        this.outputDirectory = outputDirectory;
    }

    /**
     * URL of the page for which this screenshot has been taken
     * @return
     */
    public String getLocation() {
        return location;
    }
    
    public String getImageName() {
    	if (image != null) {
    		return image.getFile().getName();
    	} else {
    		return "";
    	}
    }

    public void setLocation(String location) {
        this.location = location;
    }
    
    /**
     * Returns the relative path of HTML file (relative to outputDirectory)
     * @return
     */
    public String getHtmlSourcePath() {
        if (html != null) {
            return Paths.get(outputDirectory).relativize(Paths.get(html.getFile().getAbsolutePath())).toString().replace("\\", "/");
        } else {
            return null;
        }
        
    }

    /**
     * Get the image path relative to outputDirectory (directory where info for a specific test are recorded)
     * @return
     */
    public String getImagePath() {
        if (image != null) {
            return Paths.get(outputDirectory).relativize(Paths.get(image.getFile().getAbsolutePath())).toString().replace("\\", "/");
        } else {
            return null;
        }
    }

    /**
     * Get the title of the page associated to this screenshot
     * @return
     */
    public String getTitle() {
        return title;
    }

    public void setTitle(final String title) {
        this.title = title;
    }

    @Override
    public String toString() {
        return "|APPLICATION URL:" + this.location + "|PAGE TITLE:" + this.title
                + "|PAGE HTML SOURCE:" + this.getHtmlSourcePath() + "|PAGE IMAGE:" + this.getImagePath();
    }

	public long getDuration() {
		return duration;
	}

	public void setDuration(long duration) {
		this.duration = duration;
	}
	
	/**
	 * Move physically the image to 'destOutputDirectory'
	 * @param destOutputDirectory		the output directory to copy to. It's a root directory where test results / image / html / video are stored
	 * @throws IOException
	 */
	public void relocate(String destOutputDirectory) throws IOException {
		relocate(destOutputDirectory, getImagePath(), getHtmlSourcePath());
	}
	
	/**
	 * Move physically the image to 'destOutputDirectory'
	 * @param destOutputDirectory		the output directory to copy to. It's a root directory where test results / image / html / video are stored
	 * @param newImagePath				the new path of the image if it needs to be moved inside the output directory
     * @param newHtmlPath               the new path of the html if it needs to be moved inside the output directory
	 * @throws IOException
	 */
	public void relocate(String destOutputDirectory, String newImagePath, String newHtmlPath) throws IOException {

		if (html != null) {
		    html.relocate(destOutputDirectory, newHtmlPath);
		}
		
		if (image != null) {
			image.relocate(destOutputDirectory, newImagePath);
		}
		
		outputDirectory = destOutputDirectory;
		
	}
	
	public FileContent getImage() {
	    return image;
    }
    
    public FileContent getHtml() {
	    return html;
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy